/** * Demo Common Mixin && i18n */ import Vue from 'vue'; import i18n from 'packages/mixins/i18n'; import { Locale, Toast, Dialog } from 'packages'; import { DemoBlock, DemoSection } from 'vant-doc'; import { camelize } from 'packages/utils'; const demoBaseMixin = { beforeCreate() { const { name, i18n } = this.$options; if (name && i18n) { const formattedI18n = {}; const camelizedName = camelize(name); Object.keys(i18n).forEach(key => { formattedI18n[key] = { [camelizedName]: i18n[key] }; }); Locale.add(formattedI18n); } } }; window.Toast = Toast; window.Dialog = Dialog; Vue.mixin(i18n); Vue.mixin(demoBaseMixin); Vue.component('demo-block', DemoBlock); Vue.component('demo-section', DemoSection); Locale.add({ 'zh-CN': { add: '增加', decrease: '减少', red: '红色', orange: '橙色', yellow: '黄色', tab: '标签', tag: '标签', desc: '描述信息', back: '返回', title: '标题', status: '状态', button: '按钮', option: '选项', search: '搜索', content: '内容', custom: '自定义', username: '用户名', password: '密码', loading: '加载状态', disabled: '禁用状态', uneditable: '不可编辑', basicUsage: '基础用法', advancedUsage: '高级用法', usernamePlaceholder: '请输入用户名', passwordPlaceholder: '请输入密码' }, 'en-US': { add: 'Add', decrease: 'Decrease', red: 'Red', orange: 'Orange', yellow: 'Yellow', tab: 'Tab', tag: 'Tag', desc: 'Description', back: 'Back', title: 'Title', status: 'Status', button: 'Button', option: 'Option', search: 'Search', content: 'Content', custom: 'Custom', username: 'Username', password: 'Password', loading: 'Loading', disabled: 'Disabled', uneditable: 'Uneditable', basicUsage: 'Basic Usage', advancedUsage: 'Advanced Usage', usernamePlaceholder: 'Username', passwordPlaceholder: 'Password' } });