import { Prop, Provide, Emit, Model } from 'vue-property-decorator'; import { Subject, Subscription } from 'rxjs'; import { Watch, GridControllerBase } from '@/studio-core'; import CampaignResponseService from '@/service/campaign-response/campaign-response-service'; import MainService from './main-grid-service'; import { FormItemModel } from '@/model/form-detail'; /** * grid部件基类 * * @export * @class GridControllerBase * @extends {MainGridBase} */ export class MainGridBase extends GridControllerBase { /** * 获取部件类型 * * @protected * @type {string} * @memberof MainGridBase */ protected controlType: string = 'GRID'; /** * 建构部件服务对象 * * @type {MainService} * @memberof MainGridBase */ public service: MainService = new MainService({ $store: this.$store }); /** * 实体服务对象 * * @type {CampaignResponseService} * @memberof MainGridBase */ public appEntityService: CampaignResponseService = new CampaignResponseService({ $store: this.$store }); /** * 应用实体名称 * * @protected * @type {string} * @memberof MainGridBase */ protected appDeName: string = 'campaignresponse'; /** * 本地缓存标识 * * @protected * @type {string} * @memberof GridControllerBase */ protected localStorageTag: string = 'campaignresponse_main_grid'; /** * 所有列成员 * * @type {any[]} * @memberof MainGridBase */ public allColumns: any[] = [ { name: 'subject', label: '主题', langtag: 'entities.campaignresponse.main_grid.columns.subject', show: true, util: 'PX' }, { name: 'updateman', label: '更新人', langtag: 'entities.campaignresponse.main_grid.columns.updateman', show: true, util: 'PX' }, { name: 'updatedate', label: '更新时间', langtag: 'entities.campaignresponse.main_grid.columns.updatedate', show: true, util: 'PX' }, ] /** * 获取表格行模型 * * @type {*} * @memberof MainGridBase */ public getGridRowModel(){ return { srfkey: new FormItemModel(), } } /** * 属性值规则 * * @type {*} * @memberof MainGridBase */ public rules: any = { srfkey: [ { required: false, validator: (rule:any, value:any, callback:any) => { return (rule.required && (value === null || value === undefined || value === "")) ? false : true;}, message: '市场活动响应 值不能为空', trigger: 'change' }, { required: false, validator: (rule:any, value:any, callback:any) => { return (rule.required && (value === null || value === undefined || value === "")) ? false : true;}, message: '市场活动响应 值不能为空', trigger: 'blur' }, ], } /** * 获取对应列class * * @type {*} * @memberof MainBase */ public hasRowEdit: any = { 'subject':false, 'updateman':false, 'updatedate':false, }; /** * 获取对应列class * * @param {*} $args row 行数据,column 列数据,rowIndex 行索引,列索引 * @returns {void} * @memberof MainBase */ public getCellClassName(args: {row: any, column: any, rowIndex: number, columnIndex: number}): any { return ( this.hasRowEdit[args.column.property] && this.actualIsOpenEdit ) ? "edit-cell" : "info-cell"; } /** * 导出数据格式化 * * @param {*} filterVal * @param {*} jsonData * @param {any[]} [codelistColumns=[]] * @returns {Promise<any>} * @memberof MainGridBase */ public async formatExcelData(filterVal: any, jsonData: any, codelistColumns?: any[]): Promise<any> { return super.formatExcelData(filterVal, jsonData, [ { name: 'updateman', srfkey: 'SysOperator', codelistType : 'DYNAMIC', renderMode: 'other', textSeparator: '、', valueSeparator: ',', }, ]); } }