import snippets from './snippets'; import { formItemGeneralDataGroup, getFormItemGeneralInfoGroup, getFormItemValidateGroup, generalItemMap, } from '../_utils/defaultSchema'; export default { snippets, componentName: 'FormItemInput.Subdomain', title: '子域名输入', category: '无代码表单', group: '无代码组件', docUrl: '', screenshot: '', devMode: 'proCode', npm: { package: '@pisell/materials', version: '1.0.1', exportName: 'FormItemInput', main: 'src/index.tsx', destructuring: true, subName: 'Subdomain', }, generalProps: [ formItemGeneralDataGroup, getFormItemGeneralInfoGroup([ generalItemMap['label'], generalItemMap['placeholder'], generalItemMap['tooltip'], generalItemMap['extra'], generalItemMap['hideLabel'], generalItemMap['renderMode'], { name: 'rootDomain', title: { label: { type: 'i18n', 'en-US': 'Root domain', 'zh-CN': '根域名', }, tip: { type: 'i18n', 'en-US': 'Root domain', 'zh-CN': '根域名', }, }, isRequired: true, propType: 'string', setter: { componentName: 'SelectSetter', props: { options: [ { title: 'xZero', value: 'xzero', }, { title: 'SaaS platform', value: 'saas', }, { title: 'Custom', value: 'custom', }, ], }, }, defaultValue: 'xzero', }, { name: 'customDomain', title: { label: { type: 'i18n', 'en-US': 'Custom domain', 'zh-CN': '自定义域名', }, }, propType: 'string', setter: { componentName: 'StringSetter', props: { validate: (value) => { if (value && value[0] !== '.') { return '自定义域名必须以 "." 开头'; } const isValidCustomDomain = /^\.[a-zA-Z0-9-]+(\.[a-zA-Z0-9-]+)*$/.test(value); if (!isValidCustomDomain) { return '自定义域名格式不正确'; } return true; }, }, }, condition: (target) => { return target.getProps().getPropValue('rootDomain') === 'custom'; }, }, generalItemMap['defaultValue'], ]), getFormItemValidateGroup([ generalItemMap['requiredobj'], generalItemMap['minLengthobj'], generalItemMap['maxLengthobj'], { ...generalItemMap['typeobj'], title: { label: { type: 'i18n', 'en-US': 'Subdomain format', 'zh-CN': '子域名格式 ', }, tip: { type: 'i18n', 'en-US': 'Subdomain format', 'zh-CN': '子域名格式 ', }, }, }, ]), ], props: [ { name: 'defaultValue', title: { label: '默认值', tip: '默认内容' }, propType: 'string', setter: 'TextAreaSetter', }, { name: 'value', title: { label: '当前值', tip: '当前值' }, propType: 'string', setter: 'TextAreaSetter', }, { name: 'bordered', title: { label: '显示边框', tip: '是否有边框' }, propType: 'bool', defaultValue: true, setter: 'BoolSetter', }, { name: 'disabled', title: { label: '是否禁用', tip: '是否为禁用状态' }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', }, { name: 'placeholder', title: { label: '占位提示', tip: '占位提示' }, propType: 'string', defaultValue: '请输入', setter: 'PisellI18nSetter', }, { name: 'showCount', title: { label: '展示字数', tip: '是否展示字数' }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', }, { name: 'id', title: { label: '输入框ID', tip: '输入框的ID' }, propType: 'string', setter: 'StringSetter', }, { name: 'maxLength', title: { label: '最大长度', tip: '最大长度' }, propType: 'number', setter: 'NumberSetter', }, { name: 'size', title: { label: '控件大小', tip: '控件大小' }, propType: { type: 'oneOf', value: ['large', 'middle', 'small'] }, setter: { componentName: 'RadioGroupSetter', props: { options: [ { title: '大', value: 'large', }, { title: '中', value: 'middle', }, { title: '小', value: 'small', }, ], }, }, defaultValue: 'middle', }, { name: 'autoSize', title: { label: '高度自适应设置', tip: '高度自适应设置' }, propType: { type: 'oneOfType', value: [ 'bool', { type: 'shape', value: [ { name: 'minRows', title: '最小行数', setter: 'NumberSetter', defaultValue: 3, }, { name: 'maxRows', title: '最大行数', setter: 'NumberSetter', defaultValue: 3, }, ], }, ], }, defaultValue: false, }, { name: 'onChange', title: { label: '输入框内容变化时的回调', tip: '输入框内容变化时的回调' }, propType: 'func', }, { name: 'onPressEnter', title: { label: '按下回车的回调', tip: '按下回车的回调' }, propType: 'func', }, { name: 'onResize', title: { label: 'resize 回调', tip: 'resize 回调' }, propType: 'func', }, { name: 'onFocus', title: { label: '获取焦点回调', tip: '获取焦点回调' }, propType: 'func', }, { name: 'onKeyDown', title: { label: '按键按下时的回调', tip: '按键按下时的回调' }, propType: 'func', }, { name: 'onKeyPress', title: { label: '按键按下后的回调', tip: '按键按下之后释放之前的回调' }, propType: 'func', }, { name: 'onKeyUp', title: { label: '按键释放回调', tip: '按键释放之后的回调' }, propType: 'func', }, { name: 'onBlur', title: { label: '失去焦点回调', tip: '失去焦点回调' }, propType: 'func', }, ], configure: { supports: { style: true, events: [ { name: 'onChange', template: "onChange(event,${extParams}){\n// 输入框内容变化时的回调\nconsole.log('onChange',event);}", }, { name: 'onPressEnter', template: "onPressEnter(event,${extParams}){\n// 按下回车的回调\nconsole.log('onPressEnter',event);}", }, { name: 'onResize', template: "onResize({width,height},${extParams}){\n// resize 回调\nconsole.log('onResize',width,height);}", }, { name: 'onFocus', template: "onFocus(event,${extParams}){\n// 获取焦点回调\nconsole.log('onFocus',event);}", }, { name: 'onKeyDown', template: "onKeyDown(event,${extParams}){\n// 按键按下时的回调\nconsole.log('onKeyDown',event);}", }, { name: 'onKeyPress', template: "onKeyPress(event,${extParams}){\n// 按键按下后的回调\nconsole.log('onKeyPress',event);}", }, { name: 'onKeyUp', template: "onKeyUp(event,${extParams}){\n// 按键释放回调\nconsole.log('onKeyUp',event);}", }, { name: 'onBlur', template: "onBlur(event,${extParams}){\n// 按键释放回调\nconsole.log('onBlur',event);}", }, ], }, }, };