list.vue 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <template>
  2. <view class="content">
  3. <view class="head">
  4. <span class="title">项目列表</span>
  5. <span class="self">
  6. <uni-data-checkbox
  7. multiple
  8. v-model="checkself"
  9. :localdata="self"
  10. @change="checkSelf()"
  11. ></uni-data-checkbox>
  12. </span>
  13. </view>
  14. <view class="list">
  15. <view
  16. class="project"
  17. v-for="project in projectList"
  18. :key="project.id"
  19. @click="onClickProject(project)"
  20. >
  21. {{ `${project.project_name}(${project.project_full_code})` }}
  22. </view>
  23. </view>
  24. <uni-fab
  25. :horizontal="'right'"
  26. :popMenu="false"
  27. @fabClick="onClickAdd()"
  28. ></uni-fab>
  29. </view>
  30. </template>
  31. <script>
  32. import { queryProject } from "@/services/project";
  33. import { mapState } from "vuex";
  34. export default {
  35. computed: {
  36. ...mapState(["currentProject"]),
  37. },
  38. data() {
  39. return {
  40. checkself: [],
  41. projectList: [],
  42. projectFilter: { pageSize: 99999 },
  43. self: [{ text: "只看自己", value: 0 }],
  44. };
  45. },
  46. onShow() {
  47. this.getProject();
  48. },
  49. methods: {
  50. async getProject() {
  51. let res = {};
  52. res = await queryProject(this.projectFilter);
  53. this.projectList = res.data.list;
  54. },
  55. async onClickProject(project) {
  56. await this.$store.commit("setCurrentProject", project);
  57. uni.navigateTo({
  58. url: `./detail?id=${project.id}`,
  59. });
  60. },
  61. checkSelf() {
  62. this.projectFilter = {
  63. ...this.projectFilter,
  64. filter_type: this.checkself.length,
  65. };
  66. this.getProject();
  67. },
  68. onClickAdd() {
  69. uni.navigateTo({
  70. url: "./add",
  71. });
  72. },
  73. },
  74. };
  75. </script>
  76. <style lang="less" scoped>
  77. .content {
  78. display: flex;
  79. justify-content: center;
  80. flex-wrap: wrap;
  81. }
  82. .head {
  83. width: 100%;
  84. padding: 0 20px 20px 20px;
  85. position: fixed;
  86. background: #f8f8f8;
  87. display: flex;
  88. justify-content: space-between;
  89. align-items: center;
  90. .title {
  91. font: 24px bold;
  92. }
  93. .self {
  94. font: 16px;
  95. }
  96. }
  97. .list {
  98. width: 90%;
  99. margin-top: 60px;
  100. border-top: 2px solid gray;
  101. }
  102. .project {
  103. border-bottom: 2px solid gray;
  104. padding: 20px 0px;
  105. font-size: 18px;
  106. }
  107. </style>