index.js 7.4 KB

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