index.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. const _Http = getApp().globalData.http;
  2. Page({
  3. data: {
  4. params: {}, //请求体
  5. result: [], //返回结果
  6. radio: true, //是否为单选
  7. idname: "sa_customerpoolid", //idkey
  8. showName: "poolname", //表单用 显示名称
  9. },
  10. onLoad(options) {
  11. if (options.params) {
  12. let params = JSON.parse(options.params);
  13. if (!params.content.pageNumber || !params.content.pageTotal) {
  14. params.content.pageNumber = 1;
  15. params.content.pageTotal = 1;
  16. }
  17. this.setData({
  18. params
  19. });
  20. }
  21. this.setData({
  22. idname: options.idname || this.data.idname,
  23. showName: options.showName || this.data.showName,
  24. });
  25. this.getList()
  26. getApp().globalData.Language.getLanguagePackage(this, '选择公海池');
  27. },
  28. getList(init = false) {
  29. //init 用于初始化分页
  30. if (init.detail != undefined) init = init.detail;
  31. let params = this.data.params;
  32. if (init) params.content.pageNumber = 1;
  33. if (params.content.pageNumber > params.content.pageTotal) return;
  34. _Http.basic(params).then(res => {
  35. console.log("选择客户列表", res)
  36. this.selectComponent('#ListBox').RefreshToComplete();
  37. if (res.code != '1') return wx.showToast({
  38. title: res.data,
  39. icon: "none"
  40. })
  41. this.setData({
  42. 'params.content.pageNumber': res.pageNumber + 1,
  43. 'params.content.pageTotal': res.pageTotal,
  44. 'params.content.total': res.total,
  45. list: res.pageNumber == 1 ? res.data : this.data.list.concat(res.data)
  46. })
  47. })
  48. },
  49. /* 删除项 */
  50. deteleItem(id) {
  51. this.setData({
  52. list: this.data.list.filter(v => v[this.data.idname] != id),
  53. "params.content.total": this.data.params.content.total - 1
  54. })
  55. },
  56. /* 选中 */
  57. changeResult(e) {
  58. let {
  59. id
  60. } = e.currentTarget.dataset, result = this.data.result;
  61. if (this.data.radio) {
  62. result = [id];
  63. } else {
  64. result.some(v => v == id) ? result = result.filter(v => v != id) : result.push(id)
  65. }
  66. this.setData({
  67. result
  68. });
  69. if (this.data.radio) this.submit();
  70. },
  71. /* 提交 */
  72. submit() {
  73. let result = this.data.result,
  74. obj = this.data.radio ? {
  75. id: result,
  76. item: this.data.list.find(value => value[this.data.idname] == result),
  77. value: [this.data.list.find(value => value[this.data.idname] == result)[this.data.showName], result]
  78. } : {
  79. result,
  80. list: result.map(v => this.data.list.find(value => value[this.data.idname] == v)),
  81. value: [result.map(v => {
  82. let data = this.data.list.find(value => value[this.data.idname] == v);
  83. return data ? data[this.data.showName] : ""
  84. }), result]
  85. }
  86. getApp().globalData.handleSelect && getApp().globalData.handleSelect(obj)
  87. },
  88. onReady() {
  89. this.selectComponent("#ListBox").setHeight(".total", this);
  90. },
  91. onUnload() {
  92. //回收数据
  93. getApp().globalData.handleSelect = null;
  94. }
  95. })