| | |
| | | <div> |
| | | <div class="body" :style="{height:mainHeight+'px'}"> |
| | | |
| | | <div class="bodyTopButtonGroup"> |
| | | <el-button type="primary" icon="el-icon-circle-plus-outline" @click="add('add')">新增</el-button> |
| | | <el-button |
| | | icon="el-icon-refresh-right" |
| | | @click="syncSeaveSearchPartner" |
| | | >同步往来单位 |
| | | </el-button> |
| | | <el-button icon="el-icon-download" @click="upload">导入</el-button> |
| | | <div class="bodyTopButtonGroup" style="justify-content: space-between"> |
| | | <el-button v-waves type="primary" icon="el-icon-circle-plus-outline" @click="add('add')">新增</el-button> |
| | | <div style="display: flex"> |
| | | <el-button |
| | | v-waves |
| | | icon="el-icon-refresh-right" |
| | | @click="syncSeaveSearchPartner" |
| | | >同步往来单位 |
| | | </el-button> |
| | | <el-button v-waves icon="el-icon-download" @click="upload">导入</el-button> |
| | | </div> |
| | | </div> |
| | | |
| | | <div class="bodyTopFormGroup"> |
| | | <el-form |
| | | ref="form" |
| | | :model="form" |
| | | label-width="80px" |
| | | label-width="100px" |
| | | inline |
| | | style="display: flex;justify-content: space-between" |
| | | style="display: flex;" |
| | | > |
| | | <div class="elForm"> |
| | | <el-form-item label="单位编码" style=" display: flex;"> |
| | |
| | | <el-input v-model="form.CreateUser" style="width: 200px" placeholder="请输入" /> |
| | | </el-form-item> |
| | | </div> |
| | | <div style="display: flex;align-items: start;margin-top: 5px;z-index: 2"> |
| | | <el-button type="primary" icon="el-icon-search" @click="search">查询</el-button> |
| | | <el-button type="info" icon="el-icon-refresh" @click="reset">重置</el-button> |
| | | <div |
| | | class="bodySearchReset" |
| | | :style="{marginLeft:$store.state.app.sidebar.opened? $store.state.settings.menuIsHorizontal?'15%':'3%':'10%'}" |
| | | > |
| | | <el-button v-waves type="primary" icon="el-icon-search" @click="search">查询</el-button> |
| | | <el-button v-waves type="info" icon="el-icon-refresh" @click="reset">重置</el-button> |
| | | </div> |
| | | </el-form> |
| | | <div |
| | | class="bodyTopFormExpand" |
| | | /> |
| | | </div> |
| | | |
| | | <div class="elTableDiv"> |
| | | <el-table |
| | | ref="tableDataRef" |
| | | :data="tableData" |
| | | border |
| | | class="tableFixed" |
| | | :height="tableHeight+'px'" |
| | | :row-class-name="tableRowClassName" |
| | | highlight-current-row |
| | |
| | | <el-table-column |
| | | prop="code" |
| | | label="单位编码" |
| | | show-tooltip-when-overflow |
| | | sortable="custom" |
| | | min-width="110" |
| | | /> |
| | |
| | | prop="name" |
| | | label="单位名称" |
| | | sortable="custom" |
| | | min-width="160px" |
| | | min-width="240px" |
| | | show-tooltip-when-overflow |
| | | /> |
| | | <el-table-column |
| | | label="单位属性" |
| | | width="240" |
| | | show-tooltip-when-overflow |
| | | width="160" |
| | | sortable="custom" |
| | | prop="type" |
| | | > |
| | | <!-- sortable="custom"--> |
| | | <template slot-scope="{row}"> |
| | | <div style="display: flex;justify-content: flex-start"> |
| | | <div v-if="row.mtype==='WG'" style="margin-right: 15px">外购供方</div> |
| | | <div v-if="row.btype==='WX'" style="margin-right: 15px;">外协供方</div> |
| | | <div v-if="row.htype==='KH'">客户</div> |
| | | </div> |
| | | <div v-if="row.type==='226'">客户</div> |
| | | <div v-else-if="row.type==='211'">供应商</div> |
| | | <div v-else-if="row.type==='228'">客户/供应商</div> |
| | | <div v-else>/</div> |
| | | <!-- <div style="display: flex;justify-content: flex-start">--> |
| | | <!-- <div v-if="row.mtype==='211'" style="margin-right: 15px">供应商</div>--> |
| | | <!-- <div v-if="row.btype==='228'" style="margin-right: 15px;">客户/供应商</div>--> |
| | | <!-- <div v-if="row.htype==='226'">客户</div>--> |
| | | <!-- </div>--> |
| | | </template> |
| | | <!-- <el-table-column--> |
| | | <!-- prop="mtype"--> |
| | | <!-- width="80"--> |
| | | <!-- >--> |
| | | <!-- <template slot-scope="{row}">--> |
| | | <!-- <div v-if="row.mtype==='WG'">外购供方</div>--> |
| | | <!-- <div v-else>/</div>--> |
| | | <!-- </template>--> |
| | | <!-- </el-table-column>--> |
| | | <!-- <el-table-column--> |
| | | <!-- prop="btype"--> |
| | | <!-- width="80"--> |
| | | <!-- >--> |
| | | <!-- <template slot-scope="{row}">--> |
| | | <!-- <div v-if="row.btype==='WX'">外协供方</div>--> |
| | | <!-- <div v-else>/</div>--> |
| | | <!-- </template>--> |
| | | <!-- </el-table-column>--> |
| | | <!-- <el-table-column--> |
| | | <!-- prop="htype"--> |
| | | <!-- width="80"--> |
| | | <!-- >--> |
| | | <!-- <template slot-scope="{row}">--> |
| | | <!-- <div v-if="row.htype==='KH'">客户</div>--> |
| | | <!-- <div v-else>/</div>--> |
| | | <!-- </template>--> |
| | | <!-- </el-table-column>--> |
| | | |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="conttacts" |
| | | label="联系人" |
| | | width="110" |
| | | show-tooltip-when-overflow |
| | | sortable="custom" |
| | | /> |
| | | > |
| | | <template slot-scope="{row}"> |
| | | <div v-if="row.conttacts">{{ row.conttacts }}</div> |
| | | <div v-else>/</div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="conttphone" |
| | | label="联系方式" |
| | | show-tooltip-when-overflow |
| | | width="160" |
| | | sortable="custom" |
| | | /> |
| | | > |
| | | <template slot-scope="{row}"> |
| | | <div v-if="row.conttphone">{{ row.conttphone }}</div> |
| | | <div v-else>/</div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="addr" |
| | | min-width="160" |
| | | label="补充描述" |
| | | show-tooltip-when-overflow |
| | | sortable="custom" |
| | | /> |
| | | > |
| | | <template slot-scope="{row}"> |
| | | <div v-if="row.addr">{{ row.addr }}</div> |
| | | <div v-else>/</div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="lm_user" |
| | | label="创建人员" |
| | | width="110" |
| | | show-tooltip-when-overflow |
| | | sortable="custom" |
| | | /> |
| | | <el-table-column |
| | |
| | | label="创建时间" |
| | | sortable="custom" |
| | | width="160" |
| | | show-tooltip-when-overflow |
| | | /> |
| | | <el-table-column |
| | | label="操作" |
| | |
| | | <template slot-scope="{row}"> |
| | | <div class="operationClass"> |
| | | <el-tooltip class="item" effect="dark" content="编辑" placement="top"> |
| | | <i class="el-icon-edit-outline" @click="edit('edit',row)" /> |
| | | <i :style="{color:$store.state.settings.theme}" class="el-icon-edit-outline" @click="edit('edit',row)" /> |
| | | </el-tooltip> |
| | | <el-tooltip v-del-tab-index class="item" effect="dark" content="删除" placement="top"> |
| | | <i class="el-icon-delete" @click="del(row)" /> |
| | | <i :style="{color:$store.state.settings.theme}" class="el-icon-delete" @click="del(row)" /> |
| | | </el-tooltip> |
| | | </div> |
| | | </template> |
| | |
| | | </div> |
| | | |
| | | <el-dialog |
| | | v-el-drag-dialog |
| | | :title="operation==='add'?'新增':'编辑'" |
| | | :visible.sync="dialogVisible" |
| | | width="800px" |
| | |
| | | <el-form-item label="单位名称" prop="unitname"> |
| | | <el-input v-model="dialogForm.unitname" style="width: 220px" /> |
| | | </el-form-item> |
| | | <el-form-item style="width: 100%" label="单位属性" prop="checkboxIsSelected"> |
| | | <el-checkbox-group v-model="dialogForm.checkboxIsSelected" @change="checkboxGroupChange"> |
| | | <el-checkbox key="WG" value="WG" label="外购供方" /> |
| | | <el-checkbox key="WX" value="WX" label="外协供方" /> |
| | | <el-checkbox key="KH" value="KH" label="客户" /> |
| | | </el-checkbox-group> |
| | | <el-form-item style="width: 100%" label="单位属性" prop="type"> |
| | | <el-radio-group v-model="dialogForm.type"> |
| | | <el-radio key="226" value="226" label="客户" /> |
| | | <el-radio key="211" value="211" label="供应商" /> |
| | | <el-radio key="228" value="228" label="客户/供应商" /> |
| | | </el-radio-group> |
| | | |
| | | <!-- <el-select--> |
| | | <!-- v-model="dialogForm.UnitAttr"--> |
| | | <!-- :popper-append-to-body="false"--> |
| | | <!-- filterable--> |
| | | <!-- style="width: 200px"--> |
| | | <!-- placeholder="请选择"--> |
| | | <!-- >--> |
| | | <!-- <el-option--> |
| | | <!-- v-for="item in UnitAttrArr"--> |
| | | <!-- :key="item.value"--> |
| | | <!-- :label="item.label"--> |
| | | <!-- :value="item.value"--> |
| | | <!-- />--> |
| | | <!-- </el-select>--> |
| | | </el-form-item> |
| | | <el-form-item label="联系人" prop="person"> |
| | | <el-input v-model="dialogForm.person" style="width: 220px" /> |
| | |
| | | </el-form> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <div class="footerButton"> |
| | | <el-button @click="dialogVisibleCancel">取 消</el-button> |
| | | <el-button type="primary" @click="dialogVisibleConfirm">确 定</el-button> |
| | | <el-button v-waves @click="dialogVisibleCancel">取 消</el-button> |
| | | <el-button |
| | | v-waves |
| | | type="primary" |
| | | :loading="$store.state.app.buttonIsDisabled" |
| | | :disabled="$store.state.app.buttonIsDisabled" |
| | | @click="dialogVisibleConfirm" |
| | | >确 定</el-button> |
| | | </div> |
| | | </span> |
| | | </el-dialog> |
| | |
| | | } from '@/api/jcsz' |
| | | import { SeaveSearchPartner } from '@/api/ErpSyncMes' |
| | | import ImportPicker from '@/components/ImportPicker' |
| | | |
| | | const SER_HZ = /^[\u4e00-\u9fa5]+$/ |
| | | import { validateCode } from '@/utils/global' |
| | | import elDragDialog from '@/directive/el-drag-dialog' |
| | | import waves from '@/directive/waves' |
| | | export default { |
| | | name: 'WLDW', |
| | | components: { |
| | | Pagination, ImportPicker |
| | | }, |
| | | directives: { elDragDialog, waves }, |
| | | data() { |
| | | const validateName = (rule, value, callback) => { |
| | | if (!value) { |
| | | return callback(new Error('请输入编码')) |
| | | } else { |
| | | if (SER_HZ.test(value)) { |
| | | return callback(new Error('编码不能为中文')) |
| | | } else { |
| | | callback() |
| | | } |
| | | } |
| | | } |
| | | const validateMobile = (rule, value, callback) => { |
| | | if (!value) { |
| | | callback() |
| | |
| | | rows: 20 // 每页多少条 |
| | | }, |
| | | UnitAttrArr: [ |
| | | { label: '外购供方', value: 'WG' }, |
| | | { label: '外协供方', value: 'WX' }, |
| | | { label: '客户', value: 'KH' } |
| | | { label: '客户', value: '226' }, |
| | | { label: '供应商', value: '211' }, |
| | | { label: '客户/供应商', value: '228' } |
| | | ], |
| | | tableData: [], |
| | | total: 10, |
| | | dialogVisible: false, |
| | | dialogForm: { |
| | | checkboxIsSelected: [], // 存储el-checkbox-grounp选中的值 |
| | | |
| | | id: '', // 往来单位id |
| | | unitcode: '', // 往来单位编码 |
| | | unitname: '', // 往来单位名称 |
| | | // mtypecode: '', // 外购编码 |
| | | // btypecode: '', // 外协编码 |
| | | // htypecode: '', // 客户编码 |
| | | type: '', // 单位属性 |
| | | person: '', // 联系人 |
| | | contact: '', // 联系方式 |
| | | description: '', // 补充描述 |
| | |
| | | operation: '', |
| | | dialogFormRules: { |
| | | unitcode: [ |
| | | { required: true, validator: validateName, trigger: ['blur', 'change'] } |
| | | { required: true, validator: validateCode, trigger: ['blur', 'change'] } |
| | | ], |
| | | unitname: [ |
| | | { required: true, message: '请输入供方名称', trigger: ['blur', 'change'] } |
| | | { required: true, message: '请输入单位名称', trigger: ['blur', 'change'] } |
| | | ], |
| | | checkboxIsSelected: [ |
| | | { required: true, message: '请选择供方属性', trigger: ['blur', 'change'] } |
| | | type: [ |
| | | { required: true, message: '请选择单位属性', trigger: ['blur', 'change'] } |
| | | ], |
| | | contact: [ |
| | | { required: false, validator: validateMobile, trigger: ['blur', 'change'] } |
| | |
| | | this.form.CreateUser = '' |
| | | this.getCurrentUnitSearch() |
| | | }, |
| | | // 复选框改变事件 |
| | | checkboxGroupChange(val) { |
| | | this.dialogForm.checkboxIsSelected = val |
| | | this.dialogForm.checkboxIsSelected = this.dialogForm.checkboxIsSelected.filter(item => item !== null) |
| | | }, |
| | | |
| | | // 新增按钮 |
| | | add(operation) { |
| | | this.operation = operation |
| | |
| | | this.operation = operation |
| | | this.dialogVisible = true |
| | | |
| | | this.dialogForm.id = row.id |
| | | let mtype = null |
| | | let btype = null |
| | | let htype = null |
| | | |
| | | if (row.mtype === 'WG') { |
| | | mtype = '外购供方' |
| | | } |
| | | if (row.btype === 'WX') { |
| | | btype = '外协供方' |
| | | } |
| | | if (row.htype === 'KH') { |
| | | htype = '客户' |
| | | } |
| | | |
| | | this.$nextTick(() => { |
| | | this.dialogForm.checkboxIsSelected = [btype, htype, mtype] |
| | | this.dialogForm.id = row.id |
| | | this.dialogForm.type = this.UnitAttrArr.find(i => i.value === row.type).label |
| | | this.dialogForm.unitcode = row.code |
| | | this.dialogForm.unitname = row.name |
| | | this.dialogForm.person = row.conttacts |
| | |
| | | DeleteCurrentUnit({ unitcode: row.code }).then(res => { |
| | | if (res.code === '200') { |
| | | this.$message.success('删除成功!') |
| | | if (this.form.page > 1 && this.tableData.length === 1) { |
| | | this.form.page-- |
| | | } |
| | | this.getCurrentUnitSearch() |
| | | } |
| | | }) |
| | |
| | | this.dialogForm.person = '' |
| | | this.dialogForm.contact = '' |
| | | this.dialogForm.description = '' |
| | | this.dialogForm.checkboxIsSelected = [] |
| | | this.dialogForm.type = '' |
| | | this.$refs.dialogForm.clearValidate() |
| | | }, |
| | | // 对话框取消 |
| | |
| | | dialogVisibleConfirm() { |
| | | this.$refs.dialogForm.validate(valid => { |
| | | if (valid) { |
| | | let mtypecode = null // 外购编码 |
| | | let btypecode = null // 外协编码 |
| | | let htypecode = null // 客户编码 |
| | | const checkboxIsSelected = this.dialogForm.checkboxIsSelected// 存储el-checkbox-grounp选中的值 |
| | | if (checkboxIsSelected.includes('外购供方')) { |
| | | mtypecode = 'WG' |
| | | } |
| | | if (checkboxIsSelected.includes('外协供方')) { |
| | | btypecode = 'WX' |
| | | } |
| | | if (checkboxIsSelected.includes('客户')) { |
| | | htypecode = 'KH' |
| | | } |
| | | this.$store.state.app.buttonIsDisabled = true |
| | | |
| | | const data = { |
| | | id: this.dialogForm.id, |
| | | unitcode: this.dialogForm.unitcode, |
| | | unitname: this.dialogForm.unitname, |
| | | mtypecode: mtypecode, |
| | | btypecode: btypecode, |
| | | htypecode: htypecode, |
| | | typecode: this.UnitAttrArr.find(i => i.label === this.dialogForm.type).value, |
| | | person: this.dialogForm.person, |
| | | contact: this.dialogForm.contact, |
| | | description: this.dialogForm.description, |
| | | OperType: this.operation === 'add' ? 'Add' : 'Update' |
| | | } |
| | | // console.log(data, 2) |
| | | |
| | | AddUpdateCurrentUnit(data).then(res => { |
| | | if (res.code === '200') { |
| | | this.$message.success(this.operation === 'add' ? '添加成功!' : '修改成功!') |
| | | this.dialogVisible = false |
| | | this.$message.success(this.operation === 'add' ? '添加成功!' : '修改成功!') |
| | | this.getCurrentUnitSearch() |
| | | this.$store.state.app.buttonIsDisabled = false |
| | | } else { |
| | | this.$message.error(this.operation === 'add' ? '添加失败!' : '修改失败!') |
| | | this.$store.state.app.buttonIsDisabled = false |
| | | } |
| | | }) |
| | | } |
| | |
| | | getHeight() { |
| | | this.$nextTick(() => { |
| | | this.mainHeight = window.innerHeight - 85 |
| | | this.tableHeight = this.mainHeight - 200 |
| | | this.tableHeight = this.mainHeight - 195 |
| | | if (window.innerHeight < 769) { |
| | | this.tableHeight = this.tableHeight - 40 |
| | | } |
| | | this.$refs.tableDataRef.doLayout() |
| | | }) |
| | | }, |
| | | |
| | |
| | | .userDialogVisible ::v-deep .el-form-item { |
| | | margin-bottom: 0; |
| | | } |
| | | |
| | | .tableFixed{ |
| | | ::v-deep .el-table__fixed-right{ |
| | | height: 100% !important; |
| | | } |
| | | ::v-deep .el-table__fixed{ |
| | | height: 100% !important; |
| | | } |
| | | } |
| | | </style> |
| | | <style> |
| | | |