index.js 6.9 KB

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