import { get, post } from '../../utils/http'; Page({ /** * 页面的初始数据 */ data: { maxlength: 500, number: 0, value: "", imgs: [], // imgs: [ // { // type: "image", // url: "https://img1.baidu.com/it/u=202543353,3627416815&fm=26&fmt=auto" // }, // { // type: "image", // url: "https://img0.baidu.com/it/u=745609344,230882238&fm=26&fmt=auto" // }, // { // type: "image", // url: "https://img0.baidu.com/it/u=286636366,3227707112&fm=26&fmt=auto" // }, // { // type: "image", // url: "https://img1.baidu.com/it/u=2450865760,444795162&fm=26&fmt=auto" // }, // { // type: "image", // url: "https://img0.baidu.com/it/u=4226275504,4103997964&fm=26&fmt=auto" // }, // { // type: "image", // url: "https://img0.baidu.com/it/u=2247422843,411257408&fm=26&fmt=auto" // }, // ], raterList: [ { text: '整体满意度', num: 1 }, { text: '效果认可度', num: 2 }, { text: '价格接受度', num: 3 }, { text: '类别满意度', num: 4 }, { text: '安全认可度', num: 5 }, ], raterStatus: { 1: '差', 2: '较差', 3: '一般', 4: '满意', 5: '非常好', } }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { if(options.orderId) { this.setData({ orderId: options.orderId, cover: options.cover, name: options.name }) } }, /** * 生命周期函数--监听页面初次渲染完成 */ onReady: function () { }, /** * 生命周期函数--监听页面显示 */ onShow: function () { }, /** * 生命周期函数--监听页面隐藏 */ onHide: function () { }, /** * 生命周期函数--监听页面卸载 */ onUnload: function () { }, /** * 页面相关事件处理函数--监听用户下拉动作 */ onPullDownRefresh: function () { }, /** * 页面上拉触底事件的处理函数 */ onReachBottom: function () { }, /** * 用户点击右上角分享 */ onShareAppMessage: function () { }, /** * 监听文本域 */ bindTextAreaInput(e) { this.setData({ number: e.detail.cursor, value: e.detail.value }) }, /** * 预览图片和视频 */ previewMedia(e) { let arr = this.data.imgs let current = e.currentTarget.dataset.index wx.previewMedia({ sources: arr, current }) }, /** * 删除列表项 */ onDeleteItem(e) { let imgs = this.data.imgs; imgs.splice(e.currentTarget.dataset.index, 1); this.setData({ imgs }) console.log(imgs) }, /** * 选择图片 */ chooseImage() { let that = this; let imgs = this.data.imgs; let count = 9 - this.data.imgs.length wx.chooseImage({ count, sizeType: ['original', 'compressed'], sourceType: ['album', 'camera'], success (res) { wx.showLoading({ title: '正在上传图片', mask: true }); const tempFiles = res.tempFiles tempFiles.forEach((item) => { that.upload(item.path).then((data) => { imgs.push({ type: 'image', url: data.data.url, }) that.setData({ imgs }) wx.hideLoading() }); }) } }) }, /** * 选择视频 */ chooseVideo(){ let that = this; let imgs = this.data.imgs; wx.chooseMedia({ count: 1, mediaType: ['video'], sourceType: ['album', 'camera'], maxDuration: 30, camera: 'back', success(res) { wx.showLoading({ title: '正在上传视频', mask: true }); const tempFiles = res.tempFiles that.upload(tempFiles[0].tempFilePath).then((data) => { imgs.unshift({ type: 'video', thumb: tempFiles[0].thumbTempFilePath, url: data.data.url }) that.setData({ imgs }) wx.hideLoading() }); return; tempFiles.forEach((item) => { imgs.unshift({ type: 'video', thumb: item.thumbTempFilePath, url: item.tempFilePath }) }) that.setData({ imgs }) } }) }, /** * 选择星星 */ onChange(e) { let index = e.currentTarget.dataset.index let value = e.detail.value this.setData({ ['raterList[' + index + '].num']: value }) }, /** * 提交反馈 */ onSubmit() { // api/feedback/add let { orderId,value,raterList } = this.data; console.log(this.data.imgs) post('api/feedback/add',{ order_id: orderId, content: value, media_list: JSON.stringify(this.data.imgs), score_whole: raterList[0].num, score_effect: raterList[1].num, score_price: raterList[2].num, score_kind: raterList[3].num, score_safe: raterList[4].num, },(res) => { console.log(res) }) }, /** * 上传视频/图片 */ upload(filePath) { let that = this; // 上传类型/业务类型:avatar头像,order订单反馈,check检查表反馈 return new Promise((resolve,reject) => { let { imgs } = this.data; wx.uploadFile({ url: 'https://store.test-api.ijolijoli.com/api/upload', header: { token: wx.getStorageSync('token') || '', }, filePath, name: 'file', formData: { 'type': 'order' }, success(res) { console.log(res) if(res.statusCode == 200 && res.data) { let data = JSON.parse(res.data); if(data.code == 200 && data.data) { resolve(data) } else { wx.showToast({ title: '上传失败', icon: 'none' }) } } else { wx.showToast({ title: '上传失败', icon: 'none' }) } }, fail(err) { wx.showToast({ title: '上传失败', icon: 'none' }) } }) }) }, })