import snippets from './snippets'; const PisellLookupMeta = { componentName: 'PisellLookup', title: 'Lookup 搜索', category: 'Pro Components', docUrl: '', screenshot: '', devMode: 'proCode', npm: { package: '@pisell/materials', version: '1.0.0', exportName: 'PisellLookup', main: 'src/index.tsx', destructuring: true, subName: '', }, configure: { props: [ { title: { label: { type: 'i18n', 'en-US': 'Trigger Config', 'zh-CN': '触发器配置', }, }, display: 'block', type: 'group', items: [ { name: 'triggerType', title: { label: { type: 'i18n', 'en-US': 'Trigger Type', 'zh-CN': '触发器类型', }, tip: '预设触发器类型', }, propType: { type: 'oneOf', value: ['input', 'button', 'icon', 'text'], }, setter: [ { componentName: 'RadioGroupSetter', props: { options: [ { title: '输入框', value: 'input' }, { title: '按钮', value: 'button' }, { title: '图标', value: 'icon' }, { title: '文本', value: 'text' }, ], }, }, 'VariableSetter', ], defaultValue: 'input', }, { name: 'trigger', title: { label: { type: 'i18n', 'en-US': 'Custom Trigger', 'zh-CN': '自定义触发器', }, tip: '自定义触发器(与 triggerType 互斥)', }, propType: { type: 'node' }, setter: 'SlotSetter', }, { name: 'placeholder', title: { label: { type: 'i18n', 'en-US': 'Placeholder', 'zh-CN': '占位符', }, }, propType: 'string', setter: ['PisellI18nSetter', 'StringSetter', 'VariableSetter'], defaultValue: '请输入搜索内容', }, { name: 'buttonText', title: { label: { type: 'i18n', 'en-US': 'Button Text', 'zh-CN': '按钮文本', }, }, propType: 'string', setter: ['PisellI18nSetter', 'StringSetter', 'VariableSetter'], condition: { type: 'JSFunction', value: 'target => target.getProps().getPropValue("triggerType") === "button"', }, }, { name: 'triggerText', title: { label: { type: 'i18n', 'en-US': 'Trigger Text', 'zh-CN': '触发器文本', }, }, propType: 'string', setter: ['PisellI18nSetter', 'StringSetter', 'VariableSetter'], condition: { type: 'JSFunction', value: 'target => target.getProps().getPropValue("triggerType") === "text"', }, }, { name: 'triggerIcon', title: { label: { type: 'i18n', 'en-US': 'Trigger Icon', 'zh-CN': '触发器图标', }, }, propType: { type: 'node' }, setter: 'SlotSetter', condition: { type: 'JSFunction', value: 'target => target.getProps().getPropValue("triggerType") === "icon"', }, }, { name: 'size', title: { label: { type: 'i18n', 'en-US': 'Size', 'zh-CN': '尺寸', }, }, propType: { type: 'oneOf', value: ['large', 'middle', 'small'] }, setter: [ { componentName: 'RadioGroupSetter', props: { options: [ { title: '大号', value: 'large' }, { title: '默认', value: 'middle' }, { title: '小号', value: 'small' }, ], }, }, 'VariableSetter', ], defaultValue: 'middle', }, { name: 'disabled', title: { label: { type: 'i18n', 'en-US': 'Disabled', 'zh-CN': '是否禁用', }, }, propType: 'bool', setter: ['BoolSetter', 'VariableSetter'], defaultValue: false, }, { name: 'showPrefixIcon', title: { label: { type: 'i18n', 'en-US': 'Show Prefix Icon', 'zh-CN': '显示前缀图标', }, }, propType: 'bool', setter: ['BoolSetter', 'VariableSetter'], defaultValue: false, }, { name: 'prefixIcon', title: { label: { type: 'i18n', 'en-US': 'Prefix Icon', 'zh-CN': '前缀图标', }, }, propType: { type: 'node' }, setter: 'SlotSetter', condition: { type: 'JSFunction', value: 'target => target.getProps().getPropValue("showPrefixIcon")', }, }, { name: 'showClear', title: { label: { type: 'i18n', 'en-US': 'Show Clear Button', 'zh-CN': '显示清除按钮', }, }, propType: 'bool', setter: ['BoolSetter', 'VariableSetter'], defaultValue: true, }, { name: 'showConfirmButton', title: { label: { type: 'i18n', 'en-US': 'Show Confirm Button', 'zh-CN': '显示确认按钮', }, }, propType: 'bool', setter: ['BoolSetter', 'VariableSetter'], defaultValue: true, }, { name: 'confirmButtonText', title: { label: { type: 'i18n', 'en-US': 'Confirm Button Text', 'zh-CN': '确认按钮文本', }, }, propType: 'string', setter: ['PisellI18nSetter', 'StringSetter', 'VariableSetter'], defaultValue: 'Lookup', condition: { type: 'JSFunction', value: 'target => target.getProps().getPropValue("showConfirmButton")', }, }, ], }, { title: { label: { type: 'i18n', 'en-US': 'Search Behavior', 'zh-CN': '搜索行为', }, }, display: 'block', type: 'group', items: [ { name: 'searchMode', title: { label: { type: 'i18n', 'en-US': 'Search Mode', 'zh-CN': '搜索模式', }, tip: 'realtime: 实时搜索,confirm: 确认触发', }, propType: { type: 'oneOf', value: ['realtime', 'confirm'] }, setter: [ { componentName: 'RadioGroupSetter', props: { options: [ { title: '实时搜索', value: 'realtime' }, { title: '确认触发', value: 'confirm' }, ], }, }, 'VariableSetter', ], defaultValue: 'realtime', }, { name: 'debounceTime', title: { label: { type: 'i18n', 'en-US': 'Debounce Time', 'zh-CN': '防抖时间', }, tip: '防抖时间(毫秒)', }, propType: 'number', setter: ['NumberSetter', 'VariableSetter'], defaultValue: 300, }, { name: 'value', title: { label: { type: 'i18n', 'en-US': 'Value (Controlled)', 'zh-CN': '搜索关键词(受控)', }, }, propType: 'string', setter: ['StringSetter', 'VariableSetter'], }, { name: 'defaultValue', title: { label: { type: 'i18n', 'en-US': 'Default Value', 'zh-CN': '默认关键词', }, }, propType: 'string', setter: ['StringSetter', 'VariableSetter'], }, { name: 'showScan', title: { label: { type: 'i18n', 'en-US': 'Show Scan Button', 'zh-CN': '显示扫码按钮', }, }, propType: 'bool', setter: ['BoolSetter', 'VariableSetter'], defaultValue: true, }, ], }, { title: { label: { type: 'i18n', 'en-US': 'Auxiliary Features', 'zh-CN': '辅助功能', }, }, display: 'block', type: 'group', items: [ { name: 'showHistory', title: { label: { type: 'i18n', 'en-US': 'Show Search History', 'zh-CN': '显示搜索历史', }, }, propType: 'bool', setter: ['BoolSetter', 'VariableSetter'], defaultValue: false, }, { name: 'historyKey', title: { label: { type: 'i18n', 'en-US': 'History Storage Key', 'zh-CN': '历史记录存储 Key', }, }, propType: 'string', setter: ['StringSetter', 'VariableSetter'], defaultValue: 'pisell_lookup_history', condition: { type: 'JSFunction', value: 'target => target.getProps().getPropValue("showHistory")', }, }, { name: 'maxHistoryCount', title: { label: { type: 'i18n', 'en-US': 'Max History Count', 'zh-CN': '历史记录上限', }, }, propType: 'number', setter: ['NumberSetter', 'VariableSetter'], defaultValue: 10, condition: { type: 'JSFunction', value: 'target => target.getProps().getPropValue("showHistory")', }, }, { name: 'showSuggestions', title: { label: { type: 'i18n', 'en-US': 'Show Suggestions', 'zh-CN': '显示联想词', }, }, propType: 'bool', setter: ['BoolSetter', 'VariableSetter'], defaultValue: false, }, { name: 'showHotWords', title: { label: { type: 'i18n', 'en-US': 'Show Hot Words', 'zh-CN': '显示热门搜索', }, }, propType: 'bool', setter: ['BoolSetter', 'VariableSetter'], defaultValue: false, }, ], }, { title: { label: { type: 'i18n', 'en-US': 'Result Display', 'zh-CN': '结果展示', }, }, display: 'block', type: 'group', items: [ { name: 'displayType', title: { label: { type: 'i18n', 'en-US': 'Display Type', 'zh-CN': '展示类型', }, tip: '不指定时根据触发器类型智能判断', }, propType: { type: 'oneOf', value: ['inline', 'popup', 'modal', 'drawer', 'detached'], }, setter: [ { componentName: 'SelectSetter', props: { options: [ { title: '内联展示', value: 'inline' }, { title: '浮层展示', value: 'popup' }, { title: '弹窗展示', value: 'modal' }, { title: '抽屉展示', value: 'drawer' }, { title: '独立展示', value: 'detached' }, ], }, }, 'VariableSetter', ], }, { name: 'resultRender', title: { label: { type: 'i18n', 'en-US': 'Result Render', 'zh-CN': '结果渲染', }, tip: '自定义结果渲染函数', }, propType: { type: 'func' }, setter: [ { componentName: 'FunctionSetter', props: { template: 'resultRender(keyword, onClose, ${extParams}){\n// 渲染搜索结果\nreturn (