230 lines
5.3 KiB
Vue
230 lines
5.3 KiB
Vue
<template>
|
|
<view class='base-info'>
|
|
<view class="blank-info">
|
|
<view class='my-feed' v-if="isAdd" @click="linkToIndex()">
|
|
<view class="my-feed-info">
|
|
<i class="iconfont icon-bianzu25" style="font-size: 16px;color: #2797ff;margin-right: 5px;"></i>
|
|
<view>我的反馈记录</view>
|
|
</view>
|
|
<view>
|
|
<u-icon name="arrow-right" size="16"></u-icon>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<!-- 反馈类型 -->
|
|
|
|
<view class='label-info'>
|
|
<i class="iconfont icon-Rectangle" style="font-size: 18px;color: #2797ff;"></i>
|
|
<view>具体建议内容</view>
|
|
</view>
|
|
<view class="textarea-info">
|
|
<u--textarea v-model="model.INFO" :disabled="!isAdd" placeholder="请输入反馈意见" border="none"
|
|
height="120"></u--textarea>
|
|
</view>
|
|
|
|
<view class='label-info'>
|
|
<i class="iconfont icon-Rectangle" style="font-size: 18px;color: #2797ff;"></i>
|
|
<view>上传附件</view>
|
|
</view>
|
|
<view style="background-color: #fff;padding: 20px 15px 20px 15px;">
|
|
<full-upload v-model="model.Nav_Files" :isShowBtn='isAdd' :listProp='listProp' :isShowBlueButton="false"
|
|
:listPropVal='listPropVal'></full-upload>
|
|
</view>
|
|
|
|
|
|
<!-- <view class='label-info'>回复</view> -->
|
|
<view class='label-info' v-if="model.STATUS === 30">
|
|
<i class="iconfont icon-Rectangle" style="font-size: 18px;color: #2797ff;"></i>
|
|
<view>回复</view>
|
|
</view>
|
|
<view class="textarea-info" v-if="model.STATUS === 30">
|
|
<u--textarea v-model="model.BACKINFO" :disabled="!isAdd" placeholder="请输入反馈意见" border="none"
|
|
height="120"></u--textarea>
|
|
</view>
|
|
<view class="btn-info">
|
|
<button @click="formSubmit" type="primary" v-if="isAdd" class='save-btn'>提交</button>
|
|
</view>
|
|
|
|
<show-toast></show-toast>
|
|
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import {
|
|
feedBack,
|
|
feedBackGet
|
|
} from '../../../services/common'
|
|
import {
|
|
guid,
|
|
initFilter,
|
|
extendRule,
|
|
extendInclude
|
|
} from '../../../utils/common'
|
|
import showToast from '../../../components/custom/show-info/show-toast.vue'
|
|
|
|
export default {
|
|
data() {
|
|
return {
|
|
listProp: [],
|
|
listPropVal: [],
|
|
isAdd: true,
|
|
model: {
|
|
ID: '',
|
|
INFO: '',
|
|
USER_ID: '',
|
|
DEPARTMENT_ID: '',
|
|
STATUS: 0,
|
|
Nav_Files: []
|
|
},
|
|
rules: {
|
|
INFO: [{
|
|
type: 'string',
|
|
required: true,
|
|
message: '反馈意见不能为空',
|
|
trigger: ['blur', 'change']
|
|
}, {
|
|
max: 400,
|
|
message: '反馈意见最多400字',
|
|
trigger: ['blur', 'change']
|
|
}]
|
|
},
|
|
}
|
|
},
|
|
onLoad(option) {
|
|
if (option.isAdd) {
|
|
if (option.isAdd === 'false')
|
|
this.isAdd = false
|
|
}
|
|
if (this.isAdd == false) {
|
|
this.model.ID = option.ID //数据加载
|
|
this.loadData()
|
|
} else {
|
|
this.listProp.push('FDDEBACK_ID')
|
|
this.model.ID = guid()
|
|
this.listPropVal.push(this.model.ID)
|
|
}
|
|
},
|
|
methods: {
|
|
formSubmit() {
|
|
if (this.model.INFO === '' || this.model.BACKINFO === '') {
|
|
console.log(this.model.INFO,'000000011')
|
|
this.$showToast({
|
|
title: "反馈意见不能为空",
|
|
content: "",
|
|
icon: 'fail',
|
|
success: res => {}
|
|
});
|
|
return
|
|
}
|
|
const appInfoData = uni.getStorageSync('appInfo')
|
|
if (appInfoData.User == undefined) {
|
|
uni.$showErrorInfo('获取人员信息失败')
|
|
return false
|
|
} else if (appInfoData.User.DEPARTMENT_ID == undefined) {
|
|
uni.$showErrorInfo('获取人员部门失败')
|
|
return false
|
|
}
|
|
|
|
this.model.ORG_ID = uni.getStorageSync('orgId')
|
|
this.model.USER_ID = appInfoData.User.ID
|
|
this.model.DEPARTMENT_ID = appInfoData.User.DEPARTMENT_ID
|
|
this.model.STATUS = 10
|
|
feedBack(this.model).then(res => {
|
|
if (res.IsSuccessful) {
|
|
uni.$showMsgFunc('反馈成功!', () => {
|
|
uni.navigateBack()
|
|
}, 'success', 1000)
|
|
} else {
|
|
uni.$showErrorInfo('操作失败')
|
|
}
|
|
})
|
|
},
|
|
linkToIndex() {
|
|
uni.navigateTo({
|
|
url: 'feedBackIndex'
|
|
})
|
|
},
|
|
loadData() {
|
|
this.pageIndex++
|
|
const orgId = uni.getStorageSync('orgId')
|
|
let json = initFilter(orgId, "", "CREATE_TIME", 1, this.pageIndex);
|
|
extendRule(json, 'ID', 1, this.model.ID)
|
|
extendInclude(json, "Nav_Files.Nav_ImgFile.Nav_File")
|
|
feedBackGet(json).then(res => {
|
|
this.model = res
|
|
})
|
|
},
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
.base-info {
|
|
/* padding: 16px; */
|
|
width: 100%;
|
|
height: 100vh;
|
|
position: relative;
|
|
box-sizing: border-box;
|
|
background-color: #ffffff;
|
|
font-size: 16px;
|
|
}
|
|
|
|
.blank-info {
|
|
padding: 0px 0px 5px 0px;
|
|
background-color: #F1F2F8;
|
|
}
|
|
|
|
.my-feed {
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
background-color: #ffffff;
|
|
padding: 20px 10px 10px 10px;
|
|
}
|
|
.textarea-info {
|
|
padding: 10px 15px;
|
|
}
|
|
.textarea-info >>> .u-textarea {
|
|
background-color: #f5f7fa;
|
|
border-radius: 10px;
|
|
}
|
|
|
|
.my-feed-info {
|
|
display: flex;
|
|
flex-direction: row;
|
|
align-items: center;
|
|
margin-left: 2px;
|
|
}
|
|
|
|
.label-info {
|
|
margin: 20px 0px 10px 10px;
|
|
display: flex;
|
|
flex-direction: row;
|
|
align-items: center;
|
|
text-align: center;
|
|
}
|
|
.tabs-info {
|
|
height: 15px;
|
|
width: 4px;
|
|
background-color: #2797ff;
|
|
margin: 0px 8px;
|
|
}
|
|
|
|
.info-form {}
|
|
|
|
.save-btn {
|
|
margin-top: 20px;
|
|
}
|
|
|
|
.upload-title {
|
|
color: #303133;
|
|
font-size: 15px;
|
|
line-height: 22px;
|
|
padding: 20px 10px;
|
|
}
|
|
.btn-info {
|
|
padding: 20px;
|
|
}
|
|
</style> |