import Vue from 'vue';
import { IModalUtil, ModalParams } from '@ibiz-template/runtime';
import { ModalConfig, ModalInstance } from 'view-design';

function convertParams(params: ModalParams): ModalConfig {
  const config: IData = { ...params };
  if (config.desc) {
    config.content = config.desc;
    delete config.desc;
  }
  return config;
}

/**
 * 简洁确认操作框
 *
 * @author chitanda
 * @date 2022-08-17 16:08:52
 * @export
 * @class ModalUtil
 * @implements {IModalUtil}
 */
export class ModalUtil implements IModalUtil {
  protected modal: ModalInstance = Vue.prototype.$Modal;

  async info(params: ModalParams): Promise<void> {
    return new Promise(resolve => {
      this.modal.info({
        ...convertParams(params),
        onOk: () => {
          resolve();
        },
      });
    });
  }

  async success(params: ModalParams): Promise<void> {
    return new Promise(resolve => {
      this.modal.success({
        ...convertParams(params),
        onOk: () => {
          resolve();
        },
      });
    });
  }

  async warning(params: ModalParams): Promise<void> {
    this.modal.warning(convertParams(params));
    return new Promise(resolve => {
      this.modal.warning({
        ...convertParams(params),
        onOk: () => {
          resolve();
        },
      });
    });
  }

  async error(params: ModalParams): Promise<void> {
    return new Promise(resolve => {
      this.modal.error({
        ...convertParams(params),
        onOk: () => {
          resolve();
        },
      });
    });
  }

  async confirm(params: ModalParams): Promise<boolean> {
    return new Promise(resolve => {
      this.modal.confirm({
        ...convertParams(params),
        onOk: () => {
          resolve(true);
        },
        onCancel: () => {
          resolve(false);
        },
      });
    });
  }
}