|
|
- <template>
- <view class="task-upload">
- <!-- 任务状态提示 -->
- <view class="status-box" v-if="taskInfo.status != 0">
- <!-- 驳回状态 -->
- <view class="reject-box" v-if="taskInfo.status == 3">
- <view class="reject-icon">⚠</view>
- <view class="reject-content">
- <view class="reject-title">拒绝原因:{{taskInfo.rejectTxt}}</view>
- </view>
- </view>
- <!-- 审核中状态 -->
- <view class="reviewing-box" v-if="taskInfo.status == 1">
- <view class="reviewing-icon">⏳</view>
- <view class="reviewing-content">
- <view class="reviewing-title">任务审核中,请耐心等待审核结果</view>
- </view>
- </view>
- <!-- 已通过状态 -->
- <view class="approved-box" v-if="taskInfo.status == 2">
- <view class="approved-icon">✅</view>
- <view class="approved-content">
- <view class="approved-title">任务已审核通过</view>
- </view>
- </view>
- </view>
-
- <!-- 上传表单 -->
- <view class="upload-form">
- <!-- 链接输入 -->
- <view class="form-item">
- <view class="form-label">笔记链接</view>
- <view class="form-input">
- <u-textarea v-model="formData.proveTxt"
- :border="false"
- height="300rpx"
- :disabled="taskInfo.status == 1 || taskInfo.status == 2"
- placeholder="请输入笔记链接" :maxlength="300" count />
- </view>
- </view>
-
- <!-- 图片上传 -->
- <view class="form-item">
- <view class="form-label">笔记截图</view>
- <view class="upload-box">
- <u-upload :fileList="fileList" @afterRead="afterRead" @delete="deletePic" name="proveImage"
- multiple :maxCount="3" :disabled="taskInfo.status == 1 || taskInfo.status == 2"></u-upload>
- </view>
- </view>
-
- <!-- 提交按钮 -->
- <view class="submit-btn" v-if="taskInfo.status == 0 || taskInfo.status == 3">
- <u-button type="primary" color="#ffaa48" shape="circle" @click="submitTaskHandler">提交审核</u-button>
- </view>
- </view>
- </view>
- </template>
-
- <script>
- import { getTaskDetailUser, submitTask } from "@/api/order/task.js"
- export default {
- data() {
- return {
- taskId: null,
- taskStatus: 0,
- taskInfo: {
- id: 0,
- title: '',
- taskEndTime: '',
- rejectTxt: '',
- proveTxt: '',
- status: 0
- },
- formData: {
- taskId: 0,
- proveImage: [],
- rejectTxt: '',
- proveTxt: '',
- },
- fileList: []
- }
- },
- onLoad(options) {
- if (options.id) {
- this.taskId = options.id
- this.formData.taskId = options.id
- this.getTaskDetail()
- } else {
- uni.showToast({
- title: '任务ID不存在',
- icon: 'none'
- })
- setTimeout(() => {
- uni.navigateBack()
- }, 1500)
- }
- },
- methods: {
- getTaskDetail() {
- // 获取任务详情
- getTaskDetailUser(this.taskId).then(res => {
- if (res && res.code == 200) {
- this.taskInfo = res.data
-
- // 如果任务已有审核文本,填充到表单
- if (res.data.proveTxt) {
- this.formData.proveTxt = res.data.proveTxt;
- }
-
- // 如果任务已有图片,添加到文件列表显示
- if (res.data.proveImage) {
- const imageUrls = res.data.proveImage.split(',');
- imageUrls.forEach(url => {
- if (url) {
- this.fileList.push({
- url: url,
- status: 'success',
- message: '已上传',
- isImage: true
- });
- // 同时更新formData中的图片数组
- this.formData.proveImage.push(url);
- }
- });
- }
- }
- })
- },
- uploadFilePromise(url) {
- return new Promise((resolve, reject) => {
- let uploadTask = uni.uploadFile({
- url: 'https://store-test.catmdogd.com/test-api/h5/oss/upload',
- filePath: url,
- name: 'file',
- formData: {
- user: 'test'
- },
- success: (res) => {
- if (res && res.data) {
- try {
- let resData = JSON.parse(res.data);
- if (resData.url) {
- resolve(resData.url);
- } else {
- reject("上传失败: 未获取到图片URL");
- }
- } catch (e) {
- reject("上传失败: 解析响应数据错误");
- }
- } else {
- reject("上传失败: 响应数据为空");
- }
- },
- fail: (err) => {
- reject("上传失败: " + (err.errMsg || JSON.stringify(err)));
- }
- });
-
- // 监听上传进度
- uploadTask.onProgressUpdate((res) => {
- // 查找当前正在上传的文件
- const index = this.fileList.findIndex(file => file.status == 'uploading');
- if (index != -1) {
- // 更新上传进度信息
- this.fileList[index].message = '上传中 ' + res.progress + '%';
- }
- });
- })
- },
- formatDate(dateStr) {
- if (!dateStr) return '';
- let date = new Date(dateStr);
- let year = date.getFullYear();
- let month = (date.getMonth() + 1).toString().padStart(2, '0');
- let day = date.getDate().toString().padStart(2, '0');
- return `${year}-${month}-${day}`;
- },
- afterRead(event) {
- // 读取文件后的处理
- const { file } = event
-
- // 处理文件数组
- const fileList = Array.isArray(file) ? file : [file]
-
- // 遍历处理每个文件
- fileList.forEach(item => {
- // 更新UI显示上传中状态
- const fileListItem = {
- ...item,
- status: 'uploading',
- message: '上传中'
- }
- this.fileList.push(fileListItem)
- const currentIndex = this.fileList.length - 1
-
- // 使用Promise上传图片
- this.uploadFilePromise(item.url)
- .then(url => {
- // 上传成功,更新状态和URL
- this.fileList[currentIndex].status = 'success'
- this.fileList[currentIndex].message = '上传成功'
- this.fileList[currentIndex].url = url
- // 保存上传后的URL
- this.formData.proveImage.push(url)
- })
- .catch(err => {
- // 上传失败
- this.fileList[currentIndex].status = 'failed'
- this.fileList[currentIndex].message = '上传失败'
-
- uni.showToast({
- title: '图片上传失败',
- icon: 'none'
- })
- })
- })
- },
- deletePic(event) {
- // 删除图片
- const index = event.index
- this.fileList.splice(index, 1)
- this.formData.proveImage.splice(index, 1)
- },
- submitTaskHandler() {
- // 表单验证
- if (!this.formData.proveTxt) {
- uni.showToast({
- title: '请输入笔记链接',
- icon: 'none'
- })
- return
- }
-
- if (this.formData.proveImage.length == 0) {
- uni.showToast({
- title: '请上传至少一张截图',
- icon: 'none'
- })
- return
- }
-
- // 检查是否有正在上传的图片
- const isUploading = this.fileList.some(file => file.status == 'uploading')
- if (isUploading) {
- uni.showToast({
- title: '图片正在上传中,请稍候',
- icon: 'none'
- })
- return
- }
-
- // 显示提交中提示
- uni.showLoading({
- title: '提交中...'
- })
-
- // 提交任务
- submitTask({
- id: this.taskId,
- taskId: this.formData.taskId,
- proveTxt: this.formData.proveTxt,
- proveImage: this.formData.proveImage.join(',')
- }).then(res => {
- uni.hideLoading()
- if (res && res.code == 200) {
- uni.showToast({
- title: '提交成功',
- icon: 'success'
- })
- // 返回任务详情页
- setTimeout(() => {
- uni.navigateBack()
- }, 1500)
- } else {
- uni.showToast({
- title: res.msg || '提交失败',
- icon: 'none'
- })
- }
- }).catch(err => {
- uni.hideLoading()
- uni.showToast({
- title: '提交失败',
- icon: 'none'
- })
- console.error('提交任务失败:', err)
- })
- }
- }
- }
- </script>
-
- <style lang="scss" scoped>
- .task-upload {
- padding: 20rpx;
- background-color: #f5f5f5;
- min-height: 100vh;
-
- .status-box {
- margin-bottom: 20rpx;
- }
-
- .reject-box {
- background-color: #fff2e8;
- border-radius: 10rpx;
- padding: 20rpx 30rpx;
- margin-bottom: 20rpx;
- display: flex;
- align-items: center;
-
- .reject-icon {
- font-size: 32rpx;
- color: #ff8800;
- margin-right: 15rpx;
- font-weight: bold;
- }
-
- .reject-content {
- flex: 1;
- }
-
- .reject-title {
- font-size: 28rpx;
- color: #ff8800;
- font-weight: 500;
- }
- }
-
- .reviewing-box {
- background-color: #fff7e6;
- border-radius: 10rpx;
- padding: 20rpx 30rpx;
- margin-bottom: 20rpx;
- display: flex;
- align-items: center;
-
- .reviewing-icon {
- font-size: 32rpx;
- color: #fa8c16;
- margin-right: 15rpx;
- font-weight: bold;
- }
-
- .reviewing-content {
- flex: 1;
- }
-
- .reviewing-title {
- font-size: 28rpx;
- color: #fa8c16;
- font-weight: 500;
- }
- }
-
- .approved-box {
- background-color: #f6ffed;
- border-radius: 10rpx;
- padding: 20rpx 30rpx;
- margin-bottom: 20rpx;
- display: flex;
- align-items: center;
-
- .approved-icon {
- font-size: 32rpx;
- color: #52c41a;
- margin-right: 15rpx;
- font-weight: bold;
- }
-
- .approved-content {
- flex: 1;
- }
-
- .approved-title {
- font-size: 28rpx;
- color: #52c41a;
- font-weight: 500;
- }
- }
-
- .upload-form {
- border-radius: 10rpx;
- padding: 10rpx;
-
- .form-item {
- margin-bottom: 40rpx;
- background-color: #fff;
- padding: 30rpx;
- border-radius: 10rpx;
-
-
- &:last-child {
- margin-bottom: 0;
- }
-
- .form-label {
- font-size: 28rpx;
- color: #333;
- font-weight: 500;
- margin-bottom: 20rpx;
- position: relative;
-
- &::before {
- content: '';
- width: 6rpx;
- height: 28rpx;
- background-color: #ff8800;
- position: absolute;
- left: -20rpx;
- top: 50%;
- transform: translateY(-50%);
- border-radius: 3rpx;
- }
- }
-
- .form-input {
- margin-bottom: 10rpx;
- }
-
- .upload-box {
- margin-top: 20rpx;
- }
- }
-
- .submit-btn {
- margin-top: 60rpx;
- padding: 0 40rpx;
- }
- }
- }
- </style>
|