import { observable, action, computed, extendObservable } from 'mobx'; import * as mobx from 'mobx'; import * as Api from '../apis/resource'; // 引入API接口文件 import { WeaForm, WeaTableNew } from 'comsMobx'; import { Modal, message, Button } from 'antd' import { WeaSelect, WeaInputSearch, WeaLocaleProvider, } from 'ecCom'; import { i18n } from '../public/i18n'; import { getSecondPath } from '../util/index' import { cloneDeep, isEmpty, trim } from 'lodash'; const getLabel = WeaLocaleProvider.getLabel; const toJS = mobx.toJS; const { TableStore } = WeaTableNew; export class ResourceStore { @observable tableStore = new TableStore(); @observable topMenu = [] @observable rightMenu = []; @observable condition = []; @observable searchCondition = []; @observable defaultCondition = []; @observable isEdit = true; @observable isNew = true; @observable isPanelShow = false; //高级搜索面板 @observable form2 = new WeaForm(); @observable form = new WeaForm(); @observable lastName = ''; @observable conditionNum = 8; @observable ids = ''; //选择行id @observable searchConditionLoading = false; @observable nEdialogTitle = ''; @observable visible = false; @observable dialogLoading = true; @observable userId = ''; @observable date = ''; @observable exSpinning = false; @observable defaultShowLeft = true; @observable companysId = 1 @observable hasRight = ''; @observable selectTreeNodeInfo; @observable enable = false; @observable _showRadioGroup = false; @computed get showRadioGroup() { return this._showRadioGroup } set showRadioGroup(v) { this._showRadioGroup = v; setTimeout(() => { this.reCalculateTableHeight = new Date().getTime(); }, 0) } domRef = {}; @observable _reCalculateTableHeight = new Date().getTime(); @computed get reCalculateTableHeight() { return this._reCalculateTableHeight } set reCalculateTableHeight(v) { this._reCalculateTableHeight = v } @computed get tableHeihgt() { this.reCalculateTableHeight; const topHeight = this.domRef.top && this.domRef.top.refs.content ? this.domRef.top.refs.content.clientHeight : 0; const tabHeight = this.domRef.tab ? $(this.domRef.tab)[0].clientHeight : 0; const h = topHeight - tabHeight; return h <= 0 ? 0 : h; } @action setDomRef = (dom, type) => { dom && Object.assign(this.domRef, { [type]: dom }) && setTimeout(() => this.reCalculateTableHeight = new Date().getTime(), 500); } @observable rangeConditions = []; @observable radioParams = {}; @observable refreshRadioGroup = new Date().getTime(); @computed get radioGroupConfig(){ this.refreshRadioGroup; return { config: [ ...this.rangeConditions ], key: new Date().getTime(), onChange: this.onRadioGroupChangeHandle } } @action onRadioGroupChangeHandle = params => { this.radioParams = params; this.getTableInfo(); } @action("列表") getTableInfo() { this.tableStore = new TableStore(); let params = {}; if(this.isEmptyObject(this.radioParams)) { params = { ...this.selectTreeNodeInfo, isQuickSearch:false } if (this.isEmptyObject(this.form2.getFormParams())) { params = { ...params, lastName: this.lastName, }; } else { params = { ...params, ...this.form2.getFormParams() }; } }else { params = { ...this.radioParams, ...this.selectTreeNodeInfo, isQuickSearch:true } } this.form2.resetForm(); Api.getSearchList(params).then(res => { if (res.code === 200) { res.data.datas && this.tableStore.getDatas(res.data.datas, 1); } else { message.warning(res.msg); } }, error => { message.warning(error.msg); }) } @action("nodetree事件") doSearch(params) { this.selectTreeNodeInfo = params; this.showRadioGroup = true; this.getTableInfo(); } @action("保存") save() { let params = { ...this.form.getFormParams() }; this.form.validateForm().then(f => { if (f.isValid) { Api.add(params).then(response => { return response.json() }).then(data => { if (data.code === 200) { message.success(data.msg,1); this.getTableInfo(); this.setVisible(false); } else { message.warning(data.msg); } }).catch(error => { message.warning(error.msg); }) } else { f.showErrors(); this.setDate(new Date()); } }); } @action("新增表单") getForm() { let params = this.isNew ? {} : { id: this.userId } this.setDialogLoadingStatus(true); Api.getSchemeForm(params).then(res => { if (res.code === 200) { this.setDialogLoadingStatus(false); res.data.condition && this.setCondition(res.data.condition); res.data.condition && this.form.initFormFields(res.data.condition); } else { message.warning(res.msg); } }, error => { message.warning(error.msg); }) } @action("高级搜索表单") getSearchCondition(key = true) { this.setScLoadingStatus(true); this.form2 = new WeaForm(); let params = {}; key ? params = { templateId: this.searchTemplateId } : params = { selectKeys: this.transfer.transferKeys, } Api.getAdvanceSearchCondition(params).then(res => { if (res.code === 200) { this.setScLoadingStatus(false); res.data.conditions && this.setSearchCondition(res.data.conditions); res.data.defaultcondition && this.setDefaultCondition(res.data.defaultcondition); res.data.defaultcondition && this.form2.initFormFields(res.data.defaultcondition); } else { message.warning(res.msg); } }, error => { message.warning(error.msg); }) } @action("快捷搜索") getQuickSearchCondition() { Api.getQuickSearchCondition().then(res => { if (res.code === 200) { this.rangeConditions = res.data.rangeConditions; this.enable = res.data.enable; } else { message.warning(res.msg); } }, error => { message.warning(error.msg); }) } @action("顶部按钮") getHasRight() { Api.getHasRight().then(res => { if (res.code === 200) { this.setHasRight(res.data.hasRight); res.data.rightMenu && this.setRightMenu(res.data.rightMenu); res.data.topMenu && this.setTopMenu(res.data.topMenu); } else { message.warning(res.msg); } }, error => { message.warning(error.msg); }) } @action("导出") async export() { const params = { ...this.form.getFormParams() } this.exSpinning = true; await Api.exportResource(toJS(this.tableStore.selectedRowKeysAllPages).toString()); this.exSpinning = false; this.tableStore.selectedRowKeys = []; } @action("另存为版本") version(id) { Api.version({ id: id }).then(res => { if (res.code === 200) { message.success(res.msg); } else { message.warning(res.msg); } }, error => { message.warning(error.msg); }) } /** ============================================================================================= */ @observable search = true; @observable searchDialog = { visible: false, loading: true } @observable templates = []; @observable customTemplates = []; @observable searchTemplateName = ''; @observable searchTemplateId = "-1"; @observable customTemplateName = ''; @observable customTemplateId = '-1'; @observable search = false; SEARCHDIALOG = { hasScroll: false, icon: 'icon-coms-hrm', iconBgcolor: '#217346', onCancel: () => this.closeSearchDialog(), style: { width: 700, height: 450 }, moreBtn: { datas: [] }, } TRANSFER = { height: 350, renderItem: (items) => this.renderItem(items), filterLeft: (items) => this.filterLeft(items), filterRight: (items) => this.filterRight(items), onChange: (v) => this.updateTransferKeys(v) } @observable transfer = { transferDatas: [], transferKeys: [], transferOptions: [], transferSelectedKey: '0', transferleftIptVal: '', transferRightIptVal: '' } @action("常用条件定制保存") saveHrmSearchUserDefine = () => { this.closeSearchDialog(); this.getSearchCondition(false); } @action("列定制保存") saveCustomDefine = () => { if (this.customTemplateId == '-1') { message.error(getLabel(547650,'默认模板不能修改,将返回默认模板列')); } const params = { columns: this.transfer.transferKeys, templateId: this.customTemplateId } Api.saveColumnsCustomTemplate(params).then(res => { if (res.code === 200) { this.searchDialog.visible = false; this.getTableInfo(); } }, error => { message.warning(error.msg); }) } @action("高级搜索模板切换") changeSearchTemplate(v) { this.searchTemplateId = v; this.getSearchCondition(); } @action("常用条件定制") formatTransfer = () => { const transferDatas = [] const transferKeys = [] const transferOptions = [{ key: "", showname: "" }] this.transfer.transferSelectedKey = '0'; this.transfer.transferleftIptVal = ''; this.transfer.transferRightIptVal = ''; this.searchCondition.forEach((c, idx) => { transferOptions.push({ key: `${idx}`, showname: c.title, }) c.items.forEach((i) => { transferDatas.push({ id: i.domkey[0], label: i.label, title: c.title, idx: `${idx}` }) }) }) this.defaultCondition.forEach((c, idx) => { c.items.forEach((i) => { transferKeys.push(i.domkey[0]); }) }) this.transfer.transferDatas = transferDatas; this.transfer.transferKeys = transferKeys; this.transfer.transferOptions = transferOptions; this.searchDialog.visible = true; } @action("列定制") customization = (v = false) => { this.openCustomDialog(v); } @action("常用条件定制模板切换") getTemplateSelectKeys = v => { if (!this.search) { this.customTemplateId = v; } const params = { templateId: v, type: this.search ? 'search' : 'custom' } Api.getTemplateSelectKeys(params).then(res => { if (res.code === 200) { this.transfer.transferKeys = res.data.split(","); } else { message.warning(res.msg); } }, error => { message.warning(error.msg); }) } @action("搜索模板保存") saveTemplate = () => { if (this.searchTemplateName == '') { message.error(getLabel(547651,'搜索模板的名称不能为空')); } else { const fields = []; this.defaultCondition.forEach((c, idx) => { c.items.forEach((i) => { fields.push(i.domkey[0]); }) }) const params = { showname: this.searchTemplateName, fields: fields.toString() } Api.saveSearchTemplate(params).then(response => { return response.json() }).then(data => { if (data.code === 200) { this.searchTemplateId = data.data; this.templates = []; this.setPanelStatus(true); } else { message.warning(data.msg); } }).catch(error => { message.warning(error.msg); }) } } @action("常用定制列模板保存") saveCustomTemplate = () => { if (this.customTemplateName == '') { message.error(getLabel(547652,'列定制模板的名称不能为空')); } else { const params = { showname: this.customTemplateName, fields: this.transfer.transferKeys.toString() } Api.saveCustomTemplate(params).then(response => { return response.json() }).then(data => { if (data.code === 200) { this.customTemplateId = data.data; // this.getSearchTemplate(false); this.customization(); message.success(data.msg); } else { message.warning(data.msg); } }).catch(error => { message.warning(error.msg); }) } } @action("搜索模板删除") deleteSearchTemplate = () => { if (this.searchTemplateId == -1) { return message.error(getLabel(547653,'默认模板不可删除')); } Api.deleteSearchTemplate({ id: this.searchTemplateId }).then(response => { return response.json() }).then(data => { if (data.code === 200) { message.success(data.msg); this.searchTemplateId = '-1'; this.templates = []; this.setPanelStatus(true); } else { message.warning(data.msg); } }).catch(error => { message.warning(error.msg); }) } inputSearchStyle = { width: "105px", float: "right", marginTop: "5px", marginLeft: "10px" } selectStyle = { marginTop: "-1px", width: "85px", float: "right" } @computed get leftHeader() { const { transferleftIptVal, transferOptions, transferSelectedKey } = this.transfer; return (