select-data.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452
  1. const app = getApp();
  2. const api = require('@/utils/api.js');
  3. const Constants = require('@/utils/Constants.js')
  4. const mixins = require('@/mixins/index.js')
  5. Page({
  6. mixins: [mixins],
  7. /**
  8. * 页面的初始数据
  9. */
  10. data: {
  11. // 选择数据
  12. choosedData: [],
  13. // // 是否显示tab
  14. // tabFlag: false,
  15. // 页签默认在第一个
  16. active: 0,
  17. // 查询条件
  18. searchContent: null,
  19. // 路由
  20. routeObjName: 'common',
  21. // 列表区(内容)
  22. contentList: null,
  23. // 方法名
  24. method: null,
  25. // 字典类型
  26. dictCode: null,
  27. // 标题
  28. title: null,
  29. // 需要调到的新建路由
  30. addUrl: null,
  31. // 是否多选
  32. chooseFlag: false,
  33. // 提示信息
  34. placeholder: [],
  35. // tab页签
  36. tagList: [],
  37. // 用于多选
  38. valueKey: null,
  39. labelKey: null,
  40. // 多选时是否允许重复
  41. repeatFlag: false,
  42. // 确定按钮
  43. buttonList: [{
  44. name: 'confirm',
  45. title: '确定'
  46. }],
  47. },
  48. /**
  49. * @desc : 调到新建
  50. * @author : 姜永辉
  51. * @date : 2022/5/23 15:16
  52. */
  53. toAdd() {
  54. if (!this.data.addUrl) {
  55. return;
  56. }
  57. let _this = this
  58. wx.navigateTo({
  59. url: this.data.addUrl,
  60. events: {
  61. // // 回调后,在这里给页面赋值
  62. // bandData: function (e) {
  63. // }
  64. },
  65. success: function (res) {
  66. // 通过eventChannel向被打开页面传送数据 TODO 测试例子url是写死的,实际中,需要从route中读取
  67. res.eventChannel.emit('params', {})
  68. }
  69. })
  70. },
  71. /**
  72. * @desc : 选择数据
  73. * @author : 周兴
  74. * @date : 2024/3/25 15:16
  75. */
  76. chooseData(e) {
  77. let list = e.detail.list;
  78. let item = e.detail.item;
  79. let valueKey = this.data.valueKey;
  80. if (!valueKey) {
  81. this.setData({
  82. choosedData: list
  83. })
  84. } else {
  85. let choosedData = this.data.choosedData
  86. // 不允许重复
  87. if (!this.data.repeatFlag) {
  88. if (e.detail.checked) { // 勾选
  89. let filters = choosedData.filter(it => it[valueKey] == item[valueKey])
  90. if(!filters || filters.length == 0){
  91. choosedData.push(item);
  92. }
  93. } else { // 取消勾选
  94. choosedData = choosedData.filter(it => it[valueKey] != item[valueKey])
  95. }
  96. } else {
  97. if (e.detail.checked) { // 勾选
  98. // 可以重复
  99. choosedData.push(item);
  100. }
  101. }
  102. this.setData({
  103. choosedData: choosedData
  104. })
  105. }
  106. },
  107. /**
  108. * @desc : 确定事件-返回数据
  109. * @author : 周兴
  110. * @date : 2024/3/25 15:16
  111. */
  112. confirm() {
  113. let list = [...this.data.choosedData]
  114. let id = list.map(it => it[this.data.valueKey])
  115. let name = list.map(it => it[this.data.labelKey])
  116. const eventChannel = this.getOpenerEventChannel();
  117. eventChannel.emit('bindData', {
  118. data: { list, id, name }
  119. })
  120. wx.navigateBack({
  121. delta: 1
  122. })
  123. },
  124. /**
  125. * @desc : 点击事件-返回数据
  126. * @author : 姜永辉
  127. * @date : 2022/5/23 15:16
  128. */
  129. toDetail(e) {
  130. // 如果选择框开启就走确定模式
  131. if (this.data.chooseFlag) {
  132. return;
  133. }
  134. let item = e.detail.item
  135. // 读取传入的单据类型
  136. let route = this.data.chooseRoute
  137. let data = {}
  138. switch (route.type) {
  139. // 部门
  140. case Constants.chooseType.org:
  141. data = {
  142. id: item.orgId,
  143. name: item.orgName
  144. }
  145. break;
  146. // 员工
  147. case Constants.chooseType.staff:
  148. data = {
  149. id: item.staffId,
  150. name: item.staffName
  151. }
  152. break;
  153. // 供应商
  154. case Constants.chooseType.supplier:
  155. data = {
  156. id: item.supId,
  157. name: item.supName,
  158. item: item
  159. }
  160. break;
  161. // 对象类型
  162. case Constants.chooseType.objectType:
  163. data = {
  164. id: item.objId,
  165. name: item.objName,
  166. objType: item.objType
  167. }
  168. break;
  169. // 仓库
  170. case Constants.chooseType.warehouse:
  171. data = {
  172. id: item.whId,
  173. name: item.whName
  174. }
  175. break;
  176. // 数据字典
  177. case Constants.chooseType.dictionary:
  178. data = {
  179. id: item.dataId,
  180. name: item.dataValue,
  181. dictCode: item.dictCode,
  182. dataCode: item.dataCode,
  183. flgDefault: item.flgDefault,
  184. }
  185. break;
  186. default:
  187. data = {}
  188. break;
  189. }
  190. const eventChannel = this.getOpenerEventChannel();
  191. eventChannel.emit('bindData', {
  192. data: data
  193. })
  194. wx.navigateBack({
  195. delta: 1
  196. })
  197. },
  198. /**
  199. * @desc : 设置查询参数
  200. * @date : 2024/3/25 15:49
  201. * @author : 周兴
  202. */
  203. setSearchParams(params) {
  204. // 字典类别
  205. if (this.data.dictCode) {
  206. params.dictCode = this.data.dictCode
  207. }
  208. let chooseType = this.data.chooseRoute.type;
  209. // 供应商
  210. if (chooseType == Constants.chooseType.supplier) {
  211. params.supType = "";
  212. let active = this.data.active
  213. if (active == 1) { //采购供应商
  214. params.supType = Constants.kindCode.supplierPur;
  215. } else if (active == 2) { //服务供应商
  216. params.supType = Constants.kindCode.supplierService;
  217. }
  218. }
  219. return params
  220. },
  221. /**
  222. * @desc : 删除已选
  223. * @date : 2024年3月26日
  224. * @author : 周兴
  225. */
  226. delChoosed(e){
  227. let choosedData= this.data.choosedData;
  228. choosedData = choosedData.filter((it,index)=>index != e.detail.index)
  229. this.setData({
  230. choosedData:choosedData
  231. })
  232. },
  233. /**
  234. * @desc : 查询数据
  235. * @date : 2024年3月23日
  236. * @author : 周兴
  237. */
  238. getData(params) {
  239. let service = app.globalData[this.data.routeObjName + 'Service'];
  240. return this.excute(service, service[this.data.method], params);
  241. },
  242. /**
  243. * @desc : tab切换(列表和已选)
  244. * @date : 2024/3/25 15:49
  245. * @author : 周兴
  246. */
  247. changeTag(e) {
  248. this.setData({
  249. active: e.detail.index
  250. })
  251. },
  252. /**
  253. * @desc : 切换tab
  254. * @date : 2024/2/1 15:49
  255. * @author : 周兴
  256. */
  257. onChangeTabs(e) {
  258. let index = e.detail.detail.index
  259. this.setData({
  260. active: index,
  261. })
  262. // 查询
  263. this.searchData()
  264. },
  265. /**
  266. * @desc : 生命周期函数(初始加载)
  267. * @date : 2024年3月23日
  268. * @author : 周兴
  269. */
  270. loadInit(e) {
  271. let route = this.data.chooseRoute;
  272. if (!route || !route.type) {
  273. return;
  274. }
  275. let title;
  276. // 读取传入的单据类型
  277. let chooseType = route.type
  278. switch (chooseType) {
  279. // 部门
  280. case Constants.chooseType.org:
  281. title = "部门"
  282. this.setData({
  283. addUrl: '/package-basic-data/pages/org/org',
  284. routeObjName: 'common',
  285. method: 'getOrg',
  286. title: 'orgName',
  287. contentList: [{
  288. name: 'orgCode',
  289. title: '部门编码'
  290. },],
  291. placeholder: ['orgName']
  292. })
  293. break;
  294. // 员工
  295. case Constants.chooseType.staff:
  296. title = "员工"
  297. this.setData({
  298. addUrl: '/package-basic-data/pages/staff/add/add',
  299. routeObjName: 'common',
  300. method: 'getStaff',
  301. title: 'staffName',
  302. contentList: [{
  303. name: 'staffCode',
  304. title: '员工编码'
  305. },
  306. {
  307. name: 'orgName',
  308. title: '部门'
  309. },
  310. ],
  311. placeholder: ['staffName']
  312. })
  313. break;
  314. // 供应商
  315. case Constants.chooseType.supplier:
  316. title = "供应商"
  317. this.setData({
  318. addUrl: '/package-purchase/pages/supplier-list/add/add',
  319. routeObjName: 'supplier',
  320. method: 'selectByCond',
  321. title: 'supName',
  322. valueKey: 'supId',
  323. labelKey: 'supName',
  324. chooseFlag: route.chooseFlag,
  325. contentList: [{
  326. name: 'supTypeName',
  327. title: '供应商类别'
  328. },
  329. {
  330. name: 'returnAddress',
  331. title: '供应商地址'
  332. },
  333. ],
  334. placeholder: ['supplier']
  335. })
  336. // 多选时就不要有其他的tag标签
  337. if (!route.chooseFlag) {
  338. this.setData({
  339. tagList: [{
  340. title: mixins.$t("all") //全部
  341. }, {
  342. title: mixins.$t("procurementSupplier") //采购供应商
  343. }, {
  344. title: mixins.$t("serviceProvider") // 服务供应商
  345. }],
  346. })
  347. }
  348. break;
  349. // 仓库
  350. case Constants.chooseType.warehouse:
  351. title = "仓库"
  352. this.setData({
  353. addUrl: '/package-basic-data/pages/basic-data/basic-data',
  354. routeObjName: 'common',
  355. method: 'warehouseListBy',
  356. title: 'whName',
  357. contentList: [{
  358. name: 'supervisor',
  359. title: '仓库主管'
  360. },
  361. {
  362. name: 'contactPhone',
  363. title: '联系电话'
  364. },
  365. ],
  366. placeholder: ['whName']
  367. })
  368. break;
  369. // 数据字典
  370. case Constants.chooseType.dictionary:
  371. title = "数据字典"
  372. this.setData({
  373. addUrl: '/package-basic-data/pages/basic-data/basic-data',
  374. routeObjName: 'common',
  375. method: 'getDictionaryData',
  376. dictCode: route.dictCode,
  377. chooseFlag: route.chooseFlag,
  378. repeatFlag: route.repeatFlag,
  379. valueKey: 'dataId',
  380. title: 'dataValue',
  381. contentList: [{
  382. name: 'dataCode',
  383. title: '数据编码'
  384. },
  385. {
  386. name: 'dictCode',
  387. title: '字典项目'
  388. },
  389. ],
  390. placeholder: ['orgName']
  391. })
  392. break;
  393. // 对象类型
  394. case Constants.chooseType.objectType:
  395. title = "对象类型"
  396. this.setData({
  397. routeObjName: 'common',
  398. method: 'getSupplierAndCustomerData',
  399. title: 'objName',
  400. contentList: [{
  401. name: 'objCode',
  402. title: '对象编码'
  403. },
  404. {
  405. name: 'objTypeName',
  406. title: '对象'
  407. },
  408. {
  409. name: 'addressFull',
  410. title: '地址'
  411. },
  412. ],
  413. searchContent: [{
  414. code: 'supplier-customer',
  415. title: '选择对象',
  416. searchType: Constants.searchType.switch,
  417. list: [{
  418. code: 'supplier',
  419. title: '供应商'
  420. },
  421. {
  422. code: 'customer',
  423. title: '客户'
  424. }
  425. ]
  426. },
  427. ],
  428. placeholder: ['customerName', 'supplierName', 'address', 'telephone']
  429. })
  430. break;
  431. default:
  432. break;
  433. }
  434. // 多选,数据回显到已选列表
  435. if (this.data.chooseFlag && this.data.item && this.data.item.data) {
  436. this.setData({
  437. choosedData: this.data.item.data
  438. })
  439. }
  440. wx.setNavigationBarTitle({
  441. title: '选择' + title,
  442. })
  443. // 调取查询
  444. this.searchData();
  445. },
  446. })