Showing
58 changed files
with
3957 additions
and
0 deletions
Too many changes to show.
To preserve performance only 58 of 709 files are displayed.
.editorconfig
0 → 100644
1 | +root = true | ||
2 | + | ||
3 | +[*] | ||
4 | +charset=utf-8 | ||
5 | +end_of_line=lf | ||
6 | +insert_final_newline=true | ||
7 | +indent_style=space | ||
8 | +indent_size=2 | ||
9 | +max_line_length = 100 | ||
10 | + | ||
11 | +[*.{yml,yaml,json}] | ||
12 | +indent_style = space | ||
13 | +indent_size = 2 | ||
14 | + | ||
15 | +[*.md] | ||
16 | +trim_trailing_whitespace = false | ||
17 | + | ||
18 | +[Makefile] | ||
19 | +indent_style = tab |
.env
0 → 100644
.env.development
0 → 100644
1 | +# Whether to open mock | ||
2 | +VITE_USE_MOCK = false | ||
3 | + | ||
4 | +# public path | ||
5 | +VITE_PUBLIC_PATH = / | ||
6 | + | ||
7 | +# Cross-domain proxy, you can configure multiple | ||
8 | +# Please note that no line breaks | ||
9 | +VITE_PROXY = [["/api","http://localhost:8082/api"],["/upload","http://localhost:3300/upload"]] | ||
10 | +# VITE_PROXY=[["/api","https://vvbin.cn/test"]] | ||
11 | + | ||
12 | +# Delete console | ||
13 | +VITE_DROP_CONSOLE = false | ||
14 | + | ||
15 | +# Basic interface address SPA | ||
16 | +VITE_GLOB_API_URL=/api | ||
17 | + | ||
18 | +# File upload address, optional | ||
19 | +VITE_GLOB_UPLOAD_URL=/upload | ||
20 | + | ||
21 | +# Interface prefix | ||
22 | +VITE_GLOB_API_URL_PREFIX=/v1 |
.env.production
0 → 100644
1 | +# Whether to open mock | ||
2 | +VITE_USE_MOCK = false | ||
3 | + | ||
4 | +# public path | ||
5 | +VITE_PUBLIC_PATH = / | ||
6 | + | ||
7 | +# Delete console | ||
8 | +VITE_DROP_CONSOLE = true | ||
9 | + | ||
10 | +# Whether to enable gzip or brotli compression | ||
11 | +# Optional: gzip | brotli | none | ||
12 | +# If you need multiple forms, you can use `,` to separate | ||
13 | +VITE_BUILD_COMPRESS = 'none' | ||
14 | + | ||
15 | +# Whether to delete origin files when using compress, default false | ||
16 | +VITE_BUILD_COMPRESS_DELETE_ORIGIN_FILE = false | ||
17 | + | ||
18 | +# Basic interface address SPA | ||
19 | +VITE_GLOB_API_URL=/api | ||
20 | + | ||
21 | +# File upload address, optional | ||
22 | +# It can be forwarded by nginx or write the actual address directly | ||
23 | +VITE_GLOB_UPLOAD_URL=/upload | ||
24 | + | ||
25 | +# Interface prefix | ||
26 | +VITE_GLOB_API_URL_PREFIX=/v1 | ||
27 | + | ||
28 | +# Whether to enable image compression | ||
29 | +VITE_USE_IMAGEMIN= true | ||
30 | + | ||
31 | +# use pwa | ||
32 | +VITE_USE_PWA = false | ||
33 | + | ||
34 | +# Is it compatible with older browsers | ||
35 | +VITE_LEGACY = false |
.env.test
0 → 100644
1 | +NODE_ENV=production | ||
2 | +# Whether to open mock | ||
3 | +VITE_USE_MOCK = true | ||
4 | + | ||
5 | +# public path | ||
6 | +VITE_PUBLIC_PATH = / | ||
7 | + | ||
8 | +# Delete console | ||
9 | +VITE_DROP_CONSOLE = true | ||
10 | + | ||
11 | +# Whether to enable gzip or brotli compression | ||
12 | +# Optional: gzip | brotli | none | ||
13 | +# If you need multiple forms, you can use `,` to separate | ||
14 | +VITE_BUILD_COMPRESS = 'none' | ||
15 | + | ||
16 | +# Whether to delete origin files when using compress, default false | ||
17 | +VITE_BUILD_COMPRESS_DELETE_ORIGIN_FILE = false | ||
18 | + | ||
19 | +# Basic interface address SPA | ||
20 | +VITE_GLOB_API_URL=/basic-api | ||
21 | + | ||
22 | +# File upload address, optional | ||
23 | +# It can be forwarded by nginx or write the actual address directly | ||
24 | +VITE_GLOB_UPLOAD_URL=/upload | ||
25 | + | ||
26 | +# Interface prefix | ||
27 | +VITE_GLOB_API_URL_PREFIX= | ||
28 | + | ||
29 | +# Whether to enable image compression | ||
30 | +VITE_USE_IMAGEMIN= true | ||
31 | + | ||
32 | +# use pwa | ||
33 | +VITE_USE_PWA = false | ||
34 | + | ||
35 | +# Is it compatible with older browsers | ||
36 | +VITE_LEGACY = false |
.eslintignore
0 → 100644
.eslintrc.js
0 → 100644
1 | +// @ts-check | ||
2 | +const { defineConfig } = require('eslint-define-config'); | ||
3 | +module.exports = defineConfig({ | ||
4 | + root: true, | ||
5 | + env: { | ||
6 | + browser: true, | ||
7 | + node: true, | ||
8 | + es6: true, | ||
9 | + }, | ||
10 | + parser: 'vue-eslint-parser', | ||
11 | + parserOptions: { | ||
12 | + parser: '@typescript-eslint/parser', | ||
13 | + ecmaVersion: 2020, | ||
14 | + sourceType: 'module', | ||
15 | + jsxPragma: 'React', | ||
16 | + ecmaFeatures: { | ||
17 | + jsx: true, | ||
18 | + }, | ||
19 | + }, | ||
20 | + extends: [ | ||
21 | + 'plugin:vue/vue3-recommended', | ||
22 | + 'plugin:@typescript-eslint/recommended', | ||
23 | + 'prettier', | ||
24 | + 'plugin:prettier/recommended', | ||
25 | + 'plugin:jest/recommended', | ||
26 | + ], | ||
27 | + rules: { | ||
28 | + 'vue/script-setup-uses-vars': 'error', | ||
29 | + '@typescript-eslint/ban-ts-ignore': 'off', | ||
30 | + '@typescript-eslint/explicit-function-return-type': 'off', | ||
31 | + '@typescript-eslint/no-explicit-any': 'off', | ||
32 | + '@typescript-eslint/no-var-requires': 'off', | ||
33 | + '@typescript-eslint/no-empty-function': 'off', | ||
34 | + 'vue/custom-event-name-casing': 'off', | ||
35 | + 'no-use-before-define': 'off', | ||
36 | + '@typescript-eslint/no-use-before-define': 'off', | ||
37 | + '@typescript-eslint/ban-ts-comment': 'off', | ||
38 | + '@typescript-eslint/ban-types': 'off', | ||
39 | + '@typescript-eslint/no-non-null-assertion': 'off', | ||
40 | + '@typescript-eslint/explicit-module-boundary-types': 'off', | ||
41 | + '@typescript-eslint/no-unused-vars': [ | ||
42 | + 'error', | ||
43 | + { | ||
44 | + argsIgnorePattern: '^_', | ||
45 | + varsIgnorePattern: '^_', | ||
46 | + }, | ||
47 | + ], | ||
48 | + 'no-unused-vars': [ | ||
49 | + 'error', | ||
50 | + { | ||
51 | + argsIgnorePattern: '^_', | ||
52 | + varsIgnorePattern: '^_', | ||
53 | + }, | ||
54 | + ], | ||
55 | + 'space-before-function-paren': 'off', | ||
56 | + | ||
57 | + 'vue/attributes-order': 'off', | ||
58 | + 'vue/one-component-per-file': 'off', | ||
59 | + 'vue/html-closing-bracket-newline': 'off', | ||
60 | + 'vue/max-attributes-per-line': 'off', | ||
61 | + 'vue/multiline-html-element-content-newline': 'off', | ||
62 | + 'vue/singleline-html-element-content-newline': 'off', | ||
63 | + 'vue/attribute-hyphenation': 'off', | ||
64 | + 'vue/require-default-prop': 'off', | ||
65 | + 'vue/html-self-closing': [ | ||
66 | + 'error', | ||
67 | + { | ||
68 | + html: { | ||
69 | + void: 'always', | ||
70 | + normal: 'never', | ||
71 | + component: 'always', | ||
72 | + }, | ||
73 | + svg: 'always', | ||
74 | + math: 'always', | ||
75 | + }, | ||
76 | + ], | ||
77 | + }, | ||
78 | +}); |
.gitignore
0 → 100644
1 | +node_modules | ||
2 | +.DS_Store | ||
3 | +dist | ||
4 | +.npmrc | ||
5 | +.cache | ||
6 | + | ||
7 | +tests/server/static | ||
8 | +tests/server/static/upload | ||
9 | + | ||
10 | +.local | ||
11 | +# local env files | ||
12 | +.env.local | ||
13 | +.env.*.local | ||
14 | +.eslintcache | ||
15 | + | ||
16 | +# Log files | ||
17 | +npm-debug.log* | ||
18 | +yarn-debug.log* | ||
19 | +yarn-error.log* | ||
20 | +pnpm-debug.log* | ||
21 | + | ||
22 | +# Editor directories and files | ||
23 | +.idea | ||
24 | +# .vscode | ||
25 | +*.suo | ||
26 | +*.ntvs* | ||
27 | +*.njsproj | ||
28 | +*.sln | ||
29 | +*.sw? |
.gitpod.yml
0 → 100644
.prettierignore
0 → 100644
.stylelintignore
0 → 100644
.yarnclean
0 → 100644
1 | +# test directories | ||
2 | +__tests__ | ||
3 | +test | ||
4 | +tests | ||
5 | +powered-test | ||
6 | + | ||
7 | +# asset directories | ||
8 | +docs | ||
9 | +doc | ||
10 | +website | ||
11 | +images | ||
12 | +assets | ||
13 | + | ||
14 | +# examples | ||
15 | +example | ||
16 | +examples | ||
17 | + | ||
18 | +# code coverage directories | ||
19 | +coverage | ||
20 | +.nyc_output | ||
21 | + | ||
22 | +# build scripts | ||
23 | +Makefile | ||
24 | +Gulpfile.js | ||
25 | +Gruntfile.js | ||
26 | + | ||
27 | +# configs | ||
28 | +appveyor.yml | ||
29 | +circle.yml | ||
30 | +codeship-services.yml | ||
31 | +codeship-steps.yml | ||
32 | +wercker.yml | ||
33 | +.tern-project | ||
34 | +.gitattributes | ||
35 | +.editorconfig | ||
36 | +.*ignore | ||
37 | +.eslintrc | ||
38 | +.jshintrc | ||
39 | +.flowconfig | ||
40 | +.documentup.json | ||
41 | +.yarn-metadata.json | ||
42 | +.travis.yml | ||
43 | + | ||
44 | +# misc | ||
45 | +*.md | ||
46 | + | ||
47 | +!istanbul-reports/lib/html/assets | ||
48 | +!istanbul-api/node_modules/istanbul-reports/lib/html/assets |
README.md
0 → 100644
1 | +<div align="center"> <a href="https://github.com/anncwb/vue-vben-admin"> <img alt="VbenAdmin Logo" width="200" height="200" src="https://anncwb.github.io/anncwb/images/logo.png"> </a> <br> <br> | ||
2 | + | ||
3 | +[](LICENSE) | ||
4 | + | ||
5 | +<h1>Vue vben admin</h1> | ||
6 | +</div> | ||
7 | + | ||
8 | +**中文** | [English](./README.md) | ||
9 | + | ||
10 | +## 简介 | ||
11 | + | ||
12 | +Vue Vben Admin 是一个免费开源的中后台模版。使用了最新的`vue3`,`vite2`,`TypeScript`等主流技术开发,开箱即用的中后台前端解决方案,也可用于学习参考。 | ||
13 | + | ||
14 | +## 特性 | ||
15 | + | ||
16 | +- **最新技术栈**:使用 Vue3/vite2 等前端前沿技术开发 | ||
17 | +- **TypeScript**: 应用程序级 JavaScript 的语言 | ||
18 | +- **主题**:可配置的主题 | ||
19 | +- **国际化**:内置完善的国际化方案 | ||
20 | +- **Mock 数据** 内置 Mock 数据方案 | ||
21 | +- **权限** 内置完善的动态路由权限生成方案 | ||
22 | +- **组件** 二次封装了多个常用的组件 | ||
23 | + | ||
24 | +## 预览 | ||
25 | + | ||
26 | +- [vue-vben-admin](https://vvbin.cn/next/) - 完整版中文站点 | ||
27 | +- [vue-vben-admin-gh-pages](https://anncwb.github.io/vue-vben-admin/) - 完整版 github 站点 | ||
28 | +- [vben-admin-thin-next](https://vvbin.cn/thin/next/) - 简化版中文站点 | ||
29 | +- [vben-admin-thin-gh-pages](https://anncwb.github.io/vben-admin-thin-next/) - 简化版 github 站点 | ||
30 | + | ||
31 | +测试账号: vben/123456 | ||
32 | + | ||
33 | +<p align="center"> | ||
34 | + <img alt="VbenAdmin Logo" width="100%" src="https://anncwb.github.io/anncwb/images/preview1.png"> | ||
35 | + <img alt="VbenAdmin Logo" width="100%" src="https://anncwb.github.io/anncwb/images/preview2.png"> | ||
36 | + <img alt="VbenAdmin Logo" width="100%" src="https://anncwb.github.io/anncwb/images/preview3.png"> | ||
37 | +</p> | ||
38 | + | ||
39 | +### 使用 Gitpod | ||
40 | + | ||
41 | +在 Gitpod(适用于 GitHub 的免费在线开发环境)中打开项目,并立即开始编码. | ||
42 | + | ||
43 | +[](https://gitpod.io/#https://github.com/anncwb/vue-vben-admin) | ||
44 | + | ||
45 | +## 文档 | ||
46 | + | ||
47 | +[文档地址](https://vvbin.cn/doc-next/) | ||
48 | + | ||
49 | +## 准备 | ||
50 | + | ||
51 | +- [node](http://nodejs.org/) 和 [git](https://git-scm.com/) -项目开发环境 | ||
52 | +- [Vite](https://vitejs.dev/) - 熟悉 vite 特性 | ||
53 | +- [Vue3](https://v3.vuejs.org/) - 熟悉 Vue 基础语法 | ||
54 | +- [TypeScript](https://www.typescriptlang.org/) - 熟悉`TypeScript`基本语法 | ||
55 | +- [Es6+](http://es6.ruanyifeng.com/) - 熟悉 es6 基本语法 | ||
56 | +- [Vue-Router-Next](https://next.router.vuejs.org/) - 熟悉 vue-router 基本使用 | ||
57 | +- [Ant-Design-Vue](https://2x.antdv.com/docs/vue/introduce-cn/) - ui 基本使用 | ||
58 | +- [Mock.js](https://github.com/nuysoft/Mock) - mockjs 基本语法 | ||
59 | + | ||
60 | +## 安装使用 | ||
61 | + | ||
62 | +- 获取项目代码 | ||
63 | + | ||
64 | +```bash | ||
65 | +git clone https://github.com/anncwb/vue-vben-admin.git | ||
66 | +``` | ||
67 | + | ||
68 | +- 安装依赖 | ||
69 | + | ||
70 | +```bash | ||
71 | +cd vue-vben-admin | ||
72 | + | ||
73 | +yarn install | ||
74 | + | ||
75 | +``` | ||
76 | + | ||
77 | +- 运行 | ||
78 | + | ||
79 | +```bash | ||
80 | +yarn serve | ||
81 | +``` | ||
82 | + | ||
83 | +- 打包 | ||
84 | + | ||
85 | +```bash | ||
86 | +yarn build | ||
87 | +``` | ||
88 | + | ||
89 | +## 更新日志 | ||
90 | + | ||
91 | +[CHANGELOG](./CHANGELOG.zh_CN.md) | ||
92 | + | ||
93 | +## 项目地址 | ||
94 | + | ||
95 | +- [vue-vben-admin](https://github.com/anncwb/vue-vben-admin) - 完整版 | ||
96 | +- [vue-vben-admin-thin-next](https://github.com/anncwb/vben-admin-thin-next) - 简化版 | ||
97 | + | ||
98 | +## 如何贡献 | ||
99 | + | ||
100 | +非常欢迎你的加入 或者提交一个 Pull Request。 | ||
101 | + | ||
102 | +**Pull Request:** | ||
103 | + | ||
104 | +1. Fork 代码! | ||
105 | +2. 创建自己的分支: `git checkout -b feat/xxxx` | ||
106 | +3. 提交你的修改: `git commit -am 'feat(function): add xxxxx'` | ||
107 | +4. 推送您的分支: `git push origin feat/xxxx` | ||
108 | +5. 提交`pull request` | ||
109 | + | ||
110 | +## Git 贡献提交规范 | ||
111 | + | ||
112 | +- 参考 [vue](https://github.com/vuejs/vue/blob/dev/.github/COMMIT_CONVENTION.md) 规范 ([Angular](https://github.com/conventional-changelog/conventional-changelog/tree/master/packages/conventional-changelog-angular)) | ||
113 | + | ||
114 | + - `feat` 增加新功能 | ||
115 | + - `fix` 修复问题/BUG | ||
116 | + - `style` 代码风格相关无影响运行结果的 | ||
117 | + - `perf` 优化/性能提升 | ||
118 | + - `refactor` 重构 | ||
119 | + - `revert` 撤销修改 | ||
120 | + - `test` 测试相关 | ||
121 | + - `docs` 文档/注释 | ||
122 | + - `chore` 依赖更新/脚手架配置修改等 | ||
123 | + - `workflow` 工作流改进 | ||
124 | + - `ci` 持续集成 | ||
125 | + - `types` 类型定义文件更改 | ||
126 | + - `wip` 开发中 | ||
127 | + | ||
128 | +## 浏览器支持 | ||
129 | + | ||
130 | +本地开发推荐使用`Chrome 80+` 浏览器 | ||
131 | + | ||
132 | +支持现代浏览器, 不支持 IE | ||
133 | + | ||
134 | +| [<img src="https://raw.githubusercontent.com/alrra/browser-logos/master/src/edge/edge_48x48.png" alt=" Edge" width="24px" height="24px" />](http://godban.github.io/browsers-support-badges/)</br>IE | [<img src="https://raw.githubusercontent.com/alrra/browser-logos/master/src/edge/edge_48x48.png" alt=" Edge" width="24px" height="24px" />](http://godban.github.io/browsers-support-badges/)</br>Edge | [<img src="https://raw.githubusercontent.com/alrra/browser-logos/master/src/firefox/firefox_48x48.png" alt="Firefox" width="24px" height="24px" />](http://godban.github.io/browsers-support-badges/)</br>Firefox | [<img src="https://raw.githubusercontent.com/alrra/browser-logos/master/src/chrome/chrome_48x48.png" alt="Chrome" width="24px" height="24px" />](http://godban.github.io/browsers-support-badges/)</br>Chrome | [<img src="https://raw.githubusercontent.com/alrra/browser-logos/master/src/safari/safari_48x48.png" alt="Safari" width="24px" height="24px" />](http://godban.github.io/browsers-support-badges/)</br>Safari | | ||
135 | +| :-: | :-: | :-: | :-: | :-: | | ||
136 | +| not support | last 2 versions | last 2 versions | last 2 versions | last 2 versions | | ||
137 | + | ||
138 | +## 相关仓库 | ||
139 | + | ||
140 | +如果这些插件对你有帮助,可以给一个 star 支持下 | ||
141 | + | ||
142 | +- [vite-plugin-mock](https://github.com/anncwb/vite-plugin-mock) - 用于本地及开发环境数据 mock | ||
143 | +- [vite-plugin-html](https://github.com/anncwb/vite-plugin-html) - 用于 html 模版转换及压缩 | ||
144 | +- [vite-plugin-style-import](https://github.com/anncwb/vite-plugin-style-import) - 用于组件库样式按需引入 | ||
145 | +- [vite-plugin-theme](https://github.com/anncwb/vite-plugin-theme) - 用于在线切换主题色等颜色相关配置 | ||
146 | +- [vite-plugin-imagemin](https://github.com/anncwb/vite-plugin-imagemin) - 用于打包压缩图片资源 | ||
147 | +- [vite-plugin-compression](https://github.com/anncwb/vite-plugin-compression) - 用于打包输出.gz|.brotil 文件 | ||
148 | +- [vite-plugin-svg-icons](https://github.com/anncwb/vite-plugin-svg-icons) - 用于快速生成 svg 雪碧图 | ||
149 | + | ||
150 | +## 后台整合示例 | ||
151 | + | ||
152 | +- [lamp-cloud](https://github.com/zuihou/lamp-cloud) - 基于 SpringCloud Alibaba 的微服务中后台快速开发平台 | ||
153 | + | ||
154 | +## 维护者 | ||
155 | + | ||
156 | +[@Vben](https://github.com/anncwb) | ||
157 | + | ||
158 | +## 捐赠 | ||
159 | + | ||
160 | +如果你觉得这个项目对你有帮助,你可以帮作者买一杯咖啡表示支持! | ||
161 | + | ||
162 | + | ||
163 | + | ||
164 | +<a style="display: block;width: 100px;height: 50px;line-height: 50px; color: #fff;text-align: center; background: #408aed;border-radius: 4px;" href="https://www.paypal.com/paypalme/cvvben">Paypal Me</a> | ||
165 | + | ||
166 | +## 交流 | ||
167 | + | ||
168 | +`Vue-vben-Admin` 是完全开源免费的项目,在帮助开发者更方便地进行中大型管理系统开发,同时也提供 QQ 交流群使用问题欢迎在群内提问。 | ||
169 | + | ||
170 | +- QQ 群 `569291866` | ||
171 | + | ||
172 | +## License | ||
173 | + | ||
174 | +[MIT © Vben-2020](./LICENSE) |
build/config/themeConfig.ts
0 → 100644
1 | +import { generate } from '@ant-design/colors'; | ||
2 | + | ||
3 | +export const primaryColor = '#0960bd'; | ||
4 | + | ||
5 | +export const darkMode = 'light'; | ||
6 | + | ||
7 | +type Fn = (...arg: any) => any; | ||
8 | + | ||
9 | +type GenerateTheme = 'default' | 'dark'; | ||
10 | + | ||
11 | +export interface GenerateColorsParams { | ||
12 | + mixLighten: Fn; | ||
13 | + mixDarken: Fn; | ||
14 | + tinycolor: any; | ||
15 | + color?: string; | ||
16 | +} | ||
17 | + | ||
18 | +export function generateAntColors(color: string, theme: GenerateTheme = 'default') { | ||
19 | + return generate(color, { | ||
20 | + theme, | ||
21 | + }); | ||
22 | +} | ||
23 | + | ||
24 | +export function getThemeColors(color?: string) { | ||
25 | + const tc = color || primaryColor; | ||
26 | + const lightColors = generateAntColors(tc); | ||
27 | + const primary = lightColors[5]; | ||
28 | + const modeColors = generateAntColors(primary, 'dark'); | ||
29 | + | ||
30 | + return [...lightColors, ...modeColors]; | ||
31 | +} | ||
32 | + | ||
33 | +export function generateColors({ | ||
34 | + color = primaryColor, | ||
35 | + mixLighten, | ||
36 | + mixDarken, | ||
37 | + tinycolor, | ||
38 | +}: GenerateColorsParams) { | ||
39 | + const arr = new Array(19).fill(0); | ||
40 | + const lightens = arr.map((_t, i) => { | ||
41 | + return mixLighten(color, i / 5); | ||
42 | + }); | ||
43 | + | ||
44 | + const darkens = arr.map((_t, i) => { | ||
45 | + return mixDarken(color, i / 5); | ||
46 | + }); | ||
47 | + | ||
48 | + const alphaColors = arr.map((_t, i) => { | ||
49 | + return tinycolor(color) | ||
50 | + .setAlpha(i / 20) | ||
51 | + .toRgbString(); | ||
52 | + }); | ||
53 | + | ||
54 | + const shortAlphaColors = alphaColors.map((item) => item.replace(/\s/g, '').replace(/0\./g, '.')); | ||
55 | + | ||
56 | + const tinycolorLightens = arr | ||
57 | + .map((_t, i) => { | ||
58 | + return tinycolor(color) | ||
59 | + .lighten(i * 5) | ||
60 | + .toHexString(); | ||
61 | + }) | ||
62 | + .filter((item) => item !== '#ffffff'); | ||
63 | + | ||
64 | + const tinycolorDarkens = arr | ||
65 | + .map((_t, i) => { | ||
66 | + return tinycolor(color) | ||
67 | + .darken(i * 5) | ||
68 | + .toHexString(); | ||
69 | + }) | ||
70 | + .filter((item) => item !== '#000000'); | ||
71 | + return [ | ||
72 | + ...lightens, | ||
73 | + ...darkens, | ||
74 | + ...alphaColors, | ||
75 | + ...shortAlphaColors, | ||
76 | + ...tinycolorDarkens, | ||
77 | + ...tinycolorLightens, | ||
78 | + ].filter((item) => !item.includes('-')); | ||
79 | +} |
build/constant.ts
0 → 100644
build/generate/generateModifyVars.ts
0 → 100644
1 | +import { generateAntColors, primaryColor } from '../config/themeConfig'; | ||
2 | +import { getThemeVariables } from 'ant-design-vue/dist/theme'; | ||
3 | +import { resolve } from 'path'; | ||
4 | + | ||
5 | +/** | ||
6 | + * less global variable | ||
7 | + */ | ||
8 | +export function generateModifyVars(dark = false) { | ||
9 | + const palettes = generateAntColors(primaryColor); | ||
10 | + const primary = palettes[5]; | ||
11 | + | ||
12 | + const primaryColorObj: Record<string, string> = {}; | ||
13 | + | ||
14 | + for (let index = 0; index < 10; index++) { | ||
15 | + primaryColorObj[`primary-${index + 1}`] = palettes[index]; | ||
16 | + } | ||
17 | + | ||
18 | + const modifyVars = getThemeVariables({ dark }); | ||
19 | + return { | ||
20 | + ...modifyVars, | ||
21 | + // Used for global import to avoid the need to import each style file separately | ||
22 | + // reference: Avoid repeated references | ||
23 | + hack: `${modifyVars.hack} @import (reference) "${resolve('src/design/config.less')}";`, | ||
24 | + 'primary-color': primary, | ||
25 | + ...primaryColorObj, | ||
26 | + 'info-color': primary, | ||
27 | + 'processing-color': primary, | ||
28 | + 'success-color': '#55D187', // Success color | ||
29 | + 'error-color': '#ED6F6F', // False color | ||
30 | + 'warning-color': '#EFBD47', // Warning color | ||
31 | + //'border-color-base': '#EEEEEE', | ||
32 | + 'font-size-base': '14px', // Main font size | ||
33 | + 'border-radius-base': '2px', // Component/float fillet | ||
34 | + 'link-color': primary, // Link color | ||
35 | + 'app-content-background': '#fafafa', // Link color | ||
36 | + }; | ||
37 | +} |
build/generate/icon/index.ts
0 → 100644
1 | +import path from 'path'; | ||
2 | +import fs from 'fs-extra'; | ||
3 | +import inquirer from 'inquirer'; | ||
4 | +import chalk from 'chalk'; | ||
5 | +import pkg from '../../../package.json'; | ||
6 | + | ||
7 | +async function generateIcon() { | ||
8 | + const dir = path.resolve(process.cwd(), 'node_modules/@iconify/json'); | ||
9 | + | ||
10 | + const raw = await fs.readJSON(path.join(dir, 'collections.json')); | ||
11 | + | ||
12 | + const collections = Object.entries(raw).map(([id, v]) => ({ | ||
13 | + ...(v as any), | ||
14 | + id, | ||
15 | + })); | ||
16 | + | ||
17 | + const choices = collections.map((item) => ({ key: item.id, value: item.id, name: item.name })); | ||
18 | + | ||
19 | + inquirer | ||
20 | + .prompt([ | ||
21 | + { | ||
22 | + type: 'list', | ||
23 | + name: 'useType', | ||
24 | + choices: [ | ||
25 | + { key: 'local', value: 'local', name: 'Local' }, | ||
26 | + { key: 'onLine', value: 'onLine', name: 'OnLine' }, | ||
27 | + ], | ||
28 | + message: 'How to use icons?', | ||
29 | + }, | ||
30 | + { | ||
31 | + type: 'list', | ||
32 | + name: 'iconSet', | ||
33 | + choices: choices, | ||
34 | + message: 'Select the icon set that needs to be generated?', | ||
35 | + }, | ||
36 | + { | ||
37 | + type: 'input', | ||
38 | + name: 'output', | ||
39 | + message: 'Select the icon set that needs to be generated?', | ||
40 | + default: 'src/components/Icon/data', | ||
41 | + }, | ||
42 | + ]) | ||
43 | + .then(async (answers) => { | ||
44 | + const { iconSet, output, useType } = answers; | ||
45 | + const outputDir = path.resolve(process.cwd(), output); | ||
46 | + fs.ensureDir(outputDir); | ||
47 | + const genCollections = collections.filter((item) => [iconSet].includes(item.id)); | ||
48 | + const prefixSet: string[] = []; | ||
49 | + for (const info of genCollections) { | ||
50 | + const data = await fs.readJSON(path.join(dir, 'json', `${info.id}.json`)); | ||
51 | + if (data) { | ||
52 | + const { prefix } = data; | ||
53 | + const isLocal = useType === 'local'; | ||
54 | + const icons = Object.keys(data.icons).map( | ||
55 | + (item) => `${isLocal ? prefix + ':' : ''}${item}` | ||
56 | + ); | ||
57 | + | ||
58 | + await fs.writeFileSync( | ||
59 | + path.join(output, `icons.data.ts`), | ||
60 | + `export default ${isLocal ? JSON.stringify(icons) : JSON.stringify({ prefix, icons })}` | ||
61 | + ); | ||
62 | + prefixSet.push(prefix); | ||
63 | + } | ||
64 | + } | ||
65 | + fs.emptyDir(path.join(process.cwd(), 'node_modules/.vite')); | ||
66 | + console.log( | ||
67 | + `✨ ${chalk.cyan(`[${pkg.name}]`)}` + ' - Icon generated successfully:' + `[${prefixSet}]` | ||
68 | + ); | ||
69 | + }); | ||
70 | +} | ||
71 | + | ||
72 | +generateIcon(); |
build/getConfigFileName.ts
0 → 100644
build/script/buildConf.ts
0 → 100644
1 | +/** | ||
2 | + * Generate additional configuration files when used for packaging. The file can be configured with some global variables, so that it can be changed directly externally without repackaging | ||
3 | + */ | ||
4 | +import { GLOB_CONFIG_FILE_NAME, OUTPUT_DIR } from '../constant'; | ||
5 | +import fs, { writeFileSync } from 'fs-extra'; | ||
6 | +import chalk from 'chalk'; | ||
7 | + | ||
8 | +import { getRootPath, getEnvConfig } from '../utils'; | ||
9 | +import { getConfigFileName } from '../getConfigFileName'; | ||
10 | + | ||
11 | +import pkg from '../../package.json'; | ||
12 | + | ||
13 | +function createConfig( | ||
14 | + { | ||
15 | + configName, | ||
16 | + config, | ||
17 | + configFileName = GLOB_CONFIG_FILE_NAME, | ||
18 | + }: { configName: string; config: any; configFileName?: string } = { configName: '', config: {} } | ||
19 | +) { | ||
20 | + try { | ||
21 | + const windowConf = `window.${configName}`; | ||
22 | + // Ensure that the variable will not be modified | ||
23 | + const configStr = `${windowConf}=${JSON.stringify(config)}; | ||
24 | + Object.freeze(${windowConf}); | ||
25 | + Object.defineProperty(window, "${configName}", { | ||
26 | + configurable: false, | ||
27 | + writable: false, | ||
28 | + }); | ||
29 | + `.replace(/\s/g, ''); | ||
30 | + fs.mkdirp(getRootPath(OUTPUT_DIR)); | ||
31 | + writeFileSync(getRootPath(`${OUTPUT_DIR}/${configFileName}`), configStr); | ||
32 | + | ||
33 | + console.log(chalk.cyan(`✨ [${pkg.name}]`) + ` - configuration file is build successfully:`); | ||
34 | + console.log(chalk.gray(OUTPUT_DIR + '/' + chalk.green(configFileName)) + '\n'); | ||
35 | + } catch (error) { | ||
36 | + console.log(chalk.red('configuration file configuration file failed to package:\n' + error)); | ||
37 | + } | ||
38 | +} | ||
39 | + | ||
40 | +export function runBuildConfig() { | ||
41 | + const config = getEnvConfig(); | ||
42 | + const configFileName = getConfigFileName(config); | ||
43 | + createConfig({ config, configName: configFileName }); | ||
44 | +} |
build/script/postBuild.ts
0 → 100644
1 | +// #!/usr/bin/env node | ||
2 | + | ||
3 | +import { runBuildConfig } from './buildConf'; | ||
4 | +import chalk from 'chalk'; | ||
5 | + | ||
6 | +import pkg from '../../package.json'; | ||
7 | + | ||
8 | +export const runBuild = async () => { | ||
9 | + try { | ||
10 | + const argvList = process.argv.splice(2); | ||
11 | + | ||
12 | + // Generate configuration file | ||
13 | + if (!argvList.includes('disabled-config')) { | ||
14 | + runBuildConfig(); | ||
15 | + } | ||
16 | + | ||
17 | + console.log(`✨ ${chalk.cyan(`[${pkg.name}]`)}` + ' - build successfully!'); | ||
18 | + } catch (error) { | ||
19 | + console.log(chalk.red('vite build error:\n' + error)); | ||
20 | + process.exit(1); | ||
21 | + } | ||
22 | +}; | ||
23 | +runBuild(); |
build/utils.ts
0 → 100644
1 | +import fs from 'fs'; | ||
2 | +import path from 'path'; | ||
3 | +import dotenv from 'dotenv'; | ||
4 | + | ||
5 | +export function isDevFn(mode: string): boolean { | ||
6 | + return mode === 'development'; | ||
7 | +} | ||
8 | + | ||
9 | +export function isProdFn(mode: string): boolean { | ||
10 | + return mode === 'production'; | ||
11 | +} | ||
12 | + | ||
13 | +/** | ||
14 | + * Whether to generate package preview | ||
15 | + */ | ||
16 | +export function isReportMode(): boolean { | ||
17 | + return process.env.REPORT === 'true'; | ||
18 | +} | ||
19 | + | ||
20 | +// Read all environment variable configuration files to process.env | ||
21 | +export function wrapperEnv(envConf: Recordable): ViteEnv { | ||
22 | + const ret: any = {}; | ||
23 | + | ||
24 | + for (const envName of Object.keys(envConf)) { | ||
25 | + let realName = envConf[envName].replace(/\\n/g, '\n'); | ||
26 | + realName = realName === 'true' ? true : realName === 'false' ? false : realName; | ||
27 | + | ||
28 | + if (envName === 'VITE_PORT') { | ||
29 | + realName = Number(realName); | ||
30 | + } | ||
31 | + if (envName === 'VITE_PROXY') { | ||
32 | + try { | ||
33 | + realName = JSON.parse(realName); | ||
34 | + } catch (error) { | ||
35 | + realName = ''; | ||
36 | + } | ||
37 | + } | ||
38 | + ret[envName] = realName; | ||
39 | + if (typeof realName === 'string') { | ||
40 | + process.env[envName] = realName; | ||
41 | + } else if (typeof realName === 'object') { | ||
42 | + process.env[envName] = JSON.stringify(realName); | ||
43 | + } | ||
44 | + } | ||
45 | + return ret; | ||
46 | +} | ||
47 | + | ||
48 | +/** | ||
49 | + * 获取当前环境下生效的配置文件名 | ||
50 | + */ | ||
51 | +function getConfFiles() { | ||
52 | + const script = process.env.npm_lifecycle_script; | ||
53 | + const reg = new RegExp('--mode ([a-z]+)'); | ||
54 | + const result = reg.exec(script as string) as any; | ||
55 | + if (result) { | ||
56 | + const mode = result[1] as string; | ||
57 | + return ['.env', `.env.${mode}`]; | ||
58 | + } | ||
59 | + return ['.env', '.env.production']; | ||
60 | +} | ||
61 | + | ||
62 | +/** | ||
63 | + * Get the environment variables starting with the specified prefix | ||
64 | + * @param match prefix | ||
65 | + * @param confFiles ext | ||
66 | + */ | ||
67 | +export function getEnvConfig(match = 'VITE_GLOB_', confFiles = getConfFiles()) { | ||
68 | + let envConfig = {}; | ||
69 | + confFiles.forEach((item) => { | ||
70 | + try { | ||
71 | + const env = dotenv.parse(fs.readFileSync(path.resolve(process.cwd(), item))); | ||
72 | + envConfig = { ...envConfig, ...env }; | ||
73 | + } catch (e) { | ||
74 | + console.error(`Error in parsing ${item}`, e); | ||
75 | + } | ||
76 | + }); | ||
77 | + const reg = new RegExp(`^(${match})`); | ||
78 | + Object.keys(envConfig).forEach((key) => { | ||
79 | + if (!reg.test(key)) { | ||
80 | + Reflect.deleteProperty(envConfig, key); | ||
81 | + } | ||
82 | + }); | ||
83 | + return envConfig; | ||
84 | +} | ||
85 | + | ||
86 | +/** | ||
87 | + * Get user root directory | ||
88 | + * @param dir file path | ||
89 | + */ | ||
90 | +export function getRootPath(...dir: string[]) { | ||
91 | + return path.resolve(process.cwd(), ...dir); | ||
92 | +} |
build/vite/optimizer.ts
0 → 100644
1 | +// TODO | ||
2 | +import type { GetManualChunk } from 'rollup'; | ||
3 | + | ||
4 | +// | ||
5 | +const vendorLibs: { match: string[]; output: string }[] = [ | ||
6 | + // { | ||
7 | + // match: ['xlsx'], | ||
8 | + // output: 'xlsx', | ||
9 | + // }, | ||
10 | +]; | ||
11 | + | ||
12 | +// @ts-ignore | ||
13 | +export const configManualChunk: GetManualChunk = (id: string) => { | ||
14 | + if (/[\\/]node_modules[\\/]/.test(id)) { | ||
15 | + const matchItem = vendorLibs.find((item) => { | ||
16 | + const reg = new RegExp(`[\\/]node_modules[\\/]_?(${item.match.join('|')})(.*)`, 'ig'); | ||
17 | + return reg.test(id); | ||
18 | + }); | ||
19 | + return matchItem ? matchItem.output : null; | ||
20 | + } | ||
21 | +}; |
build/vite/plugin/compress.ts
0 → 100644
1 | +/** | ||
2 | + * Used to package and output gzip. Note that this does not work properly in Vite, the specific reason is still being investigated | ||
3 | + * https://github.com/anncwb/vite-plugin-compression | ||
4 | + */ | ||
5 | +import type { Plugin } from 'vite'; | ||
6 | + | ||
7 | +import compressPlugin from 'vite-plugin-compression'; | ||
8 | + | ||
9 | +export function configCompressPlugin( | ||
10 | + compress: 'gzip' | 'brotli' | 'none', | ||
11 | + deleteOriginFile = false | ||
12 | +): Plugin | Plugin[] { | ||
13 | + const compressList = compress.split(','); | ||
14 | + | ||
15 | + const plugins: Plugin[] = []; | ||
16 | + | ||
17 | + if (compressList.includes('gzip')) { | ||
18 | + plugins.push( | ||
19 | + compressPlugin({ | ||
20 | + ext: '.gz', | ||
21 | + deleteOriginFile, | ||
22 | + }) | ||
23 | + ); | ||
24 | + } | ||
25 | + if (compressList.includes('brotli')) { | ||
26 | + plugins.push( | ||
27 | + compressPlugin({ | ||
28 | + ext: '.br', | ||
29 | + algorithm: 'brotliCompress', | ||
30 | + deleteOriginFile, | ||
31 | + }) | ||
32 | + ); | ||
33 | + } | ||
34 | + return plugins; | ||
35 | +} |
build/vite/plugin/hmr.ts
0 → 100644
1 | +import type { Plugin } from 'vite'; | ||
2 | + | ||
3 | +/** | ||
4 | + * TODO | ||
5 | + * Temporarily solve the Vite circular dependency problem, and wait for a better solution to fix it later. I don't know what problems this writing will bring. | ||
6 | + * @returns | ||
7 | + */ | ||
8 | + | ||
9 | +export function configHmrPlugin(): Plugin { | ||
10 | + return { | ||
11 | + name: 'singleHMR', | ||
12 | + handleHotUpdate({ modules, file }) { | ||
13 | + if (file.match(/xml$/)) return []; | ||
14 | + | ||
15 | + modules.forEach((m) => { | ||
16 | + if (!m.url.match(/\.(css|less)/)) { | ||
17 | + m.importedModules = new Set(); | ||
18 | + m.importers = new Set(); | ||
19 | + } | ||
20 | + }); | ||
21 | + | ||
22 | + return modules; | ||
23 | + }, | ||
24 | + }; | ||
25 | +} |
build/vite/plugin/html.ts
0 → 100644
1 | +/** | ||
2 | + * Plugin to minimize and use ejs template syntax in index.html. | ||
3 | + * https://github.com/anncwb/vite-plugin-html | ||
4 | + */ | ||
5 | +import type { Plugin } from 'vite'; | ||
6 | + | ||
7 | +import html from 'vite-plugin-html'; | ||
8 | + | ||
9 | +import pkg from '../../../package.json'; | ||
10 | +import { GLOB_CONFIG_FILE_NAME } from '../../constant'; | ||
11 | + | ||
12 | +export function configHtmlPlugin(env: ViteEnv, isBuild: boolean) { | ||
13 | + const { VITE_GLOB_APP_TITLE, VITE_PUBLIC_PATH } = env; | ||
14 | + | ||
15 | + const path = VITE_PUBLIC_PATH.endsWith('/') ? VITE_PUBLIC_PATH : `${VITE_PUBLIC_PATH}/`; | ||
16 | + | ||
17 | + const getAppConfigSrc = () => { | ||
18 | + return `${path || '/'}${GLOB_CONFIG_FILE_NAME}?v=${pkg.version}-${new Date().getTime()}`; | ||
19 | + }; | ||
20 | + | ||
21 | + const htmlPlugin: Plugin[] = html({ | ||
22 | + minify: isBuild, | ||
23 | + inject: { | ||
24 | + // Inject data into ejs template | ||
25 | + injectData: { | ||
26 | + title: VITE_GLOB_APP_TITLE, | ||
27 | + }, | ||
28 | + // Embed the generated app.config.js file | ||
29 | + tags: isBuild | ||
30 | + ? [ | ||
31 | + { | ||
32 | + tag: 'script', | ||
33 | + attrs: { | ||
34 | + src: getAppConfigSrc(), | ||
35 | + }, | ||
36 | + }, | ||
37 | + ] | ||
38 | + : [], | ||
39 | + }, | ||
40 | + }); | ||
41 | + return htmlPlugin; | ||
42 | +} |
build/vite/plugin/imagemin.ts
0 → 100644
1 | +// Image resource files used to compress the output of the production environment | ||
2 | +// https://github.com/anncwb/vite-plugin-imagemin | ||
3 | + | ||
4 | +import viteImagemin from 'vite-plugin-imagemin'; | ||
5 | + | ||
6 | +export function configImageminPlugin() { | ||
7 | + const plugin = viteImagemin({ | ||
8 | + gifsicle: { | ||
9 | + optimizationLevel: 7, | ||
10 | + interlaced: false, | ||
11 | + }, | ||
12 | + optipng: { | ||
13 | + optimizationLevel: 7, | ||
14 | + }, | ||
15 | + mozjpeg: { | ||
16 | + quality: 20, | ||
17 | + }, | ||
18 | + pngquant: { | ||
19 | + quality: [0.8, 0.9], | ||
20 | + speed: 4, | ||
21 | + }, | ||
22 | + svgo: { | ||
23 | + plugins: [ | ||
24 | + { | ||
25 | + name: 'removeViewBox', | ||
26 | + }, | ||
27 | + { | ||
28 | + name: 'removeEmptyAttrs', | ||
29 | + active: false, | ||
30 | + }, | ||
31 | + ], | ||
32 | + }, | ||
33 | + }); | ||
34 | + return plugin; | ||
35 | +} |
build/vite/plugin/index.ts
0 → 100644
1 | +import type { Plugin } from 'vite'; | ||
2 | + | ||
3 | +import vue from '@vitejs/plugin-vue'; | ||
4 | +import vueJsx from '@vitejs/plugin-vue-jsx'; | ||
5 | +import legacy from '@vitejs/plugin-legacy'; | ||
6 | + | ||
7 | +import purgeIcons from 'vite-plugin-purge-icons'; | ||
8 | +import windiCSS from 'vite-plugin-windicss'; | ||
9 | +import { configHtmlPlugin } from './html'; | ||
10 | +import { configPwaConfig } from './pwa'; | ||
11 | +import { configMockPlugin } from './mock'; | ||
12 | +import { configCompressPlugin } from './compress'; | ||
13 | +import { configStyleImportPlugin } from './styleImport'; | ||
14 | +import { configVisualizerConfig } from './visualizer'; | ||
15 | +import { configThemePlugin } from './theme'; | ||
16 | +import { configImageminPlugin } from './imagemin'; | ||
17 | +import { configSvgIconsPlugin } from './svgSprite'; | ||
18 | +import { configHmrPlugin } from './hmr'; | ||
19 | + | ||
20 | +export function createVitePlugins(viteEnv: ViteEnv, isBuild: boolean) { | ||
21 | + const { | ||
22 | + VITE_USE_IMAGEMIN, | ||
23 | + VITE_USE_MOCK, | ||
24 | + VITE_LEGACY, | ||
25 | + VITE_BUILD_COMPRESS, | ||
26 | + VITE_BUILD_COMPRESS_DELETE_ORIGIN_FILE, | ||
27 | + } = viteEnv; | ||
28 | + | ||
29 | + const vitePlugins: (Plugin | Plugin[])[] = [ | ||
30 | + // have to | ||
31 | + vue(), | ||
32 | + // have to | ||
33 | + vueJsx(), | ||
34 | + ]; | ||
35 | + | ||
36 | + // vite-plugin-windicss | ||
37 | + vitePlugins.push(windiCSS()); | ||
38 | + | ||
39 | + // TODO | ||
40 | + !isBuild && vitePlugins.push(configHmrPlugin()); | ||
41 | + | ||
42 | + // @vitejs/plugin-legacy | ||
43 | + VITE_LEGACY && isBuild && vitePlugins.push(legacy()); | ||
44 | + | ||
45 | + // vite-plugin-html | ||
46 | + vitePlugins.push(configHtmlPlugin(viteEnv, isBuild)); | ||
47 | + | ||
48 | + // vite-plugin-svg-icons | ||
49 | + vitePlugins.push(configSvgIconsPlugin(isBuild)); | ||
50 | + | ||
51 | + // vite-plugin-mock | ||
52 | + VITE_USE_MOCK && vitePlugins.push(configMockPlugin(isBuild)); | ||
53 | + | ||
54 | + // vite-plugin-purge-icons | ||
55 | + vitePlugins.push(purgeIcons()); | ||
56 | + | ||
57 | + // vite-plugin-style-import | ||
58 | + vitePlugins.push(configStyleImportPlugin(isBuild)); | ||
59 | + | ||
60 | + // rollup-plugin-visualizer | ||
61 | + vitePlugins.push(configVisualizerConfig()); | ||
62 | + | ||
63 | + //vite-plugin-theme | ||
64 | + vitePlugins.push(configThemePlugin(isBuild)); | ||
65 | + | ||
66 | + // The following plugins only work in the production environment | ||
67 | + if (isBuild) { | ||
68 | + //vite-plugin-imagemin | ||
69 | + VITE_USE_IMAGEMIN && vitePlugins.push(configImageminPlugin()); | ||
70 | + | ||
71 | + // rollup-plugin-gzip | ||
72 | + vitePlugins.push( | ||
73 | + configCompressPlugin(VITE_BUILD_COMPRESS, VITE_BUILD_COMPRESS_DELETE_ORIGIN_FILE) | ||
74 | + ); | ||
75 | + | ||
76 | + // vite-plugin-pwa | ||
77 | + vitePlugins.push(configPwaConfig(viteEnv)); | ||
78 | + } | ||
79 | + | ||
80 | + return vitePlugins; | ||
81 | +} |
build/vite/plugin/mock.ts
0 → 100644
1 | +/** | ||
2 | + * Mock plugin for development and production. | ||
3 | + * https://github.com/anncwb/vite-plugin-mock | ||
4 | + */ | ||
5 | +import { viteMockServe } from 'vite-plugin-mock'; | ||
6 | + | ||
7 | +export function configMockPlugin(isBuild: boolean) { | ||
8 | + return viteMockServe({ | ||
9 | + ignore: /^\_/, | ||
10 | + mockPath: 'mock', | ||
11 | + localEnabled: !isBuild, | ||
12 | + prodEnabled: isBuild, | ||
13 | + injectCode: ` | ||
14 | + import { setupProdMockServer } from '../mock/_createProductionServer'; | ||
15 | + | ||
16 | + setupProdMockServer(); | ||
17 | + `, | ||
18 | + }); | ||
19 | +} |
build/vite/plugin/pwa.ts
0 → 100644
1 | +/** | ||
2 | + * Zero-config PWA for Vite | ||
3 | + * https://github.com/antfu/vite-plugin-pwa | ||
4 | + */ | ||
5 | + | ||
6 | +import { VitePWA } from 'vite-plugin-pwa'; | ||
7 | + | ||
8 | +export function configPwaConfig(env: ViteEnv) { | ||
9 | + const { VITE_USE_PWA, VITE_GLOB_APP_TITLE, VITE_GLOB_APP_SHORT_NAME } = env; | ||
10 | + | ||
11 | + if (VITE_USE_PWA) { | ||
12 | + // vite-plugin-pwa | ||
13 | + const pwaPlugin = VitePWA({ | ||
14 | + manifest: { | ||
15 | + name: VITE_GLOB_APP_TITLE, | ||
16 | + short_name: VITE_GLOB_APP_SHORT_NAME, | ||
17 | + icons: [ | ||
18 | + { | ||
19 | + src: './resource/img/pwa-192x192.png', | ||
20 | + sizes: '192x192', | ||
21 | + type: 'image/png', | ||
22 | + }, | ||
23 | + { | ||
24 | + src: './resource/img/pwa-512x512.png', | ||
25 | + sizes: '512x512', | ||
26 | + type: 'image/png', | ||
27 | + }, | ||
28 | + ], | ||
29 | + }, | ||
30 | + }); | ||
31 | + return pwaPlugin; | ||
32 | + } | ||
33 | + return []; | ||
34 | +} |
build/vite/plugin/styleImport.ts
0 → 100644
1 | +/** | ||
2 | + * Introduces component library styles on demand. | ||
3 | + * https://github.com/anncwb/vite-plugin-style-import | ||
4 | + */ | ||
5 | + | ||
6 | +import styleImport from 'vite-plugin-style-import'; | ||
7 | + | ||
8 | +export function configStyleImportPlugin(isBuild: boolean) { | ||
9 | + if (!isBuild) return []; | ||
10 | + const styleImportPlugin = styleImport({ | ||
11 | + libs: [ | ||
12 | + { | ||
13 | + libraryName: 'ant-design-vue', | ||
14 | + esModule: true, | ||
15 | + resolveStyle: (name) => { | ||
16 | + return `ant-design-vue/es/${name}/style/index`; | ||
17 | + }, | ||
18 | + }, | ||
19 | + ], | ||
20 | + }); | ||
21 | + return styleImportPlugin; | ||
22 | +} |
build/vite/plugin/svgSprite.ts
0 → 100644
1 | +/** | ||
2 | + * Vite Plugin for fast creating SVG sprites. | ||
3 | + * https://github.com/anncwb/vite-plugin-svg-icons | ||
4 | + */ | ||
5 | + | ||
6 | +import SvgIconsPlugin from 'vite-plugin-svg-icons'; | ||
7 | +import path from 'path'; | ||
8 | + | ||
9 | +export function configSvgIconsPlugin(isBuild: boolean) { | ||
10 | + const svgIconsPlugin = SvgIconsPlugin({ | ||
11 | + iconDirs: [path.resolve(process.cwd(), 'src/assets/icons')], | ||
12 | + svgoOptions: isBuild, | ||
13 | + // default | ||
14 | + symbolId: 'icon-[dir]-[name]', | ||
15 | + }); | ||
16 | + return svgIconsPlugin; | ||
17 | +} |
build/vite/plugin/theme.ts
0 → 100644
1 | +/** | ||
2 | + * Vite plugin for website theme color switching | ||
3 | + * https://github.com/anncwb/vite-plugin-theme | ||
4 | + */ | ||
5 | +import type { Plugin } from 'vite'; | ||
6 | +import path from 'path'; | ||
7 | +import { | ||
8 | + viteThemePlugin, | ||
9 | + antdDarkThemePlugin, | ||
10 | + mixLighten, | ||
11 | + mixDarken, | ||
12 | + tinycolor, | ||
13 | +} from 'vite-plugin-theme'; | ||
14 | +import { getThemeColors, generateColors } from '../../config/themeConfig'; | ||
15 | +import { generateModifyVars } from '../../generate/generateModifyVars'; | ||
16 | + | ||
17 | +export function configThemePlugin(isBuild: boolean): Plugin[] { | ||
18 | + const colors = generateColors({ | ||
19 | + mixDarken, | ||
20 | + mixLighten, | ||
21 | + tinycolor, | ||
22 | + }); | ||
23 | + const plugin = [ | ||
24 | + viteThemePlugin({ | ||
25 | + resolveSelector: (s) => { | ||
26 | + s = s.trim(); | ||
27 | + switch (s) { | ||
28 | + case '.ant-steps-item-process .ant-steps-item-icon > .ant-steps-icon': | ||
29 | + return '.ant-steps-item-icon > .ant-steps-icon'; | ||
30 | + case '.ant-radio-button-wrapper-checked:not(.ant-radio-button-wrapper-disabled)': | ||
31 | + case '.ant-radio-button-wrapper-checked:not(.ant-radio-button-wrapper-disabled):hover': | ||
32 | + case '.ant-radio-button-wrapper-checked:not(.ant-radio-button-wrapper-disabled):active': | ||
33 | + return s; | ||
34 | + case '.ant-steps-item-icon > .ant-steps-icon': | ||
35 | + return s; | ||
36 | + case '.ant-select-item-option-selected:not(.ant-select-item-option-disabled)': | ||
37 | + return s; | ||
38 | + default: | ||
39 | + if (s.indexOf('.ant-btn') >= -1) { | ||
40 | + // 按钮被重新定制过,需要过滤掉class防止覆盖 | ||
41 | + return s; | ||
42 | + } | ||
43 | + } | ||
44 | + return s.startsWith('[data-theme') ? s : `[data-theme] ${s}`; | ||
45 | + }, | ||
46 | + colorVariables: [...getThemeColors(), ...colors], | ||
47 | + }), | ||
48 | + antdDarkThemePlugin({ | ||
49 | + preloadFiles: [ | ||
50 | + path.resolve(process.cwd(), 'node_modules/ant-design-vue/dist/antd.less'), | ||
51 | + //path.resolve(process.cwd(), 'node_modules/ant-design-vue/dist/antd.dark.less'), | ||
52 | + path.resolve(process.cwd(), 'src/design/index.less'), | ||
53 | + ], | ||
54 | + filter: (id) => (isBuild ? !id.endsWith('antd.less') : true), | ||
55 | + // extractCss: false, | ||
56 | + darkModifyVars: { | ||
57 | + ...generateModifyVars(true), | ||
58 | + 'text-color': '#c9d1d9', | ||
59 | + 'primary-1': 'rgb(255 255 255 / 8%)', | ||
60 | + 'text-color-base': '#c9d1d9', | ||
61 | + 'component-background': '#151515', | ||
62 | + 'heading-color': 'rgb(255 255 255 / 65%)', | ||
63 | + // black: '#0e1117', | ||
64 | + // #8b949e | ||
65 | + 'text-color-secondary': '#8b949e', | ||
66 | + 'border-color-base': '#303030', | ||
67 | + // 'border-color-split': '#30363d', | ||
68 | + 'item-active-bg': '#111b26', | ||
69 | + 'app-content-background': 'rgb(255 255 255 / 4%)', | ||
70 | + 'tree-node-selected-bg': '#11263c', | ||
71 | + | ||
72 | + 'alert-success-border-color': '#274916', | ||
73 | + 'alert-success-bg-color': '#162312', | ||
74 | + 'alert-success-icon-color': '#49aa19', | ||
75 | + 'alert-info-border-color': '#153450', | ||
76 | + 'alert-info-bg-color': '#111b26', | ||
77 | + 'alert-info-icon-color': '#177ddc', | ||
78 | + 'alert-warning-border-color': '#594214', | ||
79 | + 'alert-warning-bg-color': '#2b2111', | ||
80 | + 'alert-warning-icon-color': '#d89614', | ||
81 | + 'alert-error-border-color': '#58181c', | ||
82 | + 'alert-error-bg-color': '#2a1215', | ||
83 | + 'alert-error-icon-color': '#a61d24', | ||
84 | + }, | ||
85 | + }), | ||
86 | + ]; | ||
87 | + | ||
88 | + return plugin as unknown as Plugin[]; | ||
89 | +} |
build/vite/plugin/visualizer.ts
0 → 100644
1 | +/** | ||
2 | + * Package file volume analysis | ||
3 | + */ | ||
4 | +import visualizer from 'rollup-plugin-visualizer'; | ||
5 | +import { isReportMode } from '../../utils'; | ||
6 | + | ||
7 | +export function configVisualizerConfig() { | ||
8 | + if (isReportMode()) { | ||
9 | + return visualizer({ | ||
10 | + filename: './node_modules/.cache/visualizer/stats.html', | ||
11 | + open: true, | ||
12 | + gzipSize: true, | ||
13 | + brotliSize: true, | ||
14 | + }) as Plugin; | ||
15 | + } | ||
16 | + return []; | ||
17 | +} |
build/vite/proxy.ts
0 → 100644
1 | +/** | ||
2 | + * Used to parse the .env.development proxy configuration | ||
3 | + */ | ||
4 | +import type { ProxyOptions } from 'vite'; | ||
5 | + | ||
6 | +type ProxyItem = [string, string]; | ||
7 | + | ||
8 | +type ProxyList = ProxyItem[]; | ||
9 | + | ||
10 | +type ProxyTargetList = Record<string, ProxyOptions & { rewrite: (path: string) => string }>; | ||
11 | + | ||
12 | +const httpsRE = /^https:\/\//; | ||
13 | + | ||
14 | +/** | ||
15 | + * Generate proxy | ||
16 | + * @param list | ||
17 | + */ | ||
18 | +export function createProxy(list: ProxyList = []) { | ||
19 | + const ret: ProxyTargetList = {}; | ||
20 | + for (const [prefix, target] of list) { | ||
21 | + const isHttps = httpsRE.test(target); | ||
22 | + | ||
23 | + // https://github.com/http-party/node-http-proxy#options | ||
24 | + ret[prefix] = { | ||
25 | + target: target, | ||
26 | + changeOrigin: true, | ||
27 | + ws: true, | ||
28 | + rewrite: (path) => path.replace(new RegExp(`^${prefix}`), ''), | ||
29 | + // https is require secure=false | ||
30 | + ...(isHttps ? { secure: false } : {}), | ||
31 | + }; | ||
32 | + } | ||
33 | + return ret; | ||
34 | +} |
index.html
0 → 100644
1 | +<!DOCTYPE html> | ||
2 | +<html lang="en" id="htmlRoot"> | ||
3 | + <head> | ||
4 | + <meta charset="UTF-8" /> | ||
5 | + <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" /> | ||
6 | + <meta name="renderer" content="webkit" /> | ||
7 | + <meta | ||
8 | + name="viewport" | ||
9 | + content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=0" | ||
10 | + /> | ||
11 | + | ||
12 | + <title><%= title %></title> | ||
13 | + <link rel="icon" href="/favicon.ico" /> | ||
14 | + </head> | ||
15 | + <body> | ||
16 | + <script> | ||
17 | + (() => { | ||
18 | + var htmlRoot = document.getElementById('htmlRoot'); | ||
19 | + var theme = window.localStorage.getItem('__APP__DARK__MODE__'); | ||
20 | + if (htmlRoot && theme) { | ||
21 | + htmlRoot.setAttribute('data-theme', theme); | ||
22 | + theme = htmlRoot = null; | ||
23 | + } | ||
24 | + })(); | ||
25 | + </script> | ||
26 | + <div id="app"> | ||
27 | + <style> | ||
28 | + html[data-theme='dark'] .app-loading { | ||
29 | + background-color: #2c344a; | ||
30 | + } | ||
31 | + | ||
32 | + html[data-theme='dark'] .app-loading .app-loading-title { | ||
33 | + color: rgba(255, 255, 255, 0.85); | ||
34 | + } | ||
35 | + | ||
36 | + .app-loading { | ||
37 | + display: flex; | ||
38 | + width: 100%; | ||
39 | + height: 100%; | ||
40 | + justify-content: center; | ||
41 | + align-items: center; | ||
42 | + flex-direction: column; | ||
43 | + background-color: #f4f7f9; | ||
44 | + } | ||
45 | + | ||
46 | + .app-loading .app-loading-wrap { | ||
47 | + position: absolute; | ||
48 | + top: 50%; | ||
49 | + left: 50%; | ||
50 | + display: flex; | ||
51 | + -webkit-transform: translate3d(-50%, -50%, 0); | ||
52 | + transform: translate3d(-50%, -50%, 0); | ||
53 | + justify-content: center; | ||
54 | + align-items: center; | ||
55 | + flex-direction: column; | ||
56 | + } | ||
57 | + | ||
58 | + .app-loading .dots { | ||
59 | + display: flex; | ||
60 | + padding: 98px; | ||
61 | + justify-content: center; | ||
62 | + align-items: center; | ||
63 | + } | ||
64 | + | ||
65 | + .app-loading .app-loading-title { | ||
66 | + display: flex; | ||
67 | + margin-top: 30px; | ||
68 | + font-size: 30px; | ||
69 | + color: rgba(0, 0, 0, 0.85); | ||
70 | + justify-content: center; | ||
71 | + align-items: center; | ||
72 | + } | ||
73 | + | ||
74 | + .app-loading .app-loading-logo { | ||
75 | + display: block; | ||
76 | + width: 90px; | ||
77 | + margin: 0 auto; | ||
78 | + margin-bottom: 20px; | ||
79 | + } | ||
80 | + | ||
81 | + .dot { | ||
82 | + position: relative; | ||
83 | + display: inline-block; | ||
84 | + width: 48px; | ||
85 | + height: 48px; | ||
86 | + margin-top: 30px; | ||
87 | + font-size: 32px; | ||
88 | + transform: rotate(45deg); | ||
89 | + box-sizing: border-box; | ||
90 | + animation: antRotate 1.2s infinite linear; | ||
91 | + } | ||
92 | + | ||
93 | + .dot i { | ||
94 | + position: absolute; | ||
95 | + display: block; | ||
96 | + width: 20px; | ||
97 | + height: 20px; | ||
98 | + background-color: #0065cc; | ||
99 | + border-radius: 100%; | ||
100 | + opacity: 0.3; | ||
101 | + transform: scale(0.75); | ||
102 | + animation: antSpinMove 1s infinite linear alternate; | ||
103 | + transform-origin: 50% 50%; | ||
104 | + } | ||
105 | + | ||
106 | + .dot i:nth-child(1) { | ||
107 | + top: 0; | ||
108 | + left: 0; | ||
109 | + } | ||
110 | + | ||
111 | + .dot i:nth-child(2) { | ||
112 | + top: 0; | ||
113 | + right: 0; | ||
114 | + -webkit-animation-delay: 0.4s; | ||
115 | + animation-delay: 0.4s; | ||
116 | + } | ||
117 | + | ||
118 | + .dot i:nth-child(3) { | ||
119 | + right: 0; | ||
120 | + bottom: 0; | ||
121 | + -webkit-animation-delay: 0.8s; | ||
122 | + animation-delay: 0.8s; | ||
123 | + } | ||
124 | + | ||
125 | + .dot i:nth-child(4) { | ||
126 | + bottom: 0; | ||
127 | + left: 0; | ||
128 | + -webkit-animation-delay: 1.2s; | ||
129 | + animation-delay: 1.2s; | ||
130 | + } | ||
131 | + @keyframes antRotate { | ||
132 | + to { | ||
133 | + -webkit-transform: rotate(405deg); | ||
134 | + transform: rotate(405deg); | ||
135 | + } | ||
136 | + } | ||
137 | + @-webkit-keyframes antRotate { | ||
138 | + to { | ||
139 | + -webkit-transform: rotate(405deg); | ||
140 | + transform: rotate(405deg); | ||
141 | + } | ||
142 | + } | ||
143 | + @keyframes antSpinMove { | ||
144 | + to { | ||
145 | + opacity: 1; | ||
146 | + } | ||
147 | + } | ||
148 | + @-webkit-keyframes antSpinMove { | ||
149 | + to { | ||
150 | + opacity: 1; | ||
151 | + } | ||
152 | + } | ||
153 | + </style> | ||
154 | + <div class="app-loading"> | ||
155 | + <div class="app-loading-wrap"> | ||
156 | + <img src="/resource/img/logo.png" class="app-loading-logo" alt="Logo" /> | ||
157 | + <div class="app-loading-dots"> | ||
158 | + <span class="dot dot-spin"><i></i><i></i><i></i><i></i></span> | ||
159 | + </div> | ||
160 | + <div class="app-loading-title"><%= title %></div> | ||
161 | + </div> | ||
162 | + </div> | ||
163 | + </div> | ||
164 | + <script type="module" src="/src/main.ts"></script> | ||
165 | + </body> | ||
166 | +</html> |
jest.config.mjs
0 → 100644
1 | +export default { | ||
2 | + preset: 'ts-jest', | ||
3 | + roots: ['<rootDir>/tests/'], | ||
4 | + clearMocks: true, | ||
5 | + moduleDirectories: ['node_modules', 'src'], | ||
6 | + moduleFileExtensions: ['js', 'ts', 'vue', 'tsx', 'jsx', 'json', 'node'], | ||
7 | + modulePaths: ['<rootDir>/src', '<rootDir>/node_modules'], | ||
8 | + testMatch: [ | ||
9 | + '**/tests/**/*.[jt]s?(x)', | ||
10 | + '**/?(*.)+(spec|test).[tj]s?(x)', | ||
11 | + '(/__tests__/.*|(\\.|/)(test|spec))\\.(js|ts)$', | ||
12 | + ], | ||
13 | + testPathIgnorePatterns: [ | ||
14 | + '<rootDir>/tests/server/', | ||
15 | + '<rootDir>/tests/__mocks__/', | ||
16 | + '/node_modules/', | ||
17 | + ], | ||
18 | + transform: { | ||
19 | + '^.+\\.tsx?$': 'ts-jest', | ||
20 | + }, | ||
21 | + transformIgnorePatterns: ['<rootDir>/tests/__mocks__/', '/node_modules/'], | ||
22 | + // A map from regular expressions to module names that allow to stub out resources with a single module | ||
23 | + moduleNameMapper: { | ||
24 | + '\\.(vs|fs|vert|frag|glsl|jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$': | ||
25 | + '<rootDir>/tests/__mocks__/fileMock.ts', | ||
26 | + '\\.(sass|s?css|less)$': '<rootDir>/tests/__mocks__/styleMock.ts', | ||
27 | + '\\?worker$': '<rootDir>/tests/__mocks__/workerMock.ts', | ||
28 | + '^/@/(.*)$': '<rootDir>/src/$1', | ||
29 | + }, | ||
30 | + testEnvironment: 'jsdom', | ||
31 | + verbose: true, | ||
32 | + collectCoverage: false, | ||
33 | + coverageDirectory: 'coverage', | ||
34 | + collectCoverageFrom: ['src/**/*.{js,ts,vue}'], | ||
35 | + coveragePathIgnorePatterns: ['^.+\\.d\\.ts$'], | ||
36 | +}; |
mock/_createProductionServer.ts
0 → 100644
1 | +import { createProdMockServer } from 'vite-plugin-mock/es/createProdMockServer'; | ||
2 | + | ||
3 | +const modules = import.meta.globEager('./**/*.ts'); | ||
4 | + | ||
5 | +const mockModules: any[] = []; | ||
6 | +Object.keys(modules).forEach((key) => { | ||
7 | + if (key.includes('/_')) { | ||
8 | + return; | ||
9 | + } | ||
10 | + mockModules.push(...modules[key].default); | ||
11 | +}); | ||
12 | + | ||
13 | +/** | ||
14 | + * Used in a production environment. Need to manually import all modules | ||
15 | + */ | ||
16 | +export function setupProdMockServer() { | ||
17 | + createProdMockServer(mockModules); | ||
18 | +} |
mock/_util.ts
0 → 100644
1 | +// Interface data format used to return a unified format | ||
2 | + | ||
3 | +export function resultSuccess<T = Recordable>(result: T, { message = 'ok' } = {}) { | ||
4 | + return { | ||
5 | + code: 0, | ||
6 | + result, | ||
7 | + message, | ||
8 | + type: 'success', | ||
9 | + }; | ||
10 | +} | ||
11 | + | ||
12 | +export function resultPageSuccess<T = any>( | ||
13 | + page: number, | ||
14 | + pageSize: number, | ||
15 | + list: T[], | ||
16 | + { message = 'ok' } = {} | ||
17 | +) { | ||
18 | + const pageData = pagination(page, pageSize, list); | ||
19 | + | ||
20 | + return { | ||
21 | + ...resultSuccess({ | ||
22 | + items: pageData, | ||
23 | + total: list.length, | ||
24 | + }), | ||
25 | + message, | ||
26 | + }; | ||
27 | +} | ||
28 | + | ||
29 | +export function resultError(message = 'Request failed', { code = -1, result = null } = {}) { | ||
30 | + return { | ||
31 | + code, | ||
32 | + result, | ||
33 | + message, | ||
34 | + type: 'error', | ||
35 | + }; | ||
36 | +} | ||
37 | + | ||
38 | +export function pagination<T = any>(pageNo: number, pageSize: number, array: T[]): T[] { | ||
39 | + const offset = (pageNo - 1) * Number(pageSize); | ||
40 | + const ret = | ||
41 | + offset + Number(pageSize) >= array.length | ||
42 | + ? array.slice(offset, array.length) | ||
43 | + : array.slice(offset, offset + Number(pageSize)); | ||
44 | + return ret; | ||
45 | +} | ||
46 | + | ||
47 | +export interface requestParams { | ||
48 | + method: string; | ||
49 | + body: any; | ||
50 | + headers?: { authorization?: string }; | ||
51 | + query: any; | ||
52 | +} | ||
53 | + | ||
54 | +/** | ||
55 | + * @description 本函数用于从request数据中获取token,请根据项目的实际情况修改 | ||
56 | + * | ||
57 | + */ | ||
58 | +export function getRequestToken({ headers }: requestParams): string | undefined { | ||
59 | + return headers?.authorization; | ||
60 | +} |
mock/demo/account.ts
0 → 100644
1 | +import { MockMethod } from 'vite-plugin-mock'; | ||
2 | +import { resultSuccess, resultError } from '../_util'; | ||
3 | + | ||
4 | +const userInfo = { | ||
5 | + name: 'Vben', | ||
6 | + userid: '00000001', | ||
7 | + email: 'test@gmail.com', | ||
8 | + signature: '海纳百川,有容乃大', | ||
9 | + introduction: '微笑着,努力着,欣赏着', | ||
10 | + title: '交互专家', | ||
11 | + group: '某某某事业群-某某平台部-某某技术部-UED', | ||
12 | + tags: [ | ||
13 | + { | ||
14 | + key: '0', | ||
15 | + label: '很有想法的', | ||
16 | + }, | ||
17 | + { | ||
18 | + key: '1', | ||
19 | + label: '专注设计', | ||
20 | + }, | ||
21 | + { | ||
22 | + key: '2', | ||
23 | + label: '辣~', | ||
24 | + }, | ||
25 | + { | ||
26 | + key: '3', | ||
27 | + label: '大长腿', | ||
28 | + }, | ||
29 | + { | ||
30 | + key: '4', | ||
31 | + label: '川妹子', | ||
32 | + }, | ||
33 | + { | ||
34 | + key: '5', | ||
35 | + label: '海纳百川', | ||
36 | + }, | ||
37 | + ], | ||
38 | + notifyCount: 12, | ||
39 | + unreadCount: 11, | ||
40 | + country: 'China', | ||
41 | + address: 'Xiamen City 77', | ||
42 | + phone: '0592-268888888', | ||
43 | +}; | ||
44 | + | ||
45 | +export default [ | ||
46 | + { | ||
47 | + url: '/basic-api/account/getAccountInfo', | ||
48 | + timeout: 1000, | ||
49 | + method: 'get', | ||
50 | + response: () => { | ||
51 | + return resultSuccess(userInfo); | ||
52 | + }, | ||
53 | + }, | ||
54 | + { | ||
55 | + url: '/basic-api/user/sessionTimeout', | ||
56 | + method: 'post', | ||
57 | + statusCode: 401, | ||
58 | + response: () => { | ||
59 | + return resultError(); | ||
60 | + }, | ||
61 | + }, | ||
62 | +] as MockMethod[]; |
mock/demo/select-demo.ts
0 → 100644
1 | +import { MockMethod } from 'vite-plugin-mock'; | ||
2 | +import { resultSuccess } from '../_util'; | ||
3 | + | ||
4 | +const demoList = (keyword) => { | ||
5 | + const result = { | ||
6 | + list: [] as any[], | ||
7 | + }; | ||
8 | + for (let index = 0; index < 20; index++) { | ||
9 | + result.list.push({ | ||
10 | + name: `${keyword ?? ''}选项${index}`, | ||
11 | + id: `${index}`, | ||
12 | + }); | ||
13 | + } | ||
14 | + return result; | ||
15 | +}; | ||
16 | + | ||
17 | +export default [ | ||
18 | + { | ||
19 | + url: '/basic-api/select/getDemoOptions', | ||
20 | + timeout: 1000, | ||
21 | + method: 'get', | ||
22 | + response: ({ query }) => { | ||
23 | + const { keyword } = query; | ||
24 | + console.log(keyword); | ||
25 | + return resultSuccess(demoList(keyword)); | ||
26 | + }, | ||
27 | + }, | ||
28 | +] as MockMethod[]; |
mock/demo/system.ts
0 → 100644
1 | +import { MockMethod } from 'vite-plugin-mock'; | ||
2 | +import { resultError, resultPageSuccess, resultSuccess } from '../_util'; | ||
3 | + | ||
4 | +const accountList = (() => { | ||
5 | + const result: any[] = []; | ||
6 | + for (let index = 0; index < 20; index++) { | ||
7 | + result.push({ | ||
8 | + id: `${index}`, | ||
9 | + account: '@first', | ||
10 | + email: '@email', | ||
11 | + nickname: '@cname()', | ||
12 | + role: '@first', | ||
13 | + createTime: '@datetime', | ||
14 | + remark: '@cword(10,20)', | ||
15 | + 'status|1': ['0', '1'], | ||
16 | + }); | ||
17 | + } | ||
18 | + return result; | ||
19 | +})(); | ||
20 | + | ||
21 | +const roleList = (() => { | ||
22 | + const result: any[] = []; | ||
23 | + for (let index = 0; index < 4; index++) { | ||
24 | + result.push({ | ||
25 | + id: index + 1, | ||
26 | + orderNo: `${index + 1}`, | ||
27 | + roleName: ['超级管理员', '管理员', '文章管理员', '普通用户'][index], | ||
28 | + roleValue: '@first', | ||
29 | + createTime: '@datetime', | ||
30 | + remark: '@cword(10,20)', | ||
31 | + menu: [['0', '1', '2'], ['0', '1'], ['0', '2'], ['2']][index], | ||
32 | + 'status|1': ['0', '1'], | ||
33 | + }); | ||
34 | + } | ||
35 | + return result; | ||
36 | +})(); | ||
37 | + | ||
38 | +const deptList = (() => { | ||
39 | + const result: any[] = []; | ||
40 | + for (let index = 0; index < 3; index++) { | ||
41 | + result.push({ | ||
42 | + id: `${index}`, | ||
43 | + deptName: ['华东分部', '华南分部', '西北分部'][index], | ||
44 | + orderNo: index + 1, | ||
45 | + createTime: '@datetime', | ||
46 | + remark: '@cword(10,20)', | ||
47 | + 'status|1': ['0', '0', '1'], | ||
48 | + children: (() => { | ||
49 | + const children: any[] = []; | ||
50 | + for (let j = 0; j < 4; j++) { | ||
51 | + children.push({ | ||
52 | + id: `${index}-${j}`, | ||
53 | + deptName: ['研发部', '市场部', '商务部', '财务部'][j], | ||
54 | + orderNo: j + 1, | ||
55 | + createTime: '@datetime', | ||
56 | + remark: '@cword(10,20)', | ||
57 | + 'status|1': ['0', '1'], | ||
58 | + parentDept: `${index}`, | ||
59 | + children: undefined, | ||
60 | + }); | ||
61 | + } | ||
62 | + return children; | ||
63 | + })(), | ||
64 | + }); | ||
65 | + } | ||
66 | + return result; | ||
67 | +})(); | ||
68 | + | ||
69 | +const menuList = (() => { | ||
70 | + const result: any[] = []; | ||
71 | + for (let index = 0; index < 3; index++) { | ||
72 | + result.push({ | ||
73 | + id: `${index}`, | ||
74 | + icon: ['ion:layers-outline', 'ion:git-compare-outline', 'ion:tv-outline'][index], | ||
75 | + component: 'LAYOUT', | ||
76 | + type: '0', | ||
77 | + menuName: ['Dashboard', '权限管理', '功能'][index], | ||
78 | + permission: '', | ||
79 | + orderNo: index + 1, | ||
80 | + createTime: '@datetime', | ||
81 | + 'status|1': ['0', '0', '1'], | ||
82 | + children: (() => { | ||
83 | + const children: any[] = []; | ||
84 | + for (let j = 0; j < 4; j++) { | ||
85 | + children.push({ | ||
86 | + id: `${index}-${j}`, | ||
87 | + type: '1', | ||
88 | + menuName: ['菜单1', '菜单2', '菜单3', '菜单4'][j], | ||
89 | + icon: 'ion:document', | ||
90 | + permission: ['menu1:view', 'menu2:add', 'menu3:update', 'menu4:del'][index], | ||
91 | + component: [ | ||
92 | + '/dashboard/welcome/index', | ||
93 | + '/dashboard/analysis/index', | ||
94 | + '/dashboard/workbench/index', | ||
95 | + '/dashboard/test/index', | ||
96 | + ][j], | ||
97 | + orderNo: j + 1, | ||
98 | + createTime: '@datetime', | ||
99 | + 'status|1': ['0', '1'], | ||
100 | + parentMenu: `${index}`, | ||
101 | + children: (() => { | ||
102 | + const children: any[] = []; | ||
103 | + for (let k = 0; k < 4; k++) { | ||
104 | + children.push({ | ||
105 | + id: `${index}-${j}-${k}`, | ||
106 | + type: '2', | ||
107 | + menuName: '按钮' + (j + 1) + '-' + (k + 1), | ||
108 | + icon: '', | ||
109 | + permission: | ||
110 | + ['menu1:view', 'menu2:add', 'menu3:update', 'menu4:del'][index] + | ||
111 | + ':btn' + | ||
112 | + (k + 1), | ||
113 | + component: [ | ||
114 | + '/dashboard/welcome/index', | ||
115 | + '/dashboard/analysis/index', | ||
116 | + '/dashboard/workbench/index', | ||
117 | + '/dashboard/test/index', | ||
118 | + ][j], | ||
119 | + orderNo: j + 1, | ||
120 | + createTime: '@datetime', | ||
121 | + 'status|1': ['0', '1'], | ||
122 | + parentMenu: `${index}-${j}`, | ||
123 | + children: undefined, | ||
124 | + }); | ||
125 | + } | ||
126 | + return children; | ||
127 | + })(), | ||
128 | + }); | ||
129 | + } | ||
130 | + return children; | ||
131 | + })(), | ||
132 | + }); | ||
133 | + } | ||
134 | + return result; | ||
135 | +})(); | ||
136 | + | ||
137 | +export default [ | ||
138 | + { | ||
139 | + url: '/basic-api/system/getAccountList', | ||
140 | + timeout: 100, | ||
141 | + method: 'get', | ||
142 | + response: ({ query }) => { | ||
143 | + const { page = 1, pageSize = 20 } = query; | ||
144 | + return resultPageSuccess(page, pageSize, accountList); | ||
145 | + }, | ||
146 | + }, | ||
147 | + { | ||
148 | + url: '/basic-api/system/getRoleListByPage', | ||
149 | + timeout: 100, | ||
150 | + method: 'get', | ||
151 | + response: ({ query }) => { | ||
152 | + const { page = 1, pageSize = 20 } = query; | ||
153 | + return resultPageSuccess(page, pageSize, roleList); | ||
154 | + }, | ||
155 | + }, | ||
156 | + { | ||
157 | + url: '/basic-api/system/setRoleStatus', | ||
158 | + timeout: 500, | ||
159 | + method: 'post', | ||
160 | + response: ({ query }) => { | ||
161 | + const { id, status } = query; | ||
162 | + return resultSuccess({ id, status }); | ||
163 | + }, | ||
164 | + }, | ||
165 | + { | ||
166 | + url: '/basic-api/system/getAllRoleList', | ||
167 | + timeout: 100, | ||
168 | + method: 'get', | ||
169 | + response: () => { | ||
170 | + return resultSuccess(roleList); | ||
171 | + }, | ||
172 | + }, | ||
173 | + { | ||
174 | + url: '/basic-api/system/getDeptList', | ||
175 | + timeout: 100, | ||
176 | + method: 'get', | ||
177 | + response: () => { | ||
178 | + return resultSuccess(deptList); | ||
179 | + }, | ||
180 | + }, | ||
181 | + { | ||
182 | + url: '/basic-api/system/getMenuList', | ||
183 | + timeout: 100, | ||
184 | + method: 'get', | ||
185 | + response: () => { | ||
186 | + return resultSuccess(menuList); | ||
187 | + }, | ||
188 | + }, | ||
189 | + { | ||
190 | + url: '/basic-api/system/accountExist', | ||
191 | + timeout: 500, | ||
192 | + method: 'post', | ||
193 | + response: ({ body }) => { | ||
194 | + const { account } = body || {}; | ||
195 | + if (account && account.indexOf('admin') !== -1) { | ||
196 | + return resultError('该字段不能包含admin'); | ||
197 | + } else { | ||
198 | + return resultSuccess(`${account} can use`); | ||
199 | + } | ||
200 | + }, | ||
201 | + }, | ||
202 | +] as MockMethod[]; |
mock/demo/table-demo.ts
0 → 100644
1 | +import { MockMethod } from 'vite-plugin-mock'; | ||
2 | +import { Random } from 'mockjs'; | ||
3 | +import { resultPageSuccess } from '../_util'; | ||
4 | + | ||
5 | +function getRandomPics(count = 10): string[] { | ||
6 | + const arr: string[] = []; | ||
7 | + for (let i = 0; i < count; i++) { | ||
8 | + arr.push(Random.image('800x600', Random.color(), Random.color(), Random.title())); | ||
9 | + } | ||
10 | + return arr; | ||
11 | +} | ||
12 | + | ||
13 | +const demoList = (() => { | ||
14 | + const result: any[] = []; | ||
15 | + for (let index = 0; index < 60; index++) { | ||
16 | + result.push({ | ||
17 | + id: `${index}`, | ||
18 | + beginTime: '@datetime', | ||
19 | + endTime: '@datetime', | ||
20 | + address: '@city()', | ||
21 | + name: '@cname()', | ||
22 | + name1: '@cname()', | ||
23 | + name2: '@cname()', | ||
24 | + name3: '@cname()', | ||
25 | + name4: '@cname()', | ||
26 | + name5: '@cname()', | ||
27 | + name6: '@cname()', | ||
28 | + name7: '@cname()', | ||
29 | + name8: '@cname()', | ||
30 | + avatar: Random.image('400x400', Random.color(), Random.color(), Random.first()), | ||
31 | + imgArr: getRandomPics(Math.ceil(Math.random() * 3) + 1), | ||
32 | + imgs: getRandomPics(Math.ceil(Math.random() * 3) + 1), | ||
33 | + date: `@date('yyyy-MM-dd')`, | ||
34 | + time: `@time('HH:mm')`, | ||
35 | + 'no|100000-10000000': 100000, | ||
36 | + 'status|1': ['normal', 'enable', 'disable'], | ||
37 | + }); | ||
38 | + } | ||
39 | + return result; | ||
40 | +})(); | ||
41 | + | ||
42 | +export default [ | ||
43 | + { | ||
44 | + url: '/basic-api/table/getDemoList', | ||
45 | + timeout: 100, | ||
46 | + method: 'get', | ||
47 | + response: ({ query }) => { | ||
48 | + const { page = 1, pageSize = 20 } = query; | ||
49 | + return resultPageSuccess(page, pageSize, demoList); | ||
50 | + }, | ||
51 | + }, | ||
52 | +] as MockMethod[]; |
mock/demo/tree-demo.ts
0 → 100644
1 | +import { MockMethod } from 'vite-plugin-mock'; | ||
2 | +import { resultSuccess } from '../_util'; | ||
3 | + | ||
4 | +const demoTreeList = (keyword) => { | ||
5 | + const result = { | ||
6 | + list: [] as Recordable[], | ||
7 | + }; | ||
8 | + for (let index = 0; index < 5; index++) { | ||
9 | + const children: Recordable[] = []; | ||
10 | + for (let j = 0; j < 3; j++) { | ||
11 | + children.push({ | ||
12 | + title: `${keyword ?? ''}选项${index}-${j}`, | ||
13 | + value: `${index}-${j}`, | ||
14 | + key: `${index}-${j}`, | ||
15 | + }); | ||
16 | + } | ||
17 | + result.list.push({ | ||
18 | + title: `${keyword ?? ''}选项${index}`, | ||
19 | + value: `${index}`, | ||
20 | + key: `${index}`, | ||
21 | + children, | ||
22 | + }); | ||
23 | + } | ||
24 | + return result; | ||
25 | +}; | ||
26 | + | ||
27 | +export default [ | ||
28 | + { | ||
29 | + url: '/basic-api/tree/getDemoOptions', | ||
30 | + timeout: 1000, | ||
31 | + method: 'get', | ||
32 | + response: ({ query }) => { | ||
33 | + const { keyword } = query; | ||
34 | + console.log(keyword); | ||
35 | + return resultSuccess(demoTreeList(keyword)); | ||
36 | + }, | ||
37 | + }, | ||
38 | +] as MockMethod[]; |
mock/sys/menu.ts
0 → 100644
1 | +import { resultSuccess, resultError, getRequestToken, requestParams } from '../_util'; | ||
2 | +import { MockMethod } from 'vite-plugin-mock'; | ||
3 | +import { createFakeUserList } from './user'; | ||
4 | + | ||
5 | +// single | ||
6 | +const dashboardRoute = { | ||
7 | + path: '/dashboard', | ||
8 | + name: 'Dashboard', | ||
9 | + component: 'LAYOUT', | ||
10 | + redirect: '/dashboard/analysis', | ||
11 | + meta: { | ||
12 | + title: 'routes.dashboard.dashboard', | ||
13 | + hideChildrenInMenu: true, | ||
14 | + icon: 'bx:bx-home', | ||
15 | + }, | ||
16 | + children: [ | ||
17 | + { | ||
18 | + path: 'analysis', | ||
19 | + name: 'Analysis', | ||
20 | + component: '/dashboard/analysis/index', | ||
21 | + meta: { | ||
22 | + hideMenu: true, | ||
23 | + hideBreadcrumb: true, | ||
24 | + title: 'routes.dashboard.analysis', | ||
25 | + currentActiveMenu: '/dashboard', | ||
26 | + icon: 'bx:bx-home', | ||
27 | + }, | ||
28 | + }, | ||
29 | + { | ||
30 | + path: 'workbench', | ||
31 | + name: 'Workbench', | ||
32 | + component: '/dashboard/workbench/index', | ||
33 | + meta: { | ||
34 | + hideMenu: true, | ||
35 | + hideBreadcrumb: true, | ||
36 | + title: 'routes.dashboard.workbench', | ||
37 | + currentActiveMenu: '/dashboard', | ||
38 | + icon: 'bx:bx-home', | ||
39 | + }, | ||
40 | + }, | ||
41 | + ], | ||
42 | +}; | ||
43 | + | ||
44 | +const backRoute = { | ||
45 | + path: 'back', | ||
46 | + name: 'PermissionBackDemo', | ||
47 | + meta: { | ||
48 | + title: 'routes.demo.permission.back', | ||
49 | + }, | ||
50 | + | ||
51 | + children: [ | ||
52 | + { | ||
53 | + path: 'page', | ||
54 | + name: 'BackAuthPage', | ||
55 | + component: '/demo/permission/back/index', | ||
56 | + meta: { | ||
57 | + title: 'routes.demo.permission.backPage', | ||
58 | + }, | ||
59 | + }, | ||
60 | + { | ||
61 | + path: 'btn', | ||
62 | + name: 'BackAuthBtn', | ||
63 | + component: '/demo/permission/back/Btn', | ||
64 | + meta: { | ||
65 | + title: 'routes.demo.permission.backBtn', | ||
66 | + }, | ||
67 | + }, | ||
68 | + ], | ||
69 | +}; | ||
70 | + | ||
71 | +const authRoute = { | ||
72 | + path: '/permission', | ||
73 | + name: 'Permission', | ||
74 | + component: 'LAYOUT', | ||
75 | + redirect: '/permission/front/page', | ||
76 | + meta: { | ||
77 | + icon: 'carbon:user-role', | ||
78 | + title: 'routes.demo.permission.permission', | ||
79 | + }, | ||
80 | + children: [backRoute], | ||
81 | +}; | ||
82 | + | ||
83 | +const levelRoute = { | ||
84 | + path: '/level', | ||
85 | + name: 'Level', | ||
86 | + component: 'LAYOUT', | ||
87 | + redirect: '/level/menu1/menu1-1', | ||
88 | + meta: { | ||
89 | + icon: 'carbon:user-role', | ||
90 | + title: 'routes.demo.level.level', | ||
91 | + }, | ||
92 | + | ||
93 | + children: [ | ||
94 | + { | ||
95 | + path: 'menu1', | ||
96 | + name: 'Menu1Demo', | ||
97 | + meta: { | ||
98 | + title: 'Menu1', | ||
99 | + }, | ||
100 | + children: [ | ||
101 | + { | ||
102 | + path: 'menu1-1', | ||
103 | + name: 'Menu11Demo', | ||
104 | + meta: { | ||
105 | + title: 'Menu1-1', | ||
106 | + }, | ||
107 | + children: [ | ||
108 | + { | ||
109 | + path: 'menu1-1-1', | ||
110 | + name: 'Menu111Demo', | ||
111 | + component: '/demo/level/Menu111', | ||
112 | + meta: { | ||
113 | + title: 'Menu111', | ||
114 | + }, | ||
115 | + }, | ||
116 | + ], | ||
117 | + }, | ||
118 | + { | ||
119 | + path: 'menu1-2', | ||
120 | + name: 'Menu12Demo', | ||
121 | + component: '/demo/level/Menu12', | ||
122 | + meta: { | ||
123 | + title: 'Menu1-2', | ||
124 | + }, | ||
125 | + }, | ||
126 | + ], | ||
127 | + }, | ||
128 | + { | ||
129 | + path: 'menu2', | ||
130 | + name: 'Menu2Demo', | ||
131 | + component: '/demo/level/Menu2', | ||
132 | + meta: { | ||
133 | + title: 'Menu2', | ||
134 | + }, | ||
135 | + }, | ||
136 | + ], | ||
137 | +}; | ||
138 | + | ||
139 | +const sysRoute = { | ||
140 | + path: '/system', | ||
141 | + name: 'System', | ||
142 | + component: 'LAYOUT', | ||
143 | + redirect: '/system/account', | ||
144 | + meta: { | ||
145 | + icon: 'ion:settings-outline', | ||
146 | + title: 'routes.demo.system.moduleName', | ||
147 | + }, | ||
148 | + children: [ | ||
149 | + { | ||
150 | + path: 'account', | ||
151 | + name: 'AccountManagement', | ||
152 | + meta: { | ||
153 | + title: 'routes.demo.system.account', | ||
154 | + ignoreKeepAlive: true, | ||
155 | + }, | ||
156 | + component: '/demo/system/account/index', | ||
157 | + }, | ||
158 | + { | ||
159 | + path: 'account_detail/:id', | ||
160 | + name: 'AccountDetail', | ||
161 | + meta: { | ||
162 | + hideMenu: true, | ||
163 | + title: 'routes.demo.system.account_detail', | ||
164 | + ignoreKeepAlive: true, | ||
165 | + showMenu: false, | ||
166 | + currentActiveMenu: '/system/account', | ||
167 | + }, | ||
168 | + component: '/demo/system/account/AccountDetail', | ||
169 | + }, | ||
170 | + { | ||
171 | + path: 'role', | ||
172 | + name: 'RoleManagement', | ||
173 | + meta: { | ||
174 | + title: 'routes.demo.system.role', | ||
175 | + ignoreKeepAlive: true, | ||
176 | + }, | ||
177 | + component: '/demo/system/role/index', | ||
178 | + }, | ||
179 | + | ||
180 | + { | ||
181 | + path: 'menu', | ||
182 | + name: 'MenuManagement', | ||
183 | + meta: { | ||
184 | + title: 'routes.demo.system.menu', | ||
185 | + ignoreKeepAlive: true, | ||
186 | + }, | ||
187 | + component: '/demo/system/menu/index', | ||
188 | + }, | ||
189 | + { | ||
190 | + path: 'dept', | ||
191 | + name: 'DeptManagement', | ||
192 | + meta: { | ||
193 | + title: 'routes.demo.system.dept', | ||
194 | + ignoreKeepAlive: true, | ||
195 | + }, | ||
196 | + component: '/demo/system/dept/index', | ||
197 | + }, | ||
198 | + { | ||
199 | + path: 'changePassword', | ||
200 | + name: 'ChangePassword', | ||
201 | + meta: { | ||
202 | + title: 'routes.demo.system.password', | ||
203 | + ignoreKeepAlive: true, | ||
204 | + }, | ||
205 | + component: '/demo/system/password/index', | ||
206 | + }, | ||
207 | + ], | ||
208 | +}; | ||
209 | + | ||
210 | +const linkRoute = { | ||
211 | + path: '/link', | ||
212 | + name: 'Link', | ||
213 | + component: 'LAYOUT', | ||
214 | + meta: { | ||
215 | + icon: 'ion:tv-outline', | ||
216 | + title: 'routes.demo.iframe.frame', | ||
217 | + }, | ||
218 | + children: [ | ||
219 | + { | ||
220 | + path: 'doc', | ||
221 | + name: 'Doc', | ||
222 | + meta: { | ||
223 | + title: 'routes.demo.iframe.doc', | ||
224 | + frameSrc: 'https://vvbin.cn/doc-next/', | ||
225 | + }, | ||
226 | + }, | ||
227 | + { | ||
228 | + path: 'https://vvbin.cn/doc-next/', | ||
229 | + name: 'DocExternal', | ||
230 | + component: 'LAYOUT', | ||
231 | + meta: { | ||
232 | + title: 'routes.demo.iframe.docExternal', | ||
233 | + }, | ||
234 | + }, | ||
235 | + ], | ||
236 | +}; | ||
237 | + | ||
238 | +export default [ | ||
239 | + { | ||
240 | + url: '/basic-api/getMenuList', | ||
241 | + timeout: 1000, | ||
242 | + method: 'get', | ||
243 | + response: (request: requestParams) => { | ||
244 | + const token = getRequestToken(request); | ||
245 | + if (!token) { | ||
246 | + return resultError('Invalid token!'); | ||
247 | + } | ||
248 | + const checkUser = createFakeUserList().find((item) => item.token === token); | ||
249 | + if (!checkUser) { | ||
250 | + return resultError('Invalid user token!'); | ||
251 | + } | ||
252 | + const id = checkUser.userId; | ||
253 | + let menu: Object[]; | ||
254 | + switch (id) { | ||
255 | + case '1': | ||
256 | + dashboardRoute.redirect = dashboardRoute.path + '/' + dashboardRoute.children[0].path; | ||
257 | + menu = [dashboardRoute, authRoute, levelRoute, sysRoute, linkRoute]; | ||
258 | + break; | ||
259 | + case '2': | ||
260 | + dashboardRoute.redirect = dashboardRoute.path + '/' + dashboardRoute.children[1].path; | ||
261 | + menu = [dashboardRoute, authRoute, levelRoute, linkRoute]; | ||
262 | + break; | ||
263 | + default: | ||
264 | + menu = []; | ||
265 | + } | ||
266 | + | ||
267 | + return resultSuccess(menu); | ||
268 | + }, | ||
269 | + }, | ||
270 | +] as MockMethod[]; |
mock/sys/user.ts
0 → 100644
1 | +import { MockMethod } from 'vite-plugin-mock'; | ||
2 | +import { resultError, resultSuccess, getRequestToken, requestParams } from '../_util'; | ||
3 | + | ||
4 | +export function createFakeUserList() { | ||
5 | + return [ | ||
6 | + { | ||
7 | + userId: '1', | ||
8 | + username: 'vben', | ||
9 | + realName: 'Vben Admin', | ||
10 | + avatar: 'https://q1.qlogo.cn/g?b=qq&nk=190848757&s=640', | ||
11 | + desc: 'manager', | ||
12 | + password: '123456', | ||
13 | + token: 'fakeToken1', | ||
14 | + homePath: '/dashboard/analysis', | ||
15 | + roles: [ | ||
16 | + { | ||
17 | + roleName: 'Super Admin', | ||
18 | + value: 'super', | ||
19 | + }, | ||
20 | + ], | ||
21 | + }, | ||
22 | + { | ||
23 | + userId: '2', | ||
24 | + username: 'test', | ||
25 | + password: '123456', | ||
26 | + realName: 'test user', | ||
27 | + avatar: 'https://q1.qlogo.cn/g?b=qq&nk=339449197&s=640', | ||
28 | + desc: 'tester', | ||
29 | + token: 'fakeToken2', | ||
30 | + homePath: '/dashboard/workbench', | ||
31 | + roles: [ | ||
32 | + { | ||
33 | + roleName: 'Tester', | ||
34 | + value: 'test', | ||
35 | + }, | ||
36 | + ], | ||
37 | + }, | ||
38 | + ]; | ||
39 | +} | ||
40 | + | ||
41 | +const fakeCodeList: any = { | ||
42 | + '1': ['1000', '3000', '5000'], | ||
43 | + | ||
44 | + '2': ['2000', '4000', '6000'], | ||
45 | +}; | ||
46 | +export default [ | ||
47 | + // mock user login | ||
48 | + { | ||
49 | + url: '/auth/login', | ||
50 | + timeout: 200, | ||
51 | + method: 'post', | ||
52 | + response: ({ body }) => { | ||
53 | + const { username, password } = body; | ||
54 | + const checkUser = createFakeUserList().find( | ||
55 | + (item) => item.username === username && password === item.password | ||
56 | + ); | ||
57 | + if (!checkUser) { | ||
58 | + return resultError('Incorrect account or password!'); | ||
59 | + } | ||
60 | + const { userId, username: _username, token, realName, desc, roles } = checkUser; | ||
61 | + return resultSuccess({ | ||
62 | + roles, | ||
63 | + userId, | ||
64 | + username: _username, | ||
65 | + token, | ||
66 | + realName, | ||
67 | + desc, | ||
68 | + }); | ||
69 | + }, | ||
70 | + }, | ||
71 | + { | ||
72 | + url: '/basic-api/getUserInfo', | ||
73 | + method: 'get', | ||
74 | + response: (request: requestParams) => { | ||
75 | + const token = getRequestToken(request); | ||
76 | + if (!token) return resultError('Invalid token'); | ||
77 | + const checkUser = createFakeUserList().find((item) => item.token === token); | ||
78 | + if (!checkUser) { | ||
79 | + return resultError('The corresponding user information was not obtained!'); | ||
80 | + } | ||
81 | + return resultSuccess(checkUser); | ||
82 | + }, | ||
83 | + }, | ||
84 | + { | ||
85 | + url: '/basic-api/getPermCode', | ||
86 | + timeout: 200, | ||
87 | + method: 'get', | ||
88 | + response: (request: requestParams) => { | ||
89 | + const token = getRequestToken(request); | ||
90 | + if (!token) return resultError('Invalid token'); | ||
91 | + const checkUser = createFakeUserList().find((item) => item.token === token); | ||
92 | + if (!checkUser) { | ||
93 | + return resultError('Invalid token!'); | ||
94 | + } | ||
95 | + const codeList = fakeCodeList[checkUser.userId]; | ||
96 | + | ||
97 | + return resultSuccess(codeList); | ||
98 | + }, | ||
99 | + }, | ||
100 | + { | ||
101 | + url: '/basic-api/logout', | ||
102 | + timeout: 200, | ||
103 | + method: 'get', | ||
104 | + response: (request: requestParams) => { | ||
105 | + const token = getRequestToken(request); | ||
106 | + if (!token) return resultError('Invalid token'); | ||
107 | + const checkUser = createFakeUserList().find((item) => item.token === token); | ||
108 | + if (!checkUser) { | ||
109 | + return resultError('Invalid token!'); | ||
110 | + } | ||
111 | + return resultSuccess(undefined, { message: 'Token has been destroyed' }); | ||
112 | + }, | ||
113 | + }, | ||
114 | +] as MockMethod[]; |
package.json
0 → 100644
1 | +{ | ||
2 | + "name": "vben-admin", | ||
3 | + "version": "2.7.1", | ||
4 | + "author": { | ||
5 | + "name": "vben", | ||
6 | + "email": "anncwb@126.com", | ||
7 | + "url": "https://github.com/anncwb" | ||
8 | + }, | ||
9 | + "scripts": { | ||
10 | + "bootstrap": "yarn install", | ||
11 | + "serve": "npm run dev", | ||
12 | + "dev": "vite", | ||
13 | + "build": "cross-env NODE_ENV=production vite build && esno ./build/script/postBuild.ts", | ||
14 | + "build:test": "cross-env vite build --mode test && esno ./build/script/postBuild.ts", | ||
15 | + "build:no-cache": "yarn clean:cache && npm run build", | ||
16 | + "report": "cross-env REPORT=true npm run build", | ||
17 | + "type:check": "vue-tsc --noEmit --skipLibCheck", | ||
18 | + "preview": "npm run build && vite preview", | ||
19 | + "preview:dist": "vite preview", | ||
20 | + "log": "conventional-changelog -p angular -i CHANGELOG.md -s", | ||
21 | + "clean:cache": "rimraf node_modules/.cache/ && rimraf node_modules/.vite", | ||
22 | + "clean:lib": "rimraf node_modules", | ||
23 | + "lint:eslint": "eslint --cache --max-warnings 0 \"{src,mock}/**/*.{vue,ts,tsx}\" --fix", | ||
24 | + "lint:prettier": "prettier --write \"src/**/*.{js,json,tsx,css,less,scss,vue,html,md}\"", | ||
25 | + "lint:stylelint": "stylelint --cache --fix \"**/*.{vue,less,postcss,css,scss}\" --cache --cache-location node_modules/.cache/stylelint/", | ||
26 | + "lint:lint-staged": "lint-staged -c ./.husky/lintstagedrc.js", | ||
27 | + "lint:pretty": "pretty-quick --staged", | ||
28 | + "test:unit": "jest", | ||
29 | + "test:unit-coverage": "jest --coverage", | ||
30 | + "test:gzip": "http-server dist --cors --gzip -c-1", | ||
31 | + "test:br": "http-server dist --cors --brotli -c-1", | ||
32 | + "reinstall": "rimraf yarn.lock && rimraf package.lock.json && rimraf node_modules && npm run bootstrap", | ||
33 | + "prepare": "husky install", | ||
34 | + "gen:icon": "esno ./build/generate/icon/index.ts" | ||
35 | + }, | ||
36 | + "dependencies": { | ||
37 | + "@iconify/iconify": "^2.0.3", | ||
38 | + "@logicflow/core": "^0.6.9", | ||
39 | + "@logicflow/extension": "^0.6.9", | ||
40 | + "@vueuse/core": "^5.3.0", | ||
41 | + "@zxcvbn-ts/core": "^1.0.0-beta.0", | ||
42 | + "ant-design-vue": "2.2.6", | ||
43 | + "axios": "^0.21.1", | ||
44 | + "codemirror": "^5.62.2", | ||
45 | + "cropperjs": "^1.5.12", | ||
46 | + "crypto-js": "^4.1.1", | ||
47 | + "echarts": "^5.1.2", | ||
48 | + "intro.js": "^4.1.0", | ||
49 | + "jwt-decode": "^3.1.2", | ||
50 | + "lodash-es": "^4.17.21", | ||
51 | + "mockjs": "^1.1.0", | ||
52 | + "nprogress": "^0.2.0", | ||
53 | + "path-to-regexp": "^6.2.0", | ||
54 | + "pinia": "2.0.0-rc.4", | ||
55 | + "print-js": "^1.6.0", | ||
56 | + "qrcode": "^1.4.4", | ||
57 | + "resize-observer-polyfill": "^1.5.1", | ||
58 | + "sortablejs": "^1.14.0", | ||
59 | + "tinymce": "^5.8.2", | ||
60 | + "vditor": "^3.8.6", | ||
61 | + "vue": "3.2.2", | ||
62 | + "vue-i18n": "9.1.7", | ||
63 | + "vue-json-pretty": "^2.0.4", | ||
64 | + "vue-router": "^4.0.11", | ||
65 | + "vue-types": "^4.0.3", | ||
66 | + "xlsx": "^0.17.0" | ||
67 | + }, | ||
68 | + "devDependencies": { | ||
69 | + "@commitlint/cli": "^13.1.0", | ||
70 | + "@commitlint/config-conventional": "^13.1.0", | ||
71 | + "@iconify/json": "^1.1.386", | ||
72 | + "@purge-icons/generated": "^0.7.0", | ||
73 | + "@types/codemirror": "^5.60.2", | ||
74 | + "@types/crypto-js": "^4.0.2", | ||
75 | + "@types/fs-extra": "^9.0.12", | ||
76 | + "@types/inquirer": "^7.3.3", | ||
77 | + "@types/intro.js": "^3.0.2", | ||
78 | + "@types/jest": "^27.0.1", | ||
79 | + "@types/lodash-es": "^4.17.4", | ||
80 | + "@types/mockjs": "^1.0.4", | ||
81 | + "@types/node": "^16.6.1", | ||
82 | + "@types/nprogress": "^0.2.0", | ||
83 | + "@types/qrcode": "^1.4.1", | ||
84 | + "@types/qs": "^6.9.7", | ||
85 | + "@types/sortablejs": "^1.10.7", | ||
86 | + "@typescript-eslint/eslint-plugin": "^4.29.1", | ||
87 | + "@typescript-eslint/parser": "^4.29.1", | ||
88 | + "@vitejs/plugin-legacy": "^1.5.1", | ||
89 | + "@vitejs/plugin-vue": "^1.4.0", | ||
90 | + "@vitejs/plugin-vue-jsx": "^1.1.7", | ||
91 | + "@vue/compiler-sfc": "3.2.2", | ||
92 | + "@vue/test-utils": "^2.0.0-rc.12", | ||
93 | + "autoprefixer": "^10.3.1", | ||
94 | + "commitizen": "^4.2.4", | ||
95 | + "conventional-changelog-cli": "^2.1.1", | ||
96 | + "cross-env": "^7.0.3", | ||
97 | + "dotenv": "^10.0.0", | ||
98 | + "eslint": "^7.32.0", | ||
99 | + "eslint-config-prettier": "^8.3.0", | ||
100 | + "eslint-define-config": "^1.0.9", | ||
101 | + "eslint-plugin-jest": "^24.4.0", | ||
102 | + "eslint-plugin-prettier": "^3.4.0", | ||
103 | + "eslint-plugin-vue": "^7.16.0", | ||
104 | + "esno": "^0.8.0", | ||
105 | + "fs-extra": "^10.0.0", | ||
106 | + "http-server": "^13.0.0", | ||
107 | + "husky": "^7.0.1", | ||
108 | + "inquirer": "^8.1.2", | ||
109 | + "is-ci": "^3.0.0", | ||
110 | + "jest": "^27.0.6", | ||
111 | + "less": "^4.1.1", | ||
112 | + "lint-staged": "^11.1.2", | ||
113 | + "npm-run-all": "^4.1.5", | ||
114 | + "postcss": "^8.3.6", | ||
115 | + "prettier": "^2.3.2", | ||
116 | + "pretty-quick": "^3.1.1", | ||
117 | + "rimraf": "^3.0.2", | ||
118 | + "rollup-plugin-visualizer": "5.5.2", | ||
119 | + "stylelint": "^13.13.1", | ||
120 | + "stylelint-config-prettier": "^8.0.2", | ||
121 | + "stylelint-config-standard": "^22.0.0", | ||
122 | + "stylelint-order": "^4.1.0", | ||
123 | + "ts-jest": "^27.0.4", | ||
124 | + "ts-node": "^10.2.0", | ||
125 | + "typescript": "4.3.5", | ||
126 | + "vite": "2.5.0", | ||
127 | + "vite-plugin-compression": "^0.3.3", | ||
128 | + "vite-plugin-html": "^2.0.7", | ||
129 | + "vite-plugin-imagemin": "^0.4.3", | ||
130 | + "vite-plugin-mock": "^2.9.4", | ||
131 | + "vite-plugin-purge-icons": "^0.7.0", | ||
132 | + "vite-plugin-pwa": "^0.10.0", | ||
133 | + "vite-plugin-style-import": "^1.1.1", | ||
134 | + "vite-plugin-svg-icons": "^1.0.4", | ||
135 | + "vite-plugin-theme": "^0.8.1", | ||
136 | + "vite-plugin-windicss": "^1.2.7", | ||
137 | + "vue-eslint-parser": "^7.10.0", | ||
138 | + "vue-tsc": "^0.2.3" | ||
139 | + }, | ||
140 | + "resolutions": { | ||
141 | + "//": "Used to install imagemin dependencies, because imagemin may not be installed in China. If it is abroad, you can delete it", | ||
142 | + "bin-wrapper": "npm:bin-wrapper-china", | ||
143 | + "rollup": "^2.56.2" | ||
144 | + }, | ||
145 | + "homepage": "https://github.com/anncwb/vue-vben-admin", | ||
146 | + "engines": { | ||
147 | + "node": "^12 || >=14" | ||
148 | + } | ||
149 | +} |
pom.xml
0 → 100644
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<project xmlns="http://maven.apache.org/POM/4.0.0" | ||
3 | + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||
4 | + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||
5 | + <parent> | ||
6 | + <artifactId>fast-iot</artifactId> | ||
7 | + <groupId>com.codeez</groupId> | ||
8 | + <version>0.0.1</version> | ||
9 | + </parent> | ||
10 | + <modelVersion>4.0.0</modelVersion> | ||
11 | + <packaging>jar</packaging> | ||
12 | + | ||
13 | + <artifactId>fast-iot-ui</artifactId> | ||
14 | + | ||
15 | + <properties> | ||
16 | + <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> | ||
17 | + <main.dir>${basedir}/..</main.dir> | ||
18 | + </properties> | ||
19 | + <build> | ||
20 | + <resources> | ||
21 | + <resource> | ||
22 | + <directory>${project.build.directory}/generated-resources</directory> | ||
23 | + </resource> | ||
24 | + </resources> | ||
25 | + <plugins> | ||
26 | + <plugin> | ||
27 | + <groupId>com.github.eirslett</groupId> | ||
28 | + <artifactId>frontend-maven-plugin</artifactId> | ||
29 | + <version>1.7.5</version> | ||
30 | + <configuration> | ||
31 | + <installDirectory>target</installDirectory> | ||
32 | + <workingDirectory>${basedir}</workingDirectory> | ||
33 | + </configuration> | ||
34 | + <executions> | ||
35 | + <execution> | ||
36 | + <id>install node and npm</id> | ||
37 | + <goals> | ||
38 | + <goal>install-node-and-yarn</goal> | ||
39 | + </goals> | ||
40 | + <configuration> | ||
41 | + <nodeVersion>v12.16.1</nodeVersion> | ||
42 | + <yarnVersion>v1.22.4</yarnVersion> | ||
43 | + </configuration> | ||
44 | + </execution> | ||
45 | + <execution> | ||
46 | + <id>yarn install</id> | ||
47 | + <goals> | ||
48 | + <goal>yarn</goal> | ||
49 | + </goals> | ||
50 | + <configuration> | ||
51 | + <arguments>install</arguments> | ||
52 | + </configuration> | ||
53 | + </execution> | ||
54 | + </executions> | ||
55 | + </plugin> | ||
56 | + </plugins> | ||
57 | + </build> | ||
58 | + <profiles> | ||
59 | + <profile> | ||
60 | + <id>yarn-build</id> | ||
61 | + <activation> | ||
62 | + <activeByDefault>true</activeByDefault> | ||
63 | + </activation> | ||
64 | + <build> | ||
65 | + <plugins> | ||
66 | + <plugin> | ||
67 | + <groupId>com.github.eirslett</groupId> | ||
68 | + <artifactId>frontend-maven-plugin</artifactId> | ||
69 | + <version>1.7.5</version> | ||
70 | + <configuration> | ||
71 | + <installDirectory>target</installDirectory> | ||
72 | + <workingDirectory>${basedir}</workingDirectory> | ||
73 | + </configuration> | ||
74 | + <executions> | ||
75 | + <execution> | ||
76 | + <id>yarn build</id> | ||
77 | + <goals> | ||
78 | + <goal>yarn</goal> | ||
79 | + </goals> | ||
80 | + <configuration> | ||
81 | + <arguments>build</arguments> | ||
82 | + </configuration> | ||
83 | + </execution> | ||
84 | + </executions> | ||
85 | + </plugin> | ||
86 | + </plugins> | ||
87 | + </build> | ||
88 | + </profile> | ||
89 | +<!-- <profile>--> | ||
90 | +<!-- <id>yarn-serve</id>--> | ||
91 | +<!-- <activation>--> | ||
92 | +<!-- <property>--> | ||
93 | +<!-- <name>yarn-serve</name>--> | ||
94 | +<!-- </property>--> | ||
95 | +<!-- </activation>--> | ||
96 | +<!-- <build>--> | ||
97 | +<!-- <plugins>--> | ||
98 | +<!-- <plugin>--> | ||
99 | +<!-- <groupId>com.github.eirslett</groupId>--> | ||
100 | +<!-- <artifactId>frontend-maven-plugin</artifactId>--> | ||
101 | +<!-- <version>1.7.5</version>--> | ||
102 | +<!-- <configuration>--> | ||
103 | +<!-- <installDirectory>target</installDirectory>--> | ||
104 | +<!-- <workingDirectory>${basedir}</workingDirectory>--> | ||
105 | +<!-- </configuration>--> | ||
106 | +<!-- <executions>--> | ||
107 | +<!-- <execution>--> | ||
108 | +<!-- <id>yarn serve</id>--> | ||
109 | +<!-- <goals>--> | ||
110 | +<!-- <goal>yarn</goal>--> | ||
111 | +<!-- </goals>--> | ||
112 | +<!-- <configuration>--> | ||
113 | +<!-- <arguments>serve</arguments>--> | ||
114 | +<!-- </configuration>--> | ||
115 | +<!-- </execution>--> | ||
116 | +<!-- </executions>--> | ||
117 | +<!-- </plugin>--> | ||
118 | +<!-- </plugins>--> | ||
119 | +<!-- </build>--> | ||
120 | +<!-- </profile>--> | ||
121 | + </profiles> | ||
122 | + | ||
123 | +</project> |
postcss.config.js
0 → 100644
prettier.config.js
0 → 100644
1 | +module.exports = { | ||
2 | + printWidth: 100, | ||
3 | + tabWidth: 2, | ||
4 | + useTabs: false, | ||
5 | + semi: true, | ||
6 | + vueIndentScriptAndStyle: true, | ||
7 | + singleQuote: true, | ||
8 | + quoteProps: 'as-needed', | ||
9 | + bracketSpacing: true, | ||
10 | + trailingComma: 'es5', | ||
11 | + jsxBracketSameLine: false, | ||
12 | + jsxSingleQuote: false, | ||
13 | + arrowParens: 'always', | ||
14 | + insertPragma: false, | ||
15 | + requirePragma: false, | ||
16 | + proseWrap: 'never', | ||
17 | + htmlWhitespaceSensitivity: 'strict', | ||
18 | + endOfLine: 'auto', | ||
19 | + rangeStart: 0, | ||
20 | +}; |
public/favicon.ico
0 → 100644
No preview for this file type
public/resource/img/logo.png
0 → 100644
3.95 KB
public/resource/img/pwa-192x192.png
0 → 100644
11.9 KB
public/resource/img/pwa-512x512.png
0 → 100644
51.4 KB
public/resource/tinymce/langs/en.js
0 → 100644
1 | +tinymce.addI18n('es', { | ||
2 | + Redo: 'Rehacer', | ||
3 | + Undo: 'Deshacer', | ||
4 | + Cut: 'Cortar', | ||
5 | + Copy: 'Copiar', | ||
6 | + Paste: 'Pegar', | ||
7 | + 'Select all': 'Seleccionar todo', | ||
8 | + 'New document': 'Nuevo documento', | ||
9 | + Ok: 'Ok', | ||
10 | + Cancel: 'Cancelar', | ||
11 | + 'Visual aids': 'Ayudas visuales', | ||
12 | + Bold: 'Negrita', | ||
13 | + Italic: 'Cursiva', | ||
14 | + Underline: 'Subrayado', | ||
15 | + Strikethrough: 'Tachado', | ||
16 | + Superscript: 'Super\u00edndice', | ||
17 | + Subscript: 'Sub\u00edndice', | ||
18 | + 'Clear formatting': 'Limpiar formato', | ||
19 | + 'Align left': 'Alinear a la izquierda', | ||
20 | + 'Align center': 'Alinear al centro', | ||
21 | + 'Align right': 'Alinear a la derecha', | ||
22 | + Justify: 'Justificar', | ||
23 | + 'Bullet list': 'Lista de vi\u00f1etas', | ||
24 | + 'Numbered list': 'Lista numerada', | ||
25 | + 'Decrease indent': 'Disminuir sangr\u00eda', | ||
26 | + 'Increase indent': 'Incrementar sangr\u00eda', | ||
27 | + Close: 'Cerrar', | ||
28 | + Formats: 'Formatos', | ||
29 | + "Your browser doesn't support direct access to the clipboard. Please use the Ctrl+X\/C\/V keyboard shortcuts instead.": 'Su navegador no es compatible con el acceso directo al portapapeles. Use las teclas Crtl+X\/C\/V de su teclado.', | ||
30 | + Headers: 'Encabezados', | ||
31 | + 'Header 1': 'Encabezado 1', | ||
32 | + 'Header 2': 'Encabezado 2', | ||
33 | + 'Header 3': 'Encabezado 3', | ||
34 | + 'Header 4': 'Encabezado 4', | ||
35 | + 'Header 5': 'Encabezado 5', | ||
36 | + 'Header 6': 'Encabezado 6', | ||
37 | + Headings: 'Encabezados', | ||
38 | + 'Heading 1': 'Encabezado 1', | ||
39 | + 'Heading 2': 'Encabezado 2', | ||
40 | + 'Heading 3': 'Encabezado 3', | ||
41 | + 'Heading 4': 'Encabezado 4', | ||
42 | + 'Heading 5': 'Encabezado 5', | ||
43 | + 'Heading 6': 'Encabezado 6', | ||
44 | + Preformatted: 'Con formato previo', | ||
45 | + Div: 'Div', | ||
46 | + Pre: 'Pre', | ||
47 | + Code: 'C\u00f3digo', | ||
48 | + Paragraph: 'P\u00e1rrafo', | ||
49 | + Blockquote: 'Blockquote', | ||
50 | + Inline: 'Alineado', | ||
51 | + Blocks: 'Bloques', | ||
52 | + 'Paste is now in plain text mode. Contents will now be pasted as plain text until you toggle this option off.': 'Pegar est\u00e1 ahora en modo de texto plano. El contenido se pegar\u00e1 como texto plano hasta que desactive esta opci\u00f3n.', | ||
53 | + Fonts: 'Fuentes', | ||
54 | + 'Font Sizes': 'Tama\u00f1os de fuente', | ||
55 | + Class: 'Clase', | ||
56 | + 'Browse for an image': 'Buscar una imagen', | ||
57 | + OR: 'OR', | ||
58 | + 'Drop an image here': 'Arrastre una imagen aqu\u00ed', | ||
59 | + Upload: 'Cargar', | ||
60 | + Block: 'Bloque', | ||
61 | + Align: 'Alinear', | ||
62 | + Default: 'Por defecto', | ||
63 | + Circle: 'C\u00edrculo', | ||
64 | + Disc: 'Disco', | ||
65 | + Square: 'Cuadrado', | ||
66 | + 'Lower Alpha': 'Inferior Alfa', | ||
67 | + 'Lower Greek': 'Inferior Griega', | ||
68 | + 'Lower Roman': 'Inferior Romana', | ||
69 | + 'Upper Alpha': 'Superior Alfa', | ||
70 | + 'Upper Roman': 'Superior Romana', | ||
71 | + 'Anchor...': 'Anclaje...', | ||
72 | + Name: 'Nombre', | ||
73 | + Id: 'Id', | ||
74 | + 'Id should start with a letter, followed only by letters, numbers, dashes, dots, colons or underscores.': 'Deber\u00eda comenzar por una letra, seguida solo de letras, n\u00fameros, guiones, puntos, dos puntos o guiones bajos.', | ||
75 | + 'You have unsaved changes are you sure you want to navigate away?': 'Tiene cambios sin guardar. \u00bfEst\u00e1 seguro de que quiere salir?', | ||
76 | + 'Restore last draft': 'Restaurar el \u00faltimo borrador', | ||
77 | + 'Special character...': 'Car\u00e1cter especial...', | ||
78 | + 'Source code': 'C\u00f3digo fuente', | ||
79 | + 'Insert\/Edit code sample': 'Insertar\/editar c\u00f3digo de prueba', | ||
80 | + Language: 'Idioma', | ||
81 | + 'Code sample...': 'Ejemplo de c\u00f3digo...', | ||
82 | + 'Color Picker': 'Selector de colores', | ||
83 | + R: 'R', | ||
84 | + G: 'V', | ||
85 | + B: 'A', | ||
86 | + 'Left to right': 'De izquierda a derecha', | ||
87 | + 'Right to left': 'De derecha a izquierda', | ||
88 | + 'Emoticons...': 'Emoticones...', | ||
89 | + 'Metadata and Document Properties': 'Metadatos y propiedades del documento', | ||
90 | + Title: 'T\u00edtulo', | ||
91 | + Keywords: 'Palabras clave', | ||
92 | + Description: 'Descripci\u00f3n', | ||
93 | + Robots: 'Robots', | ||
94 | + Author: 'Autor', | ||
95 | + Encoding: 'Codificaci\u00f3n', | ||
96 | + Fullscreen: 'Pantalla completa', | ||
97 | + Action: 'Acci\u00f3n', | ||
98 | + Shortcut: 'Atajo', | ||
99 | + Help: 'Ayuda', | ||
100 | + Address: 'Direcci\u00f3n', | ||
101 | + 'Focus to menubar': 'Enfocar la barra del men\u00fa', | ||
102 | + 'Focus to toolbar': 'Enfocar la barra de herramientas', | ||
103 | + 'Focus to element path': 'Enfocar la ruta del elemento', | ||
104 | + 'Focus to contextual toolbar': 'Enfocar la barra de herramientas contextual', | ||
105 | + 'Insert link (if link plugin activated)': 'Insertar enlace (si el complemento de enlace est\u00e1 activado)', | ||
106 | + 'Save (if save plugin activated)': 'Guardar (si el componente de salvar est\u00e1 activado)', | ||
107 | + 'Find (if searchreplace plugin activated)': 'Buscar (si el complemento buscar-remplazar est\u00e1 activado)', | ||
108 | + 'Plugins installed ({0}):': 'Plugins instalados ({0}):', | ||
109 | + 'Premium plugins:': 'Complementos premium:', | ||
110 | + 'Learn more...': 'Aprende m\u00e1s...', | ||
111 | + 'You are using {0}': 'Estas usando {0}', | ||
112 | + Plugins: 'Complementos', | ||
113 | + 'Handy Shortcuts': 'Accesos directos', | ||
114 | + 'Horizontal line': 'L\u00ednea horizontal', | ||
115 | + 'Insert\/edit image': 'Insertar\/editar imagen', | ||
116 | + 'Image description': 'Descripci\u00f3n de la imagen', | ||
117 | + Source: 'Enlace', | ||
118 | + Dimensions: 'Dimensiones', | ||
119 | + 'Constrain proportions': 'Restringir proporciones', | ||
120 | + General: 'General', | ||
121 | + Advanced: 'Avanzado', | ||
122 | + Style: 'Estilo', | ||
123 | + 'Vertical space': 'Espacio vertical', | ||
124 | + 'Horizontal space': 'Espacio horizontal', | ||
125 | + Border: 'Borde', | ||
126 | + 'Insert image': 'Insertar imagen', | ||
127 | + 'Image...': 'Imagen...', | ||
128 | + 'Image list': 'Lista de im\u00e1genes', | ||
129 | + 'Rotate counterclockwise': 'Girar a la izquierda', | ||
130 | + 'Rotate clockwise': 'Girar a la derecha', | ||
131 | + 'Flip vertically': 'Invertir verticalmente', | ||
132 | + 'Flip horizontally': 'Invertir horizontalmente', | ||
133 | + 'Edit image': 'Editar imagen', | ||
134 | + 'Image options': 'Opciones de imagen', | ||
135 | + 'Zoom in': 'Acercar', | ||
136 | + 'Zoom out': 'Alejar', | ||
137 | + Crop: 'Recortar', | ||
138 | + Resize: 'Redimensionar', | ||
139 | + Orientation: 'Orientaci\u00f3n', | ||
140 | + Brightness: 'Brillo', | ||
141 | + Sharpen: 'Forma', | ||
142 | + Contrast: 'Contraste', | ||
143 | + 'Color levels': 'Niveles de color', | ||
144 | + Gamma: 'Gamma', | ||
145 | + Invert: 'Invertir', | ||
146 | + Apply: 'Aplicar', | ||
147 | + Back: 'Atr\u00e1s', | ||
148 | + 'Insert date\/time': 'Insertar fecha\/hora', | ||
149 | + 'Date\/time': 'Fecha\/hora', | ||
150 | + 'Insert\/Edit Link': 'Insertar\/editar enlace', | ||
151 | + 'Insert\/edit link': 'Insertar\/editar enlace', | ||
152 | + 'Text to display': 'Texto para mostrar', | ||
153 | + Url: 'URL', | ||
154 | + 'Open link in...': 'Abrir enlace en...', | ||
155 | + 'Current window': 'Ventana actual', | ||
156 | + None: 'Ninguno', | ||
157 | + 'New window': 'Nueva ventana', | ||
158 | + 'Remove link': 'Quitar enlace', | ||
159 | + Anchors: 'Anclas', | ||
160 | + 'Link...': 'Enlace...', | ||
161 | + 'Paste or type a link': 'Pega o introduce un enlace', | ||
162 | + 'The URL you entered seems to be an email address. Do you want to add the required mailto: prefix?': 'El enlace que has introducido no parece ser una direcci\u00f3n de correo electr\u00f3nico. Quieres a\u00f1adir el prefijo necesario mailto: ?', | ||
163 | + 'The URL you entered seems to be an external link. Do you want to add the required http:\/\/ prefix?': 'El enlace que has introducido no parece ser una enlace externo. Quieres a\u00f1adir el prefijo necesario http:\/\/ ?', | ||
164 | + 'Link list': 'Lista de enlaces', | ||
165 | + 'Insert video': 'Insertar video', | ||
166 | + 'Insert\/edit video': 'Insertar\/editar video', | ||
167 | + 'Insert\/edit media': 'Insertar\/editar medio', | ||
168 | + 'Alternative source': 'Enlace alternativo', | ||
169 | + 'Alternative source URL': 'Origen de URL alternativo', | ||
170 | + 'Media poster (Image URL)': 'P\u00f3ster de medio (URL de imagen)', | ||
171 | + 'Paste your embed code below:': 'Pega tu c\u00f3digo embebido debajo', | ||
172 | + Embed: 'Incrustado', | ||
173 | + 'Media...': 'Medios...', | ||
174 | + 'Nonbreaking space': 'Espacio fijo', | ||
175 | + 'Page break': 'Salto de p\u00e1gina', | ||
176 | + 'Paste as text': 'Pegar como texto', | ||
177 | + Preview: 'Previsualizar', | ||
178 | + 'Print...': 'Imprimir...', | ||
179 | + Save: 'Guardar', | ||
180 | + Find: 'Buscar', | ||
181 | + 'Replace with': 'Reemplazar con', | ||
182 | + Replace: 'Reemplazar', | ||
183 | + 'Replace all': 'Reemplazar todo', | ||
184 | + Previous: 'Anterior', | ||
185 | + Next: 'Siguiente', | ||
186 | + 'Find and replace...': 'Buscar y reemplazar...', | ||
187 | + 'Could not find the specified string.': 'No se encuentra la cadena de texto especificada', | ||
188 | + 'Match case': 'Coincidencia exacta', | ||
189 | + 'Find whole words only': 'Solo palabras completas', | ||
190 | + 'Spell check': 'Revisar ortograf\u00eda', | ||
191 | + Ignore: 'Ignorar', | ||
192 | + 'Ignore all': 'Ignorar todos', | ||
193 | + Finish: 'Finalizar', | ||
194 | + 'Add to Dictionary': 'A\u00f1adir al Diccionario', | ||
195 | + 'Insert table': 'Insertar tabla', | ||
196 | + 'Table properties': 'Propiedades de la tabla', | ||
197 | + 'Delete table': 'Eliminar tabla', | ||
198 | + Cell: 'Celda', | ||
199 | + Row: 'Fila', | ||
200 | + Column: 'Columna', | ||
201 | + 'Cell properties': 'Propiedades de la celda', | ||
202 | + 'Merge cells': 'Combinar celdas', | ||
203 | + 'Split cell': 'Dividir celdas', | ||
204 | + 'Insert row before': 'Insertar fila antes', | ||
205 | + 'Insert row after': 'Insertar fila despu\u00e9s ', | ||
206 | + 'Delete row': 'Eliminar fila', | ||
207 | + 'Row properties': 'Propiedades de la fila', | ||
208 | + 'Cut row': 'Cortar fila', | ||
209 | + 'Copy row': 'Copiar fila', | ||
210 | + 'Paste row before': 'Pegar la fila antes', | ||
211 | + 'Paste row after': 'Pegar la fila despu\u00e9s', | ||
212 | + 'Insert column before': 'Insertar columna antes', | ||
213 | + 'Insert column after': 'Insertar columna despu\u00e9s', | ||
214 | + 'Delete column': 'Eliminar columna', | ||
215 | + Cols: 'Columnas', | ||
216 | + Rows: 'Filas', | ||
217 | + Width: 'Ancho', | ||
218 | + Height: 'Alto', | ||
219 | + 'Cell spacing': 'Espacio entre celdas', | ||
220 | + 'Cell padding': 'Relleno de celda', | ||
221 | + 'Show caption': 'Mostrar t\u00edtulo', | ||
222 | + Left: 'Izquierda', | ||
223 | + Center: 'Centrado', | ||
224 | + Right: 'Derecha', | ||
225 | + 'Cell type': 'Tipo de celda', | ||
226 | + Scope: '\u00c1mbito', | ||
227 | + Alignment: 'Alineaci\u00f3n', | ||
228 | + 'H Align': 'Alineamiento Horizontal', | ||
229 | + 'V Align': 'Alineamiento Vertical', | ||
230 | + Top: 'Arriba', | ||
231 | + Middle: 'Centro', | ||
232 | + Bottom: 'Abajo', | ||
233 | + 'Header cell': 'Celda de la cebecera', | ||
234 | + 'Row group': 'Grupo de filas', | ||
235 | + 'Column group': 'Grupo de columnas', | ||
236 | + 'Row type': 'Tipo de fila', | ||
237 | + Header: 'Cabecera', | ||
238 | + Body: 'Cuerpo', | ||
239 | + Footer: 'Pie de p\u00e1gina', | ||
240 | + 'Border color': 'Color del borde', | ||
241 | + 'Insert template...': 'Insertar plantilla...', | ||
242 | + Templates: 'Plantillas', | ||
243 | + Template: 'Plantilla', | ||
244 | + 'Text color': 'Color del texto', | ||
245 | + 'Background color': 'Color de fondo', | ||
246 | + 'Custom...': 'Personalizar...', | ||
247 | + 'Custom color': 'Color personalizado', | ||
248 | + 'No color': 'Sin color', | ||
249 | + 'Remove color': 'Quitar color', | ||
250 | + 'Table of Contents': 'Tabla de contenidos', | ||
251 | + 'Show blocks': 'Mostrar bloques', | ||
252 | + 'Show invisible characters': 'Mostrar caracteres invisibles', | ||
253 | + 'Word count': 'Contar palabras', | ||
254 | + Count: 'Recuento', | ||
255 | + Document: 'Documento', | ||
256 | + Selection: 'Selecci\u00f3n', | ||
257 | + Words: 'Palabras', | ||
258 | + 'Words: {0}': 'Palabras: {0}', | ||
259 | + '{0} words': '{0} palabras', | ||
260 | + File: 'Archivo', | ||
261 | + Edit: 'Editar', | ||
262 | + Insert: 'Insertar', | ||
263 | + View: 'Ver', | ||
264 | + Format: 'Formato', | ||
265 | + Table: 'Tabla', | ||
266 | + Tools: 'Herramientas', | ||
267 | + 'Powered by {0}': 'Desarrollado por {0}', | ||
268 | + 'Rich Text Area. Press ALT-F9 for menu. Press ALT-F10 for toolbar. Press ALT-0 for help': '\u00c1rea de texto enriquecido. Pulse ALT-F9 para el menu. Pulse ALT-F10 para la barra de herramientas. Pulse ALT-0 para ayuda', | ||
269 | + 'Image title': 'Titulo de imagen', | ||
270 | + 'Border width': 'Ancho de borde', | ||
271 | + 'Border style': 'Estilo de borde', | ||
272 | + Error: 'Error', | ||
273 | + Warn: 'Advertencia', | ||
274 | + Valid: 'V\u00e1lido', | ||
275 | + 'To open the popup, press Shift+Enter': 'Para abrir el elemento emergente, pulse May\u00fas+Intro', | ||
276 | + 'Rich Text Area. Press ALT-0 for help.': '\u00c1rea de texto enriquecido. Pulse ALT-0 para abrir la ayuda.', | ||
277 | + 'System Font': 'Fuente de sistema', | ||
278 | + 'Failed to upload image: {0}': 'Fallo al cargar imagen: {0}', | ||
279 | + 'Failed to load plugin: {0} from url {1}': 'Fallo al cargar complemento: {0} desde URL {1}', | ||
280 | + 'Failed to load plugin url: {0}': 'Fallo al cargar URL del complemento: {0}', | ||
281 | + 'Failed to initialize plugin: {0}': 'Fallo al iniciar el complemento: {0}', | ||
282 | + example: 'ejemplo', | ||
283 | + Search: 'Buscar', | ||
284 | + All: 'Todo', | ||
285 | + Currency: 'Divisa', | ||
286 | + Text: 'Texto', | ||
287 | + Quotations: 'Comillas', | ||
288 | + Mathematical: 'S\u00edmbolo matem\u00e1tico', | ||
289 | + 'Extended Latin': 'Latino extendido A', | ||
290 | + Symbols: 'S\u00edmbolos', | ||
291 | + Arrows: 'Flechas', | ||
292 | + 'User Defined': 'Definido por el usuario', | ||
293 | + 'dollar sign': 'signo de d\u00f3lar', | ||
294 | + 'currency sign': 'signo de divisa', | ||
295 | + 'euro-currency sign': 'signo de euro', | ||
296 | + 'colon sign': 'signo de dos puntos', | ||
297 | + 'cruzeiro sign': 'signo de cruceiro', | ||
298 | + 'french franc sign': 'signo de franco franc\u00e9s', | ||
299 | + 'lira sign': 'signo de lira', | ||
300 | + 'mill sign': 'signo de mill', | ||
301 | + 'naira sign': 'signo de naira', | ||
302 | + 'peseta sign': 'signo de peseta', | ||
303 | + 'rupee sign': 'signo de rupia', | ||
304 | + 'won sign': 'signo de won', | ||
305 | + 'new sheqel sign': 'signo de nuevo s\u00e9quel', | ||
306 | + 'dong sign': 'signo de dong', | ||
307 | + 'kip sign': 'signo de kip', | ||
308 | + 'tugrik sign': 'signo de tugrik', | ||
309 | + 'drachma sign': 'signo de dracma', | ||
310 | + 'german penny symbol': 'signo de penique alem\u00e1n', | ||
311 | + 'peso sign': 'signo de peso', | ||
312 | + 'guarani sign': 'signo de guaran\u00ed', | ||
313 | + 'austral sign': 'signo de austral', | ||
314 | + 'hryvnia sign': 'signo de grivna', | ||
315 | + 'cedi sign': 'signo de cedi', | ||
316 | + 'livre tournois sign': 'signo de libra tornesa', | ||
317 | + 'spesmilo sign': 'signo de spesmilo', | ||
318 | + 'tenge sign': 'signo de tenge', | ||
319 | + 'indian rupee sign': 'signo de rupia india', | ||
320 | + 'turkish lira sign': 'signo de lira turca', | ||
321 | + 'nordic mark sign': 'signo de marco n\u00f3rdico', | ||
322 | + 'manat sign': 'signo de manat', | ||
323 | + 'ruble sign': 'signo de rublo', | ||
324 | + 'yen character': 'car\u00e1cter de yen', | ||
325 | + 'yuan character': 'car\u00e1cter de yuan', | ||
326 | + 'yuan character, in hong kong and taiwan': 'car\u00e1cter de yuan en Hong Kong y Taiw\u00e1n', | ||
327 | + 'yen\/yuan character variant one': 'Variante uno de car\u00e1cter de yen\/yuan', | ||
328 | + 'Loading emoticons...': 'Cargando emoticonos...', | ||
329 | + 'Could not load emoticons': 'No se han podido cargar los emoticonos', | ||
330 | + People: 'Personas', | ||
331 | + 'Animals and Nature': 'Animales y naturaleza', | ||
332 | + 'Food and Drink': 'Comida y bebida', | ||
333 | + Activity: 'Actividad', | ||
334 | + 'Travel and Places': 'Viajes y lugares', | ||
335 | + Objects: 'Objetos', | ||
336 | + Flags: 'Banderas', | ||
337 | + Characters: 'Caracteres', | ||
338 | + 'Characters (no spaces)': 'Caracteres (sin espacios)', | ||
339 | + '{0} characters': '{0} caracteres', | ||
340 | + 'Error: Form submit field collision.': 'Error: Colisi\u00f3n de campo al enviar formulario.', | ||
341 | + 'Error: No form element found.': 'Error: No se encuentra ning\u00fan elemento de formulario.', | ||
342 | + Update: 'Actualizar', | ||
343 | + 'Color swatch': 'Muestrario de colores', | ||
344 | + Turquoise: 'Turquesa', | ||
345 | + Green: 'Verde', | ||
346 | + Blue: 'Azul', | ||
347 | + Purple: 'P\u00farpura', | ||
348 | + 'Navy Blue': 'Azul marino', | ||
349 | + 'Dark Turquoise': 'Turquesa oscuro', | ||
350 | + 'Dark Green': 'Verde oscuro', | ||
351 | + 'Medium Blue': 'Azul medio', | ||
352 | + 'Medium Purple': 'P\u00farpura medio', | ||
353 | + 'Midnight Blue': 'Azul medio', | ||
354 | + Yellow: 'Amarillo', | ||
355 | + Orange: 'Naranja', | ||
356 | + Red: 'Rojo', | ||
357 | + 'Light Gray': 'Gris claro', | ||
358 | + Gray: 'Gris', | ||
359 | + 'Dark Yellow': 'Amarillo oscuro', | ||
360 | + 'Dark Orange': 'Naranja oscuro', | ||
361 | + 'Dark Red': 'Rojo oscuro', | ||
362 | + 'Medium Gray': 'Gris medio', | ||
363 | + 'Dark Gray': 'Gris oscuro', | ||
364 | + 'Light Green': 'Verde claro', | ||
365 | + 'Light Yellow': 'Amarillo claro', | ||
366 | + 'Light Red': 'Rojo claro', | ||
367 | + 'Light Purple': 'Morado claro', | ||
368 | + 'Light Blue': 'Azul claro', | ||
369 | + 'Dark Purple': 'Morado oscuro', | ||
370 | + 'Dark Blue': 'Azul oscuro', | ||
371 | + Black: 'Negro', | ||
372 | + White: 'Blanco', | ||
373 | + 'Switch to or from fullscreen mode': 'Activar o desactivar modo pantalla completa', | ||
374 | + 'Open help dialog': 'Abrir di\u00e1logo de ayuda', | ||
375 | + history: 'historial', | ||
376 | + styles: 'estilos', | ||
377 | + formatting: 'formato', | ||
378 | + alignment: 'alineaci\u00f3n', | ||
379 | + indentation: 'sangr\u00eda', | ||
380 | + 'permanent pen': 'bol\u00edgrafo permanente', | ||
381 | + comments: 'comentarios', | ||
382 | + 'Format Painter': 'Copiar formato', | ||
383 | + 'Insert\/edit iframe': 'Insertar\/editar iframe', | ||
384 | + Capitalization: 'Uso de may\u00fasculas', | ||
385 | + lowercase: 'min\u00fasculas', | ||
386 | + UPPERCASE: 'MAY\u00daSCULAS', | ||
387 | + 'Title Case': 'Tipo T\u00edtulo', | ||
388 | + 'Permanent Pen Properties': 'Propiedades del bol\u00edgrafo permanente', | ||
389 | + 'Permanent pen properties...': 'Propiedades del bol\u00edgrafo permanente...', | ||
390 | + Font: 'Fuente', | ||
391 | + Size: 'Tama\u00f1o', | ||
392 | + 'More...': 'M\u00e1s...', | ||
393 | + 'Spellcheck Language': 'Corrector', | ||
394 | + 'Select...': 'Seleccionar...', | ||
395 | + Preferences: 'Preferencias', | ||
396 | + Yes: 'S\u00ed', | ||
397 | + No: 'No', | ||
398 | + 'Keyboard Navigation': 'Navegaci\u00f3n con el teclado', | ||
399 | + Version: 'Versi\u00f3n', | ||
400 | + Anchor: 'Ancla', | ||
401 | + 'Special character': 'Car\u00e1cter especial', | ||
402 | + 'Code sample': 'Ejemplo de c\u00f3digo', | ||
403 | + Color: 'Color', | ||
404 | + Emoticons: 'Emoticonos', | ||
405 | + 'Document properties': 'Propiedades del documento', | ||
406 | + Image: 'Imagen', | ||
407 | + 'Insert link': 'Insertar enlace', | ||
408 | + Target: 'Destino', | ||
409 | + Link: 'Enlace', | ||
410 | + Poster: 'Miniatura', | ||
411 | + Media: 'Media', | ||
412 | + Print: 'Imprimir', | ||
413 | + Prev: 'Anterior', | ||
414 | + 'Find and replace': 'Buscar y reemplazar', | ||
415 | + 'Whole words': 'Palabras completas', | ||
416 | + Spellcheck: 'Corrector ortogr\u00e1fico', | ||
417 | + Caption: 'Subt\u00edtulo', | ||
418 | + 'Insert template': 'Insertar plantilla' | ||
419 | +}) |
public/resource/tinymce/langs/zh_CN.js
0 → 100644
1 | +tinymce.addI18n('zh_CN',{ | ||
2 | +"Redo": "\u91cd\u505a", | ||
3 | +"Undo": "\u64a4\u9500", | ||
4 | +"Cut": "\u526a\u5207", | ||
5 | +"Copy": "\u590d\u5236", | ||
6 | +"Paste": "\u7c98\u8d34", | ||
7 | +"Select all": "\u5168\u9009", | ||
8 | +"New document": "\u65b0\u6587\u4ef6", | ||
9 | +"Ok": "\u786e\u5b9a", | ||
10 | +"Cancel": "\u53d6\u6d88", | ||
11 | +"Visual aids": "\u7f51\u683c\u7ebf", | ||
12 | +"Bold": "\u7c97\u4f53", | ||
13 | +"Italic": "\u659c\u4f53", | ||
14 | +"Underline": "\u4e0b\u5212\u7ebf", | ||
15 | +"Strikethrough": "\u5220\u9664\u7ebf", | ||
16 | +"Superscript": "\u4e0a\u6807", | ||
17 | +"Subscript": "\u4e0b\u6807", | ||
18 | +"Clear formatting": "\u6e05\u9664\u683c\u5f0f", | ||
19 | +"Align left": "\u5de6\u8fb9\u5bf9\u9f50", | ||
20 | +"Align center": "\u4e2d\u95f4\u5bf9\u9f50", | ||
21 | +"Align right": "\u53f3\u8fb9\u5bf9\u9f50", | ||
22 | +"Justify": "\u4e24\u7aef\u5bf9\u9f50", | ||
23 | +"Bullet list": "\u9879\u76ee\u7b26\u53f7", | ||
24 | +"Numbered list": "\u7f16\u53f7\u5217\u8868", | ||
25 | +"Decrease indent": "\u51cf\u5c11\u7f29\u8fdb", | ||
26 | +"Increase indent": "\u589e\u52a0\u7f29\u8fdb", | ||
27 | +"Close": "\u5173\u95ed", | ||
28 | +"Formats": "\u683c\u5f0f", | ||
29 | +"Your browser doesn't support direct access to the clipboard. Please use the Ctrl+X\/C\/V keyboard shortcuts instead.": "\u4f60\u7684\u6d4f\u89c8\u5668\u4e0d\u652f\u6301\u6253\u5f00\u526a\u8d34\u677f\uff0c\u8bf7\u4f7f\u7528Ctrl+X\/C\/V\u7b49\u5feb\u6377\u952e\u3002", | ||
30 | +"Headers": "\u6807\u9898", | ||
31 | +"Header 1": "\u6807\u98981", | ||
32 | +"Header 2": "\u6807\u98982", | ||
33 | +"Header 3": "\u6807\u98983", | ||
34 | +"Header 4": "\u6807\u98984", | ||
35 | +"Header 5": "\u6807\u98985", | ||
36 | +"Header 6": "\u6807\u98986", | ||
37 | +"Headings": "\u6807\u9898", | ||
38 | +"Heading 1": "\u6807\u98981", | ||
39 | +"Heading 2": "\u6807\u98982", | ||
40 | +"Heading 3": "\u6807\u98983", | ||
41 | +"Heading 4": "\u6807\u98984", | ||
42 | +"Heading 5": "\u6807\u98985", | ||
43 | +"Heading 6": "\u6807\u98986", | ||
44 | +"Preformatted": "\u9884\u5148\u683c\u5f0f\u5316\u7684", | ||
45 | +"Div": "Div", | ||
46 | +"Pre": "Pre", | ||
47 | +"Code": "\u4ee3\u7801", | ||
48 | +"Paragraph": "\u6bb5\u843d", | ||
49 | +"Blockquote": "\u5f15\u6587\u533a\u5757", | ||
50 | +"Inline": "\u6587\u672c", | ||
51 | +"Blocks": "\u57fa\u5757", | ||
52 | +"Paste is now in plain text mode. Contents will now be pasted as plain text until you toggle this option off.": "\u5f53\u524d\u4e3a\u7eaf\u6587\u672c\u7c98\u8d34\u6a21\u5f0f\uff0c\u518d\u6b21\u70b9\u51fb\u53ef\u4ee5\u56de\u5230\u666e\u901a\u7c98\u8d34\u6a21\u5f0f\u3002", | ||
53 | +"Fonts": "\u5b57\u4f53", | ||
54 | +"Font Sizes": "\u5b57\u53f7", | ||
55 | +"Class": "\u7c7b\u578b", | ||
56 | +"Browse for an image": "\u6d4f\u89c8\u56fe\u50cf", | ||
57 | +"OR": "\u6216", | ||
58 | +"Drop an image here": "\u62d6\u653e\u4e00\u5f20\u56fe\u50cf\u81f3\u6b64", | ||
59 | +"Upload": "\u4e0a\u4f20", | ||
60 | +"Block": "\u5757", | ||
61 | +"Align": "\u5bf9\u9f50", | ||
62 | +"Default": "\u9ed8\u8ba4", | ||
63 | +"Circle": "\u7a7a\u5fc3\u5706", | ||
64 | +"Disc": "\u5b9e\u5fc3\u5706", | ||
65 | +"Square": "\u65b9\u5757", | ||
66 | +"Lower Alpha": "\u5c0f\u5199\u82f1\u6587\u5b57\u6bcd", | ||
67 | +"Lower Greek": "\u5c0f\u5199\u5e0c\u814a\u5b57\u6bcd", | ||
68 | +"Lower Roman": "\u5c0f\u5199\u7f57\u9a6c\u5b57\u6bcd", | ||
69 | +"Upper Alpha": "\u5927\u5199\u82f1\u6587\u5b57\u6bcd", | ||
70 | +"Upper Roman": "\u5927\u5199\u7f57\u9a6c\u5b57\u6bcd", | ||
71 | +"Anchor...": "\u951a\u70b9...", | ||
72 | +"Name": "\u540d\u79f0", | ||
73 | +"Id": "\u6807\u8bc6\u7b26", | ||
74 | +"Id should start with a letter, followed only by letters, numbers, dashes, dots, colons or underscores.": "\u6807\u8bc6\u7b26\u5e94\u8be5\u4ee5\u5b57\u6bcd\u5f00\u5934\uff0c\u540e\u8ddf\u5b57\u6bcd\u3001\u6570\u5b57\u3001\u7834\u6298\u53f7\u3001\u70b9\u3001\u5192\u53f7\u6216\u4e0b\u5212\u7ebf\u3002", | ||
75 | +"You have unsaved changes are you sure you want to navigate away?": "\u4f60\u8fd8\u6709\u6587\u6863\u5c1a\u672a\u4fdd\u5b58\uff0c\u786e\u5b9a\u8981\u79bb\u5f00\uff1f", | ||
76 | +"Restore last draft": "\u6062\u590d\u4e0a\u6b21\u7684\u8349\u7a3f", | ||
77 | +"Special characters...": "\u7279\u6b8a\u5b57\u7b26...", | ||
78 | +"Source code": "\u6e90\u4ee3\u7801", | ||
79 | +"Insert\/Edit code sample": "\u63d2\u5165\/\u7f16\u8f91\u4ee3\u7801\u793a\u4f8b", | ||
80 | +"Language": "\u8bed\u8a00", | ||
81 | +"Code sample...": "\u793a\u4f8b\u4ee3\u7801...", | ||
82 | +"Color Picker": "\u9009\u8272\u5668", | ||
83 | +"R": "R", | ||
84 | +"G": "G", | ||
85 | +"B": "B", | ||
86 | +"Left to right": "\u4ece\u5de6\u5230\u53f3", | ||
87 | +"Right to left": "\u4ece\u53f3\u5230\u5de6", | ||
88 | +"Emoticons...": "\u8868\u60c5\u7b26\u53f7...", | ||
89 | +"Metadata and Document Properties": "\u5143\u6570\u636e\u548c\u6587\u6863\u5c5e\u6027", | ||
90 | +"Title": "\u6807\u9898", | ||
91 | +"Keywords": "\u5173\u952e\u8bcd", | ||
92 | +"Description": "\u63cf\u8ff0", | ||
93 | +"Robots": "\u673a\u5668\u4eba", | ||
94 | +"Author": "\u4f5c\u8005", | ||
95 | +"Encoding": "\u7f16\u7801", | ||
96 | +"Fullscreen": "\u5168\u5c4f", | ||
97 | +"Action": "\u64cd\u4f5c", | ||
98 | +"Shortcut": "\u5feb\u6377\u952e", | ||
99 | +"Help": "\u5e2e\u52a9", | ||
100 | +"Address": "\u5730\u5740", | ||
101 | +"Focus to menubar": "\u79fb\u52a8\u7126\u70b9\u5230\u83dc\u5355\u680f", | ||
102 | +"Focus to toolbar": "\u79fb\u52a8\u7126\u70b9\u5230\u5de5\u5177\u680f", | ||
103 | +"Focus to element path": "\u79fb\u52a8\u7126\u70b9\u5230\u5143\u7d20\u8def\u5f84", | ||
104 | +"Focus to contextual toolbar": "\u79fb\u52a8\u7126\u70b9\u5230\u4e0a\u4e0b\u6587\u83dc\u5355", | ||
105 | +"Insert link (if link plugin activated)": "\u63d2\u5165\u94fe\u63a5 (\u5982\u679c\u94fe\u63a5\u63d2\u4ef6\u5df2\u6fc0\u6d3b)", | ||
106 | +"Save (if save plugin activated)": "\u4fdd\u5b58(\u5982\u679c\u4fdd\u5b58\u63d2\u4ef6\u5df2\u6fc0\u6d3b)", | ||
107 | +"Find (if searchreplace plugin activated)": "\u67e5\u627e(\u5982\u679c\u67e5\u627e\u66ff\u6362\u63d2\u4ef6\u5df2\u6fc0\u6d3b)", | ||
108 | +"Plugins installed ({0}):": "\u5df2\u5b89\u88c5\u63d2\u4ef6 ({0}):", | ||
109 | +"Premium plugins:": "\u4f18\u79c0\u63d2\u4ef6\uff1a", | ||
110 | +"Learn more...": "\u4e86\u89e3\u66f4\u591a...", | ||
111 | +"You are using {0}": "\u4f60\u6b63\u5728\u4f7f\u7528 {0}", | ||
112 | +"Plugins": "\u63d2\u4ef6", | ||
113 | +"Handy Shortcuts": "\u5feb\u6377\u952e", | ||
114 | +"Horizontal line": "\u6c34\u5e73\u5206\u5272\u7ebf", | ||
115 | +"Insert\/edit image": "\u63d2\u5165\/\u7f16\u8f91\u56fe\u7247", | ||
116 | +"Image description": "\u56fe\u7247\u63cf\u8ff0", | ||
117 | +"Source": "\u5730\u5740", | ||
118 | +"Dimensions": "\u5927\u5c0f", | ||
119 | +"Constrain proportions": "\u4fdd\u6301\u7eb5\u6a2a\u6bd4", | ||
120 | +"General": "\u666e\u901a", | ||
121 | +"Advanced": "\u9ad8\u7ea7", | ||
122 | +"Style": "\u6837\u5f0f", | ||
123 | +"Vertical space": "\u5782\u76f4\u8fb9\u8ddd", | ||
124 | +"Horizontal space": "\u6c34\u5e73\u8fb9\u8ddd", | ||
125 | +"Border": "\u8fb9\u6846", | ||
126 | +"Insert image": "\u63d2\u5165\u56fe\u7247", | ||
127 | +"Image...": "\u56fe\u7247...", | ||
128 | +"Image list": "\u56fe\u7247\u5217\u8868", | ||
129 | +"Rotate counterclockwise": "\u9006\u65f6\u9488\u65cb\u8f6c", | ||
130 | +"Rotate clockwise": "\u987a\u65f6\u9488\u65cb\u8f6c", | ||
131 | +"Flip vertically": "\u5782\u76f4\u7ffb\u8f6c", | ||
132 | +"Flip horizontally": "\u6c34\u5e73\u7ffb\u8f6c", | ||
133 | +"Edit image": "\u7f16\u8f91\u56fe\u7247", | ||
134 | +"Image options": "\u56fe\u7247\u9009\u9879", | ||
135 | +"Zoom in": "\u653e\u5927", | ||
136 | +"Zoom out": "\u7f29\u5c0f", | ||
137 | +"Crop": "\u88c1\u526a", | ||
138 | +"Resize": "\u8c03\u6574\u5927\u5c0f", | ||
139 | +"Orientation": "\u65b9\u5411", | ||
140 | +"Brightness": "\u4eae\u5ea6", | ||
141 | +"Sharpen": "\u9510\u5316", | ||
142 | +"Contrast": "\u5bf9\u6bd4\u5ea6", | ||
143 | +"Color levels": "\u989c\u8272\u5c42\u6b21", | ||
144 | +"Gamma": "\u4f3d\u9a6c\u503c", | ||
145 | +"Invert": "\u53cd\u8f6c", | ||
146 | +"Apply": "\u5e94\u7528", | ||
147 | +"Back": "\u540e\u9000", | ||
148 | +"Insert date\/time": "\u63d2\u5165\u65e5\u671f\/\u65f6\u95f4", | ||
149 | +"Date\/time": "\u65e5\u671f\/\u65f6\u95f4", | ||
150 | +"Insert\/Edit Link": "\u63d2\u5165\/\u7f16\u8f91\u94fe\u63a5", | ||
151 | +"Insert\/edit link": "\u63d2\u5165\/\u7f16\u8f91\u94fe\u63a5", | ||
152 | +"Text to display": "\u663e\u793a\u6587\u5b57", | ||
153 | +"Url": "\u5730\u5740", | ||
154 | +"Open link in...": "\u94fe\u63a5\u6253\u5f00\u4f4d\u7f6e...", | ||
155 | +"Current window": "\u5f53\u524d\u7a97\u53e3", | ||
156 | +"None": "\u65e0", | ||
157 | +"New window": "\u5728\u65b0\u7a97\u53e3\u6253\u5f00", | ||
158 | +"Remove link": "\u5220\u9664\u94fe\u63a5", | ||
159 | +"Anchors": "\u951a\u70b9", | ||
160 | +"Link...": "\u94fe\u63a5...", | ||
161 | +"Paste or type a link": "\u7c98\u8d34\u6216\u8f93\u5165\u94fe\u63a5", | ||
162 | +"The URL you entered seems to be an email address. Do you want to add the required mailto: prefix?": "\u4f60\u6240\u586b\u5199\u7684URL\u5730\u5740\u4e3a\u90ae\u4ef6\u5730\u5740\uff0c\u9700\u8981\u52a0\u4e0amailto:\u524d\u7f00\u5417\uff1f", | ||
163 | +"The URL you entered seems to be an external link. Do you want to add the required http:\/\/ prefix?": "\u4f60\u6240\u586b\u5199\u7684URL\u5730\u5740\u5c5e\u4e8e\u5916\u90e8\u94fe\u63a5\uff0c\u9700\u8981\u52a0\u4e0ahttp:\/\/:\u524d\u7f00\u5417\uff1f", | ||
164 | +"Link list": "\u94fe\u63a5\u5217\u8868", | ||
165 | +"Insert video": "\u63d2\u5165\u89c6\u9891", | ||
166 | +"Insert\/edit video": "\u63d2\u5165\/\u7f16\u8f91\u89c6\u9891", | ||
167 | +"Insert\/edit media": "\u63d2\u5165\/\u7f16\u8f91\u5a92\u4f53", | ||
168 | +"Alternative source": "\u955c\u50cf", | ||
169 | +"Alternative source URL": "\u66ff\u4ee3\u6765\u6e90\u7f51\u5740", | ||
170 | +"Media poster (Image URL)": "\u5c01\u9762(\u56fe\u7247\u5730\u5740)", | ||
171 | +"Paste your embed code below:": "\u5c06\u5185\u5d4c\u4ee3\u7801\u7c98\u8d34\u5728\u4e0b\u9762:", | ||
172 | +"Embed": "\u5185\u5d4c", | ||
173 | +"Media...": "\u591a\u5a92\u4f53...", | ||
174 | +"Nonbreaking space": "\u4e0d\u95f4\u65ad\u7a7a\u683c", | ||
175 | +"Page break": "\u5206\u9875\u7b26", | ||
176 | +"Paste as text": "\u7c98\u8d34\u4e3a\u6587\u672c", | ||
177 | +"Preview": "\u9884\u89c8", | ||
178 | +"Print...": "\u6253\u5370...", | ||
179 | +"Save": "\u4fdd\u5b58", | ||
180 | +"Find": "\u67e5\u627e", | ||
181 | +"Replace with": "\u66ff\u6362\u4e3a", | ||
182 | +"Replace": "\u66ff\u6362", | ||
183 | +"Replace all": "\u5168\u90e8\u66ff\u6362", | ||
184 | +"Previous": "\u4e0a\u4e00\u4e2a", | ||
185 | +"Next": "\u4e0b\u4e00\u4e2a", | ||
186 | +"Find and replace...": "\u67e5\u627e\u5e76\u66ff\u6362...", | ||
187 | +"Could not find the specified string.": "\u672a\u627e\u5230\u641c\u7d22\u5185\u5bb9.", | ||
188 | +"Match case": "\u533a\u5206\u5927\u5c0f\u5199", | ||
189 | +"Find whole words only": "\u5168\u5b57\u5339\u914d", | ||
190 | +"Spell check": "\u62fc\u5199\u68c0\u67e5", | ||
191 | +"Ignore": "\u5ffd\u7565", | ||
192 | +"Ignore all": "\u5168\u90e8\u5ffd\u7565", | ||
193 | +"Finish": "\u5b8c\u6210", | ||
194 | +"Add to Dictionary": "\u6dfb\u52a0\u5230\u5b57\u5178", | ||
195 | +"Insert table": "\u63d2\u5165\u8868\u683c", | ||
196 | +"Table properties": "\u8868\u683c\u5c5e\u6027", | ||
197 | +"Delete table": "\u5220\u9664\u8868\u683c", | ||
198 | +"Cell": "\u5355\u5143\u683c", | ||
199 | +"Row": "\u884c", | ||
200 | +"Column": "\u5217", | ||
201 | +"Cell properties": "\u5355\u5143\u683c\u5c5e\u6027", | ||
202 | +"Merge cells": "\u5408\u5e76\u5355\u5143\u683c", | ||
203 | +"Split cell": "\u62c6\u5206\u5355\u5143\u683c", | ||
204 | +"Insert row before": "\u5728\u4e0a\u65b9\u63d2\u5165", | ||
205 | +"Insert row after": "\u5728\u4e0b\u65b9\u63d2\u5165", | ||
206 | +"Delete row": "\u5220\u9664\u884c", | ||
207 | +"Row properties": "\u884c\u5c5e\u6027", | ||
208 | +"Cut row": "\u526a\u5207\u884c", | ||
209 | +"Copy row": "\u590d\u5236\u884c", | ||
210 | +"Paste row before": "\u7c98\u8d34\u5230\u4e0a\u65b9", | ||
211 | +"Paste row after": "\u7c98\u8d34\u5230\u4e0b\u65b9", | ||
212 | +"Insert column before": "\u5728\u5de6\u4fa7\u63d2\u5165", | ||
213 | +"Insert column after": "\u5728\u53f3\u4fa7\u63d2\u5165", | ||
214 | +"Delete column": "\u5220\u9664\u5217", | ||
215 | +"Cols": "\u5217", | ||
216 | +"Rows": "\u884c", | ||
217 | +"Width": "\u5bbd", | ||
218 | +"Height": "\u9ad8", | ||
219 | +"Cell spacing": "\u5355\u5143\u683c\u5916\u95f4\u8ddd", | ||
220 | +"Cell padding": "\u5355\u5143\u683c\u5185\u8fb9\u8ddd", | ||
221 | +"Show caption": "\u663e\u793a\u6807\u9898", | ||
222 | +"Left": "\u5de6\u5bf9\u9f50", | ||
223 | +"Center": "\u5c45\u4e2d", | ||
224 | +"Right": "\u53f3\u5bf9\u9f50", | ||
225 | +"Cell type": "\u5355\u5143\u683c\u7c7b\u578b", | ||
226 | +"Scope": "\u8303\u56f4", | ||
227 | +"Alignment": "\u5bf9\u9f50\u65b9\u5f0f", | ||
228 | +"H Align": "\u6c34\u5e73\u5bf9\u9f50", | ||
229 | +"V Align": "\u5782\u76f4\u5bf9\u9f50", | ||
230 | +"Top": "\u9876\u90e8\u5bf9\u9f50", | ||
231 | +"Middle": "\u5782\u76f4\u5c45\u4e2d", | ||
232 | +"Bottom": "\u5e95\u90e8\u5bf9\u9f50", | ||
233 | +"Header cell": "\u8868\u5934\u5355\u5143\u683c", | ||
234 | +"Row group": "\u884c\u7ec4", | ||
235 | +"Column group": "\u5217\u7ec4", | ||
236 | +"Row type": "\u884c\u7c7b\u578b", | ||
237 | +"Header": "\u8868\u5934", | ||
238 | +"Body": "\u8868\u4f53", | ||
239 | +"Footer": "\u8868\u5c3e", | ||
240 | +"Border color": "\u8fb9\u6846\u989c\u8272", | ||
241 | +"Insert template...": "\u63d2\u5165\u6a21\u677f...", | ||
242 | +"Templates": "\u6a21\u677f", | ||
243 | +"Template": "\u6a21\u677f", | ||
244 | +"Text color": "\u6587\u5b57\u989c\u8272", | ||
245 | +"Background color": "\u80cc\u666f\u8272", | ||
246 | +"Custom...": "\u81ea\u5b9a\u4e49...", | ||
247 | +"Custom color": "\u81ea\u5b9a\u4e49\u989c\u8272", | ||
248 | +"No color": "\u65e0", | ||
249 | +"Remove color": "\u79fb\u9664\u989c\u8272", | ||
250 | +"Table of Contents": "\u5185\u5bb9\u5217\u8868", | ||
251 | +"Show blocks": "\u663e\u793a\u533a\u5757\u8fb9\u6846", | ||
252 | +"Show invisible characters": "\u663e\u793a\u4e0d\u53ef\u89c1\u5b57\u7b26", | ||
253 | +"Word count": "\u5b57\u6570", | ||
254 | +"Words: {0}": "\u5b57\u6570\uff1a{0}", | ||
255 | +"{0} words": "{0} \u5b57", | ||
256 | +"File": "\u6587\u4ef6", | ||
257 | +"Edit": "\u7f16\u8f91", | ||
258 | +"Insert": "\u63d2\u5165", | ||
259 | +"View": "\u89c6\u56fe", | ||
260 | +"Format": "\u683c\u5f0f", | ||
261 | +"Table": "\u8868\u683c", | ||
262 | +"Tools": "\u5de5\u5177", | ||
263 | +"Powered by {0}": "\u7531{0}\u9a71\u52a8", | ||
264 | +"Rich Text Area. Press ALT-F9 for menu. Press ALT-F10 for toolbar. Press ALT-0 for help": "\u5728\u7f16\u8f91\u533a\u6309ALT-F9\u6253\u5f00\u83dc\u5355\uff0c\u6309ALT-F10\u6253\u5f00\u5de5\u5177\u680f\uff0c\u6309ALT-0\u67e5\u770b\u5e2e\u52a9", | ||
265 | +"Image title": "\u56fe\u7247\u6807\u9898", | ||
266 | +"Border width": "\u8fb9\u6846\u5bbd\u5ea6", | ||
267 | +"Border style": "\u8fb9\u6846\u6837\u5f0f", | ||
268 | +"Error": "\u9519\u8bef", | ||
269 | +"Warn": "\u8b66\u544a", | ||
270 | +"Valid": "\u6709\u6548", | ||
271 | +"To open the popup, press Shift+Enter": "\u6309Shitf+Enter\u952e\u6253\u5f00\u5bf9\u8bdd\u6846", | ||
272 | +"Rich Text Area. Press ALT-0 for help.": "\u7f16\u8f91\u533a\u3002\u6309Alt+0\u952e\u6253\u5f00\u5e2e\u52a9\u3002", | ||
273 | +"System Font": "\u7cfb\u7edf\u5b57\u4f53", | ||
274 | +"Failed to upload image: {0}": "\u56fe\u7247\u4e0a\u4f20\u5931\u8d25: {0}", | ||
275 | +"Failed to load plugin: {0} from url {1}": "\u63d2\u4ef6\u52a0\u8f7d\u5931\u8d25: {0} \u6765\u81ea\u94fe\u63a5 {1}", | ||
276 | +"Failed to load plugin url: {0}": "\u63d2\u4ef6\u52a0\u8f7d\u5931\u8d25 \u94fe\u63a5: {0}", | ||
277 | +"Failed to initialize plugin: {0}": "\u63d2\u4ef6\u521d\u59cb\u5316\u5931\u8d25: {0}", | ||
278 | +"example": "\u793a\u4f8b", | ||
279 | +"Search": "\u641c\u7d22", | ||
280 | +"All": "\u5168\u90e8", | ||
281 | +"Currency": "\u8d27\u5e01", | ||
282 | +"Text": "\u6587\u5b57", | ||
283 | +"Quotations": "\u5f15\u7528", | ||
284 | +"Mathematical": "\u6570\u5b66", | ||
285 | +"Extended Latin": "\u62c9\u4e01\u8bed\u6269\u5145", | ||
286 | +"Symbols": "\u7b26\u53f7", | ||
287 | +"Arrows": "\u7bad\u5934", | ||
288 | +"User Defined": "\u81ea\u5b9a\u4e49", | ||
289 | +"dollar sign": "\u7f8e\u5143\u7b26\u53f7", | ||
290 | +"currency sign": "\u8d27\u5e01\u7b26\u53f7", | ||
291 | +"euro-currency sign": "\u6b27\u5143\u7b26\u53f7", | ||
292 | +"colon sign": "\u5192\u53f7", | ||
293 | +"cruzeiro sign": "\u514b\u9c81\u8d5b\u7f57\u5e01\u7b26\u53f7", | ||
294 | +"french franc sign": "\u6cd5\u90ce\u7b26\u53f7", | ||
295 | +"lira sign": "\u91cc\u62c9\u7b26\u53f7", | ||
296 | +"mill sign": "\u5bc6\u5c14\u7b26\u53f7", | ||
297 | +"naira sign": "\u5948\u62c9\u7b26\u53f7", | ||
298 | +"peseta sign": "\u6bd4\u585e\u5854\u7b26\u53f7", | ||
299 | +"rupee sign": "\u5362\u6bd4\u7b26\u53f7", | ||
300 | +"won sign": "\u97e9\u5143\u7b26\u53f7", | ||
301 | +"new sheqel sign": "\u65b0\u8c22\u514b\u5c14\u7b26\u53f7", | ||
302 | +"dong sign": "\u8d8a\u5357\u76fe\u7b26\u53f7", | ||
303 | +"kip sign": "\u8001\u631d\u57fa\u666e\u7b26\u53f7", | ||
304 | +"tugrik sign": "\u56fe\u683c\u91cc\u514b\u7b26\u53f7", | ||
305 | +"drachma sign": "\u5fb7\u62c9\u514b\u9a6c\u7b26\u53f7", | ||
306 | +"german penny symbol": "\u5fb7\u56fd\u4fbf\u58eb\u7b26\u53f7", | ||
307 | +"peso sign": "\u6bd4\u7d22\u7b26\u53f7", | ||
308 | +"guarani sign": "\u74dc\u62c9\u5c3c\u7b26\u53f7", | ||
309 | +"austral sign": "\u6fb3\u5143\u7b26\u53f7", | ||
310 | +"hryvnia sign": "\u683c\u91cc\u592b\u5c3c\u4e9a\u7b26\u53f7", | ||
311 | +"cedi sign": "\u585e\u5730\u7b26\u53f7", | ||
312 | +"livre tournois sign": "\u91cc\u5f17\u5f17\u5c14\u7b26\u53f7", | ||
313 | +"spesmilo sign": "spesmilo\u7b26\u53f7", | ||
314 | +"tenge sign": "\u575a\u6208\u7b26\u53f7", | ||
315 | +"indian rupee sign": "\u5370\u5ea6\u5362\u6bd4", | ||
316 | +"turkish lira sign": "\u571f\u8033\u5176\u91cc\u62c9", | ||
317 | +"nordic mark sign": "\u5317\u6b27\u9a6c\u514b", | ||
318 | +"manat sign": "\u9a6c\u7eb3\u7279\u7b26\u53f7", | ||
319 | +"ruble sign": "\u5362\u5e03\u7b26\u53f7", | ||
320 | +"yen character": "\u65e5\u5143\u5b57\u6837", | ||
321 | +"yuan character": "\u4eba\u6c11\u5e01\u5143\u5b57\u6837", | ||
322 | +"yuan character, in hong kong and taiwan": "\u5143\u5b57\u6837\uff08\u6e2f\u53f0\u5730\u533a\uff09", | ||
323 | +"yen\/yuan character variant one": "\u5143\u5b57\u6837\uff08\u5927\u5199\uff09", | ||
324 | +"Loading emoticons...": "\u52a0\u8f7d\u8868\u60c5\u7b26\u53f7...", | ||
325 | +"Could not load emoticons": "\u4e0d\u80fd\u52a0\u8f7d\u8868\u60c5\u7b26\u53f7", | ||
326 | +"People": "\u4eba\u7c7b", | ||
327 | +"Animals and Nature": "\u52a8\u7269\u548c\u81ea\u7136", | ||
328 | +"Food and Drink": "\u98df\u7269\u548c\u996e\u54c1", | ||
329 | +"Activity": "\u6d3b\u52a8", | ||
330 | +"Travel and Places": "\u65c5\u6e38\u548c\u5730\u70b9", | ||
331 | +"Objects": "\u7269\u4ef6", | ||
332 | +"Flags": "\u65d7\u5e1c", | ||
333 | +"Characters": "\u5b57\u7b26", | ||
334 | +"Characters (no spaces)": "\u5b57\u7b26(\u65e0\u7a7a\u683c)", | ||
335 | +"Error: Form submit field collision.": "\u9519\u8bef: \u8868\u5355\u63d0\u4ea4\u5b57\u6bb5\u51b2\u7a81\u3002", | ||
336 | +"Error: No form element found.": "\u9519\u8bef: \u6ca1\u6709\u8868\u5355\u63a7\u4ef6\u3002", | ||
337 | +"Update": "\u66f4\u65b0", | ||
338 | +"Color swatch": "\u989c\u8272\u6837\u672c", | ||
339 | +"Turquoise": "\u9752\u7eff\u8272", | ||
340 | +"Green": "\u7eff\u8272", | ||
341 | +"Blue": "\u84dd\u8272", | ||
342 | +"Purple": "\u7d2b\u8272", | ||
343 | +"Navy Blue": "\u6d77\u519b\u84dd", | ||
344 | +"Dark Turquoise": "\u6df1\u84dd\u7eff\u8272", | ||
345 | +"Dark Green": "\u6df1\u7eff\u8272", | ||
346 | +"Medium Blue": "\u4e2d\u84dd\u8272", | ||
347 | +"Medium Purple": "\u4e2d\u7d2b\u8272", | ||
348 | +"Midnight Blue": "\u6df1\u84dd\u8272", | ||
349 | +"Yellow": "\u9ec4\u8272", | ||
350 | +"Orange": "\u6a59\u8272", | ||
351 | +"Red": "\u7ea2\u8272", | ||
352 | +"Light Gray": "\u6d45\u7070\u8272", | ||
353 | +"Gray": "\u7070\u8272", | ||
354 | +"Dark Yellow": "\u6697\u9ec4\u8272", | ||
355 | +"Dark Orange": "\u6df1\u6a59\u8272", | ||
356 | +"Dark Red": "\u6df1\u7ea2\u8272", | ||
357 | +"Medium Gray": "\u4e2d\u7070\u8272", | ||
358 | +"Dark Gray": "\u6df1\u7070\u8272", | ||
359 | +"Black": "\u9ed1\u8272", | ||
360 | +"White": "\u767d\u8272", | ||
361 | +"Switch to or from fullscreen mode": "\u5207\u6362\u5168\u5c4f\u6a21\u5f0f", | ||
362 | +"Open help dialog": "\u6253\u5f00\u5e2e\u52a9\u5bf9\u8bdd\u6846", | ||
363 | +"history": "\u5386\u53f2", | ||
364 | +"styles": "\u6837\u5f0f", | ||
365 | +"formatting": "\u683c\u5f0f\u5316", | ||
366 | +"alignment": "\u5bf9\u9f50", | ||
367 | +"indentation": "\u7f29\u8fdb", | ||
368 | +"permanent pen": "\u8bb0\u53f7\u7b14", | ||
369 | +"comments": "\u5907\u6ce8", | ||
370 | +"Anchor": "\u951a\u70b9", | ||
371 | +"Special character": "\u7279\u6b8a\u7b26\u53f7", | ||
372 | +"Code sample": "\u4ee3\u7801\u793a\u4f8b", | ||
373 | +"Color": "\u989c\u8272", | ||
374 | +"Emoticons": "\u8868\u60c5", | ||
375 | +"Document properties": "\u6587\u6863\u5c5e\u6027", | ||
376 | +"Image": "\u56fe\u7247", | ||
377 | +"Insert link": "\u63d2\u5165\u94fe\u63a5", | ||
378 | +"Target": "\u6253\u5f00\u65b9\u5f0f", | ||
379 | +"Link": "\u94fe\u63a5", | ||
380 | +"Poster": "\u5c01\u9762", | ||
381 | +"Media": "\u5a92\u4f53", | ||
382 | +"Print": "\u6253\u5370", | ||
383 | +"Prev": "\u4e0a\u4e00\u4e2a", | ||
384 | +"Find and replace": "\u67e5\u627e\u548c\u66ff\u6362", | ||
385 | +"Whole words": "\u5168\u5b57\u5339\u914d", | ||
386 | +"Spellcheck": "\u62fc\u5199\u68c0\u67e5", | ||
387 | +"Caption": "\u6807\u9898", | ||
388 | +"Insert template": "\u63d2\u5165\u6a21\u677f" | ||
389 | +}); |
1 | +/** | ||
2 | + * Copyright (c) Tiny Technologies, Inc. All rights reserved. | ||
3 | + * Licensed under the LGPL or a commercial license. | ||
4 | + * For LGPL see License.txt in the project root for license information. | ||
5 | + * For commercial licenses see https://www.tiny.cloud/ | ||
6 | + */ | ||
7 | +.mce-content-body .mce-item-anchor{display: inline-block;width: 8px !important;height: 12px !important;padding: 0 2px;cursor: default;background: transparent url("data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D'8'%20height%3D'12'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%3E%3Cpath%20d%3D'M0%200L8%200%208%2012%204.09117821%209%200%2012z'%2F%3E%3C%2Fsvg%3E%0A") no-repeat center;-webkit-user-select: all;-moz-user-select: all;-ms-user-select: all;user-select: all;-webkit-user-modify: read-only;-moz-user-modify: read-only;} | ||
8 | + | ||
9 | +.mce-content-body .mce-item-anchor[data-mce-selected]{outline-offset: 1px;} | ||
10 | + | ||
11 | +.tox-comments-visible .tox-comment{background-color: #fff0b7;} | ||
12 | + | ||
13 | +.tox-comments-visible .tox-comment--active{background-color: #ffe168;} | ||
14 | + | ||
15 | +.tox-checklist>li:not(.tox-checklist--hidden){margin: .25em 0;list-style: none;} | ||
16 | + | ||
17 | +.tox-checklist>li:not(.tox-checklist--hidden)::before{position: absolute;width: 1em;height: 1em;margin-top: .125em;margin-left: -1.5em;cursor: pointer;background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2216%22%20height%3D%2216%22%20viewBox%3D%220%200%2016%2016%22%3E%3Cg%20id%3D%22checklist-unchecked%22%20fill%3D%22none%22%20fill-rule%3D%22evenodd%22%3E%3Crect%20id%3D%22Rectangle%22%20width%3D%2215%22%20height%3D%2215%22%20x%3D%22.5%22%20y%3D%22.5%22%20fill-rule%3D%22nonzero%22%20stroke%3D%22%234C4C4C%22%20rx%3D%222%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E%0A");background-size: 100%;content: '';} | ||
18 | + | ||
19 | +.tox-checklist li:not(.tox-checklist--hidden).tox-checklist--checked::before{background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2216%22%20height%3D%2216%22%20viewBox%3D%220%200%2016%2016%22%3E%3Cg%20id%3D%22checklist-checked%22%20fill%3D%22none%22%20fill-rule%3D%22evenodd%22%3E%3Crect%20id%3D%22Rectangle%22%20width%3D%2216%22%20height%3D%2216%22%20fill%3D%22%234099FF%22%20fill-rule%3D%22nonzero%22%20rx%3D%222%22%2F%3E%3Cpath%20id%3D%22Path%22%20fill%3D%22%23FFF%22%20fill-rule%3D%22nonzero%22%20d%3D%22M11.5703186%2C3.14417309%20C11.8516238%2C2.73724603%2012.4164781%2C2.62829933%2012.83558%2C2.89774797%20C13.260121%2C3.17069355%2013.3759736%2C3.72932262%2013.0909105%2C4.14168582%20L7.7580587%2C11.8560195%20C7.43776896%2C12.3193404%206.76483983%2C12.3852142%206.35607322%2C11.9948725%20L3.02491697%2C8.8138662%20C2.66090143%2C8.46625845%202.65798871%2C7.89594698%203.01850234%2C7.54483354%20C3.373942%2C7.19866177%203.94940006%2C7.19592841%204.30829608%2C7.5386474%20L6.85276923%2C9.9684299%20L11.5703186%2C3.14417309%20Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E%0A");} | ||
20 | + | ||
21 | +[dir=rtl] .tox-checklist>li:not(.tox-checklist--hidden)::before{margin-right: -1.5em;margin-left: 0;} | ||
22 | + | ||
23 | +code[class*=language-],pre[class*=language-]{font-family: Consolas,Monaco,'Andale Mono','Ubuntu Mono',monospace;font-size: .875rem;-webkit-hyphens: none;-ms-hyphens: none;hyphens: none;line-height: 1.5;word-spacing: normal;color: #000;text-shadow: 0 1px #fff;word-break: normal;word-wrap: normal;white-space: pre;-moz-tab-size: 4;tab-size: 4;} | ||
24 | + | ||
25 | +code[class*=language-] ::-moz-selection,code[class*=language-]::-moz-selection,pre[class*=language-] ::-moz-selection,pre[class*=language-]::-moz-selection{text-shadow: none;background: #b3d4fc;} | ||
26 | + | ||
27 | +code[class*=language-] ::selection,code[class*=language-]::selection,pre[class*=language-] ::selection,pre[class*=language-]::selection{text-shadow: none;background: #b3d4fc;}@media print{code[class*=language-],pre[class*=language-]{text-shadow: none;}} | ||
28 | + | ||
29 | +pre[class*=language-]{padding: 1em;margin: .5em 0;overflow: auto;} | ||
30 | + | ||
31 | +:not(pre)>code[class*=language-],pre[class*=language-]{background: 0 0 !important;border: 1px solid #ccc;} | ||
32 | + | ||
33 | +:not(pre)>code[class*=language-]{padding: .1em;border-radius: .3em;} | ||
34 | + | ||
35 | +.token.cdata,.token.comment,.token.doctype,.token.prolog{color: #708090;} | ||
36 | + | ||
37 | +.token.punctuation{color: #999;} | ||
38 | + | ||
39 | +.namespace{opacity: .7;} | ||
40 | + | ||
41 | +.token.boolean,.token.constant,.token.deleted,.token.number,.token.property,.token.symbol,.token.tag{color: #905;} | ||
42 | + | ||
43 | +.token.attr-name,.token.builtin,.token.char,.token.inserted,.token.selector,.token.string{color: #690;} | ||
44 | + | ||
45 | +.language-css .token.string,.style .token.string,.token.entity,.token.operator,.token.url{color: #a67f59;background: hsla(0,0%,100%,.5);} | ||
46 | + | ||
47 | +.token.atrule,.token.attr-value,.token.keyword{color: #07a;} | ||
48 | + | ||
49 | +.token.function{color: #dd4a68;} | ||
50 | + | ||
51 | +.token.important,.token.regex,.token.variable{color: #e90;} | ||
52 | + | ||
53 | +.token.bold,.token.important{font-weight: 700;} | ||
54 | + | ||
55 | +.token.italic{font-style: italic;} | ||
56 | + | ||
57 | +.token.entity{cursor: help;} | ||
58 | + | ||
59 | +:not([dir=rtl]) code[class*=language-],:not([dir=rtl]) pre[class*=language-]{text-align: left;direction: ltr;} | ||
60 | + | ||
61 | +[dir=rtl] code[class*=language-],[dir=rtl] pre[class*=language-]{text-align: right;direction: rtl;} | ||
62 | + | ||
63 | +.mce-content-body{overflow-wrap: break-word;word-wrap: break-word;} | ||
64 | + | ||
65 | +.mce-content-body .mce-visual-caret{position: absolute;background-color: #000;background-color: currentColor;} | ||
66 | + | ||
67 | +.mce-content-body .mce-visual-caret-hidden{display: none;} | ||
68 | + | ||
69 | +.mce-content-body [data-mce-caret]{position: absolute;top: 0;right: auto;left: -1000px;padding: 0;margin: 0;} | ||
70 | + | ||
71 | +.mce-content-body .mce-offscreen-selection{position: absolute;left: -9999999999px;max-width: 1000000px;} | ||
72 | + | ||
73 | +.mce-content-body [contentEditable=false]{cursor: default;} | ||
74 | + | ||
75 | +.mce-content-body [contentEditable=true]{cursor: text;} | ||
76 | + | ||
77 | +.tox-cursor-format-painter{cursor: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%3E%0A%20%20%3Cg%20fill%3D%22none%22%20fill-rule%3D%22evenodd%22%3E%0A%20%20%20%20%3Cpath%20fill%3D%22%23000%22%20fill-rule%3D%22nonzero%22%20d%3D%22M15%2C6%20C15%2C5.45%2014.55%2C5%2014%2C5%20L6%2C5%20C5.45%2C5%205%2C5.45%205%2C6%20L5%2C10%20C5%2C10.55%205.45%2C11%206%2C11%20L14%2C11%20C14.55%2C11%2015%2C10.55%2015%2C10%20L15%2C9%20L16%2C9%20L16%2C12%20L9%2C12%20L9%2C19%20C9%2C19.55%209.45%2C20%2010%2C20%20L11%2C20%20C11.55%2C20%2012%2C19.55%2012%2C19%20L12%2C14%20L18%2C14%20L18%2C7%20L15%2C7%20L15%2C6%20Z%22%2F%3E%0A%20%20%20%20%3Cpath%20fill%3D%22%23000%22%20fill-rule%3D%22nonzero%22%20d%3D%22M1%2C1%20L8.25%2C1%20C8.66421356%2C1%209%2C1.33578644%209%2C1.75%20L9%2C1.75%20C9%2C2.16421356%208.66421356%2C2.5%208.25%2C2.5%20L2.5%2C2.5%20L2.5%2C8.25%20C2.5%2C8.66421356%202.16421356%2C9%201.75%2C9%20L1.75%2C9%20C1.33578644%2C9%201%2C8.66421356%201%2C8.25%20L1%2C1%20Z%22%2F%3E%0A%20%20%3C%2Fg%3E%0A%3C%2Fsvg%3E%0A"),default;} | ||
78 | + | ||
79 | +.mce-content-body figure.align-left{float: left;} | ||
80 | + | ||
81 | +.mce-content-body figure.align-right{float: right;} | ||
82 | + | ||
83 | +.mce-content-body figure.image.align-center{display: table;margin-right: auto;margin-left: auto;} | ||
84 | + | ||
85 | +.mce-preview-object{position: relative;display: inline-block;margin: 0 2px 0 2px;line-height: 0;border: 1px solid gray;} | ||
86 | + | ||
87 | +.mce-preview-object .mce-shim{position: absolute;top: 0;left: 0;width: 100%;height: 100%;background: url();} | ||
88 | + | ||
89 | +.mce-preview-object[data-mce-selected="2"] .mce-shim{display: none;} | ||
90 | + | ||
91 | +.mce-object{background: transparent url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%3E%3Cpath%20d%3D%22M4%203h16a1%201%200%200%201%201%201v16a1%201%200%200%201-1%201H4a1%201%200%200%201-1-1V4a1%201%200%200%201%201-1zm1%202v14h14V5H5zm4.79%202.565l5.64%204.028a.5.5%200%200%201%200%20.814l-5.64%204.028a.5.5%200%200%201-.79-.407V7.972a.5.5%200%200%201%20.79-.407z%22%2F%3E%3C%2Fsvg%3E%0A") no-repeat center;border: 1px dashed #aaa;} | ||
92 | + | ||
93 | +.mce-pagebreak{display: block;width: 100%;height: 5px;margin-top: 15px;cursor: default;border: 1px dashed #aaa;page-break-before: always;}@media print{.mce-pagebreak{border: 0;}} | ||
94 | + | ||
95 | +.tiny-pageembed .mce-shim{position: absolute;top: 0;left: 0;width: 100%;height: 100%;background: url();} | ||
96 | + | ||
97 | +.tiny-pageembed[data-mce-selected="2"] .mce-shim{display: none;} | ||
98 | + | ||
99 | +.tiny-pageembed{position: relative;display: inline-block;} | ||
100 | + | ||
101 | +.tiny-pageembed--16by9,.tiny-pageembed--1by1,.tiny-pageembed--21by9,.tiny-pageembed--4by3{position: relative;display: block;width: 100%;padding: 0;overflow: hidden;} | ||
102 | + | ||
103 | +.tiny-pageembed--16by9::before,.tiny-pageembed--1by1::before,.tiny-pageembed--21by9::before,.tiny-pageembed--4by3::before{display: block;content: "";} | ||
104 | + | ||
105 | +.tiny-pageembed--21by9::before{padding-top: 42.857143%;} | ||
106 | + | ||
107 | +.tiny-pageembed--16by9::before{padding-top: 56.25%;} | ||
108 | + | ||
109 | +.tiny-pageembed--4by3::before{padding-top: 75%;} | ||
110 | + | ||
111 | +.tiny-pageembed--1by1::before{padding-top: 100%;} | ||
112 | + | ||
113 | +.tiny-pageembed--16by9 iframe,.tiny-pageembed--1by1 iframe,.tiny-pageembed--21by9 iframe,.tiny-pageembed--4by3 iframe{position: absolute;top: 0;left: 0;width: 100%;height: 100%;border: 0;} | ||
114 | + | ||
115 | +.mce-content-body div.mce-resizehandle{position: absolute;z-index: 10000;width: 10px;height: 10px;background-color: #4099ff;border-color: #4099ff;border-style: solid;border-width: 1px;box-sizing: border-box;} | ||
116 | + | ||
117 | +.mce-content-body div.mce-resizehandle:hover{background-color: #4099ff;} | ||
118 | + | ||
119 | +.mce-content-body div.mce-resizehandle:nth-of-type(1){cursor: nwse-resize;} | ||
120 | + | ||
121 | +.mce-content-body div.mce-resizehandle:nth-of-type(2){cursor: nesw-resize;} | ||
122 | + | ||
123 | +.mce-content-body div.mce-resizehandle:nth-of-type(3){cursor: nwse-resize;} | ||
124 | + | ||
125 | +.mce-content-body div.mce-resizehandle:nth-of-type(4){cursor: nesw-resize;} | ||
126 | + | ||
127 | +.mce-content-body .mce-clonedresizable{position: absolute;z-index: 10000;outline: 1px dashed #000;opacity: .5;} | ||
128 | + | ||
129 | +.mce-content-body .mce-resize-helper{position: absolute;z-index: 10001;display: none;padding: 5px;margin: 5px 10px;font-family: sans-serif;font-size: 12px;line-height: 14px;color: #fff;white-space: nowrap;background: #555;background: rgba(0,0,0,.75);border: 1px;border-radius: 3px;} | ||
130 | + | ||
131 | +.mce-match-marker{color: #fff;background: #aaa;} | ||
132 | + | ||
133 | +.mce-match-marker-selected{color: #fff;background: #39f;} | ||
134 | + | ||
135 | +.mce-content-body img[data-mce-selected],.mce-content-body table[data-mce-selected]{outline: 3px solid #b4d7ff;} | ||
136 | + | ||
137 | +.mce-content-body hr[data-mce-selected]{outline: 3px solid #b4d7ff;outline-offset: 1px;} | ||
138 | + | ||
139 | +.mce-content-body [contentEditable=false] [contentEditable=true]:focus{outline: 3px solid #b4d7ff;} | ||
140 | + | ||
141 | +.mce-content-body [contentEditable=false] [contentEditable=true]:hover{outline: 3px solid #b4d7ff;} | ||
142 | + | ||
143 | +.mce-content-body [contentEditable=false][data-mce-selected]{cursor: not-allowed;outline: 3px solid #b4d7ff;} | ||
144 | + | ||
145 | +.mce-content-body.mce-content-readonly [contentEditable=true]:focus,.mce-content-body.mce-content-readonly [contentEditable=true]:hover{outline: 0;} | ||
146 | + | ||
147 | +.mce-content-body [data-mce-selected=inline-boundary]{background-color: #b4d7ff;} | ||
148 | + | ||
149 | +.mce-content-body .mce-edit-focus{outline: 3px solid #b4d7ff;} | ||
150 | + | ||
151 | +.mce-content-body td[data-mce-selected],.mce-content-body th[data-mce-selected]{background-color: #b4d7ff !important;} | ||
152 | + | ||
153 | +.mce-content-body td[data-mce-selected]::-moz-selection,.mce-content-body th[data-mce-selected]::-moz-selection{background: 0 0;} | ||
154 | + | ||
155 | +.mce-content-body td[data-mce-selected]::selection,.mce-content-body th[data-mce-selected]::selection{background: 0 0;} | ||
156 | + | ||
157 | +.mce-content-body td[data-mce-selected] *,.mce-content-body th[data-mce-selected] *{-webkit-touch-callout: none;-webkit-user-select: none;-moz-user-select: none;-ms-user-select: none;user-select: none;} | ||
158 | + | ||
159 | +.mce-content-body img::-moz-selection{background: 0 0;} | ||
160 | + | ||
161 | +.mce-content-body img::selection{background: 0 0;} | ||
162 | + | ||
163 | +.ephox-snooker-resizer-bar{background-color: #b4d7ff;opacity: 0;} | ||
164 | + | ||
165 | +.ephox-snooker-resizer-cols{cursor: col-resize;} | ||
166 | + | ||
167 | +.ephox-snooker-resizer-rows{cursor: row-resize;} | ||
168 | + | ||
169 | +.ephox-snooker-resizer-bar.ephox-snooker-resizer-bar-dragging{opacity: 1;} | ||
170 | + | ||
171 | +.mce-spellchecker-word{height: 2rem;cursor: default;background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D'4'%20height%3D'4'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%3E%3Cpath%20stroke%3D'%23ff0000'%20fill%3D'none'%20stroke-linecap%3D'round'%20stroke-opacity%3D'.5'%20d%3D'M0%203L2%201%204%203'%2F%3E%3C%2Fsvg%3E%0A");background-position: 0 calc(100% + 1px);background-repeat: repeat-x;background-size: auto 6px;} | ||
172 | + | ||
173 | +.mce-spellchecker-grammar{cursor: default;background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D'4'%20height%3D'4'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%3E%3Cpath%20stroke%3D'%23008800'%20fill%3D'none'%20stroke-linecap%3D'round'%20d%3D'M0%203L2%201%204%203'%2F%3E%3C%2Fsvg%3E%0A");background-position: 0 calc(100% + 1px);background-repeat: repeat-x;background-size: auto 6px;} | ||
174 | + | ||
175 | +.mce-toc{border: 1px solid gray;} | ||
176 | + | ||
177 | +.mce-toc h2{margin: 4px;} | ||
178 | + | ||
179 | +.mce-toc li{list-style-type: none;} | ||
180 | + | ||
181 | +.mce-item-table,.mce-item-table caption,.mce-item-table td,.mce-item-table th{border: 1px dashed #bbb;} | ||
182 | + | ||
183 | +.mce-visualblocks address,.mce-visualblocks article,.mce-visualblocks aside,.mce-visualblocks blockquote,.mce-visualblocks div:not([data-mce-bogus]),.mce-visualblocks dl,.mce-visualblocks figcaption,.mce-visualblocks figure,.mce-visualblocks h1,.mce-visualblocks h2,.mce-visualblocks h3,.mce-visualblocks h4,.mce-visualblocks h5,.mce-visualblocks h6,.mce-visualblocks hgroup,.mce-visualblocks ol,.mce-visualblocks p,.mce-visualblocks pre,.mce-visualblocks section,.mce-visualblocks ul{padding-top: 10px;margin-left: 3px;background-repeat: no-repeat;border: 1px dashed #bbb;} | ||
184 | + | ||
185 | +.mce-visualblocks p{background-image: url();} | ||
186 | + | ||
187 | +.mce-visualblocks h1{background-image: url();} | ||
188 | + | ||
189 | +.mce-visualblocks h2{background-image: url();} | ||
190 | + | ||
191 | +.mce-visualblocks h3{background-image: url();} | ||
192 | + | ||
193 | +.mce-visualblocks h4{background-image: url();} | ||
194 | + | ||
195 | +.mce-visualblocks h5{background-image: url();} | ||
196 | + | ||
197 | +.mce-visualblocks h6{background-image: url();} | ||
198 | + | ||
199 | +.mce-visualblocks div:not([data-mce-bogus]){background-image: url();} | ||
200 | + | ||
201 | +.mce-visualblocks section{background-image: url();} | ||
202 | + | ||
203 | +.mce-visualblocks article{background-image: url();} | ||
204 | + | ||
205 | +.mce-visualblocks blockquote{background-image: url();} | ||
206 | + | ||
207 | +.mce-visualblocks address{background-image: url();} | ||
208 | + | ||
209 | +.mce-visualblocks pre{background-image: url();} | ||
210 | + | ||
211 | +.mce-visualblocks figure{background-image: url();} | ||
212 | + | ||
213 | +.mce-visualblocks figcaption{border: 1px dashed #bbb;} | ||
214 | + | ||
215 | +.mce-visualblocks hgroup{background-image: url();} | ||
216 | + | ||
217 | +.mce-visualblocks aside{background-image: url();} | ||
218 | + | ||
219 | +.mce-visualblocks ul{background-image: url();} | ||
220 | + | ||
221 | +.mce-visualblocks ol{background-image: url();} | ||
222 | + | ||
223 | +.mce-visualblocks dl{background-image: url();} | ||
224 | + | ||
225 | +.mce-visualblocks:not([dir=rtl]) address,.mce-visualblocks:not([dir=rtl]) article,.mce-visualblocks:not([dir=rtl]) aside,.mce-visualblocks:not([dir=rtl]) blockquote,.mce-visualblocks:not([dir=rtl]) div:not([data-mce-bogus]),.mce-visualblocks:not([dir=rtl]) dl,.mce-visualblocks:not([dir=rtl]) figcaption,.mce-visualblocks:not([dir=rtl]) figure,.mce-visualblocks:not([dir=rtl]) h1,.mce-visualblocks:not([dir=rtl]) h2,.mce-visualblocks:not([dir=rtl]) h3,.mce-visualblocks:not([dir=rtl]) h4,.mce-visualblocks:not([dir=rtl]) h5,.mce-visualblocks:not([dir=rtl]) h6,.mce-visualblocks:not([dir=rtl]) hgroup,.mce-visualblocks:not([dir=rtl]) ol,.mce-visualblocks:not([dir=rtl]) p,.mce-visualblocks:not([dir=rtl]) pre,.mce-visualblocks:not([dir=rtl]) section,.mce-visualblocks:not([dir=rtl]) ul{margin-left: 3px;} | ||
226 | + | ||
227 | +.mce-visualblocks[dir=rtl] address,.mce-visualblocks[dir=rtl] article,.mce-visualblocks[dir=rtl] aside,.mce-visualblocks[dir=rtl] blockquote,.mce-visualblocks[dir=rtl] div:not([data-mce-bogus]),.mce-visualblocks[dir=rtl] dl,.mce-visualblocks[dir=rtl] figcaption,.mce-visualblocks[dir=rtl] figure,.mce-visualblocks[dir=rtl] h1,.mce-visualblocks[dir=rtl] h2,.mce-visualblocks[dir=rtl] h3,.mce-visualblocks[dir=rtl] h4,.mce-visualblocks[dir=rtl] h5,.mce-visualblocks[dir=rtl] h6,.mce-visualblocks[dir=rtl] hgroup,.mce-visualblocks[dir=rtl] ol,.mce-visualblocks[dir=rtl] p,.mce-visualblocks[dir=rtl] pre,.mce-visualblocks[dir=rtl] section,.mce-visualblocks[dir=rtl] ul{background-position-x: right;margin-right: 3px;} | ||
228 | + | ||
229 | +.mce-nbsp,.mce-shy{background: #aaa;} | ||
230 | + | ||
231 | +.mce-shy::after{content: '-';} | ||
232 | + | ||
233 | +.tox-toolbar-dock-fadeout{opacity: 0;visibility: hidden;} | ||
234 | + | ||
235 | +.tox-toolbar-dock-fadein{opacity: 1;visibility: visible;} | ||
236 | + | ||
237 | +.tox-toolbar-dock-transition{transition: visibility 0s linear .3s,opacity .3s ease;} | ||
238 | + | ||
239 | +.tox-toolbar-dock-transition.tox-toolbar-dock-fadein{transition-delay: 0s;} |
1 | +/** | ||
2 | + * Copyright (c) Tiny Technologies, Inc. All rights reserved. | ||
3 | + * Licensed under the LGPL or a commercial license. | ||
4 | + * For LGPL see License.txt in the project root for license information. | ||
5 | + * For commercial licenses see https://www.tiny.cloud/ | ||
6 | + */ | ||
7 | +.mce-content-body .mce-item-anchor{display: inline-block;width: 8px !important;height: 12px !important;padding: 0 2px;cursor: default;background: transparent url("data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D'8'%20height%3D'12'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%3E%3Cpath%20d%3D'M0%200L8%200%208%2012%204.09117821%209%200%2012z'%2F%3E%3C%2Fsvg%3E%0A") no-repeat center;-webkit-user-select: all;-moz-user-select: all;-ms-user-select: all;user-select: all;-webkit-user-modify: read-only;-moz-user-modify: read-only;} | ||
8 | + | ||
9 | +.mce-content-body .mce-item-anchor[data-mce-selected]{outline-offset: 1px;} | ||
10 | + | ||
11 | +.tox-comments-visible .tox-comment{background-color: #fff0b7;} | ||
12 | + | ||
13 | +.tox-comments-visible .tox-comment--active{background-color: #ffe168;} | ||
14 | + | ||
15 | +.tox-checklist>li:not(.tox-checklist--hidden){margin: .25em 0;list-style: none;} | ||
16 | + | ||
17 | +.tox-checklist>li:not(.tox-checklist--hidden)::before{position: absolute;width: 1em;height: 1em;margin-top: .125em;margin-left: -1.5em;cursor: pointer;background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2216%22%20height%3D%2216%22%20viewBox%3D%220%200%2016%2016%22%3E%3Cg%20id%3D%22checklist-unchecked%22%20fill%3D%22none%22%20fill-rule%3D%22evenodd%22%3E%3Crect%20id%3D%22Rectangle%22%20width%3D%2215%22%20height%3D%2215%22%20x%3D%22.5%22%20y%3D%22.5%22%20fill-rule%3D%22nonzero%22%20stroke%3D%22%234C4C4C%22%20rx%3D%222%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E%0A");background-size: 100%;content: '';} | ||
18 | + | ||
19 | +.tox-checklist li:not(.tox-checklist--hidden).tox-checklist--checked::before{background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2216%22%20height%3D%2216%22%20viewBox%3D%220%200%2016%2016%22%3E%3Cg%20id%3D%22checklist-checked%22%20fill%3D%22none%22%20fill-rule%3D%22evenodd%22%3E%3Crect%20id%3D%22Rectangle%22%20width%3D%2216%22%20height%3D%2216%22%20fill%3D%22%234099FF%22%20fill-rule%3D%22nonzero%22%20rx%3D%222%22%2F%3E%3Cpath%20id%3D%22Path%22%20fill%3D%22%23FFF%22%20fill-rule%3D%22nonzero%22%20d%3D%22M11.5703186%2C3.14417309%20C11.8516238%2C2.73724603%2012.4164781%2C2.62829933%2012.83558%2C2.89774797%20C13.260121%2C3.17069355%2013.3759736%2C3.72932262%2013.0909105%2C4.14168582%20L7.7580587%2C11.8560195%20C7.43776896%2C12.3193404%206.76483983%2C12.3852142%206.35607322%2C11.9948725%20L3.02491697%2C8.8138662%20C2.66090143%2C8.46625845%202.65798871%2C7.89594698%203.01850234%2C7.54483354%20C3.373942%2C7.19866177%203.94940006%2C7.19592841%204.30829608%2C7.5386474%20L6.85276923%2C9.9684299%20L11.5703186%2C3.14417309%20Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E%0A");} | ||
20 | + | ||
21 | +[dir=rtl] .tox-checklist>li:not(.tox-checklist--hidden)::before{margin-right: -1.5em;margin-left: 0;} | ||
22 | + | ||
23 | +code[class*=language-],pre[class*=language-]{font-family: Consolas,Monaco,'Andale Mono','Ubuntu Mono',monospace;font-size: .875rem;-webkit-hyphens: none;-ms-hyphens: none;hyphens: none;line-height: 1.5;word-spacing: normal;color: #000;text-shadow: 0 1px #fff;word-break: normal;word-wrap: normal;white-space: pre;-moz-tab-size: 4;tab-size: 4;} | ||
24 | + | ||
25 | +code[class*=language-] ::-moz-selection,code[class*=language-]::-moz-selection,pre[class*=language-] ::-moz-selection,pre[class*=language-]::-moz-selection{text-shadow: none;background: #b3d4fc;} | ||
26 | + | ||
27 | +code[class*=language-] ::selection,code[class*=language-]::selection,pre[class*=language-] ::selection,pre[class*=language-]::selection{text-shadow: none;background: #b3d4fc;}@media print{code[class*=language-],pre[class*=language-]{text-shadow: none;}} | ||
28 | + | ||
29 | +pre[class*=language-]{padding: 1em;margin: .5em 0;overflow: auto;} | ||
30 | + | ||
31 | +:not(pre)>code[class*=language-],pre[class*=language-]{background: 0 0 !important;border: 1px solid #ccc;} | ||
32 | + | ||
33 | +:not(pre)>code[class*=language-]{padding: .1em;border-radius: .3em;} | ||
34 | + | ||
35 | +.token.cdata,.token.comment,.token.doctype,.token.prolog{color: #708090;} | ||
36 | + | ||
37 | +.token.punctuation{color: #999;} | ||
38 | + | ||
39 | +.namespace{opacity: .7;} | ||
40 | + | ||
41 | +.token.boolean,.token.constant,.token.deleted,.token.number,.token.property,.token.symbol,.token.tag{color: #905;} | ||
42 | + | ||
43 | +.token.attr-name,.token.builtin,.token.char,.token.inserted,.token.selector,.token.string{color: #690;} | ||
44 | + | ||
45 | +.language-css .token.string,.style .token.string,.token.entity,.token.operator,.token.url{color: #a67f59;background: hsla(0,0%,100%,.5);} | ||
46 | + | ||
47 | +.token.atrule,.token.attr-value,.token.keyword{color: #07a;} | ||
48 | + | ||
49 | +.token.function{color: #dd4a68;} | ||
50 | + | ||
51 | +.token.important,.token.regex,.token.variable{color: #e90;} | ||
52 | + | ||
53 | +.token.bold,.token.important{font-weight: 700;} | ||
54 | + | ||
55 | +.token.italic{font-style: italic;} | ||
56 | + | ||
57 | +.token.entity{cursor: help;} | ||
58 | + | ||
59 | +:not([dir=rtl]) code[class*=language-],:not([dir=rtl]) pre[class*=language-]{text-align: left;direction: ltr;} | ||
60 | + | ||
61 | +[dir=rtl] code[class*=language-],[dir=rtl] pre[class*=language-]{text-align: right;direction: rtl;} | ||
62 | + | ||
63 | +.mce-content-body{overflow-wrap: break-word;word-wrap: break-word;} | ||
64 | + | ||
65 | +.mce-content-body .mce-visual-caret{position: absolute;background-color: #000;background-color: currentColor;} | ||
66 | + | ||
67 | +.mce-content-body .mce-visual-caret-hidden{display: none;} | ||
68 | + | ||
69 | +.mce-content-body [data-mce-caret]{position: absolute;top: 0;right: auto;left: -1000px;padding: 0;margin: 0;} | ||
70 | + | ||
71 | +.mce-content-body .mce-offscreen-selection{position: absolute;left: -9999999999px;max-width: 1000000px;} | ||
72 | + | ||
73 | +.mce-content-body [contentEditable=false]{cursor: default;} | ||
74 | + | ||
75 | +.mce-content-body [contentEditable=true]{cursor: text;} | ||
76 | + | ||
77 | +.tox-cursor-format-painter{cursor: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%3E%0A%20%20%3Cg%20fill%3D%22none%22%20fill-rule%3D%22evenodd%22%3E%0A%20%20%20%20%3Cpath%20fill%3D%22%23000%22%20fill-rule%3D%22nonzero%22%20d%3D%22M15%2C6%20C15%2C5.45%2014.55%2C5%2014%2C5%20L6%2C5%20C5.45%2C5%205%2C5.45%205%2C6%20L5%2C10%20C5%2C10.55%205.45%2C11%206%2C11%20L14%2C11%20C14.55%2C11%2015%2C10.55%2015%2C10%20L15%2C9%20L16%2C9%20L16%2C12%20L9%2C12%20L9%2C19%20C9%2C19.55%209.45%2C20%2010%2C20%20L11%2C20%20C11.55%2C20%2012%2C19.55%2012%2C19%20L12%2C14%20L18%2C14%20L18%2C7%20L15%2C7%20L15%2C6%20Z%22%2F%3E%0A%20%20%20%20%3Cpath%20fill%3D%22%23000%22%20fill-rule%3D%22nonzero%22%20d%3D%22M1%2C1%20L8.25%2C1%20C8.66421356%2C1%209%2C1.33578644%209%2C1.75%20L9%2C1.75%20C9%2C2.16421356%208.66421356%2C2.5%208.25%2C2.5%20L2.5%2C2.5%20L2.5%2C8.25%20C2.5%2C8.66421356%202.16421356%2C9%201.75%2C9%20L1.75%2C9%20C1.33578644%2C9%201%2C8.66421356%201%2C8.25%20L1%2C1%20Z%22%2F%3E%0A%20%20%3C%2Fg%3E%0A%3C%2Fsvg%3E%0A"),default;} | ||
78 | + | ||
79 | +.mce-content-body figure.align-left{float: left;} | ||
80 | + | ||
81 | +.mce-content-body figure.align-right{float: right;} | ||
82 | + | ||
83 | +.mce-content-body figure.image.align-center{display: table;margin-right: auto;margin-left: auto;} | ||
84 | + | ||
85 | +.mce-preview-object{position: relative;display: inline-block;margin: 0 2px 0 2px;line-height: 0;border: 1px solid gray;} | ||
86 | + | ||
87 | +.mce-preview-object .mce-shim{position: absolute;top: 0;left: 0;width: 100%;height: 100%;background: url();} | ||
88 | + | ||
89 | +.mce-preview-object[data-mce-selected="2"] .mce-shim{display: none;} | ||
90 | + | ||
91 | +.mce-object{background: transparent url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%3E%3Cpath%20d%3D%22M4%203h16a1%201%200%200%201%201%201v16a1%201%200%200%201-1%201H4a1%201%200%200%201-1-1V4a1%201%200%200%201%201-1zm1%202v14h14V5H5zm4.79%202.565l5.64%204.028a.5.5%200%200%201%200%20.814l-5.64%204.028a.5.5%200%200%201-.79-.407V7.972a.5.5%200%200%201%20.79-.407z%22%2F%3E%3C%2Fsvg%3E%0A") no-repeat center;border: 1px dashed #aaa;} | ||
92 | + | ||
93 | +.mce-pagebreak{display: block;width: 100%;height: 5px;margin-top: 15px;cursor: default;border: 1px dashed #aaa;page-break-before: always;}@media print{.mce-pagebreak{border: 0;}} | ||
94 | + | ||
95 | +.tiny-pageembed .mce-shim{position: absolute;top: 0;left: 0;width: 100%;height: 100%;background: url();} | ||
96 | + | ||
97 | +.tiny-pageembed[data-mce-selected="2"] .mce-shim{display: none;} | ||
98 | + | ||
99 | +.tiny-pageembed{position: relative;display: inline-block;} | ||
100 | + | ||
101 | +.tiny-pageembed--16by9,.tiny-pageembed--1by1,.tiny-pageembed--21by9,.tiny-pageembed--4by3{position: relative;display: block;width: 100%;padding: 0;overflow: hidden;} | ||
102 | + | ||
103 | +.tiny-pageembed--16by9::before,.tiny-pageembed--1by1::before,.tiny-pageembed--21by9::before,.tiny-pageembed--4by3::before{display: block;content: "";} | ||
104 | + | ||
105 | +.tiny-pageembed--21by9::before{padding-top: 42.857143%;} | ||
106 | + | ||
107 | +.tiny-pageembed--16by9::before{padding-top: 56.25%;} | ||
108 | + | ||
109 | +.tiny-pageembed--4by3::before{padding-top: 75%;} | ||
110 | + | ||
111 | +.tiny-pageembed--1by1::before{padding-top: 100%;} | ||
112 | + | ||
113 | +.tiny-pageembed--16by9 iframe,.tiny-pageembed--1by1 iframe,.tiny-pageembed--21by9 iframe,.tiny-pageembed--4by3 iframe{position: absolute;top: 0;left: 0;width: 100%;height: 100%;border: 0;} | ||
114 | + | ||
115 | +.mce-content-body div.mce-resizehandle{position: absolute;z-index: 10000;width: 10px;height: 10px;background-color: #4099ff;border-color: #4099ff;border-style: solid;border-width: 1px;box-sizing: border-box;} | ||
116 | + | ||
117 | +.mce-content-body div.mce-resizehandle:hover{background-color: #4099ff;} | ||
118 | + | ||
119 | +.mce-content-body div.mce-resizehandle:nth-of-type(1){cursor: nwse-resize;} | ||
120 | + | ||
121 | +.mce-content-body div.mce-resizehandle:nth-of-type(2){cursor: nesw-resize;} | ||
122 | + | ||
123 | +.mce-content-body div.mce-resizehandle:nth-of-type(3){cursor: nwse-resize;} | ||
124 | + | ||
125 | +.mce-content-body div.mce-resizehandle:nth-of-type(4){cursor: nesw-resize;} | ||
126 | + | ||
127 | +.mce-content-body .mce-clonedresizable{position: absolute;z-index: 10000;outline: 1px dashed #000;opacity: .5;} | ||
128 | + | ||
129 | +.mce-content-body .mce-resize-helper{position: absolute;z-index: 10001;display: none;padding: 5px;margin: 5px 10px;font-family: sans-serif;font-size: 12px;line-height: 14px;color: #fff;white-space: nowrap;background: #555;background: rgba(0,0,0,.75);border: 1px;border-radius: 3px;} | ||
130 | + | ||
131 | +.mce-match-marker{color: #fff;background: #aaa;} | ||
132 | + | ||
133 | +.mce-match-marker-selected{color: #fff;background: #39f;} | ||
134 | + | ||
135 | +.mce-content-body img[data-mce-selected],.mce-content-body table[data-mce-selected]{outline: 3px solid #b4d7ff;} | ||
136 | + | ||
137 | +.mce-content-body hr[data-mce-selected]{outline: 3px solid #b4d7ff;outline-offset: 1px;} | ||
138 | + | ||
139 | +.mce-content-body [contentEditable=false] [contentEditable=true]:focus{outline: 3px solid #b4d7ff;} | ||
140 | + | ||
141 | +.mce-content-body [contentEditable=false] [contentEditable=true]:hover{outline: 3px solid #b4d7ff;} | ||
142 | + | ||
143 | +.mce-content-body [contentEditable=false][data-mce-selected]{cursor: not-allowed;outline: 3px solid #b4d7ff;} | ||
144 | + | ||
145 | +.mce-content-body.mce-content-readonly [contentEditable=true]:focus,.mce-content-body.mce-content-readonly [contentEditable=true]:hover{outline: 0;} | ||
146 | + | ||
147 | +.mce-content-body [data-mce-selected=inline-boundary]{background-color: #b4d7ff;} | ||
148 | + | ||
149 | +.mce-content-body .mce-edit-focus{outline: 3px solid #b4d7ff;} | ||
150 | + | ||
151 | +.mce-content-body td[data-mce-selected],.mce-content-body th[data-mce-selected]{background-color: #b4d7ff !important;} | ||
152 | + | ||
153 | +.mce-content-body td[data-mce-selected]::-moz-selection,.mce-content-body th[data-mce-selected]::-moz-selection{background: 0 0;} | ||
154 | + | ||
155 | +.mce-content-body td[data-mce-selected]::selection,.mce-content-body th[data-mce-selected]::selection{background: 0 0;} | ||
156 | + | ||
157 | +.mce-content-body td[data-mce-selected] *,.mce-content-body th[data-mce-selected] *{-webkit-touch-callout: none;-webkit-user-select: none;-moz-user-select: none;-ms-user-select: none;user-select: none;} | ||
158 | + | ||
159 | +.mce-content-body img::-moz-selection{background: 0 0;} | ||
160 | + | ||
161 | +.mce-content-body img::selection{background: 0 0;} | ||
162 | + | ||
163 | +.ephox-snooker-resizer-bar{background-color: #b4d7ff;opacity: 0;} | ||
164 | + | ||
165 | +.ephox-snooker-resizer-cols{cursor: col-resize;} | ||
166 | + | ||
167 | +.ephox-snooker-resizer-rows{cursor: row-resize;} | ||
168 | + | ||
169 | +.ephox-snooker-resizer-bar.ephox-snooker-resizer-bar-dragging{opacity: 1;} | ||
170 | + | ||
171 | +.mce-spellchecker-word{height: 2rem;cursor: default;background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D'4'%20height%3D'4'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%3E%3Cpath%20stroke%3D'%23ff0000'%20fill%3D'none'%20stroke-linecap%3D'round'%20stroke-opacity%3D'.5'%20d%3D'M0%203L2%201%204%203'%2F%3E%3C%2Fsvg%3E%0A");background-position: 0 calc(100% + 1px);background-repeat: repeat-x;background-size: auto 6px;} | ||
172 | + | ||
173 | +.mce-spellchecker-grammar{cursor: default;background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D'4'%20height%3D'4'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%3E%3Cpath%20stroke%3D'%23008800'%20fill%3D'none'%20stroke-linecap%3D'round'%20d%3D'M0%203L2%201%204%203'%2F%3E%3C%2Fsvg%3E%0A");background-position: 0 calc(100% + 1px);background-repeat: repeat-x;background-size: auto 6px;} | ||
174 | + | ||
175 | +.mce-toc{border: 1px solid gray;} | ||
176 | + | ||
177 | +.mce-toc h2{margin: 4px;} | ||
178 | + | ||
179 | +.mce-toc li{list-style-type: none;} | ||
180 | + | ||
181 | +.mce-item-table,.mce-item-table caption,.mce-item-table td,.mce-item-table th{border: 1px dashed #bbb;} | ||
182 | + | ||
183 | +.mce-visualblocks address,.mce-visualblocks article,.mce-visualblocks aside,.mce-visualblocks blockquote,.mce-visualblocks div:not([data-mce-bogus]),.mce-visualblocks dl,.mce-visualblocks figcaption,.mce-visualblocks figure,.mce-visualblocks h1,.mce-visualblocks h2,.mce-visualblocks h3,.mce-visualblocks h4,.mce-visualblocks h5,.mce-visualblocks h6,.mce-visualblocks hgroup,.mce-visualblocks ol,.mce-visualblocks p,.mce-visualblocks pre,.mce-visualblocks section,.mce-visualblocks ul{padding-top: 10px;margin-left: 3px;background-repeat: no-repeat;border: 1px dashed #bbb;} | ||
184 | + | ||
185 | +.mce-visualblocks p{background-image: url();} | ||
186 | + | ||
187 | +.mce-visualblocks h1{background-image: url();} | ||
188 | + | ||
189 | +.mce-visualblocks h2{background-image: url();} | ||
190 | + | ||
191 | +.mce-visualblocks h3{background-image: url();} | ||
192 | + | ||
193 | +.mce-visualblocks h4{background-image: url();} | ||
194 | + | ||
195 | +.mce-visualblocks h5{background-image: url();} | ||
196 | + | ||
197 | +.mce-visualblocks h6{background-image: url();} | ||
198 | + | ||
199 | +.mce-visualblocks div:not([data-mce-bogus]){background-image: url();} | ||
200 | + | ||
201 | +.mce-visualblocks section{background-image: url();} | ||
202 | + | ||
203 | +.mce-visualblocks article{background-image: url();} | ||
204 | + | ||
205 | +.mce-visualblocks blockquote{background-image: url();} | ||
206 | + | ||
207 | +.mce-visualblocks address{background-image: url();} | ||
208 | + | ||
209 | +.mce-visualblocks pre{background-image: url();} | ||
210 | + | ||
211 | +.mce-visualblocks figure{background-image: url();} | ||
212 | + | ||
213 | +.mce-visualblocks figcaption{border: 1px dashed #bbb;} | ||
214 | + | ||
215 | +.mce-visualblocks hgroup{background-image: url();} | ||
216 | + | ||
217 | +.mce-visualblocks aside{background-image: url();} | ||
218 | + | ||
219 | +.mce-visualblocks ul{background-image: url();} | ||
220 | + | ||
221 | +.mce-visualblocks ol{background-image: url();} | ||
222 | + | ||
223 | +.mce-visualblocks dl{background-image: url();} | ||
224 | + | ||
225 | +.mce-visualblocks:not([dir=rtl]) address,.mce-visualblocks:not([dir=rtl]) article,.mce-visualblocks:not([dir=rtl]) aside,.mce-visualblocks:not([dir=rtl]) blockquote,.mce-visualblocks:not([dir=rtl]) div:not([data-mce-bogus]),.mce-visualblocks:not([dir=rtl]) dl,.mce-visualblocks:not([dir=rtl]) figcaption,.mce-visualblocks:not([dir=rtl]) figure,.mce-visualblocks:not([dir=rtl]) h1,.mce-visualblocks:not([dir=rtl]) h2,.mce-visualblocks:not([dir=rtl]) h3,.mce-visualblocks:not([dir=rtl]) h4,.mce-visualblocks:not([dir=rtl]) h5,.mce-visualblocks:not([dir=rtl]) h6,.mce-visualblocks:not([dir=rtl]) hgroup,.mce-visualblocks:not([dir=rtl]) ol,.mce-visualblocks:not([dir=rtl]) p,.mce-visualblocks:not([dir=rtl]) pre,.mce-visualblocks:not([dir=rtl]) section,.mce-visualblocks:not([dir=rtl]) ul{margin-left: 3px;} | ||
226 | + | ||
227 | +.mce-visualblocks[dir=rtl] address,.mce-visualblocks[dir=rtl] article,.mce-visualblocks[dir=rtl] aside,.mce-visualblocks[dir=rtl] blockquote,.mce-visualblocks[dir=rtl] div:not([data-mce-bogus]),.mce-visualblocks[dir=rtl] dl,.mce-visualblocks[dir=rtl] figcaption,.mce-visualblocks[dir=rtl] figure,.mce-visualblocks[dir=rtl] h1,.mce-visualblocks[dir=rtl] h2,.mce-visualblocks[dir=rtl] h3,.mce-visualblocks[dir=rtl] h4,.mce-visualblocks[dir=rtl] h5,.mce-visualblocks[dir=rtl] h6,.mce-visualblocks[dir=rtl] hgroup,.mce-visualblocks[dir=rtl] ol,.mce-visualblocks[dir=rtl] p,.mce-visualblocks[dir=rtl] pre,.mce-visualblocks[dir=rtl] section,.mce-visualblocks[dir=rtl] ul{background-position-x: right;margin-right: 3px;} | ||
228 | + | ||
229 | +.mce-nbsp,.mce-shy{background: #aaa;} | ||
230 | + | ||
231 | +.mce-shy::after{content: '-';} | ||
232 | + | ||
233 | +body{font-family: sans-serif;} | ||
234 | + | ||
235 | +table{border-collapse: collapse;} |
1 | +/** | ||
2 | + * Copyright (c) Tiny Technologies, Inc. All rights reserved. | ||
3 | + * Licensed under the LGPL or a commercial license. | ||
4 | + * For LGPL see License.txt in the project root for license information. | ||
5 | + * For commercial licenses see https://www.tiny.cloud/ | ||
6 | + */ | ||
7 | +.tinymce-mobile-unfocused-selections .tinymce-mobile-unfocused-selection{position: absolute;display: inline-block;background-color: green;opacity: .5;} | ||
8 | + | ||
9 | +body{-webkit-text-size-adjust: none;} | ||
10 | + | ||
11 | +body img{max-width: 96vw;} | ||
12 | + | ||
13 | +body table img{max-width: 95%;} | ||
14 | + | ||
15 | +body{font-family: sans-serif;} | ||
16 | + | ||
17 | +table{border-collapse: collapse;} |