naive-ui/demo/store/menu-options.js
07akioni 6ee3896319
feat(tree-select): component (#211)
* site: tree-select route

* refactor(internal-selection): remove useless remote prop & on-delete-last-option

* refactor(dropdown, popselect): set slots stable mark from true to 1

* fix(scrollbar): attributes applied multiple times

* wip(tree-select): add exports

* fix(tree): misses `on-update-expanded-keys`, `on-update-selected-keys`, `on-update-checked-keys` prop

* feat(tree): support keyboard operations

* feat(tree): scroll with keyboard target node

* fix(tree): `selected-keys` prop influences original array

* feat(tree): pending on selected node at first

* feat(tree): follow tree-select's pending status

* feat(tree): `internalCheckboxFocusable` prop

* refactor(tree): split treeMate to displayTreeMate & dataTreeMate to work with tree-select

* fix(tree): scrollbar won't sync in virtual scroll mode

* feat(tree-select)

* docs: changelog

* docs(tree-select)

* feat(tree-select): stricter type

* fix: typo

* fix(select): input blinks in filterable mode when click at menu and input has value

* fix(tree): multiple line style

* docs(tree-select)

* refactor(tree-select): disable tree expand animation on tree select

* feat(tree-select): change expanded keys on filter

* chore(tree): add comment about animation

* chore

* feat(tree-select): close on single select

* fix(base-selection): input has useless empty row in multiple filterable mode

* docs(tree-select): add clearable in filterable demo
2021-06-21 15:48:15 +08:00

742 lines
15 KiB
JavaScript

// rubbish code here
import { h } from 'vue'
import { RouterLink } from 'vue-router'
export const renderMenuLabel = (option) => {
if (!('path' in option) || option.label === '--Debug') {
return option.label
}
return h(
RouterLink,
{
to: option.path
},
{ default: () => option.label }
)
}
const appendCounts = (item) => {
if (!item.children) {
item.count = 1
return item
}
if (item.children) {
item.children.forEach(appendCounts)
item.count = item.children.reduce((sum, item) => sum + item.count, 0)
if (item.type === 'group') {
item.en += ` (${item.count})`
item.zh += ` (${item.count})`
}
return item
}
}
const createDebugDemos = (item, mode) => {
if (__DEV__ && mode === 'debug') {
return [item]
} else return []
}
function createItems (lang, theme, prefix, items) {
const isZh = lang === 'zh-CN'
const langKey = isZh ? 'zh' : 'en'
return items.map((rawItem) => {
const item = {
...rawItem,
key: rawItem.en,
label: rawItem[langKey] || rawItem.en,
extra: rawItem.enSuffix && isZh ? rawItem.en : undefined,
path: rawItem.path
? `/${lang}/${theme}` + prefix + rawItem.path
: undefined
}
if (rawItem.children) {
item.children = createItems(lang, theme, prefix, rawItem.children)
}
return item
})
}
export function createDocumentationMenuOptions ({ lang, theme, mode }) {
return createItems(lang, theme, '/docs', [
{
en: 'Introduction',
zh: '介绍',
type: 'group',
children: [
{
en: 'Naive UI',
zh: 'Naive UI',
path: '/introduction'
}
]
},
{
en: 'Getting Started',
zh: '快速上手',
type: 'group',
children: [
{
en: 'Installation',
zh: '安装',
path: '/installation'
},
{
en: 'Usage in SFC',
zh: '在 SFC 中使用',
path: '/usage-sfc'
},
{
en: 'Configuring Fonts',
zh: '配置字体',
path: '/fonts'
},
{
en: 'Import on Demand',
zh: '按需引入',
path: '/import-on-demand'
},
{
en: 'Supported Platforms',
zh: '支持的平台',
path: '/supported-platforms'
},
{
en: 'Common Issues',
zh: '常见问题',
path: '/common-issues'
}
]
},
{
en: 'Guides',
zh: '指南',
type: 'group',
children: [
{
en: 'JSX & TSX',
zh: 'JSX & TSX',
path: '/jsx'
},
{
en: 'Server-Sider Rendering',
zh: '服务端渲染 SSR',
path: '/ssr'
},
{
en: 'Customizing Theme',
zh: '调整主题',
path: '/customize-theme'
},
{
en: 'Create Themed Component',
zh: '创建适配主题的组件',
path: '/theme'
}
// {
// en: 'Experimental Features',
// zh: '试验性特性',
// path: '/experimental-features'
// }
]
},
{
en: 'Version',
zh: '版本',
type: 'group',
children: [
{
en: 'Change Log',
zh: '变更日志',
path: '/changelog'
}
// {
// en: 'Migrate From V1',
// zh: '从 V1 升级',
// path: '/from-v1'
// }
]
}
])
}
export function createComponentMenuOptions ({ lang, theme, mode }) {
return createItems(lang, theme, '/components', [
appendCounts({
zh: '通用组件',
en: 'Common Components',
type: 'group',
children: [
{
en: 'Avatar',
zh: '头像',
enSuffix: true,
path: '/avatar'
},
{
en: 'Button',
zh: '按钮',
enSuffix: true,
path: '/button'
},
{
en: 'Card',
zh: '卡片',
enSuffix: true,
path: '/card'
},
{
en: 'Collapse',
zh: '折叠面板',
enSuffix: true,
path: '/collapse'
},
{
en: 'Divider',
zh: '分割线',
enSuffix: true,
path: '/divider'
},
{
en: 'Dropdown',
zh: '下拉菜单',
enSuffix: true,
path: '/dropdown'
},
{
en: 'Ellipsis',
zh: '文本省略',
enSuffix: true,
path: '/ellipsis'
},
{
en: 'Gradient Text',
zh: '渐变文字',
enSuffix: true,
path: '/gradient-text'
},
{
en: 'Icon',
zh: '图标',
enSuffix: true,
path: '/icon'
},
{
en: 'PageHeader',
zh: '页头',
enSuffix: true,
path: '/page-header'
},
{
en: 'Tag',
zh: '标签',
enSuffix: true,
path: '/tag'
},
{
en: 'Typography',
zh: '排印',
enSuffix: true,
path: '/typography'
}
]
}),
appendCounts({
zh: '数据录入组件',
en: 'Data Input Components',
type: 'group',
children: [
{
en: 'Auto Complete',
zh: '自动填充',
enSuffix: true,
path: '/auto-complete'
},
{
en: 'Cascader',
zh: '级联选择',
enSuffix: true,
path: '/cascader'
},
{
en: 'Color Picker',
zh: '颜色选择器',
enSuffix: true,
path: '/color-picker'
},
{
en: 'Checkbox',
zh: '复选框',
enSuffix: true,
path: '/checkbox'
},
{
en: 'Date Picker',
zh: '日期选择器',
enSuffix: true,
path: '/date-picker'
},
{
en: 'Dynamic Input',
zh: '动态录入',
enSuffix: true,
path: '/dynamic-input'
},
{
en: 'Dynamic Tags',
zh: '动态标签',
enSuffix: true,
path: '/dynamic-tags'
},
{
en: 'Form',
zh: '表单',
enSuffix: true,
path: '/form'
},
{
en: 'Input',
zh: '文本输入',
enSuffix: true,
path: '/input'
},
{
en: 'Input Number',
zh: '数字输入',
enSuffix: true,
path: '/input-number'
},
{
en: 'Mention',
zh: '提及',
enSuffix: true,
path: '/mention'
},
{
en: 'Radio',
zh: '单选',
enSuffix: true,
path: '/radio'
},
{
en: 'Rate',
zh: '评分',
enSuffix: true,
path: '/rate'
},
{
en: 'Select',
zh: '选择器',
enSuffix: true,
path: '/select'
},
{
en: 'Slider',
zh: '滑动选择',
enSuffix: true,
path: '/slider'
},
{
en: 'Switch',
zh: '开关',
enSuffix: true,
path: '/switch'
},
{
en: 'Time Picker',
zh: '时间选择器',
enSuffix: true,
path: '/time-picker'
},
{
en: 'Transfer',
zh: '穿梭框',
enSuffix: true,
path: '/transfer'
},
{
en: 'Tree Select',
zh: '树型选择',
enSuffix: true,
path: '/tree-select'
},
{
en: 'Upload',
zh: '上传',
enSuffix: true,
path: '/upload'
}
]
}),
appendCounts({
zh: '数据展示组件',
en: 'Data Display Components',
type: 'group',
children: [
{
en: 'Calendar',
zh: '日历',
enSuffix: true,
path: '/calendar'
},
{
en: 'Code',
zh: '代码',
enSuffix: true,
path: '/code'
},
{
en: 'Data Table',
zh: '数据表格',
enSuffix: true,
path: '/data-table'
},
{
en: 'Descriptions',
zh: '描述',
enSuffix: true,
path: '/descriptions'
},
{
en: 'Empty',
zh: '无内容',
enSuffix: true,
path: '/empty'
},
{
en: 'Image',
zh: '图像',
enSuffix: true,
path: '/image'
},
{
en: 'List',
zh: '列表',
enSuffix: true,
path: '/list'
},
{
en: 'Log',
zh: '日志',
enSuffix: true,
path: '/log'
},
{
en: 'Statistic',
zh: '统计数据',
enSuffix: true,
path: '/statistic'
},
{
en: 'Table',
zh: '表格',
enSuffix: true,
path: '/table'
},
{
en: 'Thing',
zh: '东西',
enSuffix: true,
path: '/thing'
},
{
en: 'Time',
zh: '时间',
enSuffix: true,
path: '/time'
},
{
en: 'Timeline',
zh: '时间线',
enSuffix: true,
path: '/timeline'
},
{
en: 'Tree',
zh: '树',
enSuffix: true,
path: '/tree'
}
]
}),
appendCounts({
zh: '导航组件',
en: 'Navigation Components',
type: 'group',
children: [
{
en: 'Affix',
zh: '固钉',
enSuffix: true,
path: '/affix'
},
{
en: 'Anchor',
zh: '侧边导航',
enSuffix: true,
path: '/anchor'
},
{
en: 'Back Top',
zh: '回到顶部',
enSuffix: true,
path: '/back-top'
},
{
en: 'Breadcrumb',
zh: '面包屑',
enSuffix: true,
path: '/breadcrumb'
},
{
en: 'Loading Bar',
zh: '加载条',
enSuffix: true,
path: '/loading-bar'
},
{
en: 'Menu',
zh: '菜单',
enSuffix: true,
path: '/menu'
},
{
en: 'Pagination',
zh: '分页',
enSuffix: true,
path: '/pagination'
},
{
en: 'Steps',
zh: '步骤',
enSuffix: true,
path: '/steps'
},
{
en: 'Tabs',
zh: '标签页',
enSuffix: true,
path: '/tabs'
}
]
}),
appendCounts({
zh: '反馈组件',
en: 'Feedback Components',
type: 'group',
children: [
{
en: 'Alert',
zh: '警告信息',
enSuffix: true,
path: '/alert'
},
{
en: 'Badge',
zh: '标记',
enSuffix: true,
path: '/badge'
},
{
en: 'Dialog',
zh: '对话框',
enSuffix: true,
path: '/dialog'
},
{
en: 'Drawer',
zh: '抽屉',
enSuffix: true,
path: '/drawer'
},
{
en: 'Message',
zh: '信息',
enSuffix: true,
path: '/message'
},
{
en: 'Modal',
zh: '模态框',
enSuffix: true,
path: '/modal'
},
{
en: 'Notification',
zh: '通知',
enSuffix: true,
path: '/notification'
},
{
en: 'Popconfirm',
zh: '弹出确认',
enSuffix: true,
path: '/popconfirm'
},
{
en: 'Popover',
zh: '弹出信息',
enSuffix: true,
path: '/popover'
},
{
en: 'Popselect',
zh: '弹出选择',
enSuffix: true,
path: '/popselect'
},
{
en: 'Progress',
zh: '进度',
enSuffix: true,
path: '/progress'
},
{
en: 'Result',
zh: '结果页',
enSuffix: true,
path: '/result'
},
{
en: 'Skeleton',
zh: '骨架屏',
enSuffix: true,
path: '/skeleton'
},
{
en: 'Spin',
zh: '加载',
enSuffix: true,
path: '/spin'
},
{
en: 'Tooltip',
zh: '弹出提示',
enSuffix: true,
path: '/tooltip'
}
]
}),
appendCounts({
zh: '布局组件',
en: 'Layout Components',
type: 'group',
children: [
{
en: 'Layout',
zh: '布局',
enSuffix: true,
path: '/layout'
},
{
en: 'Grid',
zh: '栅格',
enSuffix: true,
path: '/grid'
},
{
en: 'Space',
zh: '间距',
enSuffix: true,
path: '/space'
}
]
}),
appendCounts({
zh: '配置组件',
en: 'Config Components',
type: 'group',
children: [
{
en: 'Config Provider',
zh: '全局化配置',
enSuffix: true,
path: '/config-provider'
},
{
en: 'Element',
zh: '元素',
enSuffix: true,
path: '/element'
},
{
en: 'Global Style',
zh: '全局样式',
enSuffix: true,
path: '/global-style'
}
]
}),
{
zh: '废弃',
en: 'Deprecated',
type: 'group',
children: [
{
en: 'Legacy Grid',
zh: '旧版栅格',
enSuffix: true,
path: '/legacy-grid'
}
]
},
...createDebugDemos(
{
en: '--Debug',
children: [
{
en: 'SuffixDebug',
path: '/base-suffix-debug'
},
{
en: 'PopoverDebug',
path: '/popover-debug'
},
{
en: 'RouterDebug',
path: '/router-debug'
},
{
en: 'ModalDebug',
path: '/modal-debug'
},
{
en: 'ScrollbarDebug',
path: '/scrollbar-debug'
},
{
en: 'ScrollbarDebug2',
path: '/scrollbar-debug2'
},
{
en: 'DatePickerDebug',
path: '/date-picker-debug'
},
{
en: 'BackTopDebug',
path: '/back-top-debug'
},
{
en: 'CascaderDebug',
path: '/cascader-debug'
},
{
en: 'VerticalAlignDebug',
path: '/vertical-align-debug'
},
{
en: 'IconTransitionDebug',
path: '/icon-transition-debug'
},
{
en: 'SelectDebug',
path: '/select-debug'
}
]
},
mode
)
])
}