xinli/xinlidsj/pages/interventionTask/addRecord.vue

243 lines
6.5 KiB
Vue
Raw Normal View History

2026-02-24 16:49:05 +08:00
<template>
<view class="page" :class="{ big: isH5 }">
<view class="panel">
<view class="title">新增干预记录</view>
<view class="subtitle">任务ID {{ taskId || '-' }}</view>
</view>
<view class="panel">
<view class="label">记录内容</view>
<textarea class="textarea" v-model="content" placeholder="例如2025-12-10 14:00 与李四咨询,疏导刑期焦虑"></textarea>
<view class="label" style="margin-top: 18rpx;">附件</view>
<view class="attach-actions">
<button class="btn ghost" :disabled="uploading" @click="pickImage">选择图片</button>
<button class="btn ghost" :disabled="uploading" @click="pickFile">选择文件</button>
</view>
<view v-if="attachments.length" class="attach-list">
<view class="attach-item" v-for="(a, idx) in attachments" :key="idx">
{{ a.originalFilename || a.newFileName || a.fileName || a.url }}
<text class="del" @tap.stop="removeAttachment(idx)">删除</text>
</view>
</view>
<view v-if="errorMsg" class="error">{{ errorMsg }}</view>
<button class="btn primary" :disabled="saving" @click="onSave">{{ saving ? '保存中' : '保存记录' }}</button>
</view>
</view>
</template>
<script>
import { uploadCommonFile } from '../../api/common/upload'
import { addInterventionRecord } from '../../api/psychology/interventionRecord'
export default {
data() {
return {
isH5: false,
taskId: '',
content: '',
attachments: [],
uploading: false,
saving: false,
errorMsg: ''
}
},
onLoad(options) {
try {
const info = uni.getSystemInfoSync()
const p = info ? (info.uniPlatform || info.platform) : ''
this.isH5 = p === 'web' || p === 'h5'
} catch (e) {
this.isH5 = false
}
this.taskId = options && options.taskId ? options.taskId : ''
},
methods: {
removeAttachment(idx) {
this.attachments.splice(idx, 1)
},
pickImage() {
uni.chooseImage({
count: 9,
success: (res) => {
const files = (res && res.tempFilePaths) ? res.tempFilePaths : []
this.uploadMany(files)
}
})
},
pickFile() {
uni.chooseMessageFile({
count: 9,
type: 'file',
success: (res) => {
const files = (res && res.tempFiles) ? res.tempFiles.map(f => f.path) : []
this.uploadMany(files)
}
})
},
uploadMany(paths) {
if (!paths || paths.length === 0) return
this.errorMsg = ''
this.uploading = true
const uploads = paths.map(p => uploadCommonFile(p))
Promise.all(uploads).then((results) => {
this.uploading = false
results.forEach((r) => {
const data = r && r.data ? r.data : null
if (!data || data.code !== 200) {
return
}
this.attachments.push({
url: data.url,
fileName: data.fileName,
newFileName: data.newFileName,
originalFilename: data.originalFilename
})
})
}).catch((e) => {
this.uploading = false
this.errorMsg = e && e.message ? e.message : '上传失败'
})
},
onSave() {
this.errorMsg = ''
if (!this.taskId) {
this.errorMsg = '缺少 taskId'
return
}
if (!this.content || !this.content.trim()) {
this.errorMsg = '请输入记录内容'
return
}
this.saving = true
addInterventionRecord({
taskId: Number(this.taskId),
content: this.content,
attachments: this.attachments
}).then((res) => {
this.saving = false
const data = res && res.data ? res.data : null
if (!data || data.code !== 200) {
this.errorMsg = (data && data.msg) ? data.msg : '保存失败'
return
}
uni.showToast({ title: '已保存', icon: 'success' })
setTimeout(() => {
uni.navigateBack()
}, 400)
}).catch((e) => {
this.saving = false
this.errorMsg = e && e.message ? e.message : '网络错误'
})
}
}
}
</script>
<style>
.page {
min-height: 100vh;
padding: 32rpx;
box-sizing: border-box;
background: #f6f7fb;
}
.page.big {
padding: 14rpx 14rpx 120rpx;
background-image:
radial-gradient(1100rpx 520rpx at 50% 14%, rgba(43, 107, 255, 0.30) 0%, rgba(6, 16, 40, 0.0) 65%),
linear-gradient(180deg, rgba(5, 11, 24, 0.90) 0%, rgba(8, 20, 45, 0.85) 42%, rgba(6, 16, 40, 0.92) 100%),
url('/static/bg.png');
background-size: auto, auto, cover;
background-position: center, center, center;
background-repeat: no-repeat, no-repeat, no-repeat;
}
.panel {
background: #ffffff;
border-radius: 20rpx;
padding: 24rpx;
border: 1px solid rgba(0, 0, 0, 0.05);
margin-bottom: 24rpx;
}
.title {
font-size: 36rpx;
font-weight: 700;
color: #1f2329;
}
.subtitle {
margin-top: 10rpx;
font-size: 24rpx;
color: #646a73;
line-height: 36rpx;
}
.label {
font-size: 26rpx;
color: #1f2329;
margin-bottom: 10rpx;
}
.textarea {
background: #f7f8fa;
border-radius: 16rpx;
padding: 18rpx;
font-size: 24rpx;
box-sizing: border-box;
min-height: 180rpx;
}
.attach-actions {
display: flex;
justify-content: space-between;
margin-top: 8rpx;
}
.btn {
width: 48%;
border-radius: 16rpx;
}
.btn.primary {
width: 100%;
margin-top: 18rpx;
background: #1677ff;
color: #fff;
}
.btn.ghost {
background: rgba(22, 119, 255, 0.12);
color: #1677ff;
}
.attach-list {
margin-top: 14rpx;
border: 1px dashed rgba(0, 0, 0, 0.12);
border-radius: 16rpx;
padding: 14rpx;
}
.attach-item {
font-size: 24rpx;
color: #1f2329;
line-height: 40rpx;
display: flex;
justify-content: space-between;
}
.del {
color: #ff4d4f;
margin-left: 12rpx;
}
.error {
margin-top: 14rpx;
font-size: 24rpx;
color: #ff4d4f;
line-height: 36rpx;
}
.page.big .panel,
.page.big .attach-list {
border: 1px solid rgba(116, 216, 255, 0.22);
background: linear-gradient(180deg, rgba(10, 18, 38, 0.75) 0%, rgba(5, 10, 22, 0.55) 100%);
box-shadow: 0 12rpx 24rpx rgba(0, 0, 0, 0.35);
}
.page.big .title,
.page.big .label { color: rgba(235, 248, 255, 0.92); }
.page.big .subtitle { color: rgba(201, 242, 255, 0.65); }
.page.big .textarea { background: rgba(7, 13, 28, 0.35); border: 1px solid rgba(116, 216, 255, 0.18); color: rgba(235, 248, 255, 0.92); }
.page.big .btn.primary { background: linear-gradient(90deg, rgba(116, 216, 255, 0.95) 0%, rgba(43, 107, 255, 0.92) 100%); color: #0b1226; }
.page.big .btn.ghost { background: rgba(7, 13, 28, 0.35); color: rgba(201, 242, 255, 0.86); border: 1px solid rgba(116, 216, 255, 0.18); }
.page.big .attach-item { color: rgba(235, 248, 255, 0.88); }
.page.big .attach-list { border-style: solid; }
</style>