123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- <template>
- <a-card :bordered="false" v-show="visible" class="card" :title="modalTitle">
- <a-form :form="form">
- <a-form-item v-show="false">
- <a-input v-decorator="['id']" type="hidden"/>
- </a-form-item>
- <row-list :col="2">
- <row-item>
- <a-form-item
- label="设备Id"
- :labelCol="BaseTool.Constant.labelCol"
- :wrapperCol="BaseTool.Constant.wrapperCol"
- >
- <a-input
- style="width: 70%"
- disabled
- v-decorator="['sbInfoName', {rules: [{required: true, message: '设备名称不能为空'}]}]" />
- <a-button style="width: 30%" type="primary" @click="sbInfoHandleSelect">选择</a-button>
- </a-form-item>
- </row-item>
- <row-item>
- <a-form-item
- label="类型"
- :labelCol="BaseTool.Constant.labelCol"
- :wrapperCol="BaseTool.Constant.wrapperCol"
- >
- <a-select
- v-decorator="['type', {rules: [{required: true, message: '类型不能为空'}]}]"
- placeholder="请选择">
- <a-select-option
- v-for="(label,value) in typeMap"
- :key="value"
- :label="label"
- :value="parseInt(value)">{{ label }}
- </a-select-option>
- </a-select>
- </a-form-item>
- </row-item>
- <row-item>
- <a-form-item
- label="状态"
- :labelCol="BaseTool.Constant.labelCol"
- :wrapperCol="BaseTool.Constant.wrapperCol"
- >
- <a-select
- v-decorator="['status', {rules: [{required: true, message: '状态不能为空'}]}]"
- placeholder="请选择">
- <a-select-option
- v-for="(label,value) in statusMap"
- :key="value"
- :label="label"
- :value="parseInt(value)">{{ label }}
- </a-select-option>
- </a-select>
- </a-form-item>
- </row-item>
- </row-list>
- </a-form>
- <template slot="footer">
- <a-button :loading="confirmLoading" type="primary" @click="save()">保存</a-button>
- </template>
- <sb-info-select-modal ref="sbInfoSelectModal" @selected="sbInfoHandleSelected"/>
- </a-card>
- </template>
- <script>
- import pick from 'lodash.pick'
- import {addSbInfoStopDetail, updateSbInfoStopDetail } from '@/api/sb/sb-stop-details'
- export default {
- name: 'BaseSbInfoStopDetail',
- data() {
- return {
- confirmLoading: false,
- modalTitle: null,
- form: this.$form.createForm(this),
- visible: false,
- // 下拉框map
- typeMap: {},
- statusMap: {},
- }
- },
- props: {},
- created() {
- // 下拉框map
- this.typeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SB_INFO_STOP_DETAIL_)
- this.statusMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SB_INFO_STOP_DETAIL_)
- },
- methods: {
- base(record) {
- this.visible = true
- // 如果是空标识添加
- if (this.BaseTool.Object.isBlank(record)) {
- this.modalTitle = '添加'
- return
- }
- this.modalTitle = '编辑'
- const {form: {setFieldsValue}} = this
- // 日期处理
- this.$nextTick(() => {
- setFieldsValue(Object.assign(pick(record, [
- 'sbId',
- 'type',
- 'status',
- ])))
- })
- },
- save() {
- const {form: {validateFieldsAndScroll}} = this
- this.confirmLoading = true
- validateFieldsAndScroll((errors, values) => {
- if (errors) {
- this.confirmLoading = false
- return
- }
- // 日期处理
- if (this.BaseTool.String.isBlank(values.id)) {
- addSbInfoStopDetail(values)
- .then(() => {
- this.handleCancel(values)
- }).catch(() => {
- this.confirmLoading = false
- })
- } else {
- updateSbInfoStopDetail(values)
- .then(() => {
- this.handleCancel(values)
- }).catch(() => {
- this.confirmLoading = false
- })
- }
- })
- },
- handleCancel(values) {
- this.visible = false
- this.confirmLoading = false
- this.form.resetFields()
- if (this.BaseTool.Object.isNotBlank(values)) {
- this.$emit('ok', values)
- }
- }
- ,
- sbInfoHandleSelect () {
- this.$refs.sbInfoSelectModal.base({}, {})
- },
- sbInfoHandleSelected (keys, rows) {
- const [ key ] = keys
- const [ row ] = rows
- const { form: { setFieldsValue } } = this
- // 日期处理
- this.$nextTick(() => {
- setFieldsValue(Object.assign({
- 'sbId': key,
- 'sbInfoName': row.name
- }))
- })
- },
- }
- }
- </script>
|