mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-12 12:25:16 +08:00
220 lines
9.2 KiB
JavaScript
220 lines
9.2 KiB
JavaScript
import Vue from 'vue/dist/vue'
|
|
import VueRouter from 'vue-router'
|
|
import '../styles/index.scss'
|
|
import 'codemirror/lib/codemirror.css'
|
|
import './styles/atom-one-dark-reasonable.scss'
|
|
import './styles/atom-one-light.scss'
|
|
import './styles/markdown.scss'
|
|
import './styles/font.scss'
|
|
import NaiveUI from '../index'
|
|
import SourceBlock from './SourceBlock'
|
|
import VueI18n from 'vue-i18n'
|
|
|
|
import intro from './documentation/intro/intro'
|
|
import start from './documentation/intro/start'
|
|
import devGuildlines from './documentation/intro/devGuidelines'
|
|
import status from './documentation/intro/status'
|
|
|
|
import nimbusServiceLayoutDemo from './documentation/components/nimbusServiceLayoutDemo'
|
|
import homeDemo from './documentation/components/homeDemo'
|
|
import gradientText from './documentation/components/gradientText'
|
|
import iconDemo from './documentation/components/iconDemo'
|
|
import checkbox from './documentation/components/checkbox'
|
|
import button from './documentation/components/button'
|
|
import switchDemo from './documentation/components/switch'
|
|
import tableDemo from './documentation/components/tableDemo'
|
|
import input from './documentation/components/input'
|
|
import select from './documentation/components/select'
|
|
import cascaderDemo from './documentation/components/cascaderDemo'
|
|
import inputKeyValuePairsDemo from './documentation/components/inputKeyValuePairsDemo'
|
|
import modal from './documentation/components/modal'
|
|
import nimbusFormCardDemo from './documentation/components/nimbusFormCardDemo'
|
|
import message from './documentation/components/message'
|
|
import tooltip from './documentation/components/tooltip'
|
|
import popover from './documentation/components/popover'
|
|
import alert from './documentation/components/alert'
|
|
import datePicker from './documentation/components/datePicker'
|
|
import inputNumberDemo from './documentation/components/inputNumberDemo'
|
|
import nimbusIconDemo from './documentation/components/nimbusIconDemo'
|
|
import radioDemo from './documentation/components/radioDemo'
|
|
import formDemo from './documentation/components/formDemo'
|
|
import tabsDemo from './documentation/components/tabsDemo'
|
|
import timePicker from './documentation/components/timePicker'
|
|
import confirm from './documentation/components/confirm'
|
|
import backTop from './documentation/components/backTop'
|
|
import dropdownDemo from './documentation/components/dropdownDemo'
|
|
import scrollbarDebug from './debugComponents/scrollbarDebug'
|
|
import scrollbarDebug2 from './debugComponents/scrollbarDebug2'
|
|
import badge from './documentation/components/badge'
|
|
import stepsDemo from './documentation/components/stepsDemo'
|
|
import notification from './documentation/components/notification'
|
|
import nimbusConfirmCardDemo from './documentation/components/nimbusConfirmCardDemo'
|
|
import pagination from './documentation/components/pagination'
|
|
import collapse from './documentation/components/collapse'
|
|
import tag from './documentation/components/tag'
|
|
import timeline from './documentation/components/timeline'
|
|
import progress from './documentation/components/progress'
|
|
import divider from './documentation/components/divider'
|
|
import popconfirmDemo from './documentation/components/popconfirmDemo'
|
|
import anchor from './documentation/components/anchor'
|
|
import popselect from './documentation/components/popselect'
|
|
import app from './documentation/components/app'
|
|
import advancedTable from './documentation/components/advancedTable'
|
|
import transferDemo from './documentation/components/transferDemo'
|
|
import spin from './documentation/components/spin'
|
|
import drawerDemo from './documentation/components/drawerDemo'
|
|
import loadingBar from './documentation/components/loadingBar'
|
|
import timeDemo from './documentation/components/timeDemo'
|
|
import sliderDemo from './documentation/components/sliderDemo'
|
|
import treeDemo from './documentation/components/treeDemo'
|
|
import affix from './documentation/components/affix'
|
|
|
|
import demo from './demo'
|
|
import ComponentDemo from './utils/ComponentDemo'
|
|
import ComponentDemos from './utils/ComponentDemos'
|
|
import ComponentDocumentation from './utils/ComponentDocumentation'
|
|
import DocumentationWrapper from './utils/DocumentationWrapper'
|
|
import './styles/ComponentDemo.scss'
|
|
import './styles/demo.scss'
|
|
|
|
import popoverDebug from './debugComponents/popoverDebug'
|
|
import routerDebug from './debugComponents/routerDebug'
|
|
import modalDebug from './debugComponents/modalDebug'
|
|
import datePickerDebug from './debugComponents/datePickerDebug'
|
|
import backTopDebug from './debugComponents/backTopDebug'
|
|
import cancelMarkDebug from './debugComponents/cancelMarkDebug'
|
|
import cascaderDebug from './debugComponents/cascaderDebug'
|
|
import verticalAlignDebug from './debugComponents/verticalAlignDebug'
|
|
|
|
Vue.use(VueI18n)
|
|
Vue.use(VueRouter)
|
|
Vue.use(NaiveUI)
|
|
|
|
const i18n = new VueI18n({
|
|
locale: 'en-us'
|
|
})
|
|
|
|
Vue.component(SourceBlock.name, SourceBlock)
|
|
Vue.component('ComponentDemo', ComponentDemo)
|
|
Vue.component('ComponentDemos', ComponentDemos)
|
|
Vue.component('DocumentationWrapper', DocumentationWrapper)
|
|
Vue.component('ComponentDocumentation', ComponentDocumentation)
|
|
|
|
const withPrefix = (prefix, routes) =>
|
|
routes.map((route) => {
|
|
route.path = prefix + route.path
|
|
return route
|
|
})
|
|
|
|
const routes = [
|
|
{
|
|
path: '/home-demo',
|
|
component: homeDemo
|
|
},
|
|
{
|
|
path: '/:lang/:theme/n-popover-debug',
|
|
component: popoverDebug
|
|
},
|
|
{
|
|
path: '/n-back-top-debug',
|
|
component: backTopDebug
|
|
},
|
|
{
|
|
path: '/n-cascader-debug',
|
|
component: cascaderDebug
|
|
},
|
|
{
|
|
path: '/:lang/:theme/start',
|
|
component: demo,
|
|
children: withPrefix('/:lang/:theme', [
|
|
{ path: '/intro', component: intro },
|
|
{ path: '/start', component: start },
|
|
{ path: '/dev-guildlines', component: devGuildlines },
|
|
{ path: '/status', component: status },
|
|
{ path: '/n-nimbus-service-layout', component: nimbusServiceLayoutDemo },
|
|
{ path: '/n-nimbus-home-layout', component: homeDemo },
|
|
{ path: '/n-gradient-text', component: gradientText },
|
|
{ path: '/n-icon', component: iconDemo },
|
|
{ path: '/n-checkbox', component: checkbox },
|
|
{ path: '/n-button', component: button },
|
|
{ path: '/n-switch', component: switchDemo },
|
|
{ path: '/n-table', component: tableDemo },
|
|
{ path: '/n-advance-table', component: advancedTable },
|
|
{ path: '/n-input', component: input },
|
|
{ path: '/n-select', component: select },
|
|
{ path: '/n-cascader', component: cascaderDemo },
|
|
{ path: '/n-InputKeyValuePairs', component: inputKeyValuePairsDemo },
|
|
{ path: '/n-modal', component: modal },
|
|
{ path: '/n-nimbus-form-card', component: nimbusFormCardDemo },
|
|
{ path: '/n-message', component: message },
|
|
{ path: '/n-tooltip', component: tooltip },
|
|
{ path: '/n-popover', component: popover },
|
|
{ path: '/n-notification', component: notification },
|
|
{ path: '/n-nimbus-confirm-card', component: nimbusConfirmCardDemo },
|
|
{ path: '/n-pagination', component: pagination },
|
|
{ path: '/n-alert', component: alert },
|
|
{ path: '/n-date-picker', component: datePicker },
|
|
{ path: '/n-input-number', component: inputNumberDemo },
|
|
{ path: '/n-nimbus-icon', component: nimbusIconDemo },
|
|
{ path: '/n-radio', component: radioDemo },
|
|
{ path: '/n-form', component: formDemo },
|
|
{ path: '/n-tabs', component: tabsDemo },
|
|
{ path: '/n-time-picker', component: timePicker },
|
|
{ path: '/n-confirm', component: confirm },
|
|
{ path: '/n-router-debug', component: routerDebug },
|
|
{ path: '/n-modal-debug', component: modalDebug },
|
|
{ path: '/n-scrollbar-debug', component: scrollbarDebug },
|
|
{ path: '/n-badge', component: badge },
|
|
{ path: '/n-steps', component: stepsDemo },
|
|
{ path: '/n-collapse', component: collapse },
|
|
{ path: '/n-progress', component: progress },
|
|
{ path: '/n-tag', component: tag },
|
|
{ path: '/n-timeline', component: timeline },
|
|
{ path: '/n-scrollbar-debug2', component: scrollbarDebug2 },
|
|
{ path: '/n-back-top', component: backTop },
|
|
{ path: '/n-date-picker-debug', component: datePickerDebug },
|
|
{ path: '/n-divider', component: divider },
|
|
{ path: '/n-popconfirm', component: popconfirmDemo },
|
|
{ path: '/n-anchor', component: anchor },
|
|
{ path: '/n-dropdown', component: dropdownDemo },
|
|
{ path: '/n-popselect', component: popselect },
|
|
{ path: '/n-app', component: app },
|
|
{ path: '/n-cancel-mark-debug', component: cancelMarkDebug },
|
|
{ path: '/n-transfer', component: transferDemo },
|
|
{ path: '/n-spin', component: spin },
|
|
{ path: '/n-drawer', component: drawerDemo },
|
|
{ path: '/n-loading-bar', component: loadingBar },
|
|
{ path: '/n-time', component: timeDemo },
|
|
{ path: '/n-slider', component: sliderDemo },
|
|
{ path: '/n-tree', component: treeDemo },
|
|
{ path: '/n-vertical-align-debug', component: verticalAlignDebug },
|
|
{ path: '/n-affix', component: affix }
|
|
])
|
|
},
|
|
{
|
|
path: '/*',
|
|
redirect: '/en-us/dark/start'
|
|
}
|
|
]
|
|
|
|
const router = new VueRouter({
|
|
mode: 'history',
|
|
routes
|
|
})
|
|
|
|
router.beforeEach(function (to, from, next) {
|
|
Vue.prototype.$NLoadingBar.theme = to.params.theme
|
|
if (to.path !== from.path) {
|
|
Vue.prototype.$NLoadingBar.start()
|
|
}
|
|
next()
|
|
})
|
|
|
|
router.afterEach(function (to, from) {
|
|
if (to.path !== from.path) {
|
|
Vue.prototype.$NLoadingBar.finish()
|
|
}
|
|
})
|
|
|
|
export { Vue, router, i18n }
|