config.ts 1.31 KB
import cloneDeep from 'lodash-es/cloneDeep';
import { LateralNumericalControlConfig } from '.';
import {
  ConfigType,
  CreateComponentType,
  PublicComponentOptions,
  PublicPresetOptions,
} from '/@/views/visual/packages/index.type';
import { PublicConfigClass, componentInitConfig } from '/@/views/visual/packages/publicConfig';
import { ComponentConfigFieldEnum } from '../../../enum';

export const option: PublicPresetOptions = {
  [ComponentConfigFieldEnum.SHOW_DEVICE_NAME]: false,
  [ComponentConfigFieldEnum.CONTROL_BAR_COLOR]: '#0072ff',
  [ComponentConfigFieldEnum.FONT_COLOR]: '#000000',
  [ComponentConfigFieldEnum.TEXT_COLOR]: '#000000',
  [ComponentConfigFieldEnum.MIN_NUMBER]: 0,
  [ComponentConfigFieldEnum.MAX_NUMBER]: 100,
  [ComponentConfigFieldEnum.FONT_SIZE]: 14,
  [ComponentConfigFieldEnum.VALUE_SIZE]: 20,
  [ComponentConfigFieldEnum.PASS_WORD]: '',
};

export default class Config extends PublicConfigClass implements CreateComponentType {
  public key: string = LateralNumericalControlConfig.key;

  public attr = { ...componentInitConfig };

  public componentConfig: ConfigType = cloneDeep(LateralNumericalControlConfig);

  public persetOption = cloneDeep(option);

  public option: PublicComponentOptions;

  constructor(option: PublicComponentOptions) {
    super();
    this.option = { ...option };
  }
}