import { MainViewBase } from "./main-view-base";
import { MobOptViewInterface, ModelTool } from 'ibiz-core';
import { IPSAppDEMobEditView, IPSDEForm } from "@ibiz/dynamic-model-api";

/**
 * 选项操作视图基类
 *
 * @export
 * @class MobOptViewBase
 * @extends {MainViewBase}
 */
export class MobOptViewBase extends MainViewBase implements MobOptViewInterface {

    /**
     * 视图实例
     * 
     * @memberof MobOptViewBase
     */
    public declare viewInstance: IPSAppDEMobEditView;

    /**
     * 编辑表单实例
     *
     * @public
     * @type {IBizMobFormModel}
     * @memberof MobOptViewBase
     */
    public editFormInstance !: IPSDEForm;

    /**
     * 表单数据是否变化
     *
     * @public
     * @type {Engine}
     * @memberof MobOptViewBase
     */
    public dataChange: boolean = false;

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

    }

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


    /**
     * 渲染视图主体内容区
     * 
     * @memberof MobOptViewBase
     */
    public renderMainContent() {
        let { targetCtrlName, targetCtrlParam, targetCtrlEvent }: { targetCtrlName: string, targetCtrlParam: any, targetCtrlEvent: any } = this.computeTargetCtrlData(this.editFormInstance);
        return this.$createElement(targetCtrlName, { props: targetCtrlParam, ref: this.editFormInstance.name, on: targetCtrlEvent });
    }

    /**
     *  渲染视图底部按钮
     * 
     * @memberof MobOptViewBase
     */
    public renderFooter() {
        return <div class="view-footer__buttons" slot="footer">
            <app-mob-button
                class="button__item medium"
                color="medium"
                text={this.$t('app.button.cancel')}
                on-click={this.back.bind(this)} />
            <app-mob-button
                class="button__item success"
                text={this.$t('app.button.confirm')}
                on-click={this.save.bind(this)} />
        </div>
    }

    /**
     * 保存按钮事件
     *
     * @protected
     * @memberof MobOptViewBase
     */
    protected save() {
        // 取数
        let datas: any[] = [];
        let xData: any = null;
        let xDataShell: any = this.$refs.form;
        xData = xDataShell?.ctrl;
        if(!xData){
            return;
        }
        if (xData.getDatas && xData.getDatas instanceof Function) {
            datas = [...xData.getDatas()];
        }
        this.viewState.next({ tag: 'form', action: 'saveandexit', data: datas });
    }

    /**
     * 返回按钮事件
     *
     * @protected
     * @memberof MobOptViewBase
     */
    protected back(args: any[]) {
        if (this.viewDefaultUsage === "ROUTERVIEW") {
            this.$store.commit("deletePage", this.$route.fullPath);
            this.$router.go(-1);
        } else {
            this.$emit('view-event', { viewName: this.viewCodeName, action: 'close', data: args instanceof MouseEvent ? null : args });
        }
    }

    /**
     * 部件事件
     * @param ctrl 部件 
     * @param action  行为
     * @param data 数据
     * 
     * @memberof MobOptViewBase
     */
    public onCtrlEvent(controlname: string, action: string, data: any) {
        if (action == 'dataChange') {
            this.dataChange = data;
        }
        super.onCtrlEvent(controlname, action, data);
    }

    /**
     * 检查表单是否修改
     *
     * @param {any[]} args
     * @memberof MobOptViewBase
     */
    public async cheackChange(): Promise<any> {
        if (this.dataChange) {
            const title: any = this.$t('app.tabpage.sureclosetip.title');
            const contant: any = this.$t('app.tabpage.sureclosetip.content');
            const result = await this.$Notice.confirm.call(this, title, contant);
            if (result) {
                this.dataChange = false;
                return true;
            } else {
                return false;
            }
        } else {
            return true;
        }
    }

    /**
     *  关闭视图
     *
     * @memberof MobOptViewBase
     */
    public async closeView(args?: any[]) {
        let result = await this.cheackChange();
        if (result) {
            super.closeView(args);
        }
    }
}