2020-04-02 20:25:51 +08:00

61 lines
1.6 KiB
TypeScript

import { registerSetter } from '@ali/lowcode-globals';
import { DatePicker, Input, Radio, Select, Switch, NumberPicker } from '@alifd/next';
import ExpressionSetter from './expression-setter';
import MixinSetter from './mixin-setter';
import ColorSetter from './color-setter';
import JsonSetter from './json-setter';
import EventsSetter from './events-setter';
import StyleSetter from './style-setter';
export const StringSetter = {
component: Input,
defaultProps: { placeholder: '请输入' },
};
export const NumberSetter = NumberPicker;
export const BoolSetter = Switch;
// suggest: 做成 SelectSetter 一种变体
export const RadioGroupSetter = {
component: Radio.Group,
defaultProps: {
shape: 'button',
},
};
export const SelectSetter = Select;
// suggest: 做成 StringSetter 的一个参数,
export const TextAreaSetter = Input.TextArea;
export const DateSetter = DatePicker;
export const DateYearSetter = DatePicker.YearPicker;
export const DateMonthSetter = DatePicker.MonthPicker;
export const DateRangeSetter = DatePicker.RangePicker;
export { ExpressionSetter, MixinSetter, EventsSetter, StyleSetter }
// todo:
export const ClassNameSetter = () => {
return <div className="lc-block-setter"></div>;
};
const builtinSetters = {
StringSetter,
NumberSetter,
BoolSetter,
SelectSetter,
ExpressionSetter: ExpressionSetter as any,
MixinSetter,
RadioGroupSetter,
TextAreaSetter,
DateSetter,
DateYearSetter,
DateMonthSetter,
DateRangeSetter,
EventsSetter,
StyleSetter,
ColorSetter,
JsonSetter,
};
export function registerSetters() {
registerSetter(builtinSetters);
}