| | |
| | | placeholder="请选择批改提醒时间"> |
| | | </el-time-picker> |
| | | </el-form-item> |
| | | <div style="display: flex; align-items: center;"> |
| | | <el-button type="primary" @click="add" style="margin-bottom: 10px;">添加工种</el-button> |
| | | <el-button type="primary" @click="impor" style="margin-bottom: 10px;">导入工种</el-button> |
| | | <el-button type="text" @click="exprot">导入模版xls</el-button> |
| | | <div style="width: 100%; padding: 10px; box-sizing: border-box; border: 1px solid #ececec;"> |
| | | <div style="display: flex; align-items: center; margin-bottom: 10px;"> |
| | | <el-select filterable multiple style="width: 800px;" v-model="worktypeId" placeholder="请选择"> |
| | | <el-option |
| | | v-for="item in typeWorkCopy" |
| | | :key="item.id" |
| | | :label="item.name" |
| | | :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | <el-button type="primary" @click="add" :disabled="worktypeId.length === 0" style="margin-left: 10px;">添加工种</el-button> |
| | | <el-button type="primary" @click="impor">导入工种</el-button> |
| | | <el-button type="text" @click="exprot">导入模版xls</el-button> |
| | | </div> |
| | | <u-table |
| | | :data="form.worktypeIdList" |
| | | border |
| | | use-virtual |
| | | style="width: 100%; margin-bottom: 20px;"> |
| | | <u-table-column |
| | | label="序号" |
| | | width="80"> |
| | | <template slot-scope="scope"> |
| | | <span>{{scope.$index + 1}}</span> |
| | | </template> |
| | | </u-table-column> |
| | | <u-table-column |
| | | prop="worktypeName" |
| | | label="所属工种"> |
| | | </u-table-column> |
| | | <u-table-column |
| | | label="操作" |
| | | width="100"> |
| | | <template slot-scope="scope"> |
| | | <el-button type="text" size="small" style="color: red;" @click="dele(scope.$index)">删除</el-button> |
| | | </template> |
| | | </u-table-column> |
| | | </u-table> |
| | | </div> |
| | | <el-table |
| | | :data="form.worktypeIdList" |
| | | border |
| | | style="width: 100%; margin-bottom: 20px;"> |
| | | <el-table-column |
| | | label="序号" |
| | | align="center" |
| | | width="80"> |
| | | <template slot-scope="scope"> |
| | | <span>{{scope.$index + 1}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | label="所属工种"> |
| | | <template slot-scope="{row}"> |
| | | <el-select filterable v-model="row.worktypeId" placeholder="请选择"> |
| | | <el-option |
| | | v-for="item in typeWork" |
| | | :key="item.id" |
| | | :label="item.name" |
| | | :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="操作" |
| | | align="center" |
| | | width="100"> |
| | | <template slot-scope="scope"> |
| | | <el-button type="text" size="small" style="color: red;" @click="dele(scope.$index)">删除</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | <el-form-item label="特别约定" prop="specialAgreement"> |
| | | <RichEditor :richData="form.specialAgreement" :styleEditor="'border: 1px solid #ccc;display: inline-block;'" @getWangedditor="getWangedditor" :readonly="false"/> |
| | | </el-form-item> |
| | |
| | | import UploadFile from '@/components/common/UploadFile' |
| | | import { numRule } from '@/utils/form' |
| | | import RichEditor from '@/components/common/RichEditor' |
| | | import { UTable, UTableColumn } from 'umy-ui' |
| | | export default { |
| | | name: 'OperaSolutionsBaseWindow', |
| | | extends: BaseOpera, |
| | | components: { GlobalWindow, UploadFile, RichEditor }, |
| | | components: { GlobalWindow, UploadFile, RichEditor, UTable, UTableColumn }, |
| | | data () { |
| | | var validType = (rule, value, callback) => { |
| | | if (this.form.validType === 0 && !value) { |
| | |
| | | delOnlyReplace: 0, |
| | | canAdd: 0, |
| | | correctWarnTime: '', |
| | | worktypeIdList: [{ worktypeId: '' }] |
| | | worktypeIdList: [] |
| | | }, |
| | | worktypeId: [], |
| | | // 验证规则 |
| | | rules: { |
| | | name: [ |
| | |
| | | }, |
| | | shops: [], |
| | | company: [], |
| | | typeWork: [] |
| | | typeWork: [], |
| | | typeWorkCopy: [] |
| | | } |
| | | }, |
| | | created () { |
| | |
| | | formdate.append('insuranceId', this.form.insuranceId) |
| | | importExcelForSolution(formdate) |
| | | .then(res => { |
| | | console.log(res) |
| | | res.forEach(id => { |
| | | if (this.form.worktypeIdList.length === 1 && !this.form.worktypeIdList[0].worktypeId) { |
| | | this.form.worktypeIdList[0].worktypeId = id |
| | | } else { |
| | | this.form.worktypeIdList.push({ worktypeId: id }) |
| | | } |
| | | let arr = [] |
| | | res.forEach(item => { |
| | | arr.push({ worktypeId: item.id, worktypeName: item.name }) |
| | | }) |
| | | this.form.worktypeIdList = [...arr, ...this.form.worktypeIdList] |
| | | let valData = this.form.worktypeIdList.map(item => item.worktypeName) |
| | | this.typeWorkCopy = this.typeWorkCopy.filter(item => !valData.includes(item.name)) |
| | | }) |
| | | .catch(err => { |
| | | this.$message.error(err.message) |
| | |
| | | }) |
| | | }, |
| | | impor() { |
| | | if (!this.form.insuranceId) return this.$message.warning('请先选择企业') |
| | | if (!this.form.insuranceId) return this.$message.warning('请先选择保险公司') |
| | | this.$refs.upload.click() |
| | | }, |
| | | // 导出模板 |
| | |
| | | }, |
| | | // 切换公司 |
| | | getAllWorktype1 () { |
| | | this.form.worktypeIdList = [{ worktypeId: '' }] |
| | | this.form.worktypeIdList = [] |
| | | this.getAllWorktype() |
| | | }, |
| | | changeValidType(e) { |
| | |
| | | this.form.delOnlyReplace = 0 |
| | | this.form.delValidDays = 0 |
| | | this.form.canAdd = 0 |
| | | this.form.worktypeIdList = [{ worktypeId: '' }] |
| | | this.form.worktypeIdList = [] |
| | | this.typeWork = [] |
| | | this.typeWorkCopy = [] |
| | | // this.$refs['$upload'].clearFiles()//初始化导入组件 |
| | | this.allCompany() |
| | | this.allShops() |
| | |
| | | this.form.maxAge = '' |
| | | this.form.validTypeNum = '' |
| | | this.form.fanganFile = null |
| | | this.form.worktypeIdList = [{ worktypeId: '' }] |
| | | this.form.worktypeIdList = [] |
| | | this.form[this.configData['field.id']] = null |
| | | }) |
| | | return |
| | |
| | | if (res.worktypeList) { |
| | | this.form.worktypeIdList = res.worktypeList.map(item => { |
| | | return { |
| | | worktypeId: item.worktypeId |
| | | worktypeId: item.worktypeId, |
| | | worktypeName: item.worktypeName |
| | | } |
| | | }) |
| | | } |
| | |
| | | // 查询保险公司下全部工种 |
| | | getAllWorktype () { |
| | | allWorktype({ |
| | | insuranceId: this.form.insuranceId |
| | | insuranceId: this.form.insuranceId, |
| | | dataType: 2 |
| | | }).then(res => { |
| | | this.typeWork = res |
| | | this.typeWork = res |
| | | if (!this.form.id) { |
| | | this.typeWorkCopy = res |
| | | } else { |
| | | let valData = this.form.worktypeIdList.map(item => item.worktypeName) |
| | | this.typeWorkCopy = res.filter(item => !valData.includes(item.name)) |
| | | } |
| | | }) |
| | | }, |
| | | |
| | |
| | | allCompany () { |
| | | all({ dataType: 2, status: 0 }) |
| | | .then(res => { |
| | | console.log(res) |
| | | this.company = res |
| | | }) |
| | | }, |
| | | allShops () { |
| | | shopList({ type: 1, status: 0 }) |
| | | .then(res => { |
| | | console.log(res) |
| | | this.shops = res |
| | | }) |
| | | }, |
| | | add () { |
| | | this.form.worktypeIdList.push({ worktypeId: '' }) |
| | | let arr = this.typeWorkCopy.filter(item => this.worktypeId.includes(item.id)) |
| | | let dataVal = arr.map(item => { |
| | | return { |
| | | worktypeId: item.id, |
| | | worktypeName: item.name |
| | | } |
| | | }) |
| | | this.form.worktypeIdList = [ ...dataVal, ...this.form.worktypeIdList ] |
| | | let valData = this.form.worktypeIdList.map(item => item.worktypeName) |
| | | this.typeWorkCopy = this.typeWorkCopy.filter(item => !valData.includes(item.name)) |
| | | this.worktypeId = [] |
| | | }, |
| | | dele (index) { |
| | | if (this.form.worktypeIdList.length === 1) { |
| | | this.$message.warning('至少要保留一项') |
| | | return |
| | | } |
| | | let row = this.typeWork.filter(item => item.name === this.form.worktypeIdList[index].worktypeName) |
| | | this.typeWorkCopy.unshift(row[0]) |
| | | this.form.worktypeIdList.splice(index, 1) |
| | | } |
| | | } |