import { IPSAppDEWFActionView, IPSDEForm } from '@ibiz/dynamic-model-api';
import { ModelTool, WFActionViewEngine, WFActionViewInterface } from 'ibiz-core';
import { MainViewBase } from './mainview-base';


/**
 * 工作流操作视图基类
 *
 * @export
 * @class WFActionViewBase
 * @extends {MainViewBase}
 * @implements {WFActionViewInterface}
 */
export class WFActionViewBase extends MainViewBase implements WFActionViewInterface {
    
    /**
     * 视图实例
     * 
     * @memberof WFActionViewBase
     */
    public declare viewInstance: IPSAppDEWFActionView;

    /**
     * 视图引擎
     * 
     * @memberof WFActionViewBase
     */
    public engine: WFActionViewEngine = new WFActionViewEngine();

    /**
     * 表单实例
     * 
     * @memberof WFActionViewBase
     */
    protected formInstance!: IPSDEForm;

    /**
     * 初始化编辑视图实例
     * 
     * @memberof WFActionViewBase
     */
    public async viewModelInit() {
        await super.viewModelInit();
        this.formInstance = ModelTool.findPSControlByName('form',this.viewInstance.getPSControls()) as IPSDEForm;
    }

    /**
     * 引擎初始化
     *
     * @public
     * @memberof WFActionViewBase
     */
    public engineInit(): void {
        if (this.Environment && this.Environment.isPreviewMode) {
            return;
        }
        this.engine.init({
            view: this,
            form: (this.$refs[this.formInstance.name] as any).ctrl,
            p2k: '0',
            isLoadDefault: true,
            keyPSDEField: this.appDeCodeName.toLowerCase(),
            majorPSDEField: this.appDeMajorFieldName.toLowerCase(),
        });
    }

    /**
     * 渲染视图主体内容区
     * 
     * @memberof WFActionViewBase
     */
    public renderMainContent() {
        if(!this.formInstance){
            return;
        }
        let { targetCtrlName, targetCtrlParam, targetCtrlEvent } = this.computeTargetCtrlData(this.formInstance);
        return this.$createElement(targetCtrlName, { slot: 'default', props: targetCtrlParam, ref: "form", on: targetCtrlEvent });
    }

    /**
     * 确定
     *
     * @memberof WFActionViewBase
     */
    public onClickOk(): void {
        const form: any = (this.$refs[this.formInstance.name] as any)?.ctrl;
        if (!form) {
            return;
        }
        form.wfsubmit([{...form.data}]).then((response:any) =>{
            if (!response || response.status !== 200) {
                return;
            }
            this.$emit('view-event', { viewName: this.viewInstance.name, action: 'viewdataschange', data: [{ ...response.data }] });
            this.$emit('view-event', { viewName: this.viewInstance.name, action: 'close', data: null });
        })
    }

    /**
     * 取消
     *
     * @memberof WFActionViewBase
     */
    public onClickCancel(): void {
        this.$store.commit('viewAction/setViewDataChange', { viewTag: this.viewtag, viewDataChange: false });
        this.$emit('view-event', { viewName: this.viewInstance.name, action: 'close', data: null });
    }
}