├── .editorconfig
├── .eslintrc.js
├── .gitignore
├── .vscode
└── launch.json
├── README.md
├── assets
├── css
│ ├── common.less
│ ├── fonts
│ │ ├── ionicons.eot
│ │ ├── ionicons.svg
│ │ ├── ionicons.ttf
│ │ └── ionicons.woff
│ ├── loading.less
│ ├── main.css
│ └── main.less
└── images
│ ├── cropper-test.png
│ ├── logo-min.jpg
│ └── logo.jpg
├── backpack.config.js
├── build
├── main.js
└── main.map
├── components
├── access
│ ├── access-test.vue
│ ├── access.less
│ └── access.vue
├── advanced-router
│ ├── advanced-router.less
│ ├── argument-page.vue
│ ├── component
│ │ ├── expandRow.vue
│ │ ├── order-info.vue
│ │ └── shopping-info.vue
│ └── mutative-router.vue
├── error-page
│ ├── 403.less
│ ├── 403.vue
│ ├── 404.less
│ ├── 404.vue
│ ├── 500.less
│ ├── 500.vue
│ ├── error-page.less
│ └── error-page.vue
├── form
│ ├── article-publish
│ │ ├── article-publish.less
│ │ ├── article-publish.vue
│ │ ├── preview.less
│ │ └── preview.vue
│ └── work-flow
│ │ ├── work-flow.less
│ │ └── work-flow.vue
├── home
│ ├── components
│ │ ├── countUp.vue
│ │ ├── dataSourcePie.vue
│ │ ├── inforCard.vue
│ │ ├── map.vue
│ │ ├── mapDataTable.vue
│ │ ├── serviceRequests.vue
│ │ ├── styles
│ │ │ ├── infor-card.less
│ │ │ └── to-do-list-item.less
│ │ ├── toDoListItem.vue
│ │ ├── userFlow.vue
│ │ └── visiteVolume.vue
│ ├── home.less
│ ├── home.vue
│ └── map-data
│ │ ├── china.json
│ │ ├── get-city-value.js
│ │ ├── get-geography-value.js
│ │ └── get-style-json.js
├── loading.vue
├── main-components
│ ├── breadcrumb-nav.vue
│ ├── fullscreen.vue
│ ├── lockscreen
│ │ ├── components
│ │ │ ├── locking-page.vue
│ │ │ └── unlock.vue
│ │ ├── lockscreen.vue
│ │ └── styles
│ │ │ └── unlock.less
│ ├── message-tip.vue
│ ├── shrinkable-menu
│ │ ├── components
│ │ │ ├── sidebarMenu.vue
│ │ │ └── sidebarMenuShrink.vue
│ │ ├── shrinkable-menu.vue
│ │ └── styles
│ │ │ └── menu.less
│ ├── tags-page-opened.vue
│ └── theme-switch
│ │ ├── theme-switch.vue
│ │ └── theme
│ │ ├── g.css
│ │ ├── r.css
│ │ └── y.css
├── main.less
├── message
│ ├── message.less
│ └── message.vue
├── my-components
│ ├── area-linkage
│ │ ├── area-linkage.less
│ │ ├── area-linkage.vue
│ │ ├── components
│ │ │ ├── al-cascader.vue
│ │ │ └── al-selector.vue
│ │ └── util
│ │ │ └── index.js
│ ├── count-to
│ │ ├── CountTo.vue
│ │ ├── count-to.less
│ │ └── count-to.vue
│ ├── draggable-list
│ │ ├── draggable-list.less
│ │ └── draggable-list.vue
│ ├── file-upload
│ │ ├── file-upload.vue
│ │ └── upload.less
│ ├── image-editor
│ │ ├── cropper.min.css
│ │ ├── image-editor.less
│ │ └── image-editor.vue
│ ├── markdown-editor
│ │ ├── markdown-editor.less
│ │ ├── markdown-editor.vue
│ │ └── simplemde.min.css
│ ├── scroll-bar
│ │ ├── scroll-bar-page.vue
│ │ └── vue-scroller-bars
│ │ │ ├── index.js
│ │ │ ├── scroll-bar.less
│ │ │ └── scroll-bar.vue
│ ├── split-pane
│ │ ├── split-pane-page.vue
│ │ └── split-pane
│ │ │ ├── index.js
│ │ │ ├── split-pane.less
│ │ │ └── split-pane.vue
│ └── text-editor
│ │ ├── text-editor.vue
│ │ └── tinymce
│ │ ├── langs
│ │ ├── en_GB.js
│ │ └── zh_CN.GB2312.js
│ │ ├── plugins
│ │ ├── advlist
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── anchor
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── autolink
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── autoresize
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── autosave
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── bbcode
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── charmap
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── code
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── codesample
│ │ │ ├── css
│ │ │ │ └── prism.css
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── colorpicker
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── contextmenu
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── directionality
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── emoticons
│ │ │ ├── img
│ │ │ │ ├── smiley-cool.gif
│ │ │ │ ├── smiley-cry.gif
│ │ │ │ ├── smiley-embarassed.gif
│ │ │ │ ├── smiley-foot-in-mouth.gif
│ │ │ │ ├── smiley-frown.gif
│ │ │ │ ├── smiley-innocent.gif
│ │ │ │ ├── smiley-kiss.gif
│ │ │ │ ├── smiley-laughing.gif
│ │ │ │ ├── smiley-money-mouth.gif
│ │ │ │ ├── smiley-sealed.gif
│ │ │ │ ├── smiley-smile.gif
│ │ │ │ ├── smiley-surprised.gif
│ │ │ │ ├── smiley-tongue-out.gif
│ │ │ │ ├── smiley-undecided.gif
│ │ │ │ ├── smiley-wink.gif
│ │ │ │ └── smiley-yell.gif
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── fullpage
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── fullscreen
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── help
│ │ │ ├── img
│ │ │ │ └── logo.png
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── hr
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── image
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── imagetools
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── importcss
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── insertdatetime
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── legacyoutput
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── link
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── lists
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── media
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── nonbreaking
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── noneditable
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── pagebreak
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── paste
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── preview
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── print
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── save
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── searchreplace
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── spellchecker
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── tabfocus
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── table
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── template
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── textcolor
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── textpattern
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── toc
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── visualblocks
│ │ │ ├── css
│ │ │ │ └── visualblocks.css
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── visualchars
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ └── wordcount
│ │ │ ├── index.js
│ │ │ ├── plugin.js
│ │ │ └── plugin.min.js
│ │ ├── skins
│ │ └── lightgray
│ │ │ ├── content.inline.min.css
│ │ │ ├── content.min.css
│ │ │ ├── content.mobile.min.css
│ │ │ ├── fonts
│ │ │ ├── tinymce-mobile.woff
│ │ │ ├── tinymce-small.eot
│ │ │ ├── tinymce-small.svg
│ │ │ ├── tinymce-small.ttf
│ │ │ ├── tinymce-small.woff
│ │ │ ├── tinymce.eot
│ │ │ ├── tinymce.svg
│ │ │ ├── tinymce.ttf
│ │ │ └── tinymce.woff
│ │ │ ├── img
│ │ │ ├── anchor.gif
│ │ │ ├── loader.gif
│ │ │ ├── object.gif
│ │ │ └── trans.gif
│ │ │ ├── skin.min.css
│ │ │ └── skin.mobile.min.css
│ │ └── themes
│ │ ├── inlite
│ │ ├── index.js
│ │ ├── theme.js
│ │ └── theme.min.js
│ │ └── modern
│ │ ├── index.js
│ │ ├── theme.js
│ │ └── theme.min.js
├── other.vue
└── tables
│ ├── components
│ ├── ExportExcel.vue
│ ├── canEditTable.vue
│ ├── dragableTable.vue
│ ├── editable-table.less
│ ├── multiPageTable.vue
│ ├── table.less
│ └── table_data.js
│ ├── data
│ ├── search.js
│ ├── table2csv.js
│ └── table2excel.js
│ ├── dragable-table.vue
│ ├── editable-table.vue
│ ├── exportable-table.vue
│ ├── searchable-table.vue
│ └── table-to-image.vue
├── ecosystem.config.js
├── layouts
├── default.vue
├── error.vue
└── full.vue
├── libs
├── md5.js
├── table2excel.js
└── util.js
├── middleware
├── auth.js
├── redirect.js
└── route.js
├── nuxt.config.js
├── package.json
├── pages
├── error-page
│ ├── 403.vue
│ ├── 404.vue
│ ├── 500.vue
│ └── error-page.vue
├── form
│ ├── article-publish.vue
│ ├── preview.vue
│ └── work-flow.vue
├── index.vue
├── login.vue
└── tables
│ ├── dragable-table.vue
│ └── editable-table.vue
├── plugins
├── axios.js
├── axios2.js
├── flexible.js
└── iview.js
├── router
└── router.js
├── screenshot
├── sc1.png
├── sc2.png
├── sc3.png
└── sc4.png
├── server
├── config
│ └── index.js
├── controller
│ └── user.js
├── index.js
├── routers
│ └── index.js
└── src
│ ├── styles
│ ├── fonts
│ │ ├── ionicons.eot
│ │ ├── ionicons.svg
│ │ ├── ionicons.ttf
│ │ └── ionicons.woff
│ └── iview.css
│ └── theme
│ ├── g.css
│ ├── r.css
│ └── y.css
├── static
└── favicon.ico
├── store
├── index.js
└── modules
│ ├── app.js
│ └── user.js
├── test
├── config.test.js
├── helpers
│ └── create-nuxt.js
└── login.test.js
└── yarn.lock
/.editorconfig:
--------------------------------------------------------------------------------
1 | # editorconfig.org
2 | root = true
3 |
4 | [*]
5 | indent_size = 2
6 | indent_style = space
7 | end_of_line = lf
8 | charset = utf-8
9 | trim_trailing_whitespace = true
10 | insert_final_newline = true
11 |
12 | [*.md]
13 | trim_trailing_whitespace = false
14 |
--------------------------------------------------------------------------------
/.eslintrc.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | root: true,
3 | parser: 'babel-eslint',
4 | env: {
5 | browser: true,
6 | node: true
7 | },
8 | extends: 'standard',
9 | // required to lint *.vue files
10 | plugins: [
11 | 'html'
12 | ],
13 | // add your custom rules here
14 | rules: {
15 | 'space-before-function-paren': [
16 | 2,
17 | {
18 | anonymous: 'always',
19 | named: 'never'
20 | }
21 | ]
22 | },
23 | globals: {}
24 | }
25 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # dependencies
2 | node_modules
3 |
4 | # logs
5 | npm-debug.log
6 |
7 | # Nuxt build
8 | .nuxt
9 |
10 | # Nuxt generate
11 | dist
12 |
13 | .idea
14 |
--------------------------------------------------------------------------------
/.vscode/launch.json:
--------------------------------------------------------------------------------
1 | {
2 | "version": "0.2.0",
3 | "configurations": [
4 | {
5 | "type": "node",
6 | "request": "launch",
7 | "name": "npm run dev",
8 | "protocol": "inspector",
9 | // "program": "${workspaceRoot}/node_modules/nuxt/bin/nuxt",
10 | // "args": ["dev"],
11 | // "stopOnEntry": false,
12 | // "cwd": "${workspaceRoot}",
13 | // "sourceMaps": true,
14 | // "env": {
15 | // "NODE_ENV": "development",
16 | // "DEBUG": "nuxt:*,app"
17 | // },
18 | "runtimeExecutable": "npm",
19 | "runtimeArgs": ["run-script", "dev-debug"]
20 | }
21 | ]
22 | }
23 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # nuxt-demo
2 |
3 | > 最近公司CRM项目采用 nuxt+ivew+iview-admin+koa2的组合模式开发,目前正在踩坑中,demo还不完整,后面会继续更新
4 |
5 |
6 | ### 相关页面效果
7 |
8 | 截图一: 账号和密码随意填写
9 |
10 | 
11 |
12 | 截图二:
13 |
14 | 
15 |
16 | 截图三:
17 |
18 | 
19 |
20 | 刷新浏览器,重新从服务器端获取页面,看到是已经渲染过的html
21 |
22 | 
23 |
24 |
25 | ### 项目地址
26 |
27 | ```bash
28 | git clone https://github.com/moedong/nuxt-iview.git
29 | ```
30 | ### 安装
31 | ```bash
32 | npm install
33 | ```
34 |
35 | ### 开发
36 | ```bash
37 | npm run dev
38 |
39 | // GO to http://127.0.0.1:3000
40 | ```
41 |
42 | ### 测试环境
43 | ```bash
44 | // 需要pm2,如果没有安装的先安装 npm install -g pm2
45 | npm run publish:test
46 | ```
47 |
48 | ### 生产环境
49 | ```bash
50 | // 需要pm2,如果没有安装的先安装 npm install -g pm2
51 | npm run publish:prod
52 | ```
53 |
54 | 参考资料
55 |
56 | [Nuxt.js docs](https://github.com/nuxt/nuxt.js)
57 |
58 | [iview docs](https://www.iviewui.com/docs/guide/install)
59 |
60 | [iview-admin](https://github.com/iview/iview-admin)
61 |
62 | [koa-template](https://github.com/nuxt-community/koa-template)
63 |
64 |
65 |
--------------------------------------------------------------------------------
/assets/css/common.less:
--------------------------------------------------------------------------------
1 | .margin-top-8{
2 | margin-top: 8px;
3 | }
4 | .margin-top-10{
5 | margin-top: 10px;
6 | }
7 | .margin-top-20{
8 | margin-top: 20px;
9 | }
10 | .margin-left-10{
11 | margin-left: 10px;
12 | }
13 | .margin-bottom-10{
14 | margin-bottom: 10px;
15 | }
16 | .margin-bottom-100{
17 | margin-bottom: 100px;
18 | }
19 | .margin-right-10{
20 | margin-right: 10px;
21 | }
22 | .padding-left-6{
23 | padding-left: 6px;
24 | }
25 | .padding-left-8{
26 | padding-left: 5px;
27 | }
28 | .padding-left-10{
29 | padding-left: 10px;
30 | }
31 | .padding-left-20{
32 | padding-left: 20px;
33 | }
34 | .height-100{
35 | height: 100%;
36 | }
37 | .height-120px{
38 | height: 100px;
39 | }
40 | .height-200px{
41 | height: 200px;
42 | }
43 | .height-492px{
44 | height: 492px;
45 | }
46 | .height-460px{
47 | height: 460px;
48 | }
49 | .line-gray{
50 | height: 0;
51 | border-bottom: 2px solid #dcdcdc;
52 | }
53 | .notwrap{
54 | word-break:keep-all;
55 | white-space:nowrap;
56 | overflow: hidden;
57 | text-overflow: ellipsis;
58 | }
59 | .padding-left-5{
60 | padding-left: 10px;
61 | }
62 | [v-cloak]{
63 | display: none;
64 | }
--------------------------------------------------------------------------------
/assets/css/fonts/ionicons.eot:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/assets/css/fonts/ionicons.eot
--------------------------------------------------------------------------------
/assets/css/fonts/ionicons.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/assets/css/fonts/ionicons.ttf
--------------------------------------------------------------------------------
/assets/css/fonts/ionicons.woff:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/assets/css/fonts/ionicons.woff
--------------------------------------------------------------------------------
/assets/css/loading.less:
--------------------------------------------------------------------------------
1 | .demo-spin-icon-load{
2 | animation: ani-demo-spin 1s linear infinite;
3 | }
4 | @keyframes ani-demo-spin {
5 | from { transform: rotate(0deg);}
6 | 50% { transform: rotate(180deg);}
7 | to { transform: rotate(360deg);}
8 | }
--------------------------------------------------------------------------------
/assets/css/main.css:
--------------------------------------------------------------------------------
1 | html,
2 | body {
3 | background-color: #eaeaea;
4 | letter-spacing: 0.5px;
5 | height: 100vh;
6 | margin: 0;
7 | color: #464c5b;
8 | }
9 |
10 | * {
11 | font-size: 13px;
12 | font-family: "Helvetica Neue", Helvetica, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", Arial, sans-serif;
13 | -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
14 | }
15 | *,
16 | :after,
17 | :before {
18 | box-sizing: border-box;
19 | }
20 |
21 | a,
22 | a:hover,
23 | a:focus,
24 | a:visited {}
25 |
26 | article,
27 | aside,
28 | blockquote,
29 | body,
30 | button,
31 | code,
32 | dd,
33 | details,
34 | div,
35 | dl,
36 | dt,
37 | fieldset,
38 | figcaption,
39 | figure,
40 | footer,
41 | form,
42 | h1,
43 | h2,
44 | h3,
45 | h4,
46 | h5,
47 | h6,
48 | header,
49 | hgroup,
50 | hr,
51 | input,
52 | legend,
53 | li,
54 | menu,
55 | nav,
56 | ol,
57 | p,
58 | pre,
59 | section,
60 | td,
61 | textarea,
62 | th,
63 | ul {
64 | margin: 0;
65 | padding: 0;
66 | }
67 |
--------------------------------------------------------------------------------
/assets/css/main.less:
--------------------------------------------------------------------------------
1 | html {
2 | font-family: "Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
3 | font-size: 100px;
4 | word-spacing: 1px;
5 | -ms-text-size-adjust: 100%;
6 | -webkit-text-size-adjust: 100%;
7 | -moz-osx-font-smoothing: grayscale;
8 | -webkit-font-smoothing: antialiased;
9 | box-sizing: border-box;
10 | }
11 |
12 | *, *:before, *:after {
13 | box-sizing: border-box;
14 | margin: 0;
15 | }
16 |
--------------------------------------------------------------------------------
/assets/images/cropper-test.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/assets/images/cropper-test.png
--------------------------------------------------------------------------------
/assets/images/logo-min.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/assets/images/logo-min.jpg
--------------------------------------------------------------------------------
/assets/images/logo.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/assets/images/logo.jpg
--------------------------------------------------------------------------------
/backpack.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | webpack: (config, options, webpack) => {
3 | config.entry.main = './server/index.js'
4 | return config
5 | }
6 | }
7 |
--------------------------------------------------------------------------------
/components/access/access-test.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | 当前用户的权限值是 0 时,才可以看到这个页面。
5 |
6 |
7 |
8 |
9 |
14 |
15 |
18 |
--------------------------------------------------------------------------------
/components/access/access.less:
--------------------------------------------------------------------------------
1 | .access{
2 | &-user-con{
3 | height: 200px;
4 | }
5 | &-current-user-con{
6 | text-align: center;
7 | padding-top: 10px;
8 | img{
9 | display: block;
10 | width: 100px;
11 | height: 100px;
12 | border: 2px solid #dddde2;
13 | border-radius: 50%;
14 | margin: 0px auto 10px;
15 | }
16 | p{
17 | display: block;
18 | padding: 20px 0 0;
19 | b{
20 | margin: 0 10px;
21 | color: #2d8cf0;
22 | }
23 | }
24 | }
25 | &-change-access-con{
26 | &-row{
27 | height: 200px;
28 | }
29 | }
30 | }
--------------------------------------------------------------------------------
/components/access/access.vue:
--------------------------------------------------------------------------------
1 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 | 当前用户
14 |
15 |
16 |
![]()
17 |
当前用户权限值:{{ accessCode }}
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 | 不同权限用户的不同菜单
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 | 您可以通过左侧的开关来切换当前用户的权限值,然后您可以观察左侧菜单栏的变化,如果当前用户的权限值是 0 ,则左侧菜单栏会显示’权限测试页‘这一项('权限测试页'只用于测试,点击不会跳转)。
36 |
37 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 |
74 |
75 |
78 |
--------------------------------------------------------------------------------
/components/advanced-router/advanced-router.less:
--------------------------------------------------------------------------------
1 | .advanced-router{
2 | height: 240px !important;
3 | &-tip-p{
4 | padding: 10px 0;
5 | }
6 | }
--------------------------------------------------------------------------------
/components/advanced-router/argument-page.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 | 购物记录(传递参数)
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
95 |
--------------------------------------------------------------------------------
/components/advanced-router/component/expandRow.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 | 职业:
10 | {{ row.job }}
11 |
12 |
13 | 兴趣:
14 | {{ row.interest }}
15 |
16 |
17 | 生日:
18 | {{ row.birthday }}
19 |
20 |
21 |
22 |
23 | 最喜欢的书:
24 | 《{{ row.book }}》
25 |
26 |
27 | 最喜欢的电影:
28 | {{ row.movie }}
29 |
30 |
31 | 最喜欢的音乐:
32 | {{ row.music }}
33 |
34 |
35 |
36 |
37 |
--------------------------------------------------------------------------------
/components/advanced-router/component/shopping-info.vue:
--------------------------------------------------------------------------------
1 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 | 订单详情
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
75 |
--------------------------------------------------------------------------------
/components/advanced-router/mutative-router.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 | 订单详情(动态路由)
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
93 |
--------------------------------------------------------------------------------
/components/error-page/403.less:
--------------------------------------------------------------------------------
1 | @keyframes error403animation {
2 | 0% {
3 | transform: rotateZ(0deg);
4 | }
5 | 40% {
6 | transform: rotateZ(-20deg);
7 | }
8 | 45% {
9 | transform: rotateZ(-15deg);
10 | }
11 | 50% {
12 | transform: rotateZ(-20deg);
13 | }
14 | 55% {
15 | transform: rotateZ(-15deg);
16 | }
17 | 60% {
18 | transform: rotateZ(-20deg);
19 | }
20 | 100% {
21 | transform: rotateZ(0deg);
22 | }
23 | }
24 | .error403{
25 | &-body-con{
26 | width: 700px;
27 | height: 500px;
28 | position: absolute;
29 | left: 50%;
30 | top: 50%;
31 | transform: translate(-50%,-50%);
32 | &-title{
33 | text-align: center;
34 | font-size: 240px;
35 | font-weight: 700;
36 | color: #2d8cf0;
37 | height: 260px;
38 | line-height: 260px;
39 | margin-top: 40px;
40 | .error403-0-span{
41 | display: inline-block;
42 | position: relative;
43 | width: 170px;
44 | height: 170px;
45 | border-radius: 50%;
46 | border: 20px solid #ed3f14;
47 | color: #ed3f14;
48 | margin-right: 10px;
49 | i{
50 | display: inline-block;
51 | font-size: 120px;
52 | position: absolute;
53 | left: 50%;
54 | top: 50%;
55 | transform: translate(-50%,-50%);
56 | }
57 | }
58 | .error403-key-span{
59 | display: inline-block;
60 | position: relative;
61 | width: 100px;
62 | height: 190px;
63 | border-radius: 50%;
64 | margin-right: 10px;
65 | i{
66 | display: inline-block;
67 | font-size: 190px;
68 | position: absolute;
69 | left: 20px;
70 | transform: translate(-50%,-60%);
71 | transform-origin: center bottom;
72 | animation: error403animation 2.8s ease 0s infinite;
73 | }
74 | }
75 | }
76 | &-message{
77 | display: block;
78 | text-align: center;
79 | font-size: 30px;
80 | font-weight: 500;
81 | letter-spacing: 4px;
82 | color: #dddde2;
83 | }
84 | }
85 | &-btn-con{
86 | text-align: center;
87 | padding: 20px 0;
88 | margin-bottom: 40px;
89 | }
90 | }
--------------------------------------------------------------------------------
/components/error-page/403.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 | 4
10 | You don't have permission
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
35 |
--------------------------------------------------------------------------------
/components/error-page/404.less:
--------------------------------------------------------------------------------
1 | @keyframes error404animation {
2 | 0% {
3 | transform: rotateZ(0deg);
4 | }
5 | 20% {
6 | transform: rotateZ(-60deg);
7 | }
8 | 40% {
9 | transform: rotateZ(-10deg);
10 | }
11 | 60% {
12 | transform: rotateZ(50deg);
13 | }
14 | 80% {
15 | transform: rotateZ(-20deg);
16 | }
17 | 100% {
18 | transform: rotateZ(0deg);
19 | }
20 | }
21 | .error404{
22 | &-body-con{
23 | width: 700px;
24 | height: 500px;
25 | position: absolute;
26 | left: 50%;
27 | top: 50%;
28 | transform: translate(-50%,-50%);
29 | &-title{
30 | text-align: center;
31 | font-size: 240px;
32 | font-weight: 700;
33 | color: #2d8cf0;
34 | height: 260px;
35 | line-height: 260px;
36 | margin-top: 40px;
37 | span{
38 | display: inline-block;
39 | color: #19be6b;
40 | font-size: 230px;
41 | animation: error404animation 3s ease 0s infinite alternate;
42 | }
43 | }
44 | &-message{
45 | display: block;
46 | text-align: center;
47 | font-size: 30px;
48 | font-weight: 500;
49 | letter-spacing: 12px;
50 | color: #dddde2;
51 | }
52 | }
53 | &-btn-con{
54 | text-align: center;
55 | padding: 20px 0;
56 | margin-bottom: 40px;
57 | }
58 | }
--------------------------------------------------------------------------------
/components/error-page/404.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 | 44
10 | YOU LOOK LOST
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
35 |
--------------------------------------------------------------------------------
/components/error-page/500.less:
--------------------------------------------------------------------------------
1 | @keyframes error500animation {
2 | 0% {
3 | transform: rotateZ(0deg);
4 | }
5 | 20% {
6 | transform: rotateZ(-10deg);
7 | }
8 | 40% {
9 | transform: rotateZ(5deg);
10 | }
11 | 60% {
12 | transform: rotateZ(-5deg);
13 | }
14 | 80% {
15 | transform: rotateZ(10deg);
16 | }
17 | 100% {
18 | transform: rotateZ(0deg);
19 | }
20 | }
21 | .error500{
22 | &-body-con{
23 | width: 700px;
24 | height: 500px;
25 | position: absolute;
26 | left: 50%;
27 | top: 50%;
28 | transform: translate(-50%,-50%);
29 | &-title{
30 | text-align: center;
31 | font-size: 240px;
32 | font-weight: 700;
33 | color: #2d8cf0;
34 | height: 260px;
35 | line-height: 260px;
36 | margin-top: 40px;
37 | .error500-0-span{
38 | display: inline-block;
39 | position: relative;
40 | width: 170px;
41 | height: 170px;
42 | border-radius: 50%;
43 | border: 20px solid #ed3f14;
44 | color: #ed3f14;
45 | margin-right: 10px;
46 | i{
47 | display: inline-block;
48 | font-size: 120px;
49 | position: absolute;
50 | bottom: -10px;
51 | left: 10px;
52 | transform-origin: center bottom;
53 | animation: error500animation 3s ease 0s infinite alternate;
54 | }
55 | }
56 | }
57 | &-message{
58 | display: block;
59 | text-align: center;
60 | font-size: 30px;
61 | font-weight: 500;
62 | letter-spacing: 4px;
63 | color: #dddde2;
64 | }
65 | }
66 | &-btn-con{
67 | text-align: center;
68 | padding: 20px 0;
69 | margin-bottom: 40px;
70 | }
71 | }
--------------------------------------------------------------------------------
/components/error-page/500.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 |
10 | 5
11 |
12 | Oops! the server is wrong
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
37 |
--------------------------------------------------------------------------------
/components/error-page/error-page.less:
--------------------------------------------------------------------------------
1 | .error-page{
2 | &-show{
3 | width: 100%;
4 | height: 180px;
5 | transform: scale(0.4);
6 | }
7 | &-cover{
8 | position: absolute;
9 | width: 100%;
10 | height: 100%;
11 | left: 0;
12 | top: 0;
13 | }
14 | &-intro-con{
15 | height: 180px;
16 | p{
17 | display: block;
18 | width: 100%;
19 | text-align: center;
20 | }
21 | }
22 | }
--------------------------------------------------------------------------------
/components/form/article-publish/article-publish.less:
--------------------------------------------------------------------------------
1 | .article-link-con{
2 | height: 32px;
3 | width: 100%;
4 | }
5 | .fixed-link-enter{
6 | opacity: 0;
7 | }
8 | .fixed-link-enter-active, .fixed-link-leave-active {
9 | transition: opacity .3s
10 | }
11 | .fixed-link-enter-to{
12 | opacity: 1
13 | }
14 | .openness-radio-con{
15 | margin-left: 40px;
16 | padding-left: 10px;
17 | height: 130px;
18 | border-left: 1px dashed #ebe9f3;
19 | overflow: hidden;
20 | }
21 | .publish-time-picker-con{
22 | margin-left: 40px;
23 | padding-left: 10px;
24 | height: 100px;
25 | border-left: 1px dashed #ebe9f3;
26 | overflow: hidden;
27 | }
28 | .openness-con-enter{
29 | height: 0;
30 | }
31 | .openness-con-enter-active, .openness-con-leave-active{
32 | transition: height .3s;
33 | }
34 | .openness-con-enter-to{
35 | height: 130px;
36 | }
37 | .openness-con-leave{
38 | height: 130px;
39 | }
40 | .openness-con-leave-to{
41 | height: 0;
42 | }
43 | .publish-button-con{
44 | border-top: 1px solid #f3eff1;
45 | padding-top: 14px;
46 | }
47 | .publish-button{
48 | float: right;
49 | margin-left: 10px;
50 | }
51 | .publish-time-enter{
52 | height: 0;
53 | }
54 | .publish-time-enter-active, .publish-time-leave-active{
55 | transition: height .3s;
56 | }
57 | .publish-time-enter-to{
58 | height: 100px;
59 | }
60 | .publish-time-leave{
61 | height: 100px;
62 | }
63 | .publish-time-leave-to{
64 | height: 0;
65 | }
66 | .classification-con{
67 | height: 200px;
68 | margin-top: -16px;
69 | border-left: 1px solid #dddee1;
70 | border-right: 1px solid #dddee1;
71 | border-bottom: 1px solid #dddee1;
72 | border-radius: 0 0 3px 3px;
73 | padding: 10px;
74 | overflow: auto;
75 | }
76 | .add-new-tag-con{
77 | margin-top: 20px;
78 | border-top: 1px dashed #dbdddf;
79 | padding: 20px 0;
80 | height: 60px;
81 | overflow: hidden;
82 | }
83 | .add-new-tag-enter{
84 | height: 0;
85 | margin-top: 0;
86 | padding: 0px 0;
87 | }
88 | .add-new-tag-enter-active, .add-new-tag-leave-active{
89 | transition: all .3s;
90 | }
91 | .add-new-tag-enter-to{
92 | height: 60px;
93 | margin-top: 20px;
94 | padding: 20px 0;
95 | }
96 | .add-new-tag-leave{
97 | height: 60px;
98 | margin-top: 20px;
99 | padding: 20px 0;
100 | }
101 | .add-new-tag-leave-to{
102 | height: 0;
103 | margin-top: 0;
104 | padding: 0px 0;
105 | }
--------------------------------------------------------------------------------
/components/form/article-publish/preview.less:
--------------------------------------------------------------------------------
1 | .preview{
2 | &-main{
3 | width: 100%;
4 | height: 100%;
5 | background: #d7e1ed;
6 | }
7 | &-header{
8 | padding-right: 20px;
9 | height: 60px;
10 | background: #4a5161;
11 | text-align: right;
12 | ul{
13 | display: inline-block !important;
14 | }
15 | }
16 | &-placeholderCon{
17 | height: 200px;
18 | }
19 | &-placeholder{
20 | height: 40px;
21 | margin-bottom: 10px;
22 | background: #9fafd4;
23 | border-radius: 3px;
24 | }
25 | &-tags-con{
26 | padding: 5px 0;
27 | margin: 10px 0;
28 | }
29 | &-tip{
30 | font-size: 12px;
31 | color: #c3c3c3;
32 | }
33 | &-content-con{
34 | border-top: 1px solid #edeff1;
35 | border-bottom: 1px solid #edeff1;
36 | padding: 12px 0 20px;
37 | margin-bottom: 20px;
38 | }
39 | &-classifition-con{
40 | padding: 5px 0;
41 | }
42 | &-classifition-item{
43 | margin-right: 8px;
44 | }
45 | &-publish-time{
46 | font-size: 12px;
47 | color: gray;
48 | margin-top: 5px;
49 | }
50 | }
--------------------------------------------------------------------------------
/components/form/work-flow/work-flow.less:
--------------------------------------------------------------------------------
1 | .step{
2 | &-header-con{
3 | text-align: center;
4 | h3{
5 | margin: 10px 0;
6 | }
7 | h5{
8 | margin: 0 0 5px;
9 | }
10 | }
11 | &-content{
12 | padding: 5px 20px 26px;
13 | margin-bottom: 20px;
14 | border-bottom: 1px solid #dbdddf;
15 | }
16 | &-form{
17 | padding-bottom: 10px;
18 | border-bottom: 1px solid #dbdddf;
19 | margin-bottom: 20px;
20 | }
21 | }
--------------------------------------------------------------------------------
/components/home/components/countUp.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
{{ startVal }}{{ unit }}
4 |
5 |
6 |
7 |
8 |
109 |
--------------------------------------------------------------------------------
/components/home/components/dataSourcePie.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
59 |
--------------------------------------------------------------------------------
/components/home/components/inforCard.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
23 | {{ introText }}
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
60 |
61 |
--------------------------------------------------------------------------------
/components/home/components/map.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
89 |
90 |
91 |
--------------------------------------------------------------------------------
/components/home/components/mapDataTable.vue:
--------------------------------------------------------------------------------
1 |
2 |
5 |
6 |
7 |
32 |
--------------------------------------------------------------------------------
/components/home/components/serviceRequests.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
--------------------------------------------------------------------------------
/components/home/components/styles/infor-card.less:
--------------------------------------------------------------------------------
1 | .infor-card-icon-con{
2 | height: 100%;
3 | }
4 | .height-100{
5 | height: 100%;
6 | }
7 | .infor-card-con{
8 | height: 100px;
9 | }
10 | .infor-intro-text{
11 | font-size:12px;
12 | font-weight:500;
13 | color:#C8C8C8;
14 | }
--------------------------------------------------------------------------------
/components/home/components/styles/to-do-list-item.less:
--------------------------------------------------------------------------------
1 | .to-do-list-item-text{
2 | word-break:keep-all;
3 | white-space:nowrap;
4 | overflow: hidden;
5 | text-overflow: ellipsis;
6 | font-weight: 500;
7 | cursor: pointer;
8 | height: 36px;
9 |
10 | .height-100{
11 | height: 100%;
12 | }
13 | .infor-icon-row{
14 | color: #c8c8c8;
15 | }
16 | }
17 | .hasDid{
18 | text-decoration: line-through;
19 | color: gray;
20 | font-weight: 100;
21 | }
--------------------------------------------------------------------------------
/components/home/components/toDoListItem.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 | {{ content }}
15 |
16 |
17 |
18 |
19 |
20 |
--------------------------------------------------------------------------------
/components/home/components/userFlow.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
82 |
--------------------------------------------------------------------------------
/components/home/components/visiteVolume.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
77 |
--------------------------------------------------------------------------------
/components/home/home.less:
--------------------------------------------------------------------------------
1 | .user-infor{
2 | height: 135px;
3 | }
4 | .avator-img{
5 | display: block;
6 | width: 80%;
7 | max-width: 100px;
8 | height: auto;
9 | }
10 | .card-user-infor-name{
11 | font-size: 2em;
12 | color: #2d8cf0;
13 | }
14 | .card-title{
15 | color: #abafbd;
16 | }
17 | .made-child-con-middle{
18 | height: 100%;
19 | }
20 | .to-do-list-con{
21 | height: 145px;
22 | overflow: auto;
23 | }
24 | .to-do-item{
25 | padding: 2px;
26 | }
27 | .infor-card-con{
28 | height: 100px;
29 | }
30 | .infor-card-icon-con{
31 | height: 100%;
32 | color: white;
33 | border-radius: 3px 0 0 3px;
34 | }
35 | .map-con{
36 | height: 305px;
37 | }
38 | .map-incon{
39 | height: 100%;
40 | }
41 | .data-source-row{
42 | height: 200px;
43 | }
44 | .line-chart-con{
45 | height: 150px;
46 | }
47 |
--------------------------------------------------------------------------------
/components/home/map-data/get-city-value.js:
--------------------------------------------------------------------------------
1 | export default [
2 | {name: '海门', value: 45},
3 | {name: '鄂尔多斯', value: 34},
4 | {name: '招远', value: 47},
5 | {name: '舟山', value: 22},
6 | {name: '齐齐哈尔', value: 74},
7 | {name: '广州', value: 138},
8 | {name: '盐城', value: 15},
9 | {name: '北京', value: 250},
10 | {name: '深圳', value: 141},
11 | {name: '赤峰', value: 16},
12 | {name: '青岛', value: 89},
13 | {name: '乳山', value: 18},
14 | {name: '金昌', value: 34},
15 | {name: '泉州', value: 21},
16 | {name: '莱西', value: 66},
17 | {name: '日照', value: 45},
18 | {name: '胶南', value: 23},
19 | {name: '南通', value: 54},
20 | {name: '拉萨', value: 22},
21 | {name: '云浮', value: 78},
22 | {name: '梅州', value: 23},
23 | {name: '文登', value: 78},
24 | {name: '上海', value: 218}
25 | ];
26 |
--------------------------------------------------------------------------------
/components/home/map-data/get-geography-value.js:
--------------------------------------------------------------------------------
1 | export default {
2 | '海门': [121.15, 31.89],
3 | '鄂尔多斯': [109.781327, 39.608266],
4 | '招远': [120.38, 37.35],
5 | '舟山': [122.207216, 29.985295],
6 | '齐齐哈尔': [123.97, 47.33],
7 | '广州': [113.23, 23.16],
8 | '盐城': [120.13, 33.38],
9 | '赤峰': [118.87, 42.28],
10 | '深圳': [114.07, 22.62],
11 | '青岛': [120.33, 36.07],
12 | '北京': [116.46, 39.92],
13 | '乳山': [121.52, 36.89],
14 | '金昌': [102.188043, 38.520089],
15 | '泉州': [118.58, 24.93],
16 | '莱西': [120.53, 36.86],
17 | '日照': [119.46, 35.42],
18 | '胶南': [119.97, 35.88],
19 | '南通': [121.05, 32.08],
20 | '拉萨': [91.11, 29.97],
21 | '云浮': [112.02, 22.93],
22 | '梅州': [116.1, 24.55],
23 | '文登': [122.05, 37.2],
24 | '上海': [121.48, 31.22]
25 | };
26 |
--------------------------------------------------------------------------------
/components/home/map-data/get-style-json.js:
--------------------------------------------------------------------------------
1 | export default [{
2 | 'featureType': 'water',
3 | 'elementType': 'all',
4 | 'stylers': {
5 | 'visibility': 'off'
6 | }
7 | }, {
8 | 'featureType': 'land',
9 | 'elementType': 'all',
10 | 'stylers': {
11 | 'color': 'red'
12 | }
13 | }, {
14 | 'featureType': 'railway',
15 | 'elementType': 'all',
16 | 'stylers': {
17 | 'visibility': 'off'
18 | }
19 | }, {
20 | 'featureType': 'highway',
21 | 'elementType': 'all',
22 | 'stylers': {
23 | 'color': '#fdfdfd'
24 | }
25 | }, {
26 | 'featureType': 'highway',
27 | 'elementType': 'labels',
28 | 'stylers': {
29 | 'visibility': 'off'
30 | }
31 | }, {
32 | 'featureType': 'arterial',
33 | 'elementType': 'geometry',
34 | 'stylers': {
35 | 'color': '#00ff00'
36 | }
37 | }, {
38 | 'featureType': 'arterial',
39 | 'elementType': 'geometry.fill',
40 | 'stylers': {
41 | 'color': '#fefefe'
42 | }
43 | }, {
44 | 'featureType': 'poi',
45 | 'elementType': 'all',
46 | 'stylers': {
47 | 'visibility': 'off'
48 | }
49 | }, {
50 | 'featureType': 'green',
51 | 'elementType': 'all',
52 | 'stylers': {
53 | 'visibility': 'off'
54 | }
55 | }, {
56 | 'featureType': 'subway',
57 | 'elementType': 'all',
58 | 'stylers': {
59 | 'visibility': 'off'
60 | }
61 | }, {
62 | 'featureType': 'manmade',
63 | 'elementType': 'all',
64 | 'stylers': {
65 | 'color': 'red'
66 | }
67 | }, {
68 | 'featureType': 'local',
69 | 'elementType': 'all',
70 | 'stylers': {
71 | 'color': 'red'
72 | }
73 | }, {
74 | 'featureType': 'arterial',
75 | 'elementType': 'labels',
76 | 'stylers': {
77 | 'visibility': 'off'
78 | }
79 | }, {
80 | 'featureType': 'boundary',
81 | 'elementType': 'all',
82 | 'stylers': {
83 | 'color': '#000'
84 | }
85 | }, {
86 | 'featureType': 'building',
87 | 'elementType': 'all',
88 | 'stylers': {
89 | 'color': '#d1d1d1'
90 | }
91 | }, {
92 | 'featureType': 'label',
93 | 'elementType': 'labels.text.fill',
94 | 'stylers': {
95 | 'color': '#999999'
96 | }
97 | }];
98 |
--------------------------------------------------------------------------------
/components/loading.vue:
--------------------------------------------------------------------------------
1 |
2 |
5 |
6 |
7 |
22 |
23 |
37 |
--------------------------------------------------------------------------------
/components/main-components/breadcrumb-nav.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 | {{ itemTitle(item) }}
8 |
9 |
10 |
11 |
28 |
29 |
--------------------------------------------------------------------------------
/components/main-components/fullscreen.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
75 |
--------------------------------------------------------------------------------
/components/main-components/lockscreen/components/locking-page.vue:
--------------------------------------------------------------------------------
1 |
2 |
7 |
8 |
9 |
45 |
--------------------------------------------------------------------------------
/components/main-components/lockscreen/components/unlock.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 |
![]()
10 |
14 |
15 |
16 |
24 |
已锁定
25 |
26 |
27 |
28 |
29 |
81 |
--------------------------------------------------------------------------------
/components/main-components/lockscreen/lockscreen.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
66 |
67 |
--------------------------------------------------------------------------------
/components/main-components/message-tip.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
31 |
--------------------------------------------------------------------------------
/components/main-components/shrinkable-menu/components/sidebarMenu.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
27 |
28 |
29 |
65 |
--------------------------------------------------------------------------------
/components/main-components/shrinkable-menu/components/sidebarMenuShrink.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
9 |
10 |
11 | {{ itemTitle(child) }}
12 |
13 |
14 |
15 |
16 |
19 |
20 | {{ itemTitle(item.children[0]) }}
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
58 |
--------------------------------------------------------------------------------
/components/main-components/shrinkable-menu/shrinkable-menu.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
24 |
25 |
26 |
89 |
--------------------------------------------------------------------------------
/components/main-components/shrinkable-menu/styles/menu.less:
--------------------------------------------------------------------------------
1 | .ivu-shrinkable-menu{
2 | height: 100%;
3 | width: 100%;
4 | }
--------------------------------------------------------------------------------
/components/my-components/area-linkage/area-linkage.less:
--------------------------------------------------------------------------------
1 | .area-linkage-page{
2 | &-row1{
3 | height: 366px !important;
4 | }
5 | &-row2{
6 | height: 112px !important;
7 | }
8 | }
--------------------------------------------------------------------------------
/components/my-components/area-linkage/util/index.js:
--------------------------------------------------------------------------------
1 | let util = {};
2 |
3 | util.levelArr = [0, 1, 2, 3];
4 |
5 | util.oneOf = (item, arr) => {
6 | return arr.some(i => {
7 | return i === item;
8 | });
9 | };
10 | util.getIndex = (list, name) => {
11 | for (const i in list) {
12 | if (list[i] === name) {
13 | return i;
14 | }
15 | }
16 | };
17 |
18 | util.dataType = ['all', 'code', 'name'];
19 |
20 | util.checkLevel = val => {
21 | return util.oneOf(val, util.levelArr);
22 | };
23 |
24 | export default util;
25 |
--------------------------------------------------------------------------------
/components/my-components/count-to/count-to.less:
--------------------------------------------------------------------------------
1 | .countto-page-row{
2 | height: 200px;
3 | }
4 | .count-to-con{
5 | display: block;
6 | width: 100%;
7 | text-align: center;
8 | }
9 | .pre-code-show-con p{
10 | height: 30px;
11 | margin: 0;
12 | }
--------------------------------------------------------------------------------
/components/my-components/draggable-list/draggable-list.less:
--------------------------------------------------------------------------------
1 | .iview-admin-draggable-list{
2 | height: 100%;
3 | }
4 | .iview-admin-draggable-list li{
5 | padding: 9px;
6 | border: 1px solid #e7ebee;
7 | border-radius: 3px;
8 | margin-bottom: 5px;
9 | cursor: pointer;
10 | position: relative;
11 | transition: all .2s;
12 | }
13 | .iview-admin-draggable-list li:hover{
14 | color: #87b4ee;
15 | border-color: #87b4ee;
16 | transition: all .2s;
17 | }
18 | .iview-admin-draggable-delete{
19 | height: 100%;
20 | position: absolute;
21 | right: -8px;
22 | top: 0px;
23 | display: none;
24 | }
25 | .iview-admin-draggable-list li:hover .iview-admin-draggable-delete{
26 | display: block;
27 | }
28 | .placeholder-style{
29 | display: block !important;
30 | color: transparent;
31 | border-style: dashed !important;
32 | }
33 | .delte-item-animation{
34 | opacity: 0;
35 | transition: all .2s;
36 | }
37 | .iview-admin-draggable-list{
38 | overflow: auto
39 | }
--------------------------------------------------------------------------------
/components/my-components/file-upload/upload.less:
--------------------------------------------------------------------------------
1 | .admin-upload-list{
2 | display: inline-block;
3 | width: 60px;
4 | height: 60px;
5 | text-align: center;
6 | line-height: 60px;
7 | border: 1px solid transparent;
8 | border-radius: 4px;
9 | overflow: hidden;
10 | background: #fff;
11 | position: relative;
12 | box-shadow: 0 1px 1px rgba(0,0,0,.2);
13 | margin-right: 4px;
14 | }
15 | .admin-upload-list img{
16 | width: 100%;
17 | height: 100%;
18 | }
19 | .admin-upload-list-cover{
20 | display: none;
21 | position: absolute;
22 | top: 0;
23 | bottom: 0;
24 | left: 0;
25 | right: 0;
26 | background: rgba(0,0,0,.6);
27 | }
28 | .admin-upload-list:hover .admin-upload-list-cover{
29 | display: block;
30 | }
31 | .admin-upload-list-cover i{
32 | color: #fff;
33 | font-size: 20px;
34 | cursor: pointer;
35 | margin: 0 2px;
36 | }
--------------------------------------------------------------------------------
/components/my-components/image-editor/image-editor.less:
--------------------------------------------------------------------------------
1 | .image-editor{
2 | .cropper{
3 | box-sizing: border-box;
4 | border: 1px solid #c3c3c3;
5 | width: 100%;
6 | height: 100%;
7 | img{
8 | max-height: 100%;
9 | }
10 | }
11 | .fileinput{
12 | display: none;
13 | }
14 | .filelabel{
15 | display: block;
16 | padding: 6px 15px;
17 | background: #2d8cf0;
18 | display: inline-block;
19 | border: 1px solid #2d8cf0;
20 | border-radius: 4px;
21 | cursor: pointer;
22 | color: white;
23 | font-size: 12px;
24 | text-align: center;
25 | transition: all .2s;
26 | &:hover{
27 | background: #5cadff;
28 | border: 1px solid #5cadff;
29 | transition: all .2s;
30 | }
31 | }
32 | &-con1{
33 | height: 300px;
34 | &-preview-con{
35 | width: 100% !important;
36 | height: 200px !important;
37 | border: 1px solid #c3c3c3;
38 | #preview1{
39 | width: 100%;
40 | height: 100%;
41 | overflow: hidden;
42 | }
43 | }
44 | }
45 | &-con2{
46 | height: 300px;
47 | p{
48 | font-size: 14px;
49 | padding: 6px;
50 | border-bottom: 1px solid #c3c3c3;
51 | b{
52 | display: inline-block;
53 | width: 80px;
54 | }
55 | }
56 | }
57 | &-con3{
58 | height: 300px;
59 | .cropper3{
60 | box-sizing: border-box;
61 | border: 1px solid #c3c3c3;
62 | width: 100%;
63 | height: 100%;
64 | img{
65 | max-height: 100%;
66 | }
67 | }
68 | &-btn-box{
69 | text-align: center;
70 | }
71 | .filelabel3{
72 | width: 190px;
73 | box-sizing: border-box;
74 | }
75 | .crop3-btn-box{
76 | text-align: center;
77 | }
78 | &-preview-con{
79 | width: 100% !important;
80 | height: 300px !important;
81 | border: 1px solid #c3c3c3;
82 | #preview3{
83 | width: 100%;
84 | height: 100%;
85 | overflow: hidden;
86 | }
87 | }
88 | }
89 | }
--------------------------------------------------------------------------------
/components/my-components/markdown-editor/markdown-editor.less:
--------------------------------------------------------------------------------
1 | .CodeMirror, .CodeMirror-scroll {
2 | min-height: 600px !important;
3 | }
4 | .CodeMirror{
5 | height: 400px;
6 | }
--------------------------------------------------------------------------------
/components/my-components/markdown-editor/markdown-editor.vue:
--------------------------------------------------------------------------------
1 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
34 |
--------------------------------------------------------------------------------
/components/my-components/scroll-bar/scroll-bar-page.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
13 |
14 |
15 |
16 |
17 |
22 |
23 |
24 |
25 |
26 |
31 |
32 |
33 |
34 |
35 |
40 |
41 |
42 |
43 |
44 |
45 |
46 |
51 |
52 |
53 |
54 |
55 |
60 |
61 |
62 |
63 |
64 |
69 |
70 |
71 |
72 |
73 |
78 |
79 |
80 |
81 |
82 |
83 |
84 |
93 |
94 |
103 |
--------------------------------------------------------------------------------
/components/my-components/scroll-bar/vue-scroller-bars/index.js:
--------------------------------------------------------------------------------
1 | import scrollBar from './scroll-bar.vue';
2 |
3 | export default scrollBar;
4 |
--------------------------------------------------------------------------------
/components/my-components/scroll-bar/vue-scroller-bars/scroll-bar.less:
--------------------------------------------------------------------------------
1 | @prefix: ~'vue-scroller-bars';
2 |
3 | .@{prefix}{
4 | &-wraper{
5 | height: 100%;
6 | width: 100%;
7 | overflow: hidden;
8 | position: relative;
9 | &.show-when-hover{
10 | .@{prefix}-scroll{
11 | opacity: 0;
12 | }
13 | .@{prefix}-place-holder{
14 | opacity: 0;
15 | }
16 | }
17 | &.show-when-hover:hover{
18 | .@{prefix}-scroll{
19 | opacity: 1;
20 | }
21 | .@{prefix}-place-holder{
22 | opacity: 1;
23 | }
24 | }
25 | }
26 | &-content{
27 | position: absolute;
28 | min-width: 100%;
29 | left: 0;
30 | top: 0;
31 | }
32 | &-scroll{
33 | position: relative;
34 | transition: opacity .3s ease .2s;
35 | background: rgba(250, 250, 250, 1);
36 | box-sizing: border-box;
37 | padding: 1px 2px;
38 | z-index: 9999999;
39 | &:hover &-bar{
40 | background: rgb(100, 100, 100);
41 | }
42 | &-y{
43 | width: 14px;
44 | height: 100%;
45 | float: right;
46 | border-left: 1px solid rgba(190, 190, 190, .5);
47 | border-right: 1px solid rgba(190, 190, 190, .5);
48 | &.scroll-y-cover{
49 | position: absolute;
50 | right: 0px;
51 | top: 0px;
52 | }
53 | }
54 | &-x{
55 | width: 100%;
56 | height: 14px;
57 | float: right;
58 | border-top: 1px solid rgba(190, 190, 190, .5);
59 | border-bottom: 1px solid rgba(190, 190, 190, .5);
60 | &.scroll-x-cover{
61 | position: absolute;
62 | left: 0px;
63 | bottom: 0px;
64 | }
65 | }
66 | &-bar{
67 | background: rgba(190, 190, 190, 1);
68 | position: absolute;
69 | border-radius: 4px;
70 | transition: background .2s ease;
71 | &-y{
72 | width: ~'calc(100% - 4px)';
73 | min-height: 14px;
74 | }
75 | &-x{
76 | height: ~'calc(100% - 4px)';
77 | min-width: 14px;
78 | }
79 | }
80 | }
81 | &-place-holder{
82 | position: absolute;
83 | transition: opacity .3s ease .2s;
84 | right: 0px;
85 | bottom: 0px;
86 | width: 14px;
87 | height: 14px;
88 | background: rgba(250, 250, 250, 1);
89 | }
90 | }
--------------------------------------------------------------------------------
/components/my-components/split-pane/split-pane/index.js:
--------------------------------------------------------------------------------
1 | import splitPane from './split-pane.vue';
2 |
3 | export default splitPane;
4 |
--------------------------------------------------------------------------------
/components/my-components/split-pane/split-pane/split-pane.less:
--------------------------------------------------------------------------------
1 | @prefix: ~"split-pane";
2 | @container: ~"@{prefix}-container";
3 | @trigger: ~"@{prefix}-trigger";
4 |
5 | .@{prefix}{
6 | position: relative;
7 | &-container{
8 | height: 100%;
9 | width: 100%;
10 | }
11 |
12 | &-horizontal{
13 | & > div > .@{trigger}{
14 | transform: translateX(-50%);
15 | cursor: col-resize;
16 | width: 8px;
17 | height: 100%;
18 | margin: 0 1px;
19 | .trigger-middle-point{
20 | width: 3px;
21 | height: 20px;
22 | p{
23 | width: 100%;
24 | height: 1px;
25 | margin-top: 2px;
26 | }
27 | }
28 | }
29 | }
30 |
31 | &-vertical{
32 | & > div > .@{trigger}{
33 | transform: translateY(-50%);
34 | cursor: row-resize;
35 | height: 8px;
36 | width: 100%;
37 | margin: 1px 0;
38 | .trigger-middle-point{
39 | width: 20px;
40 | height: 3px;
41 | p{
42 | height: 100%;
43 | width: 1px;
44 | display: inline-block;
45 | margin-left: 2px;
46 | }
47 | }
48 | }
49 | }
50 |
51 | &-trigger{
52 | position: absolute;
53 | z-index: 3;
54 | background: #F8F8F9;
55 | box-shadow: 0 0 4px 0 rgba(28,36,56,0.32);
56 | .trigger-middle-point{
57 | position: absolute;
58 | top: 50%;
59 | left: 50%;
60 | transform: translate(-50%,-87%);
61 | line-height: 0px;
62 | p{
63 | background: rgba(23,35,61,0.25);
64 | }
65 | }
66 | }
67 |
68 | &-left-area{
69 | height: 100%;
70 | float: left;
71 | z-index: 2;
72 | // overflow: auto;
73 | }
74 |
75 | &-right-area{
76 | height: 100%;
77 | float: left;
78 | z-index: 2;
79 | // overflow: auto;
80 | }
81 |
82 | &-top-area{
83 | width: 100%;
84 | z-index: 2;
85 | // overflow: auto;
86 | }
87 |
88 | &-bottom-area{
89 | width: 100%;
90 | z-index: 2;
91 | // overflow: auto;
92 | }
93 | }
--------------------------------------------------------------------------------
/components/my-components/text-editor/text-editor.vue:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 | 加载组件中...
13 |
14 |
15 |
16 |
17 |
74 |
75 |
78 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/advlist/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "advlist" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/advlist')
5 | // ES2015:
6 | // import 'tinymce/plugins/advlist'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/anchor/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "anchor" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/anchor')
5 | // ES2015:
6 | // import 'tinymce/plugins/anchor'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/anchor/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('5', tinymce.util.Tools.resolve), g('1', ['5'], function (a) { return a('tinymce.PluginManager'); }), g('7', [], function () { var a = function (a) { return /^[A-Za-z][A-Za-z0-9\-:._]*$/.test(a); }, b = function (a) { var b = a.selection.getNode(), c = b.tagName === 'A' && a.dom.getAttrib(b, 'href') === ''; return c ? b.id || b.name : ''; }, c = function (a, b) { var c = a.selection.getNode(), d = c.tagName === 'A' && a.dom.getAttrib(c, 'href') === ''; d ? (c.removeAttribute('name'), c.id = b) : (a.focus(), a.selection.collapse(!0), a.execCommand('mceInsertContent', !1, a.dom.createHTML('a', {id: b}))); }; return {isValidId: a, getId: b, insert: c}; }), g('6', ['7'], function (a) { var b = function (b, c) { return a.isValidId(c) ? (a.insert(b, c), !1) : (b.windowManager.alert('Id should start with a letter, followed only by letters, numbers, dashes, dots, colons or underscores.'), !0); }, c = function (c) { var d = a.getId(c); c.windowManager.open({title: 'Anchor', body: {type: 'textbox', name: 'id', size: 40, label: 'Id', value: d}, onsubmit: function (a) { var d = a.data.id; b(c, d) && a.preventDefault(); }}); }; return {open: c}; }), g('2', ['6'], function (a) { var b = function (b) { b.addCommand('mceAnchor', function () { a.open(b); }); }; return {register: b}; }), g('3', [], function () { var a = function (a) { return !a.attr('href') && (a.attr('id') || a.attr('name')) && !a.firstChild; }, b = function (b) { return function (c) { for (var d = 0; d < c.length; d++)a(c[d]) && c[d].attr('contenteditable', b); }; }, c = function (a) { a.on('PreInit', function () { a.parser.addNodeFilter('a', b('false')), a.serializer.addNodeFilter('a', b(null)); }); }; return {setup: c}; }), g('4', [], function () { var a = function (a) { a.addButton('anchor', {icon: 'anchor', tooltip: 'Anchor', cmd: 'mceAnchor', stateSelector: 'a:not([href])'}), a.addMenuItem('anchor', {icon: 'anchor', text: 'Anchor', context: 'insert', cmd: 'mceAnchor'}); }; return {register: a}; }), g('0', ['1', '2', '3', '4'], function (a, b, c, d) { return a.add('anchor', function (a) { c.setup(a), b.register(a), d.register(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/autolink/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "autolink" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/autolink')
5 | // ES2015:
6 | // import 'tinymce/plugins/autolink'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/autoresize/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "autoresize" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/autoresize')
5 | // ES2015:
6 | // import 'tinymce/plugins/autoresize'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/autosave/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "autosave" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/autosave')
5 | // ES2015:
6 | // import 'tinymce/plugins/autosave'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/bbcode/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "bbcode" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/bbcode')
5 | // ES2015:
6 | // import 'tinymce/plugins/bbcode'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/charmap/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "charmap" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/charmap')
5 | // ES2015:
6 | // import 'tinymce/plugins/charmap'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/code/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "code" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/code')
5 | // ES2015:
6 | // import 'tinymce/plugins/code'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/code/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('4', tinymce.util.Tools.resolve), g('1', ['4'], function (a) { return a('tinymce.PluginManager'); }), g('8', ['4'], function (a) { return a('tinymce.dom.DOMUtils'); }), g('6', ['8'], function (a) { var b = function (a) { return a.getParam('code_dialog_width', 600); }, c = function (b) { return b.getParam('code_dialog_height', Math.min(a.DOM.getViewPort().h - 200, 500)); }; return {getMinWidth: b, getMinHeight: c}; }), g('7', [], function () { var a = function (a, b) { a.focus(), a.undoManager.transact(function () { a.setContent(b); }), a.selection.setCursorLocation(), a.nodeChanged(); }, b = function (a) { return a.getContent({source_view: !0}); }; return {setContent: a, getContent: b}; }), g('5', ['6', '7'], function (a, b) { var c = function (c) { var d = a.getMinWidth(c), e = a.getMinHeight(c), f = c.windowManager.open({title: 'Source code', body: {type: 'textbox', name: 'code', multiline: !0, minWidth: d, minHeight: e, spellcheck: !1, style: 'direction: ltr; text-align: left'}, onSubmit: function (a) { b.setContent(c, a.data.code); }}); f.find('#code').value(b.getContent(c)); }; return {open: c}; }), g('2', ['5'], function (a) { var b = function (b) { b.addCommand('mceCodeEditor', function () { a.open(b); }); }; return {register: b}; }), g('3', ['5'], function (a) { var b = function (b) { b.addButton('code', {icon: 'code', tooltip: 'Source code', onclick: function () { a.open(b); }}), b.addMenuItem('code', {icon: 'code', text: 'Source code', onclick: function () { a.open(b); }}); }; return {register: b}; }), g('0', ['1', '2', '3'], function (a, b, c) { return a.add('code', function (a) { return b.register(a), c.register(a), {}; }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/codesample/css/prism.css:
--------------------------------------------------------------------------------
1 | /* http://prismjs.com/download.html?themes=prism&languages=markup+css+clike+javascript */
2 | /**
3 | * prism.js default theme for JavaScript, CSS and HTML
4 | * Based on dabblet (http://dabblet.com)
5 | * @author Lea Verou
6 | */
7 |
8 | code[class*="language-"],
9 | pre[class*="language-"] {
10 | color: black;
11 | text-shadow: 0 1px white;
12 | font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
13 | direction: ltr;
14 | text-align: left;
15 | white-space: pre;
16 | word-spacing: normal;
17 | word-break: normal;
18 | word-wrap: normal;
19 | line-height: 1.5;
20 |
21 | -moz-tab-size: 4;
22 | -o-tab-size: 4;
23 | tab-size: 4;
24 |
25 | -webkit-hyphens: none;
26 | -moz-hyphens: none;
27 | -ms-hyphens: none;
28 | hyphens: none;
29 | }
30 |
31 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection,
32 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection {
33 | text-shadow: none;
34 | background: #b3d4fc;
35 | }
36 |
37 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection,
38 | code[class*="language-"]::selection, code[class*="language-"] ::selection {
39 | text-shadow: none;
40 | background: #b3d4fc;
41 | }
42 |
43 | @media print {
44 | code[class*="language-"],
45 | pre[class*="language-"] {
46 | text-shadow: none;
47 | }
48 | }
49 |
50 | /* Code blocks */
51 | pre[class*="language-"] {
52 | padding: 1em;
53 | margin: .5em 0;
54 | overflow: auto;
55 | }
56 |
57 | :not(pre) > code[class*="language-"],
58 | pre[class*="language-"] {
59 | background: #f5f2f0;
60 | }
61 |
62 | /* Inline code */
63 | :not(pre) > code[class*="language-"] {
64 | padding: .1em;
65 | border-radius: .3em;
66 | }
67 |
68 | .token.comment,
69 | .token.prolog,
70 | .token.doctype,
71 | .token.cdata {
72 | color: slategray;
73 | }
74 |
75 | .token.punctuation {
76 | color: #999;
77 | }
78 |
79 | .namespace {
80 | opacity: .7;
81 | }
82 |
83 | .token.property,
84 | .token.tag,
85 | .token.boolean,
86 | .token.number,
87 | .token.constant,
88 | .token.symbol,
89 | .token.deleted {
90 | color: #905;
91 | }
92 |
93 | .token.selector,
94 | .token.attr-name,
95 | .token.string,
96 | .token.char,
97 | .token.builtin,
98 | .token.inserted {
99 | color: #690;
100 | }
101 |
102 | .token.operator,
103 | .token.entity,
104 | .token.url,
105 | .language-css .token.string,
106 | .style .token.string {
107 | color: #a67f59;
108 | background: hsla(0, 0%, 100%, .5);
109 | }
110 |
111 | .token.atrule,
112 | .token.attr-value,
113 | .token.keyword {
114 | color: #07a;
115 | }
116 |
117 | .token.function {
118 | color: #DD4A68;
119 | }
120 |
121 | .token.regex,
122 | .token.important,
123 | .token.variable {
124 | color: #e90;
125 | }
126 |
127 | .token.important,
128 | .token.bold {
129 | font-weight: bold;
130 | }
131 | .token.italic {
132 | font-style: italic;
133 | }
134 |
135 | .token.entity {
136 | cursor: help;
137 | }
138 |
139 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/codesample/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "codesample" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/codesample')
5 | // ES2015:
6 | // import 'tinymce/plugins/codesample'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/colorpicker/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "colorpicker" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/colorpicker')
5 | // ES2015:
6 | // import 'tinymce/plugins/colorpicker'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/colorpicker/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('3', tinymce.util.Tools.resolve), g('1', ['3'], function (a) { return a('tinymce.PluginManager'); }), g('4', ['3'], function (a) { return a('tinymce.util.Color'); }), g('2', ['4'], function (a) { var b = function (a, b) { a.find('#preview')[0].getEl().style.background = b; }, c = function (c, d) { var e = new a(d), f = e.toRgb(); c.fromJSON({r: f.r, g: f.g, b: f.b, hex: e.toHex().substr(1)}), b(c, e.toHex()); }, d = function (a, d, e) { var f = a.windowManager.open({title: 'Color', items: {type: 'container', layout: 'flex', direction: 'row', align: 'stretch', padding: 5, spacing: 10, items: [{type: 'colorpicker', value: e, onchange: function () { var a = this.rgb(); f && (f.find('#r').value(a.r), f.find('#g').value(a.g), f.find('#b').value(a.b), f.find('#hex').value(this.value().substr(1)), b(f, this.value())); }}, {type: 'form', padding: 0, labelGap: 5, defaults: {type: 'textbox', size: 7, value: '0', flex: 1, spellcheck: !1, onchange: function () { var a, b, d = f.find('colorpicker')[0]; return a = this.name(), b = this.value(), a === 'hex' ? (b = '#' + b, c(f, b), void d.value(b)) : (b = {r: f.find('#r').value(), g: f.find('#g').value(), b: f.find('#b').value()}, d.value(b), void c(f, b)); }}, items: [{name: 'r', label: 'R', autofocus: 1}, {name: 'g', label: 'G'}, {name: 'b', label: 'B'}, {name: 'hex', label: '#', value: '000000'}, {name: 'preview', type: 'container', border: 1}]}]}, onSubmit: function () { d('#' + f.toJSON().hex); }}); c(f, e); }; return {open: d}; }), g('0', ['1', '2'], function (a, b) { return a.add('colorpicker', function (a) { a.settings.color_picker_callback || (a.settings.color_picker_callback = function (c, d) { b.open(a, c, d); }); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/contextmenu/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "contextmenu" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/contextmenu')
5 | // ES2015:
6 | // import 'tinymce/plugins/contextmenu'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/directionality/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "directionality" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/directionality')
5 | // ES2015:
6 | // import 'tinymce/plugins/directionality'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/directionality/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('4', tinymce.util.Tools.resolve), g('1', ['4'], function (a) { return a('tinymce.PluginManager'); }), g('6', ['4'], function (a) { return a('tinymce.util.Tools'); }), g('5', ['6'], function (a) { var b = function (b, c) { var d, e = b.dom, f = b.selection.getSelectedBlocks(); f.length && (d = e.getAttrib(f[0], 'dir'), a.each(f, function (a) { e.getParent(a.parentNode, '*[dir="' + c + '"]', e.getRoot()) || e.setAttrib(a, 'dir', d !== c ? c : null); }), b.nodeChanged()); }; return {setDir: b}; }), g('2', ['5'], function (a) { var b = function (b) { b.addCommand('mceDirectionLTR', function () { a.setDir(b, 'ltr'); }), b.addCommand('mceDirectionRTL', function () { a.setDir(b, 'rtl'); }); }; return {register: b}; }), g('3', ['6'], function (a) { var b = function (b) { var c = []; return a.each('h1 h2 h3 h4 h5 h6 div p'.split(' '), function (a) { c.push(a + '[dir=' + b + ']'); }), c.join(','); }, c = function (a) { a.addButton('ltr', {title: 'Left to right', cmd: 'mceDirectionLTR', stateSelector: b('ltr')}), a.addButton('rtl', {title: 'Right to left', cmd: 'mceDirectionRTL', stateSelector: b('rtl')}); }; return {register: c}; }), g('0', ['1', '2', '3'], function (a, b, c) { return a.add('directionality', function (a) { b.register(a), c.register(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-cool.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-cool.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-cry.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-cry.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-embarassed.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-embarassed.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-foot-in-mouth.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-foot-in-mouth.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-frown.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-frown.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-innocent.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-innocent.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-kiss.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-kiss.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-laughing.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-laughing.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-money-mouth.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-money-mouth.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-sealed.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-sealed.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-smile.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-smile.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-surprised.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-surprised.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-tongue-out.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-tongue-out.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-undecided.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-undecided.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-wink.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-wink.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-yell.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/emoticons/img/smiley-yell.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "emoticons" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/emoticons')
5 | // ES2015:
6 | // import 'tinymce/plugins/emoticons'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/emoticons/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('3', tinymce.util.Tools.resolve), g('1', ['3'], function (a) { return a('tinymce.PluginManager'); }), g('5', ['3'], function (a) { return a('tinymce.util.Tools'); }), g('4', ['5'], function (a) { var b = [['cool', 'cry', 'embarassed', 'foot-in-mouth'], ['frown', 'innocent', 'kiss', 'laughing'], ['money-mouth', 'sealed', 'smile', 'surprised'], ['tongue-out', 'undecided', 'wink', 'yell']], c = function (c) { var d; return d = '
', a.each(b, function (b) { d += '', a.each(b, function (a) { var b = c + '/img/smiley-' + a + '.gif'; d += ' | '; }), d += '
'; }), d += '
'; }; return {getHtml: c}; }), g('2', ['4'], function (a) { var b = function (a, b, c) { a.insertContent(a.dom.createHTML('img', {src: b, alt: c})); }, c = function (c, d) { var e = a.getHtml(d); c.addButton('emoticons', {type: 'panelbutton', panel: {role: 'application', autohide: !0, html: e, onclick: function (a) { var d = c.dom.getParent(a.target, 'a'); d && (b(c, d.getAttribute('data-mce-url'), d.getAttribute('data-mce-alt')), this.hide()); }}, tooltip: 'Emoticons'}); }; return {register: c}; }), g('0', ['1', '2'], function (a, b) { return a.add('emoticons', function (a, c) { b.register(a, c); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/fullpage/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "fullpage" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/fullpage')
5 | // ES2015:
6 | // import 'tinymce/plugins/fullpage'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/fullscreen/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "fullscreen" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/fullscreen')
5 | // ES2015:
6 | // import 'tinymce/plugins/fullscreen'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/help/img/logo.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/plugins/help/img/logo.png
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/help/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "help" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/help')
5 | // ES2015:
6 | // import 'tinymce/plugins/help'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/hr/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "hr" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/hr')
5 | // ES2015:
6 | // import 'tinymce/plugins/hr'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/hr/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('4', tinymce.util.Tools.resolve), g('1', ['4'], function (a) { return a('tinymce.PluginManager'); }), g('2', [], function () { var a = function (a) { a.addCommand('InsertHorizontalRule', function () { a.execCommand('mceInsertContent', !1, '
'); }); }; return {register: a}; }), g('3', [], function () { var a = function (a) { a.addButton('hr', {icon: 'hr', tooltip: 'Horizontal line', cmd: 'InsertHorizontalRule'}), a.addMenuItem('hr', {icon: 'hr', text: 'Horizontal line', cmd: 'InsertHorizontalRule', context: 'insert'}); }; return {register: a}; }), g('0', ['1', '2', '3'], function (a, b, c) { return a.add('hr', function (a) { b.register(a), c.register(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/image/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "image" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/image')
5 | // ES2015:
6 | // import 'tinymce/plugins/image'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/imagetools/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "imagetools" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/imagetools')
5 | // ES2015:
6 | // import 'tinymce/plugins/imagetools'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/importcss/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "importcss" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/importcss')
5 | // ES2015:
6 | // import 'tinymce/plugins/importcss'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/insertdatetime/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "insertdatetime" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/insertdatetime')
5 | // ES2015:
6 | // import 'tinymce/plugins/insertdatetime'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/legacyoutput/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "legacyoutput" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/legacyoutput')
5 | // ES2015:
6 | // import 'tinymce/plugins/legacyoutput'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/link/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "link" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/link')
5 | // ES2015:
6 | // import 'tinymce/plugins/link'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/lists/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "lists" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/lists')
5 | // ES2015:
6 | // import 'tinymce/plugins/lists'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/media/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "media" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/media')
5 | // ES2015:
6 | // import 'tinymce/plugins/media'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/nonbreaking/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "nonbreaking" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/nonbreaking')
5 | // ES2015:
6 | // import 'tinymce/plugins/nonbreaking'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/nonbreaking/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('5', tinymce.util.Tools.resolve), g('1', ['5'], function (a) { return a('tinymce.PluginManager'); }), g('6', [], function () { var a = function (a, b) { for (var c = '', d = 0; d < b; d++)c += a; return c; }, b = function (a) { return !!a.plugins.visualchars && a.plugins.visualchars.isEnabled(); }, c = function (c, d) { var e = b(c) ? ' ' : ' '; c.insertContent(a(e, d)), c.dom.setAttrib(c.dom.select('span.mce-nbsp'), 'data-mce-bogus', '1'); }; return {insertNbsp: c}; }), g('2', ['6'], function (a) { var b = function (b) { b.addCommand('mceNonBreaking', function () { a.insertNbsp(b, 1); }); }; return {register: b}; }), g('7', [], function () { var a = function (a) { var b = a.getParam('nonbreaking_force_tab', 0); return typeof tabs === 'boolean' ? b === !0 ? 3 : 0 : b; }; return {getKeyboardSpaces: a}; }), g('3', ['7', '6'], function (a, b) { var c = function (c) { var d = a.getKeyboardSpaces(c); d > 0 && c.on('keydown', function (a) { if (a.keyCode === 9) { if (a.shiftKey) return; a.preventDefault(), b.insertNbsp(c, d); } }); }; return {setup: c}; }), g('4', [], function () { var a = function (a) { a.addButton('nonbreaking', {title: 'Nonbreaking space', cmd: 'mceNonBreaking'}), a.addMenuItem('nonbreaking', {text: 'Nonbreaking space', cmd: 'mceNonBreaking', context: 'insert'}); }; return {register: a}; }), g('0', ['1', '2', '3', '4'], function (a, b, c, d) { return a.add('nonbreaking', function (a) { b.register(a), d.register(a), c.setup(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/noneditable/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "noneditable" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/noneditable')
5 | // ES2015:
6 | // import 'tinymce/plugins/noneditable'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/noneditable/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('3', tinymce.util.Tools.resolve), g('1', ['3'], function (a) { return a('tinymce.PluginManager'); }), g('4', ['3'], function (a) { return a('tinymce.util.Tools'); }), g('5', [], function () { var a = function (a) { return a.getParam('noneditable_noneditable_class', 'mceNonEditable'); }, b = function (a) { return a.getParam('noneditable_editable_class', 'mceEditable'); }, c = function (a) { var b = a.getParam('noneditable_regexp', []); return b && b.constructor === RegExp ? [b] : b; }; return {getNonEditableClass: a, getEditableClass: b, getNonEditableRegExps: c}; }), g('2', ['4', '5'], function (a, b) { var c = function (a) { return function (b) { return (' ' + b.attr('class') + ' ').indexOf(a) !== -1; }; }, d = function (a, b, c) { return function (d) { var e = arguments, f = e[e.length - 2], g = f > 0 ? b.charAt(f - 1) : ''; if (g === '"') return d; if (g === '>') { var h = b.lastIndexOf('<', f); if (h !== -1) { var i = b.substring(h, f); if (i.indexOf('contenteditable="false"') !== -1) return d; } } return '' + a.dom.encode(typeof e[1] === 'string' ? e[1] : e[0]) + ''; }; }, e = function (a, c, e) { var f = c.length, g = e.content; if (e.format !== 'raw') { for (;f--;)g = g.replace(c[f], d(a, g, b.getNonEditableClass(a))); e.content = g; } }, f = function (d) { var f, g, h = 'contenteditable'; f = ' ' + a.trim(b.getEditableClass(d)) + ' ', g = ' ' + a.trim(b.getNonEditableClass(d)) + ' '; var i = c(f), j = c(g), k = b.getNonEditableRegExps(d); d.on('PreInit', function () { k.length > 0 && d.on('BeforeSetContent', function (a) { e(d, k, a); }), d.parser.addAttributeFilter('class', function (a) { for (var b, c = a.length; c--;)b = a[c], i(b) ? b.attr(h, 'true') : j(b) && b.attr(h, 'false'); }), d.serializer.addAttributeFilter(h, function (a) { for (var b, c = a.length; c--;)b = a[c], (i(b) || j(b)) && (k.length > 0 && b.attr('data-mce-content') ? (b.name = '#text', b.type = 3, b.raw = !0, b.value = b.attr('data-mce-content')) : b.attr(h, null)); }); }); }; return {setup: f}; }), g('0', ['1', '2'], function (a, b) { return a.add('noneditable', function (a) { b.setup(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/pagebreak/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "pagebreak" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/pagebreak')
5 | // ES2015:
6 | // import 'tinymce/plugins/pagebreak'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/pagebreak/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('7', tinymce.util.Tools.resolve), g('1', ['7'], function (a) { return a('tinymce.Env'); }), g('2', ['7'], function (a) { return a('tinymce.PluginManager'); }), g('8', [], function () { var a = function (a) { return a.getParam('pagebreak_separator', ''); }, b = function (a) { return a.getParam('pagebreak_split_block', !1); }; return {getSeparatorHtml: a, shouldSplitBlock: b}; }), g('4', ['1', '8'], function (a, b) { var c = function () { return 'mce-pagebreak'; }, d = function () { return '
'; }, e = function (a) { var c = b.getSeparatorHtml(a), e = new RegExp(c.replace(/[\?\.\*\[\]\(\)\{\}\+\^\$\:]/g, function (a) { return '\\' + a; }), 'gi'); a.on('BeforeSetContent', function (a) { a.content = a.content.replace(e, d()); }), a.on('PreInit', function () { a.serializer.addNodeFilter('img', function (d) { for (var e, f, g = d.length; g--;) if (e = d[g], f = e.attr('class'), f && f.indexOf('mce-pagebreak') !== -1) { var h = e.parent; if (a.schema.getBlockElements()[h.name] && b.shouldSplitBlock(a)) { h.type = 3, h.value = c, h.raw = !0, e.remove(); continue; }e.type = 3, e.value = c, e.raw = !0; } }); }); }; return {setup: e, getPlaceholderHtml: d, getPageBreakClass: c}; }), g('3', ['4'], function (a) { var b = function (b) { b.addCommand('mcePageBreak', function () { b.settings.pagebreak_split_block ? b.insertContent('' + a.getPlaceholderHtml() + '
') : b.insertContent(a.getPlaceholderHtml()); }); }; return {register: b}; }), g('5', ['4'], function (a) { var b = function (b) { b.on('ResolveName', function (c) { c.target.nodeName === 'IMG' && b.dom.hasClass(c.target, a.getPageBreakClass()) && (c.name = 'pagebreak'); }); }; return {setup: b}; }), g('6', [], function () { var a = function (a) { a.addButton('pagebreak', {title: 'Page break', cmd: 'mcePageBreak'}), a.addMenuItem('pagebreak', {text: 'Page break', icon: 'pagebreak', cmd: 'mcePageBreak', context: 'insert'}); }; return {register: a}; }), g('0', ['1', '2', '3', '4', '5', '6'], function (a, b, c, d, e, f) { return b.add('pagebreak', function (a) { c.register(a), f.register(a), d.setup(a), e.setup(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/paste/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "paste" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/paste')
5 | // ES2015:
6 | // import 'tinymce/plugins/paste'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/preview/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "preview" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/preview')
5 | // ES2015:
6 | // import 'tinymce/plugins/preview'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/preview/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('4', tinymce.util.Tools.resolve), g('1', ['4'], function (a) { return a('tinymce.PluginManager'); }), g('6', ['4'], function (a) { return a('tinymce.Env'); }), g('7', ['4'], function (a) { return a('tinymce.util.Tools'); }), g('8', [], function () { var a = function (a) { return parseInt(a.getParam('plugin_preview_width', '650'), 10); }, b = function (a) { return parseInt(a.getParam('plugin_preview_height', '500'), 10); }; return {getPreviewDialogWidth: a, getPreviewDialogHeight: b}; }), g('9', ['7'], function (a) { var b = function (b, c, d) { var e, f = '', g = b.dom.encode; f += '', a.each(b.contentCSS, function (a) { f += ''; }); var h = b.settings.body_id || 'tinymce'; h.indexOf('=') !== -1 && (h = b.getParam('body_id', '', 'hash'), h = h[b.id] || h); var i = b.settings.body_class || ''; i.indexOf('=') !== -1 && (i = b.getParam('body_class', '', 'hash'), i = i[b.id] || ''); var j = ' ', k = b.settings.directionality ? ' dir="' + b.settings.directionality + '"' : ''; if (e = '' + f + '' + b.getContent() + j + '', d)c.src = 'data:text/html;charset=utf-8,' + encodeURIComponent(e); else { var l = c.contentWindow.document; l.open(), l.write(e), l.close(); } }; return {injectIframeContent: b}; }), g('5', ['6', '7', '8', '9'], function (a, b, c, d) { var e = function (b) { var e = !a.ie, f = '', g = c.getPreviewDialogWidth(b), h = c.getPreviewDialogHeight(b); b.windowManager.open({title: 'Preview', width: g, height: h, html: f, buttons: {text: 'Close', onclick: function (a) { a.control.parent().parent().close(); }}, onPostRender: function (a) { var c = a.control.getEl('body').firstChild; d.injectIframeContent(b, c, e); }}); }; return {open: e}; }), g('2', ['5'], function (a) { var b = function (b) { b.addCommand('mcePreview', function () { a.open(b); }); }; return {register: b}; }), g('3', [], function () { var a = function (a) { a.addButton('preview', {title: 'Preview', cmd: 'mcePreview'}), a.addMenuItem('preview', {text: 'Preview', cmd: 'mcePreview', context: 'view'}); }; return {register: a}; }), g('0', ['1', '2', '3'], function (a, b, c) { return a.add('preview', function (a) { b.register(a), c.register(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/print/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "print" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/print')
5 | // ES2015:
6 | // import 'tinymce/plugins/print'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/print/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('4', tinymce.util.Tools.resolve), g('1', ['4'], function (a) { return a('tinymce.PluginManager'); }), g('2', [], function () { var a = function (a) { a.addCommand('mcePrint', function () { a.getWin().print(); }); }; return {register: a}; }), g('3', [], function () { var a = function (a) { a.addButton('print', {title: 'Print', cmd: 'mcePrint'}), a.addMenuItem('print', {text: 'Print', cmd: 'mcePrint', icon: 'print'}); }; return {register: a}; }), g('0', ['1', '2', '3'], function (a, b, c) { return a.add('print', function (a) { b.register(a), c.register(a), a.addShortcut('Meta+P', '', 'mcePrint'); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/save/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "save" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/save')
5 | // ES2015:
6 | // import 'tinymce/plugins/save'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/save/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('4', tinymce.util.Tools.resolve), g('1', ['4'], function (a) { return a('tinymce.PluginManager'); }), g('7', ['4'], function (a) { return a('tinymce.dom.DOMUtils'); }), g('8', ['4'], function (a) { return a('tinymce.util.Tools'); }), g('6', [], function () { var a = function (a) { return a.getParam('save_enablewhendirty', !0); }, b = function (a) { return !!a.getParam('save_onsavecallback'); }, c = function (a) { return !!a.getParam('save_oncancelcallback'); }; return {enableWhenDirty: a, hasOnSaveCallback: b, hasOnCancelCallback: c}; }), g('5', ['7', '8', '6'], function (a, b, c) { var d = function (a, b) { a.notificationManager.open({text: a.translate(b), type: 'error'}); }, e = function (b) { var e; if (e = a.DOM.getParent(b.id, 'form'), !c.enableWhenDirty(b) || b.isDirty()) return b.save(), c.hasOnSaveCallback(b) ? (b.execCallback('save_onsavecallback', b), void b.nodeChanged()) : void (e ? (b.setDirty(!1), e.onsubmit && !e.onsubmit() || (typeof e.submit === 'function' ? e.submit() : d(b, 'Error: Form submit field collision.')), b.nodeChanged()) : d(b, 'Error: No form element found.')); }, f = function (a) { var d = b.trim(a.startContent); return c.hasOnCancelCallback(a) ? void a.execCallback('save_oncancelcallback', a) : (a.setContent(d), a.undoManager.clear(), void a.nodeChanged()); }; return {save: e, cancel: f}; }), g('2', ['5'], function (a) { var b = function (b) { b.addCommand('mceSave', function () { a.save(b); }), b.addCommand('mceCancel', function () { a.cancel(b); }); }; return {register: b}; }), g('3', ['6'], function (a) { var b = function (b) { return function (c) { var d = c.control; b.on('nodeChange dirty', function () { d.disabled(a.enableWhenDirty(b) && !b.isDirty()); }); }; }, c = function (a) { a.addButton('save', {icon: 'save', text: 'Save', cmd: 'mceSave', disabled: !0, onPostRender: b(a)}), a.addButton('cancel', {text: 'Cancel', icon: !1, cmd: 'mceCancel', disabled: !0, onPostRender: b(a)}), a.addShortcut('Meta+S', '', 'mceSave'); }; return {register: c}; }), g('0', ['1', '2', '3'], function (a, b, c) { return a.add('save', function (a) { c.register(a), b.register(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/searchreplace/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "searchreplace" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/searchreplace')
5 | // ES2015:
6 | // import 'tinymce/plugins/searchreplace'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/spellchecker/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "spellchecker" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/spellchecker')
5 | // ES2015:
6 | // import 'tinymce/plugins/spellchecker'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/tabfocus/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "tabfocus" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/tabfocus')
5 | // ES2015:
6 | // import 'tinymce/plugins/tabfocus'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/tabfocus/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; h('3', tinymce.util.Tools.resolve), g('1', ['3'], function (a) { return a('tinymce.PluginManager'); }), h('4', window), g('5', ['3'], function (a) { return a('tinymce.dom.DOMUtils'); }), g('6', ['3'], function (a) { return a('tinymce.EditorManager'); }), g('7', ['3'], function (a) { return a('tinymce.Env'); }), g('8', ['3'], function (a) { return a('tinymce.util.Delay'); }), g('9', ['3'], function (a) { return a('tinymce.util.Tools'); }), g('a', ['3'], function (a) { return a('tinymce.util.VK'); }), g('b', [], function () { var a = function (a) { return a.getParam('tabfocus_elements', ':prev,:next'); }, b = function (b) { return b.getParam('tab_focus', a(b)); }; return {getTabFocus: b}; }), g('2', ['4', '5', '6', '7', '8', '9', 'a', 'b'], function (a, b, c, d, e, f, g, h) { var i = b.DOM, j = function (a) { a.keyCode !== g.TAB || a.ctrlKey || a.altKey || a.metaKey || a.preventDefault(); }, k = function (b) { function k (j) { function k (a) { function d (a) { return a.nodeName === 'BODY' || a.type !== 'hidden' && a.style.display !== 'none' && a.style.visibility !== 'hidden' && d(a.parentNode); } function e (a) { return /INPUT|TEXTAREA|BUTTON/.test(a.tagName) && c.get(j.id) && a.tabIndex !== -1 && d(a); } if (m = i.select(':input:enabled,*[tabindex]:not(iframe)'), f.each(m, function (a, c) { if (a.id === b.id) return l = c, !1; }), a > 0) { for (o = l + 1; o < m.length; o++) if (e(m[o])) return m[o]; } else for (o = l - 1; o >= 0; o--) if (e(m[o])) return m[o]; return null; } var l, m, n, o; if (!(j.keyCode !== g.TAB || j.ctrlKey || j.altKey || j.metaKey || j.isDefaultPrevented()) && (n = f.explode(h.getTabFocus(b)), n.length === 1 && (n[1] = n[0], n[0] = ':prev'), m = j.shiftKey ? n[0] === ':prev' ? k(-1) : i.get(n[0]) : n[1] === ':next' ? k(1) : i.get(n[1]))) { var p = c.get(m.id || m.name); m.id && p ? p.focus() : e.setTimeout(function () { d.webkit || a.focus(), m.focus(); }, 10), j.preventDefault(); } }b.on('init', function () { b.inline && i.setAttrib(b.getBody(), 'tabIndex', null), b.on('keyup', j), d.gecko ? b.on('keypress keydown', k) : b.on('keydown', k); }); }; return {setup: k}; }), g('0', ['1', '2'], function (a, b) { return a.add('tabfocus', function (a) { b.setup(a); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/table/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "table" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/table')
5 | // ES2015:
6 | // import 'tinymce/plugins/table'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/template/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "template" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/template')
5 | // ES2015:
6 | // import 'tinymce/plugins/template'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/textcolor/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "textcolor" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/textcolor')
5 | // ES2015:
6 | // import 'tinymce/plugins/textcolor'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/textpattern/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "textpattern" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/textpattern')
5 | // ES2015:
6 | // import 'tinymce/plugins/textpattern'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/toc/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "toc" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/toc')
5 | // ES2015:
6 | // import 'tinymce/plugins/toc'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/visualblocks/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "visualblocks" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/visualblocks')
5 | // ES2015:
6 | // import 'tinymce/plugins/visualblocks'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/visualblocks/plugin.min.js:
--------------------------------------------------------------------------------
1 | !(function () { var a = {}, b = function (b) { for (var c = a[b], e = c.deps, f = c.defn, g = e.length, h = new Array(g), i = 0; i < g; ++i)h[i] = d(e[i]); var j = f.apply(null, h); if (void 0 === j) throw 'module [' + b + '] returned undefined'; c.instance = j; }, c = function (b, c, d) { if (typeof b !== 'string') throw 'module id must be a string'; if (void 0 === c) throw 'no dependencies for ' + b; if (void 0 === d) throw 'no definition function for ' + b; a[b] = {deps: c, defn: d, instance: void 0}; }, d = function (c) { var d = a[c]; if (void 0 === d) throw 'module [' + c + '] was undefined'; return void 0 === d.instance && b(c), d.instance; }, e = function (a, b) { for (var c = a.length, e = new Array(c), f = 0; f < c; ++f)e[f] = d(a[f]); b.apply(null, e); }, f = {}; f.bolt = {module: {api: {define: c, require: e, demand: d}}}; var g = c, h = function (a, b) { g(a, [], function () { return b; }); }; g('1', [], function () { var a = function (b) { var c = b, d = function () { return c; }, e = function (a) { c = a; }, f = function () { return a(d()); }; return {get: d, set: e, clone: f}; }; return a; }), h('6', tinymce.util.Tools.resolve), g('2', ['6'], function (a) { return a('tinymce.PluginManager'); }), g('9', [], function () { var a = function (a, b) { a.fire('VisualBlocks', {state: b}); }; return {fireVisualBlocks: a}; }), g('8', [], function () { var a = function (a) { return a.getParam('visualblocks_default_state', !1); }, b = function (a) { return a.settings.visualblocks_content_css; }; return {isEnabledByDefault: a, getContentCss: b}; }), g('b', ['6'], function (a) { return a('tinymce.dom.DOMUtils'); }), g('c', ['6'], function (a) { return a('tinymce.util.Tools'); }), g('a', ['b', 'c'], function (a, b) { var c = a.DOM.uniqueId(), d = function (d, e) { var f = b.toArray(d.getElementsByTagName('link')), g = b.grep(f, function (a) { return a.id === c; }); if (g.length === 0) { var h = a.DOM.create('link', {id: c, rel: 'stylesheet', href: e}); d.getElementsByTagName('head')[0].appendChild(h); } }; return {load: d}; }), g('7', ['9', '8', 'a'], function (a, b, c) { var d = function (d, e, f) { var g = d.dom, h = b.getContentCss(d); c.load(d.getDoc(), h || e + '/css/visualblocks.css'), g.toggleClass(d.getBody(), 'mce-visualblocks'), f.set(!f.get()), a.fireVisualBlocks(d, f.get()); }; return {toggleVisualBlocks: d}; }), g('3', ['7'], function (a) { var b = function (b, c, d) { b.addCommand('mceVisualBlocks', function () { a.toggleVisualBlocks(b, c, d); }); }; return {register: b}; }), g('4', ['8', '7'], function (a, b) { var c = function (c, d, e) { c.on('PreviewFormats AfterPreviewFormats', function (a) { e.get() && c.dom.toggleClass(c.getBody(), 'mce-visualblocks', a.type === 'afterpreviewformats'); }), c.on('init', function () { a.isEnabledByDefault(c) && b.toggleVisualBlocks(c, d, e); }), c.on('remove', function () { c.dom.removeClass(c.getBody(), 'mce-visualblocks'); }); }; return {setup: c}; }), g('5', ['7'], function (a) { var b = function (a, b) { return function (c) { var d = c.control; d.active(b.get()), a.on('VisualBlocks', function (a) { d.active(a.state); }); }; }, c = function (a, c) { a.addButton('visualblocks', {title: 'Show blocks', cmd: 'mceVisualBlocks', onPostRender: b(a, c)}), a.addMenuItem('visualblocks', {text: 'Show blocks', cmd: 'mceVisualBlocks', onPostRender: b(a, c), selectable: !0, context: 'view', prependToContext: !0}); }; return {register: c}; }), g('0', ['1', '2', '3', '4', '5'], function (a, b, c, d, e) { return b.add('visualblocks', function (b, f) { var g = a(!1); c.register(b, f, g), e.register(b, g), d.setup(b, f, g); }), function () {}; }), d('0')(); }());
2 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/visualchars/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "visualchars" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/visualchars')
5 | // ES2015:
6 | // import 'tinymce/plugins/visualchars'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/plugins/wordcount/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "wordcount" plugin for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/plugins/wordcount')
5 | // ES2015:
6 | // import 'tinymce/plugins/wordcount'
7 | require('./plugin.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/content.inline.min.css:
--------------------------------------------------------------------------------
1 | .word-wrap{word-wrap:break-word;-ms-word-break:break-all;word-break:break-all;word-break:break-word;-ms-hyphens:auto;-moz-hyphens:auto;-webkit-hyphens:auto;hyphens:auto}.mce-content-body .mce-reset{margin:0;padding:0;border:0;outline:0;vertical-align:top;background:transparent;text-decoration:none;color:black;font-family:Arial;font-size:11px;text-shadow:none;float:none;position:static;width:auto;height:auto;white-space:nowrap;cursor:inherit;line-height:normal;font-weight:normal;text-align:left;-webkit-tap-highlight-color:transparent;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;direction:ltr;max-width:none}.mce-object{border:1px dotted #3A3A3A;background:#D5D5D5 url(img/object.gif) no-repeat center}.mce-preview-object{display:inline-block;position:relative;margin:0 2px 0 2px;line-height:0;border:1px solid gray}.mce-preview-object[data-mce-selected="2"] .mce-shim{display:none}.mce-preview-object .mce-shim{position:absolute;top:0;left:0;width:100%;height:100%;background:url()}figure.align-left{float:left}figure.align-right{float:right}figure.image.align-center{display:table;margin-left:auto;margin-right:auto}figure.image{display:inline-block;border:1px solid gray;margin:0 2px 0 1px;background:#f5f2f0}figure.image img{margin:8px 8px 0 8px}figure.image figcaption{margin:6px 8px 6px 8px;text-align:center}.mce-toc{border:1px solid gray}.mce-toc h2{margin:4px}.mce-toc li{list-style-type:none}.mce-pagebreak{cursor:default;display:block;border:0;width:100%;height:5px;border:1px dashed #666;margin-top:15px;page-break-before:always}@media print{.mce-pagebreak{border:0}}.mce-item-anchor{cursor:default;display:inline-block;-webkit-user-select:all;-webkit-user-modify:read-only;-moz-user-select:all;-moz-user-modify:read-only;user-select:all;user-modify:read-only;width:9px !important;height:9px !important;border:1px dotted #3A3A3A;background:#D5D5D5 url(img/anchor.gif) no-repeat center}.mce-nbsp,.mce-shy{background:#AAA}.mce-shy::after{content:'-'}.mce-match-marker{background:#AAA;color:#fff}.mce-match-marker-selected{background:#3399ff;color:#fff}.mce-spellchecker-word{border-bottom:2px solid rgba(208,2,27,0.5);cursor:default}.mce-spellchecker-grammar{border-bottom:2px solid #008000;cursor:default}.mce-item-table,.mce-item-table td,.mce-item-table th,.mce-item-table caption{border:1px dashed #BBB}td[data-mce-selected],th[data-mce-selected]{background-color:#2276d2 !important}.mce-edit-focus{outline:1px dotted #333}.mce-resize-bar-dragging{background-color:#2276d2;opacity:.25;filter:alpha(opacity=25);zoom:1}.mce-content-body *[contentEditable=false] *[contentEditable=true]:focus{outline:2px solid #2276d2}.mce-content-body *[contentEditable=false] *[contentEditable=true]:hover{outline:2px solid #2276d2}.mce-content-body *[contentEditable=false][data-mce-selected]{outline:2px solid #2276d2}.mce-content-body a[data-mce-selected],.mce-content-body code[data-mce-selected],.mce-content-body b[data-mce-selected],.mce-content-body i[data-mce-selected],.mce-content-body em[data-mce-selected],.mce-content-body strong[data-mce-selected],.mce-content-body sup[data-mce-selected],.mce-content-body sub[data-mce-selected]{background:#bfe6ff}.mce-content-body .mce-item-anchor[data-mce-selected]{background:#D5D5D5 url(img/anchor.gif) no-repeat center}.mce-content-body hr{cursor:default}.mce-content-body{line-height:1.3}
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/content.mobile.min.css:
--------------------------------------------------------------------------------
1 | .tinymce-mobile-unfocused-selections .tinymce-mobile-unfocused-selection{position:absolute;display:inline-block;background-color:green;opacity:.5}body{-webkit-text-size-adjust:none}body img{max-width:96vw}body table img{max-width:95%}
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce-mobile.woff:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce-mobile.woff
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce-small.eot:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce-small.eot
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce-small.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce-small.ttf
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce-small.woff:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce-small.woff
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce.eot:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce.eot
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce.ttf
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce.woff:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/fonts/tinymce.woff
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/img/anchor.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/img/anchor.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/img/loader.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/img/loader.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/img/object.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/img/object.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/skins/lightgray/img/trans.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/components/my-components/text-editor/tinymce/skins/lightgray/img/trans.gif
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/themes/inlite/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "inlite" theme for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/themes/inlite')
5 | // ES2015:
6 | // import 'tinymce/themes/inlite'
7 | require('./theme.js');
8 |
--------------------------------------------------------------------------------
/components/my-components/text-editor/tinymce/themes/modern/index.js:
--------------------------------------------------------------------------------
1 | // Exports the "modern" theme for usage with module loaders
2 | // Usage:
3 | // CommonJS:
4 | // require('tinymce/themes/modern')
5 | // ES2015:
6 | // import 'tinymce/themes/modern'
7 | require('./theme.js');
8 |
--------------------------------------------------------------------------------
/components/other.vue:
--------------------------------------------------------------------------------
1 |
2 |
6 |
7 |
8 |
58 |
59 |
--------------------------------------------------------------------------------
/components/tables/components/ExportExcel.vue:
--------------------------------------------------------------------------------
1 |
2 |
6 |
7 |
8 |
22 |
--------------------------------------------------------------------------------
/components/tables/components/dragableTable.vue:
--------------------------------------------------------------------------------
1 |
2 |
11 |
12 |
13 |
51 |
52 |
--------------------------------------------------------------------------------
/components/tables/components/editable-table.less:
--------------------------------------------------------------------------------
1 | .show-edit-btn{
2 | display: none;
3 | margin-left: -10px;
4 | }
5 | .ivu-table-cell:hover .show-edit-btn{
6 | display: inline-block;
7 | }
--------------------------------------------------------------------------------
/components/tables/components/table.less:
--------------------------------------------------------------------------------
1 | .dragging-tip-enter-active{
2 | opacity: 1;
3 | transition: opacity .3s;
4 | }
5 | .dragging-tip-enter, .dragging-tip-leave-to{
6 | opacity: 0;
7 | transition: opacity .3s
8 | }
9 | .dragging-tip-con{
10 | display: block;
11 | text-align: center;
12 | width: 100%;
13 | height: 50px;
14 | }
15 | .dragging-tip-con span{
16 | font-size: 18px;
17 | }
18 | .record-tip-con{
19 | display: block;
20 | width: 100%;
21 | height: 292px;
22 | overflow: auto;
23 | }
24 | .record-item{
25 | box-sizing: content-box;
26 | display: block;
27 | overflow: hidden;
28 | height: 24px;
29 | line-height: 24px;
30 | padding: 8px 10px;
31 | border-bottom: 1px dashed gainsboro;
32 | }
33 | .record-tip-con span{
34 | font-size: 14px;
35 | }
36 | .edittable-test-con{
37 | height: 160px;
38 | }
39 | .edittable-table-height-con{
40 | height: 190px;
41 | }
42 | .edittable-con-1{
43 | box-sizing: content-box;
44 | padding: 15px 0 0;
45 | height: 196px;
46 | }
47 | .edittable-table-get-currentdata-con{
48 | height: 190px !important;
49 | }
50 | .exportable-table-download-con1{
51 | padding: 16px 0 16px 20px;
52 | border-bottom: 1px dashed #c3c3c3;
53 | margin-bottom: 16px;
54 | }
55 | .exportable-table-download-con2{
56 | padding-left: 20px;
57 | }
58 | .show-image{
59 | padding: 20px 0px;
60 | }
61 | .show-image img{
62 | display: block;
63 | width: 100%;
64 | height: auto;
65 | }
66 | .searchable-table{
67 | &-con1{
68 | height: 230px !important;
69 | }
70 | }
--------------------------------------------------------------------------------
/components/tables/data/search.js:
--------------------------------------------------------------------------------
1 | export const columns1 = [
2 | {
3 | key: 'name',
4 | title: '姓名'
5 | },
6 | {
7 | key: 'tel',
8 | title: '电话号码'
9 | }
10 | ];
11 |
12 | export const searchTable1 = [
13 | {
14 | name: 'Aresn',
15 | tel: '17712345678'
16 | },
17 | {
18 | name: 'Lison',
19 | tel: '17787654321'
20 | },
21 | {
22 | name: 'Lili',
23 | tel: '12212345678'
24 | },
25 | {
26 | name: 'Lucy',
27 | tel: '13312345678'
28 | }
29 | ];
30 |
31 | export const searchTable2 = [
32 | {
33 | name: 'Aresn',
34 | tel: '17712345678'
35 | },
36 | {
37 | name: 'Lison',
38 | tel: '17787654321'
39 | },
40 | {
41 | name: 'Lili',
42 | tel: '12212345678'
43 | },
44 | {
45 | name: 'Lucy',
46 | tel: '13312345678'
47 | }
48 | ];
49 |
50 | export const searchTable3 = [
51 | {
52 | name: 'Aresn',
53 | tel: '17712345678'
54 | },
55 | {
56 | name: 'Lison',
57 | tel: '17787654321'
58 | },
59 | {
60 | name: 'Lili',
61 | tel: '12212345678'
62 | },
63 | {
64 | name: 'Lucy',
65 | tel: '13312345678'
66 | }
67 | ];
68 |
--------------------------------------------------------------------------------
/ecosystem.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | apps: [
3 | {
4 | name: 'nuxt-iview',
5 | script: 'build/main.js',
6 | watch: true,
7 | env: {
8 | NODE_ENV: 'development',
9 | BACKEND_URL: 'https://dev.domain.com',
10 | COOKIE_DOMAIN: '.domain.com'
11 | },
12 | env_test: {
13 | NODE_ENV: 'test',
14 | BACKEND_URL: 'https://test.domain.com',
15 | COOKIE_DOMAIN: '.domain.com'
16 | },
17 | env_production: {
18 | NODE_ENV: 'production',
19 | BACKEND_URL: 'https://pro.domain.com',
20 | COOKIE_DOMAIN: '.domain.com'
21 | }
22 | }
23 | ]
24 | }
25 |
--------------------------------------------------------------------------------
/layouts/error.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
{{ error.statusCode }}
5 |
6 |
{{ error.message }}
7 |
8 |
Back to the home page
9 |
10 |
11 |
12 |
13 |
24 |
25 |
67 |
--------------------------------------------------------------------------------
/layouts/full.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
--------------------------------------------------------------------------------
/middleware/auth.js:
--------------------------------------------------------------------------------
1 | export default function ({ store, error, redirect }) {
2 | // console.log('store', store.getters.getToken)
3 | if (!store.getters.token) {
4 | redirect('/login')
5 | }
6 | }
7 |
--------------------------------------------------------------------------------
/middleware/redirect.js:
--------------------------------------------------------------------------------
1 | export default function ({ store, error, redirect, req }) {
2 | redirect('/home')
3 | }
4 |
--------------------------------------------------------------------------------
/middleware/route.js:
--------------------------------------------------------------------------------
1 | export default function ({ route }) {
2 | // console.log('路由中间件', route.fullPath)
3 | // return axios.post('http://my-stats-api.com', {
4 | // url: route.fullPath
5 | // })
6 | }
7 |
--------------------------------------------------------------------------------
/nuxt.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | /*
3 | ** Headers of the page
4 | */
5 | head: {
6 | title: 'nuxt-temp',
7 | meta: [
8 | { charset: 'utf-8' },
9 | { hid: 'description', name: 'description', content: 'Nuxt.js project' }
10 | ],
11 | link: [
12 | { rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' },
13 | { rel: 'stylesheet', name: 'iview', href: '/styles/iview.css' },
14 | { rel: 'stylesheet', name: 'theme', href: '' }
15 | ]
16 | },
17 | css: [
18 | { src: '~assets/css/main.css' }
19 | // { src: 'iview/dist/styles/iview.css' }
20 | ],
21 | plugins: [
22 | { src: '~plugins/flexible.js', ssr: false },
23 | { src: '~plugins/iview.js', ssr: true }
24 | ],
25 | loading: './components/loading.vue',
26 | env: {
27 | NODE_ENV: process.env.NODE_ENV
28 | },
29 | cache: {
30 | max: 1000,
31 | maxAge: 900000
32 | },
33 | router: {
34 | middleware: 'route' // 在每页渲染前运行 middleware/route.js 中间件的逻辑
35 | },
36 | build: {
37 | vendor: ['axios', 'iview', './plugins/iview.js'],
38 | extend(config, ctx) {
39 | if (ctx.isClient) {
40 | // config.module.rules.push({
41 | // enforce: 'pre',
42 | // test: /\.(js|vue)$/,
43 | // loader: 'eslint-loader',
44 | // exclude: /(node_modules)/
45 | // })
46 | }
47 | }
48 | }
49 | }
50 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "nuxt-demo",
3 | "version": "1.0.0",
4 | "description": "Nuxt.js project",
5 | "author": "moedong",
6 | "private": true,
7 | "scripts": {
8 | "dev": "backpack dev",
9 | "build:prod": "cross-env NODE_ENV=production nuxt build && cross-env NODE_ENV=production backpack build",
10 | "build:test": "cross-env NODE_ENV=test nuxt build && cross-env NODE_ENV=test backpack build",
11 | "start:prod": "pm2 start ecosystem.config.js --env production",
12 | "start:test": "pm2 start ecosystem.config.js --env test",
13 | "publish:prod": "npm run build:prod && npm run start:prod",
14 | "publish:test": "npm run build:test && npm run start:test",
15 | "generate": "nuxt generate",
16 | "precommit": "npm run lint",
17 | "lint": "eslint --ext .js,.vue --ignore-path .gitignore .",
18 | "dev-debug": "node node_modules/.bin/backpack dev --inspect-brk",
19 | "test": "nuxt build && ava --verbose --serial"
20 | },
21 | "ava": {
22 | "require": [
23 | "babel-register"
24 | ]
25 | },
26 | "dependencies": {
27 | "@koa/cors": "^2.2.1",
28 | "@nuxtjs/router": "^1.0.1",
29 | "area-data": "^5.0.6",
30 | "axios": "^0.17.1",
31 | "clipboard": "^1.7.1",
32 | "countup": "^1.8.2",
33 | "cropperjs": "^1.2.2",
34 | "cross-env": "^5.0.1",
35 | "echarts": "^3.8.5",
36 | "html2canvas": "^0.5.0-beta4",
37 | "iview": "^2.14.2",
38 | "js-cookie": "^2.2.0",
39 | "koa": "^2.4.1",
40 | "koa-bodyparser": "^4.2.1",
41 | "koa-logger": "^3.2.0",
42 | "koa-router": "^7.4.0",
43 | "koa-session2": "^2.2.6",
44 | "koa-static": "^5.0.0",
45 | "nuxt": "latest",
46 | "rasterizehtml": "^1.2.4",
47 | "simplemde": "^1.11.2",
48 | "sortablejs": "^1.7.0",
49 | "source-map-support": "^0.4.15",
50 | "tinymce": "^4.7.4",
51 | "vuex-persist": "^1.2.2"
52 | },
53 | "devDependencies": {
54 | "autoprefixer-loader": "^3.2.0",
55 | "ava": "^0.25.0",
56 | "axios-mock-adapter": "^1.15.0",
57 | "babel": "^6.23.0",
58 | "babel-core": "^6.23.1",
59 | "babel-eslint": "^8.2.1",
60 | "babel-loader": "^7.1.2",
61 | "babel-plugin-syntax-dynamic-import": "^6.18.0",
62 | "babel-plugin-transform-runtime": "^6.12.0",
63 | "babel-preset-env": "^1.6.1",
64 | "babel-preset-es2015": "^6.9.0",
65 | "babel-preset-stage-3": "^6.24.1",
66 | "babel-runtime": "^6.11.6",
67 | "backpack-core": "^0.4.1",
68 | "eslint": "^4.3.0",
69 | "eslint-config-standard": "^10.2.1",
70 | "eslint-loader": "^1.9.0",
71 | "eslint-plugin-html": "^3.1.1",
72 | "eslint-plugin-import": "^2.7.0",
73 | "eslint-plugin-node": "^5.1.1",
74 | "eslint-plugin-promise": "^3.5.0",
75 | "eslint-plugin-standard": "^3.0.1",
76 | "jsdom": "^11.11.0",
77 | "less": "^2.7.3",
78 | "less-loader": "^4.0.5",
79 | "nodemon": "^1.11.0",
80 | "scmp": "^2.0.0",
81 | "vue-i18n": "^7.6.0"
82 | }
83 | }
84 |
--------------------------------------------------------------------------------
/pages/error-page/404.vue:
--------------------------------------------------------------------------------
1 |
61 |
62 |
63 |
64 |
65 |
66 | 4
67 |
68 |
69 | 4
70 | YOU LOOK LOST
71 |
72 |
73 |
74 |
75 |
76 |
77 |
78 | 当访问的页面不存在时会跳转到404页面,您可以在浏览器地址栏中修改url为一个不存在的路径,体验一下效果
79 |
80 |
81 |
82 |
83 |
84 |
85 |
100 |
--------------------------------------------------------------------------------
/pages/error-page/500.vue:
--------------------------------------------------------------------------------
1 |
74 |
75 |
76 |
77 |
78 |
79 |
80 | 5
81 |
82 |
83 |
84 |
85 |
86 |
87 |
88 | Oops! the server is wrong
89 |
90 | 返回主页
91 |
92 |
93 |
94 |
95 |
96 |
97 | 当请求之后出现服务端错误时跳转到该页面,您可以在ajax请求方法中判断返回的状态码为500时跳转到该页面
98 |
99 |
100 |
101 |
102 |
103 |
118 |
--------------------------------------------------------------------------------
/plugins/axios2.js:
--------------------------------------------------------------------------------
1 | /**
2 | * 用于浏览器端ajax请求
3 | */
4 |
5 | import Axios from 'axios'
6 | import { Message } from 'iview'
7 |
8 | // 环境变量
9 | const env = process.env.NODE_ENV || 'development'
10 |
11 | let baseUrl = {
12 | development: 'http://127.0.0.1:3000',
13 | test: 'https://crmfront.tiaoweilian.com',
14 | production: 'https://crm.youjiangliao.com'
15 | }
16 |
17 | let options = {
18 | baseURL: baseUrl[env],
19 | timeout: 5000,
20 | responseType: 'json',
21 | headers: {
22 | post: {
23 | 'Content-Type': 'application/json'
24 | }
25 | }
26 | }
27 | // 创建实例
28 | let axios = Axios.create(options)
29 |
30 | // 拦截
31 | axios.interceptors.response.use(
32 | res => {
33 | if (res.status && res.status === 200 && res.data.status === 'error') {
34 | return
35 | }
36 | return res
37 | },
38 | err => {
39 | if (err.response.status !== 200) {
40 | if (process.client) {
41 | Message.error(err.response.data.msg || '')
42 | }
43 | }
44 | return Promise.resolve(err.response)
45 | }
46 | )
47 | export default axios
48 |
--------------------------------------------------------------------------------
/plugins/flexible.js:
--------------------------------------------------------------------------------
1 | !function(){var a="@charset \"utf-8\";html{color:#000;background:#fff;overflow-y:scroll;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}html *{outline:0;-webkit-text-size-adjust:none;-webkit-tap-highlight-color:rgba(0,0,0,0)}html,body{font-family:sans-serif}body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote,th,td,hr,button,article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{margin:0;padding:0}input,select,textarea{font-size:100%}table{border-collapse:collapse;border-spacing:0}fieldset,img{border:0}abbr,acronym{border:0;font-variant:normal}del{text-decoration:line-through}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:500}ol,ul{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:500}q:before,q:after{content:''}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}a:hover{text-decoration:underline}ins,a{text-decoration:none}",b=document.createElement("style");if(document.getElementsByTagName("head")[0].appendChild(b),b.styleSheet)b.styleSheet.disabled||(b.styleSheet.cssText=a);else try{b.innerHTML=a}catch(c){b.innerText=a}}();!function(a,b){function c(){var b=f.getBoundingClientRect().width;b/i>540&&(b=540*i);var c=b/10;f.style.fontSize=c+"px",k.rem=a.rem=c}var d,e=a.document,f=e.documentElement,g=e.querySelector('meta[name="viewport"]'),h=e.querySelector('meta[name="flexible"]'),i=0,j=0,k=b.flexible||(b.flexible={});if(g){console.warn("灏嗘牴鎹凡鏈夌殑meta鏍囩鏉ヨ缃缉鏀炬瘮渚�");var l=g.getAttribute("content").match(/initial\-scale=([\d\.]+)/);l&&(j=parseFloat(l[1]),i=parseInt(1/j))}else if(h){var m=h.getAttribute("content");if(m){var n=m.match(/initial\-dpr=([\d\.]+)/),o=m.match(/maximum\-dpr=([\d\.]+)/);n&&(i=parseFloat(n[1]),j=parseFloat((1/i).toFixed(2))),o&&(i=parseFloat(o[1]),j=parseFloat((1/i).toFixed(2)))}}if(!i&&!j){var p=(a.navigator.appVersion.match(/android/gi),a.navigator.appVersion.match(/iphone/gi)),q=a.devicePixelRatio;i=p?q>=3&&(!i||i>=3)?3:q>=2&&(!i||i>=2)?2:1:1,j=1/i}if(f.setAttribute("data-dpr",i),!g)if(g=e.createElement("meta"),g.setAttribute("name","viewport"),g.setAttribute("content","initial-scale="+j+", maximum-scale="+j+", minimum-scale="+j+", user-scalable=no"),f.firstElementChild)f.firstElementChild.appendChild(g);else{var r=e.createElement("div");r.appendChild(g),e.write(r.innerHTML)}a.addEventListener("resize",function(){clearTimeout(d),d=setTimeout(c,300)},!1),a.addEventListener("pageshow",function(a){a.persisted&&(clearTimeout(d),d=setTimeout(c,300))},!1),"complete"===e.readyState?e.body.style.fontSize=12*i+"px":e.addEventListener("DOMContentLoaded",function(){e.body.style.fontSize=12*i+"px"},!1),c(),k.dpr=a.dpr=i,k.refreshRem=c,k.rem2px=function(a){var b=parseFloat(a)*this.rem;return"string"==typeof a&&a.match(/rem$/)&&(b+="px"),b},k.px2rem=function(a){var b=parseFloat(a)/this.rem;return"string"==typeof a&&a.match(/px$/)&&(b+="rem"),b}}(window,window.lib||(window.lib={}));
--------------------------------------------------------------------------------
/plugins/iview.js:
--------------------------------------------------------------------------------
1 | import Vue from 'vue'
2 | import iView from 'iview';
3 |
4 | Vue.use(iView);
5 |
--------------------------------------------------------------------------------
/router/router.js:
--------------------------------------------------------------------------------
1 | // router.js
2 | // 作为Main组件的子页面展示但是不在左侧菜单显示的路由写在otherRouter里
3 | export const otherRouter = {
4 | path: '/',
5 | name: 'otherRouter',
6 | children: [
7 | {
8 | path: '/index',
9 | title: '主页',
10 | name: 'index',
11 | icon: 'ios-home'
12 | }
13 | ]
14 | }
15 |
16 | // 作为Main组件的子页面展示并且在左侧菜单显示的路由写在appRouter里
17 | export const appRouter = [
18 | {
19 | path: '/form',
20 | icon: 'android-checkbox',
21 | name: 'form',
22 | title: '表单编辑',
23 | children: [
24 | {
25 | path: '/form/work-flow',
26 | title: '工作流',
27 | name: 'form-work-flow',
28 | icon: 'arrow-swap'
29 | },
30 | {
31 | path: '/form/article-publish',
32 | title: '发布文章',
33 | name: 'form-article-publish',
34 | icon: 'ios-home'
35 | }
36 | ]
37 | },
38 | {
39 | path: '/tables',
40 | icon: 'ios-grid-view',
41 | title: '表格',
42 | name: 'tables',
43 | children: [
44 | {
45 | path: '/tables/dragable-table',
46 | title: '可拖拽排序',
47 | icon: 'arrow-move',
48 | name: 'tables-dragable-table'
49 | },
50 | {
51 | path: '/tables/editable-table',
52 | title: '可编辑表格',
53 | icon: 'edit',
54 | name: 'tables-editable-table'
55 | }
56 | ]
57 | },
58 | {
59 | path: '/error-page',
60 | icon: 'android-sad',
61 | title: '错误页面',
62 | name: 'errorpage',
63 | children: [
64 | {
65 | path: '/error-page/403',
66 | title: '403错误',
67 | name: 'error-page-403',
68 | icon: 'close-circled'
69 | },
70 | {
71 | path: '/error-page/404',
72 | title: '404错误',
73 | name: 'error-page-404',
74 | icon: 'alert-circled'
75 | },
76 | {
77 | path: '/error-page/500',
78 | title: '500错误',
79 | name: 'error-page-500',
80 | icon: 'settings'
81 | }
82 | ]
83 | }
84 | ]
85 |
--------------------------------------------------------------------------------
/screenshot/sc1.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/screenshot/sc1.png
--------------------------------------------------------------------------------
/screenshot/sc2.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/screenshot/sc2.png
--------------------------------------------------------------------------------
/screenshot/sc3.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/screenshot/sc3.png
--------------------------------------------------------------------------------
/screenshot/sc4.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/screenshot/sc4.png
--------------------------------------------------------------------------------
/server/config/index.js:
--------------------------------------------------------------------------------
1 | const config = {
2 | base_url: 'https://crmback.tiaoweilian.com',
3 | sign_key: 'RFHIJUGVCFTRQKJMJKNHGBIOJUHGBNFG'
4 | }
5 |
6 | export default config
7 |
--------------------------------------------------------------------------------
/server/controller/user.js:
--------------------------------------------------------------------------------
1 | import axios from 'axios'
2 | import config from '../config'
3 | import MockAdapter from 'axios-mock-adapter'
4 |
5 | var mock = new MockAdapter(axios)
6 | mock.onPost(config.base_url + '/api/v1.user/login').reply(function (config) {
7 | // console.log(JSON.parse(config.data).mobile)
8 | return [
9 | 200,
10 | {'ret': 200, 'msg': '请求成功', 'data': {'code': 0, 'message': '登录成功', 'token': 'PhU0Sd9zwUSwOQgXnJpj7pgSwdA7YD80', 'id': 1, 'mobile': '13770267077', 'name': JSON.parse(config.data).mobile, 'sex': 1, 'status': 1, 'role_id': 1, 'depart_id': 1, 'leader_id': 0}}
11 | ]
12 | })
13 |
14 | export const userinfo = async (ctx, next) => {
15 | let token = ctx.session.user.token || ''
16 | return (ctx.body = {
17 | ret: 200,
18 | msg: '获取成功',
19 | data: { token: token }
20 | })
21 | }
22 |
23 | export const login = async (ctx, next) => {
24 | const { mobile, psd } = ctx.request.body
25 | if (!mobile || !psd) {
26 | return (ctx.body = {
27 | ret: 303,
28 | msg: '缺少请求参数',
29 | data: {}
30 | })
31 | }
32 |
33 | // 发起请求
34 | let _url = config.base_url + '/api/v1.user/login'
35 | let req = await axios.post(_url, {
36 | mobile: mobile,
37 | psd: psd,
38 | sign: ''
39 | })
40 | // 网络异常
41 | if (req.status !== 200) {
42 | return (ctx.body = {
43 | ret: 400,
44 | msg: '网络通讯异常',
45 | data: {}
46 | })
47 | }
48 | // 系统异常
49 | if (req.data.ret !== 200) {
50 | let ret = req.data.ret || 400
51 | let msg = req.data.msg || '失败'
52 | return (ctx.body = {
53 | ret: ret,
54 | msg: msg,
55 | data: {}
56 | })
57 | }
58 |
59 | // 登陆失败
60 | if (req.data.data.code !== 0) {
61 | let code = req.data.data.code || -1
62 | let message = req.data.data.message || '登录失败'
63 | return (ctx.body = {
64 | ret: 200,
65 | msg: '请求成功',
66 | data: {
67 | code: code,
68 | message: message
69 | }
70 | })
71 | }
72 |
73 | // 登陆成功
74 | let token = req.data.data.token
75 | let signkey = config.sign_key
76 |
77 | let info = {
78 | id: req.data.data.id,
79 | mobile: req.data.data.mobile,
80 | name: req.data.data.name,
81 | sex: req.data.data.sex,
82 | status: req.data.data.status,
83 | role_id: req.data.data.role_id,
84 | depart_id: req.data.data.depart_id,
85 | deader_id: req.data.data.deader_id
86 | }
87 |
88 | let session = ctx.session
89 | session.user = {
90 | token: token,
91 | sign_key: signkey,
92 | info: info
93 | }
94 | ctx.session = session
95 |
96 | return (ctx.body = {
97 | ret: 200,
98 | msg: '请求成功',
99 | data: {
100 | code: 0,
101 | message: '登录成功',
102 | token: token,
103 | info: info
104 | }
105 | })
106 | }
107 |
108 | export const logout = async (ctx, next) => {
109 | try {
110 | ctx.session.user = null
111 | return (ctx.body = {
112 | ret: 200,
113 | msg: '请求成功',
114 | data: {
115 | code: 0,
116 | message: '退出成功'
117 | }
118 | })
119 | } catch (e) {
120 | return (ctx.body = {
121 | ret: 200,
122 | msg: '请求成功',
123 | data: {
124 | code: -1,
125 | message: '退出失败'
126 | }
127 | })
128 | }
129 | }
130 |
--------------------------------------------------------------------------------
/server/index.js:
--------------------------------------------------------------------------------
1 | import Koa from 'koa'
2 | import { Nuxt, Builder } from 'nuxt'
3 | import session from 'koa-session2'
4 | import bodyParser from 'koa-bodyparser'
5 | import Router from 'koa-router'
6 | import koaLogger from 'koa-logger'
7 | import route from './routers'
8 | import cors from '@koa/cors'
9 | import koaStatic from 'koa-static'
10 | import path from 'path'
11 |
12 | async function start() {
13 | const app = new Koa()
14 | const host = process.env.HOST || '127.0.0.1'
15 | const port = process.env.PORT || 3000
16 |
17 | // session必须在路由前注册
18 | app.use(
19 | session({
20 | key: '12345',
21 | overwrite: true
22 | })
23 | )
24 | // 配置控制台日志中间件
25 | app.use(koaLogger())
26 |
27 | // 配置静态资源加载中间件
28 | app.use(koaStatic(path.join(__dirname, './src')))
29 |
30 | app.use(cors())
31 | app.use(bodyParser())
32 |
33 | const router = new Router()
34 | router.use('', route.routes())
35 | app.use(router.routes()).use(router.allowedMethods())
36 |
37 | // Import and Set Nuxt.js options
38 | let config = require('../nuxt.config.js')
39 | // 由于涉及到三个环境变化,使用在test,production 时候,为false
40 | config.dev = !(app.env === 'production' || app.env === 'test')
41 | // console.log('env === ', app.env, env, process.env.COOKIE_DOMAIN, process.env.APP_ENV, config.dev)
42 |
43 | // Instantiate nuxt.js
44 | const nuxt = new Nuxt(config)
45 |
46 | // Build in development
47 | if (config.dev) {
48 | const builder = new Builder(nuxt)
49 | await builder.build()
50 | }
51 |
52 | app.use(async (ctx, next) => {
53 | await next()
54 | ctx.status = 200 // koa defaults to 404 when it sees that status is unset
55 | ctx.req.session = ctx.session // 必须将session添加进request中,否则nuxt的req获取不到session
56 | return new Promise((resolve, reject) => {
57 | ctx.res.on('close', resolve)
58 | ctx.res.on('finish', resolve)
59 | nuxt.render(ctx.req, ctx.res, promise => {
60 | // nuxt.render passes a rejected promise into callback on error.
61 | promise.then(resolve).catch(reject)
62 | })
63 | })
64 | })
65 |
66 | app.listen(port, host)
67 | console.log('Server listening on ' + host + ':' + port) // eslint-disable-line no-console
68 | }
69 |
70 | start()
71 |
--------------------------------------------------------------------------------
/server/routers/index.js:
--------------------------------------------------------------------------------
1 | import Router from 'koa-router'
2 | import { userinfo, login, logout } from '../controller/user'
3 | const router = new Router()
4 |
5 | router.get('/api/user', userinfo)
6 | router.post('/api/login', login)
7 | router.post('/api/logout', logout)
8 | router.get('/api/logout', logout)
9 |
10 | export default router
11 |
--------------------------------------------------------------------------------
/server/src/styles/fonts/ionicons.eot:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/server/src/styles/fonts/ionicons.eot
--------------------------------------------------------------------------------
/server/src/styles/fonts/ionicons.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/server/src/styles/fonts/ionicons.ttf
--------------------------------------------------------------------------------
/server/src/styles/fonts/ionicons.woff:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/server/src/styles/fonts/ionicons.woff
--------------------------------------------------------------------------------
/static/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/moedong/nuxt-iview/5f36c7789ee02e063b9ad608c3e306dbbcd27b8b/static/favicon.ico
--------------------------------------------------------------------------------
/store/index.js:
--------------------------------------------------------------------------------
1 | import Vue from 'vue'
2 | import Vuex from 'vuex'
3 | import app from './modules/app'
4 | import user from './modules/user'
5 |
6 | Vue.use(Vuex)
7 |
8 | const store = () =>
9 | new Vuex.Store({
10 | state: {
11 | name: ''
12 | },
13 | getters: {
14 | },
15 | mutations: {},
16 | actions: {
17 | nuxtServerInit: async ({ commit }, { req, res }) => {
18 | // console.log('nuxtServerInit', res.session)
19 | if (!!req.session && !!req.session.user && !!req.session.user.token) {
20 | commit('LOGIN', req.session)
21 | } else {
22 | commit('LOGOUT')
23 | }
24 | }
25 | },
26 | modules: {
27 | app,
28 | user
29 | }
30 | })
31 |
32 | export default store
33 |
--------------------------------------------------------------------------------
/store/modules/user.js:
--------------------------------------------------------------------------------
1 | const user = {
2 | state: {
3 | token: null, // 登陆token
4 | sign_key: null, // 加密密钥
5 | info: {} // 用户的信息
6 | },
7 | getters: {
8 | getToken: state => {
9 | return state.token
10 | },
11 | getSignKey: state => {
12 | return state.sign_key
13 | },
14 | token: state => {
15 | return state.token
16 | },
17 | signkey: state => {
18 | return state.sign_key
19 | },
20 | getUserId: state => {
21 | return state.info.id || null
22 | },
23 | getInfo: state => {
24 | return state.info
25 | }
26 | },
27 | mutations: {
28 | SET_TOKEN: (state, token) => {
29 | state.token = token
30 | },
31 | SET_USERINFO: (state, info = {}) => {
32 | state.info = info
33 | },
34 | // 登陆
35 | LOGIN: (state, session) => {
36 | state.token = session.user.token || null
37 | state.sign_key = session.user.sign_key || null
38 | state.info = session.user.info || {}
39 | },
40 | // 登出
41 | LOGOUT: state => {
42 | state.token = null
43 | state.sign_key = null
44 | state.info = {}
45 | }
46 | },
47 | actions: {
48 | // 登出
49 | LOGOUT: state => {
50 | state.token = null
51 | state.sign_key = null
52 | state.info = {}
53 | }
54 | }
55 | }
56 |
57 | export default user
58 |
--------------------------------------------------------------------------------
/test/config.test.js:
--------------------------------------------------------------------------------
1 | import test from 'ava'
2 | import createNuxt from './helpers/create-nuxt'
3 |
4 | let nuxt = null
5 | const headers = {
6 | 'accept-language': 'zh'
7 | }
8 | // Init nuxt.js and create server listening on localhost:4000
9 | test.before('Init Nuxt.js', async t => {
10 | nuxt = createNuxt()
11 | await nuxt.listen(3000, '127.0.0.1')
12 | })
13 |
14 | // 初始化 Nuxt.js 并创建一个监听 localhost:4000 的服务器
15 | // test.before('Init Nuxt.js', async t => {
16 | // const rootDir = resolve(__dirname, '..')
17 | // let config = {}
18 | // try { config = require(resolve(rootDir, 'nuxt.config.js')) } catch (e) {}
19 | // config.rootDir = rootDir // 项目目录
20 | // config.dev = false // 生产构建模式
21 | // nuxt = new Nuxt(config)
22 | // await new Builder(nuxt).build()
23 | // nuxt.listen(4000, 'localhost')
24 | // })
25 |
26 | test('Vendor', async t => {
27 | const vendor = nuxt.options.build.vendor
28 | t.true(!!~vendor.indexOf('axios'), 'axios added to config')
29 | })
30 |
31 | test('Plugin', async t => {
32 | const plugins = nuxt.options.plugins
33 | t.is(
34 | plugins[0].src,
35 | '~plugins/flexible.js',
36 | 'flexible plugin added to config'
37 | )
38 | t.is(plugins[1].src, '~plugins/iview.js', 'iview plugin added to config')
39 | })
40 |
41 | // 测试生成的html
42 | test('路由 / 有效且能渲染 HTML', async t => {
43 | const { html } = await nuxt.renderRoute('/', {
44 | req: { session: {}, headers }
45 | })
46 | t.true(html.includes(''))
47 | })
48 |
49 | // 关掉服务器和Nuxt实例,停止文件监听。
50 | test.after('Closing server and nuxt.js', async t => {
51 | await nuxt.close()
52 | })
53 |
--------------------------------------------------------------------------------
/test/helpers/create-nuxt.js:
--------------------------------------------------------------------------------
1 | import { Nuxt } from 'nuxt'
2 | import { resolve } from 'path'
3 |
4 | export default function createNuxt () {
5 | const rootDir = resolve(__dirname, '../../')
6 | let config = require(resolve(rootDir, 'nuxt.config.js'))
7 | config.rootDir = rootDir // project folder
8 | config.dev = false // production build
9 | let nuxt = new Nuxt(config)
10 | return nuxt
11 | }
12 |
--------------------------------------------------------------------------------
/test/login.test.js:
--------------------------------------------------------------------------------
1 | import test from 'ava'
2 | import createNuxt from './helpers/create-nuxt'
3 |
4 | // We keep the nuxt and server instance
5 | // So we can close them at the end of the test
6 | let nuxt = null
7 | const headers = {
8 | 'accept-language': 'zh'
9 | }
10 | // Init Nuxt.js and create a server listening on localhost:4000
11 | test.before('Init Nuxt.js', async t => {
12 | nuxt = createNuxt()
13 | await nuxt.listen(3000, 'localhost')
14 | })
15 |
16 | test('Route /login', async t => {
17 | const { html } = await nuxt.renderRoute('/login', {req: {session: {}, headers}})
18 | t.true(html.includes('欢迎'), 'login page render normal')
19 | })
20 |
21 | // Close server and ask nuxt to stop listening to file changes
22 | test.after('Closing server and nuxt.js', async t => {
23 | await nuxt.close()
24 | })
25 |
--------------------------------------------------------------------------------