index.js 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. const _Http = getApp().globalData.http;
  2. Page({
  3. /**
  4. * 页面的初始数据
  5. */
  6. data: {
  7. loading: true,
  8. typeList: [{
  9. name: '客户报价',
  10. index: 0
  11. }, {
  12. name: '项目报价',
  13. index: 1
  14. }],
  15. typeShow: false,
  16. navList: [{
  17. label: "我负责的",
  18. icon: "icon-webxialaxuanxiangjiantou",
  19. color: "",
  20. width: "",
  21. id: "1"
  22. }, {
  23. label: "排序",
  24. icon: "icon-jiangxu1",
  25. color: "",
  26. width: "",
  27. id: "sort"
  28. }, {
  29. label: "筛选",
  30. icon: "icon-shaixuan",
  31. color: "",
  32. width: "",
  33. id: "2"
  34. }],
  35. classShow: false,
  36. content: {
  37. "nocache": true,
  38. deleted: 0,
  39. "type": 1,
  40. "version": 1,
  41. "pageNumber": 1,
  42. "pageSize": 20,
  43. "where": {
  44. "condition": "",
  45. "startdate": "",
  46. "enddate": "",
  47. "status": "",
  48. },
  49. "sort": []
  50. },
  51. filter: {
  52. show: false,
  53. type: ['客户报价', '项目报价'], //状态项
  54. typeActive: "",
  55. status: ['新建', '提交', '审核', "复核"], //状态项
  56. statusActive: "",
  57. startdate: "",
  58. enddate: ""
  59. }
  60. },
  61. onLoad(options) {
  62. this.setData({
  63. insert: wx.getStorageSync('auth').woffer.options.some(v => v == 'insert'), //查询新增权限
  64. classActions: wx.getStorageSync('templetList').map(v => {
  65. return {
  66. name: v.templetname,
  67. index: v.templetid
  68. }
  69. }),
  70. 'navList[0].label': wx.getStorageSync('templetList')[0].templetname,
  71. "content.type": wx.getStorageSync('templetList')[0].templetid,
  72. });
  73. this.getList();
  74. },
  75. /* 获取列表 */
  76. getList(init = false, data) {
  77. if (init.detail != undefined) init = init.detail;
  78. let content = this.data.content;
  79. if (init) content.pageNumber = 1;
  80. if (content.pageNumber > content.pageTotal) return;
  81. if (data) {
  82. content.where.status = data.statusActive;
  83. content.where.startdate = data.startdate;
  84. content.where.enddate = data.enddate;
  85. content.where.isproject = data.typeActive;
  86. }
  87. _Http.basic({
  88. "id": 20221020165103,
  89. content
  90. }).then(res => {
  91. console.log("报价单列表", res)
  92. this.selectComponent('#ListBox').RefreshToComplete();
  93. if (res.msg != '成功') return wx.showToast({
  94. title: res.msg,
  95. icon: "none"
  96. })
  97. res.data = res.data.map(v => {
  98. v.progress = v.stage / v.totalstage * 100;
  99. return v
  100. })
  101. this.setData({
  102. loading: false,
  103. 'content.pageNumber': res.pageNumber + 1,
  104. 'content.pageTotal': res.pageTotal,
  105. 'content.total': res.total,
  106. 'content.sort': res.sort,
  107. list: res.pageNumber == 1 ? res.data : this.data.list.concat(res.data)
  108. });
  109. this.setListHeight();
  110. this.getTags();
  111. })
  112. },
  113. /* 处理搜索 */
  114. onSearch({
  115. detail
  116. }) {
  117. this.setData({
  118. "content.where.condition": detail
  119. });
  120. this.getList(true);
  121. },
  122. /* 获取列表标签 */
  123. getTags() {
  124. let list = this.data.list,
  125. ownerids = list.map(v => v.sa_quotedpriceid);
  126. _Http.basic({
  127. "id": 20221018102001,
  128. "content": {
  129. nocache: true,
  130. "ownertable": "sa_quotedprice",
  131. ownerids
  132. }
  133. }).then(res => {
  134. console.log("标签", res)
  135. for (let key in res.data) {
  136. let index = list.findIndex(v => v.sa_quotedpriceid == key);
  137. list[index].tags = res.data[key]
  138. };
  139. this.setData({
  140. list
  141. })
  142. })
  143. },
  144. /* 去添加 */
  145. openType() {
  146. this.setData({
  147. typeShow: true
  148. })
  149. },
  150. typeCancel() {
  151. this.setData({
  152. typeShow: false
  153. })
  154. },
  155. /* 选择添加报价形式 */
  156. typeSelect({
  157. detail
  158. }) {
  159. wx.navigateTo({
  160. url: detail.name == '项目报价' ? '/packageA/offers/addProjectOffer' : '/packageA/offers/addSetclientOffer',
  161. });
  162. this.typeCancel();
  163. },
  164. onReady() {
  165. this.setListHeight();
  166. },
  167. setListHeight() {
  168. this.selectComponent("#ListBox").setHeight(".total", this);
  169. },
  170. /* 顶部条件导航回调 */
  171. navClick({
  172. detail
  173. }) {
  174. switch (detail.id) {
  175. case '1':
  176. this.setData({
  177. classShow: true
  178. })
  179. break;
  180. case '2':
  181. this.setData({
  182. 'filter.show': true
  183. })
  184. break;
  185. }
  186. },
  187. classClose() {
  188. this.setData({
  189. classShow: false
  190. })
  191. },
  192. classSelect({
  193. detail
  194. }) {
  195. if (this.data.content.type == detail.index) return this.classClose();
  196. this.setData({
  197. "content.type": detail.index,
  198. 'navList[0].label': detail.name
  199. })
  200. this.classClose();
  201. this.getList(true)
  202. },
  203. /* 筛选状态选择 */
  204. selectStatus(e) {
  205. const {
  206. item
  207. } = e.currentTarget.dataset;
  208. this.setData({
  209. "filter.statusActive": this.data.filter.statusActive == item ? "" : item
  210. })
  211. },
  212. /* 筛选状态选择 */
  213. typeStatus(e) {
  214. const {
  215. item
  216. } = e.currentTarget.dataset;
  217. this.setData({
  218. "filter.typeActive": this.data.filter.typeActive == item ? "" : item
  219. })
  220. },
  221. /* 处理筛选 */
  222. handleFilter({
  223. detail
  224. }) {
  225. const data = this.data.filter;
  226. if (data.typeActive) data.typeActive = data.typeActive == '客户报价' ? 0 : 1;
  227. switch (detail) {
  228. case 'confirm':
  229. this.setData({
  230. 'filter.show': false
  231. });
  232. this.getList(true, data);
  233. break;
  234. case 'reset':
  235. this.setData({
  236. 'filter.statusActive': "",
  237. 'filter.typeActive': "",
  238. 'filter.startdate': "",
  239. 'filter.enddate': "",
  240. });
  241. this.getList(true, this.data.filter)
  242. break;
  243. case 'close':
  244. this.setData({
  245. 'filter.show': false
  246. });
  247. break;
  248. }
  249. }
  250. })