index.js 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  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. /* input事件剔除特殊字符 */
  85. eliminate(value) {
  86. const {
  87. name
  88. } = value.target.dataset;
  89. this.setData({
  90. [name]: _Verify.Eliminate(value.detail)
  91. })
  92. },
  93. /* 日期选择 */
  94. dateChange({
  95. detail
  96. }) {
  97. this.setData({
  98. optionDate: detail.value
  99. })
  100. },
  101. /* 添加图片 */
  102. imageChange(data) {
  103. this.setData({
  104. attinfos: data.detail.fileList
  105. })
  106. },
  107. /* 表单验证 */
  108. formVerify() {
  109. let errTips = this.data.errTips,
  110. verify = true;
  111. /* 验证分类 */
  112. if (!_Verify.required(this.data.ftype)) {
  113. errTips.ftype = true;
  114. verify = false;
  115. }
  116. /* 验证标题 */
  117. if (!_Verify.required(this.data.ftitle)) {
  118. errTips.ftitle = true;
  119. verify = false;
  120. }
  121. /* 验证内容 */
  122. if (!_Verify.required(this.data.fcontent)) {
  123. errTips.fcontent = true;
  124. verify = false;
  125. }
  126. this.setData({
  127. errTips
  128. })
  129. return verify;
  130. },
  131. /* 提交 */
  132. submit() {
  133. if (!this.formVerify()) return wx.showToast({
  134. title: '请检查表单内容',
  135. icon: "error"
  136. });
  137. if (this.data.throttle) return;
  138. this.addOrModify()
  139. },
  140. /* */
  141. checkedOnChange({
  142. detail
  143. }) {
  144. const that = this;
  145. wx.showModal({
  146. title: '提示',
  147. content: (detail) ? '是否确认上架' : "是否确认下架",
  148. success: function (res) {
  149. if (res.confirm) {
  150. that.setData({
  151. checked: detail
  152. })
  153. }
  154. }
  155. })
  156. },
  157. /* 新增或修改 */
  158. addOrModify() {
  159. let fenddate = this.data.optionDate;
  160. if (this.data.optionDate == '选择日期') fenddate = '';
  161. /* 发送请求 */
  162. _Http.basic({
  163. "accesstoken": wx.getStorageSync('userData').token,
  164. "classname": "customer.supplyanddemand.supplyanddemand",
  165. "method": "insertormodify",
  166. "content": {
  167. "tsupplyanddemandid": this.data.tsupplyanddemandid,
  168. "ftype": this.data.ftype,
  169. "ftitle": this.data.ftitle,
  170. "fcontent": this.data.fcontent,
  171. "fenddate": fenddate,
  172. "fissupply": 0
  173. }
  174. }).then(res => {
  175. console.log(res)
  176. if (res.msg != "成功") return wx.showToast({
  177. title: res.data,
  178. icon: "none"
  179. });
  180. this.setData({
  181. throttle: true
  182. })
  183. let content = {
  184. ownerid: res.data[0].tsupplyanddemandid,
  185. ownertable: "tsupplyanddemand",
  186. tattachmentid: 0
  187. };
  188. this.selectComponent("#UploadFiles").saveTheChanges(content);
  189. let httpData = {
  190. "accesstoken": wx.getStorageSync('userData').token,
  191. "classname": "customer.supplyanddemand.supplyanddemand",
  192. "method": "updatesupplyanddemandstatus",
  193. "content": {
  194. "tsupplyanddemandid": res.data[0].tsupplyanddemandid,
  195. "fstatus": "发布"
  196. }
  197. }
  198. //判断是否上架
  199. if ((res.data[0].fstatus == '新建' || res.data[0].fstatus == '已解决' || res.data[0].fstatus == '已过期')) {
  200. if (this.data.checked) {
  201. _Http.basic(httpData).then(res => {
  202. if (res.msg != '成功') return wx.showToast({
  203. title: res.data,
  204. icon: "none"
  205. })
  206. })
  207. }
  208. };
  209. //判断是否下架
  210. if ((res.data[0].fstatus == '待对接' || res.data[0].fstatus == '正在对接')) {
  211. if (!this.data.checked) {
  212. httpData.content.fstatus = '新建';
  213. _Http.basic(httpData).then(res => {
  214. if (res.msg != '成功') return wx.showToast({
  215. title: res.data,
  216. icon: "none"
  217. })
  218. })
  219. }
  220. };
  221. wx.showToast({
  222. title: '保存成功',
  223. })
  224. setTimeout(() => {
  225. wx.navigateBack({
  226. delta: 1,
  227. })
  228. }, 500)
  229. })
  230. },
  231. /* 弹出层 */
  232. showPop() {
  233. this.setData({
  234. popups: !this.data.popups
  235. })
  236. },
  237. /* 单选改变 */
  238. radioChange(value) {
  239. this.setData({
  240. ftype: value.detail,
  241. popups: false,
  242. "errTips.ftype": false
  243. })
  244. },
  245. /* 获取焦点 */
  246. inputFocus(e) {
  247. const {
  248. name
  249. } = e.currentTarget.dataset;
  250. let errTips = this.data.errTips;
  251. errTips[name] = false;
  252. this.setData({
  253. errTips
  254. })
  255. },
  256. /* 失去焦点 */
  257. inputBlur(e) {
  258. const {
  259. name
  260. } = e.currentTarget.dataset;
  261. const {
  262. value
  263. } = e.detail;
  264. if (value.trim() == "") {
  265. let errTips = this.data.errTips;
  266. errTips[name] = true;
  267. this.setData({
  268. errTips
  269. })
  270. }
  271. },
  272. /**
  273. * 生命周期函数--监听页面初次渲染完成
  274. */
  275. onReady: function () {
  276. },
  277. /**
  278. * 生命周期函数--监听页面显示
  279. */
  280. onShow: function () {
  281. },
  282. /**
  283. * 生命周期函数--监听页面隐藏
  284. */
  285. onHide: function () {
  286. },
  287. /**
  288. * 生命周期函数--监听页面卸载
  289. */
  290. onUnload: function () {},
  291. /**
  292. * 页面相关事件处理函数--监听用户下拉动作
  293. */
  294. onPullDownRefresh: function () {
  295. },
  296. /**
  297. * 页面上拉触底事件的处理函数
  298. */
  299. onReachBottom: function () {
  300. },
  301. /**
  302. * 用户点击右上角分享
  303. */
  304. onShareAppMessage: function () {
  305. }
  306. })