index.js 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. const _Http = getApp().globalData.http;
  2. import {
  3. getTypes
  4. } from "./modules/query";
  5. Page({
  6. data: {
  7. loading: true,
  8. navList: [{
  9. label: "我负责的",
  10. icon: "icon-webxialaxuanxiangjiantou",
  11. color: "",
  12. width: "",
  13. id: "1"
  14. }, {
  15. label: "排序",
  16. icon: "icon-jiangxu1",
  17. color: "",
  18. width: "",
  19. id: "sort"
  20. }, {
  21. label: "筛选",
  22. icon: "icon-shaixuan",
  23. color: "",
  24. width: "",
  25. id: "2"
  26. }],
  27. content: {
  28. isend: 0,
  29. nocache: true,
  30. "type": 1,
  31. deleted: 0,
  32. "pageNumber": 1,
  33. "pageSize": 20,
  34. "isExport": 0,
  35. "where": {},
  36. "sort": [{
  37. sortname: "默认",
  38. sorted: 1,
  39. sortid: 67,
  40. reversed: 0
  41. }]
  42. },
  43. list: [],
  44. classShow: false, //type类型
  45. },
  46. /* 去添加 */
  47. toAdd() {
  48. wx.navigateTo({
  49. url: './addAndEditor'
  50. })
  51. },
  52. async onLoad(options) {
  53. this.setData({
  54. insert: wx.getStorageSync('auth').wCustomer.options.some(v => v == 'insert'), //查询新增权限
  55. classActions: wx.getStorageSync('templetList').map(v => {
  56. return {
  57. name: v.templetname,
  58. index: v.templetid
  59. }
  60. }),
  61. 'navList[0].label': wx.getStorageSync('templetList')[0].templetname,
  62. "content.type": wx.getStorageSync('templetList')[0].templetid,
  63. });
  64. this.getList()
  65. let filtratelist = [{
  66. label: "部门",
  67. index: null,
  68. showName: "depname", //显示字段
  69. valueKey: "departmentid", //返回Key
  70. selectKey: "departmentid", //传参 代表选着字段 不传参返回整个选择对象
  71. value: "", //选中值
  72. type: 'multilevelClass',
  73. list: await _Http.basic({
  74. "id": 20230620102004,
  75. "content": {},
  76. }).then(res => {
  77. console.log("获取部门", res)
  78. return res.data.dep
  79. })
  80. }, {
  81. label: "客户类型",
  82. index: null,
  83. showName: "value", //显示字段
  84. valueKey: "type", //返回Key
  85. selectKey: "value", //传参 代表选着字段 不传参返回整个选择对象
  86. value: "", //选中值
  87. list: await getTypes('customertypemx')
  88. }, {
  89. label: "客户分类",
  90. index: null,
  91. showName: "value", //显示字段
  92. valueKey: "customergrade", //返回Key
  93. selectKey: "value", //传参 代表选着字段 不传参返回整个选择对象
  94. value: "", //选中值
  95. list: await getTypes('customergrade')
  96. }, {
  97. label: "客户等级",
  98. index: null,
  99. showName: "value", //显示字段
  100. valueKey: "grade", //返回Key
  101. selectKey: "value", //传参 代表选着字段 不传参返回整个选择对象
  102. value: "", //选中值
  103. list: await getTypes('agentgrade')
  104. }, {
  105. label: "所属行业",
  106. index: null,
  107. showName: "value", //显示字段
  108. valueKey: "industry", //返回Key
  109. selectKey: "value", //传参 代表选着字段 不传参返回整个选择对象
  110. value: "", //选中值
  111. list: await getTypes('industry')
  112. }, {
  113. label: "合作状态",
  114. index: null,
  115. showName: "value", //显示字段
  116. valueKey: "status", //返回Key
  117. selectKey: "value", //传参 代表选着字段 不传参返回整个选择对象
  118. value: "", //选中值
  119. list: [{
  120. value: "潜在"
  121. }, {
  122. value: "合作中"
  123. }, {
  124. value: "已终止"
  125. }]
  126. }, {
  127. label: "成交状态",
  128. index: null,
  129. showName: "value", //显示字段
  130. valueKey: "tradingstatus", //返回Key
  131. selectKey: "value", //传参 代表选着字段 不传参返回整个选择对象
  132. value: "", //选中值
  133. list: [{
  134. value: "未成交"
  135. }, {
  136. value: "已成交"
  137. }, {
  138. value: "多次成交"
  139. }]
  140. }, {
  141. label: "标签",
  142. index: null,
  143. type: "checkbox",
  144. showName: "tag", //显示字段
  145. valueKey: "tag", //返回Key
  146. selectKey: "tag", //传参 代表选着字段 不传参返回整个选择对象
  147. value: "", //选中值
  148. list: await getTypes('tags')
  149. }]
  150. this.setData({
  151. filtratelist
  152. })
  153. },
  154. /* 处理筛选 */
  155. handleFilter({
  156. detail
  157. }) {
  158. detail.condition = this.data.content.where.condition;
  159. this.data.content.where = detail;
  160. this.getList(true);
  161. },
  162. getList(init = false) {
  163. //init 用于初始化分页
  164. if (init.detail != undefined) init = init.detail;
  165. if (init) this.setData({
  166. ['content.pageNumber']: 1
  167. })
  168. if (this.data.content.pageNumber > this.data.content.pageTotal) return;
  169. console.log(this.data.content)
  170. _Http.basic({
  171. "id": 20221012164402,
  172. content: this.data.content
  173. }).then(res => {
  174. console.log("客户列表", res)
  175. this.selectComponent('#ListBox').RefreshToComplete();
  176. if (res.msg != '成功') return wx.showToast({
  177. title: res.msg,
  178. icon: "none"
  179. })
  180. this.setData({
  181. loading: false,
  182. 'content.pageNumber': res.pageNumber + 1,
  183. 'content.pageTotal': res.pageTotal,
  184. 'content.total': res.total,
  185. 'content.sort': res.sort,
  186. list: res.pageNumber == 1 ? res.data : this.data.list.concat(res.data)
  187. })
  188. this.getTags();
  189. })
  190. },
  191. /* 获取列表标签 */
  192. getTags() {
  193. let list = this.data.list,
  194. ownerids = list.map(v => v.sa_customersid)
  195. _Http.basic({
  196. "id": 20221018102001,
  197. "content": {
  198. "ownertable": "sa_customers",
  199. ownerids
  200. }
  201. }).then(res => {
  202. for (let key in res.data) {
  203. let index = list.findIndex(v => v.sa_customersid == key);
  204. list[index].tags = res.data[key]
  205. };
  206. this.setData({
  207. list
  208. })
  209. })
  210. },
  211. /* 顶部条件导航回调 */
  212. navClick({
  213. detail
  214. }) {
  215. switch (detail.id) {
  216. case '1':
  217. this.setData({
  218. classShow: true
  219. })
  220. break;
  221. case '2':
  222. this.setData({
  223. 'filterShow': true
  224. })
  225. break;
  226. case '3':
  227. this.setData({
  228. 'content.sort[0].reversed': this.data.content.sort[0].reversed == 0 ? 1 : 0
  229. });
  230. this.getList(true)
  231. break;
  232. default:
  233. break;
  234. }
  235. },
  236. /* 处理搜索 */
  237. onSearch({
  238. detail
  239. }) {
  240. this.data.content.where.condition = detail;
  241. this.getList(true);
  242. },
  243. classClose() {
  244. this.setData({
  245. classShow: false
  246. })
  247. },
  248. classSelect({
  249. detail
  250. }) {
  251. if (this.data.content.type == detail.index) return this.classClose();
  252. this.setData({
  253. "content.type": detail.index,
  254. 'navList[0].label': detail.name
  255. })
  256. this.classClose();
  257. this.getList(true)
  258. },
  259. onReady() {
  260. this.selectComponent("#ListBox").setHeight(".total", this);
  261. },
  262. onShareAppMessage() {}
  263. })