index.js 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. const _Http = getApp().globalData.http;
  2. Page({
  3. data: {
  4. list: [],
  5. filtrate: false,
  6. navList: [{
  7. label: "我负责的",
  8. icon: "icon-webxialaxuanxiangjiantou",
  9. color: "",
  10. width: "",
  11. id: "1"
  12. }, {
  13. label: "排序",
  14. icon: "icon-jiangxu1",
  15. color: "",
  16. width: "",
  17. id: "sort"
  18. }, {
  19. label: "筛选",
  20. icon: "icon-shaixuan",
  21. color: "",
  22. width: "",
  23. id: "2"
  24. }],
  25. classActions: [{
  26. name: '我负责的',
  27. index: 1
  28. },
  29. {
  30. name: '我参与的',
  31. index: 2
  32. },
  33. {
  34. name: '我创建的',
  35. index: 5
  36. },
  37. {
  38. name: "我下属负责的",
  39. index: 3
  40. }, {
  41. name: "我下属参与的",
  42. index: 4
  43. }
  44. ],
  45. content: {
  46. nocache: true,
  47. "pageNumber": 1,
  48. "pageSize": 20,
  49. "isExport": 0,
  50. "type": 1,
  51. "where": {
  52. "condition": "",
  53. "startdate": "",
  54. "enddate": ""
  55. },
  56. "sort": []
  57. },
  58. classShow: false, //type类型
  59. filtratelist: [{
  60. label: "任务状态",
  61. index: null,
  62. showName: "name", //显示字段
  63. valueKey: "status", //返回Key
  64. selectKey: "name", //传参 代表选着字段 不传参返回整个选择对象
  65. value: "", //选中值
  66. list: [{
  67. name: "待执行"
  68. }, {
  69. name: "进行中"
  70. }, {
  71. name: "已完成"
  72. }]
  73. }]
  74. },
  75. /* 导航点击功能 */
  76. navOnClick({
  77. detail
  78. }) {
  79. if (detail.label == '筛选') {
  80. this.setData({
  81. filtrate: true
  82. })
  83. } else if (detail.id == 1) {
  84. this.setData({
  85. classShow: true
  86. })
  87. }
  88. },
  89. /* 处理筛选 */
  90. handleFilter(e) {
  91. this.data.content.where.status = e.detail.status || "";
  92. this.getList(true)
  93. },
  94. /* 去添加 */
  95. toAdd() {
  96. wx.navigateTo({
  97. url: './add'
  98. })
  99. },
  100. onLoad(options) {
  101. this.getList()
  102. },
  103. /* 筛选状态选择 */
  104. selectStatus(e) {
  105. const {
  106. item
  107. } = e.currentTarget.dataset;
  108. this.setData({
  109. "filter.statusActive": this.data.filter.statusActive == item ? "" : item
  110. })
  111. },
  112. /* 筛选日期范围 */
  113. changeDate(e) {
  114. const name = e.currentTarget.dataset.name,
  115. value = e.detail.value;
  116. this.setData({
  117. [`filter.${name}`]: value
  118. })
  119. },
  120. getList(init = false) {
  121. //init 用于初始化分页
  122. if (init.detail != undefined) init = init.detail;
  123. let content = this.data.content;
  124. if (init) content.pageNumber = 1;
  125. if (content.pageNumber > content.pageTotal) return;
  126. _Http.basic({
  127. "id": 20220901162901,
  128. content
  129. }).then(res => {
  130. console.log("任务列表", res)
  131. this.selectComponent('#ListBox').RefreshToComplete();
  132. if (res.msg != '成功') return wx.showToast({
  133. title: res.data,
  134. icon: "none"
  135. })
  136. this.setData({
  137. 'content.pageNumber': res.pageNumber + 1,
  138. 'content.pageTotal': res.pageTotal,
  139. 'content.total': res.total,
  140. 'content.sort': res.sort,
  141. list: res.pageNumber == 1 ? res.data : this.data.list.concat(res.data)
  142. })
  143. this.getTags();
  144. })
  145. },
  146. /* 获取列表标签 */
  147. getTags() {
  148. let list = this.data.list,
  149. ownerids = list.map(v => v.sys_taskid)
  150. _Http.basic({
  151. "id": 20221018102001,
  152. "content": {
  153. "ownertable": "sys_task",
  154. ownerids
  155. }
  156. }).then(res => {
  157. for (let key in res.data) {
  158. let index = list.findIndex(v => v.sys_taskid == key);
  159. list[index].tags = res.data[key]
  160. };
  161. this.setData({
  162. list
  163. })
  164. })
  165. },
  166. /* 顶部条件导航回调 */
  167. navClick({
  168. detail
  169. }) {
  170. switch (detail.id) {
  171. case '1':
  172. this.setData({
  173. classShow: true
  174. })
  175. break;
  176. case '2':
  177. this.setData({
  178. 'filter.show': true
  179. })
  180. break;
  181. case '3':
  182. this.setData({
  183. 'content.sort[0].reversed': this.data.content.sort[0].reversed == 0 ? 1 : 0
  184. });
  185. this.getList(true)
  186. break;
  187. default:
  188. break;
  189. }
  190. },
  191. /* 处理搜索 */
  192. onSearch({
  193. detail
  194. }) {
  195. this.setData({
  196. "content.where.condition": detail
  197. });
  198. this.getList(true);
  199. },
  200. classClose() {
  201. this.setData({
  202. classShow: false
  203. })
  204. },
  205. classSelect({
  206. detail
  207. }) {
  208. if (this.data.content.type == detail.index) return this.classClose();
  209. this.setData({
  210. "content.type": detail.index,
  211. 'navList[0].label': detail.name
  212. })
  213. this.classClose();
  214. this.getList(true)
  215. },
  216. onReady() {
  217. this.selectComponent("#ListBox").setHeight(".total", this);
  218. },
  219. onShareAppMessage() {}
  220. })