inspect.js 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. import { post,api_url } from "../../../../utils/http";
  2. // pages/recordSheet/components/inspect/inspect.js
  3. Component({
  4. /**
  5. * 组件的属性列表
  6. */
  7. options: {
  8. addGlobalClass: true
  9. },
  10. properties: {
  11. preCheck: {
  12. type: Object,
  13. value: null,
  14. observer(newVal,oldVal) {
  15. if(newVal) {
  16. console.log(newVal)
  17. console.log(newVal.option_list)
  18. newVal.option_list.forEach((item,index)=> {
  19. item.children.forEach((newItem) => {
  20. console.log(newItem)
  21. newItem.status = true
  22. })
  23. })
  24. this.setData({
  25. check: newVal
  26. })
  27. console.log(this.data.check)
  28. }
  29. console.log(newVal,oldVal)
  30. // this.setData({
  31. // check
  32. // })
  33. }
  34. },
  35. check_id: {
  36. type: String,
  37. value: null,
  38. }
  39. },
  40. /**
  41. * 组件的初始数据
  42. */
  43. data: {
  44. is_list: true,
  45. list: ['','','',''],
  46. more: true,
  47. maxlength: 500,
  48. number: 0,
  49. value: "",
  50. imgs: [],
  51. check: {}
  52. },
  53. /**
  54. * 组件的方法列表
  55. */
  56. methods: {
  57. onOpenList() {
  58. this.setData({
  59. more: false
  60. })
  61. },
  62. /**
  63. * 切换结果
  64. */
  65. onChangeStatus(e) {
  66. let { idx,index,status } = e.currentTarget.dataset;
  67. this.setData({
  68. ['check.option_list[' + idx + '].children['+index+'].status']: status == 'true' ? true : false
  69. })
  70. },
  71. /** 监听文本域 */
  72. bindTextAreaInput(e) {
  73. this.setData({
  74. number: e.detail.cursor,
  75. value: e.detail.value
  76. })
  77. },
  78. /** 选择图片 */
  79. chooseImage() {
  80. let that = this;
  81. let imgs = this.data.imgs;
  82. let count = 9 - this.data.imgs.length
  83. wx.chooseImage({
  84. count,
  85. sizeType: ['original', 'compressed'],
  86. sourceType: ['album', 'camera'],
  87. success (res) {
  88. wx.showLoading({
  89. title: '正在上传图片',
  90. mask: true
  91. });
  92. const tempFiles = res.tempFiles
  93. tempFiles.forEach((item) => {
  94. that.upload(item.path).then((data) => {
  95. imgs.push({
  96. type: 'image',
  97. url: data.data.url,
  98. })
  99. that.setData({ imgs })
  100. wx.hideLoading()
  101. });
  102. })
  103. }
  104. })
  105. },
  106. /** 选择视频 */
  107. chooseVideo(){
  108. let that = this;
  109. let imgs = this.data.imgs;
  110. wx.chooseMedia({
  111. count: 1,
  112. mediaType: ['video'],
  113. sourceType: ['album', 'camera'],
  114. maxDuration: 30,
  115. camera: 'back',
  116. success(res) {
  117. wx.showLoading({
  118. title: '正在上传视频',
  119. mask: true
  120. });
  121. const tempFiles = res.tempFiles
  122. that.upload(tempFiles[0].thumbTempFilePath).then((data) => {
  123. if(imgs.length > 0 && imgs[0].type == 'video') {
  124. that.setData({
  125. ['imgs[' + 0 + '].thumb']: data.data.url
  126. })
  127. } else {
  128. imgs.unshift({
  129. type: 'video',
  130. thumb: data.data.url,
  131. url: ''
  132. })
  133. that.setData({ imgs })
  134. }
  135. // that.setData({ imgs })
  136. wx.hideLoading()
  137. });
  138. that.upload(tempFiles[0].tempFilePath).then((data) => {
  139. if(imgs.length > 0 && imgs[0].type == 'video') {
  140. that.setData({
  141. ['imgs[' + 0 + '].url']: data.data.url
  142. })
  143. } else {
  144. imgs.unshift({
  145. type: 'video',
  146. thumb: '',
  147. url: data.data.url
  148. })
  149. that.setData({ imgs })
  150. }
  151. // imgs.unshift({
  152. // type: 'video',
  153. // thumb: tempFiles[0].thumbTempFilePath,
  154. // url: data.data.url
  155. // })
  156. // that.setData({ imgs })
  157. wx.hideLoading()
  158. });
  159. }
  160. })
  161. },
  162. /** 上传视频/图片 */
  163. upload(filePath) {
  164. let that = this;
  165. // 上传类型/业务类型:avatar头像,order订单反馈,check检查表反馈
  166. return new Promise((resolve,reject) => {
  167. let { imgs } = this.data;
  168. wx.uploadFile({
  169. url: `${api_url}api/upload`,
  170. // url: 'https://store.test-api.ijolijoli.com/api/upload',
  171. header: {
  172. token: wx.getStorageSync('token') || '',
  173. },
  174. filePath,
  175. name: 'file',
  176. formData: {
  177. 'type': 'check'
  178. },
  179. success(res) {
  180. console.log(res)
  181. if(res.statusCode == 200 && res.data) {
  182. let data = JSON.parse(res.data);
  183. if(data.code == 200 && data.data) {
  184. resolve(data)
  185. } else {
  186. wx.showToast({
  187. title: '上传失败',
  188. icon: 'none'
  189. })
  190. }
  191. } else {
  192. wx.showToast({
  193. title: '上传失败',
  194. icon: 'none'
  195. })
  196. }
  197. },
  198. fail(err) {
  199. wx.showToast({
  200. title: '上传失败',
  201. icon: 'none'
  202. })
  203. }
  204. })
  205. })
  206. },
  207. /**
  208. * 删除列表项
  209. */
  210. onDeleteItem(e) {
  211. let imgs = this.data.imgs;
  212. if(this.data.is_list) {
  213. imgs = this.data.check.feedback.media_list
  214. }
  215. imgs.splice(e.currentTarget.dataset.index, 1);
  216. this.setData({ imgs })
  217. console.log(imgs)
  218. },
  219. /**
  220. * /api/check/update
  221. * 添加/修改检查信息
  222. */
  223. onCheckUpdate() {
  224. let { orderId,value,imgs,check,check_id } = this.data;
  225. let option_ids = [], option_values= [];
  226. check.option_list.forEach((item,index) => {
  227. item.children.forEach((newItem,index) => {
  228. option_ids.push(newItem.id)
  229. if(newItem.status) {
  230. option_values.push(1)
  231. } else {
  232. option_values.push(2)
  233. }
  234. })
  235. })
  236. post('api/check/update',{
  237. check_id,
  238. type: check.type,
  239. option_ids: option_ids.toString(),
  240. option_values: option_values.toString(),
  241. content: value,
  242. media_list: JSON.stringify(imgs)
  243. },(res) => {
  244. wx.showToast({
  245. title: res.msg,
  246. icon: 'none'
  247. })
  248. setTimeout(() => {
  249. let pages=getCurrentPages()
  250. let prePage = pages[pages.length-1]
  251. prePage.onShow()
  252. this.setData({
  253. is_list: true
  254. })
  255. }, 1500);
  256. console.log(res)
  257. })
  258. },
  259. /** 预览图片和视频 */
  260. previewMedia(e) {
  261. let arr = this.data.imgs
  262. if(this.data.is_list) {
  263. arr = this.data.check.feedback.media_list
  264. }
  265. let current = e.currentTarget.dataset.index
  266. wx.previewMedia({
  267. sources: arr,
  268. current
  269. })
  270. },
  271. /** 切换编辑 */
  272. onChangeEdit() {
  273. this.setData({
  274. is_list: false
  275. })
  276. }
  277. }
  278. })