培训通知 通知显示

培训记录  考核与不考核做区分
多选 文本显示 添加公共方法
This commit is contained in:
wyw 2026-03-03 14:06:31 +08:00
parent bc54c7d446
commit c715cf7eb7
4 changed files with 515 additions and 166 deletions

View File

@ -3,57 +3,90 @@
<view class="card"> <view class="card">
<view class="background"></view> <view class="background"></view>
<view> <view>
<u--form labelPosition="left" labelWidth="auto" labelAlign="center" :model="model" :rules="rules" ref="wForm" errorType="border-bottom" class="demo-ruleForm"> <u--form labelPosition="left" labelWidth="auto" labelAlign="center" :model="model" :rules="rules"
ref="wForm" errorType="border-bottom" class="demo-ruleForm">
<u-form-item required label="培训名称" prop="NAME" borderBottom> <u-form-item required label="培训名称" prop="NAME" borderBottom>
<u--input v-model="model.NAME" border="none" slot="right" inputAlign="right" fontSize="14px" placeholder="请输入培训名称"></u--input> <u--input v-model="model.NAME" border="none" slot="right" inputAlign="right" fontSize="14px"
placeholder="请输入培训名称"></u--input>
</u-form-item> </u-form-item>
<u-form-item required label="培训类型" prop="Nav_TrainType.NAME" borderBottom @click="handleChange('Nav_TrainType','')"> <u-form-item required label="培训类型" prop="Nav_TrainType.NAME" borderBottom
<u--input v-if="model.Nav_TrainType" v-model="model.Nav_TrainType.NAME" placeholder="请选择培训类型" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> @click="handleChange('Nav_TrainType','')">
<u--input v-if="model.Nav_TrainType" v-model="model.Nav_TrainType.NAME" placeholder="请选择培训类型"
border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"> <u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12">
</u-icon> </u-icon>
</u-form-item> </u-form-item>
<u-form-item label="培训性质" prop="IN_OUT_SHOW" borderBottom @click="handleShowSheet({title: '培训性质', name: 'TrainInOut'})"> <u-form-item label="培训性质" prop="IN_OUT_SHOW" borderBottom
<u--input :value="model.IN_OUT_SHOW" placeholder="请选择培训性质" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> @click="handleShowSheet({title: '培训性质', name: 'TrainInOut'})">
<u--input :value="model.IN_OUT_SHOW" placeholder="请选择培训性质" border="none" inputAlign="right"
disabled disabledColor="#fff" fontSize="14px"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"></u-icon> <u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"></u-icon>
</u-form-item> </u-form-item>
<u-form-item required label="培训级别" prop="LEVEL_SHOW" borderBottom @click="handleShowSheet({title: '层级', name: 'FMDepartmentType'})"> <u-form-item required label="培训级别" prop="LEVEL_SHOW" borderBottom
<u--input :value="model.LEVEL_SHOW" placeholder="请选择层级" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> @click="handleShowSheet({title: '层级', name: 'FMDepartmentType'})">
<u--input :value="model.LEVEL_SHOW" placeholder="请选择层级" border="none" inputAlign="right"
disabled disabledColor="#fff" fontSize="14px"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"></u-icon> <u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"></u-icon>
</u-form-item> </u-form-item>
<u-form-item label="开始时间" required prop="TRAIN_START_TIME" borderBottom @click="showCheckDate({ name: 'TRAIN_START_TIME'})"> <u-form-item label="开始时间" required prop="TRAIN_START_TIME" borderBottom
<u--input disabledColor="#fff" v-model="model.TRAIN_START_TIME" disabled placeholder="请选择开始时间" suffixIcon="arrow-down" suffixIconStyle="font-size:12px" fontSize="14px" border="none" @click="showCheckDate({ name: 'TRAIN_START_TIME'})">
<u--input disabledColor="#fff" v-model="model.TRAIN_START_TIME" disabled placeholder="请选择开始时间"
suffixIcon="arrow-down" suffixIconStyle="font-size:12px" fontSize="14px" border="none"
customStyle="margin:0px;display:flex;padding:3px 0px" inputAlign="right"> customStyle="margin:0px;display:flex;padding:3px 0px" inputAlign="right">
</u--input> </u--input>
</u-form-item> </u-form-item>
<u-form-item label="结束时间" required prop="TRAIN_END_TIME" borderBottom @click="showCheckDate({name: 'TRAIN_END_TIME'})"> <u-form-item label="结束时间" required prop="TRAIN_END_TIME" borderBottom
<u--input disabledColor="#fff" v-model="model.TRAIN_END_TIME" disabled placeholder="请选择结束时间" suffixIcon="arrow-down" suffixIconStyle="font-size:12px" fontSize="14px" border="none" @click="showCheckDate({name: 'TRAIN_END_TIME'})">
<u--input disabledColor="#fff" v-model="model.TRAIN_END_TIME" disabled placeholder="请选择结束时间"
suffixIcon="arrow-down" suffixIconStyle="font-size:12px" fontSize="14px" border="none"
inputAlign="right" customStyle="margin:0px;display:flex;padding:3px 0px"> inputAlign="right" customStyle="margin:0px;display:flex;padding:3px 0px">
</u--input> </u--input>
</u-form-item> </u-form-item>
<u-form-item required label="培训地点" prop="TRAIN_ADDR" borderBottom> <u-form-item required label="培训地点" prop="TRAIN_ADDR" borderBottom>
<u--input v-model="model.TRAIN_ADDR" border="none" slot="right" inputAlign="right" fontSize="14px" placeholder="请填写培训地点"></u--input> <u--input v-model="model.TRAIN_ADDR" border="none" slot="right" inputAlign="right"
fontSize="14px" placeholder="请填写培训地点"></u--input>
</u-form-item> </u-form-item>
<u-form-item required label="培训学时" prop="HOURS" borderBottom> <u-form-item required label="培训学时" prop="HOURS" borderBottom>
<u--input v-model="model.HOURS" type="number" border="none" slot="right" placeholder="请填写培训学时" inputAlign="right" fontSize="14px"></u--input> <u--input v-model="model.HOURS" type="number" border="none" slot="right" placeholder="请填写培训学时"
inputAlign="right" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item required label="培训老师" prop="Nav_UserTeacher.NAME" borderBottom @click="handleChange('Nav_UserTeacher','')"> <u-form-item required label="培训老师" prop="Nav_UserTeacher.NAME" borderBottom
<u--input v-model="(model.Nav_UserTeacher||{}).NAME" border="none" placeholder="请选择培训老师" inputAlign="right" fontSize="14px"></u--input> @click="handleChange('Nav_UserTeacher','')">
<u--input v-model="(model.Nav_UserTeacher||{}).NAME" border="none" placeholder="请选择培训老师"
inputAlign="right" fontSize="14px"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"> <u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12">
</u-icon> </u-icon>
</u-form-item> </u-form-item>
<u-form-item required label="培训形式" prop="TRAINTYPE_SHOW" borderBottom @click="handleShowSheet({title: '培训形式', name: 'TrainType'})"> <u-form-item required label="培训形式" prop="TRAINTYPE_SHOW" borderBottom
<u--input v-model="model.TRAINTYPE_SHOW" placeholder="请选择培训形式" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> @click="handleShowSheet({title: '培训形式', name: 'TrainType'})">
<u--input v-model="model.TRAINTYPE_SHOW" placeholder="请选择培训形式" border="none" inputAlign="right"
disabled disabledColor="#fff" fontSize="14px"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"></u-icon> <u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"></u-icon>
</u-form-item> </u-form-item>
<u-form-item required label="考核方式" prop="CHECKTYPE_SHOW" borderBottom @click="handleShowSheet({title: '培训形式', name: 'PlanCheckType'})"> <u-form-item required label="考核方式" prop="CHECKTYPE_SHOW" borderBottom
<u--input v-model="model.CHECKTYPE_SHOW" placeholder="请选择考核方式" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> @click="handleShowSheet({title: '培训形式', name: 'PlanCheckType'})">
<u--input v-model="model.CHECKTYPE_SHOW" placeholder="请选择考核方式" border="none" inputAlign="right"
disabled disabledColor="#fff" fontSize="14px"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"> <u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12">
</u-icon> </u-icon>
</u-form-item> </u-form-item>
<u-form-item required class="custom-form-item" label="培训内容" prop="DetailPost" borderBottom @click="handleQuerySelect({ formIndex: 'Nav_TrainContentList', isMultiple: true})"> <u-form-item class="custom-form-item" label="培训课件" prop="DetailPost" borderBottom
@click="handleQuerySelect({ formIndex: 'Nav_ListCour', isMultiple: true})">
<view slot="right" class="custom-form-item-right"> <view slot="right" class="custom-form-item-right">
<view class="multi"> <view class="multi">
<u--text v-for="(i, k) in model.Nav_TrainContentList" :key="k" class="item" :text="k + 1 + '. ' + i.Nav_Point.NAME" :size="14"></u--text> <u--text v-for="(i, k) in model.Nav_ListCour" :key="k" class="item"
:text="k + 1 + '. ' + i.Nav_Cour.NAME" :size="14"></u--text>
</view>
<u-icon class="icon" name="arrow-down" size="12">
</u-icon>
</view>
</u-form-item>
<u-form-item class="custom-form-item" label="培训内容" prop="DetailPost" borderBottom
@click="handleQuerySelect({ formIndex: 'Nav_TrainContentList', isMultiple: true})">
<view slot="right" class="custom-form-item-right">
<view class="multi">
<u--text v-for="(i, k) in model.Nav_TrainContentList" :key="k" class="item"
:text="k + 1 + '. ' + i.Nav_Point.NAME" :size="14"></u--text>
</view> </view>
<u-icon class="icon" name="arrow-down" size="12"> <u-icon class="icon" name="arrow-down" size="12">
</u-icon> </u-icon>
@ -62,37 +95,56 @@
<u-form-item label="培训安排及要求" prop="TRAIN_PLAN" borderBottom> <u-form-item label="培训安排及要求" prop="TRAIN_PLAN" borderBottom>
</u-form-item> </u-form-item>
<u--textarea required v-model="model.TRAIN_PLAN" border="surround"></u--textarea> <u--textarea required v-model="model.TRAIN_PLAN" border="surround"></u--textarea>
<u-form-item label="是否需要培训效果评估" prop="NEED_EVALUATION" borderBottom @click="handleShowSheet({title: '是否需要培训效果评估', name: 'SETrainNeedSuvey'})"> <u-form-item label="是否需要培训效果评估" prop="NEED_EVALUATION" borderBottom
<u--input :value="model.NEED_EVALUATION_SHOW" placeholder="请选择" border="none" inputAlign="right" disabled disabledColor="#fff"></u--input> @click="handleShowSheet({title: '是否需要培训效果评估', name: 'SETrainNeedSuvey'})">
<u--input :value="model.NEED_EVALUATION_SHOW" placeholder="请选择" border="none" inputAlign="right"
disabled disabledColor="#fff"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"></u-icon> <u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"></u-icon>
</u-form-item> </u-form-item>
<u-form-item label="是否触发培训记录" prop="CREATE_NOTIFY_RECORD" borderBottom> <u-form-item label="是否触发培训记录" prop="CREATE_NOTIFY_RECORD" borderBottom>
<u-switch inactiveColor="rgb(230, 230, 230)" size="24" space="4" v-model="model.CREATE_NOTIFY_RECORD" @change="changeSwitch" border="none" slot="right" inputAlign="right"></u-switch> <u-switch inactiveColor="rgb(230, 230, 230)" size="24" space="4"
v-model="model.CREATE_NOTIFY_RECORD" @change="changeSwitch" border="none" slot="right"
inputAlign="right"></u-switch>
</u-form-item> </u-form-item>
<u-form-item required label="记录人员" prop="Nav_RecordUser.NAME" borderBottom @click="handleChange('Nav_RecordUser','')"> <u-form-item required label="记录人员" prop="Nav_RecordUser.NAME" borderBottom
<u--input v-if="model.Nav_RecordUser" v-model="model.Nav_RecordUser.NAME" placeholder="记录人员" border="none" inputAlign="right" disabled disabledColor="#fff"></u--input> @click="handleChange('Nav_RecordUser','')">
<u--input v-if="model.Nav_RecordUser" v-model="model.Nav_RecordUser.NAME" placeholder="记录人员"
border="none" inputAlign="right" disabled disabledColor="#fff"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12"> <u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12">
</u-icon> </u-icon>
</u-form-item> </u-form-item>
<view class="upload-title">附件</view> <view class="upload-title">附件</view>
<full-upload v-model="model.Nav_Files" :isShowBtn='true' :listProp='listPropUpload' :listPropVal='listPropValUpload'></full-upload> <full-upload v-model="model.Nav_Files" :isShowBtn='true' :listProp='listPropUpload'
:listPropVal='listPropValUpload'></full-upload>
<u-form-item required label="培训人员"> <u-form-item required label="培训人员">
<u-icon name="man-add" @click="handleShowUserSelector()" size="24" color="#3d9cff" slot="right"></u-icon> <u-icon name="man-add" @click="handleShowUserSelector()" size="24" color="#3d9cff"
slot="right"></u-icon>
</u-form-item> </u-form-item>
<!-- <view v-show="!!model.Nav_TrainUserList.length" class="tag-view">
<uni-tag class="tag" v-for="(i, k) in model.Nav_TrainUserList.filter(i => !i.IS_DELETED)"
:key="k" :inverted="true" :text="i.NAME" type="primary" />
</view> -->
<view v-show="!!model.Nav_TrainUserList.length" class="tag-view"> <view v-show="!!model.Nav_TrainUserList.length" class="tag-view">
<uni-tag class="tag" v-for="(i, k) in model.Nav_TrainUserList.filter(i => !i.IS_DELETED)" :key="k" :inverted="true" :text="i.NAME" type="primary" /> <uni-tag class="tag" v-for="(i, k) in model.Nav_TrainUserList.filter(i => !i.IS_DELETED)"
:key="k" :inverted="true" :text="i.Nav_User.NAME" type="primary" />
</view> </view>
</u--form> </u--form>
</view> </view>
</view> </view>
<query-selector :show="showPopup" :lists="Lists" @close="handleClosePopup" @search="handleSearch" @select="handleSelected" /> <query-selector :show="showPopup" :lists="Lists" @close="handleClosePopup" @search="handleSearch"
<u-picker :show="comPickerInfo.showSheet" :columns="comPickerInfo.columns" @confirm="onConfirmPicker" :defaultIndex="[0]" @close="closePicker" @cancel="closePicker" keyName="NAME"></u-picker> @select="handleSelected" />
<u-picker :show="comPickerInfo.showSheet" :columns="comPickerInfo.columns" @confirm="onConfirmPicker"
:defaultIndex="[0]" @close="closePicker" @cancel="closePicker" keyName="NAME"></u-picker>
<view class="bottom-button"> <view class="bottom-button">
</view> </view>
<u-datetime-picker :show="dateTimePickerInfo.showCheckDate" mode="datetime" v-model='dateTimePickerInfo.defaultDateTime' :formatter="formatter" @confirm="handleCheckDate" <u-datetime-picker :show="dateTimePickerInfo.showCheckDate" mode="datetime"
@close="dateTimePickerInfo.showCheckDate = false;" @cancel="dateTimePickerInfo.showCheckDate = false;"></u-datetime-picker> v-model='dateTimePickerInfo.defaultDateTime' :formatter="formatter" @confirm="handleCheckDate"
<query-selector :multiple="qsCom.isMultiple" :total="curTotal" :show="qsCom.show" :lists="qsCom.lists" @close="onCloseQS" @search="onSearchQS" @select="onSelectedQS" /> @close="dateTimePickerInfo.showCheckDate = false;"
<people-selector :defaultChecked="peopleSelectOption.defaultChecked" :show="peopleSelectOption.showSelector" @select="handleSelectorPeople" @close="peopleSelectOption.showSelector = false"> @cancel="dateTimePickerInfo.showCheckDate = false;"></u-datetime-picker>
<query-selector :multiple="qsCom.isMultiple" :total="curTotal" :show="qsCom.show" :lists="qsCom.lists"
@close="onCloseQS" @search="onSearchQS" @select="onSelectedQS" :defaultChecked="qsCom.defaultChecked" />
<people-selector :defaultChecked="peopleSelectOption.defaultChecked" :show="peopleSelectOption.showSelector"
@select="handleSelectorPeople" @close="peopleSelectOption.showSelector = false">
</people-selector> </people-selector>
<view class="bottom-button"> <view class="bottom-button">
<u-button type="primary" @click="submit" color="#3d4b70">提交</u-button> <u-button type="primary" @click="submit" color="#3d4b70">提交</u-button>
@ -222,6 +274,7 @@
qsCom: { qsCom: {
show: false, show: false,
lists: [], lists: [],
defaultChecked: [],
formIndex: undefined, formIndex: undefined,
isMultiple: false, isMultiple: false,
}, },
@ -343,6 +396,12 @@
this.model.TRAIN_END_TIME = uni.$u.timeFormat(e.value, this.model.TRAIN_END_TIME = uni.$u.timeFormat(e.value,
'yyyy-mm-dd hh:MM') 'yyyy-mm-dd hh:MM')
} }
//
if (this.model.TRAIN_START_TIME && this.model.TRAIN_END_TIME) {
this.model.HOURS = ((new Date(this.model.TRAIN_END_TIME).getTime() - new Date(this.model
.TRAIN_START_TIME).getTime()) / 1000 / 60 / 45.0).toFixed(1)
}
this.dateTimePickerInfo.showCheckDate = false this.dateTimePickerInfo.showCheckDate = false
}, },
//end //end
@ -415,13 +474,26 @@
//start //start
async handleQuerySelect(opt) { async handleQuerySelect(opt) {
let column = await this.handleGet(opt, 'init') let column = await this.handleGet(opt, 'init')
var defaultChecked = []
if (opt.formIndex == 'Nav_TrainContentList') {
if (this.model.Nav_TrainContentList != null && this.model.Nav_TrainContentList.length > 0)
this.model.Nav_TrainContentList.forEach(e => {
defaultChecked.push(e.Nav_Point)
})
} else if (opt.formIndex == 'Nav_ListCour') {
if (this.model.Nav_ListCour != null && this.model.Nav_ListCour.length > 0)
this.model.Nav_ListCour.forEach(e => {
defaultChecked.push(e.Nav_Cour)
})
}
if (column && column.length) { if (column && column.length) {
this.qsCom = { this.qsCom = {
show: true, show: true,
name: opt.NAME, name: opt.NAME,
formIndex: opt.formIndex, formIndex: opt.formIndex,
isMultiple: opt.isMultiple, isMultiple: opt.isMultiple,
lists: column lists: column,
defaultChecked: defaultChecked
} }
} }
}, },
@ -437,6 +509,8 @@
}) })
}, },
async handleGet(opt, value, pageIndex) { async handleGet(opt, value, pageIndex) {
var api = (opt.formIndex == 'Nav_TrainContentList') ? '/SE/TestEnumPoint/OrderPaged' :
'/SE/Coursewearlibrary/OrderPaged'
const json = initFilter(this.ORG_ID, '', "", 0, pageIndex || 1) const json = initFilter(this.ORG_ID, '', "", 0, pageIndex || 1)
if (value !== 'init') { if (value !== 'init') {
const tempGroup = initFilterGroup(false); const tempGroup = initFilterGroup(false);
@ -448,7 +522,7 @@
json.Start = (pageIndex - 1) * 20; json.Start = (pageIndex - 1) * 20;
} }
let result = [] let result = []
const raw = await getRequest(json, "/SE/TestEnumPoint/OrderPaged").then(res => { const raw = await getRequest(json, api).then(res => {
this.curTotal = res.TotalCount this.curTotal = res.TotalCount
return res return res
}) })
@ -465,11 +539,14 @@
const { const {
formIndex, formIndex,
} = this.qsCom } = this.qsCom
//formIndex Nav_ListCour Nav_TrainContentList
if (formIndex == 'Nav_TrainContentList') {
this.model.Nav_TrainContentList = []; this.model.Nav_TrainContentList = [];
val.forEach(item => { val.forEach(item => {
let obj = { let obj = {
POINT_ID: item.ID, POINT_ID: item.ID,
Nav_Point: { Nav_Point: {
ID: item.ID,
NAME: item.NAME NAME: item.NAME
}, },
ID: guid(), ID: guid(),
@ -478,7 +555,24 @@
} }
this.model.Nav_TrainContentList.push(obj); this.model.Nav_TrainContentList.push(obj);
}) })
} else if (formIndex == 'Nav_ListCour') {
this.model.Nav_ListCour = [];
val.forEach(item => {
let obj = {
COURSEWEARLIBRARY_ID: item.ID,
Nav_Cour: {
ID: item.ID,
NAME: item.NAME
},
ID: guid(),
NOTIFY_ID: this.model.ID,
ORG_ID: this.ORG_ID,
}
this.model.Nav_ListCour.push(obj);
})
}
this.qsCom.show = false this.qsCom.show = false
this.qsCom.defaultChecked = []
}, },
onCloseQS() { onCloseQS() {
this.qsCom = { this.qsCom = {
@ -539,11 +633,16 @@
extendRule(json, 'ID', 1, this.model.ID) extendRule(json, 'ID', 1, this.model.ID)
getRequest(json, "/SE/TrainNotify/Get").then(res => { getRequest(json, "/SE/TrainNotify/Get").then(res => {
this.model = res this.model = res
this.model.LEVEL_SHOW = res.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(item => item.code === res.LEVEL)?.name : ''; this.model.LEVEL_SHOW = res.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(
this.model.TRAINTYPE_SHOW = res.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(item => item.code === res.TRAINTYPE)?.name : ''; item => item.code === res.LEVEL)?.name : '';
this.model.CHECKTYPE_SHOW = res.CHECKTYPE !== undefined ? this.enumsData['PlanCheckType'].find(item => item.code === res.CHECKTYPE)?.name : ''; this.model.TRAINTYPE_SHOW = res.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(
this.model.IN_OUT_SHOW = res.IN_OUT !== undefined ? this.enumsData['TrainInOut'].find(item => item.code === res.IN_OUT)?.name : ''; item => item.code === res.TRAINTYPE)?.name : '';
this.model.NEED_EVALUATION_SHOW = res.NEED_EVALUATION !== undefined ? this.enumsData['SETrainNeedSuvey'].find(item => item.code === res.NEED_EVALUATION)?.name : ''; this.model.CHECKTYPE_SHOW = res.CHECKTYPE !== undefined ? this.enumsData['PlanCheckType'].find(
item => item.code === res.CHECKTYPE)?.name : '';
this.model.IN_OUT_SHOW = res.IN_OUT !== undefined ? this.enumsData['TrainInOut'].find(item =>
item.code === res.IN_OUT)?.name : '';
this.model.NEED_EVALUATION_SHOW = res.NEED_EVALUATION !== undefined ? this.enumsData[
'SETrainNeedSuvey'].find(item => item.code === res.NEED_EVALUATION)?.name : '';
}) })
}, },
closePicker() { closePicker() {
@ -615,9 +714,7 @@
submit() { submit() {
const ele = this.$refs const ele = this.$refs
ele['wForm'].validate().then(res => { ele['wForm'].validate().then(res => {
this.modelEdit = JSON.parse(JSON.stringify(this.model)) this.modelEdit = JSON.parse(JSON.stringify(this.model))
this.modelEdit.PUBLISH = "SaveAndNotify"; this.modelEdit.PUBLISH = "SaveAndNotify";
if (this.TaskID != "") { if (this.TaskID != "") {
this.modelEdit.TaskID = this.TaskID; this.modelEdit.TaskID = this.TaskID;

View File

@ -3,46 +3,64 @@
<view class="card"> <view class="card">
<view class="background"></view> <view class="background"></view>
<view> <view>
<u--form labelPosition="left" labelWidth="auto" labelAlign="center" :model="model" class="demo-ruleForm"> <u--form labelPosition="left" labelWidth="auto" labelAlign="center" :model="model"
class="demo-ruleForm">
<u-form-item label="培训名称:" prop="NAME" borderBottom> <u-form-item label="培训名称:" prop="NAME" borderBottom>
<u--input v-model="model.NAME" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.NAME" border="none" slot="right" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="发起时间:" prop="LAUNCH_TIME" borderBottom> <u-form-item label="发起时间:" prop="LAUNCH_TIME" borderBottom>
<u--input v-model="model.LAUNCH_TIME" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.LAUNCH_TIME" border="none" slot="right" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="发起部门:" prop="Nav_LaunchDepartment.NAME" borderBottom> <u-form-item label="发起部门:" prop="Nav_LaunchDepartment.NAME" borderBottom>
<u--input v-if="model.Nav_LaunchDepartment" v-model="model.Nav_LaunchDepartment.NAME" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-if="model.Nav_LaunchDepartment" v-model="model.Nav_LaunchDepartment.NAME"
border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff"
fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="发起人员:" prop="Nav_LaunchUser.NAME" borderBottom> <u-form-item label="发起人员:" prop="Nav_LaunchUser.NAME" borderBottom>
<u--input v-if="model.Nav_LaunchUser" v-model="model.Nav_LaunchUser.NAME" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-if="model.Nav_LaunchUser" v-model="model.Nav_LaunchUser.NAME" border="none"
slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训类型:" prop="Nav_LaunchUser.NAME" borderBottom> <u-form-item label="培训类型:" prop="Nav_LaunchUser.NAME" borderBottom>
<u--input v-if="model.Nav_TrainType" v-model="model.Nav_TrainType.NAME" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-if="model.Nav_TrainType" v-model="model.Nav_TrainType.NAME" border="none"
slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训级别:" prop="LEVEL" borderBottom> <u-form-item label="培训级别:" prop="LEVEL" borderBottom>
<u--input v-model="model.LEVEL_SHOW" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.LEVEL_SHOW" border="none" slot="right" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="开始时间:" prop="TRAIN_START_TIME" borderBottom> <u-form-item label="开始时间:" prop="TRAIN_START_TIME" borderBottom>
<u--input v-model="model.TRAIN_START_TIME" border="none" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.TRAIN_START_TIME" border="none" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="结束时间:" prop="TRAIN_END_TIME" borderBottom> <u-form-item label="结束时间:" prop="TRAIN_END_TIME" borderBottom>
<u--input v-model="model.TRAIN_END_TIME" border="none" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.TRAIN_END_TIME" border="none" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训地点:" prop="TRAIN_ADDR" borderBottom> <u-form-item label="培训地点:" prop="TRAIN_ADDR" borderBottom>
<u--input v-model="model.TRAIN_ADDR" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.TRAIN_ADDR" border="none" slot="right" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训学时:" prop="HOURS" borderBottom> <u-form-item label="培训学时:" prop="HOURS" borderBottom>
<u--input v-model="model.HOURS" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.HOURS" border="none" slot="right" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训老师:" prop="TRAIN_TEACHER" borderBottom> <u-form-item label="培训老师:" prop="TRAIN_TEACHER" borderBottom>
<u--input v-model="(model.Nav_UserTeacher||{}).NAME" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="(model.Nav_UserTeacher||{}).NAME" border="none" slot="right"
inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训形式:" prop="" borderBottom> <u-form-item label="培训形式:" prop="" borderBottom>
<u--input v-model="model.TRAINTYPE_SHOW" border="none" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.TRAINTYPE_SHOW" border="none" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="考核方式:" prop="Nav_TrainCheckType.NAME" borderBottom> <u-form-item label="考核方式:" prop="Nav_TrainCheckType.NAME" borderBottom>
<u--input v-model="model.CHECKTYPE_SHOW" border="none" slot="right" inputAlign="right" disabled disabledColor="#ffffff" fontSize="14px"></u--input> <u--input v-model="model.CHECKTYPE_SHOW" border="none" slot="right" inputAlign="right" disabled
disabledColor="#ffffff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训课件:" prop='model.Nav_ListCour_Show' borderBottom>
</u-form-item>
<u-textarea autoHeight v-html="model.Nav_ListCour_Show" border="none" disabled></u-textarea>
<u-form-item label="培训内容:" prop="TRAINCONTENT" borderBottom> <u-form-item label="培训内容:" prop="TRAINCONTENT" borderBottom>
</u-form-item> </u-form-item>
<u-textarea autoHeight v-html="model.TRAINCONTENT" border="none" disabled></u-textarea> <u-textarea autoHeight v-html="model.TRAINCONTENT" border="none" disabled></u-textarea>
@ -53,7 +71,8 @@
</u-form-item> </u-form-item>
<rich-text v-html="model.users" border="none" disabled style="font-size: 14px;"></rich-text> <rich-text v-html="model.users" border="none" disabled style="font-size: 14px;"></rich-text>
<view class="upload-title">附件</view> <view class="upload-title">附件</view>
<full-upload v-model="model.Nav_Files" :listProp='listPropUpload' :listPropVal='listPropValUpload' :isShowBtn="false"></full-upload> <full-upload v-model="model.Nav_Files" :listProp='listPropUpload' :listPropVal='listPropValUpload'
:isShowBtn="false"></full-upload>
</u--form> </u--form>
</view> </view>
@ -64,8 +83,10 @@
<u--textarea height='3em' v-model="LEAVE_REASON" placeholder="请输入请假理由"></u--textarea> <u--textarea height='3em' v-model="LEAVE_REASON" placeholder="请输入请假理由"></u--textarea>
</view> </view>
<view class="buttons"> <view class="buttons">
<u-button type="primary" color="#3d4b70" class="btn first-btn" @click="onChargeUserAgree(1)" text="参加"></u-button> <u-button type="primary" color="#3d4b70" class="btn first-btn" @click="onChargeUserAgree(1)"
<u-button color="#3d4b70" :plain="true" type="warning" @click="onChargeUserAgree(2)" text="请假"></u-button> text="参加"></u-button>
<u-button color="#3d4b70" :plain="true" type="warning" @click="onChargeUserAgree(2)"
text="请假"></u-button>
</view> </view>
</view> </view>
</u--form> </u--form>
@ -78,7 +99,8 @@
import { import {
initFilter, initFilter,
extendRule, extendRule,
extendInclude extendInclude,
getArryPropShow
} from '../../../../utils/common' } from '../../../../utils/common'
import { import {
getRequest, getRequest,
@ -167,6 +189,7 @@
extendInclude(json, 'Nav_TrainUserList.Nav_User'); extendInclude(json, 'Nav_TrainUserList.Nav_User');
extendInclude(json, 'Nav_Files.Nav_ImgFile'); extendInclude(json, 'Nav_Files.Nav_ImgFile');
extendInclude(json, "Nav_UserTeacher") extendInclude(json, "Nav_UserTeacher")
extendInclude(json, "Nav_ListCour.Nav_Cour")
getRequest(json, "/SE/TrainNotify/Get").then(res => { getRequest(json, "/SE/TrainNotify/Get").then(res => {
this.model = res this.model = res
let trainContent = ''; let trainContent = '';
@ -197,11 +220,17 @@
// this.model.LEVEL = this.transLevel(this.model.LEVEL); // this.model.LEVEL = this.transLevel(this.model.LEVEL);
this.model.TRAINCONTENT = trainContent; this.model.TRAINCONTENT = trainContent;
this.model.users = users; this.model.users = users;
this.model.LEVEL_SHOW = res.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(item => item.code === res.LEVEL)?.name : ''; this.model.LEVEL_SHOW = res.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(
this.model.TRAINTYPE_SHOW = res.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(item => item.code === res.TRAINTYPE)?.name : ''; item => item.code === res.LEVEL)?.name : '';
this.model.CHECKTYPE_SHOW = res.CHECKTYPE !== undefined ? this.enumsData['PlanCheckType'].find(item => item.code === res.CHECKTYPE)?.name : ''; this.model.TRAINTYPE_SHOW = res.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(
this.model.IN_OUT_SHOW = res.IN_OUT !== undefined ? this.enumsData['TrainInOut'].find(item => item.code === res.IN_OUT)?.name : ''; item => item.code === res.TRAINTYPE)?.name : '';
this.model.NEED_EVALUATION_SHOW = res.NEED_EVALUATION !== undefined ? this.enumsData['SETrainNeedSuvey'].find(item => item.code === res.NEED_EVALUATION)?.name : ''; this.model.CHECKTYPE_SHOW = res.CHECKTYPE !== undefined ? this.enumsData['PlanCheckType'].find(
item => item.code === res.CHECKTYPE)?.name : '';
this.model.IN_OUT_SHOW = res.IN_OUT !== undefined ? this.enumsData['TrainInOut'].find(item =>
item.code === res.IN_OUT)?.name : '';
this.model.NEED_EVALUATION_SHOW = res.NEED_EVALUATION !== undefined ? this.enumsData[
'SETrainNeedSuvey'].find(item => item.code === res.NEED_EVALUATION)?.name : '';
this.model.Nav_ListCour_Show = getArryPropShow(this.model.Nav_ListCour, 'Nav_Cour.NAME')
this.isLoadOK = true; this.isLoadOK = true;
}) })
}, },

View File

@ -3,72 +3,145 @@
<view class="card"> <view class="card">
<view class="background"></view> <view class="background"></view>
<view> <view>
<u--form labelPosition="left" labelWidth="auto" labelAlign="center" :model="model" :rules="rules" ref="wForm" errorType="border-bottom" class="demo-ruleForm"> <u--form labelPosition="left" labelWidth="auto" labelAlign="center" :model="model" :rules="rules"
ref="wForm" errorType="border-bottom" class="demo-ruleForm">
<u-form-item required label="培训名称:" prop="Nav_Notify.NAME" borderBottom> <u-form-item required label="培训名称:" prop="Nav_Notify.NAME" borderBottom>
<u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.NAME" border="none" slot="right" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.NAME" border="none" slot="right"
inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训类型:" prop="Nav_TrainType.NAME" borderBottom> <u-form-item label="培训类型:" prop="Nav_TrainType.NAME" borderBottom>
<u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.Nav_TrainType.NAME" placeholder="培训类型" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.Nav_TrainType.NAME"
placeholder="培训类型" border="none" inputAlign="right" disabled disabledColor="#fff"
fontSize="14px"></u--input>
</u-icon> </u-icon>
</u-form-item> </u-form-item>
<u-form-item label="培训级别:" prop="LEVEL" borderBottom> <u-form-item label="培训级别:" prop="LEVEL" borderBottom>
<u--input v-if="model.Nav_Notify" :value="model.Nav_Notify.LEVEL_SHOW" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" :value="model.Nav_Notify.LEVEL_SHOW" border="none"
inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="组织部门:" prop="LEVEL" borderBottom> <u-form-item label="组织部门:" prop="LEVEL" borderBottom>
<u--input v-if="model.Nav_Notify" :value="model.Nav_Notify.Nav_LaunchDepartment.NAME" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" :value="model.Nav_Notify.Nav_LaunchDepartment.NAME"
border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="开始时间" required prop="Nav_Notify.TRAIN_START_TIME" @click="showCheckDate({ name: 'TRAIN_START_TIME'})" borderBottom> <u-form-item label="开始时间" required prop="Nav_Notify.TRAIN_START_TIME"
<u--input v-if="model.Nav_Notify" disabledColor="#fff" v-model="model.Nav_Notify.TRAIN_START_TIME" disabled placeholder="请选择开始时间" suffixIcon="arrow-down" suffixIconStyle="font-size:12px" @click="showCheckDate({ name: 'TRAIN_START_TIME'})" borderBottom>
fontSize="14px" border="none" customStyle="margin:0px;display:flex;padding:3px 0px" inputAlign="right"> <u--input v-if="model.Nav_Notify" disabledColor="#fff"
v-model="model.Nav_Notify.TRAIN_START_TIME" disabled placeholder="请选择开始时间"
suffixIcon="arrow-down" suffixIconStyle="font-size:12px" fontSize="14px" border="none"
customStyle="margin:0px;display:flex;padding:3px 0px" inputAlign="right">
</u--input> </u--input>
</u-form-item> </u-form-item>
<u-form-item label="结束时间" required prop="Nav_Notify.TRAIN_END_TIME" @click="showCheckDate({name: 'TRAIN_END_TIME'})" borderBottom> <u-form-item label="结束时间" required prop="Nav_Notify.TRAIN_END_TIME"
<u--input v-if="model.Nav_Notify" disabledColor="#fff" v-model="model.Nav_Notify.TRAIN_END_TIME" border="none" disabled placeholder="请选择结束时间" suffixIcon="arrow-down" @click="showCheckDate({name: 'TRAIN_END_TIME'})" borderBottom>
suffixIconStyle="font-size:12px" fontSize="14px" customStyle="margin:0px;display:flex;padding:3px 0px" inputAlign="right"> <u--input v-if="model.Nav_Notify" disabledColor="#fff" v-model="model.Nav_Notify.TRAIN_END_TIME"
border="none" disabled placeholder="请选择结束时间" suffixIcon="arrow-down"
suffixIconStyle="font-size:12px" fontSize="14px"
customStyle="margin:0px;display:flex;padding:3px 0px" inputAlign="right">
</u--input> </u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训地点:" prop="TRAIN_ADDR" borderBottom> <u-form-item label="培训地点:" prop="TRAIN_ADDR" borderBottom>
<u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.TRAIN_ADDR" border="none" slot="right" inputAlign="right" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.TRAIN_ADDR" border="none"
slot="right" inputAlign="right" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训学时:" prop="HOURS" borderBottom> <u-form-item label="培训学时:" prop="HOURS" borderBottom>
<u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.HOURS" type="number" border="none" slot="right" inputAlign="right" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.HOURS" type="number" border="none"
slot="right" inputAlign="right" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训老师:" prop="TRAIN_TEACHER" borderBottom> <u-form-item label="培训老师:" prop="TRAIN_TEACHER" borderBottom>
<u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.TRAIN_TEACHER" border="none" slot="right" inputAlign="right" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.TRAIN_TEACHER" border="none"
slot="right" inputAlign="right" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="培训形式:" prop="TRAIN_MODEL" borderBottom> <u-form-item label="培训形式:" prop="TRAIN_MODEL" borderBottom>
<u--input v-if="model.Nav_Notify" :value="model.Nav_Notify.TRAINTYPE_SHOW" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" :value="model.Nav_Notify.TRAINTYPE_SHOW" border="none"
inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item label="考核方式:" prop="Nav_TrainCheckType.NAME" borderBottom> <u-form-item label="考核方式:" prop="Nav_TrainCheckType.NAME" borderBottom>
<u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.CHECKTYPE_SHOW" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input> <u--input v-if="model.Nav_Notify" v-model="model.Nav_Notify.CHECKTYPE_SHOW" border="none"
inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input>
</u-form-item> </u-form-item>
<u-form-item class="custom-form-item" label="培训课件:" prop="Nav_ListCour_Show" :borderBottom="false">
</u-form-item>
<u-textarea v-html="model.Nav_ListCour_Show" style="font-size: 14px;"></u-textarea>
<u-form-item class="custom-form-item" label="培训内容:" prop="DetailPost" :borderBottom="false"> <u-form-item class="custom-form-item" label="培训内容:" prop="DetailPost" :borderBottom="false">
</u-form-item> </u-form-item>
<u-textarea v-html="model.Nav_TrainContentList_SHOW" style="font-size: 14px;"></u-textarea> <u-textarea v-html="model.Nav_TrainContentList_SHOW" style="font-size: 14px;"></u-textarea>
<view class="upload-title">附件</view> <view class="upload-title">附件</view>
<full-upload v-model="model.Nav_Files" :isShowBtn='true' :listProp='listPropUpload' :listPropVal='listPropValUpload'></full-upload> <full-upload v-model="model.Nav_Files" :isShowBtn='true' :listProp='listPropUpload'
:listPropVal='listPropValUpload'></full-upload>
</u--form> </u--form>
</view> </view>
</view> </view>
<u-sticky offset-top="20"> <u-sticky offset-top="20">
<view class="sub-form"> <view class="sub-form">
<view class="sub-form-wrap"> <view class="sub-form-wrap">
<u--form labelPosition="left" labelWidth="auto" labelAlign="center" errorType="border-bottom" ref="sForm"> <u--form labelPosition="left" labelWidth="auto" labelAlign="center" errorType="border-bottom"
<!-- <u-collapse :border="false" accordion> --> ref="sForm">
<view style="margin-bottom: 16px;" v-for="(item, index) in model.Nav_Users"> <!-- 线上考核 只有参与与否是可以编辑的
<u-form-item :label="(index+1)+'. '+ item.Nav_User.NAME"> 线下考核 需要填写 是否合格 成绩 考卷等 -->
<u-subsection activeColor="#0eacf5" mode="subsection" :list="list" :current="item.STATUS" @change="sectionChange($event,item)"></u-subsection> <view v-if="model.Nav_Notify.CHECKTYPE==56||model.Nav_Notify.CHECKTYPE==81"
style="margin-bottom: 16px;" v-for="(item, index) in model.Nav_Users">
<!-- 状态 STATUS SETrainRecordUserStatusEnum 考核结果 EXAMINATION_RESULTS SEExaminationResultsEnum 分数 SCORE 附件 Nav_Files -->
<!-- 参与 = 0, 请假 = 1, 缺席 = 2, item.Nav_User.STATUS==1?'请假':(item.Nav_User.STATUS==2:'缺席':'参与')-->
<uni-card style="margin-bottom: 16px;" margin="0" spacing="0" :is-shadow="false">
<uni-collapse-item :title="(index+1)+'. '+ item.Nav_User.NAME +''+item.STATUS_SHOW+''"
name="1">
<u-form-item required label="参加状态" prop="STATUS" borderBottom
@click="handleShowSheet({title: '参加状态选择', name: 'STATUS',itemData:item})">
<u--input v-model="item.STATUS_SHOW" placeholder="请选择参加状态" border="none"
inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12">
</u-icon>
</u-form-item> </u-form-item>
<u-form-item required label="考核结果" prop="EXAMINATION_RESULTS" borderBottom
@click="handleShowSheet({title: '考核结果选择', name: 'EXAMINATION_RESULTS',itemData:item})">
<u--input v-model="item.EXAMINATION_RESULTS_SHOW" placeholder="请选择考核结果"
border="none" inputAlign="right" disabled disabledColor="#fff"
fontSize="14px"></u--input>
<u-icon style="margin-left: 4px;" slot="right" name="arrow-down" size="12">
</u-icon>
</u-form-item>
<u-form-item label="分数" prop="SCORE" borderBottom>
<u--input disabledColor="#fff" v-model="item.SCORE" border="none"
inputAlign="right"></u--input>
</u-form-item>
<view class="upload-title">附件</view>
<full-upload v-model="item.Nav_Files" :isShowBtn='true'
:listProp='listSubPropUpload'
:listPropVal='item.listSubPropValUpload'></full-upload>
</uni-collapse-item>
</uni-card>
</view> </view>
<!-- </u-collapse> -->
<uni-collapse v-else :border="false" accordion>
<u-form-item :label="(index+1)+'. '+ item.Nav_User.NAME">
<u-subsection activeColor="#0eacf5" mode="subsection" :list="list"
:current="item.STATUS" @change="sectionChange($event,item)"></u-subsection>
</u-form-item>
</uni-collapse>
</u--form> </u--form>
</view> </view>
</view> </view>
</u-sticky> </u-sticky>
<query-selector :show="showPopup" :lists="Lists" @close="handleClosePopup" @search="handleSearch" @select="handleSelected" /> <!-- <query-selector :show="showPopup" :lists="Lists" @close="handleClosePopup" @search="handleSearch"
<u-picker :show="comPickerInfo.showSheet" :columns="comPickerInfo.columns" @confirm="onConfirmPicker" @close="closePicker" @cancel="closePicker" keyName="NAME"></u-picker> @select="handleSelected" /> -->
<u-datetime-picker :show="dateTimePickerInfo.showCheckDate" mode="datetime" v-model='dateTimePickerInfo.defaultDateTime' :formatter="formatter" @confirm="handleCheckDate" <u-picker :show="comPickerInfo.showSheet" :columns="comPickerInfo.columns" @confirm="onConfirmPicker"
@close="dateTimePickerInfo.showCheckDate = false;" @cancel="dateTimePickerInfo.showCheckDate = false;"></u-datetime-picker> @close="closePicker" @cancel="closePicker" keyName="NAME"></u-picker>
<u-datetime-picker :show="dateTimePickerInfo.showCheckDate" mode="datetime"
v-model='dateTimePickerInfo.defaultDateTime' :formatter="formatter" @confirm="handleCheckDate"
@close="dateTimePickerInfo.showCheckDate = false;"
@cancel="dateTimePickerInfo.showCheckDate = false;"></u-datetime-picker>
<!--
<query-selector :show="selectorInfo.showPopup" :defaultChecked="selectorInfo.defaultChecked"
:title="selectorInfo.title" :lists="selectorInfo.dataLists" @search="handleSearch" @select="handleSelected"
@close="selectorInfo.showPopup=false" :total="selectorInfo.totalCount" /> -->
<u-picker :show="selectorInfo.showPopup" :columns="selectorInfo.dataLists" @confirm="onConfirmPicker"
:defaultIndex="[0]" @close="closePicker" @cancel="closePicker" keyName="NAME"></u-picker>
<view class="bottom-button"> <view class="bottom-button">
<u-button type="primary" @click="submit" color="#3d4b70">提交</u-button> <u-button type="primary" @click="submit" color="#3d4b70">提交</u-button>
</view> </view>
@ -84,13 +157,15 @@
extendRule, extendRule,
guid, guid,
initFilter, initFilter,
initFilterGroup initFilterGroup,
getArryPropShow
} from '../../../../utils/common' } from '../../../../utils/common'
import { import {
getRequest, getRequest,
} from '../../../../services/apply/FOServices/FOServices'; } from '../../../../services/apply/FOServices/FOServices';
import { import {
getEnum getEnum,
GetEnumAnyOrder
} from '../../../../services/common'; } from '../../../../services/common';
export default { export default {
data() { data() {
@ -98,6 +173,8 @@
Lists: [], Lists: [],
listPropUpload: ['RECORD_ID'], listPropUpload: ['RECORD_ID'],
listPropValUpload: [], listPropValUpload: [],
listSubPropUpload: ['RECORD_USER_ID'],
listSubPropValUpload: [],
model: { model: {
Nav_Users: [], Nav_Users: [],
ORG_ID: "", ORG_ID: "",
@ -126,6 +203,7 @@
}, },
list: ['参与', '请假', '缺席'], list: ['参与', '请假', '缺席'],
showPopup: false, showPopup: false,
title: '',
tableKey: '0', tableKey: '0',
TaskID: '', TaskID: '',
isLoadOK: false, isLoadOK: false,
@ -141,47 +219,78 @@
formatter: null, formatter: null,
enumsData: {}, // enumsData: {}, //
enumsText: {}, // enumsText: {}, //
selectorInfo: {
isSubShow: false,
isMultiple: false,
showPopup: false,
totalCount: 0,
title: '检查人员',
itemData: {},
index: 0,
dataLists: [],
defaultText: '',
defaultValue: '',
name: '',
defaultChecked: []
},
} }
}, },
onLoad(option) { onLoad(option) {
this.TaskID = option.taskID ? option.taskID : ''; this.TaskID = option.taskID ? option.taskID : '';
this.model.ID = option.ID ? option.ID : ''; this.model.ID = option.ID ? option.ID : '';
this.tableKey = option.tableKey ? option.tableKey : '0'; this.tableKey = option.tableKey ? option.tableKey : '0';
this.fetchEnums(['TrainType', 'PlanCheckType','FMDepartmentType']); this.fetchEnums(['TrainType', 'PlanCheckType', 'FMDepartmentType', 'SETrainRecordUserStatusEnum',
'SEExaminationResultsEnum'
]);
}, },
methods: { methods: {
async fetchEnums(enumNames) { async fetchEnums(enumNames) {
try { try {
// Promise // // Promise
const enumPromises = enumNames.map(name => { // const enumPromises = enumNames.map(name => {
return getEnum({ // return getEnum({
name // name
}).then(res => { // }).then(res => {
// name/code便 // // name/code便
return { // return {
enumName: name, // enumName: name,
data: res.map(item => ({ // data: res.map(item => ({
...item, // ...item,
name: item.NAME, // // name: item.NAME, //
code: item.ID // // code: item.ID //
})) // }))
}; // };
}); // });
}); // });
// //
// const results = await Promise.all(enumPromises);
// // data
// results.forEach(({
// enumName,
// data
// }) => {
// this.enumsData[enumName] = data;
// //
// this.enumsText[enumName] = data.map(item => item.name);
// });
// // loadData
// this.loadData();
// GetEnumAnyOrder({
const results = await Promise.all(enumPromises); name: 'TrainType|PlanCheckType|FMDepartmentType|SETrainRecordUserStatusEnum|SEExaminationResultsEnum'
// data }).then(res => {
results.forEach(({ res.forEach((e, index) => {
enumName, var dataTemp = e.map(sube => ({
data ...sube,
}) => { name: sube.NAME, //
this.enumsData[enumName] = data; code: sube.ID //
// }));
this.enumsText[enumName] = data.map(item => item.name);
}); this.enumsData[enumNames[index]] = dataTemp
// loadData this.enumsText[enumNames[index]] = dataTemp.map(item => item.name);
})
this.loadData(); this.loadData();
})
} catch (error) { } catch (error) {
console.error('枚举请求失败:', error); console.error('枚举请求失败:', error);
uni.showToast({ uni.showToast({
@ -249,8 +358,28 @@
extendInclude(json, 'Nav_Users.Nav_User'); extendInclude(json, 'Nav_Users.Nav_User');
extendInclude(json, 'Nav_Files.Nav_ImgFile'); extendInclude(json, 'Nav_Files.Nav_ImgFile');
extendInclude(json, 'Nav_Users'); extendInclude(json, 'Nav_Users');
extendInclude(json, "Nav_Notify.Nav_ListCour.Nav_Cour")
extendRule(json, 'ID', 1, this.model.ID) extendRule(json, 'ID', 1, this.model.ID)
getRequest(json, "/SE/TrainRecord/Get").then(res => { getRequest(json, "/SE/TrainRecord/Get").then(res => {
var SETrainRecordUserStatusEnum = this.enumsData["SETrainRecordUserStatusEnum"]
var SEExaminationResultsEnum = this.enumsData["SEExaminationResultsEnum"]
res.Nav_Users.forEach(e => {
try {
if (e.STATUS == undefined || e.STATUS == null) {
e.STATUS = 0
}
if (e.EXAMINATION_RESULTS == undefined || e.EXAMINATION_RESULTS == null) {
e.EXAMINATION_RESULTS = 1
}
e.STATUS_SHOW = SETrainRecordUserStatusEnum.filter(es => es.ID == e.STATUS)[0]
.NAME
e.EXAMINATION_RESULTS_SHOW = SEExaminationResultsEnum.filter(es => es.ID == e
.EXAMINATION_RESULTS)[0].NAME
} catch (e) {}
e.listSubPropValUpload = []
e.listSubPropValUpload.push(e.ID)
})
this.model = res this.model = res
// if (this.model.Nav_Notify.LEVEL == 0) { // if (this.model.Nav_Notify.LEVEL == 0) {
// this.model.Nav_Notify.LEVEL_SHOW = ""; // this.model.Nav_Notify.LEVEL_SHOW = "";
@ -261,24 +390,29 @@
// } else if (this.model.Nav_Notify.LEVEL == 3) { // } else if (this.model.Nav_Notify.LEVEL == 3) {
// this.model.Nav_Notify.LEVEL_SHOW = ""; // this.model.Nav_Notify.LEVEL_SHOW = "";
// } // }
this.model.Nav_Notify.LEVEL_SHOW= res.Nav_Notify.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(item => item.code === res.Nav_Notify.LEVEL)?.name : ''; this.model.Nav_Notify.LEVEL_SHOW = res.Nav_Notify.LEVEL !== undefined ? this.enumsData[
this.model.Nav_Notify.TRAINTYPE_SHOW = res.Nav_Notify.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(item => item.code === res.Nav_Notify.TRAINTYPE)?.name : ''; 'FMDepartmentType'].find(item => item.code === res.Nav_Notify.LEVEL)?.name : '';
this.model.Nav_Notify.CHECKTYPE_SHOW = res.Nav_Notify.CHECKTYPE !== undefined ? this.enumsData['PlanCheckType'].find(item => item.code === res.Nav_Notify.CHECKTYPE)?.name : ''; this.model.Nav_Notify.TRAINTYPE_SHOW = res.Nav_Notify.TRAINTYPE !== undefined ? this.enumsData[
this.model.Nav_Notify.TRAIN_MODEL_SHOW = ""; 'TrainType'].find(item => item.code === res.Nav_Notify.TRAINTYPE)?.name : '';
if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(1) > 0) { this.model.Nav_Notify.CHECKTYPE_SHOW = res.Nav_Notify.CHECKTYPE !== undefined ? this.enumsData[
this.model.Nav_Notify.TRAIN_MODEL_SHOW += "讲授法 "; 'PlanCheckType'].find(item => item.code === res.Nav_Notify.CHECKTYPE)?.name : '';
} else if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(2) > 0) { // this.model.Nav_Notify.TRAIN_MODEL_SHOW = "";
this.model.Nav_Notify.TRAIN_MODEL_SHOW += "视听法 "; // if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(1) > 0) {
} else if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(3) > 0) { // this.model.Nav_Notify.TRAIN_MODEL_SHOW += " ";
this.model.Nav_Notify.TRAIN_MODEL_SHOW += "研讨法 "; // } else if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(2) > 0) {
} else if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(4) > 0) { // this.model.Nav_Notify.TRAIN_MODEL_SHOW += " ";
this.model.Nav_Notify.TRAIN_MODEL_SHOW += "演示法 "; // } else if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(3) > 0) {
} // this.model.Nav_Notify.TRAIN_MODEL_SHOW += " ";
// } else if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(4) > 0) {
// this.model.Nav_Notify.TRAIN_MODEL_SHOW += " ";
// }
this.model.Nav_TrainContentList_SHOW = ""; this.model.Nav_TrainContentList_SHOW = "";
for (let i = 0; i < this.model.Nav_Notify.Nav_TrainContentList.length; i++) { for (let i = 0; i < this.model.Nav_Notify.Nav_TrainContentList.length; i++) {
this.model.Nav_TrainContentList_SHOW += (i + 1) + "." + this.model.Nav_Notify this.model.Nav_TrainContentList_SHOW += (i + 1) + "." + this.model.Nav_Notify
.Nav_TrainContentList[i].Nav_Point.NAME + "<br/>"; .Nav_TrainContentList[i].Nav_Point.NAME + "<br/>";
} }
this.model.Nav_ListCour_Show = getArryPropShow(this.model.Nav_Notify.Nav_ListCour,
'Nav_Cour.NAME', '<br/>')
this.model.Nav_Users_SHOW = ""; this.model.Nav_Users_SHOW = "";
for (let i = 0; i < this.model.Nav_Users.length; i++) { for (let i = 0; i < this.model.Nav_Users.length; i++) {
this.model.Nav_Users_SHOW += (i + 1) + "." + this.model.Nav_Users[i].Nav_User.NAME + this.model.Nav_Users_SHOW += (i + 1) + "." + this.model.Nav_Users[i].Nav_User.NAME +
@ -321,6 +455,76 @@
}) })
}, },
//
handleSearch(val, pageIndex) {
var p = {
name: this.selectorInfo.name,
title: this.selectorInfo.title,
val: val,
pageIndex: pageIndex
}
this.handleShowSheet(p)
},
//
async handleShowSheet(p) {
// const orgId = uni.getStorageSync('orgId')
// const json = initFilter(orgId, "", "", 0, p.pageIndex ?? 1)
let dataSelect = []
var defaultChecked = []
if (p.name == 'STATUS') {
dataSelect = this.enumsData['SETrainRecordUserStatusEnum']
} else if (p.name == 'EXAMINATION_RESULTS') {
dataSelect = this.enumsData['SEExaminationResultsEnum']
}
if (defaultChecked == null)
defaultChecked = []
if (dataSelect.length) {
this.selectorInfo = {
itemData: p.itemData != undefined ? p.itemData : this.selectorInfo.itemData,
totalCount: this.selectorInfo.totalCount,
showPopup: true,
title: p.title,
name: p.name,
dataLists: [dataSelect],
defaultChecked: defaultChecked
}
} else {
//
debugger
}
},
handleSelected(e) {
this.selectorInfo.showPopup = false
if (this.selectorInfo.name == "STATUS") {
this.selectorInfo.itemData.STATUS = e.ID
this.selectorInfo.itemData.STATUS_SHOW = e.NAME
} else if (this.selectorInfo.name == 'EXAMINATION_RESULTS') {
this.selectorInfo.itemData.EXAMINATION_RESULTS = e.ID
this.selectorInfo.itemData.EXAMINATION_RESULTS_SHOW = e.NAME
}
},
onConfirmPicker(e) {
this.selectorInfo.showPopup = false
if (this.selectorInfo.name == "STATUS") {
this.selectorInfo.itemData.STATUS = e.value[0].ID
this.selectorInfo.itemData.STATUS_SHOW = e.value[0].NAME
} else if (this.selectorInfo.name == 'EXAMINATION_RESULTS') {
this.selectorInfo.itemData.EXAMINATION_RESULTS = e.value[0].ID
this.selectorInfo.itemData.EXAMINATION_RESULTS_SHOW = e.value[0].NAME
}
},
closePicker() {
this.selectorInfo = {
showPopup: false,
dataLists: [],
title: '',
name: '',
dataIndex: undefined,
formIndex: undefined
}
},
} }
} }
</script> </script>

View File

@ -2070,3 +2070,22 @@ export function SourceFormcode(json) {
} }
return linkToUrl return linkToUrl
} }
export function getArryPropShow(arry, propPath, htmlPerAdd) {
var arryShow = ''
const [prop1, prop2] = propPath.split('.');
if (arry && arry.length > 0 && propPath) {
arry.map(function(item, index) {
var itemProp = item[prop1]?.[prop2]
if (itemProp && itemProp.length > 0) {
if (htmlPerAdd != null && htmlPerAdd != undefined) {
arryShow += itemProp + ((htmlPerAdd != null && htmlPerAdd != undefined) ? htmlPerAdd : '');
} else {
arryShow += (index > 0 ? ',' : '') + itemProp
}
}
});
}
return arryShow;
}