├── .babelrc
├── .editorconfig
├── .gitignore
├── .postcssrc.js
├── README.md
├── build
├── build.js
├── check-versions.js
├── logo.png
├── utils.js
├── vue-loader.conf.js
├── webpack.base.conf.js
├── webpack.dev.conf.js
└── webpack.prod.conf.js
├── config
├── dev.env.js
├── index.js
├── prod.env.js
└── test.env.js
├── index.html
├── package-lock.json
├── package.json
├── src
├── App.vue
├── api
│ ├── exceldata.js
│ └── tabledata.js
├── assets
│ └── icon
│ │ ├── demo.css
│ │ ├── demo_fontclass.html
│ │ ├── demo_symbol.html
│ │ ├── demo_unicode.html
│ │ ├── iconfont.css
│ │ ├── iconfont.eot
│ │ ├── iconfont.js
│ │ ├── iconfont.svg
│ │ ├── iconfont.ttf
│ │ └── iconfont.woff
├── components
│ ├── DownTime
│ │ └── index.vue
│ ├── MyTransfer
│ │ ├── README.md
│ │ └── index.vue
│ ├── SelfTimePicker
│ │ └── index.vue
│ ├── Selftabs
│ │ └── index.vue
│ ├── Selfupload
│ │ ├── del.png
│ │ ├── index.vue
│ │ └── upload.png
│ ├── TabBar
│ │ └── index.vue
│ ├── selfDownMenu
│ │ └── index.vue
│ ├── selfInputNumber
│ │ └── index.vue
│ └── ue
│ │ └── ue.vue
├── main.js
├── mock
│ ├── data
│ │ ├── exceldata.js
│ │ └── goods.js
│ ├── exceldata.js
│ ├── index.js
│ └── tabledata.js
├── router
│ └── index.js
├── routes.js
├── store
│ └── index.js
├── styles
│ ├── app.scss
│ └── index.scss
├── utils
│ ├── date.js
│ ├── index.js
│ └── request.js
├── vendor
│ ├── Blob.js
│ ├── Export2Excel.js
│ └── Export2Zip.js
└── views
│ ├── Echarts.vue
│ ├── Edit.vue
│ ├── GDMap.vue
│ ├── Home.vue
│ ├── Vuexapplication.vue
│ ├── complexTable.vue
│ ├── exportExcel.vue
│ ├── mockspmile.vue
│ ├── mytransfer.vue
│ └── notes.vue
├── static
├── .gitkeep
└── UE
│ ├── dialogs
│ ├── anchor
│ │ └── anchor.html
│ ├── attachment
│ │ ├── attachment.css
│ │ ├── attachment.html
│ │ ├── attachment.js
│ │ ├── fileTypeImages
│ │ │ ├── icon_chm.gif
│ │ │ ├── icon_default.png
│ │ │ ├── icon_doc.gif
│ │ │ ├── icon_exe.gif
│ │ │ ├── icon_jpg.gif
│ │ │ ├── icon_mp3.gif
│ │ │ ├── icon_mv.gif
│ │ │ ├── icon_pdf.gif
│ │ │ ├── icon_ppt.gif
│ │ │ ├── icon_psd.gif
│ │ │ ├── icon_rar.gif
│ │ │ ├── icon_txt.gif
│ │ │ └── icon_xls.gif
│ │ └── images
│ │ │ ├── alignicon.gif
│ │ │ ├── alignicon.png
│ │ │ ├── bg.png
│ │ │ ├── file-icons.gif
│ │ │ ├── file-icons.png
│ │ │ ├── icons.gif
│ │ │ ├── icons.png
│ │ │ ├── image.png
│ │ │ ├── progress.png
│ │ │ ├── success.gif
│ │ │ └── success.png
│ ├── background
│ │ ├── background.css
│ │ ├── background.html
│ │ ├── background.js
│ │ └── images
│ │ │ ├── bg.png
│ │ │ └── success.png
│ ├── charts
│ │ ├── chart.config.js
│ │ ├── charts.css
│ │ ├── charts.html
│ │ ├── charts.js
│ │ └── images
│ │ │ ├── charts0.png
│ │ │ ├── charts1.png
│ │ │ ├── charts2.png
│ │ │ ├── charts3.png
│ │ │ ├── charts4.png
│ │ │ └── charts5.png
│ ├── emotion
│ │ ├── emotion.css
│ │ ├── emotion.html
│ │ ├── emotion.js
│ │ └── images
│ │ │ ├── 0.gif
│ │ │ ├── bface.gif
│ │ │ ├── cface.gif
│ │ │ ├── fface.gif
│ │ │ ├── jxface2.gif
│ │ │ ├── neweditor-tab-bg.png
│ │ │ ├── tface.gif
│ │ │ ├── wface.gif
│ │ │ └── yface.gif
│ ├── gmap
│ │ └── gmap.html
│ ├── help
│ │ ├── help.css
│ │ ├── help.html
│ │ └── help.js
│ ├── image
│ │ ├── image.css
│ │ ├── image.html
│ │ ├── image.js
│ │ └── images
│ │ │ ├── alignicon.jpg
│ │ │ ├── bg.png
│ │ │ ├── icons.gif
│ │ │ ├── icons.png
│ │ │ ├── image.png
│ │ │ ├── progress.png
│ │ │ ├── success.gif
│ │ │ └── success.png
│ ├── insertframe
│ │ └── insertframe.html
│ ├── internal.js
│ ├── link
│ │ └── link.html
│ ├── map
│ │ ├── map.html
│ │ └── show.html
│ ├── music
│ │ ├── music.css
│ │ ├── music.html
│ │ └── music.js
│ ├── preview
│ │ └── preview.html
│ ├── scrawl
│ │ ├── images
│ │ │ ├── addimg.png
│ │ │ ├── brush.png
│ │ │ ├── delimg.png
│ │ │ ├── delimgH.png
│ │ │ ├── empty.png
│ │ │ ├── emptyH.png
│ │ │ ├── eraser.png
│ │ │ ├── redo.png
│ │ │ ├── redoH.png
│ │ │ ├── scale.png
│ │ │ ├── scaleH.png
│ │ │ ├── size.png
│ │ │ ├── undo.png
│ │ │ └── undoH.png
│ │ ├── scrawl.css
│ │ ├── scrawl.html
│ │ └── scrawl.js
│ ├── searchreplace
│ │ ├── searchreplace.html
│ │ └── searchreplace.js
│ ├── snapscreen
│ │ └── snapscreen.html
│ ├── spechars
│ │ ├── spechars.html
│ │ └── spechars.js
│ ├── table
│ │ ├── dragicon.png
│ │ ├── edittable.css
│ │ ├── edittable.html
│ │ ├── edittable.js
│ │ ├── edittd.html
│ │ └── edittip.html
│ ├── template
│ │ ├── config.js
│ │ ├── images
│ │ │ ├── bg.gif
│ │ │ ├── pre0.png
│ │ │ ├── pre1.png
│ │ │ ├── pre2.png
│ │ │ ├── pre3.png
│ │ │ └── pre4.png
│ │ ├── template.css
│ │ ├── template.html
│ │ └── template.js
│ ├── video
│ │ ├── images
│ │ │ ├── bg.png
│ │ │ ├── center_focus.jpg
│ │ │ ├── file-icons.gif
│ │ │ ├── file-icons.png
│ │ │ ├── icons.gif
│ │ │ ├── icons.png
│ │ │ ├── image.png
│ │ │ ├── left_focus.jpg
│ │ │ ├── none_focus.jpg
│ │ │ ├── progress.png
│ │ │ ├── right_focus.jpg
│ │ │ ├── success.gif
│ │ │ └── success.png
│ │ ├── video.css
│ │ ├── video.html
│ │ └── video.js
│ ├── webapp
│ │ └── webapp.html
│ └── wordimage
│ │ ├── fClipboard_ueditor.swf
│ │ ├── imageUploader.swf
│ │ ├── tangram.js
│ │ ├── wordimage.html
│ │ └── wordimage.js
│ ├── lang
│ └── zh-cn
│ │ ├── images
│ │ ├── copy.png
│ │ ├── localimage.png
│ │ ├── music.png
│ │ └── upload.png
│ │ └── zh-cn.js
│ ├── themes
│ ├── default
│ │ ├── css
│ │ │ ├── ueditor.css
│ │ │ └── ueditor.min.css
│ │ ├── dialogbase.css
│ │ └── images
│ │ │ ├── anchor.gif
│ │ │ ├── arrow.png
│ │ │ ├── arrow_down.png
│ │ │ ├── arrow_up.png
│ │ │ ├── button-bg.gif
│ │ │ ├── cancelbutton.gif
│ │ │ ├── charts.png
│ │ │ ├── cursor_h.gif
│ │ │ ├── cursor_h.png
│ │ │ ├── cursor_v.gif
│ │ │ ├── cursor_v.png
│ │ │ ├── dialog-title-bg.png
│ │ │ ├── filescan.png
│ │ │ ├── highlighted.gif
│ │ │ ├── icons-all.gif
│ │ │ ├── icons.gif
│ │ │ ├── icons.png
│ │ │ ├── loaderror.png
│ │ │ ├── loading.gif
│ │ │ ├── lock.gif
│ │ │ ├── neweditor-tab-bg.png
│ │ │ ├── pagebreak.gif
│ │ │ ├── scale.png
│ │ │ ├── sortable.png
│ │ │ ├── spacer.gif
│ │ │ ├── sparator_v.png
│ │ │ ├── table-cell-align.png
│ │ │ ├── tangram-colorpicker.png
│ │ │ ├── toolbar_bg.png
│ │ │ ├── unhighlighted.gif
│ │ │ ├── upload.png
│ │ │ ├── videologo.gif
│ │ │ ├── word.gif
│ │ │ └── wordpaste.png
│ └── iframe.css
│ ├── third-party
│ ├── SyntaxHighlighter
│ │ ├── shCore.js
│ │ └── shCoreDefault.css
│ ├── codemirror
│ │ ├── codemirror.css
│ │ └── codemirror.js
│ ├── highcharts
│ │ ├── adapters
│ │ │ ├── mootools-adapter.js
│ │ │ ├── mootools-adapter.src.js
│ │ │ ├── prototype-adapter.js
│ │ │ ├── prototype-adapter.src.js
│ │ │ ├── standalone-framework.js
│ │ │ └── standalone-framework.src.js
│ │ ├── highcharts-more.js
│ │ ├── highcharts-more.src.js
│ │ ├── highcharts.js
│ │ ├── highcharts.src.js
│ │ ├── modules
│ │ │ ├── annotations.js
│ │ │ ├── annotations.src.js
│ │ │ ├── canvas-tools.js
│ │ │ ├── canvas-tools.src.js
│ │ │ ├── data.js
│ │ │ ├── data.src.js
│ │ │ ├── drilldown.js
│ │ │ ├── drilldown.src.js
│ │ │ ├── exporting.js
│ │ │ ├── exporting.src.js
│ │ │ ├── funnel.js
│ │ │ ├── funnel.src.js
│ │ │ ├── heatmap.js
│ │ │ ├── heatmap.src.js
│ │ │ ├── map.js
│ │ │ ├── map.src.js
│ │ │ ├── no-data-to-display.js
│ │ │ └── no-data-to-display.src.js
│ │ └── themes
│ │ │ ├── dark-blue.js
│ │ │ ├── dark-green.js
│ │ │ ├── gray.js
│ │ │ ├── grid.js
│ │ │ └── skies.js
│ ├── jquery-1.10.2.js
│ ├── jquery-1.10.2.min.js
│ ├── jquery-1.10.2.min.map
│ ├── video-js
│ │ ├── font
│ │ │ ├── vjs.eot
│ │ │ ├── vjs.svg
│ │ │ ├── vjs.ttf
│ │ │ └── vjs.woff
│ │ ├── video-js.css
│ │ ├── video-js.min.css
│ │ ├── video-js.swf
│ │ ├── video.dev.js
│ │ └── video.js
│ ├── webuploader
│ │ ├── Uploader.swf
│ │ ├── webuploader.css
│ │ ├── webuploader.custom.js
│ │ ├── webuploader.custom.min.js
│ │ ├── webuploader.flashonly.js
│ │ ├── webuploader.flashonly.min.js
│ │ ├── webuploader.html5only.js
│ │ ├── webuploader.html5only.min.js
│ │ ├── webuploader.js
│ │ ├── webuploader.min.js
│ │ ├── webuploader.withoutimage.js
│ │ └── webuploader.withoutimage.min.js
│ └── zeroclipboard
│ │ ├── ZeroClipboard.js
│ │ ├── ZeroClipboard.min.js
│ │ └── ZeroClipboard.swf
│ ├── ueditor.all.js
│ ├── ueditor.all.min.js
│ ├── ueditor.config.js
│ ├── ueditor.parse.js
│ └── ueditor.parse.min.js
└── test
├── e2e
├── custom-assertions
│ └── elementCount.js
├── nightwatch.conf.js
├── runner.js
└── specs
│ └── test.js
└── unit
├── .eslintrc
├── jest.conf.js
├── setup.js
└── specs
└── HelloWorld.spec.js
/.babelrc:
--------------------------------------------------------------------------------
1 | {
2 |
3 | "presets": [
4 | ["env", {
5 | "modules": false,
6 | "targets": {
7 | "browsers": ["> 1%", "last 2 versions", "not ie <= 8"]
8 | }
9 | }],
10 | "stage-2"
11 | ],
12 | "plugins": ["transform-vue-jsx", "transform-runtime"],
13 | "env": {
14 | "test": {
15 | "presets": ["env", "stage-2"],
16 | "plugins": ["transform-vue-jsx", "transform-es2015-modules-commonjs", "dynamic-import-node","transform-remove-strict-mode"]
17 | }
18 | }
19 | }
20 |
--------------------------------------------------------------------------------
/.editorconfig:
--------------------------------------------------------------------------------
1 | root = true
2 |
3 | [*]
4 | charset = utf-8
5 | indent_style = space
6 | indent_size = 2
7 | end_of_line = lf
8 | insert_final_newline = true
9 | trim_trailing_whitespace = true
10 |
11 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | .DS_Store
2 | node_modules/
3 | /dist/
4 | npm-debug.log*
5 | yarn-debug.log*
6 | yarn-error.log*
7 | /test/unit/coverage/
8 | /test/e2e/reports/
9 | selenium-debug.log
10 |
11 | # Editor directories and files
12 | .idea
13 | .vscode
14 | *.suo
15 | *.ntvs*
16 | *.njsproj
17 | *.sln
18 |
19 |
--------------------------------------------------------------------------------
/.postcssrc.js:
--------------------------------------------------------------------------------
1 | // https://github.com/michael-ciniawsky/postcss-load-config
2 |
3 | module.exports = {
4 | "plugins": {
5 | "postcss-import": {},
6 | "postcss-url": {},
7 | // to edit target browsers: use "browserslist" field in package.json
8 | "autoprefixer": {}
9 | }
10 | }
11 |
12 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # mocktest
2 |
3 | > A Vue.js project
4 |
5 | ## Build Setup
6 |
7 | ``` bash
8 | # install dependencies
9 | npm install or cnpm install
10 |
11 |
12 | # serve with hot reload at localhost:3000
13 | npm run dev
14 |
15 | # build for production with minification
16 | npm run build
17 |
18 | # build for production and view the bundle analyzer report
19 | npm run build --report
20 |
21 | # run unit tests
22 | npm run unit
23 |
24 | # run e2e tests
25 | npm run e2e
26 |
27 | # run all tests
28 | npm test
29 | ```
30 |
31 | For a detailed explanation on how things work, check out the [guide](http://vuejs-templates.github.io/webpack/) and [docs for vue-loader](http://vuejs.github.io/vue-loader).
32 |
--------------------------------------------------------------------------------
/build/build.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | require('./check-versions')()
3 |
4 | process.env.NODE_ENV = 'production'
5 |
6 | const ora = require('ora')
7 | const rm = require('rimraf')
8 | const path = require('path')
9 | const chalk = require('chalk')
10 | const webpack = require('webpack')
11 | const config = require('../config')
12 | const webpackConfig = require('./webpack.prod.conf')
13 |
14 | const spinner = ora('building for production...')
15 | spinner.start()
16 |
17 | rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => {
18 | if (err) throw err
19 | webpack(webpackConfig, (err, stats) => {
20 | spinner.stop()
21 | if (err) throw err
22 | process.stdout.write(stats.toString({
23 | colors: true,
24 | modules: false,
25 | children: false, // If you are using ts-loader, setting this to true will make TypeScript errors show up during build.
26 | chunks: false,
27 | chunkModules: false
28 | }) + '\n\n')
29 |
30 | if (stats.hasErrors()) {
31 | console.log(chalk.red(' Build failed with errors.\n'))
32 | process.exit(1)
33 | }
34 |
35 | console.log(chalk.cyan(' Build complete.\n'))
36 | console.log(chalk.yellow(
37 | ' Tip: built files are meant to be served over an HTTP server.\n' +
38 | ' Opening index.html over file:// won\'t work.\n'
39 | ))
40 | })
41 | })
42 |
--------------------------------------------------------------------------------
/build/check-versions.js:
--------------------------------------------------------------------------------
1 | /*2018-4-3 wangyuelei*/
2 | 'use strict'
3 | const chalk = require('chalk')
4 | const semver = require('semver')
5 | const packageConfig = require('../package.json')
6 | const shell = require('shelljs')
7 |
8 | function exec (cmd) {
9 | return require('child_process').execSync(cmd).toString().trim()
10 | }
11 |
12 | const versionRequirements = [
13 | {
14 | name: 'node',
15 | currentVersion: semver.clean(process.version),
16 | versionRequirement: packageConfig.engines.node
17 | }
18 | ]
19 |
20 | if (shell.which('npm')) {
21 | versionRequirements.push({
22 | name: 'npm',
23 | currentVersion: exec('npm --version'),
24 | versionRequirement: packageConfig.engines.npm
25 | })
26 | }
27 |
28 | module.exports = function () {
29 | const warnings = []
30 |
31 | for (let i = 0; i < versionRequirements.length; i++) {
32 | const mod = versionRequirements[i]
33 |
34 | if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) {
35 | warnings.push(mod.name + ': ' +
36 | chalk.red(mod.currentVersion) + ' should be ' +
37 | chalk.green(mod.versionRequirement)
38 | )
39 | }
40 | }
41 |
42 | if (warnings.length) {
43 | console.log('')
44 | console.log(chalk.yellow('To use this template, you must update following to modules:'))
45 | console.log()
46 |
47 | for (let i = 0; i < warnings.length; i++) {
48 | const warning = warnings[i]
49 | console.log(' ' + warning)
50 | }
51 |
52 | console.log()
53 | process.exit(1)
54 | }
55 | }
56 |
--------------------------------------------------------------------------------
/build/logo.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/build/logo.png
--------------------------------------------------------------------------------
/build/utils.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | const path = require('path')
3 | const config = require('../config')
4 | const ExtractTextPlugin = require('extract-text-webpack-plugin')
5 | const packageConfig = require('../package.json')
6 |
7 | exports.assetsPath = function (_path) {
8 | const assetsSubDirectory = process.env.NODE_ENV === 'production'
9 | ? config.build.assetsSubDirectory
10 | : config.dev.assetsSubDirectory
11 |
12 | return path.posix.join(assetsSubDirectory, _path)
13 | }
14 |
15 | exports.cssLoaders = function (options) {
16 | options = options || {}
17 |
18 | const cssLoader = {
19 | loader: 'css-loader',
20 | options: {
21 | sourceMap: options.sourceMap
22 | }
23 | }
24 |
25 | const postcssLoader = {
26 | loader: 'postcss-loader',
27 | options: {
28 | sourceMap: options.sourceMap
29 | }
30 | }
31 |
32 | // generate loader string to be used with extract text plugin
33 | function generateLoaders (loader, loaderOptions) {
34 | const loaders = options.usePostCSS ? [cssLoader, postcssLoader] : [cssLoader]
35 |
36 | if (loader) {
37 | loaders.push({
38 | loader: loader + '-loader',
39 | options: Object.assign({}, loaderOptions, {
40 | sourceMap: options.sourceMap
41 | })
42 | })
43 | }
44 |
45 | // Extract CSS when that option is specified
46 | // (which is the case during production build)
47 | if (options.extract) {
48 | return ExtractTextPlugin.extract({
49 | use: loaders,
50 | fallback: 'vue-style-loader'
51 | })
52 | } else {
53 | return ['vue-style-loader'].concat(loaders)
54 | }
55 | }
56 |
57 | // https://vue-loader.vuejs.org/en/configurations/extract-css.html
58 | return {
59 | css: generateLoaders(),
60 | postcss: generateLoaders(),
61 | less: generateLoaders('less'),
62 | sass: generateLoaders('sass', { indentedSyntax: true }),
63 | scss: generateLoaders('sass'),
64 | stylus: generateLoaders('stylus'),
65 | styl: generateLoaders('stylus')
66 | }
67 | }
68 |
69 | // Generate loaders for standalone style files (outside of .vue)
70 | exports.styleLoaders = function (options) {
71 | const output = []
72 | const loaders = exports.cssLoaders(options)
73 |
74 | for (const extension in loaders) {
75 | const loader = loaders[extension]
76 | output.push({
77 | test: new RegExp('\\.' + extension + '$'),
78 | use: loader
79 | })
80 | }
81 |
82 | return output
83 | }
84 |
85 | exports.createNotifierCallback = () => {
86 | const notifier = require('node-notifier')
87 |
88 | return (severity, errors) => {
89 | if (severity !== 'error') return
90 |
91 | const error = errors[0]
92 | const filename = error.file && error.file.split('!').pop()
93 |
94 | notifier.notify({
95 | title: packageConfig.name,
96 | message: severity + ': ' + error.name,
97 | subtitle: filename || '',
98 | icon: path.join(__dirname, 'logo.png')
99 | })
100 | }
101 | }
102 |
--------------------------------------------------------------------------------
/build/vue-loader.conf.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | const utils = require('./utils')
3 | const config = require('../config')
4 | const isProduction = process.env.NODE_ENV === 'production'
5 | const sourceMapEnabled = isProduction
6 | ? config.build.productionSourceMap
7 | : config.dev.cssSourceMap
8 |
9 | module.exports = {
10 | loaders: utils.cssLoaders({
11 | sourceMap: sourceMapEnabled,
12 | extract: isProduction
13 | }),
14 | cssSourceMap: sourceMapEnabled,
15 | cacheBusting: config.dev.cacheBusting,
16 | transformToRequire: {
17 | video: ['src', 'poster'],
18 | source: 'src',
19 | img: 'src',
20 | image: 'xlink:href'
21 | }
22 | }
23 |
--------------------------------------------------------------------------------
/build/webpack.base.conf.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | const path = require('path')
3 | const utils = require('./utils')
4 | const config = require('../config')
5 | const vueLoaderConfig = require('./vue-loader.conf')
6 |
7 | function resolve (dir) {
8 | return path.join(__dirname, '..', dir)
9 | }
10 |
11 |
12 |
13 | module.exports = {
14 | context: path.resolve(__dirname, '../'),
15 | entry: {
16 | app: './src/main.js'
17 | },
18 | output: {
19 | path: config.build.assetsRoot,
20 | filename: '[name].js',
21 | publicPath: process.env.NODE_ENV === 'production'
22 | ? config.build.assetsPublicPath
23 | : config.dev.assetsPublicPath
24 | },
25 | resolve: {
26 | extensions: ['.js', '.vue', '.json'],
27 | alias: {
28 | 'vue$': 'vue/dist/vue.esm.js',
29 | '@': resolve('src'),
30 | }
31 | },
32 | module: {
33 | rules: [
34 | {
35 | test: /\.vue$/,
36 | loader: 'vue-loader',
37 | options: vueLoaderConfig
38 | },
39 | {
40 | test: /\.js$/,
41 | loader: 'babel-loader',
42 | include: [resolve('src'), resolve('test'), resolve('node_modules/webpack-dev-server/client')]
43 | },
44 | {
45 | test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
46 | loader: 'url-loader',
47 | options: {
48 | limit: 10000,
49 | name: utils.assetsPath('img/[name].[hash:7].[ext]')
50 | }
51 | },
52 | {
53 | test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
54 | loader: 'url-loader',
55 | options: {
56 | limit: 10000,
57 | name: utils.assetsPath('media/[name].[hash:7].[ext]')
58 | }
59 | },
60 | {
61 | test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
62 | loader: 'url-loader',
63 | options: {
64 | limit: 10000,
65 | name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
66 | }
67 | }
68 | ]
69 | },
70 | node: {
71 | // prevent webpack from injecting useless setImmediate polyfill because Vue
72 | // source contains it (although only uses it if it's native).
73 | setImmediate: false,
74 | // prevent webpack from injecting mocks to Node native modules
75 | // that does not make sense for the client
76 | dgram: 'empty',
77 | fs: 'empty',
78 | net: 'empty',
79 | tls: 'empty',
80 | child_process: 'empty'
81 | }
82 | }
83 |
--------------------------------------------------------------------------------
/build/webpack.dev.conf.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | const utils = require('./utils')
3 | const webpack = require('webpack')
4 | const config = require('../config')
5 | const merge = require('webpack-merge')
6 | const path = require('path')
7 | const baseWebpackConfig = require('./webpack.base.conf')
8 | const CopyWebpackPlugin = require('copy-webpack-plugin')
9 | const HtmlWebpackPlugin = require('html-webpack-plugin')
10 | const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
11 | const portfinder = require('portfinder')
12 |
13 | const HOST = process.env.HOST
14 | const PORT = process.env.PORT && Number(process.env.PORT)
15 |
16 | const devWebpackConfig = merge(baseWebpackConfig, {
17 | module: {
18 | rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap, usePostCSS: true })
19 | },
20 | // cheap-module-eval-source-map is faster for development
21 | devtool: config.dev.devtool,
22 |
23 | // these devServer options should be customized in /config/index.js
24 | devServer: {
25 | clientLogLevel: 'warning',
26 | historyApiFallback: {
27 | rewrites: [
28 | { from: /.*/, to: path.posix.join(config.dev.assetsPublicPath, 'index.html') },
29 | ],
30 | },
31 | hot: true,
32 | contentBase: false, // since we use CopyWebpackPlugin.
33 | compress: true,
34 | host: HOST || config.dev.host,
35 | port: PORT || config.dev.port,
36 | open: config.dev.autoOpenBrowser,
37 | overlay: config.dev.errorOverlay
38 | ? { warnings: false, errors: true }
39 | : false,
40 | publicPath: config.dev.assetsPublicPath,
41 | proxy: config.dev.proxyTable,
42 | quiet: true, // necessary for FriendlyErrorsPlugin
43 | watchOptions: {
44 | poll: config.dev.poll,
45 | }
46 | },
47 | plugins: [
48 | new webpack.DefinePlugin({
49 | 'process.env': require('../config/dev.env')
50 | }),
51 | new webpack.HotModuleReplacementPlugin(),
52 | new webpack.NamedModulesPlugin(), // HMR shows correct file names in console on update.
53 | new webpack.NoEmitOnErrorsPlugin(),
54 | // https://github.com/ampedandwired/html-webpack-plugin
55 | new HtmlWebpackPlugin({
56 | filename: 'index.html',
57 | template: 'index.html',
58 | inject: true
59 | }),
60 | // copy custom static assets
61 | new CopyWebpackPlugin([
62 | {
63 | from: path.resolve(__dirname, '../static'),
64 | to: config.dev.assetsSubDirectory,
65 | ignore: ['.*']
66 | }
67 | ])
68 | ]
69 | })
70 |
71 | module.exports = new Promise((resolve, reject) => {
72 | portfinder.basePort = process.env.PORT || config.dev.port
73 | portfinder.getPort((err, port) => {
74 | if (err) {
75 | reject(err)
76 | } else {
77 | // publish the new Port, necessary for e2e tests
78 | process.env.PORT = port
79 | // add port to devServer config
80 | devWebpackConfig.devServer.port = port
81 |
82 | // Add FriendlyErrorsPlugin
83 | devWebpackConfig.plugins.push(new FriendlyErrorsPlugin({
84 | compilationSuccessInfo: {
85 | messages: [`Your application is running here: http://${devWebpackConfig.devServer.host}:${port}`],
86 | },
87 | onErrors: config.dev.notifyOnErrors
88 | ? utils.createNotifierCallback()
89 | : undefined
90 | }))
91 |
92 | resolve(devWebpackConfig)
93 | }
94 | })
95 | })
96 |
--------------------------------------------------------------------------------
/config/dev.env.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | const merge = require('webpack-merge')
3 | const prodEnv = require('./prod.env')
4 |
5 | module.exports = merge(prodEnv, {
6 | NODE_ENV: '"development"'
7 | })
8 |
--------------------------------------------------------------------------------
/config/index.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | // Template version: 1.3.1
3 | // see http://vuejs-templates.github.io/webpack for documentation.
4 |
5 | const path = require('path')
6 |
7 | module.exports = {
8 |
9 | dev: {
10 | // Paths
11 | assetsSubDirectory: 'static',
12 | assetsPublicPath: '/',
13 | proxyTable: {
14 | },
15 |
16 | // Various Dev Server settings
17 | host: 'localhost', // can be overwritten by process.env.HOST
18 | port: 3000, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined
19 | autoOpenBrowser: true,//自动启动浏览器
20 | errorOverlay: true,
21 | notifyOnErrors: true,
22 | poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions-
23 |
24 |
25 | /**
26 | * Source Maps
27 | */
28 |
29 | // https://webpack.js.org/configuration/devtool/#development
30 | devtool: 'cheap-module-eval-source-map',
31 |
32 | // If you have problems debugging vue-files in devtools,
33 | // set this to false - it *may* help
34 | // https://vue-loader.vuejs.org/en/options.html#cachebusting
35 | cacheBusting: true,
36 |
37 | cssSourceMap: true
38 | },
39 |
40 | build: {
41 | // Template for index.html
42 | index: path.resolve(__dirname, '../dist/index.html'),
43 |
44 | // Paths
45 | assetsRoot: path.resolve(__dirname, '../dist'),
46 | assetsSubDirectory: 'static',
47 | assetsPublicPath: '/',
48 |
49 | /**
50 | * Source Maps
51 | */
52 |
53 | productionSourceMap: true,
54 | // https://webpack.js.org/configuration/devtool/#production
55 | devtool: '#source-map',
56 |
57 | // Gzip off by default as many popular static hosts such as
58 | // Surge or Netlify already gzip all static assets for you.
59 | // Before setting to `true`, make sure to:
60 | // npm install --save-dev compression-webpack-plugin
61 | productionGzip: false,
62 | productionGzipExtensions: ['js', 'css'],
63 |
64 | // Run the build command with an extra argument to
65 | // View the bundle analyzer report after build finishes:
66 | // `npm run build --report`
67 | // Set to `true` or `false` to always turn it on or off
68 | bundleAnalyzerReport: process.env.npm_config_report
69 | }
70 | }
71 |
--------------------------------------------------------------------------------
/config/prod.env.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | module.exports = {
3 | NODE_ENV: '"production"'
4 | }
5 |
--------------------------------------------------------------------------------
/config/test.env.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | const merge = require('webpack-merge')
3 | const devEnv = require('./dev.env')
4 |
5 | module.exports = merge(devEnv, {
6 | NODE_ENV: '"testing"'
7 | })
8 |
--------------------------------------------------------------------------------
/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 | mocktest
12 |
13 |
14 |
15 |
16 |
17 |
18 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/package-lock.json
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "mocktest",
3 | "version": "1.0.0",
4 | "description": "A Vue.js project",
5 | "author": "wangyuelei ",
6 | "private": true,
7 | "scripts": {
8 | "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
9 | "start": "npm run dev",
10 | "unit": "jest --config test/unit/jest.conf.js --coverage",
11 | "e2e": "node test/e2e/runner.js",
12 | "test": "npm run unit && npm run e2e",
13 | "build": "node build/build.js"
14 | },
15 | "dependencies": {
16 | "axios": "^0.18.0",
17 | "echarts": "^4.0.4",
18 | "element-ui": "^2.3.2",
19 | "file-saver": "^1.3.8",
20 | "node-sass": "^4.8.3",
21 | "sass-loader": "^7.0.0",
22 | "vue": "^2.5.2",
23 | "vue-amap": "^0.5.8",
24 | "vue-router": "^3.0.1",
25 | "vue2-editor": "^2.4.4",
26 | "xlsx": "^0.12.7"
27 | },
28 | "devDependencies": {
29 | "autoprefixer": "^8.2.0",
30 | "axios-mock-adapter": "^1.14.1",
31 | "babel-core": "^6.22.1",
32 | "babel-helper-vue-jsx-merge-props": "^2.0.3",
33 | "babel-jest": "^22.4.3",
34 | "babel-loader": "^7.1.1",
35 | "babel-plugin-dynamic-import-node": "^1.2.0",
36 | "babel-plugin-syntax-jsx": "^6.18.0",
37 | "babel-plugin-transform-es2015-modules-commonjs": "^6.26.0",
38 | "babel-plugin-transform-runtime": "^6.22.0",
39 | "babel-plugin-transform-vue-jsx": "^3.5.0",
40 | "babel-preset-env": "^1.3.2",
41 | "babel-preset-stage-2": "^6.22.0",
42 | "babel-register": "^6.22.0",
43 | "chalk": "^2.0.1",
44 | "chromedriver": "^2.27.2",
45 | "copy-webpack-plugin": "^4.0.1",
46 | "cross-spawn": "^6.0.5",
47 | "css-loader": "^0.28.0",
48 | "extract-text-webpack-plugin": "^3.0.0",
49 | "file-loader": "^1.1.4",
50 | "friendly-errors-webpack-plugin": "^1.6.1",
51 | "html-webpack-plugin": "^3.1.0",
52 | "jest": "^22.0.4",
53 | "jest-serializer-vue": "^1.0.0",
54 | "mockjs": "^1.0.1-beta3",
55 | "nightwatch": "^0.9.12",
56 | "node-notifier": "^5.1.2",
57 | "optimize-css-assets-webpack-plugin": "^4.0.0",
58 | "ora": "^2.0.0",
59 | "portfinder": "^1.0.13",
60 | "postcss-import": "^11.0.0",
61 | "postcss-loader": "^2.0.8",
62 | "postcss-url": "^7.2.1",
63 | "rimraf": "^2.6.0",
64 | "sass-resources-loader": "^1.3.3",
65 | "script-loader": "^0.7.2",
66 | "selenium-server": "^3.0.1",
67 | "semver": "^5.3.0",
68 | "shelljs": "^0.8.1",
69 | "uglifyjs-webpack-plugin": "^1.1.1",
70 | "url-loader": "^1.0.1",
71 | "vue-jest": "^2.3.0",
72 | "vue-loader": "^14.2.2",
73 | "vue-style-loader": "^4.1.0",
74 | "vue-template-compiler": "^2.5.2",
75 | "vuex": "^3.0.1",
76 | "webpack": "^4.3.0",
77 | "webpack-bundle-analyzer": "^2.9.0",
78 | "webpack-dev-server": "^3.1.1",
79 | "webpack-merge": "^4.1.0"
80 | },
81 | "engines": {
82 | "node": ">= 6.0.0",
83 | "npm": ">= 3.0.0"
84 | },
85 | "browserslist": [
86 | "> 1%",
87 | "last 2 versions",
88 | "not ie <= 8"
89 | ]
90 | }
91 |
--------------------------------------------------------------------------------
/src/App.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
47 |
48 |
49 |
50 | Vue+Element项目实例{{$route.a}}
51 |
52 |
53 |
54 |
55 |
56 |
57 |
58 |
59 |
60 |
61 |
62 |
63 |
64 |
65 |
87 |
88 |
119 |
--------------------------------------------------------------------------------
/src/api/exceldata.js:
--------------------------------------------------------------------------------
1 | import request from '@/utils/request'
2 |
3 | export function fetchList(query) {
4 | return request({
5 | url: '/exceldata/list',
6 | method: 'get',
7 | params: query
8 | })
9 | }
10 |
--------------------------------------------------------------------------------
/src/api/tabledata.js:
--------------------------------------------------------------------------------
1 | import request from '@/utils/request'
2 | //获取数据
3 | export function fetchList(query) {
4 | return request({
5 | url: '/tabledata/list',
6 | method: 'get',
7 | params: query
8 | })
9 | }
10 |
11 | export function createTableData(data) {
12 | return request({
13 | url: '/tabledata/create',
14 | method: 'post',
15 | data
16 | })
17 | }
18 |
19 | export function updateTableData(data) {
20 | return request({
21 | url: '/tabledata/update',
22 | method: 'post',
23 | data
24 | })
25 | }
26 |
--------------------------------------------------------------------------------
/src/assets/icon/demo.css:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/assets/icon/demo.css
--------------------------------------------------------------------------------
/src/assets/icon/demo_fontclass.html:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/assets/icon/demo_fontclass.html
--------------------------------------------------------------------------------
/src/assets/icon/demo_symbol.html:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/assets/icon/demo_symbol.html
--------------------------------------------------------------------------------
/src/assets/icon/iconfont.eot:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/assets/icon/iconfont.eot
--------------------------------------------------------------------------------
/src/assets/icon/iconfont.js:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/assets/icon/iconfont.js
--------------------------------------------------------------------------------
/src/assets/icon/iconfont.svg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/assets/icon/iconfont.svg
--------------------------------------------------------------------------------
/src/assets/icon/iconfont.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/assets/icon/iconfont.ttf
--------------------------------------------------------------------------------
/src/assets/icon/iconfont.woff:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/assets/icon/iconfont.woff
--------------------------------------------------------------------------------
/src/components/DownTime/index.vue:
--------------------------------------------------------------------------------
1 |
2 | {{time}}
3 |
4 |
5 |
--------------------------------------------------------------------------------
/src/components/MyTransfer/README.md:
--------------------------------------------------------------------------------
1 | 这一个自定义的一对三的穿棱框组件,如何应用在实例中可以尝试,也可以修改后应用,希望对你有用。
--------------------------------------------------------------------------------
/src/components/Selftabs/index.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
8 |
9 |
10 |
{{option.title}}
11 | {{option.content}}
12 |
13 |
14 |
15 |
16 |
17 |
62 |
63 |
71 |
72 |
73 |
74 |
75 |
76 |
77 |
78 |
79 |
--------------------------------------------------------------------------------
/src/components/Selfupload/del.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/components/Selfupload/del.png
--------------------------------------------------------------------------------
/src/components/Selfupload/upload.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/src/components/Selfupload/upload.png
--------------------------------------------------------------------------------
/src/components/selfDownMenu/index.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | {{menuName}}
5 |
6 |
7 |
15 |
16 |
17 |
18 |
19 |
20 |
67 |
--------------------------------------------------------------------------------
/src/components/selfInputNumber/index.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
105 |
137 |
--------------------------------------------------------------------------------
/src/components/ue/ue.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
42 |
--------------------------------------------------------------------------------
/src/main.js:
--------------------------------------------------------------------------------
1 | // The Vue build version to load with the `import` command
2 | // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
3 | import Vue from 'vue'
4 | import App from './App'
5 | import axios from 'axios'
6 | import VueRouter from 'vue-router'
7 | import store from './store'
8 | import routes from './routes'
9 | import ElementUI from 'element-ui'
10 | import 'element-ui/lib/theme-chalk/index.css'
11 | import echarts from 'echarts'
12 | import './mock'
13 | import '../static/UE/ueditor.config.js'
14 | import '../static/UE/ueditor.all.min.js'
15 | import '../static/UE/lang/zh-cn/zh-cn.js'
16 | import '../static/UE/ueditor.parse.min.js'
17 | import './assets/icon/iconfont.css'
18 | //import AMap from 'vue-amap'
19 | //Vue.use(AMap)
20 | // 初始化vue-amap
21 | //AMap.initAMapApiLoader({
22 | // 申请的高德key
23 | //key: '160cab8ad6c50752175d76e61ef92c50',
24 | // 插件集合
25 | //plugin: ['AMap.Autocomplete','AMap.PlaceSearch',
26 | //'AMap.Scale', 'AMap.OverView',
27 | //'AMap.MouseTool',
28 | //'AMap.ToolBar', 'AMap.MapType',
29 | //'AMap.PolyEditor',
30 | //'AMap.CircleEditor']
31 |
32 | //});
33 | //定义全局变量
34 | Vue.prototype.$echarts = echarts
35 | Vue.config.productionTip = false
36 | Vue.prototype.Url = 'https://github.com/yueLeiWang/vue-element-admin'
37 | Vue.use(ElementUI)
38 | Vue.use(VueRouter)
39 |
40 | // 按下标删除数组的对应元素
41 | Array.prototype.del = function(dx) {
42 | if (isNaN(dx) || dx > this.length) { return false }
43 | this.splice(dx, 1)
44 | }
45 | // 指定元素从Array对象中删除
46 | Array.prototype.remove = function(val) {
47 | var index = this.indexOf(val)
48 | if (index > -1) {
49 | this.splice(index, 1)
50 | }
51 | }
52 | // 确定指定对象是否是 Array 对象中的元素
53 | Array.prototype.contains = function(obj) {
54 | var i = this.length
55 | while (i--) {
56 | if (this[i] === obj) {
57 | return true
58 | }
59 | }
60 | return false
61 | }
62 | // 数组去重
63 | Array.prototype.unique = function() {
64 | var res = [this[0]]
65 | for (var i = 1; i < this.length; i++) {
66 | var repeat = false
67 | for (var j = 0; j < res.length; j++) {
68 | if (this[i] === res[j]) {
69 | repeat = true
70 | break
71 | }
72 | }
73 | if (!repeat) {
74 | res.push(this[i])
75 | }
76 | }
77 | return res
78 | }
79 | // 数组去重(重新排序)
80 | Array.prototype.distinct = function (){
81 | var arr = this,
82 | result = [];
83 | arr.forEach(function(v, i ,arr){ //这里利用map,filter方法也可以实现
84 | var bool = arr.indexOf(v,i+1); //从传入参数的下一个索引值开始寻找是否存在重复
85 | if(bool === -1){
86 | result.push(v);
87 | }
88 | })
89 | result.sort();
90 | return result;
91 | };
92 | //对象深拷贝(应用时this.cloneObj(obj))
93 | Vue.prototype.cloneObj=function (obj){
94 | var str, newobj = obj.constructor === Array ? [] : {};
95 | if(typeof obj !== 'object'){
96 | return;
97 | } else if(window.JSON){
98 | str = JSON.stringify(obj), //序列化对象
99 | newobj = JSON.parse(str); //还原
100 | } else {//如果不支持以上方法
101 | for(var i in obj){
102 | newobj[i] = typeof obj[i] === 'object' ? cloneObj(obj[i]) : obj[i];
103 | }
104 | }
105 | return newobj;
106 | };
107 | const router = new VueRouter({
108 | routes
109 | })
110 | /* eslint-disable no-new */
111 | new Vue({
112 | el: '#app',
113 | router,
114 | store,
115 | components: { App },
116 | template: ''
117 | })
118 |
--------------------------------------------------------------------------------
/src/mock/data/exceldata.js:
--------------------------------------------------------------------------------
1 | //引入mockjs
2 | import Mock from 'mockjs';
3 | //表格数据
4 | const ExcelData = Mock.mock({
5 | // 属性 list 的值是一个数组
6 | 'list|10-50': [{
7 | 'id|+1': 1,
8 | 'name': "@ctitle(2,15)",
9 | "img": "@image('600x600',#b7ef7c)",
10 | 'status|1':['yes','no'],
11 | "brief": "@csentence(1,50)",
12 | "price|0-20.0-2": 1,
13 | "num|30-150": 0,
14 | "minusFlag": true,
15 | "time": "@time",
16 | "peisongfei|0-100.0-2": 1,
17 | "limit|0-50": 1
18 | }]
19 | });
20 | export default {ExcelData}
21 |
22 |
23 |
--------------------------------------------------------------------------------
/src/mock/data/goods.js:
--------------------------------------------------------------------------------
1 | //引入mockjs
2 | import Mock from 'mockjs';
3 | const data = Mock.mock({
4 | // 属性 list 的值是一个数组,其中含有 1 到 10 个元素
5 | 'foods|10-50': [{
6 | 'id|+1': 1,
7 | 'name': "@ctitle(2,15)",
8 | "img": "@image('600x600',#b7ef7c)",
9 | "brief": "@csentence(1,50)",
10 | "price|0-20.0-2": 1,
11 | "num|30-150": 0,
12 | "minusFlag": true,
13 | "time": "@time",
14 | "peisongfei|0-100.0-2": 1,
15 | "limit|0-50": 1
16 | }]
17 | });
18 | export default {data}
19 |
--------------------------------------------------------------------------------
/src/mock/exceldata.js:
--------------------------------------------------------------------------------
1 | //引入mockjs
2 | import Mock from 'mockjs';
3 |
4 | const List = []
5 | const count = 20
6 |
7 | for (let i = 0; i < count; i++) {
8 | List.push(Mock.mock({
9 | 'id|+1': 1,
10 | 'name': "@ctitle(2,15)",
11 | "img": "@image('600x600',#b7ef7c)",
12 | 'status|1':['yes','no'],
13 | "brief": "@csentence(1,50)",
14 | "price|0-20.0-2": 1,
15 | "num|30-150": 0,
16 | "minusFlag": true,
17 | "time": "@time",
18 | "peisongfei|0-100.0-2": 1,
19 | "limit|0-50": 1
20 | }))
21 | }
22 | export default {
23 | getList: () => {
24 | return {
25 | total: List.length,
26 | items: List
27 | }
28 | }
29 | }
30 |
31 |
--------------------------------------------------------------------------------
/src/mock/index.js:
--------------------------------------------------------------------------------
1 | import Mock from 'mockjs'
2 | import tabledataAPI from './tabledata'
3 | import exceldataAPI from './exceldata'
4 | // 表格相关
5 | Mock.mock(/\/tabledata\/list/, 'get', tabledataAPI.getList)
6 | Mock.mock(/\/tabledata\/create/, 'post', tabledataAPI.createTableData)
7 | Mock.mock(/\/tabledata\/update/, 'post', tabledataAPI.updateTableData)
8 | //excelTableData
9 | Mock.mock(/\/exceldata\/list/, 'get', exceldataAPI.getList)
10 |
11 | export default Mock
12 |
--------------------------------------------------------------------------------
/src/mock/tabledata.js:
--------------------------------------------------------------------------------
1 | import Mock from 'mockjs'
2 | import { param2Obj } from '@/utils'
3 |
4 | const List = []
5 | const count = 100
6 |
7 | for (let i = 0; i < count; i++) {
8 | List.push(Mock.mock({
9 | id: '@increment',
10 | author: '@cname()',
11 | reviewer: '@cname()',
12 | title: '@ctitle(2,16)',
13 | dateTime: '@datetime'
14 | }))
15 | }
16 |
17 | export default {
18 | getList: config => {
19 | const { title, page = 1, limit = 20, sort } = param2Obj(config.url)
20 |
21 | let mockList = List.filter(item => {
22 | if (title && item.title.indexOf(title) < 0) return false
23 | return true
24 | })
25 | if (sort === '-id') {
26 | mockList = mockList.reverse()
27 | }
28 | const pageList = mockList.filter((item, index) => index < limit * page && index >= limit * (page - 1))
29 |
30 | return {
31 | total: mockList.length,
32 | items: pageList
33 | }
34 | },
35 | createTableData: () => ({
36 | data: 'success'
37 | }),
38 | updateTableData: () => ({
39 | data: 'success'
40 | })
41 | }
42 |
--------------------------------------------------------------------------------
/src/router/index.js:
--------------------------------------------------------------------------------
1 | import Hello from './views/Hello'
2 | import index from './views/index'
3 | let routes = [
4 | {
5 | path: '/',
6 | name: 'Hello',
7 | component: Hello
8 | },
9 | {
10 | path: '/index',
11 | name: 'index',
12 | component: index
13 | }
14 | ];
15 |
16 | export default routes;
17 |
--------------------------------------------------------------------------------
/src/routes.js:
--------------------------------------------------------------------------------
1 | import Home from './views/Home'
2 | import Echarts from './views/Echarts'
3 | import GDMap from './views/GDMap'
4 | import mockspmile from './views/mockspmile'
5 | import mytransfer from './views/mytransfer'
6 | import exportExcel from './views/exportExcel'
7 | import Vuexapplication from './views/Vuexapplication'
8 | import complexTable from './views/complexTable'
9 | import notes from './views/notes'
10 | import Edit from './views/Edit'
11 | let routes = [
12 | {
13 | path: '/',
14 | name: '首页',
15 | component: Home,
16 | meta:{keepAlive: false}
17 | },
18 | {
19 | path: '/Echarts',
20 | name: 'Echarts应用',
21 | component:Echarts,
22 | meta:{keepAlive: false}
23 | },
24 | {
25 | path: '/complexTable',
26 | name: 'Table操作',
27 | component:complexTable,
28 | meta:{keepAlive: false}
29 | },
30 | {
31 | path: '/GDMap',
32 | name: '高德地图',
33 | component:GDMap,
34 | meta:{keepAlive: false}
35 | },
36 | {
37 | path: '/mockspmile',
38 | name: '数据模拟',
39 | component:mockspmile,
40 | meta:{keepAlive: false}
41 | },
42 | {
43 | path:'/mytransfer',
44 | name:'自定义组件',
45 | component:mytransfer,
46 | meta:{keepAlive: false}
47 | },
48 | {
49 | path:'/exportExcel',
50 | name:'excel表格导出',
51 | component:exportExcel,
52 | meta:{keepAlive: false}
53 | },
54 | {
55 | path:'/Edit',
56 | name:'文本编辑器',
57 | component:Edit,
58 | meta:{keepAlive: false}
59 | },
60 | {
61 | path:'/Vuexapplication',
62 | name:'Vuex应用实例',
63 | component:Vuexapplication,
64 | meta:{keepAlive: false}
65 | },
66 | {
67 | path:'/notes',
68 | name:'学习笔记',
69 | component:notes,
70 | meta:{keepAlive: true},
71 | }
72 |
73 | ];
74 |
75 | export default routes;
76 |
--------------------------------------------------------------------------------
/src/store/index.js:
--------------------------------------------------------------------------------
1 | import Vue from 'vue'
2 | import Vuex from 'vuex'
3 |
4 | Vue.use(Vuex)
5 | //存放组件之间共享的数据
6 | const state = {
7 | count:0,
8 | visitedViews: []
9 | }
10 | //获取数据的方法
11 | const getters = {
12 | count: state => state.count
13 | }
14 | //显式的更改state里的数据
15 | const mutations = {
16 | increment (state){
17 | state.count++
18 | },
19 | deccrement (state){
20 | state.count--
21 | },
22 | //定义方法
23 | ADD_VISITED_VIEWS: (state, view) => {
24 | if (state.visitedViews.some(v => v.path === view.path)) return
25 | state.visitedViews.push({ name: view.name, path: view.path })
26 | },
27 | DEL_VISITED_VIEWS: (state, view) => {
28 | let index
29 | for (const [i, v] of state.visitedViews.entries()) {
30 | if (v.path === view.path) {
31 | index = i
32 | break
33 | }
34 | }
35 | state.visitedViews.splice(index, 1)
36 | }
37 | }
38 | //异步更改state里的数据
39 | const actions = {
40 | //调用mutations里定义的方法
41 | addVisitedViews({ commit }, view) {
42 | commit('ADD_VISITED_VIEWS', view)
43 | },
44 | delVisitedViews({ commit, state }, view) {
45 | return new Promise((resolve) => {
46 | commit('DEL_VISITED_VIEWS', view)
47 | resolve([...state.visitedViews])
48 | })
49 | }
50 | }
51 | export default new Vuex.Store({
52 | state,
53 | getters,
54 | mutations,
55 | actions
56 | })
57 |
--------------------------------------------------------------------------------
/src/styles/app.scss:
--------------------------------------------------------------------------------
1 | html {
2 | font-size: 20px;
3 | }
4 | @media only screen and (min-width: 401px) {
5 | html {
6 | font-size: 25px !important;
7 | }
8 | }
9 | @media only screen and (min-width: 428px) {
10 | html {
11 | font-size: 26.75px !important;
12 | }
13 | }
14 | @media only screen and (min-width: 481px) {
15 | html {
16 | font-size: 30px !important;
17 | }
18 | }
19 | @media only screen and (min-width: 569px) {
20 | html {
21 | font-size: 35px !important;
22 | }
23 | }
24 | @media only screen and (min-width: 641px) {
25 | html {
26 | font-size: 40px !important;
27 | }
28 | }
29 | @media only screen and (min-width: 751px) {
30 | html {
31 | font-size: 50px !important;
32 | }
33 | }
34 | @media only screen and (min-width: 1080px) {
35 | html {
36 | font-size: 60px !important;
37 | }
38 | }
39 |
--------------------------------------------------------------------------------
/src/styles/index.scss:
--------------------------------------------------------------------------------
1 | //公共样式调整
2 | body {
3 | min-width: 960px;
4 | -moz-osx-font-smoothing: grayscale;
5 | -webkit-font-smoothing: antialiased;
6 | text-rendering: optimizeLegibility;
7 | font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif;
8 | background:#fff;
9 | font-size:14px;
10 | }
11 | .el-main{padding:20px 0px;}
12 | .app-container{padding:20px;}
13 | .el-table{margin-top:20px !important;}
14 | b{font-family:"iconfont";color: #909399;font-size:20px;}
15 |
16 |
17 |
18 |
--------------------------------------------------------------------------------
/src/utils/date.js:
--------------------------------------------------------------------------------
1 | var SIGN_REGEXP = /([yMdhsm])(\1*)/g
2 | var DEFAULT_PATTERN = 'yyyy-MM-dd'
3 | function padding(s, len) {
4 | var len = len - (s + '').length;
5 | for (var i = 0; i < len; i++) { s = '0' + s }
6 | return s;
7 | }
8 | export default {
9 | formatDate: {
10 | format: function (date, pattern) {
11 | pattern = pattern || DEFAULT_PATTERN;
12 | return pattern.replace(SIGN_REGEXP, function ($0) {
13 | switch ($0.charAt(0)) {
14 | case 'y': return padding(date.getFullYear(), $0.length)
15 | case 'M': return padding(date.getMonth() + 1, $0.length)
16 | case 'd': return padding(date.getDate(), $0.length)
17 | case 'w': return date.getDay() + 1
18 | case 'h': return padding(date.getHours(), $0.length)
19 | case 'm': return padding(date.getMinutes(), $0.length)
20 | case 's': return padding(date.getSeconds(), $0.length)
21 | }
22 | })
23 | },
24 | parse: function (dateString, pattern) {
25 | var matchs1 = pattern.match(SIGN_REGEXP)
26 | var matchs2 = dateString.match(/(\d)+/g)
27 | if (matchs1.length == matchs2.length) {
28 | var _date = new Date(1970, 0, 1)
29 | for (var i = 0; i < matchs1.length; i++) {
30 | var _int = parseInt(matchs2[i])
31 | var sign = matchs1[i];
32 | switch (sign.charAt(0)) {
33 | case 'y': _date.setFullYear(_int); break
34 | case 'M': _date.setMonth(_int - 1); break
35 | case 'd': _date.setDate(_int); break
36 | case 'h': _date.setHours(_int); break
37 | case 'm': _date.setMinutes(_int); break
38 | case 's': _date.setSeconds(_int); break
39 | }
40 | }
41 | return _date
42 | }
43 | return null
44 | }
45 |
46 | }
47 |
48 | };
49 |
--------------------------------------------------------------------------------
/src/utils/index.js:
--------------------------------------------------------------------------------
1 | /*url pramse*/
2 | export function param2Obj(url) {
3 | const search = url.split('?')[1]
4 | if (!search) {
5 | return {}
6 | }
7 | return JSON.parse('{"' + decodeURIComponent(search).replace(/"/g, '\\"').replace(/&/g, '","').replace(/=/g, '":"') + '"}')
8 | }
9 |
10 |
11 |
--------------------------------------------------------------------------------
/src/utils/request.js:
--------------------------------------------------------------------------------
1 | import axios from 'axios'
2 | import { Message } from 'element-ui'
3 | import store from '@/store'
4 | // create an axios instance
5 | const service = axios.create({
6 | baseURL: process.env.BASE_API, // api的base_url
7 | timeout: 5000 // request timeout
8 | })
9 |
10 | // request interceptor
11 | service.interceptors.request.use(config => {
12 | // Do something before request is sent
13 | return config
14 | }, error => {
15 | // Do something with request error
16 | console.log(error) // for debug
17 | Promise.reject(error)
18 | })
19 |
20 | // respone interceptor
21 | service.interceptors.response.use(
22 | response => response,
23 | error => {
24 | console.log('err' + error)// for debug
25 | Message({
26 | message: error.message,
27 | type: 'error',
28 | duration: 5 * 1000
29 | })
30 | return Promise.reject(error)
31 | })
32 |
33 | export default service
34 |
--------------------------------------------------------------------------------
/src/vendor/Export2Zip.js:
--------------------------------------------------------------------------------
1 | /* eslint-disable */
2 | require('script-loader!file-saver');
3 | import JSZip from 'jszip'
4 |
5 | export function export_txt_to_zip(th, jsonData, txtName, zipName) {
6 | const zip = new JSZip()
7 | const txt_name = txtName || 'file'
8 | const zip_name = zipName || 'file'
9 | const data = jsonData
10 | let txtData = `${th}\r\n`
11 | data.forEach((row) => {
12 | let tempStr = ''
13 | tempStr = row.toString()
14 | txtData += `${tempStr}\r\n`
15 | })
16 | zip.file(`${txt_name}.txt`, txtData)
17 | zip.generateAsync({type:"blob"}).then((blob) => {
18 | saveAs(blob, `${zip_name}.zip`)
19 | }, (err) => {
20 | alert('导出失败')
21 | })
22 | }
23 |
--------------------------------------------------------------------------------
/src/views/Echarts.vue:
--------------------------------------------------------------------------------
1 |
2 |
6 |
7 |
8 |
43 |
49 |
--------------------------------------------------------------------------------
/src/views/Edit.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
8 |
9 |
10 |
11 |
12 |
dddd
13 |
14 |
15 |
28 |
63 |
64 |
65 |
66 |
67 |
68 |
69 |
70 |
71 |
72 |
73 |
74 |
75 |
76 |
77 |
78 |
79 |
80 |
81 |
--------------------------------------------------------------------------------
/src/views/Home.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
本项目是基于vue、Element、mockjs构建的(全部为当前最新版本),其中引入了高德地图、Echarts、Excel表格导出、富文本编辑器的第三方组件。
4 |
还有部分本人在实际项目中自己写的组件也在项目中有应该实例,内容还在不断更新中.....
5 |
下载项目
6 |
7 |
8 |
9 |
21 |
27 |
--------------------------------------------------------------------------------
/src/views/Vuexapplication.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
{{msg}}
4 |
{{ getCount }}
5 |
+1
6 |
-1
7 |
时间转化
8 |
{{time}}
9 |
{{timeString}}
10 |
11 |
12 |
13 |
54 |
60 |
--------------------------------------------------------------------------------
/src/views/exportExcel.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | {{msg}}
5 | 导出
6 |
7 |
11 |
16 |
17 |
22 |
23 |
28 |
29 |
33 |
34 |
38 |
39 |
42 |
43 | 上架
44 | 下架
45 |
46 |
47 |
48 |
49 |
50 |
51 |
109 |
115 |
--------------------------------------------------------------------------------
/src/views/mockspmile.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
{{msg}}
4 |
8 |
13 |
14 |
19 |
20 |
25 |
26 |
30 |
31 |
35 |
36 |
37 |
38 |
39 |
40 |
64 |
70 |
--------------------------------------------------------------------------------
/src/views/notes.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
学习笔记
4 |
5 |
按需引入Element-ui
6 |
7 |
(一)导入Element-ui与安装babel-plugin-component
8 |
npm install element-ui --save
9 |
npm install babel-plugin-component -D
10 |
11 |
12 |
(二)在main.js中加入
13 |
import {Pagination} from 'element-ui'//可以引入多个
14 |
Vue.use(Pagination)//一个一个的引入
15 |
16 |
17 |
(三)在.babelrc文件中的"plugins"的对象中加入:
18 |
19 | [
20 | "component",
21 | {
22 | "libraryName": "element-ui",
23 | "styleLibraryName": "theme-chalk"
24 | }
25 | ]
26 |
27 |
28 |
29 |
合并对象(给原对象新增属性)
30 |
31 |
Object.assign({},obj,obj1)
32 |
花括号叫目标对象,后面的obj、obj1是源对象。对象合并是指:将源对象里面的属性添加到目标对象中去,若两者的属性名有冲突,后面的将会覆盖前面的
33 |
【注意】:当Object.assign()方法用于数组时,对象是根据属性名来对应,数组是根据索引号来对应
34 |
var arr11 = Object.assign([1,2,3],[4,5]);
35 |
console.log(arr11);//[4,5,3]
36 |
37 |
38 |
39 |
Element-ui 样式自定义(覆盖)
40 |
41 |
(一)先安装sass-loader与node-sass
42 |
npm intall sass-loader --save;
43 |
npm install node-sass --save;
44 |
45 |
46 |
(二)新建styles文件夹,其内创建index.scss,写新样式就可以了
47 |
48 |
$nextTick的理解
49 |
50 |
$nextTick 是在下次 DOM 更新循环结束之后执行延迟回调,在修改数据之后使用 $nextTick,则可以在回调中获取更新后的 DOM
51 |
$nextTick在change事件中应用的较多
52 |
53 |
54 |
55 | ddddddddddd
56 | aaaaaaaaaaa
57 |
58 |
dd
59 |
60 |
61 | llllllllllllllllllll
62 |
63 |
64 |
65 |
66 |
67 |
94 |
109 |
--------------------------------------------------------------------------------
/static/.gitkeep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/.gitkeep
--------------------------------------------------------------------------------
/static/UE/dialogs/anchor/anchor.html:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 |
6 |
7 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
39 |
40 |
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/attachment.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | ueditor图片对话框
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 | 0%
32 |
33 |
34 |
38 |
39 |
44 |
47 |
48 |
49 |
50 |
51 |
54 |
55 |
56 |
57 |
58 |
59 |
60 |
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_chm.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_chm.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_default.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_default.png
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_doc.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_doc.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_exe.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_exe.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_jpg.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_jpg.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_mp3.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_mp3.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_mv.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_mv.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_pdf.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_pdf.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_ppt.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_ppt.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_psd.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_psd.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_rar.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_rar.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_txt.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_txt.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/fileTypeImages/icon_xls.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/fileTypeImages/icon_xls.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/alignicon.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/alignicon.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/alignicon.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/alignicon.png
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/bg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/bg.png
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/file-icons.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/file-icons.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/file-icons.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/file-icons.png
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/icons.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/icons.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/icons.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/icons.png
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/image.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/image.png
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/progress.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/progress.png
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/success.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/success.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/attachment/images/success.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/attachment/images/success.png
--------------------------------------------------------------------------------
/static/UE/dialogs/background/background.css:
--------------------------------------------------------------------------------
1 | .wrapper{ width: 424px;margin: 10px auto; zoom:1;position: relative}
2 | .tabbody{height:225px;}
3 | .tabbody .panel { position: absolute;width:100%; height:100%;background: #fff; display: none;}
4 | .tabbody .focus { display: block;}
5 |
6 | body{font-size: 12px;color: #888;overflow: hidden;}
7 | input,label{vertical-align:middle}
8 | .clear{clear: both;}
9 | .pl{padding-left: 18px;padding-left: 23px\9;}
10 |
11 | #imageList {width: 420px;height: 215px;margin-top: 10px;overflow: hidden;overflow-y: auto;}
12 | #imageList div {float: left;width: 100px;height: 95px;margin: 5px 10px;}
13 | #imageList img {cursor: pointer;border: 2px solid white;}
14 |
15 | .bgarea{margin: 10px;padding: 5px;height: 84%;border: 1px solid #A8A297;}
16 | .content div{margin: 10px 0 10px 5px;}
17 | .content .iptradio{margin: 0px 5px 5px 0px;}
18 | .txt{width:280px;}
19 |
20 | .wrapcolor{height: 19px;}
21 | div.color{float: left;margin: 0;}
22 | #colorPicker{width: 17px;height: 17px;border: 1px solid #CCC;display: inline-block;border-radius: 3px;box-shadow: 2px 2px 5px #D3D6DA;margin: 0;float: left;}
23 | div.alignment,#custom{margin-left: 23px;margin-left: 28px\9;}
24 | #custom input{height: 15px;min-height: 15px;width:20px;}
25 | #repeatType{width:100px;}
26 |
27 |
28 | /* 图片管理样式 */
29 | #imgManager {
30 | width: 100%;
31 | height: 225px;
32 | }
33 | #imgManager #imageList{
34 | width: 100%;
35 | overflow-x: hidden;
36 | overflow-y: auto;
37 | }
38 | #imgManager ul {
39 | display: block;
40 | list-style: none;
41 | margin: 0;
42 | padding: 0;
43 | }
44 | #imgManager li {
45 | float: left;
46 | display: block;
47 | list-style: none;
48 | padding: 0;
49 | width: 113px;
50 | height: 113px;
51 | margin: 9px 0 0 19px;
52 | background-color: #eee;
53 | overflow: hidden;
54 | cursor: pointer;
55 | position: relative;
56 | }
57 | #imgManager li.clearFloat {
58 | float: none;
59 | clear: both;
60 | display: block;
61 | width:0;
62 | height:0;
63 | margin: 0;
64 | padding: 0;
65 | }
66 | #imgManager li img {
67 | cursor: pointer;
68 | }
69 | #imgManager li .icon {
70 | cursor: pointer;
71 | width: 113px;
72 | height: 113px;
73 | position: absolute;
74 | top: 0;
75 | left: 0;
76 | z-index: 2;
77 | border: 0;
78 | background-repeat: no-repeat;
79 | }
80 | #imgManager li .icon:hover {
81 | width: 107px;
82 | height: 107px;
83 | border: 3px solid #1094fa;
84 | }
85 | #imgManager li.selected .icon {
86 | background-image: url(images/success.png);
87 | background-position: 75px 75px;
88 | }
89 | #imgManager li.selected .icon:hover {
90 | width: 107px;
91 | height: 107px;
92 | border: 3px solid #1094fa;
93 | background-position: 72px 72px;
94 | }
--------------------------------------------------------------------------------
/static/UE/dialogs/background/background.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
47 |
48 |
49 |
52 |
53 |
54 |
55 |
56 |
57 |
--------------------------------------------------------------------------------
/static/UE/dialogs/background/images/bg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/background/images/bg.png
--------------------------------------------------------------------------------
/static/UE/dialogs/background/images/success.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/background/images/success.png
--------------------------------------------------------------------------------
/static/UE/dialogs/charts/chart.config.js:
--------------------------------------------------------------------------------
1 | /*
2 | * 图表配置文件
3 | * */
4 |
5 |
6 | //不同类型的配置
7 | var typeConfig = [
8 | {
9 | chart: {
10 | type: 'line'
11 | },
12 | plotOptions: {
13 | line: {
14 | dataLabels: {
15 | enabled: false
16 | },
17 | enableMouseTracking: true
18 | }
19 | }
20 | }, {
21 | chart: {
22 | type: 'line'
23 | },
24 | plotOptions: {
25 | line: {
26 | dataLabels: {
27 | enabled: true
28 | },
29 | enableMouseTracking: false
30 | }
31 | }
32 | }, {
33 | chart: {
34 | type: 'area'
35 | }
36 | }, {
37 | chart: {
38 | type: 'bar'
39 | }
40 | }, {
41 | chart: {
42 | type: 'column'
43 | }
44 | }, {
45 | chart: {
46 | plotBackgroundColor: null,
47 | plotBorderWidth: null,
48 | plotShadow: false
49 | },
50 | plotOptions: {
51 | pie: {
52 | allowPointSelect: true,
53 | cursor: 'pointer',
54 | dataLabels: {
55 | enabled: true,
56 | color: '#000000',
57 | connectorColor: '#000000',
58 | formatter: function() {
59 | return ''+ this.point.name +': '+ ( Math.round( this.point.percentage*100 ) / 100 ) +' %';
60 | }
61 | }
62 | }
63 | }
64 | }
65 | ];
66 |
--------------------------------------------------------------------------------
/static/UE/dialogs/charts/charts.css:
--------------------------------------------------------------------------------
1 | html, body {
2 | width: 100%;
3 | height: 100%;
4 | margin: 0;
5 | padding: 0;
6 | overflow-x: hidden;
7 | }
8 |
9 | .main {
10 | width: 100%;
11 | overflow: hidden;
12 | }
13 |
14 | .table-view {
15 | height: 100%;
16 | float: left;
17 | margin: 20px;
18 | width: 40%;
19 | }
20 |
21 | .table-view .table-container {
22 | width: 100%;
23 | margin-bottom: 50px;
24 | overflow: scroll;
25 | }
26 |
27 | .table-view th {
28 | padding: 5px 10px;
29 | background-color: #F7F7F7;
30 | }
31 |
32 | .table-view td {
33 | width: 50px;
34 | text-align: center;
35 | padding:0;
36 | }
37 |
38 | .table-container input {
39 | width: 40px;
40 | padding: 5px;
41 | border: none;
42 | outline: none;
43 | }
44 |
45 | .table-view caption {
46 | font-size: 18px;
47 | text-align: left;
48 | }
49 |
50 | .charts-view {
51 | /*margin-left: 49%!important;*/
52 | width: 50%;
53 | margin-left: 49%;
54 | height: 400px;
55 | }
56 |
57 | .charts-container {
58 | border-left: 1px solid #c3c3c3;
59 | }
60 |
61 | .charts-format fieldset {
62 | padding-left: 20px;
63 | margin-bottom: 50px;
64 | }
65 |
66 | .charts-format legend {
67 | padding-left: 10px;
68 | padding-right: 10px;
69 | }
70 |
71 | .format-item-container {
72 | padding: 20px;
73 | }
74 |
75 | .format-item-container label {
76 | display: block;
77 | margin: 10px 0;
78 | }
79 |
80 | .charts-format .data-item {
81 | border: 1px solid black;
82 | outline: none;
83 | padding: 2px 3px;
84 | }
85 |
86 | /* 图表类型 */
87 |
88 | .charts-type {
89 | margin-top: 50px;
90 | height: 300px;
91 | }
92 |
93 | .scroll-view {
94 | border: 1px solid #c3c3c3;
95 | border-left: none;
96 | border-right: none;
97 | overflow: hidden;
98 | }
99 |
100 | .scroll-container {
101 | margin: 20px;
102 | width: 100%;
103 | overflow: hidden;
104 | }
105 |
106 | .scroll-bed {
107 | width: 10000px;
108 | _margin-top: 20px;
109 | -webkit-transition: margin-left .5s ease;
110 | -moz-transition: margin-left .5s ease;
111 | transition: margin-left .5s ease;
112 | }
113 |
114 | .view-box {
115 | display: inline-block;
116 | *display: inline;
117 | *zoom: 1;
118 | margin-right: 20px;
119 | border: 2px solid white;
120 | line-height: 0;
121 | overflow: hidden;
122 | cursor: pointer;
123 | }
124 |
125 | .view-box img {
126 | border: 1px solid #cecece;
127 | }
128 |
129 | .view-box.selected {
130 | border-color: #7274A7;
131 | }
132 |
133 | .button-container {
134 | margin-bottom: 20px;
135 | text-align: center;
136 | }
137 |
138 | .button-container a {
139 | display: inline-block;
140 | width: 100px;
141 | height: 25px;
142 | line-height: 25px;
143 | border: 1px solid #c2ccd1;
144 | margin-right: 30px;
145 | text-decoration: none;
146 | color: black;
147 | -webkit-border-radius: 2px;
148 | -moz-border-radius: 2px;
149 | border-radius: 2px;
150 | }
151 |
152 | .button-container a:HOVER {
153 | background: #fcfcfc;
154 | }
155 |
156 | .button-container a:ACTIVE {
157 | border-top-color: #c2ccd1;
158 | box-shadow:inset 0 5px 4px -4px rgba(49, 49, 64, 0.1);
159 | }
160 |
161 | .edui-charts-not-data {
162 | height: 100px;
163 | line-height: 100px;
164 | text-align: center;
165 | }
--------------------------------------------------------------------------------
/static/UE/dialogs/charts/images/charts0.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/charts/images/charts0.png
--------------------------------------------------------------------------------
/static/UE/dialogs/charts/images/charts1.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/charts/images/charts1.png
--------------------------------------------------------------------------------
/static/UE/dialogs/charts/images/charts2.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/charts/images/charts2.png
--------------------------------------------------------------------------------
/static/UE/dialogs/charts/images/charts3.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/charts/images/charts3.png
--------------------------------------------------------------------------------
/static/UE/dialogs/charts/images/charts4.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/charts/images/charts4.png
--------------------------------------------------------------------------------
/static/UE/dialogs/charts/images/charts5.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/charts/images/charts5.png
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/emotion.css:
--------------------------------------------------------------------------------
1 | .jd img{
2 | background:transparent url(images/jxface2.gif?v=1.1) no-repeat scroll left top;
3 | cursor:pointer;width:35px;height:35px;display:block;
4 | }
5 | .pp img{
6 | background:transparent url(images/fface.gif?v=1.1) no-repeat scroll left top;
7 | cursor:pointer;width:25px;height:25px;display:block;
8 | }
9 | .ldw img{
10 | background:transparent url(images/wface.gif?v=1.1) no-repeat scroll left top;
11 | cursor:pointer;width:35px;height:35px;display:block;
12 | }
13 | .tsj img{
14 | background:transparent url(images/tface.gif?v=1.1) no-repeat scroll left top;
15 | cursor:pointer;width:35px;height:35px;display:block;
16 | }
17 | .cat img{
18 | background:transparent url(images/cface.gif?v=1.1) no-repeat scroll left top;
19 | cursor:pointer;width:35px;height:35px;display:block;
20 | }
21 | .bb img{
22 | background:transparent url(images/bface.gif?v=1.1) no-repeat scroll left top;
23 | cursor:pointer;width:35px;height:35px;display:block;
24 | }
25 | .youa img{
26 | background:transparent url(images/yface.gif?v=1.1) no-repeat scroll left top;
27 | cursor:pointer;width:35px;height:35px;display:block;
28 | }
29 |
30 | .smileytable td {height: 37px;}
31 | #tabPanel{margin-left:5px;overflow: hidden;}
32 | #tabContent {float:left;background:#FFFFFF;}
33 | #tabContent div{display: none;width:480px;overflow:hidden;}
34 | #tabIconReview.show{left:17px;display:block;}
35 | .menuFocus{background:#ACCD3C;}
36 | .menuDefault{background:#FFFFFF;}
37 | #tabIconReview{position:absolute;left:406px;left:398px \9;top:41px;z-index:65533;width:90px;height:76px;}
38 | img.review{width:90px;height:76px;border:2px solid #9cb945;background:#FFFFFF;background-position:center;background-repeat:no-repeat;}
39 |
40 | .wrapper .tabbody{position:relative;float:left;clear:both;padding:10px;width: 95%;}
41 | .tabbody table{width: 100%;}
42 | .tabbody td{border:1px solid #BAC498;}
43 | .tabbody td span{display: block;zoom:1;padding:0 4px;}
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/emotion.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |

33 |
34 |
35 |
53 |
54 |
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/0.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/0.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/bface.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/bface.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/cface.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/cface.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/fface.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/fface.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/jxface2.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/jxface2.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/neweditor-tab-bg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/neweditor-tab-bg.png
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/tface.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/tface.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/wface.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/wface.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/emotion/images/yface.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/emotion/images/yface.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/gmap/gmap.html:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 |
6 |
7 |
8 |
14 |
15 |
16 |
17 |
27 |
88 |
89 |
--------------------------------------------------------------------------------
/static/UE/dialogs/help/help.css:
--------------------------------------------------------------------------------
1 | .wrapper{width: 370px;margin: 10px auto;zoom: 1;}
2 | .tabbody{height: 360px;}
3 | .tabbody .panel{width:100%;height: 360px;position: absolute;background: #fff;}
4 | .tabbody .panel h1{font-size:26px;margin: 5px 0 0 5px;}
5 | .tabbody .panel p{font-size:12px;margin: 5px 0 0 5px;}
6 | .tabbody table{width:90%;line-height: 20px;margin: 5px 0 0 5px;;}
7 | .tabbody table thead{font-weight: bold;line-height: 25px;}
--------------------------------------------------------------------------------
/static/UE/dialogs/help/help.html:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 | 帮助
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
UEditor
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 | |
27 | |
28 |
29 |
30 |
31 |
32 | ctrl+b |
33 | |
34 |
35 |
36 | ctrl+c |
37 | |
38 |
39 |
40 | ctrl+x |
41 | |
42 |
43 |
44 | ctrl+v |
45 | |
46 |
47 |
48 | ctrl+y |
49 | |
50 |
51 |
52 | ctrl+z |
53 | |
54 |
55 |
56 | ctrl+i |
57 | |
58 |
59 |
60 | ctrl+u |
61 | |
62 |
63 |
64 | ctrl+a |
65 | |
66 |
67 |
68 | shift+enter |
69 | |
70 |
71 |
72 | alt+z |
73 | |
74 |
75 |
76 |
77 |
78 |
79 |
80 |
81 |
82 |
--------------------------------------------------------------------------------
/static/UE/dialogs/help/help.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Created with JetBrains PhpStorm.
3 | * User: xuheng
4 | * Date: 12-9-26
5 | * Time: 下午1:06
6 | * To change this template use File | Settings | File Templates.
7 | */
8 | /**
9 | * tab点击处理事件
10 | * @param tabHeads
11 | * @param tabBodys
12 | * @param obj
13 | */
14 | function clickHandler( tabHeads,tabBodys,obj ) {
15 | //head样式更改
16 | for ( var k = 0, len = tabHeads.length; k < len; k++ ) {
17 | tabHeads[k].className = "";
18 | }
19 | obj.className = "focus";
20 | //body显隐
21 | var tabSrc = obj.getAttribute( "tabSrc" );
22 | for ( var j = 0, length = tabBodys.length; j < length; j++ ) {
23 | var body = tabBodys[j],
24 | id = body.getAttribute( "id" );
25 | body.onclick = function(){
26 | this.style.zoom = 1;
27 | };
28 | if ( id != tabSrc ) {
29 | body.style.zIndex = 1;
30 | } else {
31 | body.style.zIndex = 200;
32 | }
33 | }
34 |
35 | }
36 |
37 | /**
38 | * TAB切换
39 | * @param tabParentId tab的父节点ID或者对象本身
40 | */
41 | function switchTab( tabParentId ) {
42 | var tabElements = $G( tabParentId ).children,
43 | tabHeads = tabElements[0].children,
44 | tabBodys = tabElements[1].children;
45 |
46 | for ( var i = 0, length = tabHeads.length; i < length; i++ ) {
47 | var head = tabHeads[i];
48 | if ( head.className === "focus" )clickHandler(tabHeads,tabBodys, head );
49 | head.onclick = function () {
50 | clickHandler(tabHeads,tabBodys,this);
51 | }
52 | }
53 | }
54 | switchTab("helptab");
55 |
56 | document.getElementById('version').innerHTML = parent.UE.version;
--------------------------------------------------------------------------------
/static/UE/dialogs/image/images/alignicon.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/image/images/alignicon.jpg
--------------------------------------------------------------------------------
/static/UE/dialogs/image/images/bg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/image/images/bg.png
--------------------------------------------------------------------------------
/static/UE/dialogs/image/images/icons.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/image/images/icons.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/image/images/icons.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/image/images/icons.png
--------------------------------------------------------------------------------
/static/UE/dialogs/image/images/image.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/image/images/image.png
--------------------------------------------------------------------------------
/static/UE/dialogs/image/images/progress.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/image/images/progress.png
--------------------------------------------------------------------------------
/static/UE/dialogs/image/images/success.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/image/images/success.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/image/images/success.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/image/images/success.png
--------------------------------------------------------------------------------
/static/UE/dialogs/internal.js:
--------------------------------------------------------------------------------
1 | (function () {
2 | var parent = window.parent;
3 | //dialog对象
4 | dialog = parent.$EDITORUI[window.frameElement.id.replace( /_iframe$/, '' )];
5 | //当前打开dialog的编辑器实例
6 | editor = dialog.editor;
7 |
8 | UE = parent.UE;
9 |
10 | domUtils = UE.dom.domUtils;
11 |
12 | utils = UE.utils;
13 |
14 | browser = UE.browser;
15 |
16 | ajax = UE.ajax;
17 |
18 | $G = function ( id ) {
19 | return document.getElementById( id )
20 | };
21 | //focus元素
22 | $focus = function ( node ) {
23 | setTimeout( function () {
24 | if ( browser.ie ) {
25 | var r = node.createTextRange();
26 | r.collapse( false );
27 | r.select();
28 | } else {
29 | node.focus()
30 | }
31 | }, 0 )
32 | };
33 | utils.loadFile(document,{
34 | href:editor.options.themePath + editor.options.theme + "/dialogbase.css?cache="+Math.random(),
35 | tag:"link",
36 | type:"text/css",
37 | rel:"stylesheet"
38 | });
39 | lang = editor.getLang(dialog.className.split( "-" )[2]);
40 | if(lang){
41 | domUtils.on(window,'load',function () {
42 |
43 | var langImgPath = editor.options.langPath + editor.options.lang + "/images/";
44 | //针对静态资源
45 | for ( var i in lang["static"] ) {
46 | var dom = $G( i );
47 | if(!dom) continue;
48 | var tagName = dom.tagName,
49 | content = lang["static"][i];
50 | if(content.src){
51 | //clone
52 | content = utils.extend({},content,false);
53 | content.src = langImgPath + content.src;
54 | }
55 | if(content.style){
56 | content = utils.extend({},content,false);
57 | content.style = content.style.replace(/url\s*\(/g,"url(" + langImgPath)
58 | }
59 | switch ( tagName.toLowerCase() ) {
60 | case "var":
61 | dom.parentNode.replaceChild( document.createTextNode( content ), dom );
62 | break;
63 | case "select":
64 | var ops = dom.options;
65 | for ( var j = 0, oj; oj = ops[j]; ) {
66 | oj.innerHTML = content.options[j++];
67 | }
68 | for ( var p in content ) {
69 | p != "options" && dom.setAttribute( p, content[p] );
70 | }
71 | break;
72 | default :
73 | domUtils.setAttributes( dom, content);
74 | }
75 | }
76 | } );
77 | }
78 |
79 |
80 | })();
81 |
82 |
--------------------------------------------------------------------------------
/static/UE/dialogs/music/music.css:
--------------------------------------------------------------------------------
1 | .wrapper{margin: 5px 10px;}
2 |
3 | .searchBar{height:30px;padding:7px 0 3px;text-align:center;}
4 | .searchBtn{font-size:13px;height:24px;}
5 |
6 | .resultBar{width:460px;margin:5px auto;border: 1px solid #CCC;border-radius: 5px;box-shadow: 2px 2px 5px #D3D6DA;overflow: hidden;}
7 |
8 | .listPanel{overflow: hidden;}
9 | .panelon{display:block;}
10 | .paneloff{display:none}
11 |
12 | .page{width:220px;margin:20px auto;overflow: hidden;}
13 | .pageon{float:right;width:24px;line-height:24px;height:24px;margin-right: 5px;background: none;border: none;color: #000;font-weight: bold;text-align:center}
14 | .pageoff{float:right;width:24px;line-height:24px;height:24px;cursor:pointer;background-color: #fff;
15 | border: 1px solid #E7ECF0;color: #2D64B3;margin-right: 5px;text-decoration: none;text-align:center;}
16 |
17 | .m-box{width:460px;}
18 | .m-m{float: left;line-height: 20px;height: 20px;}
19 | .m-h{height:24px;line-height:24px;padding-left: 46px;background-color:#FAFAFA;border-bottom: 1px solid #DAD8D8;font-weight: bold;font-size: 12px;color: #333;}
20 | .m-l{float:left;width:40px; }
21 | .m-t{float:left;width:140px;}
22 | .m-s{float:left;width:110px;}
23 | .m-z{float:left;width:100px;}
24 | .m-try-t{float: left;width: 60px;;}
25 |
26 | .m-try{float:left;width:20px;height:20px;background:url('http://static.tieba.baidu.com/tb/editor/images/try_music.gif') no-repeat ;}
27 | .m-trying{float:left;width:20px;height:20px;background:url('http://static.tieba.baidu.com/tb/editor/images/stop_music.gif') no-repeat ;}
28 |
29 | .loading{width:95px;height:7px;font-size:7px;margin:60px auto;background:url(http://static.tieba.baidu.com/tb/editor/images/loading.gif) no-repeat}
30 | .empty{width:300px;height:40px;padding:2px;margin:50px auto;line-height:40px; color:#006699;text-align:center;}
--------------------------------------------------------------------------------
/static/UE/dialogs/music/music.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | 插入音乐
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
19 |
20 |
21 |
22 |
31 |
32 |
--------------------------------------------------------------------------------
/static/UE/dialogs/preview/preview.html:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 |
6 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
40 |
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/addimg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/addimg.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/brush.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/brush.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/delimg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/delimg.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/delimgH.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/delimgH.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/empty.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/empty.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/emptyH.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/emptyH.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/eraser.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/eraser.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/redo.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/redo.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/redoH.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/redoH.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/scale.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/scale.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/scaleH.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/scaleH.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/size.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/size.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/undo.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/undo.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/images/undoH.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/scrawl/images/undoH.png
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/scrawl.css:
--------------------------------------------------------------------------------
1 | /*common
2 | */
3 | body{margin: 0;}
4 | table{width:100%;}
5 | table td{padding:2px 4px;vertical-align: middle;}
6 | a{text-decoration: none;}
7 | em{font-style: normal;}
8 | .border_style1{border: 1px solid #ccc;border-radius: 5px;box-shadow:2px 2px 5px #d3d6da;}
9 | /*module
10 | */
11 | .main{margin: 8px;overflow: hidden;}
12 |
13 | .hot{float:left;height:335px;}
14 | .drawBoard{position: relative; cursor: crosshair;}
15 | .brushBorad{position: absolute;left:0;top:0;z-index: 998;}
16 | .picBoard{border: none;text-align: center;line-height: 300px;cursor: default;}
17 | .operateBar{margin-top:10px;font-size:12px;text-align: center;}
18 | .operateBar span{margin-left: 10px;}
19 |
20 | .drawToolbar{float:right;width:110px;height:300px;overflow: hidden;}
21 | .colorBar{margin-top:10px;font-size: 12px;text-align: center;}
22 | .colorBar a{display:block;width: 10px;height: 10px;border:1px solid #1006F1;border-radius: 3px; box-shadow:2px 2px 5px #d3d6da;opacity: 0.3}
23 | .sectionBar{margin-top:15px;font-size: 12px;text-align: center;}
24 | .sectionBar a{display:inline-block;width:10px;height:12px;color: #888;text-indent: -999px;opacity: 0.3}
25 | .size1{background: url('images/size.png') 1px center no-repeat ;}
26 | .size2{background: url('images/size.png') -10px center no-repeat;}
27 | .size3{background: url('images/size.png') -22px center no-repeat;}
28 | .size4{background: url('images/size.png') -35px center no-repeat;}
29 |
30 | .addImgH{position: relative;}
31 | .addImgH_form{position: absolute;left: 18px;top: -1px;width: 75px;height: 21px;opacity: 0;cursor: pointer;}
32 | .addImgH_form input{width: 100%;}
33 | /*scrawl遮罩层
34 | */
35 | .maskLayerNull{display: none;}
36 | .maskLayer{position: absolute;top:0;left:0;width: 100%; height: 100%;opacity: 0.7;
37 | background-color: #fff;text-align:center;font-weight:bold;line-height:300px;z-index: 1000;}
38 | /*btn state
39 | */
40 | .previousStepH .icon{display: inline-block;width:16px;height:16px;background-image: url('images/undoH.png');cursor: pointer;}
41 | .previousStepH .text{color:#888;cursor:pointer;}
42 | .previousStep .icon{display: inline-block;width:16px;height:16px;background-image: url('images/undo.png');cursor:default;}
43 | .previousStep .text{color:#ccc;cursor:default;}
44 |
45 | .nextStepH .icon{display: inline-block;width:16px;height:16px;background-image: url('images/redoH.png');cursor: pointer;}
46 | .nextStepH .text{color:#888;cursor:pointer;}
47 | .nextStep .icon{display: inline-block;width:16px;height:16px;background-image: url('images/redo.png');cursor:default;}
48 | .nextStep .text{color:#ccc;cursor:default;}
49 |
50 | .clearBoardH .icon{display: inline-block;width:16px;height:16px;background-image: url('images/emptyH.png');cursor: pointer;}
51 | .clearBoardH .text{color:#888;cursor:pointer;}
52 | .clearBoard .icon{display: inline-block;width:16px;height:16px;background-image: url('images/empty.png');cursor:default;}
53 | .clearBoard .text{color:#ccc;cursor:default;}
54 |
55 | .scaleBoardH .icon{display: inline-block;width:16px;height:16px;background-image: url('images/scaleH.png');cursor: pointer;}
56 | .scaleBoardH .text{color:#888;cursor:pointer;}
57 | .scaleBoard .icon{display: inline-block;width:16px;height:16px;background-image: url('images/scale.png');cursor:default;}
58 | .scaleBoard .text{color:#ccc;cursor:default;}
59 |
60 | .removeImgH .icon{display: inline-block;width:16px;height:16px;background-image: url('images/delimgH.png');cursor: pointer;}
61 | .removeImgH .text{color:#888;cursor:pointer;}
62 | .removeImg .icon{display: inline-block;width:16px;height:16px;background-image: url('images/delimg.png');cursor:default;}
63 | .removeImg .text{color:#ccc;cursor:default;}
64 |
65 | .addImgH .icon{vertical-align:top;display: inline-block;width:16px;height:16px;background-image: url('images/addimg.png')}
66 | .addImgH .text{color:#888;cursor:pointer;}
67 | /*icon
68 | */
69 | .brushIcon{display: inline-block;width:16px;height:16px;background-image: url('images/brush.png')}
70 | .eraserIcon{display: inline-block;width:16px;height:16px;background-image: url('images/eraser.png')}
71 |
72 |
73 |
--------------------------------------------------------------------------------
/static/UE/dialogs/scrawl/scrawl.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 |
70 |
71 |
72 |
73 |
74 |
94 |
95 |
--------------------------------------------------------------------------------
/static/UE/dialogs/snapscreen/snapscreen.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
47 |
48 |
49 |
50 |
51 |
52 |
53 |
54 |
55 |
56 |
57 |
58 |
--------------------------------------------------------------------------------
/static/UE/dialogs/spechars/spechars.html:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 |
6 |
7 |
8 |
14 |
15 |
16 |
19 |
20 |
21 |
--------------------------------------------------------------------------------
/static/UE/dialogs/spechars/spechars.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Created with JetBrains PhpStorm.
3 | * User: xuheng
4 | * Date: 12-9-26
5 | * Time: 下午1:09
6 | * To change this template use File | Settings | File Templates.
7 | */
8 | var charsContent = [
9 | { name:"tsfh", title:lang.tsfh, content:toArray("、,。,·,ˉ,ˇ,¨,〃,々,—,~,‖,…,‘,’,“,”,〔,〕,〈,〉,《,》,「,」,『,』,〖,〗,【,】,±,×,÷,∶,∧,∨,∑,∏,∪,∩,∈,∷,√,⊥,∥,∠,⌒,⊙,∫,∮,≡,≌,≈,∽,∝,≠,≮,≯,≤,≥,∞,∵,∴,♂,♀,°,′,″,℃,$,¤,¢,£,‰,§,№,☆,★,○,●,◎,◇,◆,□,■,△,▲,※,→,←,↑,↓,〓,〡,〢,〣,〤,〥,〦,〧,〨,〩,㊣,㎎,㎏,㎜,㎝,㎞,㎡,㏄,㏎,㏑,㏒,㏕,︰,¬,¦,℡,ˊ,ˋ,˙,–,―,‥,‵,℅,℉,↖,↗,↘,↙,∕,∟,∣,≒,≦,≧,⊿,═,║,╒,╓,╔,╕,╖,╗,╘,╙,╚,╛,╜,╝,╞,╟,╠,╡,╢,╣,╤,╥,╦,╧,╨,╩,╪,╫,╬,╭,╮,╯,╰,╱,╲,╳,▁,▂,▃,▄,▅,▆,▇,�,█,▉,▊,▋,▌,▍,▎,▏,▓,▔,▕,▼,▽,◢,◣,◤,◥,☉,⊕,〒,〝,〞")},
10 | { name:"lmsz", title:lang.lmsz, content:toArray("ⅰ,ⅱ,ⅲ,ⅳ,ⅴ,ⅵ,ⅶ,ⅷ,ⅸ,ⅹ,Ⅰ,Ⅱ,Ⅲ,Ⅳ,Ⅴ,Ⅵ,Ⅶ,Ⅷ,Ⅸ,Ⅹ,Ⅺ,Ⅻ")},
11 | { name:"szfh", title:lang.szfh, content:toArray("⒈,⒉,⒊,⒋,⒌,⒍,⒎,⒏,⒐,⒑,⒒,⒓,⒔,⒕,⒖,⒗,⒘,⒙,⒚,⒛,⑴,⑵,⑶,⑷,⑸,⑹,⑺,⑻,⑼,⑽,⑾,⑿,⒀,⒁,⒂,⒃,⒄,⒅,⒆,⒇,①,②,③,④,⑤,⑥,⑦,⑧,⑨,⑩,㈠,㈡,㈢,㈣,㈤,㈥,㈦,㈧,㈨,㈩")},
12 | { name:"rwfh", title:lang.rwfh, content:toArray("ぁ,あ,ぃ,い,ぅ,う,ぇ,え,ぉ,お,か,が,き,ぎ,く,ぐ,け,げ,こ,ご,さ,ざ,し,じ,す,ず,せ,ぜ,そ,ぞ,た,だ,ち,ぢ,っ,つ,づ,て,で,と,ど,な,に,ぬ,ね,の,は,ば,ぱ,ひ,び,ぴ,ふ,ぶ,ぷ,へ,べ,ぺ,ほ,ぼ,ぽ,ま,み,む,め,も,ゃ,や,ゅ,ゆ,ょ,よ,ら,り,る,れ,ろ,ゎ,わ,ゐ,ゑ,を,ん,ァ,ア,ィ,イ,ゥ,ウ,ェ,エ,ォ,オ,カ,ガ,キ,ギ,ク,グ,ケ,ゲ,コ,ゴ,サ,ザ,シ,ジ,ス,ズ,セ,ゼ,ソ,ゾ,タ,ダ,チ,ヂ,ッ,ツ,ヅ,テ,デ,ト,ド,ナ,ニ,ヌ,ネ,ノ,ハ,バ,パ,ヒ,ビ,ピ,フ,ブ,プ,ヘ,ベ,ペ,ホ,ボ,ポ,マ,ミ,ム,メ,モ,ャ,ヤ,ュ,ユ,ョ,ヨ,ラ,リ,ル,レ,ロ,ヮ,ワ,ヰ,ヱ,ヲ,ン,ヴ,ヵ,ヶ")},
13 | { name:"xlzm", title:lang.xlzm, content:toArray("Α,Β,Γ,Δ,Ε,Ζ,Η,Θ,Ι,Κ,Λ,Μ,Ν,Ξ,Ο,Π,Ρ,Σ,Τ,Υ,Φ,Χ,Ψ,Ω,α,β,γ,δ,ε,ζ,η,θ,ι,κ,λ,μ,ν,ξ,ο,π,ρ,σ,τ,υ,φ,χ,ψ,ω")},
14 | { name:"ewzm", title:lang.ewzm, content:toArray("А,Б,В,Г,Д,Е,Ё,Ж,З,И,Й,К,Л,М,Н,О,П,Р,С,Т,У,Ф,Х,Ц,Ч,Ш,Щ,Ъ,Ы,Ь,Э,Ю,Я,а,б,в,г,д,е,ё,ж,з,и,й,к,л,м,н,о,п,р,с,т,у,ф,х,ц,ч,ш,щ,ъ,ы,ь,э,ю,я")},
15 | { name:"pyzm", title:lang.pyzm, content:toArray("ā,á,ǎ,à,ē,é,ě,è,ī,í,ǐ,ì,ō,ó,ǒ,ò,ū,ú,ǔ,ù,ǖ,ǘ,ǚ,ǜ,ü")},
16 | { name:"yyyb", title:lang.yyyb, content:toArray("i:,i,e,æ,ʌ,ə:,ə,u:,u,ɔ:,ɔ,a:,ei,ai,ɔi,əu,au,iə,εə,uə,p,t,k,b,d,g,f,s,ʃ,θ,h,v,z,ʒ,ð,tʃ,tr,ts,dʒ,dr,dz,m,n,ŋ,l,r,w,j,")},
17 | { name:"zyzf", title:lang.zyzf, content:toArray("ㄅ,ㄆ,ㄇ,ㄈ,ㄉ,ㄊ,ㄋ,ㄌ,ㄍ,ㄎ,ㄏ,ㄐ,ㄑ,ㄒ,ㄓ,ㄔ,ㄕ,ㄖ,ㄗ,ㄘ,ㄙ,ㄚ,ㄛ,ㄜ,ㄝ,ㄞ,ㄟ,ㄠ,ㄡ,ㄢ,ㄣ,ㄤ,ㄥ,ㄦ,ㄧ,ㄨ")}
18 | ];
19 | (function createTab(content) {
20 | for (var i = 0, ci; ci = content[i++];) {
21 | var span = document.createElement("span");
22 | span.setAttribute("tabSrc", ci.name);
23 | span.innerHTML = ci.title;
24 | if (i == 1)span.className = "focus";
25 | domUtils.on(span, "click", function () {
26 | var tmps = $G("tabHeads").children;
27 | for (var k = 0, sk; sk = tmps[k++];) {
28 | sk.className = "";
29 | }
30 | tmps = $G("tabBodys").children;
31 | for (var k = 0, sk; sk = tmps[k++];) {
32 | sk.style.display = "none";
33 | }
34 | this.className = "focus";
35 | $G(this.getAttribute("tabSrc")).style.display = "";
36 | });
37 | $G("tabHeads").appendChild(span);
38 | domUtils.insertAfter(span, document.createTextNode("\n"));
39 | var div = document.createElement("div");
40 | div.id = ci.name;
41 | div.style.display = (i == 1) ? "" : "none";
42 | var cons = ci.content;
43 | for (var j = 0, con; con = cons[j++];) {
44 | var charSpan = document.createElement("span");
45 | charSpan.innerHTML = con;
46 | domUtils.on(charSpan, "click", function () {
47 | editor.execCommand("insertHTML", this.innerHTML);
48 | dialog.close();
49 | });
50 | div.appendChild(charSpan);
51 | }
52 | $G("tabBodys").appendChild(div);
53 | }
54 | })(charsContent);
55 | function toArray(str) {
56 | return str.split(",");
57 | }
58 |
--------------------------------------------------------------------------------
/static/UE/dialogs/table/dragicon.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/table/dragicon.png
--------------------------------------------------------------------------------
/static/UE/dialogs/table/edittable.css:
--------------------------------------------------------------------------------
1 | body{
2 | overflow: hidden;
3 | width: 540px;
4 | }
5 | .wrapper {
6 | margin: 10px auto 0;
7 | font-size: 12px;
8 | overflow: hidden;
9 | width: 520px;
10 | height: 315px;
11 | }
12 |
13 | .clear {
14 | clear: both;
15 | }
16 |
17 | .wrapper .left {
18 | float: left;
19 | margin-left: 10px;;
20 | }
21 |
22 | .wrapper .right {
23 | float: right;
24 | border-left: 2px dotted #EDEDED;
25 | padding-left: 15px;
26 | }
27 |
28 | .section {
29 | margin-bottom: 15px;
30 | width: 240px;
31 | overflow: hidden;
32 | }
33 |
34 | .section h3 {
35 | font-weight: bold;
36 | padding: 5px 0;
37 | margin-bottom: 10px;
38 | border-bottom: 1px solid #EDEDED;
39 | font-size: 12px;
40 | }
41 |
42 | .section ul {
43 | list-style: none;
44 | overflow: hidden;
45 | clear: both;
46 |
47 | }
48 |
49 | .section li {
50 | float: left;
51 | width: 120px;;
52 | }
53 |
54 | .section .tone {
55 | width: 80px;;
56 | }
57 |
58 | .section .preview {
59 | width: 220px;
60 | }
61 |
62 | .section .preview table {
63 | text-align: center;
64 | vertical-align: middle;
65 | color: #666;
66 | }
67 |
68 | .section .preview caption {
69 | font-weight: bold;
70 | }
71 |
72 | .section .preview td {
73 | border-width: 1px;
74 | border-style: solid;
75 | height: 22px;
76 | }
77 |
78 | .section .preview th {
79 | border-style: solid;
80 | border-color: #DDD;
81 | border-width: 2px 1px 1px 1px;
82 | height: 22px;
83 | background-color: #F7F7F7;
84 | }
--------------------------------------------------------------------------------
/static/UE/dialogs/table/edittable.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
62 |
63 |
64 |
--------------------------------------------------------------------------------
/static/UE/dialogs/table/edittd.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
60 |
61 |
--------------------------------------------------------------------------------
/static/UE/dialogs/table/edittip.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | 表格删除提示
5 |
6 |
17 |
18 |
19 |
27 |
32 |
33 |
--------------------------------------------------------------------------------
/static/UE/dialogs/template/images/bg.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/template/images/bg.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/template/images/pre0.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/template/images/pre0.png
--------------------------------------------------------------------------------
/static/UE/dialogs/template/images/pre1.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/template/images/pre1.png
--------------------------------------------------------------------------------
/static/UE/dialogs/template/images/pre2.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/template/images/pre2.png
--------------------------------------------------------------------------------
/static/UE/dialogs/template/images/pre3.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/template/images/pre3.png
--------------------------------------------------------------------------------
/static/UE/dialogs/template/images/pre4.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/template/images/pre4.png
--------------------------------------------------------------------------------
/static/UE/dialogs/template/template.css:
--------------------------------------------------------------------------------
1 | .wrap{ padding: 5px;font-size: 14px;}
2 | .left{width:425px;float: left;}
3 | .right{width:160px;border: 1px solid #ccc;float: right;padding: 5px;margin-right: 5px;}
4 | .right .pre{height: 332px;overflow-y: auto;}
5 | .right .preitem{border: white 1px solid;margin: 5px 0;padding: 2px 0;}
6 | .right .preitem:hover{background-color: lemonChiffon;cursor: pointer;border: #ccc 1px solid;}
7 | .right .preitem img{display: block;margin: 0 auto;width:100px;}
8 | .clear{clear: both;}
9 | .top{height:26px;line-height: 26px;padding: 5px;}
10 | .bottom{height:320px;width:100%;margin: 0 auto;}
11 | .transparent{ background: url("images/bg.gif") repeat;}
12 | .bottom table tr td{border:1px dashed #ccc;}
13 | #colorPicker{width: 17px;height: 17px;border: 1px solid #CCC;display: inline-block;border-radius: 3px;box-shadow: 2px 2px 5px #D3D6DA;}
14 | .border_style1{padding:2px;border: 1px solid #ccc;border-radius: 5px;box-shadow:2px 2px 5px #d3d6da;}
15 | p{margin: 5px 0}
16 | table{clear:both;margin-bottom:10px;border-collapse:collapse;word-break:break-all;}
17 | li{clear:both}
18 | ol{padding-left:40px; }
--------------------------------------------------------------------------------
/static/UE/dialogs/template/template.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
--------------------------------------------------------------------------------
/static/UE/dialogs/template/template.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Created with JetBrains PhpStorm.
3 | * User: xuheng
4 | * Date: 12-8-8
5 | * Time: 下午2:09
6 | * To change this template use File | Settings | File Templates.
7 | */
8 | (function () {
9 | var me = editor,
10 | preview = $G( "preview" ),
11 | preitem = $G( "preitem" ),
12 | tmps = templates,
13 | currentTmp;
14 | var initPre = function () {
15 | var str = "";
16 | for ( var i = 0, tmp; tmp = tmps[i++]; ) {
17 | str += '
';
18 | }
19 | preitem.innerHTML = str;
20 | };
21 | var pre = function ( n ) {
22 | var tmp = tmps[n - 1];
23 | currentTmp = tmp;
24 | clearItem();
25 | domUtils.setStyles( preitem.childNodes[n - 1], {
26 | "background-color":"lemonChiffon",
27 | "border":"#ccc 1px solid"
28 | } );
29 | preview.innerHTML = tmp.preHtml ? tmp.preHtml : "";
30 | };
31 | var clearItem = function () {
32 | var items = preitem.children;
33 | for ( var i = 0, item; item = items[i++]; ) {
34 | domUtils.setStyles( item, {
35 | "background-color":"",
36 | "border":"white 1px solid"
37 | } );
38 | }
39 | };
40 | dialog.onok = function () {
41 | if ( !$G( "issave" ).checked ){
42 | me.execCommand( "cleardoc" );
43 | }
44 | var obj = {
45 | html:currentTmp && currentTmp.html
46 | };
47 | me.execCommand( "template", obj );
48 | };
49 | initPre();
50 | window.pre = pre;
51 | pre(2)
52 |
53 | })();
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/bg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/bg.png
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/center_focus.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/center_focus.jpg
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/file-icons.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/file-icons.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/file-icons.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/file-icons.png
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/icons.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/icons.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/icons.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/icons.png
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/image.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/image.png
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/left_focus.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/left_focus.jpg
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/none_focus.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/none_focus.jpg
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/progress.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/progress.png
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/right_focus.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/right_focus.jpg
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/success.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/success.gif
--------------------------------------------------------------------------------
/static/UE/dialogs/video/images/success.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/video/images/success.png
--------------------------------------------------------------------------------
/static/UE/dialogs/webapp/webapp.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
12 |
13 |
14 |
17 |
52 |
53 |
--------------------------------------------------------------------------------
/static/UE/dialogs/wordimage/fClipboard_ueditor.swf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/wordimage/fClipboard_ueditor.swf
--------------------------------------------------------------------------------
/static/UE/dialogs/wordimage/imageUploader.swf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/dialogs/wordimage/imageUploader.swf
--------------------------------------------------------------------------------
/static/UE/lang/zh-cn/images/copy.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/lang/zh-cn/images/copy.png
--------------------------------------------------------------------------------
/static/UE/lang/zh-cn/images/localimage.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/lang/zh-cn/images/localimage.png
--------------------------------------------------------------------------------
/static/UE/lang/zh-cn/images/music.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/lang/zh-cn/images/music.png
--------------------------------------------------------------------------------
/static/UE/lang/zh-cn/images/upload.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/lang/zh-cn/images/upload.png
--------------------------------------------------------------------------------
/static/UE/themes/default/dialogbase.css:
--------------------------------------------------------------------------------
1 | /*弹出对话框页面样式组件
2 | */
3 |
4 | /*reset
5 | */
6 | html, body, div, span, applet, object, iframe,
7 | h1, h2, h3, h4, h5, h6, p, blockquote, pre,
8 | a, abbr, acronym, address, big, cite, code,
9 | del, dfn, em, font, img, ins, kbd, q, s, samp,
10 | small, strike, strong, sub, sup, tt, var,
11 | b, u, i, center,
12 | dl, dt, dd, ol, ul, li,
13 | fieldset, form, label, legend,
14 | table, caption, tbody, tfoot, thead, tr, th, td {
15 | margin: 0;
16 | padding: 0;
17 | outline: 0;
18 | font-size: 100%;
19 | }
20 |
21 | body {
22 | line-height: 1;
23 | }
24 |
25 | ol, ul {
26 | list-style: none;
27 | }
28 |
29 | blockquote, q {
30 | quotes: none;
31 | }
32 |
33 | ins {
34 | text-decoration: none;
35 | }
36 |
37 | del {
38 | text-decoration: line-through;
39 | }
40 |
41 | table {
42 | border-collapse: collapse;
43 | border-spacing: 0;
44 | }
45 |
46 | /*module
47 | */
48 | body {
49 | background-color: #fff;
50 | font: 12px/1.5 sans-serif, "宋体", "Arial Narrow", HELVETICA;
51 | color: #646464;
52 | }
53 |
54 | /*tab*/
55 | .tabhead {
56 | position: relative;
57 | z-index: 10;
58 | }
59 |
60 | .tabhead span {
61 | display: inline-block;
62 | padding: 0 5px;
63 | height: 30px;
64 | border: 1px solid #ccc;
65 | background: url("images/dialog-title-bg.png") repeat-x;
66 | text-align: center;
67 | line-height: 30px;
68 | cursor: pointer;
69 | *margin-right: 5px;
70 | }
71 |
72 | .tabhead span.focus {
73 | height: 31px;
74 | border-bottom: none;
75 | background: #fff;
76 | }
77 |
78 | .tabbody {
79 | position: relative;
80 | top: -1px;
81 | margin: 0 auto;
82 | border: 1px solid #ccc;
83 | }
84 |
85 | /*button*/
86 | a.button {
87 | display: block;
88 | text-align: center;
89 | line-height: 24px;
90 | text-decoration: none;
91 | height: 24px;
92 | width: 95px;
93 | border: 0;
94 | color: #838383;
95 | background: url(../../themes/default/images/icons-all.gif) no-repeat;
96 | }
97 |
98 | a.button:hover {
99 | background-position: 0 -30px;
100 | }
--------------------------------------------------------------------------------
/static/UE/themes/default/images/anchor.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/anchor.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/arrow.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/arrow.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/arrow_down.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/arrow_down.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/arrow_up.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/arrow_up.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/button-bg.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/button-bg.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/cancelbutton.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/cancelbutton.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/charts.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/charts.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/cursor_h.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/cursor_h.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/cursor_h.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/cursor_h.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/cursor_v.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/cursor_v.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/cursor_v.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/cursor_v.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/dialog-title-bg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/dialog-title-bg.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/filescan.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/filescan.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/highlighted.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/highlighted.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/icons-all.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/icons-all.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/icons.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/icons.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/icons.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/icons.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/loaderror.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/loaderror.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/loading.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/loading.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/lock.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/lock.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/neweditor-tab-bg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/neweditor-tab-bg.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/pagebreak.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/pagebreak.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/scale.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/scale.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/sortable.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/sortable.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/spacer.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/spacer.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/sparator_v.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/sparator_v.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/table-cell-align.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/table-cell-align.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/tangram-colorpicker.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/tangram-colorpicker.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/toolbar_bg.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/toolbar_bg.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/unhighlighted.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/unhighlighted.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/upload.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/upload.png
--------------------------------------------------------------------------------
/static/UE/themes/default/images/videologo.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/videologo.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/word.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/word.gif
--------------------------------------------------------------------------------
/static/UE/themes/default/images/wordpaste.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/themes/default/images/wordpaste.png
--------------------------------------------------------------------------------
/static/UE/themes/iframe.css:
--------------------------------------------------------------------------------
1 | /*可以在这里添加你自己的css*/
2 |
--------------------------------------------------------------------------------
/static/UE/third-party/codemirror/codemirror.css:
--------------------------------------------------------------------------------
1 | .CodeMirror {
2 | line-height: 1em;
3 | font-family: monospace;
4 | }
5 |
6 | .CodeMirror-scroll {
7 | overflow: auto;
8 | height: 300px;
9 | /* This is needed to prevent an IE[67] bug where the scrolled content
10 | is visible outside of the scrolling box. */
11 | position: relative;
12 | }
13 |
14 | .CodeMirror-gutter {
15 | position: absolute; left: 0; top: 0;
16 | z-index: 10;
17 | background-color: #f7f7f7;
18 | border-right: 1px solid #eee;
19 | min-width: 2em;
20 | height: 100%;
21 | }
22 | .CodeMirror-gutter-text {
23 | color: #aaa;
24 | text-align: right;
25 | padding: .4em .2em .4em .4em;
26 | white-space: pre !important;
27 | }
28 | .CodeMirror-lines {
29 | padding: .4em;
30 | }
31 |
32 | .CodeMirror pre {
33 | -moz-border-radius: 0;
34 | -webkit-border-radius: 0;
35 | -o-border-radius: 0;
36 | border-radius: 0;
37 | border-width: 0; margin: 0; padding: 0; background: transparent;
38 | font-family: inherit;
39 | font-size: inherit;
40 | padding: 0; margin: 0;
41 | white-space: pre;
42 | word-wrap: normal;
43 | }
44 |
45 | .CodeMirror-wrap pre {
46 | word-wrap: break-word;
47 | white-space: pre-wrap;
48 | }
49 | .CodeMirror-wrap .CodeMirror-scroll {
50 | overflow-x: hidden;
51 | }
52 |
53 | .CodeMirror textarea {
54 | outline: none !important;
55 | }
56 |
57 | .CodeMirror pre.CodeMirror-cursor {
58 | z-index: 10;
59 | position: absolute;
60 | visibility: hidden;
61 | border-left: 1px solid black;
62 | }
63 | .CodeMirror-focused pre.CodeMirror-cursor {
64 | visibility: visible;
65 | }
66 |
67 | span.CodeMirror-selected { background: #d9d9d9; }
68 | .CodeMirror-focused span.CodeMirror-selected { background: #d2dcf8; }
69 |
70 | .CodeMirror-searching {background: #ffa;}
71 |
72 | /* Default theme */
73 |
74 | .cm-s-default span.cm-keyword {color: #708;}
75 | .cm-s-default span.cm-atom {color: #219;}
76 | .cm-s-default span.cm-number {color: #164;}
77 | .cm-s-default span.cm-def {color: #00f;}
78 | .cm-s-default span.cm-variable {color: black;}
79 | .cm-s-default span.cm-variable-2 {color: #05a;}
80 | .cm-s-default span.cm-variable-3 {color: #085;}
81 | .cm-s-default span.cm-property {color: black;}
82 | .cm-s-default span.cm-operator {color: black;}
83 | .cm-s-default span.cm-comment {color: #a50;}
84 | .cm-s-default span.cm-string {color: #a11;}
85 | .cm-s-default span.cm-string-2 {color: #f50;}
86 | .cm-s-default span.cm-meta {color: #555;}
87 | .cm-s-default span.cm-error {color: #f00;}
88 | .cm-s-default span.cm-qualifier {color: #555;}
89 | .cm-s-default span.cm-builtin {color: #30a;}
90 | .cm-s-default span.cm-bracket {color: #cc7;}
91 | .cm-s-default span.cm-tag {color: #170;}
92 | .cm-s-default span.cm-attribute {color: #00c;}
93 | .cm-s-default span.cm-header {color: #a0a;}
94 | .cm-s-default span.cm-quote {color: #090;}
95 | .cm-s-default span.cm-hr {color: #999;}
96 | .cm-s-default span.cm-link {color: #00c;}
97 |
98 | span.cm-header, span.cm-strong {font-weight: bold;}
99 | span.cm-em {font-style: italic;}
100 | span.cm-emstrong {font-style: italic; font-weight: bold;}
101 | span.cm-link {text-decoration: underline;}
102 |
103 | div.CodeMirror span.CodeMirror-matchingbracket {color: #0f0;}
104 | div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #f22;}
105 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/adapters/mootools-adapter.js:
--------------------------------------------------------------------------------
1 | /*
2 | Highcharts JS v3.0.6 (2013-10-04)
3 | MooTools adapter
4 |
5 | (c) 2010-2013 Torstein Hønsi
6 |
7 | License: www.highcharts.com/license
8 | */
9 | (function(){var e=window,h=document,f=e.MooTools.version.substring(0,3),i=f==="1.2"||f==="1.1",j=i||f==="1.3",g=e.$extend||function(){return Object.append.apply(Object,arguments)};e.HighchartsAdapter={init:function(a){var b=Fx.prototype,c=b.start,d=Fx.Morph.prototype,e=d.compute;b.start=function(b,d){var e=this.element;if(b.d)this.paths=a.init(e,e.d,this.toD);c.apply(this,arguments);return this};d.compute=function(b,c,d){var f=this.paths;if(f)this.element.attr("d",a.step(f[0],f[1],d,this.toD));else return e.apply(this,
10 | arguments)}},adapterRun:function(a,b){if(b==="width"||b==="height")return parseInt($(a).getStyle(b),10)},getScript:function(a,b){var c=h.getElementsByTagName("head")[0],d=h.createElement("script");d.type="text/javascript";d.src=a;d.onload=b;c.appendChild(d)},animate:function(a,b,c){var d=a.attr,f=c&&c.complete;if(d&&!a.setStyle)a.getStyle=a.attr,a.setStyle=function(){var a=arguments;this.attr.call(this,a[0],a[1][0])},a.$family=function(){return!0};e.HighchartsAdapter.stop(a);c=new Fx.Morph(d?a:$(a),
11 | g({transition:Fx.Transitions.Quad.easeInOut},c));if(d)c.element=a;if(b.d)c.toD=b.d;f&&c.addEvent("complete",f);c.start(b);a.fx=c},each:function(a,b){return i?$each(a,b):Array.each(a,b)},map:function(a,b){return a.map(b)},grep:function(a,b){return a.filter(b)},inArray:function(a,b,c){return b?b.indexOf(a,c):-1},offset:function(a){a=a.getPosition();return{left:a.x,top:a.y}},extendWithEvents:function(a){a.addEvent||(a.nodeName?$(a):g(a,new Events))},addEvent:function(a,b,c){typeof b==="string"&&(b===
12 | "unload"&&(b="beforeunload"),e.HighchartsAdapter.extendWithEvents(a),a.addEvent(b,c))},removeEvent:function(a,b,c){typeof a!=="string"&&a.addEvent&&(b?(b==="unload"&&(b="beforeunload"),c?a.removeEvent(b,c):a.removeEvents&&a.removeEvents(b)):a.removeEvents())},fireEvent:function(a,b,c,d){b={type:b,target:a};b=j?new Event(b):new DOMEvent(b);b=g(b,c);if(!b.target&&b.event)b.target=b.event.target;b.preventDefault=function(){d=null};a.fireEvent&&a.fireEvent(b.type,b);d&&d(b)},washMouseEvent:function(a){if(a.page)a.pageX=
13 | a.page.x,a.pageY=a.page.y;return a},stop:function(a){a.fx&&a.fx.cancel()}}})();
14 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/adapters/prototype-adapter.js:
--------------------------------------------------------------------------------
1 | /*
2 | Highcharts JS v3.0.6 (2013-10-04)
3 | Prototype adapter
4 |
5 | @author Michael Nelson, Torstein Hønsi.
6 |
7 | Feel free to use and modify this script.
8 | Highcharts license: www.highcharts.com/license.
9 | */
10 | var HighchartsAdapter=function(){var f=typeof Effect!=="undefined";return{init:function(a){if(f)Effect.HighchartsTransition=Class.create(Effect.Base,{initialize:function(b,c,d,g){var e;this.element=b;this.key=c;e=b.attr?b.attr(c):$(b).getStyle(c);if(c==="d")this.paths=a.init(b,b.d,d),this.toD=d,e=0,d=1;this.start(Object.extend(g||{},{from:e,to:d,attribute:c}))},setup:function(){HighchartsAdapter._extend(this.element);if(!this.element._highchart_animation)this.element._highchart_animation={};this.element._highchart_animation[this.key]=
11 | this},update:function(b){var c=this.paths,d=this.element;c&&(b=a.step(c[0],c[1],b,this.toD));d.attr?d.element&&d.attr(this.options.attribute,b):(c={},c[this.options.attribute]=b,$(d).setStyle(c))},finish:function(){this.element&&this.element._highchart_animation&&delete this.element._highchart_animation[this.key]}})},adapterRun:function(a,b){return parseInt($(a).getStyle(b),10)},getScript:function(a,b){var c=$$("head")[0];c&&c.appendChild((new Element("script",{type:"text/javascript",src:a})).observe("load",
12 | b))},addNS:function(a){var b=/^(?:click|mouse(?:down|up|over|move|out))$/;return/^(?:load|unload|abort|error|select|change|submit|reset|focus|blur|resize|scroll)$/.test(a)||b.test(a)?a:"h:"+a},addEvent:function(a,b,c){a.addEventListener||a.attachEvent?Event.observe($(a),HighchartsAdapter.addNS(b),c):(HighchartsAdapter._extend(a),a._highcharts_observe(b,c))},animate:function(a,b,c){var d,c=c||{};c.delay=0;c.duration=(c.duration||500)/1E3;c.afterFinish=c.complete;if(f)for(d in b)new Effect.HighchartsTransition($(a),
13 | d,b[d],c);else{if(a.attr)for(d in b)a.attr(d,b[d]);c.complete&&c.complete()}a.attr||$(a).setStyle(b)},stop:function(a){var b;if(a._highcharts_extended&&a._highchart_animation)for(b in a._highchart_animation)a._highchart_animation[b].cancel()},each:function(a,b){$A(a).each(b)},inArray:function(a,b,c){return b?b.indexOf(a,c):-1},offset:function(a){return $(a).cumulativeOffset()},fireEvent:function(a,b,c,d){a.fire?a.fire(HighchartsAdapter.addNS(b),c):a._highcharts_extended&&(c=c||{},a._highcharts_fire(b,
14 | c));c&&c.defaultPrevented&&(d=null);d&&d(c)},removeEvent:function(a,b,c){$(a).stopObserving&&(b&&(b=HighchartsAdapter.addNS(b)),$(a).stopObserving(b,c));window===a?Event.stopObserving(a,b,c):(HighchartsAdapter._extend(a),a._highcharts_stop_observing(b,c))},washMouseEvent:function(a){return a},grep:function(a,b){return a.findAll(b)},map:function(a,b){return a.map(b)},_extend:function(a){a._highcharts_extended||Object.extend(a,{_highchart_events:{},_highchart_animation:null,_highcharts_extended:!0,
15 | _highcharts_observe:function(b,a){this._highchart_events[b]=[this._highchart_events[b],a].compact().flatten()},_highcharts_stop_observing:function(b,a){b?a?this._highchart_events[b]=[this._highchart_events[b]].compact().flatten().without(a):delete this._highchart_events[b]:this._highchart_events={}},_highcharts_fire:function(a,c){var d=this;(this._highchart_events[a]||[]).each(function(a){if(!c.stopped)c.preventDefault=function(){c.defaultPrevented=!0},c.target=d,a.bind(this)(c)===!1&&c.preventDefault()}.bind(this))}})}}}();
16 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/modules/annotations.js:
--------------------------------------------------------------------------------
1 | (function(i,C){function m(a){return typeof a==="number"}function n(a){return a!==D&&a!==null}var D,p,r,s=i.Chart,t=i.extend,z=i.each;r=["path","rect","circle"];p={top:0,left:0,center:0.5,middle:0.5,bottom:1,right:1};var u=C.inArray,A=i.merge,B=function(){this.init.apply(this,arguments)};B.prototype={init:function(a,d){var c=d.shape&&d.shape.type;this.chart=a;var b,f;f={xAxis:0,yAxis:0,title:{style:{},text:"",x:0,y:0},shape:{params:{stroke:"#000000",fill:"transparent",strokeWidth:2}}};b={circle:{params:{x:0,
2 | y:0}}};if(b[c])f.shape=A(f.shape,b[c]);this.options=A({},f,d)},render:function(a){var d=this.chart,c=this.chart.renderer,b=this.group,f=this.title,e=this.shape,h=this.options,i=h.title,l=h.shape;if(!b)b=this.group=c.g();if(!e&&l&&u(l.type,r)!==-1)e=this.shape=c[h.shape.type](l.params),e.add(b);if(!f&&i)f=this.title=c.label(i),f.add(b);b.add(d.annotations.group);this.linkObjects();a!==!1&&this.redraw()},redraw:function(){var a=this.options,d=this.chart,c=this.group,b=this.title,f=this.shape,e=this.linkedObject,
3 | h=d.xAxis[a.xAxis],v=d.yAxis[a.yAxis],l=a.width,w=a.height,x=p[a.anchorY],y=p[a.anchorX],j,o,g,q;if(e)j=e instanceof i.Point?"point":e instanceof i.Series?"series":null,j==="point"?(a.xValue=e.x,a.yValue=e.y,o=e.series):j==="series"&&(o=e),c.visibility!==o.group.visibility&&c.attr({visibility:o.group.visibility});e=n(a.xValue)?h.toPixels(a.xValue+h.minPointOffset)-h.minPixelPadding:a.x;j=n(a.yValue)?v.toPixels(a.yValue):a.y;if(!isNaN(e)&&!isNaN(j)&&m(e)&&m(j)){b&&(b.attr(a.title),b.css(a.title.style));
4 | if(f){b=t({},a.shape.params);if(a.units==="values"){for(g in b)u(g,["width","x"])>-1?b[g]=h.translate(b[g]):u(g,["height","y"])>-1&&(b[g]=v.translate(b[g]));b.width&&(b.width-=h.toPixels(0)-h.left);b.x&&(b.x+=h.minPixelPadding);if(a.shape.type==="path"){g=b.d;o=e;for(var r=j,s=g.length,k=0;k-1&&d.splice(c,1);z(["title","shape","group"],function(b){a[b]&&(a[b].destroy(),a[b]=null)});a.group=a.title=a.shape=a.chart=a.options=null},update:function(a,d){t(this.options,a);this.linkObjects();this.render(d)},
6 | linkObjects:function(){var a=this.chart,d=this.linkedObject,c=d&&(d.id||d.options.id),b=this.options.linkedTo;if(n(b)){if(!n(d)||b!==c)this.linkedObject=a.get(b)}else this.linkedObject=null}};t(s.prototype,{annotations:{add:function(a,d){var c=this.allItems,b=this.chart,f,e;Object.prototype.toString.call(a)==="[object Array]"||(a=[a]);for(e=a.length;e--;)f=new B(b,a[e]),c.push(f),f.render(d)},redraw:function(){z(this.allItems,function(a){a.redraw()})}}});s.prototype.callbacks.push(function(a){var d=
7 | a.options.annotations,c;c=a.renderer.g("annotations");c.attr({zIndex:7});c.add();a.annotations.allItems=[];a.annotations.chart=a;a.annotations.group=c;Object.prototype.toString.call(d)==="[object Array]"&&d.length>0&&a.annotations.add(a.options.annotations);i.addEvent(a,"redraw",function(){a.annotations.redraw()})})})(Highcharts,HighchartsAdapter);
8 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/modules/data.js:
--------------------------------------------------------------------------------
1 | /*
2 | Data plugin for Highcharts
3 |
4 | (c) 2012-2013 Torstein Hønsi
5 | Last revision 2013-06-07
6 |
7 | License: www.highcharts.com/license
8 | */
9 | (function(h){var k=h.each,m=function(b,a){this.init(b,a)};h.extend(m.prototype,{init:function(b,a){this.options=b;this.chartOptions=a;this.columns=b.columns||this.rowsToColumns(b.rows)||[];this.columns.length?this.dataFound():(this.parseCSV(),this.parseTable(),this.parseGoogleSpreadsheet())},getColumnDistribution:function(){var b=this.chartOptions,a=b&&b.chart&&b.chart.type,c=[];k(b&&b.series||[],function(b){c.push((h.seriesTypes[b.type||a||"line"].prototype.pointArrayMap||[0]).length)});this.valueCount=
10 | {global:(h.seriesTypes[a||"line"].prototype.pointArrayMap||[0]).length,individual:c}},dataFound:function(){this.parseTypes();this.findHeaderRow();this.parsed();this.complete()},parseCSV:function(){var b=this,a=this.options,c=a.csv,d=this.columns,f=a.startRow||0,i=a.endRow||Number.MAX_VALUE,j=a.startColumn||0,e=a.endColumn||Number.MAX_VALUE,g=0;c&&(c=c.replace(/\r\n/g,"\n").replace(/\r/g,"\n").split(a.lineDelimiter||"\n"),k(c,function(c,h){var n=b.trim(c),p=n.indexOf("#")===0;h>=f&&h<=i&&!p&&n!==""&&
11 | (n=c.split(a.itemDelimiter||","),k(n,function(b,a){a>=j&&a<=e&&(d[a-j]||(d[a-j]=[]),d[a-j][g]=b)}),g+=1)}),this.dataFound())},parseTable:function(){var b=this.options,a=b.table,c=this.columns,d=b.startRow||0,f=b.endRow||Number.MAX_VALUE,i=b.startColumn||0,j=b.endColumn||Number.MAX_VALUE,e;a&&(typeof a==="string"&&(a=document.getElementById(a)),k(a.getElementsByTagName("tr"),function(a,b){e=0;b>=d&&b<=f&&k(a.childNodes,function(a){if((a.tagName==="TD"||a.tagName==="TH")&&e>=i&&e<=j)c[e]||(c[e]=[]),
12 | c[e][b-d]=a.innerHTML,e+=1})}),this.dataFound())},parseGoogleSpreadsheet:function(){var b=this,a=this.options,c=a.googleSpreadsheetKey,d=this.columns,f=a.startRow||0,i=a.endRow||Number.MAX_VALUE,j=a.startColumn||0,e=a.endColumn||Number.MAX_VALUE,g,h;c&&jQuery.getJSON("https://spreadsheets.google.com/feeds/cells/"+c+"/"+(a.googleSpreadsheetWorksheet||"od6")+"/public/values?alt=json-in-script&callback=?",function(a){var a=a.feed.entry,c,k=a.length,m=0,o=0,l;for(l=0;l=j&&l<=e)d[l-j]=[],d[l-j].length=Math.min(o,i-f);for(l=0;l=j&&h<=e&&g>=f&&g<=i)d[h-j][g-f]=c.content.$t;b.dataFound()})},findHeaderRow:function(){k(this.columns,function(){});this.headerRow=0},trim:function(b){return typeof b==="string"?b.replace(/^\s+|\s+$/g,""):b},parseTypes:function(){for(var b=this.columns,a=b.length,c,d,f,i;a--;)for(c=b[a].length;c--;)d=b[a][c],f=parseFloat(d),i=this.trim(d),
14 | i==f?(b[a][c]=f,f>31536E6?b[a].isDatetime=!0:b[a].isNumeric=!0):(d=this.parseDate(d),a===0&&typeof d==="number"&&!isNaN(d)?(b[a][c]=d,b[a].isDatetime=!0):b[a][c]=i===""?null:i)},dateFormats:{"YYYY-mm-dd":{regex:"^([0-9]{4})-([0-9]{2})-([0-9]{2})$",parser:function(b){return Date.UTC(+b[1],b[2]-1,+b[3])}}},parseDate:function(b){var a=this.options.parseDate,c,d,f;a&&(c=a(b));if(typeof b==="string")for(d in this.dateFormats)a=this.dateFormats[d],(f=b.match(a.regex))&&(c=a.parser(f));return c},rowsToColumns:function(b){var a,
15 | c,d,f,i;if(b){i=[];c=b.length;for(a=0;a1&&(a=b.shift(),this.headerRow===0&&a.shift(),a.isDatetime?c="datetime":a.isNumeric||(c="category"));for(e=0;e1&&j[g].push(b[e+1][g]!==void 0?b[e+1][g]:null),f>2&&j[g].push(b[e+2][g]!==void 0?b[e+2][g]:null),f>3&&j[g].push(b[e+3][g]!==void 0?b[e+3][g]:null),f>4&&j[g].push(b[e+4][g]!==void 0?b[e+4][g]:null);i[k]={name:b[e].name,data:j};e+=f}d.complete({xAxis:{type:c},series:i})}}});h.Data=m;h.data=function(b,a){return new m(b,a)};h.wrap(h.Chart.prototype,
17 | "init",function(b,a,c){var d=this;a&&a.data?h.data(h.extend(a.data,{complete:function(f){a.series&&k(a.series,function(b,c){a.series[c]=h.merge(b,f.series[c])});a=h.merge(f,a);b.call(d,a,c)}}),a):b.call(d,a,c)})})(Highcharts);
18 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/modules/funnel.js:
--------------------------------------------------------------------------------
1 | /*
2 |
3 | Highcharts funnel module, Beta
4 |
5 | (c) 2010-2012 Torstein Hønsi
6 |
7 | License: www.highcharts.com/license
8 | */
9 | (function(d){var u=d.getOptions().plotOptions,p=d.seriesTypes,D=d.merge,z=function(){},A=d.each;u.funnel=D(u.pie,{center:["50%","50%"],width:"90%",neckWidth:"30%",height:"100%",neckHeight:"25%",dataLabels:{connectorWidth:1,connectorColor:"#606060"},size:!0,states:{select:{color:"#C0C0C0",borderColor:"#000000",shadow:!1}}});p.funnel=d.extendClass(p.pie,{type:"funnel",animate:z,translate:function(){var a=function(k,a){return/%$/.test(k)?a*parseInt(k,10)/100:parseInt(k,10)},g=0,e=this.chart,f=e.plotWidth,
10 | e=e.plotHeight,h=0,c=this.options,C=c.center,b=a(C[0],f),d=a(C[0],e),p=a(c.width,f),i,q,j=a(c.height,e),r=a(c.neckWidth,f),s=a(c.neckHeight,e),v=j-s,a=this.data,w,x,u=c.dataLabels.position==="left"?1:0,y,m,B,n,l,t,o;this.getWidthAt=q=function(k){return k>j-s||j===s?r:r+(p-r)*((j-s-k)/(j-s))};this.getX=function(k,a){return b+(a?-1:1)*(q(k)/2+c.dataLabels.distance)};this.center=[b,d,j];this.centerX=b;A(a,function(a){g+=a.y});A(a,function(a){o=null;x=g?a.y/g:0;m=d-j/2+h*j;l=m+x*j;i=q(m);y=b-i/2;B=y+
11 | i;i=q(l);n=b-i/2;t=n+i;m>v?(y=n=b-r/2,B=t=b+r/2):l>v&&(o=l,i=q(v),n=b-i/2,t=n+i,l=v);w=["M",y,m,"L",B,m,t,l];o&&w.push(t,o,n,o);w.push(n,l,"Z");a.shapeType="path";a.shapeArgs={d:w};a.percentage=x*100;a.plotX=b;a.plotY=(m+(o||l))/2;a.tooltipPos=[b,a.plotY];a.slice=z;a.half=u;h+=x});this.setTooltipPoints()},drawPoints:function(){var a=this,g=a.options,e=a.chart.renderer;A(a.data,function(f){var h=f.graphic,c=f.shapeArgs;h?h.animate(c):f.graphic=e.path(c).attr({fill:f.color,stroke:g.borderColor,"stroke-width":g.borderWidth}).add(a.group)})},
12 | sortByAngle:z,drawDataLabels:function(){var a=this.data,g=this.options.dataLabels.distance,e,f,h,c=a.length,d,b;for(this.center[2]-=2*g;c--;)h=a[c],f=(e=h.half)?1:-1,b=h.plotY,d=this.getX(b,e),h.labelPos=[0,b,d+(g-5)*f,b,d+g*f,b,e?"right":"left",0];p.pie.prototype.drawDataLabels.call(this)}})})(Highcharts);
13 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/modules/heatmap.js:
--------------------------------------------------------------------------------
1 | (function(b){var k=b.seriesTypes,l=b.each;k.heatmap=b.extendClass(k.map,{colorKey:"z",useMapGeometry:!1,pointArrayMap:["y","z"],translate:function(){var c=this,b=c.options,i=Number.MAX_VALUE,j=Number.MIN_VALUE;c.generatePoints();l(c.data,function(a){var e=a.x,f=a.y,d=a.z,g=(b.colsize||1)/2,h=(b.rowsize||1)/2;a.path=["M",e-g,f-h,"L",e+g,f-h,"L",e+g,f+h,"L",e-g,f+h,"Z"];a.shapeType="path";a.shapeArgs={d:c.translatePath(a.path)};typeof d==="number"&&(d>j?j=d:d dataMax) {
39 | dataMax = value;
40 | } else if (value < dataMin) {
41 | dataMin = value;
42 | }
43 | }
44 | });
45 |
46 | series.translateColors(dataMin, dataMax);
47 | },
48 |
49 | getBox: function () {}
50 |
51 | });
52 |
53 | }(Highcharts));
54 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/modules/no-data-to-display.js:
--------------------------------------------------------------------------------
1 | /*
2 | Highcharts JS v3.0.6 (2013-10-04)
3 | Plugin for displaying a message when there is no data visible in chart.
4 |
5 | (c) 2010-2013 Highsoft AS
6 | Author: Øystein Moseng
7 |
8 | License: www.highcharts.com/license
9 | */
10 | (function(c){function f(){return!!this.points.length}function g(){this.hasData()?this.hideNoData():this.showNoData()}var d=c.seriesTypes,e=c.Chart.prototype,h=c.getOptions(),i=c.extend;i(h.lang,{noData:"No data to display"});h.noData={position:{x:0,y:0,align:"center",verticalAlign:"middle"},attr:{},style:{fontWeight:"bold",fontSize:"12px",color:"#60606a"}};d.pie.prototype.hasData=f;if(d.gauge)d.gauge.prototype.hasData=f;if(d.waterfall)d.waterfall.prototype.hasData=f;c.Series.prototype.hasData=function(){return this.dataMax!==
11 | void 0&&this.dataMin!==void 0};e.showNoData=function(a){var b=this.options,a=a||b.lang.noData,b=b.noData;if(!this.noDataLabel)this.noDataLabel=this.renderer.label(a,0,0,null,null,null,null,null,"no-data").attr(b.attr).css(b.style).add(),this.noDataLabel.align(i(this.noDataLabel.getBBox(),b.position),!1,"plotBox")};e.hideNoData=function(){if(this.noDataLabel)this.noDataLabel=this.noDataLabel.destroy()};e.hasData=function(){for(var a=this.series,b=a.length;b--;)if(a[b].hasData()&&!a[b].options.isInternal)return!0;
12 | return!1};e.callbacks.push(function(a){c.addEvent(a,"load",g);c.addEvent(a,"redraw",g)})})(Highcharts);
13 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/modules/no-data-to-display.src.js:
--------------------------------------------------------------------------------
1 | /**
2 | * @license Highcharts JS v3.0.6 (2013-10-04)
3 | * Plugin for displaying a message when there is no data visible in chart.
4 | *
5 | * (c) 2010-2013 Highsoft AS
6 | * Author: Øystein Moseng
7 | *
8 | * License: www.highcharts.com/license
9 | */
10 |
11 | (function (H) { // docs
12 |
13 | var seriesTypes = H.seriesTypes,
14 | chartPrototype = H.Chart.prototype,
15 | defaultOptions = H.getOptions(),
16 | extend = H.extend;
17 |
18 | // Add language option
19 | extend(defaultOptions.lang, {
20 | noData: 'No data to display'
21 | });
22 |
23 | // Add default display options for message
24 | defaultOptions.noData = {
25 | position: {
26 | x: 0,
27 | y: 0,
28 | align: 'center',
29 | verticalAlign: 'middle'
30 | },
31 | attr: {
32 | },
33 | style: {
34 | fontWeight: 'bold',
35 | fontSize: '12px',
36 | color: '#60606a'
37 | }
38 | };
39 |
40 | /**
41 | * Define hasData functions for series. These return true if there are data points on this series within the plot area
42 | */
43 | function hasDataPie() {
44 | return !!this.points.length; /* != 0 */
45 | }
46 |
47 | seriesTypes.pie.prototype.hasData = hasDataPie;
48 |
49 | if (seriesTypes.gauge) {
50 | seriesTypes.gauge.prototype.hasData = hasDataPie;
51 | }
52 |
53 | if (seriesTypes.waterfall) {
54 | seriesTypes.waterfall.prototype.hasData = hasDataPie;
55 | }
56 |
57 | H.Series.prototype.hasData = function () {
58 | return this.dataMax !== undefined && this.dataMin !== undefined;
59 | };
60 |
61 | /**
62 | * Display a no-data message.
63 | *
64 | * @param {String} str An optional message to show in place of the default one
65 | */
66 | chartPrototype.showNoData = function (str) {
67 | var chart = this,
68 | options = chart.options,
69 | text = str || options.lang.noData,
70 | noDataOptions = options.noData;
71 |
72 | if (!chart.noDataLabel) {
73 | chart.noDataLabel = chart.renderer.label(text, 0, 0, null, null, null, null, null, 'no-data')
74 | .attr(noDataOptions.attr)
75 | .css(noDataOptions.style)
76 | .add();
77 | chart.noDataLabel.align(extend(chart.noDataLabel.getBBox(), noDataOptions.position), false, 'plotBox');
78 | }
79 | };
80 |
81 | /**
82 | * Hide no-data message
83 | */
84 | chartPrototype.hideNoData = function () {
85 | var chart = this;
86 | if (chart.noDataLabel) {
87 | chart.noDataLabel = chart.noDataLabel.destroy();
88 | }
89 | };
90 |
91 | /**
92 | * Returns true if there are data points within the plot area now
93 | */
94 | chartPrototype.hasData = function () {
95 | var chart = this,
96 | series = chart.series,
97 | i = series.length;
98 |
99 | while (i--) {
100 | if (series[i].hasData() && !series[i].options.isInternal) {
101 | return true;
102 | }
103 | }
104 |
105 | return false;
106 | };
107 |
108 | /**
109 | * Show no-data message if there is no data in sight. Otherwise, hide it.
110 | */
111 | function handleNoData() {
112 | var chart = this;
113 | if (chart.hasData()) {
114 | chart.hideNoData();
115 | } else {
116 | chart.showNoData();
117 | }
118 | }
119 |
120 | /**
121 | * Add event listener to handle automatic display of no-data message
122 | */
123 | chartPrototype.callbacks.push(function (chart) {
124 | H.addEvent(chart, 'load', handleNoData);
125 | H.addEvent(chart, 'redraw', handleNoData);
126 | });
127 |
128 | }(Highcharts));
129 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/themes/grid.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Grid theme for Highcharts JS
3 | * @author Torstein Hønsi
4 | */
5 |
6 | Highcharts.theme = {
7 | colors: ['#058DC7', '#50B432', '#ED561B', '#DDDF00', '#24CBE5', '#64E572', '#FF9655', '#FFF263', '#6AF9C4'],
8 | chart: {
9 | backgroundColor: {
10 | linearGradient: { x1: 0, y1: 0, x2: 1, y2: 1 },
11 | stops: [
12 | [0, 'rgb(255, 255, 255)'],
13 | [1, 'rgb(240, 240, 255)']
14 | ]
15 | },
16 | borderWidth: 2,
17 | plotBackgroundColor: 'rgba(255, 255, 255, .9)',
18 | plotShadow: true,
19 | plotBorderWidth: 1
20 | },
21 | title: {
22 | style: {
23 | color: '#000',
24 | font: 'bold 16px "Trebuchet MS", Verdana, sans-serif'
25 | }
26 | },
27 | subtitle: {
28 | style: {
29 | color: '#666666',
30 | font: 'bold 12px "Trebuchet MS", Verdana, sans-serif'
31 | }
32 | },
33 | xAxis: {
34 | gridLineWidth: 1,
35 | lineColor: '#000',
36 | tickColor: '#000',
37 | labels: {
38 | style: {
39 | color: '#000',
40 | font: '11px Trebuchet MS, Verdana, sans-serif'
41 | }
42 | },
43 | title: {
44 | style: {
45 | color: '#333',
46 | fontWeight: 'bold',
47 | fontSize: '12px',
48 | fontFamily: 'Trebuchet MS, Verdana, sans-serif'
49 |
50 | }
51 | }
52 | },
53 | yAxis: {
54 | minorTickInterval: 'auto',
55 | lineColor: '#000',
56 | lineWidth: 1,
57 | tickWidth: 1,
58 | tickColor: '#000',
59 | labels: {
60 | style: {
61 | color: '#000',
62 | font: '11px Trebuchet MS, Verdana, sans-serif'
63 | }
64 | },
65 | title: {
66 | style: {
67 | color: '#333',
68 | fontWeight: 'bold',
69 | fontSize: '12px',
70 | fontFamily: 'Trebuchet MS, Verdana, sans-serif'
71 | }
72 | }
73 | },
74 | legend: {
75 | itemStyle: {
76 | font: '9pt Trebuchet MS, Verdana, sans-serif',
77 | color: 'black'
78 |
79 | },
80 | itemHoverStyle: {
81 | color: '#039'
82 | },
83 | itemHiddenStyle: {
84 | color: 'gray'
85 | }
86 | },
87 | labels: {
88 | style: {
89 | color: '#99b'
90 | }
91 | },
92 |
93 | navigation: {
94 | buttonOptions: {
95 | theme: {
96 | stroke: '#CCCCCC'
97 | }
98 | }
99 | }
100 | };
101 |
102 | // Apply the theme
103 | var highchartsOptions = Highcharts.setOptions(Highcharts.theme);
104 |
--------------------------------------------------------------------------------
/static/UE/third-party/highcharts/themes/skies.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Skies theme for Highcharts JS
3 | * @author Torstein Hønsi
4 | */
5 |
6 | Highcharts.theme = {
7 | colors: ["#514F78", "#42A07B", "#9B5E4A", "#72727F", "#1F949A", "#82914E", "#86777F", "#42A07B"],
8 | chart: {
9 | className: 'skies',
10 | borderWidth: 0,
11 | plotShadow: true,
12 | plotBackgroundImage: 'http://www.highcharts.com/demo/gfx/skies.jpg',
13 | plotBackgroundColor: {
14 | linearGradient: [0, 0, 250, 500],
15 | stops: [
16 | [0, 'rgba(255, 255, 255, 1)'],
17 | [1, 'rgba(255, 255, 255, 0)']
18 | ]
19 | },
20 | plotBorderWidth: 1
21 | },
22 | title: {
23 | style: {
24 | color: '#3E576F',
25 | font: '16px Lucida Grande, Lucida Sans Unicode, Verdana, Arial, Helvetica, sans-serif'
26 | }
27 | },
28 | subtitle: {
29 | style: {
30 | color: '#6D869F',
31 | font: '12px Lucida Grande, Lucida Sans Unicode, Verdana, Arial, Helvetica, sans-serif'
32 | }
33 | },
34 | xAxis: {
35 | gridLineWidth: 0,
36 | lineColor: '#C0D0E0',
37 | tickColor: '#C0D0E0',
38 | labels: {
39 | style: {
40 | color: '#666',
41 | fontWeight: 'bold'
42 | }
43 | },
44 | title: {
45 | style: {
46 | color: '#666',
47 | font: '12px Lucida Grande, Lucida Sans Unicode, Verdana, Arial, Helvetica, sans-serif'
48 | }
49 | }
50 | },
51 | yAxis: {
52 | alternateGridColor: 'rgba(255, 255, 255, .5)',
53 | lineColor: '#C0D0E0',
54 | tickColor: '#C0D0E0',
55 | tickWidth: 1,
56 | labels: {
57 | style: {
58 | color: '#666',
59 | fontWeight: 'bold'
60 | }
61 | },
62 | title: {
63 | style: {
64 | color: '#666',
65 | font: '12px Lucida Grande, Lucida Sans Unicode, Verdana, Arial, Helvetica, sans-serif'
66 | }
67 | }
68 | },
69 | legend: {
70 | itemStyle: {
71 | font: '9pt Trebuchet MS, Verdana, sans-serif',
72 | color: '#3E576F'
73 | },
74 | itemHoverStyle: {
75 | color: 'black'
76 | },
77 | itemHiddenStyle: {
78 | color: 'silver'
79 | }
80 | },
81 | labels: {
82 | style: {
83 | color: '#3E576F'
84 | }
85 | }
86 | };
87 |
88 | // Apply the theme
89 | var highchartsOptions = Highcharts.setOptions(Highcharts.theme);
90 |
--------------------------------------------------------------------------------
/static/UE/third-party/video-js/font/vjs.eot:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/third-party/video-js/font/vjs.eot
--------------------------------------------------------------------------------
/static/UE/third-party/video-js/font/vjs.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/third-party/video-js/font/vjs.ttf
--------------------------------------------------------------------------------
/static/UE/third-party/video-js/font/vjs.woff:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/third-party/video-js/font/vjs.woff
--------------------------------------------------------------------------------
/static/UE/third-party/video-js/video-js.swf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/third-party/video-js/video-js.swf
--------------------------------------------------------------------------------
/static/UE/third-party/webuploader/Uploader.swf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/third-party/webuploader/Uploader.swf
--------------------------------------------------------------------------------
/static/UE/third-party/webuploader/webuploader.css:
--------------------------------------------------------------------------------
1 | .webuploader-container {
2 | position: relative;
3 | }
4 | .webuploader-element-invisible {
5 | position: absolute !important;
6 | clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
7 | clip: rect(1px,1px,1px,1px);
8 | }
9 | .webuploader-pick {
10 | position: relative;
11 | display: inline-block;
12 | cursor: pointer;
13 | background: #00b7ee;
14 | padding: 10px 15px;
15 | color: #fff;
16 | text-align: center;
17 | border-radius: 3px;
18 | overflow: hidden;
19 | }
20 | .webuploader-pick-hover {
21 | background: #00a2d4;
22 | }
23 |
24 | .webuploader-pick-disable {
25 | opacity: 0.6;
26 | pointer-events:none;
27 | }
28 |
29 |
--------------------------------------------------------------------------------
/static/UE/third-party/zeroclipboard/ZeroClipboard.swf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yueLeiWang/vue-element-admin/2d95e6baaedb5fab2e6f63757d492fd38dd000b7/static/UE/third-party/zeroclipboard/ZeroClipboard.swf
--------------------------------------------------------------------------------
/test/e2e/custom-assertions/elementCount.js:
--------------------------------------------------------------------------------
1 | // A custom Nightwatch assertion.
2 | // The assertion name is the filename.
3 | // Example usage:
4 | //
5 | // browser.assert.elementCount(selector, count)
6 | //
7 | // For more information on custom assertions see:
8 | // http://nightwatchjs.org/guide#writing-custom-assertions
9 |
10 | exports.assertion = function (selector, count) {
11 | this.message = 'Testing if element <' + selector + '> has count: ' + count
12 | this.expected = count
13 | this.pass = function (val) {
14 | return val === this.expected
15 | }
16 | this.value = function (res) {
17 | return res.value
18 | }
19 | this.command = function (cb) {
20 | var self = this
21 | return this.api.execute(function (selector) {
22 | return document.querySelectorAll(selector).length
23 | }, [selector], function (res) {
24 | cb.call(self, res)
25 | })
26 | }
27 | }
28 |
--------------------------------------------------------------------------------
/test/e2e/nightwatch.conf.js:
--------------------------------------------------------------------------------
1 | require('babel-register')
2 |
3 | var config = require('../../config')
4 |
5 | // http://nightwatchjs.org/gettingstarted#settings-file
6 | module.exports = {
7 | src_folders: ['test/e2e/specs'],
8 | output_folder: 'test/e2e/reports',
9 | custom_assertions_path: ['test/e2e/custom-assertions'],
10 |
11 | selenium: {
12 | start_process: true,
13 | server_path: require('selenium-server').path,
14 | host: '127.0.0.1',
15 | port: 4444,
16 | cli_args: {
17 | 'webdriver.chrome.driver': require('chromedriver').path
18 | }
19 | },
20 |
21 | test_settings: {
22 | default: {
23 | selenium_port: 4444,
24 | selenium_host: 'localhost',
25 | silent: true,
26 | globals: {
27 | devServerURL: 'http://localhost:' + (process.env.PORT || config.dev.port)
28 | }
29 | },
30 | chrome: {
31 | desiredCapabilities: {
32 | browserName: 'chrome',
33 | javascriptEnabled: true,
34 | acceptSslCerts: true
35 | }
36 | },
37 |
38 | firefox: {
39 | desiredCapabilities: {
40 | browserName: 'firefox',
41 | javascriptEnabled: true,
42 | acceptSslCerts: true
43 | }
44 | }
45 | }
46 | }
47 |
--------------------------------------------------------------------------------
/test/e2e/runner.js:
--------------------------------------------------------------------------------
1 | // 1. start the dev server using production config
2 | process.env.NODE_ENV = 'testing'
3 |
4 | const webpack = require('webpack')
5 | const DevServer = require('webpack-dev-server')
6 |
7 | const webpackConfig = require('../../build/webpack.prod.conf')
8 | const devConfigPromise = require('../../build/webpack.dev.conf')
9 |
10 | let server
11 |
12 | devConfigPromise.then(devConfig => {
13 | const devServerOptions = devConfig.devServer
14 | const compiler = webpack(webpackConfig)
15 | server = new DevServer(compiler, devServerOptions)
16 | const port = devServerOptions.port
17 | const host = devServerOptions.host
18 | return server.listen(port, host)
19 | })
20 | .then(() => {
21 | // 2. run the nightwatch test suite against it
22 | // to run in additional browsers:
23 | // 1. add an entry in test/e2e/nightwatch.conf.js under "test_settings"
24 | // 2. add it to the --env flag below
25 | // or override the environment flag, for example: `npm run e2e -- --env chrome,firefox`
26 | // For more information on Nightwatch's config file, see
27 | // http://nightwatchjs.org/guide#settings-file
28 | let opts = process.argv.slice(2)
29 | if (opts.indexOf('--config') === -1) {
30 | opts = opts.concat(['--config', 'test/e2e/nightwatch.conf.js'])
31 | }
32 | if (opts.indexOf('--env') === -1) {
33 | opts = opts.concat(['--env', 'chrome'])
34 | }
35 |
36 | const spawn = require('cross-spawn')
37 | const runner = spawn('./node_modules/.bin/nightwatch', opts, { stdio: 'inherit' })
38 |
39 | runner.on('exit', function (code) {
40 | server.close()
41 | process.exit(code)
42 | })
43 |
44 | runner.on('error', function (err) {
45 | server.close()
46 | throw err
47 | })
48 | })
49 |
--------------------------------------------------------------------------------
/test/e2e/specs/test.js:
--------------------------------------------------------------------------------
1 | // For authoring Nightwatch tests, see
2 | // http://nightwatchjs.org/guide#usage
3 |
4 | module.exports = {
5 | 'default e2e tests': function (browser) {
6 | // automatically uses dev Server port from /config.index.js
7 | // default: http://localhost:8080
8 | // see nightwatch.conf.js
9 | const devServer = browser.globals.devServerURL
10 |
11 | browser
12 | .url(devServer)
13 | .waitForElementVisible('#app', 5000)
14 | .assert.elementPresent('.hello')
15 | .assert.containsText('h1', 'Welcome to Your Vue.js App')
16 | .assert.elementCount('img', 1)
17 | .end()
18 | }
19 | }
20 |
--------------------------------------------------------------------------------
/test/unit/.eslintrc:
--------------------------------------------------------------------------------
1 | {
2 | "env": {
3 | "jest": true
4 | },
5 | "globals": {
6 | }
7 | }
8 |
--------------------------------------------------------------------------------
/test/unit/jest.conf.js:
--------------------------------------------------------------------------------
1 | const path = require('path')
2 |
3 | module.exports = {
4 | rootDir: path.resolve(__dirname, '../../'),
5 | moduleFileExtensions: [
6 | 'js',
7 | 'json',
8 | 'vue'
9 | ],
10 | moduleNameMapper: {
11 | '^@/(.*)$': '/src/$1'
12 | },
13 | transform: {
14 | '^.+\\.js$': '/node_modules/babel-jest',
15 | '.*\\.(vue)$': '/node_modules/vue-jest'
16 | },
17 | testPathIgnorePatterns: [
18 | '/test/e2e'
19 | ],
20 | snapshotSerializers: ['/node_modules/jest-serializer-vue'],
21 | setupFiles: ['/test/unit/setup'],
22 | mapCoverage: true,
23 | coverageDirectory: '/test/unit/coverage',
24 | collectCoverageFrom: [
25 | 'src/**/*.{js,vue}',
26 | '!src/main.js',
27 | '!src/router/index.js',
28 | '!**/node_modules/**'
29 | ]
30 | }
31 |
--------------------------------------------------------------------------------
/test/unit/setup.js:
--------------------------------------------------------------------------------
1 | import Vue from 'vue'
2 |
3 | Vue.config.productionTip = false
4 |
--------------------------------------------------------------------------------
/test/unit/specs/HelloWorld.spec.js:
--------------------------------------------------------------------------------
1 | import Vue from 'vue'
2 | import HelloWorld from '@/components/HelloWorld'
3 |
4 | describe('HelloWorld.vue', () => {
5 | it('should render correct contents', () => {
6 | const Constructor = Vue.extend(HelloWorld)
7 | const vm = new Constructor().$mount()
8 | expect(vm.$el.querySelector('.hello h1').textContent)
9 | .toEqual('Welcome to Your Vue.js App')
10 | })
11 | })
12 |
--------------------------------------------------------------------------------