index.js 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  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. showName: "tag", //显示字段
  144. valueKey: "tag", //返回Key
  145. selectKey: "tag", //传参 代表选着字段 不传参返回整个选择对象
  146. value: "", //选中值
  147. list: await getTypes('tags')
  148. }]
  149. this.setData({
  150. filtratelist
  151. })
  152. },
  153. /* 处理筛选 */
  154. handleFilter({
  155. detail
  156. }) {
  157. detail.condition = this.data.content.where.condition;
  158. this.data.content.where = detail;
  159. this.getList(true);
  160. },
  161. getList(init = false) {
  162. //init 用于初始化分页
  163. if (init.detail != undefined) init = init.detail;
  164. if (init) this.setData({
  165. ['content.pageNumber']: 1
  166. })
  167. if (this.data.content.pageNumber > this.data.content.pageTotal) return;
  168. console.log(this.data.content)
  169. _Http.basic({
  170. "id": 20221012164402,
  171. content: this.data.content
  172. }).then(res => {
  173. console.log("客户列表", res)
  174. this.selectComponent('#ListBox').RefreshToComplete();
  175. if (res.msg != '成功') return wx.showToast({
  176. title: res.msg,
  177. icon: "none"
  178. })
  179. this.setData({
  180. loading: false,
  181. 'content.pageNumber': res.pageNumber + 1,
  182. 'content.pageTotal': res.pageTotal,
  183. 'content.total': res.total,
  184. 'content.sort': res.sort,
  185. list: res.pageNumber == 1 ? res.data : this.data.list.concat(res.data)
  186. })
  187. this.getTags();
  188. })
  189. },
  190. /* 获取列表标签 */
  191. getTags() {
  192. let list = this.data.list,
  193. ownerids = list.map(v => v.sa_customersid)
  194. _Http.basic({
  195. "id": 20221018102001,
  196. "content": {
  197. "ownertable": "sa_customers",
  198. ownerids
  199. }
  200. }).then(res => {
  201. for (let key in res.data) {
  202. let index = list.findIndex(v => v.sa_customersid == key);
  203. list[index].tags = res.data[key]
  204. };
  205. this.setData({
  206. list
  207. })
  208. })
  209. },
  210. /* 顶部条件导航回调 */
  211. navClick({
  212. detail
  213. }) {
  214. switch (detail.id) {
  215. case '1':
  216. this.setData({
  217. classShow: true
  218. })
  219. break;
  220. case '2':
  221. this.setData({
  222. 'filterShow': true
  223. })
  224. break;
  225. case '3':
  226. this.setData({
  227. 'content.sort[0].reversed': this.data.content.sort[0].reversed == 0 ? 1 : 0
  228. });
  229. this.getList(true)
  230. break;
  231. default:
  232. break;
  233. }
  234. },
  235. /* 处理搜索 */
  236. onSearch({
  237. detail
  238. }) {
  239. this.data.content.where.condition = detail;
  240. this.getList(true);
  241. },
  242. classClose() {
  243. this.setData({
  244. classShow: false
  245. })
  246. },
  247. classSelect({
  248. detail
  249. }) {
  250. if (this.data.content.type == detail.index) return this.classClose();
  251. this.setData({
  252. "content.type": detail.index,
  253. 'navList[0].label': detail.name
  254. })
  255. this.classClose();
  256. this.getList(true)
  257. },
  258. onReady() {
  259. this.selectComponent("#ListBox").setHeight(".total", this);
  260. },
  261. onShareAppMessage() {}
  262. })