培训通知 通知显示
培训记录 考核与不考核做区分 多选 文本显示 添加公共方法
This commit is contained in:
parent
bc54c7d446
commit
c715cf7eb7
@ -3,57 +3,90 @@
|
||||
<view class="card">
|
||||
<view class="background"></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--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 required label="培训类型" prop="Nav_TrainType.NAME" borderBottom @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-form-item required label="培训类型" prop="Nav_TrainType.NAME" borderBottom
|
||||
@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>
|
||||
</u-form-item>
|
||||
<u-form-item label="培训性质" prop="IN_OUT_SHOW" borderBottom @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-form-item label="培训性质" prop="IN_OUT_SHOW" borderBottom
|
||||
@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-form-item>
|
||||
<u-form-item required label="培训级别" prop="LEVEL_SHOW" borderBottom @click="handleShowSheet({title: '层级', name: 'FMDepartmentType'})">
|
||||
<u--input :value="model.LEVEL_SHOW" placeholder="请选择层级" border="none" inputAlign="right" disabled disabledColor="#fff" fontSize="14px"></u--input>
|
||||
<u-form-item required label="培训级别" prop="LEVEL_SHOW" borderBottom
|
||||
@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-form-item>
|
||||
<u-form-item label="开始时间" required prop="TRAIN_START_TIME" borderBottom @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"
|
||||
<u-form-item label="开始时间" required prop="TRAIN_START_TIME" borderBottom
|
||||
@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">
|
||||
</u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="结束时间" required prop="TRAIN_END_TIME" borderBottom @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"
|
||||
<u-form-item label="结束时间" required prop="TRAIN_END_TIME" borderBottom
|
||||
@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">
|
||||
</u--input>
|
||||
</u-form-item>
|
||||
<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 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 required label="培训老师" prop="Nav_UserTeacher.NAME" borderBottom @click="handleChange('Nav_UserTeacher','')">
|
||||
<u--input v-model="(model.Nav_UserTeacher||{}).NAME" border="none" placeholder="请选择培训老师" inputAlign="right" fontSize="14px"></u--input>
|
||||
<u-form-item required label="培训老师" prop="Nav_UserTeacher.NAME" borderBottom
|
||||
@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>
|
||||
</u-form-item>
|
||||
<u-form-item required label="培训形式" prop="TRAINTYPE_SHOW" borderBottom @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-form-item required label="培训形式" prop="TRAINTYPE_SHOW" borderBottom
|
||||
@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-form-item>
|
||||
<u-form-item required label="考核方式" prop="CHECKTYPE_SHOW" borderBottom @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-form-item required label="考核方式" prop="CHECKTYPE_SHOW" borderBottom
|
||||
@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>
|
||||
</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 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>
|
||||
<u-icon class="icon" name="arrow-down" size="12">
|
||||
</u-icon>
|
||||
@ -62,37 +95,56 @@
|
||||
<u-form-item label="培训安排及要求" prop="TRAIN_PLAN" borderBottom>
|
||||
</u-form-item>
|
||||
<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--input :value="model.NEED_EVALUATION_SHOW" placeholder="请选择" border="none" inputAlign="right" disabled disabledColor="#fff"></u--input>
|
||||
<u-form-item label="是否需要培训效果评估" prop="NEED_EVALUATION" borderBottom
|
||||
@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-form-item>
|
||||
<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 required label="记录人员" prop="Nav_RecordUser.NAME" borderBottom @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-form-item required label="记录人员" prop="Nav_RecordUser.NAME" borderBottom
|
||||
@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>
|
||||
</u-form-item>
|
||||
<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-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>
|
||||
<!-- <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">
|
||||
<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>
|
||||
</u--form>
|
||||
</view>
|
||||
</view>
|
||||
<query-selector :show="showPopup" :lists="Lists" @close="handleClosePopup" @search="handleSearch" @select="handleSelected" />
|
||||
<u-picker :show="comPickerInfo.showSheet" :columns="comPickerInfo.columns" @confirm="onConfirmPicker" :defaultIndex="[0]" @close="closePicker" @cancel="closePicker" keyName="NAME"></u-picker>
|
||||
<query-selector :show="showPopup" :lists="Lists" @close="handleClosePopup" @search="handleSearch"
|
||||
@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>
|
||||
<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 :multiple="qsCom.isMultiple" :total="curTotal" :show="qsCom.show" :lists="qsCom.lists" @close="onCloseQS" @search="onSearchQS" @select="onSelectedQS" />
|
||||
<people-selector :defaultChecked="peopleSelectOption.defaultChecked" :show="peopleSelectOption.showSelector" @select="handleSelectorPeople" @close="peopleSelectOption.showSelector = false">
|
||||
<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 :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>
|
||||
<view class="bottom-button">
|
||||
<u-button type="primary" @click="submit" color="#3d4b70">提交</u-button>
|
||||
@ -130,8 +182,8 @@
|
||||
NEED_EVALUATION_SHOW: "",
|
||||
NEED_EVALUATION: "",
|
||||
CREATE_NOTIFY_RECORD: true,
|
||||
IN_OUT_SHOW:'',
|
||||
IN_OUT:'',
|
||||
IN_OUT_SHOW: '',
|
||||
IN_OUT: '',
|
||||
},
|
||||
options: [{
|
||||
text: '删除',
|
||||
@ -222,6 +274,7 @@
|
||||
qsCom: {
|
||||
show: false,
|
||||
lists: [],
|
||||
defaultChecked: [],
|
||||
formIndex: undefined,
|
||||
isMultiple: false,
|
||||
},
|
||||
@ -247,7 +300,7 @@
|
||||
this.TaskID = option.taskID ? option.taskID : '';
|
||||
this.model.ID = option.ID ? option.ID : '';
|
||||
this.tableKey = option.tableKey ? option.tableKey : '0';
|
||||
this.fetchEnums(['TrainType', 'PlanCheckType', 'FMDepartmentType','TrainInOut','SETrainNeedSuvey']);
|
||||
this.fetchEnums(['TrainType', 'PlanCheckType', 'FMDepartmentType', 'TrainInOut', 'SETrainNeedSuvey']);
|
||||
this.isAdd = option.isAdd
|
||||
|
||||
},
|
||||
@ -343,6 +396,12 @@
|
||||
this.model.TRAIN_END_TIME = uni.$u.timeFormat(e.value,
|
||||
'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
|
||||
},
|
||||
//时间end
|
||||
@ -379,7 +438,7 @@
|
||||
}
|
||||
})
|
||||
})
|
||||
} else if (this.currSearchType == "Nav_RecordUser"||this.currSearchType == "Nav_UserTeacher") {
|
||||
} else if (this.currSearchType == "Nav_RecordUser" || this.currSearchType == "Nav_UserTeacher") {
|
||||
getRequest(json, "/FM/FMUser/OrderPagedUseful").then(res => {
|
||||
this.Lists = res.map(i => {
|
||||
return {
|
||||
@ -415,13 +474,26 @@
|
||||
//多选start
|
||||
async handleQuerySelect(opt) {
|
||||
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) {
|
||||
this.qsCom = {
|
||||
show: true,
|
||||
name: opt.NAME,
|
||||
formIndex: opt.formIndex,
|
||||
isMultiple: opt.isMultiple,
|
||||
lists: column
|
||||
lists: column,
|
||||
defaultChecked: defaultChecked
|
||||
}
|
||||
}
|
||||
},
|
||||
@ -437,6 +509,8 @@
|
||||
})
|
||||
},
|
||||
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)
|
||||
if (value !== 'init') {
|
||||
const tempGroup = initFilterGroup(false);
|
||||
@ -448,7 +522,7 @@
|
||||
json.Start = (pageIndex - 1) * 20;
|
||||
}
|
||||
let result = []
|
||||
const raw = await getRequest(json, "/SE/TestEnumPoint/OrderPaged").then(res => {
|
||||
const raw = await getRequest(json, api).then(res => {
|
||||
this.curTotal = res.TotalCount
|
||||
return res
|
||||
})
|
||||
@ -465,11 +539,14 @@
|
||||
const {
|
||||
formIndex,
|
||||
} = this.qsCom
|
||||
//formIndex Nav_ListCour Nav_TrainContentList
|
||||
if (formIndex == 'Nav_TrainContentList') {
|
||||
this.model.Nav_TrainContentList = [];
|
||||
val.forEach(item => {
|
||||
let obj = {
|
||||
POINT_ID: item.ID,
|
||||
Nav_Point: {
|
||||
ID: item.ID,
|
||||
NAME: item.NAME
|
||||
},
|
||||
ID: guid(),
|
||||
@ -478,7 +555,24 @@
|
||||
}
|
||||
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.defaultChecked = []
|
||||
},
|
||||
onCloseQS() {
|
||||
this.qsCom = {
|
||||
@ -539,11 +633,16 @@
|
||||
extendRule(json, 'ID', 1, this.model.ID)
|
||||
getRequest(json, "/SE/TrainNotify/Get").then(res => {
|
||||
this.model = res
|
||||
this.model.LEVEL_SHOW = res.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(item => item.code === res.LEVEL)?.name : '';
|
||||
this.model.TRAINTYPE_SHOW = res.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(item => item.code === res.TRAINTYPE)?.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.LEVEL_SHOW = res.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(
|
||||
item => item.code === res.LEVEL)?.name : '';
|
||||
this.model.TRAINTYPE_SHOW = res.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(
|
||||
item => item.code === res.TRAINTYPE)?.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() {
|
||||
@ -615,9 +714,7 @@
|
||||
submit() {
|
||||
const ele = this.$refs
|
||||
ele['wForm'].validate().then(res => {
|
||||
|
||||
this.modelEdit = JSON.parse(JSON.stringify(this.model))
|
||||
|
||||
this.modelEdit.PUBLISH = "SaveAndNotify";
|
||||
if (this.TaskID != "") {
|
||||
this.modelEdit.TaskID = this.TaskID;
|
||||
|
||||
@ -3,46 +3,64 @@
|
||||
<view class="card">
|
||||
<view class="background"></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--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 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 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 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 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 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 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 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 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 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 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 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 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 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>
|
||||
<u-textarea autoHeight v-html="model.TRAINCONTENT" border="none" disabled></u-textarea>
|
||||
@ -53,7 +71,8 @@
|
||||
</u-form-item>
|
||||
<rich-text v-html="model.users" border="none" disabled style="font-size: 14px;"></rich-text>
|
||||
<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>
|
||||
</view>
|
||||
|
||||
@ -64,8 +83,10 @@
|
||||
<u--textarea height='3em' v-model="LEAVE_REASON" placeholder="请输入请假理由"></u--textarea>
|
||||
</view>
|
||||
<view class="buttons">
|
||||
<u-button type="primary" color="#3d4b70" class="btn first-btn" @click="onChargeUserAgree(1)" text="参加"></u-button>
|
||||
<u-button color="#3d4b70" :plain="true" type="warning" @click="onChargeUserAgree(2)" text="请假"></u-button>
|
||||
<u-button type="primary" color="#3d4b70" class="btn first-btn" @click="onChargeUserAgree(1)"
|
||||
text="参加"></u-button>
|
||||
<u-button color="#3d4b70" :plain="true" type="warning" @click="onChargeUserAgree(2)"
|
||||
text="请假"></u-button>
|
||||
</view>
|
||||
</view>
|
||||
</u--form>
|
||||
@ -78,7 +99,8 @@
|
||||
import {
|
||||
initFilter,
|
||||
extendRule,
|
||||
extendInclude
|
||||
extendInclude,
|
||||
getArryPropShow
|
||||
} from '../../../../utils/common'
|
||||
import {
|
||||
getRequest,
|
||||
@ -110,7 +132,7 @@
|
||||
this.model.ID = option.ID;
|
||||
this.TaskID = option.taskID;
|
||||
this.tableKey = option.tableKey ? option.tableKey : '0'
|
||||
this.fetchEnums(['TrainType', 'PlanCheckType','FMDepartmentType', 'TrainInOut','SETrainNeedSuvey']);
|
||||
this.fetchEnums(['TrainType', 'PlanCheckType', 'FMDepartmentType', 'TrainInOut', 'SETrainNeedSuvey']);
|
||||
},
|
||||
methods: {
|
||||
async fetchEnums(enumNames) {
|
||||
@ -167,6 +189,7 @@
|
||||
extendInclude(json, 'Nav_TrainUserList.Nav_User');
|
||||
extendInclude(json, 'Nav_Files.Nav_ImgFile');
|
||||
extendInclude(json, "Nav_UserTeacher")
|
||||
extendInclude(json, "Nav_ListCour.Nav_Cour")
|
||||
getRequest(json, "/SE/TrainNotify/Get").then(res => {
|
||||
this.model = res
|
||||
let trainContent = '';
|
||||
@ -197,11 +220,17 @@
|
||||
// this.model.LEVEL = this.transLevel(this.model.LEVEL);
|
||||
this.model.TRAINCONTENT = trainContent;
|
||||
this.model.users = users;
|
||||
this.model.LEVEL_SHOW = res.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(item => item.code === res.LEVEL)?.name : '';
|
||||
this.model.TRAINTYPE_SHOW = res.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(item => item.code === res.TRAINTYPE)?.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.LEVEL_SHOW = res.LEVEL !== undefined ? this.enumsData['FMDepartmentType'].find(
|
||||
item => item.code === res.LEVEL)?.name : '';
|
||||
this.model.TRAINTYPE_SHOW = res.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(
|
||||
item => item.code === res.TRAINTYPE)?.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;
|
||||
})
|
||||
},
|
||||
|
||||
@ -3,72 +3,145 @@
|
||||
<view class="card">
|
||||
<view class="background"></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--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 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-form-item>
|
||||
<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 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 label="开始时间" required prop="Nav_Notify.TRAIN_START_TIME" @click="showCheckDate({ name: 'TRAIN_START_TIME'})" borderBottom>
|
||||
<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-form-item label="开始时间" required prop="Nav_Notify.TRAIN_START_TIME"
|
||||
@click="showCheckDate({ name: 'TRAIN_START_TIME'})" borderBottom>
|
||||
<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-form-item>
|
||||
<u-form-item label="结束时间" required prop="Nav_Notify.TRAIN_END_TIME" @click="showCheckDate({name: 'TRAIN_END_TIME'})" borderBottom>
|
||||
<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-form-item label="结束时间" required prop="Nav_Notify.TRAIN_END_TIME"
|
||||
@click="showCheckDate({name: 'TRAIN_END_TIME'})" borderBottom>
|
||||
<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-form-item>
|
||||
<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 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 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 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 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 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>
|
||||
<u-textarea v-html="model.Nav_TrainContentList_SHOW" style="font-size: 14px;"></u-textarea>
|
||||
<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>
|
||||
</view>
|
||||
</view>
|
||||
<u-sticky offset-top="20">
|
||||
<view class="sub-form">
|
||||
<view class="sub-form-wrap">
|
||||
<u--form labelPosition="left" labelWidth="auto" labelAlign="center" errorType="border-bottom" ref="sForm">
|
||||
<!-- <u-collapse :border="false" accordion> -->
|
||||
<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>
|
||||
<u--form labelPosition="left" labelWidth="auto" labelAlign="center" errorType="border-bottom"
|
||||
ref="sForm">
|
||||
<!-- 线上考核 只有参与与否是可以编辑的
|
||||
线下考核 需要填写 是否合格 成绩 考卷等 -->
|
||||
<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 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>
|
||||
<!-- </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>
|
||||
</view>
|
||||
</view>
|
||||
</u-sticky>
|
||||
<query-selector :show="showPopup" :lists="Lists" @close="handleClosePopup" @search="handleSearch" @select="handleSelected" />
|
||||
<u-picker :show="comPickerInfo.showSheet" :columns="comPickerInfo.columns" @confirm="onConfirmPicker" @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="showPopup" :lists="Lists" @close="handleClosePopup" @search="handleSearch"
|
||||
@select="handleSelected" /> -->
|
||||
<u-picker :show="comPickerInfo.showSheet" :columns="comPickerInfo.columns" @confirm="onConfirmPicker"
|
||||
@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">
|
||||
<u-button type="primary" @click="submit" color="#3d4b70">提交</u-button>
|
||||
</view>
|
||||
@ -84,13 +157,15 @@
|
||||
extendRule,
|
||||
guid,
|
||||
initFilter,
|
||||
initFilterGroup
|
||||
initFilterGroup,
|
||||
getArryPropShow
|
||||
} from '../../../../utils/common'
|
||||
import {
|
||||
getRequest,
|
||||
} from '../../../../services/apply/FOServices/FOServices';
|
||||
import {
|
||||
getEnum
|
||||
getEnum,
|
||||
GetEnumAnyOrder
|
||||
} from '../../../../services/common';
|
||||
export default {
|
||||
data() {
|
||||
@ -98,6 +173,8 @@
|
||||
Lists: [],
|
||||
listPropUpload: ['RECORD_ID'],
|
||||
listPropValUpload: [],
|
||||
listSubPropUpload: ['RECORD_USER_ID'],
|
||||
listSubPropValUpload: [],
|
||||
model: {
|
||||
Nav_Users: [],
|
||||
ORG_ID: "",
|
||||
@ -126,6 +203,7 @@
|
||||
},
|
||||
list: ['参与', '请假', '缺席'],
|
||||
showPopup: false,
|
||||
title: '',
|
||||
tableKey: '0',
|
||||
TaskID: '',
|
||||
isLoadOK: false,
|
||||
@ -141,47 +219,78 @@
|
||||
formatter: null,
|
||||
enumsData: {}, // 存储所有枚举数据(键:枚举名称,值:处理后的枚举列表)
|
||||
enumsText: {}, // 存储枚举文本列表(用于下拉选择等场景)
|
||||
selectorInfo: {
|
||||
isSubShow: false,
|
||||
isMultiple: false,
|
||||
showPopup: false,
|
||||
totalCount: 0,
|
||||
title: '检查人员',
|
||||
itemData: {},
|
||||
index: 0,
|
||||
dataLists: [],
|
||||
defaultText: '',
|
||||
defaultValue: '',
|
||||
name: '',
|
||||
defaultChecked: []
|
||||
},
|
||||
}
|
||||
},
|
||||
onLoad(option) {
|
||||
this.TaskID = option.taskID ? option.taskID : '';
|
||||
this.model.ID = option.ID ? option.ID : '';
|
||||
this.tableKey = option.tableKey ? option.tableKey : '0';
|
||||
this.fetchEnums(['TrainType', 'PlanCheckType','FMDepartmentType']);
|
||||
this.fetchEnums(['TrainType', 'PlanCheckType', 'FMDepartmentType', 'SETrainRecordUserStatusEnum',
|
||||
'SEExaminationResultsEnum'
|
||||
]);
|
||||
},
|
||||
methods: {
|
||||
async fetchEnums(enumNames) {
|
||||
try {
|
||||
// 存储所有枚举请求的Promise
|
||||
const enumPromises = enumNames.map(name => {
|
||||
return getEnum({
|
||||
name
|
||||
}).then(res => {
|
||||
// 统一处理枚举格式:添加name/code字段,便于后续映射
|
||||
return {
|
||||
enumName: name,
|
||||
data: res.map(item => ({
|
||||
...item,
|
||||
name: item.NAME, // 统一显示名称字段
|
||||
code: item.ID // 统一值字段
|
||||
}))
|
||||
};
|
||||
});
|
||||
});
|
||||
// // 存储所有枚举请求的Promise
|
||||
// const enumPromises = enumNames.map(name => {
|
||||
// return getEnum({
|
||||
// name
|
||||
// }).then(res => {
|
||||
// // 统一处理枚举格式:添加name/code字段,便于后续映射
|
||||
// return {
|
||||
// enumName: name,
|
||||
// data: res.map(item => ({
|
||||
// ...item,
|
||||
// name: item.NAME, // 统一显示名称字段
|
||||
// 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();
|
||||
|
||||
// 等待所有枚举请求完成
|
||||
const results = await Promise.all(enumPromises);
|
||||
// 存储枚举结果到data中(键为枚举名称,值为处理后的数据)
|
||||
results.forEach(({
|
||||
enumName,
|
||||
data
|
||||
}) => {
|
||||
this.enumsData[enumName] = data;
|
||||
// 生成文本列表(如需要)
|
||||
this.enumsText[enumName] = data.map(item => item.name);
|
||||
});
|
||||
// 所有枚举获取完成后,执行loadData
|
||||
GetEnumAnyOrder({
|
||||
name: 'TrainType|PlanCheckType|FMDepartmentType|SETrainRecordUserStatusEnum|SEExaminationResultsEnum'
|
||||
}).then(res => {
|
||||
res.forEach((e, index) => {
|
||||
var dataTemp = e.map(sube => ({
|
||||
...sube,
|
||||
name: sube.NAME, // 统一显示名称字段
|
||||
code: sube.ID // 统一值字段
|
||||
}));
|
||||
|
||||
this.enumsData[enumNames[index]] = dataTemp
|
||||
this.enumsText[enumNames[index]] = dataTemp.map(item => item.name);
|
||||
})
|
||||
this.loadData();
|
||||
})
|
||||
} catch (error) {
|
||||
console.error('枚举请求失败:', error);
|
||||
uni.showToast({
|
||||
@ -249,8 +358,28 @@
|
||||
extendInclude(json, 'Nav_Users.Nav_User');
|
||||
extendInclude(json, 'Nav_Files.Nav_ImgFile');
|
||||
extendInclude(json, 'Nav_Users');
|
||||
extendInclude(json, "Nav_Notify.Nav_ListCour.Nav_Cour")
|
||||
extendRule(json, 'ID', 1, this.model.ID)
|
||||
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
|
||||
// if (this.model.Nav_Notify.LEVEL == 0) {
|
||||
// this.model.Nav_Notify.LEVEL_SHOW = "部门";
|
||||
@ -261,24 +390,29 @@
|
||||
// } else if (this.model.Nav_Notify.LEVEL == 3) {
|
||||
// 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.TRAINTYPE_SHOW = res.Nav_Notify.TRAINTYPE !== undefined ? this.enumsData['TrainType'].find(item => item.code === res.Nav_Notify.TRAINTYPE)?.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.TRAIN_MODEL_SHOW = "";
|
||||
if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(1) > 0) {
|
||||
this.model.Nav_Notify.TRAIN_MODEL_SHOW += "讲授法 ";
|
||||
} else if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(2) > 0) {
|
||||
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_Notify.LEVEL_SHOW = res.Nav_Notify.LEVEL !== undefined ? this.enumsData[
|
||||
'FMDepartmentType'].find(item => item.code === res.Nav_Notify.LEVEL)?.name : '';
|
||||
this.model.Nav_Notify.TRAINTYPE_SHOW = res.Nav_Notify.TRAINTYPE !== undefined ? this.enumsData[
|
||||
'TrainType'].find(item => item.code === res.Nav_Notify.TRAINTYPE)?.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.TRAIN_MODEL_SHOW = "";
|
||||
// if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(1) > 0) {
|
||||
// this.model.Nav_Notify.TRAIN_MODEL_SHOW += "讲授法 ";
|
||||
// } else if (this.model.Nav_Notify.TRAIN_MODEL.indexOf(2) > 0) {
|
||||
// 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 = "";
|
||||
for (let i = 0; i < this.model.Nav_Notify.Nav_TrainContentList.length; i++) {
|
||||
this.model.Nav_TrainContentList_SHOW += (i + 1) + "." + this.model.Nav_Notify
|
||||
.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 = "";
|
||||
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 +
|
||||
@ -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>
|
||||
|
||||
@ -2070,3 +2070,22 @@ export function SourceFormcode(json) {
|
||||
}
|
||||
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;
|
||||
}
|
||||
Loading…
Reference in New Issue
Block a user