You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

261 lines
6.0 KiB
JavaScript

2 years ago
// pages/task-edit/task-edit.js
import {
saveTask,
getTaskById
} from '../../api/api'
Page({
/**
* 页面的初始数据
*/
data: {
mode: '',
datetimeVisible: false,
datetime: new Date().getTime(),
datetimeText: '',
jtTaskName: '',
jtTaskIntroduction: '',
completionMethod: 0,
fileList: [],
gridConfig: {
column: 4,
width: 160,
height: 160,
},
id: ''
},
/**
* 生命周期函数--监听页面加载
*/
onLoad(options) {
if (options.id) {
this.data.id = options.id
getTaskById({
id: options.id
}).then(res => {
const fileList = res.data.jtTaskAttachment ? res.data.jtTaskAttachment.split(',') : []
const arr = []
for (let i = 0; i < fileList.length; i++) {
const element = fileList[i];
arr.push({
url: element,
name: `uploaded${i}.png`,
type: 'image',
})
}
this.setData({
id: options.id,
jtTaskName: res.data.jtTaskName,
jtTaskIntroduction: res.data.jtTaskIntroduction,
completionMethod: res.data.completionMethod || 0,
datetime: new Date(res.data.jtTaskDeadline).getTime(),
datetimeText: res.data.jtTaskDeadline.slice(0, -3),
fileList: arr,
})
})
}
},
handleAdd(e) {
const {
fileList
} = this.data;
const {
files
} = e.detail;
// 方法2每次选择图片都上传展示每次上传图片的进度
files.forEach(file => this.onUpload(file))
},
onUpload(file) {
const {
fileList
} = this.data;
this.setData({
fileList: [...fileList, {
...file,
status: 'loading'
}],
});
const {
length
} = fileList;
const task = wx.uploadFile({
url: 'https://task.51jingcheng.com/oss/imgUpload', // 仅为示例,非真实的接口地址
filePath: file.url,
name: 'file',
formData: {
user: 'test'
},
success: (res) => {
console.log(res.data)
const result = res.data ? JSON.parse(res.data) : {
url: ''
}
this.setData({
[`fileList[${length}].status`]: 'done',
[`fileList[${length}].url`]: result.url,
});
},
});
task.onProgressUpdate((res) => {
this.setData({
[`fileList[${length}].percent`]: res.progress,
});
});
},
onChange(event) {
const {
value
} = event.detail;
this.setData({
completionMethod: value
});
},
handleRemove(e) {
const {
index
} = e.detail;
const {
fileList
} = this.data;
fileList.splice(index, 1);
this.setData({
fileList,
});
},
showPicker(e) {
const {
mode
} = e?.currentTarget?.dataset;
this.setData({
mode,
[`${mode}Visible`]: true,
});
},
hidePicker() {
const {
mode
} = this.data;
this.setData({
[`${mode}Visible`]: false,
});
},
onConfirm(e) {
const {
value
} = e?.detail;
const {
mode
} = this.data;
this.setData({
[mode]: value,
[`${mode}Text`]: value,
});
this.hidePicker();
},
formSubmit(e) {
console.log('form发生了submit事件携带数据为', e.detail.value)
const values = {
...e.detail.value
}
for (const key in values) {
if (Object.hasOwnProperty.call(values, key)) {
const element = values[key];
if (!element) {
wx.showToast({
icon: 'none',
title: '任务名称/任务说明不能为空',
})
return
}
}
}
if (!this.data.datetimeText) {
wx.showToast({
icon: 'none',
title: '请选择要求完成时间',
})
return
}
const param = {
id: this.data.id,
jtTaskName: values.name,
jtTaskIntroduction: values.tips,
completionMethod: this.data.completionMethod,
jtTaskDeadline: this.data.datetimeText + ':00',
jtTaskAttachment: this.data.fileList.map(e => e.url).join(','),
jtTaskState: 1
}
saveTask(param).then(res => {
wx.showToast({
icon: 'none',
title: '保存成功',
}).then(res => {
wx.navigateBack()
})
})
},
/**
* 生命周期函数--监听页面初次渲染完成
*/
onReady() {
},
/**
* 生命周期函数--监听页面显示
*/
onShow() {
},
/**
* 生命周期函数--监听页面隐藏
*/
onHide() {
},
/**
* 生命周期函数--监听页面卸载
*/
onUnload() {
},
/**
* 页面相关事件处理函数--监听用户下拉动作
*/
onPullDownRefresh() {
},
/**
* 页面上拉触底事件的处理函数
*/
onReachBottom() {
},
/**
* 用户点击右上角分享
*/
onShareAppMessage() {
}
})