index.js 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  1. import {
  2. ApiModel
  3. } from "../../utils/api";
  4. const _Http = new ApiModel;
  5. import {
  6. TestVerify
  7. } from "../../utils/verify";
  8. const _Verify = new TestVerify();
  9. Page({
  10. /**
  11. * 页面的初始数据
  12. */
  13. data: {
  14. showCalendar: false, //日历显示
  15. tsupplyanddemandid: 0, //ID 0为新增
  16. popups: false, //弹出层控制
  17. ftype: "", //供需类型
  18. ftitle: "", //供需标题
  19. fcontent: "", //需求内容
  20. throttle: false, //节流阀
  21. /* 必填 */
  22. errTips: {
  23. ftype: false,
  24. ftitle: false,
  25. fcontent: false
  26. },
  27. dateStart: null, //日期选择开始时间 当前时间+1天
  28. dateEnd: null, //日期选择结束时间 当前时间+6个月
  29. optionDate: "选择日期", //选择日期
  30. checked: true, //开关
  31. fstatus: '', //状态
  32. },
  33. /**
  34. * 生命周期函数--监听页面加载
  35. */
  36. onLoad: function (options) {
  37. /* 设置日期选择器 */
  38. const time = new Date(Date.parse(new Date()) + 86400000),
  39. End = new Date(Date.parse(time) + 15724800000);
  40. this.setData({
  41. dateStart: time.getFullYear() + '-' + (time.getMonth() + 1) + '-' + time.getDate(),
  42. dateEnd: End.getFullYear() + '-' + (End.getMonth() + 1) + '-' + End.getDate()
  43. });
  44. /* 修改参数 */
  45. if (options.data != undefined) {
  46. const data = JSON.parse(options.data);
  47. console.log(data)
  48. let attinfos = [];
  49. /* 格式化图片 */
  50. for (let i = 0; i < data.attinfos.length; i++) {
  51. let arr = {
  52. url: data.attinfos[i].fobsurl,
  53. ownerid: data.attinfos[i].ownerid,
  54. tattachmentid: data.attinfos[i].tattachmentid,
  55. ownertable: data.attinfos[i].ownertable,
  56. fdocument: data.attinfos[i].fdocument
  57. }
  58. attinfos.push(arr)
  59. };
  60. let optionDate = this.data.optionDate;
  61. /* 格式化时间 */
  62. if (data.fenddate != null && data.fenddate != '') {
  63. optionDate = data.fenddate
  64. /* const i = data.fenddate.lastIndexOf(' ');
  65. let end = data.fenddate.slice(1, i).split(" ");
  66. optionDate = end[0]; */
  67. };
  68. /* 修改开关状态 */
  69. let checked = true;
  70. if (data.fstatus == "已过期" || data.fstatus == "已解决" || data.fstatus == "新建") checked = false;
  71. this.setData({
  72. ftype: data.ftype, //供需类型
  73. ftitle: data.ftitle, //供需标题
  74. fcontent: data.fcontent, //需求内容
  75. fenddate: data.fenddate, //截止日期
  76. attinfos, //附件列表
  77. tsupplyanddemandid: data.tsupplyanddemandid, //ID 0为新增
  78. optionDate,
  79. fstatus: data.fstatus,
  80. checked
  81. })
  82. };
  83. },
  84. /* 日期选择 */
  85. dateChange({
  86. detail
  87. }) {
  88. this.setData({
  89. optionDate: detail.value
  90. })
  91. },
  92. /* 添加图片 */
  93. imageChange(data) {
  94. this.setData({
  95. attinfos: data.detail.fileList
  96. })
  97. },
  98. /* 表单验证 */
  99. formVerify() {
  100. let errTips = this.data.errTips,
  101. verify = true;
  102. /* 验证分类 */
  103. if (!_Verify.required(this.data.ftype)) {
  104. errTips.ftype = true;
  105. verify = false;
  106. }
  107. /* 验证标题 */
  108. if (!_Verify.required(this.data.ftitle)) {
  109. errTips.ftitle = true;
  110. verify = false;
  111. }
  112. /* 验证内容 */
  113. if (!_Verify.required(this.data.fcontent)) {
  114. errTips.fcontent = true;
  115. verify = false;
  116. }
  117. this.setData({
  118. errTips
  119. })
  120. return verify;
  121. },
  122. /* 提交 */
  123. submit() {
  124. if (!this.formVerify()) return wx.showToast({
  125. title: '请检查表单内容',
  126. icon: "error"
  127. });
  128. if (this.data.throttle) return;
  129. this.addOrModify()
  130. },
  131. /* */
  132. checkedOnChange({
  133. detail
  134. }) {
  135. const that = this;
  136. wx.showModal({
  137. title: '提示',
  138. content: (detail) ? '是否确认上架' : "是否确认下架",
  139. success: function (res) {
  140. if (res.confirm) {
  141. that.setData({
  142. checked: detail
  143. })
  144. }
  145. }
  146. })
  147. },
  148. /* 新增或修改 */
  149. addOrModify() {
  150. let fenddate = this.data.optionDate;
  151. if (this.data.optionDate == '选择日期') fenddate = '';
  152. /* 发送请求 */
  153. _Http.basic({
  154. "accesstoken": wx.getStorageSync('userData').token,
  155. "classname": "customer.supplyanddemand.supplyanddemand",
  156. "method": "insertormodify",
  157. "content": {
  158. "tsupplyanddemandid": this.data.tsupplyanddemandid,
  159. "ftype": this.data.ftype,
  160. "ftitle": this.data.ftitle,
  161. "fcontent": this.data.fcontent,
  162. "fenddate": fenddate,
  163. "fissupply": 0
  164. }
  165. }).then(res => {
  166. console.log(res)
  167. if (res.msg != "成功") return wx.showToast({
  168. title: res.data,
  169. icon: "none"
  170. });
  171. this.setData({
  172. throttle: true
  173. })
  174. let content = {
  175. ownerid: res.data[0].tsupplyanddemandid,
  176. ownertable: "tsupplyanddemand",
  177. tattachmentid: 0
  178. };
  179. this.selectComponent("#UploadFiles").saveTheChanges(content);
  180. let httpData = {
  181. "accesstoken": wx.getStorageSync('userData').token,
  182. "classname": "customer.supplyanddemand.supplyanddemand",
  183. "method": "updatesupplyanddemandstatus",
  184. "content": {
  185. "tsupplyanddemandid": res.data[0].tsupplyanddemandid,
  186. "fstatus": "发布"
  187. }
  188. }
  189. //判断是否上架
  190. if ((res.data[0].fstatus == '新建' || res.data[0].fstatus == '已解决' || res.data[0].fstatus == '已过期')) {
  191. if (this.data.checked) {
  192. _Http.basic(httpData).then(res => {
  193. if (res.msg != '成功') return wx.showToast({
  194. title: res.data,
  195. icon: "none"
  196. })
  197. })
  198. }
  199. };
  200. //判断是否下架
  201. if ((res.data[0].fstatus == '待对接' || res.data[0].fstatus == '正在对接')) {
  202. if (!this.data.checked) {
  203. httpData.content.fstatus = '新建';
  204. _Http.basic(httpData).then(res => {
  205. if (res.msg != '成功') return wx.showToast({
  206. title: res.data,
  207. icon: "none"
  208. })
  209. })
  210. }
  211. };
  212. wx.showToast({
  213. title: '保存成功',
  214. })
  215. setTimeout(() => {
  216. wx.navigateBack({
  217. delta: 1,
  218. })
  219. }, 500)
  220. })
  221. },
  222. /* 弹出层 */
  223. showPop() {
  224. this.setData({
  225. popups: !this.data.popups
  226. })
  227. },
  228. /* 单选改变 */
  229. radioChange(value) {
  230. this.setData({
  231. ftype: value.detail,
  232. popups: false,
  233. "errTips.ftype": false
  234. })
  235. },
  236. /* 获取焦点 */
  237. inputFocus(e) {
  238. const {
  239. name
  240. } = e.currentTarget.dataset;
  241. let errTips = this.data.errTips;
  242. errTips[name] = false;
  243. this.setData({
  244. errTips
  245. })
  246. },
  247. /* 失去焦点 */
  248. inputBlur(e) {
  249. const {
  250. name
  251. } = e.currentTarget.dataset;
  252. const {
  253. value
  254. } = e.detail;
  255. if (value.trim() == "") {
  256. let errTips = this.data.errTips;
  257. errTips[name] = true;
  258. this.setData({
  259. errTips
  260. })
  261. }
  262. },
  263. /**
  264. * 生命周期函数--监听页面初次渲染完成
  265. */
  266. onReady: function () {
  267. },
  268. /**
  269. * 生命周期函数--监听页面显示
  270. */
  271. onShow: function () {
  272. },
  273. /**
  274. * 生命周期函数--监听页面隐藏
  275. */
  276. onHide: function () {
  277. },
  278. /**
  279. * 生命周期函数--监听页面卸载
  280. */
  281. onUnload: function () {},
  282. /**
  283. * 页面相关事件处理函数--监听用户下拉动作
  284. */
  285. onPullDownRefresh: function () {
  286. },
  287. /**
  288. * 页面上拉触底事件的处理函数
  289. */
  290. onReachBottom: function () {
  291. },
  292. /**
  293. * 用户点击右上角分享
  294. */
  295. onShareAppMessage: function () {
  296. }
  297. })