select-data.js 13 KB

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