index.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. const _Http = getApp().globalData.http,
  2. file = require("../../utils/FormatTheAttachment");
  3. Page({
  4. data: {
  5. loading: true,
  6. params: {}, //请求体
  7. result: [], //返回结果
  8. radio: false, //是否为单选
  9. idname: "itemid", //idkey
  10. showName: "itemname"
  11. },
  12. onLoad(options) {
  13. if (options.item) {
  14. let item = JSON.parse(options.item);
  15. this.setData({
  16. item,
  17. params: item.params
  18. });
  19. }
  20. if (options.params) this.setData({
  21. params: JSON.parse(options.params)
  22. });
  23. this.setData({
  24. radio: options.radio ? true : false,
  25. idname: options.idname || this.data.idname,
  26. showName: options.showName || this.data.showName,
  27. });
  28. this.getList()
  29. },
  30. getList(init = false) {
  31. //init 用于初始化分页
  32. if (init.detail != undefined) init = init.detail;
  33. let params = this.data.params;
  34. if (init) params.content.pageNumber = 1
  35. if (params.content.pageNumber > params.content.pageTotal) return;
  36. _Http.basic(params).then(res => {
  37. console.log("选择产品列表", res)
  38. this.selectComponent('#ListBox').RefreshToComplete();
  39. if (res.msg != '成功') return wx.showToast({
  40. title: res.data,
  41. icon: "none"
  42. })
  43. res.data = res.data.map(value => {
  44. if (value.attinfos.length == 0) return value;
  45. value.attinfos = file.fileList(value.attinfos)
  46. let image = value.attinfos.find(v => v.fileType == "image");
  47. value.cover = image ? image.cover : "";
  48. return value;
  49. })
  50. this.setData({
  51. 'params.content.pageNumber': res.pageNumber + 1,
  52. 'params.content.pageTotal': res.pageTotal,
  53. 'params.content.total': res.total,
  54. list: res.pageNumber == 1 ? res.data : this.data.list.concat(res.data),
  55. loading: false
  56. })
  57. })
  58. },
  59. /* 选中 */
  60. changeResult(e) {
  61. let {
  62. id
  63. } = e.currentTarget.dataset, result = this.data.result;
  64. if (this.data.radio) {
  65. result = [id];
  66. } else {
  67. result.some(v => v == id) ? result = result.filter(v => v != id) : result.push(id)
  68. }
  69. this.setData({
  70. result
  71. });
  72. if (this.data.radio) this.submit();
  73. },
  74. /* 提交 */
  75. submit() {
  76. let result = this.data.result,
  77. obj = this.data.radio ? {
  78. id: result,
  79. item: this.data.list.find(value => value[this.data.idname] == result),
  80. value: [this.data.list.find(value => value[this.data.idname] == result), result]
  81. } : {
  82. result,
  83. list: result.map(v => this.data.list.find(value => value[this.data.idname] == v)),
  84. value: [result.map(v => {
  85. let data = this.data.list.find(value => value[this.data.idname] == v);
  86. return data ? data[this.data.showName] : ""
  87. }), result]
  88. }
  89. getApp().globalData.handleSelect && getApp().globalData.handleSelect(obj)
  90. },
  91. /* 预览图片 */
  92. viewImage(e) {
  93. const {
  94. file
  95. } = e.currentTarget.dataset;
  96. if (file.length) wx.previewMedia({
  97. sources: file.filter(value => ['image', 'vadio'].includes(value.fileType)).map(v => {
  98. return {
  99. url: v.url,
  100. type: v.fileType
  101. }
  102. }),
  103. current: 0,
  104. showmenu: true
  105. })
  106. },
  107. /* 开始搜索 */
  108. startSearch({
  109. detail
  110. }) {
  111. let condition = this.data.content ? this.data.content.where.condition : this.data.params.content.where.condition;
  112. if (detail == condition) return;
  113. this.setData({
  114. 'content.where.condition': detail,
  115. 'params.content.where.condition': detail
  116. });
  117. this.getList(true);
  118. },
  119. /* 取消搜索 */
  120. onClear() {
  121. this.setData({
  122. 'content.where.condition': "",
  123. 'params.content.where.condition': ""
  124. });
  125. this.getList(true);
  126. },
  127. onReady() {
  128. this.selectComponent("#ListBox").setHeight(".total", this);
  129. },
  130. onUnload() {
  131. //回收数据
  132. getApp().globalData.handleSelect = null;
  133. getApp().globalData.savePage = null;
  134. }
  135. })