refactor build
This commit is contained in:
		
							
								
								
									
										9
									
								
								.babelrc
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								.babelrc
									
									
									
									
									
								
							@@ -1,7 +1,12 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  "presets": [
 | 
					  "presets": [
 | 
				
			||||||
    ["env", { "modules": false }],
 | 
					    ["env", {
 | 
				
			||||||
 | 
					      "modules": false,
 | 
				
			||||||
 | 
					      "targets": {
 | 
				
			||||||
 | 
					        "browsers": ["> 1%", "last 2 versions", "not ie <= 8"]
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    "stage-2"
 | 
					    "stage-2"
 | 
				
			||||||
  ],
 | 
					  ],
 | 
				
			||||||
  "plugins": ["transform-runtime"]
 | 
					  "plugins": ["transform-vue-jsx", "transform-runtime"]
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										96
									
								
								.eslintrc.js
									
									
									
									
									
								
							
							
						
						
									
										96
									
								
								.eslintrc.js
									
									
									
									
									
								
							@@ -24,27 +24,51 @@ module.exports = {
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  // add your custom rules here
 | 
					  // add your custom rules here
 | 
				
			||||||
  //it is base on https://github.com/vuejs/eslint-config-vue
 | 
					  //it is base on https://github.com/vuejs/eslint-config-vue
 | 
				
			||||||
    'rules': {
 | 
					  rules: {
 | 
				
			||||||
    'accessor-pairs': 2,
 | 
					    'accessor-pairs': 2,
 | 
				
			||||||
        'arrow-spacing': [2, { 'before': true, 'after': true }],
 | 
					    'arrow-spacing': [2, {
 | 
				
			||||||
 | 
					      'before': true,
 | 
				
			||||||
 | 
					      'after': true
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'block-spacing': [2, 'always'],
 | 
					    'block-spacing': [2, 'always'],
 | 
				
			||||||
        'brace-style': [2, '1tbs', { 'allowSingleLine': true }],
 | 
					    'brace-style': [2, '1tbs', {
 | 
				
			||||||
        'camelcase': [0, { 'properties': 'always' }],
 | 
					      'allowSingleLine': true
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
 | 
					    'camelcase': [0, {
 | 
				
			||||||
 | 
					      'properties': 'always'
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'comma-dangle': [2, 'never'],
 | 
					    'comma-dangle': [2, 'never'],
 | 
				
			||||||
        'comma-spacing': [2, { 'before': false, 'after': true }],
 | 
					    'comma-spacing': [2, {
 | 
				
			||||||
 | 
					      'before': false,
 | 
				
			||||||
 | 
					      'after': true
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'comma-style': [2, 'last'],
 | 
					    'comma-style': [2, 'last'],
 | 
				
			||||||
    'constructor-super': 2,
 | 
					    'constructor-super': 2,
 | 
				
			||||||
    'curly': [2, 'multi-line'],
 | 
					    'curly': [2, 'multi-line'],
 | 
				
			||||||
    'dot-location': [2, 'property'],
 | 
					    'dot-location': [2, 'property'],
 | 
				
			||||||
    'eol-last': 2,
 | 
					    'eol-last': 2,
 | 
				
			||||||
    'eqeqeq': [2, 'allow-null'],
 | 
					    'eqeqeq': [2, 'allow-null'],
 | 
				
			||||||
        'generator-star-spacing': [2, { 'before': true, 'after': true }],
 | 
					    'generator-star-spacing': [2, {
 | 
				
			||||||
 | 
					      'before': true,
 | 
				
			||||||
 | 
					      'after': true
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'handle-callback-err': [2, '^(err|error)$'],
 | 
					    'handle-callback-err': [2, '^(err|error)$'],
 | 
				
			||||||
        'indent': [2, 2, { 'SwitchCase': 1 }],
 | 
					    'indent': [2, 2, {
 | 
				
			||||||
 | 
					      'SwitchCase': 1
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'jsx-quotes': [2, 'prefer-single'],
 | 
					    'jsx-quotes': [2, 'prefer-single'],
 | 
				
			||||||
        'key-spacing': [2, { 'beforeColon': false, 'afterColon': true }],
 | 
					    'key-spacing': [2, {
 | 
				
			||||||
        'keyword-spacing': [2, { 'before': true, 'after': true }],
 | 
					      'beforeColon': false,
 | 
				
			||||||
        'new-cap': [2, { 'newIsCap': true, 'capIsNew': false }],
 | 
					      'afterColon': true
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
 | 
					    'keyword-spacing': [2, {
 | 
				
			||||||
 | 
					      'before': true,
 | 
				
			||||||
 | 
					      'after': true
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
 | 
					    'new-cap': [2, {
 | 
				
			||||||
 | 
					      'newIsCap': true,
 | 
				
			||||||
 | 
					      'capIsNew': false
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'new-parens': 2,
 | 
					    'new-parens': 2,
 | 
				
			||||||
    'no-array-constructor': 2,
 | 
					    'no-array-constructor': 2,
 | 
				
			||||||
    'no-caller': 2,
 | 
					    'no-caller': 2,
 | 
				
			||||||
@@ -75,12 +99,17 @@ module.exports = {
 | 
				
			|||||||
    'no-irregular-whitespace': 2,
 | 
					    'no-irregular-whitespace': 2,
 | 
				
			||||||
    'no-iterator': 2,
 | 
					    'no-iterator': 2,
 | 
				
			||||||
    'no-label-var': 2,
 | 
					    'no-label-var': 2,
 | 
				
			||||||
        'no-labels': [2, { 'allowLoop': false, 'allowSwitch': false }],
 | 
					    'no-labels': [2, {
 | 
				
			||||||
 | 
					      'allowLoop': false,
 | 
				
			||||||
 | 
					      'allowSwitch': false
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'no-lone-blocks': 2,
 | 
					    'no-lone-blocks': 2,
 | 
				
			||||||
    'no-mixed-spaces-and-tabs': 2,
 | 
					    'no-mixed-spaces-and-tabs': 2,
 | 
				
			||||||
    'no-multi-spaces': 2,
 | 
					    'no-multi-spaces': 2,
 | 
				
			||||||
    'no-multi-str': 2,
 | 
					    'no-multi-str': 2,
 | 
				
			||||||
        'no-multiple-empty-lines': [2, { 'max': 1 }],
 | 
					    'no-multiple-empty-lines': [2, {
 | 
				
			||||||
 | 
					      'max': 1
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'no-native-reassign': 2,
 | 
					    'no-native-reassign': 2,
 | 
				
			||||||
    'no-negated-in-lhs': 2,
 | 
					    'no-negated-in-lhs': 2,
 | 
				
			||||||
    'no-new-object': 2,
 | 
					    'no-new-object': 2,
 | 
				
			||||||
@@ -108,28 +137,51 @@ module.exports = {
 | 
				
			|||||||
    'no-undef-init': 2,
 | 
					    'no-undef-init': 2,
 | 
				
			||||||
    'no-unexpected-multiline': 2,
 | 
					    'no-unexpected-multiline': 2,
 | 
				
			||||||
    'no-unmodified-loop-condition': 2,
 | 
					    'no-unmodified-loop-condition': 2,
 | 
				
			||||||
        'no-unneeded-ternary': [2, { 'defaultAssignment': false }],
 | 
					    'no-unneeded-ternary': [2, {
 | 
				
			||||||
 | 
					      'defaultAssignment': false
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'no-unreachable': 2,
 | 
					    'no-unreachable': 2,
 | 
				
			||||||
    'no-unsafe-finally': 2,
 | 
					    'no-unsafe-finally': 2,
 | 
				
			||||||
        'no-unused-vars': [2, { 'vars': 'all', 'args': 'none' }],
 | 
					    'no-unused-vars': [2, {
 | 
				
			||||||
 | 
					      'vars': 'all',
 | 
				
			||||||
 | 
					      'args': 'none'
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'no-useless-call': 2,
 | 
					    'no-useless-call': 2,
 | 
				
			||||||
    'no-useless-computed-key': 2,
 | 
					    'no-useless-computed-key': 2,
 | 
				
			||||||
    'no-useless-constructor': 2,
 | 
					    'no-useless-constructor': 2,
 | 
				
			||||||
    'no-useless-escape': 0,
 | 
					    'no-useless-escape': 0,
 | 
				
			||||||
    'no-whitespace-before-property': 2,
 | 
					    'no-whitespace-before-property': 2,
 | 
				
			||||||
    'no-with': 2,
 | 
					    'no-with': 2,
 | 
				
			||||||
        'one-var': [2, { 'initialized': 'never' }],
 | 
					    'one-var': [2, {
 | 
				
			||||||
        'operator-linebreak': [2, 'after', { 'overrides': { '?': 'before', ':': 'before' } }],
 | 
					      'initialized': 'never'
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
 | 
					    'operator-linebreak': [2, 'after', {
 | 
				
			||||||
 | 
					      'overrides': {
 | 
				
			||||||
 | 
					        '?': 'before',
 | 
				
			||||||
 | 
					        ':': 'before'
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'padded-blocks': [2, 'never'],
 | 
					    'padded-blocks': [2, 'never'],
 | 
				
			||||||
        'quotes': [2, 'single', { 'avoidEscape': true, 'allowTemplateLiterals': true }],
 | 
					    'quotes': [2, 'single', {
 | 
				
			||||||
 | 
					      'avoidEscape': true,
 | 
				
			||||||
 | 
					      'allowTemplateLiterals': true
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'semi': [2, 'never'],
 | 
					    'semi': [2, 'never'],
 | 
				
			||||||
        'semi-spacing': [2, { 'before': false, 'after': true }],
 | 
					    'semi-spacing': [2, {
 | 
				
			||||||
 | 
					      'before': false,
 | 
				
			||||||
 | 
					      'after': true
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'space-before-blocks': [2, 'always'],
 | 
					    'space-before-blocks': [2, 'always'],
 | 
				
			||||||
    'space-before-function-paren': [2, 'never'],
 | 
					    'space-before-function-paren': [2, 'never'],
 | 
				
			||||||
    'space-in-parens': [2, 'never'],
 | 
					    'space-in-parens': [2, 'never'],
 | 
				
			||||||
    'space-infix-ops': 2,
 | 
					    'space-infix-ops': 2,
 | 
				
			||||||
        'space-unary-ops': [2, { 'words': true, 'nonwords': false }],
 | 
					    'space-unary-ops': [2, {
 | 
				
			||||||
        'spaced-comment': [2, 'always', { 'markers': ['global', 'globals', 'eslint', 'eslint-disable', '*package', '!', ','] }],
 | 
					      'words': true,
 | 
				
			||||||
 | 
					      'nonwords': false
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
 | 
					    'spaced-comment': [2, 'always', {
 | 
				
			||||||
 | 
					      'markers': ['global', 'globals', 'eslint', 'eslint-disable', '*package', '!', ',']
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'template-curly-spacing': [2, 'never'],
 | 
					    'template-curly-spacing': [2, 'never'],
 | 
				
			||||||
    'use-isnan': 2,
 | 
					    'use-isnan': 2,
 | 
				
			||||||
    'valid-typeof': 2,
 | 
					    'valid-typeof': 2,
 | 
				
			||||||
@@ -138,7 +190,9 @@ module.exports = {
 | 
				
			|||||||
    'yoda': [2, 'never'],
 | 
					    'yoda': [2, 'never'],
 | 
				
			||||||
    'prefer-const': 2,
 | 
					    'prefer-const': 2,
 | 
				
			||||||
    'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0,
 | 
					    'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0,
 | 
				
			||||||
        'object-curly-spacing': [2, 'always', { objectsInObjects: false }],
 | 
					    'object-curly-spacing': [2, 'always', {
 | 
				
			||||||
 | 
					      objectsInObjects: false
 | 
				
			||||||
 | 
					    }],
 | 
				
			||||||
    'array-bracket-spacing': [2, 'never']
 | 
					    'array-bracket-spacing': [2, 'never']
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										8
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@@ -5,3 +5,11 @@ npm-debug.log*
 | 
				
			|||||||
yarn-debug.log*
 | 
					yarn-debug.log*
 | 
				
			||||||
yarn-error.log*
 | 
					yarn-error.log*
 | 
				
			||||||
package-lock.json
 | 
					package-lock.json
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Editor directories and files
 | 
				
			||||||
 | 
					.idea
 | 
				
			||||||
 | 
					.vscode
 | 
				
			||||||
 | 
					*.suo
 | 
				
			||||||
 | 
					*.ntvs*
 | 
				
			||||||
 | 
					*.njsproj
 | 
				
			||||||
 | 
					*.sln
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,6 +3,7 @@
 | 
				
			|||||||
module.exports = {
 | 
					module.exports = {
 | 
				
			||||||
  "plugins": {
 | 
					  "plugins": {
 | 
				
			||||||
    // to edit target browsers: use "browserslist" field in package.json
 | 
					    // to edit target browsers: use "browserslist" field in package.json
 | 
				
			||||||
 | 
					    "postcss-import": {},
 | 
				
			||||||
    "autoprefixer": {}
 | 
					    "autoprefixer": {}
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,21 +1,22 @@
 | 
				
			|||||||
 | 
					'use strict'
 | 
				
			||||||
require('./check-versions')()
 | 
					require('./check-versions')()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
process.env.NODE_ENV = 'production'
 | 
					process.env.NODE_ENV = 'production'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var ora = require('ora')
 | 
					const ora = require('ora')
 | 
				
			||||||
var rm = require('rimraf')
 | 
					const rm = require('rimraf')
 | 
				
			||||||
var path = require('path')
 | 
					const path = require('path')
 | 
				
			||||||
var chalk = require('chalk')
 | 
					const chalk = require('chalk')
 | 
				
			||||||
var webpack = require('webpack')
 | 
					const webpack = require('webpack')
 | 
				
			||||||
var config = require('../config')
 | 
					const config = require('../config')
 | 
				
			||||||
var webpackConfig = require('./webpack.prod.conf')
 | 
					const webpackConfig = require('./webpack.prod.conf')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var spinner = ora('building for production...')
 | 
					const spinner = ora('building for production...')
 | 
				
			||||||
spinner.start()
 | 
					spinner.start()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => {
 | 
					rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => {
 | 
				
			||||||
  if (err) throw err
 | 
					  if (err) throw err
 | 
				
			||||||
  webpack(webpackConfig, function (err, stats) {
 | 
					  webpack(webpackConfig, (err, stats) => {
 | 
				
			||||||
    spinner.stop()
 | 
					    spinner.stop()
 | 
				
			||||||
    if (err) throw err
 | 
					    if (err) throw err
 | 
				
			||||||
    process.stdout.write(stats.toString({
 | 
					    process.stdout.write(stats.toString({
 | 
				
			||||||
@@ -26,6 +27,11 @@ rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => {
 | 
				
			|||||||
      chunkModules: false
 | 
					      chunkModules: false
 | 
				
			||||||
    }) + '\n\n')
 | 
					    }) + '\n\n')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (stats.hasErrors()) {
 | 
				
			||||||
 | 
					      console.log(chalk.red('  Build failed with errors.\n'))
 | 
				
			||||||
 | 
					      process.exit(1)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    console.log(chalk.cyan('  Build complete.\n'))
 | 
					    console.log(chalk.cyan('  Build complete.\n'))
 | 
				
			||||||
    console.log(chalk.yellow(
 | 
					    console.log(chalk.yellow(
 | 
				
			||||||
      '  Tip: built files are meant to be served over an HTTP server.\n' +
 | 
					      '  Tip: built files are meant to be served over an HTTP server.\n' +
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,17 +1,19 @@
 | 
				
			|||||||
var chalk = require('chalk')
 | 
					'use strict'
 | 
				
			||||||
var semver = require('semver')
 | 
					const chalk = require('chalk')
 | 
				
			||||||
var packageConfig = require('../package.json')
 | 
					const semver = require('semver')
 | 
				
			||||||
var shell = require('shelljs')
 | 
					const packageConfig = require('../package.json')
 | 
				
			||||||
 | 
					const shell = require('shelljs')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function exec (cmd) {
 | 
					function exec (cmd) {
 | 
				
			||||||
  return require('child_process').execSync(cmd).toString().trim()
 | 
					  return require('child_process').execSync(cmd).toString().trim()
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var versionRequirements = [
 | 
					const versionRequirements = [
 | 
				
			||||||
  {
 | 
					  {
 | 
				
			||||||
    name: 'node',
 | 
					    name: 'node',
 | 
				
			||||||
    currentVersion: semver.clean(process.version),
 | 
					    currentVersion: semver.clean(process.version),
 | 
				
			||||||
    versionRequirement: packageConfig.engines.node
 | 
					    versionRequirement: packageConfig.engines.node
 | 
				
			||||||
  },
 | 
					  }
 | 
				
			||||||
]
 | 
					]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if (shell.which('npm')) {
 | 
					if (shell.which('npm')) {
 | 
				
			||||||
@@ -23,9 +25,11 @@ if (shell.which('npm')) {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
module.exports = function () {
 | 
					module.exports = function () {
 | 
				
			||||||
  var warnings = []
 | 
					  const warnings = []
 | 
				
			||||||
  for (var i = 0; i < versionRequirements.length; i++) {
 | 
					
 | 
				
			||||||
    var mod = versionRequirements[i]
 | 
					  for (let i = 0; i < versionRequirements.length; i++) {
 | 
				
			||||||
 | 
					    const mod = versionRequirements[i]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) {
 | 
					    if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) {
 | 
				
			||||||
      warnings.push(mod.name + ': ' +
 | 
					      warnings.push(mod.name + ': ' +
 | 
				
			||||||
        chalk.red(mod.currentVersion) + ' should be ' +
 | 
					        chalk.red(mod.currentVersion) + ' should be ' +
 | 
				
			||||||
@@ -38,10 +42,12 @@ module.exports = function () {
 | 
				
			|||||||
    console.log('')
 | 
					    console.log('')
 | 
				
			||||||
    console.log(chalk.yellow('To use this template, you must update following to modules:'))
 | 
					    console.log(chalk.yellow('To use this template, you must update following to modules:'))
 | 
				
			||||||
    console.log()
 | 
					    console.log()
 | 
				
			||||||
    for (var i = 0; i < warnings.length; i++) {
 | 
					
 | 
				
			||||||
      var warning = warnings[i]
 | 
					    for (let i = 0; i < warnings.length; i++) {
 | 
				
			||||||
 | 
					      const warning = warnings[i]
 | 
				
			||||||
      console.log('  ' + warning)
 | 
					      console.log('  ' + warning)
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    console.log()
 | 
					    console.log()
 | 
				
			||||||
    process.exit(1)
 | 
					    process.exit(1)
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,9 +0,0 @@
 | 
				
			|||||||
/* eslint-disable */
 | 
					 | 
				
			||||||
require('eventsource-polyfill')
 | 
					 | 
				
			||||||
var hotClient = require('webpack-hot-middleware/client?noInfo=true&reload=true')
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
hotClient.subscribe(function (event) {
 | 
					 | 
				
			||||||
  if (event.action === 'reload') {
 | 
					 | 
				
			||||||
    window.location.reload()
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
@@ -1,89 +0,0 @@
 | 
				
			|||||||
require('./check-versions')()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var config = require('../config')
 | 
					 | 
				
			||||||
if (!process.env.NODE_ENV) {
 | 
					 | 
				
			||||||
  process.env.NODE_ENV = JSON.parse(config.dev.env.NODE_ENV)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var opn = require('opn')
 | 
					 | 
				
			||||||
var path = require('path')
 | 
					 | 
				
			||||||
var express = require('express')
 | 
					 | 
				
			||||||
var webpack = require('webpack')
 | 
					 | 
				
			||||||
var proxyMiddleware = require('http-proxy-middleware')
 | 
					 | 
				
			||||||
var webpackConfig = require('./webpack.dev.conf')
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// default port where dev server listens for incoming traffic
 | 
					 | 
				
			||||||
var port = process.env.PORT || config.dev.port
 | 
					 | 
				
			||||||
// automatically open browser, if not set will be false
 | 
					 | 
				
			||||||
var autoOpenBrowser = !!config.dev.autoOpenBrowser
 | 
					 | 
				
			||||||
// Define HTTP proxies to your custom API backend
 | 
					 | 
				
			||||||
// https://github.com/chimurai/http-proxy-middleware
 | 
					 | 
				
			||||||
var proxyTable = config.dev.proxyTable
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var app = express()
 | 
					 | 
				
			||||||
var compiler = webpack(webpackConfig)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var devMiddleware = require('webpack-dev-middleware')(compiler, {
 | 
					 | 
				
			||||||
  publicPath: webpackConfig.output.publicPath,
 | 
					 | 
				
			||||||
  quiet: true
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var hotMiddleware = require('webpack-hot-middleware')(compiler, {
 | 
					 | 
				
			||||||
  log: () => {}
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
// force page reload when html-webpack-plugin template changes
 | 
					 | 
				
			||||||
compiler.plugin('compilation', function (compilation) {
 | 
					 | 
				
			||||||
  compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) {
 | 
					 | 
				
			||||||
    hotMiddleware.publish({ action: 'reload' })
 | 
					 | 
				
			||||||
    cb()
 | 
					 | 
				
			||||||
  })
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// proxy api requests
 | 
					 | 
				
			||||||
Object.keys(proxyTable).forEach(function (context) {
 | 
					 | 
				
			||||||
  var options = proxyTable[context]
 | 
					 | 
				
			||||||
  if (typeof options === 'string') {
 | 
					 | 
				
			||||||
    options = { target: options }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
  app.use(proxyMiddleware(options.filter || context, options))
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// handle fallback for HTML5 history API
 | 
					 | 
				
			||||||
app.use(require('connect-history-api-fallback')())
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// serve webpack bundle output
 | 
					 | 
				
			||||||
app.use(devMiddleware)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// enable hot-reload and state-preserving
 | 
					 | 
				
			||||||
// compilation error display
 | 
					 | 
				
			||||||
app.use(hotMiddleware)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// serve pure static assets
 | 
					 | 
				
			||||||
var staticPath = path.posix.join(config.dev.assetsPublicPath, config.dev.assetsSubDirectory)
 | 
					 | 
				
			||||||
app.use(staticPath, express.static('./static'))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var uri = 'http://localhost:' + port
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var _resolve
 | 
					 | 
				
			||||||
var readyPromise = new Promise(resolve => {
 | 
					 | 
				
			||||||
  _resolve = resolve
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
console.log('> Starting dev server...')
 | 
					 | 
				
			||||||
devMiddleware.waitUntilValid(() => {
 | 
					 | 
				
			||||||
  console.log('> Listening at ' + uri + '\n')
 | 
					 | 
				
			||||||
  // when env is testing, don't need open it
 | 
					 | 
				
			||||||
  if (autoOpenBrowser && process.env.NODE_ENV !== 'testing') {
 | 
					 | 
				
			||||||
    opn(uri)
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
  _resolve()
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var server = app.listen(port)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
module.exports = {
 | 
					 | 
				
			||||||
  ready: readyPromise,
 | 
					 | 
				
			||||||
  close: () => {
 | 
					 | 
				
			||||||
    server.close()
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
							
								
								
									
										
											BIN
										
									
								
								build/logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								build/logo.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 6.7 KiB  | 
@@ -1,28 +1,38 @@
 | 
				
			|||||||
var path = require('path')
 | 
					'use strict'
 | 
				
			||||||
var config = require('../config')
 | 
					const path = require('path')
 | 
				
			||||||
var ExtractTextPlugin = require('extract-text-webpack-plugin')
 | 
					const config = require('../config')
 | 
				
			||||||
 | 
					const ExtractTextPlugin = require('extract-text-webpack-plugin')
 | 
				
			||||||
 | 
					const packageConfig = require('../package.json')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
exports.assetsPath = function (_path) {
 | 
					exports.assetsPath = function (_path) {
 | 
				
			||||||
  var assetsSubDirectory = process.env.NODE_ENV === 'production'
 | 
					  const assetsSubDirectory = process.env.NODE_ENV === 'production'
 | 
				
			||||||
    ? config.build.assetsSubDirectory
 | 
					    ? config.build.assetsSubDirectory
 | 
				
			||||||
    : config.dev.assetsSubDirectory
 | 
					    : config.dev.assetsSubDirectory
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return path.posix.join(assetsSubDirectory, _path)
 | 
					  return path.posix.join(assetsSubDirectory, _path)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
exports.cssLoaders = function (options) {
 | 
					exports.cssLoaders = function (options) {
 | 
				
			||||||
  options = options || {}
 | 
					  options = options || {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  var cssLoader = {
 | 
					  const cssLoader = {
 | 
				
			||||||
    loader: 'css-loader',
 | 
					    loader: 'css-loader',
 | 
				
			||||||
    options: {
 | 
					    options: {
 | 
				
			||||||
      minimize: process.env.NODE_ENV === 'production',
 | 
					      sourceMap: options.sourceMap
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const postcssLoader = {
 | 
				
			||||||
 | 
					    loader: 'postcss-loader',
 | 
				
			||||||
 | 
					    options: {
 | 
				
			||||||
      sourceMap: options.sourceMap
 | 
					      sourceMap: options.sourceMap
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  // generate loader string to be used with extract text plugin
 | 
					  // generate loader string to be used with extract text plugin
 | 
				
			||||||
  function generateLoaders (loader, loaderOptions) {
 | 
					  function generateLoaders (loader, loaderOptions) {
 | 
				
			||||||
    var loaders = [cssLoader]
 | 
					    const loaders = options.usePostCSS ? [cssLoader, postcssLoader] : [cssLoader]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (loader) {
 | 
					    if (loader) {
 | 
				
			||||||
      loaders.push({
 | 
					      loaders.push({
 | 
				
			||||||
        loader: loader + '-loader',
 | 
					        loader: loader + '-loader',
 | 
				
			||||||
@@ -58,14 +68,34 @@ exports.cssLoaders = function (options) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
// Generate loaders for standalone style files (outside of .vue)
 | 
					// Generate loaders for standalone style files (outside of .vue)
 | 
				
			||||||
exports.styleLoaders = function (options) {
 | 
					exports.styleLoaders = function (options) {
 | 
				
			||||||
  var output = []
 | 
					  const output = []
 | 
				
			||||||
  var loaders = exports.cssLoaders(options)
 | 
					  const loaders = exports.cssLoaders(options)
 | 
				
			||||||
  for (var extension in loaders) {
 | 
					
 | 
				
			||||||
    var loader = loaders[extension]
 | 
					  for (const extension in loaders) {
 | 
				
			||||||
 | 
					    const loader = loaders[extension]
 | 
				
			||||||
    output.push({
 | 
					    output.push({
 | 
				
			||||||
      test: new RegExp('\\.' + extension + '$'),
 | 
					      test: new RegExp('\\.' + extension + '$'),
 | 
				
			||||||
      use: loader
 | 
					      use: loader
 | 
				
			||||||
    })
 | 
					    })
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return output
 | 
					  return output
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					exports.createNotifierCallback = () => {
 | 
				
			||||||
 | 
					  const notifier = require('node-notifier')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return (severity, errors) => {
 | 
				
			||||||
 | 
					    if (severity !== 'error') return
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    const error = errors[0]
 | 
				
			||||||
 | 
					    const filename = error.file && error.file.split('!').pop()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    notifier.notify({
 | 
				
			||||||
 | 
					      title: packageConfig.name,
 | 
				
			||||||
 | 
					      message: severity + ': ' + error.name,
 | 
				
			||||||
 | 
					      subtitle: filename || '',
 | 
				
			||||||
 | 
					      icon: path.join(__dirname, 'logo.png')
 | 
				
			||||||
 | 
					    })
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,22 @@
 | 
				
			|||||||
var utils = require('./utils')
 | 
					'use strict'
 | 
				
			||||||
var config = require('../config')
 | 
					const utils = require('./utils')
 | 
				
			||||||
var isProduction = process.env.NODE_ENV === 'production'
 | 
					const config = require('../config')
 | 
				
			||||||
 | 
					const isProduction = process.env.NODE_ENV === 'production'
 | 
				
			||||||
 | 
					const sourceMapEnabled = isProduction
 | 
				
			||||||
 | 
					  ? config.build.productionSourceMap
 | 
				
			||||||
 | 
					  : config.dev.cssSourceMap
 | 
				
			||||||
 | 
					
 | 
				
			||||||
module.exports = {
 | 
					module.exports = {
 | 
				
			||||||
  loaders: utils.cssLoaders({
 | 
					  loaders: utils.cssLoaders({
 | 
				
			||||||
    sourceMap: isProduction
 | 
					    sourceMap: sourceMapEnabled,
 | 
				
			||||||
      ? config.build.productionSourceMap
 | 
					 | 
				
			||||||
      : config.dev.cssSourceMap,
 | 
					 | 
				
			||||||
    extract: isProduction
 | 
					    extract: isProduction
 | 
				
			||||||
  })
 | 
					  }),
 | 
				
			||||||
 | 
					  cssSourceMap: sourceMapEnabled,
 | 
				
			||||||
 | 
					  cacheBusting: config.dev.cacheBusting,
 | 
				
			||||||
 | 
					  transformToRequire: {
 | 
				
			||||||
 | 
					    video: ['src', 'poster'],
 | 
				
			||||||
 | 
					    source: 'src',
 | 
				
			||||||
 | 
					    img: 'src',
 | 
				
			||||||
 | 
					    image: 'xlink:href'
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,13 +1,26 @@
 | 
				
			|||||||
var path = require('path')
 | 
					'use strict'
 | 
				
			||||||
var utils = require('./utils')
 | 
					const path = require('path')
 | 
				
			||||||
var config = require('../config')
 | 
					const utils = require('./utils')
 | 
				
			||||||
var vueLoaderConfig = require('./vue-loader.conf')
 | 
					const config = require('../config')
 | 
				
			||||||
 | 
					const vueLoaderConfig = require('./vue-loader.conf')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function resolve (dir) {
 | 
					function resolve (dir) {
 | 
				
			||||||
  return path.join(__dirname, '..', dir)
 | 
					  return path.join(__dirname, '..', dir)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const createLintingRule = () => ({
 | 
				
			||||||
 | 
					  test: /\.(js|vue)$/,
 | 
				
			||||||
 | 
					  loader: 'eslint-loader',
 | 
				
			||||||
 | 
					  enforce: 'pre',
 | 
				
			||||||
 | 
					  include: [resolve('src'), resolve('test')],
 | 
				
			||||||
 | 
					  options: {
 | 
				
			||||||
 | 
					    formatter: require('eslint-friendly-formatter'),
 | 
				
			||||||
 | 
					    emitWarning: !config.dev.showEslintErrorsInOverlay
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
module.exports = {
 | 
					module.exports = {
 | 
				
			||||||
 | 
					  context: path.resolve(__dirname, '../'),
 | 
				
			||||||
  entry: {
 | 
					  entry: {
 | 
				
			||||||
    app: './src/main.js'
 | 
					    app: './src/main.js'
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
@@ -22,20 +35,12 @@ module.exports = {
 | 
				
			|||||||
    extensions: ['.js', '.vue', '.json'],
 | 
					    extensions: ['.js', '.vue', '.json'],
 | 
				
			||||||
    alias: {
 | 
					    alias: {
 | 
				
			||||||
      'vue$': 'vue/dist/vue.esm.js',
 | 
					      'vue$': 'vue/dist/vue.esm.js',
 | 
				
			||||||
      '@': resolve('src')
 | 
					      '@': resolve('src'),
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  module: {
 | 
					  module: {
 | 
				
			||||||
    rules: [
 | 
					    rules: [
 | 
				
			||||||
      // {
 | 
					      ...(config.dev.useEslint ? [createLintingRule()] : []),
 | 
				
			||||||
      //   test: /\.(js|vue)$/,
 | 
					 | 
				
			||||||
      //   loader: 'eslint-loader',
 | 
					 | 
				
			||||||
      //   enforce: 'pre',
 | 
					 | 
				
			||||||
      //   include: [resolve('src'), resolve('test')],
 | 
					 | 
				
			||||||
      //   options: {
 | 
					 | 
				
			||||||
      //     formatter: require('eslint-friendly-formatter')
 | 
					 | 
				
			||||||
      //   }
 | 
					 | 
				
			||||||
      // },
 | 
					 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
        test: /\.vue$/,
 | 
					        test: /\.vue$/,
 | 
				
			||||||
        loader: 'vue-loader',
 | 
					        loader: 'vue-loader',
 | 
				
			||||||
@@ -63,6 +68,14 @@ module.exports = {
 | 
				
			|||||||
          name: utils.assetsPath('img/[name].[hash:7].[ext]')
 | 
					          name: utils.assetsPath('img/[name].[hash:7].[ext]')
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
 | 
				
			||||||
 | 
					        loader: 'url-loader',
 | 
				
			||||||
 | 
					        options: {
 | 
				
			||||||
 | 
					          limit: 10000,
 | 
				
			||||||
 | 
					          name: utils.assetsPath('media/[name].[hash:7].[ext]')
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
        test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
 | 
					        test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
 | 
				
			||||||
        loader: 'url-loader',
 | 
					        loader: 'url-loader',
 | 
				
			||||||
@@ -72,5 +85,17 @@ module.exports = {
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    ]
 | 
					    ]
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  node: {
 | 
				
			||||||
 | 
					    // prevent webpack from injecting useless setImmediate polyfill because Vue
 | 
				
			||||||
 | 
					    // source contains it (although only uses it if it's native).
 | 
				
			||||||
 | 
					    setImmediate: false,
 | 
				
			||||||
 | 
					    // prevent webpack from injecting mocks to Node native modules
 | 
				
			||||||
 | 
					    // that does not make sense for the client
 | 
				
			||||||
 | 
					    dgram: 'empty',
 | 
				
			||||||
 | 
					    fs: 'empty',
 | 
				
			||||||
 | 
					    net: 'empty',
 | 
				
			||||||
 | 
					    tls: 'empty',
 | 
				
			||||||
 | 
					    child_process: 'empty'
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,41 +1,87 @@
 | 
				
			|||||||
var utils = require('./utils')
 | 
					'use strict'
 | 
				
			||||||
var path = require('path')
 | 
					const path = require('path')
 | 
				
			||||||
var webpack = require('webpack')
 | 
					const utils = require('./utils')
 | 
				
			||||||
var config = require('../config')
 | 
					const webpack = require('webpack')
 | 
				
			||||||
var merge = require('webpack-merge')
 | 
					const config = require('../config')
 | 
				
			||||||
var baseWebpackConfig = require('./webpack.base.conf')
 | 
					const merge = require('webpack-merge')
 | 
				
			||||||
var HtmlWebpackPlugin = require('html-webpack-plugin')
 | 
					const baseWebpackConfig = require('./webpack.base.conf')
 | 
				
			||||||
var FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
 | 
					const HtmlWebpackPlugin = require('html-webpack-plugin')
 | 
				
			||||||
 | 
					const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
 | 
				
			||||||
 | 
					const portfinder = require('portfinder')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function resolveApp(relativePath) {
 | 
					function resolve (dir) {
 | 
				
			||||||
  return path.resolve(relativePath);
 | 
					  return path.join(__dirname, '..', dir)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// add hot-reload related code to entry chunks
 | 
					const HOST = process.env.HOST
 | 
				
			||||||
Object.keys(baseWebpackConfig.entry).forEach(function (name) {
 | 
					const PORT = process.env.PORT && Number(process.env.PORT)
 | 
				
			||||||
  baseWebpackConfig.entry[name] = ['./build/dev-client'].concat(baseWebpackConfig.entry[name])
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
module.exports = merge(baseWebpackConfig, {
 | 
					const devWebpackConfig = merge(baseWebpackConfig, {
 | 
				
			||||||
  module: {
 | 
					  module: {
 | 
				
			||||||
    rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap })
 | 
					    rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap, usePostCSS: true })
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  // cheap-module-eval-source-map is faster for development
 | 
					  // cheap-module-eval-source-map is faster for development
 | 
				
			||||||
  devtool: '#cheap-module-eval-source-map',
 | 
					  devtool: config.dev.devtool,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // these devServer options should be customized in /config/index.js
 | 
				
			||||||
 | 
					  devServer: {
 | 
				
			||||||
 | 
					    clientLogLevel: 'warning',
 | 
				
			||||||
 | 
					    historyApiFallback: true,
 | 
				
			||||||
 | 
					    hot: true,
 | 
				
			||||||
 | 
					    compress: true,
 | 
				
			||||||
 | 
					    host: HOST || config.dev.host,
 | 
				
			||||||
 | 
					    port: PORT || config.dev.port,
 | 
				
			||||||
 | 
					    open: config.dev.autoOpenBrowser,
 | 
				
			||||||
 | 
					    overlay: config.dev.errorOverlay
 | 
				
			||||||
 | 
					      ? { warnings: false, errors: true }
 | 
				
			||||||
 | 
					      : false,
 | 
				
			||||||
 | 
					    publicPath: config.dev.assetsPublicPath,
 | 
				
			||||||
 | 
					    proxy: config.dev.proxyTable,
 | 
				
			||||||
 | 
					    quiet: true, // necessary for FriendlyErrorsPlugin
 | 
				
			||||||
 | 
					    watchOptions: {
 | 
				
			||||||
 | 
					      poll: config.dev.poll,
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
  plugins: [
 | 
					  plugins: [
 | 
				
			||||||
    new webpack.DefinePlugin({
 | 
					    new webpack.DefinePlugin({
 | 
				
			||||||
      'process.env': config.dev.env
 | 
					      'process.env': require('../config/dev.env')
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
    // https://github.com/glenjamin/webpack-hot-middleware#installation--usage
 | 
					 | 
				
			||||||
    new webpack.HotModuleReplacementPlugin(),
 | 
					    new webpack.HotModuleReplacementPlugin(),
 | 
				
			||||||
 | 
					    new webpack.NamedModulesPlugin(), // HMR shows correct file names in console on update.
 | 
				
			||||||
    new webpack.NoEmitOnErrorsPlugin(),
 | 
					    new webpack.NoEmitOnErrorsPlugin(),
 | 
				
			||||||
    // https://github.com/ampedandwired/html-webpack-plugin
 | 
					    // https://github.com/ampedandwired/html-webpack-plugin
 | 
				
			||||||
    new HtmlWebpackPlugin({
 | 
					    new HtmlWebpackPlugin({
 | 
				
			||||||
      filename: 'index.html',
 | 
					      filename: 'index.html',
 | 
				
			||||||
      template: 'index.html',
 | 
					      template: 'index.html',
 | 
				
			||||||
      favicon: resolveApp('favicon.ico'),
 | 
					      inject: true,
 | 
				
			||||||
      inject: true
 | 
					      favicon: resolve('favicon.ico'),
 | 
				
			||||||
 | 
					      title: 'vue-element-admin'
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
    new FriendlyErrorsPlugin()
 | 
					 | 
				
			||||||
  ]
 | 
					  ]
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					module.exports = new Promise((resolve, reject) => {
 | 
				
			||||||
 | 
					  portfinder.basePort = process.env.PORT || config.dev.port
 | 
				
			||||||
 | 
					  portfinder.getPort((err, port) => {
 | 
				
			||||||
 | 
					    if (err) {
 | 
				
			||||||
 | 
					      reject(err)
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					      // publish the new Port, necessary for e2e tests
 | 
				
			||||||
 | 
					      process.env.PORT = port
 | 
				
			||||||
 | 
					      // add port to devServer config
 | 
				
			||||||
 | 
					      devWebpackConfig.devServer.port = port
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // Add FriendlyErrorsPlugin
 | 
				
			||||||
 | 
					      devWebpackConfig.plugins.push(new FriendlyErrorsPlugin({
 | 
				
			||||||
 | 
					        compilationSuccessInfo: {
 | 
				
			||||||
 | 
					          messages: [`Your application is running here: http://${devWebpackConfig.devServer.host}:${port}`],
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        onErrors: config.dev.notifyOnErrors
 | 
				
			||||||
 | 
					        ? utils.createNotifierCallback()
 | 
				
			||||||
 | 
					        : undefined
 | 
				
			||||||
 | 
					      }))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      resolve(devWebpackConfig)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,28 +1,31 @@
 | 
				
			|||||||
var path = require('path')
 | 
					'use strict'
 | 
				
			||||||
var utils = require('./utils')
 | 
					const path = require('path')
 | 
				
			||||||
var webpack = require('webpack')
 | 
					const utils = require('./utils')
 | 
				
			||||||
var config = require('../config')
 | 
					const webpack = require('webpack')
 | 
				
			||||||
var merge = require('webpack-merge')
 | 
					const config = require('../config')
 | 
				
			||||||
var baseWebpackConfig = require('./webpack.base.conf')
 | 
					const merge = require('webpack-merge')
 | 
				
			||||||
var CopyWebpackPlugin = require('copy-webpack-plugin')
 | 
					const baseWebpackConfig = require('./webpack.base.conf')
 | 
				
			||||||
var HtmlWebpackPlugin = require('html-webpack-plugin')
 | 
					const CopyWebpackPlugin = require('copy-webpack-plugin')
 | 
				
			||||||
var ExtractTextPlugin = require('extract-text-webpack-plugin')
 | 
					const HtmlWebpackPlugin = require('html-webpack-plugin')
 | 
				
			||||||
var OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin')
 | 
					const ExtractTextPlugin = require('extract-text-webpack-plugin')
 | 
				
			||||||
 | 
					const OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin')
 | 
				
			||||||
 | 
					const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var env = config.build.env
 | 
					function resolve (dir) {
 | 
				
			||||||
 | 
					  return path.join(__dirname, '..', dir)
 | 
				
			||||||
function resolveApp(relativePath) {
 | 
					 | 
				
			||||||
    return path.resolve(relativePath);
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var webpackConfig = merge(baseWebpackConfig, {
 | 
					const env = require('../config/prod.env')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const webpackConfig = merge(baseWebpackConfig, {
 | 
				
			||||||
  module: {
 | 
					  module: {
 | 
				
			||||||
    rules: utils.styleLoaders({
 | 
					    rules: utils.styleLoaders({
 | 
				
			||||||
      sourceMap: config.build.productionSourceMap,
 | 
					      sourceMap: config.build.productionSourceMap,
 | 
				
			||||||
      extract: true
 | 
					      extract: true,
 | 
				
			||||||
 | 
					      usePostCSS: true
 | 
				
			||||||
    })
 | 
					    })
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  devtool: config.build.productionSourceMap ? '#source-map' : false,
 | 
					  devtool: config.build.productionSourceMap ? config.build.devtool : false,
 | 
				
			||||||
  output: {
 | 
					  output: {
 | 
				
			||||||
    path: config.build.assetsRoot,
 | 
					    path: config.build.assetsRoot,
 | 
				
			||||||
    filename: utils.assetsPath('js/[name].[chunkhash].js'),
 | 
					    filename: utils.assetsPath('js/[name].[chunkhash].js'),
 | 
				
			||||||
@@ -33,22 +36,30 @@ var webpackConfig = merge(baseWebpackConfig, {
 | 
				
			|||||||
    new webpack.DefinePlugin({
 | 
					    new webpack.DefinePlugin({
 | 
				
			||||||
      'process.env': env
 | 
					      'process.env': env
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
    new webpack.optimize.UglifyJsPlugin({
 | 
					    new UglifyJsPlugin({
 | 
				
			||||||
 | 
					      uglifyOptions: {
 | 
				
			||||||
        compress: {
 | 
					        compress: {
 | 
				
			||||||
          warnings: false
 | 
					          warnings: false
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      sourceMap: true
 | 
					      sourceMap: config.build.productionSourceMap,
 | 
				
			||||||
 | 
					      parallel: true
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
    // extract css into its own file
 | 
					    // extract css into its own file
 | 
				
			||||||
    new ExtractTextPlugin({
 | 
					    new ExtractTextPlugin({
 | 
				
			||||||
      filename: utils.assetsPath('css/[name].[contenthash].css')
 | 
					      filename: utils.assetsPath('css/[name].[contenthash].css'),
 | 
				
			||||||
 | 
					      // Setting the following option to `false` will not extract CSS from codesplit chunks.
 | 
				
			||||||
 | 
					      // Their CSS will instead be inserted dynamically with style-loader when the codesplit chunk has been loaded by webpack.
 | 
				
			||||||
 | 
					      // It's currently set to `true` because we are seeing that sourcemaps are included in the codesplit bundle as well when it's `false`,
 | 
				
			||||||
 | 
					      // increasing file size: https://github.com/vuejs-templates/webpack/issues/1110
 | 
				
			||||||
 | 
					      allChunks: true,
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
    // Compress extracted CSS. We are using this plugin so that possible
 | 
					    // Compress extracted CSS. We are using this plugin so that possible
 | 
				
			||||||
    // duplicated CSS from different components can be deduped.
 | 
					    // duplicated CSS from different components can be deduped.
 | 
				
			||||||
    new OptimizeCSSPlugin({
 | 
					    new OptimizeCSSPlugin({
 | 
				
			||||||
      cssProcessorOptions: {
 | 
					      cssProcessorOptions: config.build.productionSourceMap
 | 
				
			||||||
        safe: true
 | 
					        ? { safe: true, map: { inline: false } }
 | 
				
			||||||
      }
 | 
					        : { safe: true }
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
    // generate dist index.html with correct asset hash for caching.
 | 
					    // generate dist index.html with correct asset hash for caching.
 | 
				
			||||||
    // you can customize output by editing /index.html
 | 
					    // you can customize output by editing /index.html
 | 
				
			||||||
@@ -57,7 +68,8 @@ var webpackConfig = merge(baseWebpackConfig, {
 | 
				
			|||||||
      filename: config.build.index,
 | 
					      filename: config.build.index,
 | 
				
			||||||
      template: 'index.html',
 | 
					      template: 'index.html',
 | 
				
			||||||
      inject: true,
 | 
					      inject: true,
 | 
				
			||||||
      favicon: resolveApp('favicon.ico'),
 | 
					      favicon: resolve('favicon.ico'),
 | 
				
			||||||
 | 
					      title: 'vue-element-admin',
 | 
				
			||||||
      minify: {
 | 
					      minify: {
 | 
				
			||||||
        removeComments: true,
 | 
					        removeComments: true,
 | 
				
			||||||
        collapseWhitespace: true,
 | 
					        collapseWhitespace: true,
 | 
				
			||||||
@@ -68,12 +80,14 @@ var webpackConfig = merge(baseWebpackConfig, {
 | 
				
			|||||||
      // necessary to consistently work with multiple chunks via CommonsChunkPlugin
 | 
					      // necessary to consistently work with multiple chunks via CommonsChunkPlugin
 | 
				
			||||||
      chunksSortMode: 'dependency'
 | 
					      chunksSortMode: 'dependency'
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
    // cache Module Identifiers
 | 
					    // keep module.id stable when vender modules does not change
 | 
				
			||||||
    new webpack.HashedModuleIdsPlugin(),
 | 
					    new webpack.HashedModuleIdsPlugin(),
 | 
				
			||||||
 | 
					    // enable scope hoisting
 | 
				
			||||||
 | 
					    new webpack.optimize.ModuleConcatenationPlugin(),
 | 
				
			||||||
    // split vendor js into its own file
 | 
					    // split vendor js into its own file
 | 
				
			||||||
    new webpack.optimize.CommonsChunkPlugin({
 | 
					    new webpack.optimize.CommonsChunkPlugin({
 | 
				
			||||||
      name: 'vendor',
 | 
					      name: 'vendor',
 | 
				
			||||||
      minChunks: function (module, count) {
 | 
					      minChunks (module) {
 | 
				
			||||||
        // any required modules inside node_modules are extracted to vendor
 | 
					        // any required modules inside node_modules are extracted to vendor
 | 
				
			||||||
        return (
 | 
					        return (
 | 
				
			||||||
          module.resource &&
 | 
					          module.resource &&
 | 
				
			||||||
@@ -88,8 +102,18 @@ var webpackConfig = merge(baseWebpackConfig, {
 | 
				
			|||||||
    // prevent vendor hash from being updated whenever app bundle is updated
 | 
					    // prevent vendor hash from being updated whenever app bundle is updated
 | 
				
			||||||
    new webpack.optimize.CommonsChunkPlugin({
 | 
					    new webpack.optimize.CommonsChunkPlugin({
 | 
				
			||||||
      name: 'manifest',
 | 
					      name: 'manifest',
 | 
				
			||||||
      chunks: ['vendor']
 | 
					      minChunks: Infinity
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
 | 
					    // This instance extracts shared chunks from code splitted chunks and bundles them
 | 
				
			||||||
 | 
					    // in a separate chunk, similar to the vendor chunk
 | 
				
			||||||
 | 
					    // see: https://webpack.js.org/plugins/commons-chunk-plugin/#extra-async-commons-chunk
 | 
				
			||||||
 | 
					    new webpack.optimize.CommonsChunkPlugin({
 | 
				
			||||||
 | 
					      name: 'app',
 | 
				
			||||||
 | 
					      async: 'vendor-async',
 | 
				
			||||||
 | 
					      children: true,
 | 
				
			||||||
 | 
					      minChunks: 3
 | 
				
			||||||
 | 
					    }),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // copy custom static assets
 | 
					    // copy custom static assets
 | 
				
			||||||
    new CopyWebpackPlugin([
 | 
					    new CopyWebpackPlugin([
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
@@ -102,7 +126,7 @@ var webpackConfig = merge(baseWebpackConfig, {
 | 
				
			|||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if (config.build.productionGzip) {
 | 
					if (config.build.productionGzip) {
 | 
				
			||||||
  var CompressionWebpackPlugin = require('compression-webpack-plugin')
 | 
					  const CompressionWebpackPlugin = require('compression-webpack-plugin')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  webpackConfig.plugins.push(
 | 
					  webpackConfig.plugins.push(
 | 
				
			||||||
    new CompressionWebpackPlugin({
 | 
					    new CompressionWebpackPlugin({
 | 
				
			||||||
@@ -120,7 +144,7 @@ if (config.build.productionGzip) {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if (config.build.bundleAnalyzerReport) {
 | 
					if (config.build.bundleAnalyzerReport) {
 | 
				
			||||||
  var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin
 | 
					  const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin
 | 
				
			||||||
  webpackConfig.plugins.push(new BundleAnalyzerPlugin())
 | 
					  webpackConfig.plugins.push(new BundleAnalyzerPlugin())
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,5 +1,6 @@
 | 
				
			|||||||
var merge = require('webpack-merge')
 | 
					'use strict'
 | 
				
			||||||
var prodEnv = require('./prod.env')
 | 
					const merge = require('webpack-merge')
 | 
				
			||||||
 | 
					const prodEnv = require('./prod.env')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
module.exports = merge(prodEnv, {
 | 
					module.exports = merge(prodEnv, {
 | 
				
			||||||
  NODE_ENV: '"development"',
 | 
					  NODE_ENV: '"development"',
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,38 +1,83 @@
 | 
				
			|||||||
 | 
					'use strict'
 | 
				
			||||||
 | 
					// Template version: 1.2.6
 | 
				
			||||||
// see http://vuejs-templates.github.io/webpack for documentation.
 | 
					// see http://vuejs-templates.github.io/webpack for documentation.
 | 
				
			||||||
var path = require('path')
 | 
					
 | 
				
			||||||
 | 
					const path = require('path')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
module.exports = {
 | 
					module.exports = {
 | 
				
			||||||
 | 
					  dev: {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Paths
 | 
				
			||||||
 | 
					    assetsSubDirectory: 'static',
 | 
				
			||||||
 | 
					    assetsPublicPath: '/',
 | 
				
			||||||
 | 
					    proxyTable: {},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Various Dev Server settings
 | 
				
			||||||
 | 
					    host: 'localhost', // can be overwritten by process.env.HOST
 | 
				
			||||||
 | 
					    port: 9528, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined
 | 
				
			||||||
 | 
					    autoOpenBrowser: true,
 | 
				
			||||||
 | 
					    errorOverlay: true,
 | 
				
			||||||
 | 
					    notifyOnErrors: false,
 | 
				
			||||||
 | 
					    poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions-
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Use Eslint Loader?
 | 
				
			||||||
 | 
					    // If true, your code will be linted during bundling and
 | 
				
			||||||
 | 
					    // linting errors and warnings will be shown in the console.
 | 
				
			||||||
 | 
					    useEslint: true,
 | 
				
			||||||
 | 
					    // If true, eslint errors and warnings will also be shown in the error overlay
 | 
				
			||||||
 | 
					    // in the browser.
 | 
				
			||||||
 | 
					    showEslintErrorsInOverlay: false,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Source Maps
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // https://webpack.js.org/configuration/devtool/#development
 | 
				
			||||||
 | 
					    devtool: 'eval-source-map',
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // If you have problems debugging vue-files in devtools,
 | 
				
			||||||
 | 
					    // set this to false - it *may* help
 | 
				
			||||||
 | 
					    // https://vue-loader.vuejs.org/en/options.html#cachebusting
 | 
				
			||||||
 | 
					    cacheBusting: true,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // CSS Sourcemaps off by default because relative paths are "buggy"
 | 
				
			||||||
 | 
					    // with this option, according to the CSS-Loader README
 | 
				
			||||||
 | 
					    // (https://github.com/webpack/css-loader#sourcemaps)
 | 
				
			||||||
 | 
					    // In our experience, they generally work as expected,
 | 
				
			||||||
 | 
					    // just be aware of this issue when enabling this option.
 | 
				
			||||||
 | 
					    cssSourceMap: false,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  build: {
 | 
					  build: {
 | 
				
			||||||
    env: require('./prod.env'),
 | 
					    // Template for index.html
 | 
				
			||||||
    index: path.resolve(__dirname, '../dist/index.html'),
 | 
					    index: path.resolve(__dirname, '../dist/index.html'),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Paths
 | 
				
			||||||
    assetsRoot: path.resolve(__dirname, '../dist'),
 | 
					    assetsRoot: path.resolve(__dirname, '../dist'),
 | 
				
			||||||
    assetsSubDirectory: 'static',
 | 
					    assetsSubDirectory: 'static',
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // you can set by youself according to actual condition
 | 
				
			||||||
    assetsPublicPath: './',
 | 
					    assetsPublicPath: './',
 | 
				
			||||||
    productionSourceMap: true,
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Source Maps
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    productionSourceMap: false,
 | 
				
			||||||
 | 
					    // https://webpack.js.org/configuration/devtool/#production
 | 
				
			||||||
 | 
					    devtool: '#source-map',
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // Gzip off by default as many popular static hosts such as
 | 
					    // Gzip off by default as many popular static hosts such as
 | 
				
			||||||
    // Surge or Netlify already gzip all static assets for you.
 | 
					    // Surge or Netlify already gzip all static assets for you.
 | 
				
			||||||
    // Before setting to `true`, make sure to:
 | 
					    // Before setting to `true`, make sure to:
 | 
				
			||||||
    // npm install --save-dev compression-webpack-plugin
 | 
					    // npm install --save-dev compression-webpack-plugin
 | 
				
			||||||
    productionGzip: false,
 | 
					    productionGzip: false,
 | 
				
			||||||
    productionGzipExtensions: ['js', 'css'],
 | 
					    productionGzipExtensions: ['js', 'css'],
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // Run the build command with an extra argument to
 | 
					    // Run the build command with an extra argument to
 | 
				
			||||||
    // View the bundle analyzer report after build finishes:
 | 
					    // View the bundle analyzer report after build finishes:
 | 
				
			||||||
    // `npm run build --report`
 | 
					    // `npm run build --report`
 | 
				
			||||||
    // Set to `true` or `false` to always turn it on or off
 | 
					    // Set to `true` or `false` to always turn it on or off
 | 
				
			||||||
    bundleAnalyzerReport: process.env.npm_config_report
 | 
					    bundleAnalyzerReport: process.env.npm_config_report
 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
  dev: {
 | 
					 | 
				
			||||||
    env: require('./dev.env'),
 | 
					 | 
				
			||||||
    port: 9528,
 | 
					 | 
				
			||||||
    autoOpenBrowser: true,
 | 
					 | 
				
			||||||
    assetsSubDirectory: 'static',
 | 
					 | 
				
			||||||
    assetsPublicPath: '/',
 | 
					 | 
				
			||||||
    proxyTable: {},
 | 
					 | 
				
			||||||
    // CSS Sourcemaps off by default because relative paths are "buggy"
 | 
					 | 
				
			||||||
    // with this option, according to the CSS-Loader README
 | 
					 | 
				
			||||||
    // (https://github.com/webpack/css-loader#sourcemaps)
 | 
					 | 
				
			||||||
    // In our experience, they generally work as expected,
 | 
					 | 
				
			||||||
    // just be aware of this issue when enabling this option.
 | 
					 | 
				
			||||||
    cssSourceMap: false
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,3 +1,4 @@
 | 
				
			|||||||
 | 
					'use strict'
 | 
				
			||||||
module.exports = {
 | 
					module.exports = {
 | 
				
			||||||
  NODE_ENV: '"production"',
 | 
					  NODE_ENV: '"production"',
 | 
				
			||||||
  BASE_API: '"https://easy-mock.com/mock/5950a2419adc231f356a6636/vue-admin"',
 | 
					  BASE_API: '"https://easy-mock.com/mock/5950a2419adc231f356a6636/vue-admin"',
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,6 +2,7 @@
 | 
				
			|||||||
<html>
 | 
					<html>
 | 
				
			||||||
  <head>
 | 
					  <head>
 | 
				
			||||||
    <meta charset="utf-8">
 | 
					    <meta charset="utf-8">
 | 
				
			||||||
 | 
					    <meta name="viewport" content="width=device-width,initial-scale=1.0">
 | 
				
			||||||
    <title>vue-admin-template</title>
 | 
					    <title>vue-admin-template</title>
 | 
				
			||||||
  </head>
 | 
					  </head>
 | 
				
			||||||
  <body>
 | 
					  <body>
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										38
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								package.json
									
									
									
									
									
								
							@@ -5,63 +5,65 @@
 | 
				
			|||||||
  "description": "A vue admin template with Element UI & axios & iconfont & permission control & lint",
 | 
					  "description": "A vue admin template with Element UI & axios & iconfont & permission control & lint",
 | 
				
			||||||
  "author": "Pan <panfree23@gmail.com>",
 | 
					  "author": "Pan <panfree23@gmail.com>",
 | 
				
			||||||
  "scripts": {
 | 
					  "scripts": {
 | 
				
			||||||
    "dev": "node build/dev-server.js",
 | 
					    "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
 | 
				
			||||||
    "start": "node build/dev-server.js",
 | 
					    "start": "npm run dev",
 | 
				
			||||||
    "build": "node build/build.js",
 | 
					    "build": "node build/build.js",
 | 
				
			||||||
    "lint": "eslint --ext .js,.vue src",
 | 
					    "lint": "eslint --ext .js,.vue src",
 | 
				
			||||||
    "test": "npm run lint"
 | 
					    "test": "npm run lint"
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  "dependencies": {
 | 
					  "dependencies": {
 | 
				
			||||||
    "axios": "0.17.1",
 | 
					    "axios": "0.17.1",
 | 
				
			||||||
    "element-ui": "2.0.5",
 | 
					    "element-ui": "2.0.8",
 | 
				
			||||||
    "js-cookie": "2.2.0",
 | 
					    "js-cookie": "2.2.0",
 | 
				
			||||||
    "normalize.css": "7.0.0",
 | 
					    "normalize.css": "7.0.0",
 | 
				
			||||||
    "nprogress": "0.2.0",
 | 
					    "nprogress": "0.2.0",
 | 
				
			||||||
    "vue": "2.5.9",
 | 
					    "vue": "2.5.10",
 | 
				
			||||||
    "vue-router": "3.0.1",
 | 
					    "vue-router": "3.0.1",
 | 
				
			||||||
    "vuex": "3.0.1"
 | 
					    "vuex": "3.0.1"
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  "devDependencies": {
 | 
					  "devDependencies": {
 | 
				
			||||||
    "autoprefixer": "7.1.6",
 | 
					    "autoprefixer": "7.2.3",
 | 
				
			||||||
    "babel-core": "6.26.0",
 | 
					    "babel-core": "6.26.0",
 | 
				
			||||||
    "babel-eslint": "8.0.2",
 | 
					    "babel-eslint": "8.0.3",
 | 
				
			||||||
 | 
					    "babel-helper-vue-jsx-merge-props": "2.0.3",
 | 
				
			||||||
    "babel-loader": "7.1.2",
 | 
					    "babel-loader": "7.1.2",
 | 
				
			||||||
 | 
					    "babel-plugin-syntax-jsx": "6.18.0",
 | 
				
			||||||
    "babel-plugin-transform-runtime": "6.23.0",
 | 
					    "babel-plugin-transform-runtime": "6.23.0",
 | 
				
			||||||
 | 
					    "babel-plugin-transform-vue-jsx": "3.5.0",
 | 
				
			||||||
    "babel-preset-env": "1.6.1",
 | 
					    "babel-preset-env": "1.6.1",
 | 
				
			||||||
    "babel-preset-stage-2": "6.24.1",
 | 
					    "babel-preset-stage-2": "6.24.1",
 | 
				
			||||||
    "babel-register": "6.26.0",
 | 
					 | 
				
			||||||
    "chalk": "2.3.0",
 | 
					    "chalk": "2.3.0",
 | 
				
			||||||
    "connect-history-api-fallback": "1.5.0",
 | 
					 | 
				
			||||||
    "copy-webpack-plugin": "4.2.3",
 | 
					    "copy-webpack-plugin": "4.2.3",
 | 
				
			||||||
    "css-loader": "0.28.7",
 | 
					    "css-loader": "0.28.7",
 | 
				
			||||||
    "eslint": "4.11.0",
 | 
					    "eslint": "4.13.1",
 | 
				
			||||||
    "eslint-friendly-formatter": "3.0.0",
 | 
					    "eslint-friendly-formatter": "3.0.0",
 | 
				
			||||||
    "eslint-loader": "1.9.0",
 | 
					    "eslint-loader": "1.9.0",
 | 
				
			||||||
    "eslint-plugin-html": "4.0.1",
 | 
					    "eslint-plugin-html": "4.0.1",
 | 
				
			||||||
    "eventsource-polyfill": "0.9.6",
 | 
					    "eventsource-polyfill": "0.9.6",
 | 
				
			||||||
    "express": "4.16.2",
 | 
					 | 
				
			||||||
    "extract-text-webpack-plugin": "3.0.2",
 | 
					    "extract-text-webpack-plugin": "3.0.2",
 | 
				
			||||||
    "file-loader": "1.1.5",
 | 
					    "file-loader": "1.1.5",
 | 
				
			||||||
    "friendly-errors-webpack-plugin": "1.6.1",
 | 
					    "friendly-errors-webpack-plugin": "1.6.1",
 | 
				
			||||||
    "html-webpack-plugin": "2.30.1",
 | 
					    "html-webpack-plugin": "2.30.1",
 | 
				
			||||||
    "http-proxy-middleware": "0.17.4",
 | 
					    "node-notifier": "5.1.2",
 | 
				
			||||||
    "node-sass": "^4.7.2",
 | 
					    "node-sass": "^4.7.2",
 | 
				
			||||||
    "opn": "5.1.0",
 | 
					 | 
				
			||||||
    "optimize-css-assets-webpack-plugin": "3.2.0",
 | 
					    "optimize-css-assets-webpack-plugin": "3.2.0",
 | 
				
			||||||
    "ora": "1.3.0",
 | 
					    "ora": "1.3.0",
 | 
				
			||||||
 | 
					    "portfinder": "1.0.13",
 | 
				
			||||||
 | 
					    "postcss-import": "11.0.0",
 | 
				
			||||||
 | 
					    "postcss-loader": "2.0.9",
 | 
				
			||||||
    "rimraf": "2.6.2",
 | 
					    "rimraf": "2.6.2",
 | 
				
			||||||
    "sass-loader": "6.0.6",
 | 
					    "sass-loader": "6.0.6",
 | 
				
			||||||
    "semver": "5.4.1",
 | 
					    "semver": "5.4.1",
 | 
				
			||||||
    "shelljs": "0.7.8",
 | 
					    "shelljs": "0.7.8",
 | 
				
			||||||
    "svg-sprite-loader": "3.4.1",
 | 
					    "svg-sprite-loader": "3.5.2",
 | 
				
			||||||
    "url-loader": "0.6.1",
 | 
					    "uglifyjs-webpack-plugin": "1.1.3",
 | 
				
			||||||
 | 
					    "url-loader": "0.6.2",
 | 
				
			||||||
    "vue-loader": "13.5.0",
 | 
					    "vue-loader": "13.5.0",
 | 
				
			||||||
    "vue-style-loader": "3.0.3",
 | 
					    "vue-style-loader": "3.0.3",
 | 
				
			||||||
    "vue-template-compiler": "2.5.9",
 | 
					    "vue-template-compiler": "2.5.10",
 | 
				
			||||||
    "webpack": "3.8.1",
 | 
					    "webpack": "3.10.0",
 | 
				
			||||||
    "webpack-bundle-analyzer": "2.9.1",
 | 
					    "webpack-bundle-analyzer": "2.9.1",
 | 
				
			||||||
    "webpack-dev-middleware": "1.12.1",
 | 
					    "webpack-dev-server": "2.9.7",
 | 
				
			||||||
    "webpack-hot-middleware": "2.20.0",
 | 
					 | 
				
			||||||
    "webpack-merge": "4.1.1"
 | 
					    "webpack-merge": "4.1.1"
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  "engines": {
 | 
					  "engines": {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -11,6 +11,6 @@ export default {
 | 
				
			|||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<style lang="scss">
 | 
					<style lang="scss">
 | 
				
			||||||
  @import '~normalize.css/normalize.css';// normalize.css 样式格式化
 | 
					  // @import '~normalize.css/normalize.css';// normalize.css 样式格式化
 | 
				
			||||||
  @import './styles/index.scss'; // 全局自定义的css样式
 | 
					  @import './styles/index.scss'; // 全局自定义的css样式
 | 
				
			||||||
</style>
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user