zengyicheng 2 jaren geleden
bovenliggende
commit
a9d25c02f6
100 gewijzigde bestanden met toevoegingen van 4475 en 12340 verwijderingen
  1. 0 12
      .babelrc
  2. 3 0
      .browserslistrc
  3. 2 6
      .editorconfig
  4. 17 0
      .eslintrc.js
  5. 11 1
      .gitignore
  6. 0 10
      .postcssrc.js
  7. 23 1
      README.md
  8. 5 0
      babel.config.js
  9. 0 41
      build/build.js
  10. 0 54
      build/check-versions.js
  11. BIN
      build/logo.png
  12. 0 102
      build/utils.js
  13. 0 22
      build/vue-loader.conf.js
  14. 0 82
      build/webpack.base.conf.js
  15. 0 95
      build/webpack.dev.conf.js
  16. 0 145
      build/webpack.prod.conf.js
  17. 0 7
      config/dev.env.js
  18. 0 70
      config/index.js
  19. 0 4
      config/prod.env.js
  20. 0 48
      index.html
  21. 19 0
      jsconfig.json
  22. 2944 3373
      package-lock.json
  23. 30 82
      package.json
  24. BIN
      public/favicon.ico
  25. 17 0
      public/index.html
  26. 232 261
      src/App.vue
  27. 92 0
      src/api/userApi.js
  28. BIN
      src/assets/anliDetail/down.png
  29. BIN
      src/assets/anliDetail/expand.png
  30. BIN
      src/assets/anliDetail/fileList.png
  31. BIN
      src/assets/anliDetail/first.png
  32. BIN
      src/assets/anliDetail/five.png
  33. BIN
      src/assets/anliDetail/fold.png
  34. BIN
      src/assets/anliDetail/fouth.png
  35. BIN
      src/assets/anliDetail/jdNavBg.png
  36. BIN
      src/assets/anliDetail/jdNewTitle.png
  37. BIN
      src/assets/anliDetail/jdTitle.png
  38. BIN
      src/assets/anliDetail/learnObj.png
  39. BIN
      src/assets/anliDetail/longNavBg.png
  40. BIN
      src/assets/anliDetail/navBg.png
  41. BIN
      src/assets/anliDetail/noFile.jpg
  42. BIN
      src/assets/anliDetail/noFile.png
  43. BIN
      src/assets/anliDetail/onePic.png
  44. BIN
      src/assets/anliDetail/proEff.png
  45. BIN
      src/assets/anliDetail/proEva.png
  46. BIN
      src/assets/anliDetail/proOver.png
  47. BIN
      src/assets/anliDetail/proOverTwo.png
  48. BIN
      src/assets/anliDetail/process.png
  49. BIN
      src/assets/anliDetail/rwTitle.png
  50. BIN
      src/assets/anliDetail/second.png
  51. BIN
      src/assets/anliDetail/six.png
  52. BIN
      src/assets/anliDetail/third.png
  53. BIN
      src/assets/img/icons.png
  54. BIN
      src/assets/img/jj.jpg
  55. BIN
      src/assets/img/login-bg-autumn.jpg
  56. BIN
      src/assets/img/login-logo.png
  57. BIN
      src/assets/img/logo.png
  58. BIN
      src/assets/img/qq.png
  59. BIN
      src/assets/img/sclogo.png
  60. BIN
      src/assets/img/sclogo2.png
  61. BIN
      src/assets/img/sclogo3.png
  62. BIN
      src/assets/img/weixin.png
  63. BIN
      src/assets/logo-mini.png
  64. 539 0
      src/assets/sc/demo.css
  65. 203 0
      src/assets/sc/iconfont.css
  66. 0 0
      src/assets/sc/iconfont.js
  67. 338 0
      src/assets/sc/iconfont.json
  68. BIN
      src/assets/sc/iconfont.ttf
  69. BIN
      src/assets/sc/iconfont.woff
  70. BIN
      src/assets/sc/iconfont.woff2
  71. BIN
      src/assets/vector/down.png
  72. BIN
      src/assets/vector/expand.png
  73. BIN
      src/assets/vector/fileList.png
  74. BIN
      src/assets/vector/first.png
  75. BIN
      src/assets/vector/five.png
  76. BIN
      src/assets/vector/fold.png
  77. BIN
      src/assets/vector/fouth.png
  78. BIN
      src/assets/vector/jdNavBg.png
  79. BIN
      src/assets/vector/jdNewTitle.png
  80. BIN
      src/assets/vector/jdTitle.png
  81. BIN
      src/assets/vector/learnObj.png
  82. BIN
      src/assets/vector/longNavBg.png
  83. BIN
      src/assets/vector/navBg.png
  84. BIN
      src/assets/vector/noFile.jpg
  85. BIN
      src/assets/vector/noFile.png
  86. BIN
      src/assets/vector/onePic.png
  87. BIN
      src/assets/vector/proEff.png
  88. BIN
      src/assets/vector/proEva.png
  89. BIN
      src/assets/vector/proOver.png
  90. BIN
      src/assets/vector/proOverTwo.png
  91. BIN
      src/assets/vector/process.png
  92. BIN
      src/assets/vector/rwTitle.png
  93. BIN
      src/assets/vector/second.png
  94. BIN
      src/assets/vector/six.png
  95. BIN
      src/assets/vector/third.png
  96. 0 174
      src/common/Blob.js
  97. 0 178
      src/common/Export2Excel.js
  98. 0 3
      src/common/aws-sdk-2.235.1.min.js
  99. 0 82
      src/common/axios.config.js
  100. 0 7487
      src/common/pdf.worker.js

+ 0 - 12
.babelrc

@@ -1,12 +0,0 @@
-{
-  "presets": [
-    ["env", {
-      "modules": false,
-      "targets": {
-        "browsers": ["> 1%", "last 2 versions", "not ie <= 8"]
-      }
-    }],
-    "stage-2"
-  ],
-  "plugins": ["transform-vue-jsx", "transform-runtime"]
-}

+ 3 - 0
.browserslistrc

@@ -0,0 +1,3 @@
+> 1%
+last 2 versions
+not dead

+ 2 - 6
.editorconfig

@@ -1,9 +1,5 @@
-root = true
-
-[*]
-charset = utf-8
+[*.{js,jsx,ts,tsx,vue}]
 indent_style = space
 indent_size = 2
-end_of_line = lf
-insert_final_newline = true
 trim_trailing_whitespace = true
+insert_final_newline = true

+ 17 - 0
.eslintrc.js

@@ -0,0 +1,17 @@
+module.exports = {
+  root: true,
+  env: {
+    node: true
+  },
+  extends: [
+    'plugin:vue/essential',
+    '@vue/standard'
+  ],
+  parserOptions: {
+    parser: '@babel/eslint-parser'
+  },
+  rules: {
+    'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
+    'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off'
+  }
+}

+ 11 - 1
.gitignore

@@ -1,8 +1,17 @@
 .DS_Store
-node_modules/
+node_modules
+/dist
+
+
+# local env files
+.env.local
+.env.*.local
+
+# Log files
 npm-debug.log*
 yarn-debug.log*
 yarn-error.log*
+pnpm-debug.log*
 
 # Editor directories and files
 .idea
@@ -11,3 +20,4 @@ yarn-error.log*
 *.ntvs*
 *.njsproj
 *.sln
+*.sw?

+ 0 - 10
.postcssrc.js

@@ -1,10 +0,0 @@
-// https://github.com/michael-ciniawsky/postcss-load-config
-
-module.exports = {
-  "plugins": {
-    "postcss-import": {},
-    "postcss-url": {},
-    // to edit target browsers: use "browserslist" field in package.json
-    "autoprefixer": {}
-  }
-}

+ 23 - 1
README.md

@@ -1,2 +1,24 @@
-# pbl-teacher
+# scproject
 
+## Project setup
+```
+npm install
+```
+
+### Compiles and hot-reloads for development
+```
+npm run serve
+```
+
+### Compiles and minifies for production
+```
+npm run build
+```
+
+### Lints and fixes files
+```
+npm run lint
+```
+
+### Customize configuration
+See [Configuration Reference](https://cli.vuejs.org/config/).

+ 5 - 0
babel.config.js

@@ -0,0 +1,5 @@
+module.exports = {
+  presets: [
+    '@vue/cli-plugin-babel/preset'
+  ]
+}

+ 0 - 41
build/build.js

@@ -1,41 +0,0 @@
-'use strict'
-require('./check-versions')()
-
-process.env.NODE_ENV = 'production'
-
-const ora = require('ora')
-const rm = require('rimraf')
-const path = require('path')
-const chalk = require('chalk')
-const webpack = require('webpack')
-const config = require('../config')
-const webpackConfig = require('./webpack.prod.conf')
-
-const spinner = ora('building for production...')
-spinner.start()
-
-rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => {
-  if (err) throw err
-  webpack(webpackConfig, (err, stats) => {
-    spinner.stop()
-    if (err) throw err
-    process.stdout.write(stats.toString({
-      colors: true,
-      modules: false,
-      children: false, // If you are using ts-loader, setting this to true will make TypeScript errors show up during build.
-      chunks: false,
-      chunkModules: false
-    }) + '\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.yellow(
-      '  Tip: built files are meant to be served over an HTTP server.\n' +
-      '  Opening index.html over file:// won\'t work.\n'
-    ))
-  })
-})

+ 0 - 54
build/check-versions.js

@@ -1,54 +0,0 @@
-'use strict'
-const chalk = require('chalk')
-const semver = require('semver')
-const packageConfig = require('../package.json')
-const shell = require('shelljs')
-
-function exec (cmd) {
-  return require('child_process').execSync(cmd).toString().trim()
-}
-
-const versionRequirements = [
-  {
-    name: 'node',
-    currentVersion: semver.clean(process.version),
-    versionRequirement: packageConfig.engines.node
-  }
-]
-
-if (shell.which('npm')) {
-  versionRequirements.push({
-    name: 'npm',
-    currentVersion: exec('npm --version'),
-    versionRequirement: packageConfig.engines.npm
-  })
-}
-
-module.exports = function () {
-  const warnings = []
-
-  for (let i = 0; i < versionRequirements.length; i++) {
-    const mod = versionRequirements[i]
-
-    if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) {
-      warnings.push(mod.name + ': ' +
-        chalk.red(mod.currentVersion) + ' should be ' +
-        chalk.green(mod.versionRequirement)
-      )
-    }
-  }
-
-  if (warnings.length) {
-    console.log('')
-    console.log(chalk.yellow('To use this template, you must update following to modules:'))
-    console.log()
-
-    for (let i = 0; i < warnings.length; i++) {
-      const warning = warnings[i]
-      console.log('  ' + warning)
-    }
-
-    console.log()
-    process.exit(1)
-  }
-}

BIN
build/logo.png


+ 0 - 102
build/utils.js

@@ -1,102 +0,0 @@
-'use strict'
-const path = require('path')
-const config = require('../config')
-const ExtractTextPlugin = require('extract-text-webpack-plugin')
-const packageConfig = require('../package.json')
-
-exports.assetsPath = function (_path) {
-  const assetsSubDirectory = process.env.NODE_ENV === 'production'
-    ? config.build.assetsSubDirectory
-    : config.dev.assetsSubDirectory
-
-  return path.posix.join(assetsSubDirectory, _path)
-}
-
-exports.cssLoaders = function (options) {
-  options = options || {}
-
-  const cssLoader = {
-    loader: 'css-loader',
-    options: {
-      sourceMap: options.sourceMap
-    }
-  }
-
-  const postcssLoader = {
-    loader: 'postcss-loader',
-    options: {
-      sourceMap: options.sourceMap
-    }
-  }
-
-  // generate loader string to be used with extract text plugin
-  function generateLoaders (loader, loaderOptions) {
-    const loaders = options.usePostCSS ? [cssLoader, postcssLoader] : [cssLoader]
-
-    if (loader) {
-      loaders.push({
-        loader: loader + '-loader',
-        options: Object.assign({}, loaderOptions, {
-          sourceMap: options.sourceMap
-        })
-      })
-    }
-
-    // Extract CSS when that option is specified
-    // (which is the case during production build)
-    if (options.extract) {
-      return ExtractTextPlugin.extract({
-        use: loaders,
-        fallback: 'vue-style-loader',
-        publicPath: '../../'  //在此处添加这行代码
-      })
-    } else {
-      return ['vue-style-loader'].concat(loaders)
-    }
-  }
-
-  // https://vue-loader.vuejs.org/en/configurations/extract-css.html
-  return {
-    css: generateLoaders(),
-    postcss: generateLoaders(),
-    less: generateLoaders('less'),
-    sass: generateLoaders('sass', { indentedSyntax: true }),
-    scss: generateLoaders('sass'),
-    stylus: generateLoaders('stylus'),
-    styl: generateLoaders('stylus')
-  }
-}
-
-// Generate loaders for standalone style files (outside of .vue)
-exports.styleLoaders = function (options) {
-  const output = []
-  const loaders = exports.cssLoaders(options)
-
-  for (const extension in loaders) {
-    const loader = loaders[extension]
-    output.push({
-      test: new RegExp('\\.' + extension + '$'),
-      use: loader
-    })
-  }
-
-  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')
-    })
-  }
-}

+ 0 - 22
build/vue-loader.conf.js

@@ -1,22 +0,0 @@
-'use strict'
-const utils = require('./utils')
-const config = require('../config')
-const isProduction = process.env.NODE_ENV === 'production'
-const sourceMapEnabled = isProduction
-  ? config.build.productionSourceMap
-  : config.dev.cssSourceMap
-
-module.exports = {
-  loaders: utils.cssLoaders({
-    sourceMap: sourceMapEnabled,
-    extract: isProduction
-  }),
-  cssSourceMap: sourceMapEnabled,
-  cacheBusting: config.dev.cacheBusting,
-  transformToRequire: {
-    video: ['src', 'poster'],
-    source: 'src',
-    img: 'src',
-    image: 'xlink:href'
-  }
-}

+ 0 - 82
build/webpack.base.conf.js

@@ -1,82 +0,0 @@
-'use strict'
-const path = require('path')
-const utils = require('./utils')
-const config = require('../config')
-const vueLoaderConfig = require('./vue-loader.conf')
-
-function resolve(dir) {
-  return path.join(__dirname, '..', dir)
-}
-
-
-
-module.exports = {
-  context: path.resolve(__dirname, '../'),
-  entry: {
-    app: './src/main.js'
-  },
-  output: {
-    path: config.build.assetsRoot,
-    filename: '[name].js',
-    publicPath: process.env.NODE_ENV === 'production'
-      ? config.build.assetsPublicPath
-      : config.dev.assetsPublicPath
-  },
-  resolve: {
-    extensions: ['.js', '.vue', '.json'],
-    alias: {
-      'vue$': 'vue/dist/vue.esm.js',
-      '@': resolve('src'),
-    }
-  },
-  module: {
-    rules: [
-      {
-        test: /\.vue$/,
-        loader: 'vue-loader',
-        options: vueLoaderConfig
-      },
-      {
-        test: /\.js$/,
-        loader: 'babel-loader',
-        include: [resolve('src'), resolve('test'), resolve('node_modules/webpack-dev-server/client')]
-      },
-      {
-        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
-        loader: 'url-loader',
-        options: {
-          limit: 10000,
-          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)(\?.*)?$/,
-        loader: 'url-loader',
-        options: {
-          limit: 10000,
-          name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
-        }
-      }
-    ]
-  },
-  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'
-  }
-}

+ 0 - 95
build/webpack.dev.conf.js

@@ -1,95 +0,0 @@
-'use strict'
-const utils = require('./utils')
-const webpack = require('webpack')
-const config = require('../config')
-const merge = require('webpack-merge')
-const path = require('path')
-const baseWebpackConfig = require('./webpack.base.conf')
-const CopyWebpackPlugin = require('copy-webpack-plugin')
-const HtmlWebpackPlugin = require('html-webpack-plugin')
-const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
-const portfinder = require('portfinder')
-
-const HOST = process.env.HOST
-const PORT = process.env.PORT && Number(process.env.PORT)
-
-const devWebpackConfig = merge(baseWebpackConfig, {
-  module: {
-    rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap, usePostCSS: true })
-  },
-  // cheap-module-eval-source-map is faster for development
-  devtool: config.dev.devtool,
-
-  // these devServer options should be customized in /config/index.js
-  devServer: {
-    clientLogLevel: 'warning',
-    historyApiFallback: {
-      rewrites: [
-        { from: /.*/, to: path.posix.join(config.dev.assetsPublicPath, 'index.html') },
-      ],
-    },
-    hot: true,
-    contentBase: false, // since we use CopyWebpackPlugin.
-    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: [
-    new webpack.DefinePlugin({
-      'process.env': require('../config/dev.env')
-    }),
-    new webpack.HotModuleReplacementPlugin(),
-    new webpack.NamedModulesPlugin(), // HMR shows correct file names in console on update.
-    new webpack.NoEmitOnErrorsPlugin(),
-    // https://github.com/ampedandwired/html-webpack-plugin
-    new HtmlWebpackPlugin({
-      filename: 'index.html',
-      template: 'index.html',
-      inject: true
-    }),
-    // copy custom static assets
-    new CopyWebpackPlugin([
-      {
-        from: path.resolve(__dirname, '../static'),
-        to: config.dev.assetsSubDirectory,
-        ignore: ['.*']
-      }
-    ])
-  ]
-})
-
-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)
-    }
-  })
-})

+ 0 - 145
build/webpack.prod.conf.js

@@ -1,145 +0,0 @@
-'use strict'
-const path = require('path')
-const utils = require('./utils')
-const webpack = require('webpack')
-const config = require('../config')
-const merge = require('webpack-merge')
-const baseWebpackConfig = require('./webpack.base.conf')
-const CopyWebpackPlugin = require('copy-webpack-plugin')
-const HtmlWebpackPlugin = require('html-webpack-plugin')
-const ExtractTextPlugin = require('extract-text-webpack-plugin')
-const OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin')
-const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
-
-const env = require('../config/prod.env')
-
-const webpackConfig = merge(baseWebpackConfig, {
-  module: {
-    rules: utils.styleLoaders({
-      sourceMap: config.build.productionSourceMap,
-      extract: true,
-      usePostCSS: true
-    })
-  },
-  devtool: config.build.productionSourceMap ? config.build.devtool : false,
-  output: {
-    path: config.build.assetsRoot,
-    filename: utils.assetsPath('js/[name].[chunkhash].js'),
-    chunkFilename: utils.assetsPath('js/[id].[chunkhash].js')
-  },
-  plugins: [
-    // http://vuejs.github.io/vue-loader/en/workflow/production.html
-    new webpack.DefinePlugin({
-      'process.env': env
-    }),
-    new UglifyJsPlugin({
-      uglifyOptions: {
-        compress: {
-          warnings: false
-        }
-      },
-      sourceMap: config.build.productionSourceMap,
-      parallel: true
-    }),
-    // extract css into its own file
-    new ExtractTextPlugin({
-      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
-    // duplicated CSS from different components can be deduped.
-    new OptimizeCSSPlugin({
-      cssProcessorOptions: config.build.productionSourceMap
-        ? { safe: true, map: { inline: false } }
-        : { safe: true }
-    }),
-    // generate dist index.html with correct asset hash for caching.
-    // you can customize output by editing /index.html
-    // see https://github.com/ampedandwired/html-webpack-plugin
-    new HtmlWebpackPlugin({
-      filename: config.build.index,
-      template: 'index.html',
-      inject: true,
-      minify: {
-        removeComments: true,
-        collapseWhitespace: true,
-        removeAttributeQuotes: true
-        // more options:
-        // https://github.com/kangax/html-minifier#options-quick-reference
-      },
-      // necessary to consistently work with multiple chunks via CommonsChunkPlugin
-      chunksSortMode: 'dependency'
-    }),
-    // keep module.id stable when vendor modules does not change
-    new webpack.HashedModuleIdsPlugin(),
-    // enable scope hoisting
-    new webpack.optimize.ModuleConcatenationPlugin(),
-    // split vendor js into its own file
-    new webpack.optimize.CommonsChunkPlugin({
-      name: 'vendor',
-      minChunks (module) {
-        // any required modules inside node_modules are extracted to vendor
-        return (
-          module.resource &&
-          /\.js$/.test(module.resource) &&
-          module.resource.indexOf(
-            path.join(__dirname, '../node_modules')
-          ) === 0
-        )
-      }
-    }),
-    // extract webpack runtime and module manifest to its own file in order to
-    // prevent vendor hash from being updated whenever app bundle is updated
-    new webpack.optimize.CommonsChunkPlugin({
-      name: 'manifest',
-      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
-    new CopyWebpackPlugin([
-      {
-        from: path.resolve(__dirname, '../static'),
-        to: config.build.assetsSubDirectory,
-        ignore: ['.*']
-      }
-    ])
-  ]
-})
-
-if (config.build.productionGzip) {
-  const CompressionWebpackPlugin = require('compression-webpack-plugin')
-
-  webpackConfig.plugins.push(
-    new CompressionWebpackPlugin({
-      asset: '[path].gz[query]',
-      algorithm: 'gzip',
-      test: new RegExp(
-        '\\.(' +
-        config.build.productionGzipExtensions.join('|') +
-        ')$'
-      ),
-      threshold: 10240,
-      minRatio: 0.8
-    })
-  )
-}
-
-if (config.build.bundleAnalyzerReport) {
-  const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin
-  webpackConfig.plugins.push(new BundleAnalyzerPlugin())
-}
-
-module.exports = webpackConfig

+ 0 - 7
config/dev.env.js

@@ -1,7 +0,0 @@
-'use strict'
-const merge = require('webpack-merge')
-const prodEnv = require('./prod.env')
-
-module.exports = merge(prodEnv, {
-  NODE_ENV: '"development"'
-})

+ 0 - 70
config/index.js

@@ -1,70 +0,0 @@
-'use strict'
-// Template version: 1.3.1
-// see http://vuejs-templates.github.io/webpack for documentation.
-
-const path = require('path')
-
-module.exports = {
-  dev: {
-
-    // Paths
-    assetsSubDirectory: 'static',
-    assetsPublicPath: '/',
-    proxyTable: {},
-
-    // Various Dev Server settings
-    host: 'localhost', // can be overwritten by process.env.HOST
-    port: 8080, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined
-    autoOpenBrowser: false,
-    errorOverlay: true,
-    notifyOnErrors: true,
-    poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions-
-
-    
-    /**
-     * Source Maps
-     */
-
-    // https://webpack.js.org/configuration/devtool/#development
-    devtool: 'cheap-module-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,
-
-    cssSourceMap: true
-  },
-
-  build: {
-    // Template for index.html
-    index: path.resolve(__dirname, '../dist/index.html'),
-
-    // Paths
-    assetsRoot: path.resolve(__dirname, '../dist'),
-    assetsSubDirectory: 'static',
-    assetsPublicPath: './',
-
-    /**
-     * Source Maps
-     */
-
-    productionSourceMap: true,
-    // https://webpack.js.org/configuration/devtool/#production
-    devtool: '#source-map',
-    // devtool: 'cheap-module-eval-source-map',
-
-    // Gzip off by default as many popular static hosts such as
-    // Surge or Netlify already gzip all static assets for you.
-    // Before setting to `true`, make sure to:
-    // npm install --save-dev compression-webpack-plugin
-    productionGzip: false,
-    productionGzipExtensions: ['js', 'css'],
-
-    // Run the build command with an extra argument to
-    // View the bundle analyzer report after build finishes:
-    // `npm run build --report`
-    // Set to `true` or `false` to always turn it on or off
-    bundleAnalyzerReport: process.env.npm_config_report
-  }
-}

+ 0 - 4
config/prod.env.js

@@ -1,4 +0,0 @@
-'use strict'
-module.exports = {
-  NODE_ENV: '"production"'
-}

+ 0 - 48
index.html

@@ -1,48 +0,0 @@
-<!DOCTYPE html>
-<html>
-
-<head>
-    <meta charset="utf-8">
-    <meta name="viewport" content="width=device-width,initial-scale=1.0">
-    <title></title>
-    <link rel="shortcut icon" type="image/x-icon" href="static/logo1.ico">
-    <style>
-        @charset "utf-8";
-        div::-webkit-scrollbar {
-            /*滚动条整体样式*/
-            width: 6px;
-            /*高宽分别对应横竖滚动条的尺寸*/
-            height: 6px;
-        }
-        /*定义滚动条轨道 内阴影+圆角*/
-        
-        div::-webkit-scrollbar-track {
-            border-radius: 10px;
-            background-color: rgba(0, 0, 0, 0.1);
-        }
-        /*定义滑块 内阴影+圆角*/
-        
-        div::-webkit-scrollbar-thumb {
-            border-radius: 10px;
-            -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);
-            background-color: rgba(0, 0, 0, 0.1);
-        }
-        
-        html,
-        body {
-            height: 100%;
-            width: 100%;
-            background: #e6eaf0;
-        }
-    </style>
-</head>
-
-<body>
-    <div id="app"></div>
-    <!-- built files will be auto injected -->
-</body>
-
-</html>
-<script>
-    document.domain = document.domain.split(".").slice(-2).join(".");
-</script>

+ 19 - 0
jsconfig.json

@@ -0,0 +1,19 @@
+{
+  "compilerOptions": {
+    "target": "es5",
+    "module": "esnext",
+    "baseUrl": "./",
+    "moduleResolution": "node",
+    "paths": {
+      "@/*": [
+        "src/*"
+      ]
+    },
+    "lib": [
+      "esnext",
+      "dom",
+      "dom.iterable",
+      "scripthost"
+    ]
+  }
+}

File diff suppressed because it is too large
+ 2944 - 3373
package-lock.json


+ 30 - 82
package.json

@@ -1,91 +1,39 @@
 {
-  "name": "cocoroboworkpc",
-  "version": "1.0.0",
-  "description": "A Vue.js project",
-  "author": "lsc <1249685148@qq.com>",
+  "name": "scproject",
+  "version": "0.1.0",
   "private": true,
   "scripts": {
-    "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
-    "start": "npm run dev",
-    "build": "node build/build.js"
+    "serve": "vue-cli-service serve",
+    "build": "vue-cli-service build",
+    "lint": "vue-cli-service lint"
   },
   "dependencies": {
-    "axios": "^0.21.1",
-    "cacache": "^16.1.1",
-    "clipboard": "^2.0.10",
-    "echarts": "^5.0.2",
-    "element-china-area-data": "^5.0.2",
-    "element-ui": "^2.15.1",
-    "file-saver": "^2.0.5",
-    "hevue-img-preview": "^5.0.3",
-    "html-docx-js": "^0.3.1",
-    "html2canvas": "^1.4.1",
-    "jquery": "^3.6.0",
-    "js-audio-recorder": "^1.0.7",
-    "js-pinyin": "^0.1.9",
-    "jsmind": "^0.4.8",
-    "lamejs": "^1.2.1",
-    "pdfjs-dist": "^2.5.207",
-    "pdfvuer": "^1.7.5",
-    "qs": "^6.10.1",
-    "v-viewer": "^1.6.4",
-    "vant": "^2.12.10",
-    "vue": "^2.5.2",
-    "vue-cookies": "^1.7.4",
-    "vue-pdf": "^4.2.0",
-    "vue-router": "^3.0.1",
-    "vue-video-player": "^5.0.2",
-    "vuedraggable": "^2.24.3",
+    "axios": "^1.2.1",
+    "core-js": "^3.8.3",
+    "element-ui": "^2.4.5",
+    "less": "^4.1.3",
+    "less-loader": "^11.1.0",
+    "vue": "^2.6.14",
+    "vue-router": "^3.5.1",
+    "vue2-editor": "^2.10.3",
     "vuex": "^3.6.2",
-    "wangeditor": "^4.6.14",
-    "xlsx": "^0.16.9"
+    "vuex-persistedstate": "^4.1.0"
   },
   "devDependencies": {
-    "autoprefixer": "^7.1.2",
-    "babel-core": "^6.22.1",
-    "babel-helper-vue-jsx-merge-props": "^2.0.3",
-    "babel-loader": "^7.1.1",
-    "babel-plugin-syntax-jsx": "^6.18.0",
-    "babel-plugin-transform-runtime": "^6.22.0",
-    "babel-plugin-transform-vue-jsx": "^3.5.0",
-    "babel-preset-env": "^1.3.2",
-    "babel-preset-stage-2": "^6.22.0",
-    "chalk": "^2.0.1",
-    "copy-webpack-plugin": "^4.0.1",
-    "css-loader": "^0.28.0",
-    "extract-text-webpack-plugin": "^3.0.0",
-    "file-loader": "^1.1.4",
-    "friendly-errors-webpack-plugin": "^1.6.1",
-    "html-webpack-plugin": "^2.30.1",
-    "node-notifier": "^5.1.2",
-    "node-sass": "^7.0.1",
-    "optimize-css-assets-webpack-plugin": "^3.2.0",
-    "ora": "^1.2.0",
-    "portfinder": "^1.0.13",
-    "postcss-import": "^11.0.0",
-    "postcss-loader": "^2.0.8",
-    "postcss-url": "^7.2.1",
-    "rimraf": "^2.6.0",
-    "script-loader": "^0.7.2",
-    "semver": "^5.3.0",
-    "shelljs": "^0.7.6",
-    "uglifyjs-webpack-plugin": "^1.1.1",
-    "url-loader": "^0.5.8",
-    "vue-loader": "^13.3.0",
-    "vue-style-loader": "^3.0.1",
-    "vue-template-compiler": "^2.5.2",
-    "webpack": "^3.6.0",
-    "webpack-bundle-analyzer": "^2.9.0",
-    "webpack-dev-server": "^2.9.1",
-    "webpack-merge": "^4.1.0"
-  },
-  "engines": {
-    "node": ">= 6.0.0",
-    "npm": ">= 3.0.0"
-  },
-  "browserslist": [
-    "> 1%",
-    "last 2 versions",
-    "not ie <= 8"
-  ]
+    "@babel/core": "^7.12.16",
+    "@babel/eslint-parser": "^7.12.16",
+    "@vue/cli-plugin-babel": "~5.0.0",
+    "@vue/cli-plugin-eslint": "~5.0.0",
+    "@vue/cli-plugin-router": "~5.0.0",
+    "@vue/cli-plugin-vuex": "~5.0.0",
+    "@vue/cli-service": "~5.0.0",
+    "@vue/eslint-config-standard": "^6.1.0",
+    "eslint": "^7.32.0",
+    "eslint-plugin-import": "^2.25.3",
+    "eslint-plugin-node": "^11.1.0",
+    "eslint-plugin-promise": "^5.1.0",
+    "eslint-plugin-vue": "^8.0.3",
+    "vue-cli-plugin-element": "^1.0.1",
+    "vue-template-compiler": "^2.6.14"
+  }
 }

BIN
public/favicon.ico


+ 17 - 0
public/index.html

@@ -0,0 +1,17 @@
+<!DOCTYPE html>
+<html lang="">
+  <head>
+    <meta charset="utf-8">
+    <meta http-equiv="X-UA-Compatible" content="IE=edge">
+    <meta name="viewport" content="width=device-width,initial-scale=1.0">
+    <!-- <link rel="icon" href="<%= BASE_URL %>favicon.ico"> -->
+    <title>双创学院</title>
+  </head>
+  <body>
+    <!-- <noscript>
+      <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
+    </noscript> -->
+    <div id="app"></div>
+    <!-- built files will be auto injected -->
+  </body>
+</html>

+ 232 - 261
src/App.vue

@@ -1,270 +1,241 @@
 <template>
-  <div id="app" :class="{}">
-    <div
-      style="width: 100%; height: 100%"
-      :class="{
-        ggheight: true,
-      }"
-    >
-      <!-- main 内容 -->
-      <keep-alive v-if="$route.meta.keepAlive">
-        <!-- 这里是会被缓存的视图组件 -->
-        <router-view
-          v-if="$route.meta.keepAlive"
-          :class="{ pb_body: isShowNav }"
-        />
-      </keep-alive>
-      <!-- 这里是不被缓存的视图组件 -->
-      <router-view
-        v-if="!$route.meta.keepAlive"
-        :class="{ pb_body: isShowNav }"
-      />
-
-      <!-- 底部导航 -->
-      <!-- <footer-nav
-        v-if="isShowNav"
-        :nav="nav"
-        :luyou="this.$store.state.luyou"
-      ></footer-nav> -->
-    </div>
+  <div class="page">
+      <el-header v-if="$route.meta.isAuth">
+        <img src="./assets/img/sclogo3.png" alt="">
+        <div class="homeExitContent">
+          <div>袁一鸣</div>
+          <div class="homeExit" @click="homeExit">退出</div>
+        </div>
+      </el-header>
+
+    <router-view></router-view>
   </div>
 </template>
 
 <script>
-import leftBar from "./components/tools/leftBar";
-import { Message } from "element-ui";
-export default {
-  name: "App",
-  data() {
-    return {
-      isShowNav: false, // 是否显示导航 Tab
-      navTabs: [
-       
-      ],
-
-      nav: [],
-    };
-  },
-  components: {
-    "footer-nav": leftBar,
-  },
-  methods: {
-  },
-  watch: {
-    $route(to, from) {
-      const { navTabs, navTabs2, navTabs3 } = this.$data;
-      const { userInfo } = this.$store.state;
-      const toPath = to.path;
-      const fromName = from.name;
-    },
-  },
-  created() {
-  },
-};
+    export default {
+        data() {
+          return {
+            
+          }
+        },
+        methods:{
+          homeExit(){
+          this.$router.push('/login')
+        }
+        }
+    }
 </script>
 
-<style>
-* {
-  margin: 0;
-  padding: 0;
-}
-
-body {
-  font-family: "Helvetica Neue", Helvetica, "PingFang SC", "Hiragino Sans GB",
-    "Microsoft YaHei", "微软雅黑", Arial, sans-serif;
-}
-
-#app {
-  height: 100%;
-  width: 100%;
-  background: #e6eaf0;
-  /* min-width: 1380px; */
-  /* min-width: 1250px; */
-}
-
-.appNoWidth {
-  min-width: unset !important;
-  display: inline-block !important;
-  min-width: 550px;
-}
-
-.appNoHeight {
-  min-height: 750px;
-}
-
-.app_head,
-.app_headBg {
-  height: 50px;
-  width: 100%;
-  background-color: #293e68;
-  display: flex;
-  align-items: center;
-  min-width: 1000px;
-}
-
-/* .app_headBg {
-  background: url("./assets/icon/topBg.png");
-} */
-
-/* .logo {
-  height: 40px;
-  width: 40px;
-  background: url("./assets/logo1.png");
-  background-size: 100% 100%;
-  margin-left: 20px;
-} */
-
-.pb_body {
-  margin-left: 220px;
-  width: calc(100% - 240px) !important;
-  /* min-width: 1140px; */
-  min-width: 750px;
-  display: inline-block;
-  /* height: calc(100% - 100px); */
-  /* min-height: 750px; */
-  background: #fff;
-  margin-top: 20px;
-  border-radius: 5px;
-  position: absolute;
-  height: calc(100% - 100px);
-  overflow: auto;
-}
-
-.ggheight {
-  height: calc(100% - 67.5px) !important;
-}
-
-.pb_head {
-  font-size: 26px;
-  /* font-weight: 600; */
-  width: 95%;
-  margin: 10px auto;
-  padding: 10px 5px;
-  border-bottom: 1px solid #eee;
-}
-
-.pb_content {
-  /* height: 100%; */
-}
-
-.pb_content_body {
-  width: 94%;
-  margin: 10px auto;
-  /* overflow: auto;
-	  height: calc(100% - 120px); */
-}
-
-.user_head {
-  display: flex;
-  align-items: center;
-  margin-left: auto;
-  margin-right: 20px;
-  font-size: 18px;
-  font-weight: 600;
-}
-
-.user_head .user_name {
-  color: #fff;
-  margin-right: 10px;
-}
-
-.user_head div {
-  display: flex;
-  align-items: center;
-  cursor: pointer;
-}
-
-/* .user_head .exitI {
-  background-image: url("./assets/exit.png");
-  width: 25px;
-  height: 25px;
-  background-size: 100% 100%;
-  margin-top: 1px;
-  line-height: 25px;
-  vertical-align: text-top;
-  background-repeat: no-repeat;
-} */
-
-.noticeBox {
-  position: relative;
-  margin-right: 10px;
-}
-
-/* .user_head .noticeI {
-  background-image: url("./assets/icon/noticeA.png");
-  width: 25px;
-  height: 25px;
-  background-size: 100% 100%;
-  margin-top: 1px;
-  line-height: 25px;
-  vertical-align: text-top;
-  background-repeat: no-repeat;
-  cursor: pointer;
-} */
-
-.noticeBox span {
-  position: absolute;
-  background: red;
-  width: 15px;
-  height: 15px;
-  border-radius: 30px;
-  color: #fff;
-  text-align: center;
-  font-size: 12px;
-  display: flex;
-  align-items: center;
-  justify-content: center;
-  top: -3px;
-  right: -3px;
-}
-
-.stuWidth {
-  min-width: 1180px;
-}
-
-.gHeight {
-  height: 100%;
-}
-
-html::-webkit-scrollbar {
-  /*滚动条整体样式*/
-  width: 6px;
-  /*高宽分别对应横竖滚动条的尺寸*/
-  height: 6px;
-}
-
-/*定义滚动条轨道 内阴影+圆角*/
-html::-webkit-scrollbar {
-  border-radius: 10px;
-  background-color: #eee;
-}
-
-/*定义滑块 内阴影+圆角*/
-html::-webkit-scrollbar-thumb {
-  border-radius: 10px;
-  -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
-  background-color: rgba(0, 0, 0, 0.1);
-}
-
-.btnClassGM {
-  background: #8681b7 !important;
-  border-color: #8681b7 !important;
-}
-
-.btnClassGM:focus,
-.btnClassGM:hover {
-  background: #8681b7 !important;
-  border-color: #8681b7 !important;
-}
-
-.GMBg {
-  background: rgb(184, 181, 202) !important;
-}
+<style lang="less">
+  *{
+    margin: 0;
+    padding: 0;
+  }
+  html,body{
+    height: 100%;
+    width: 100%;
+    overflow:hidden ;
+  }
+  hr{   //hr横线
+    border: none;
+    height: 1px;
+    width: 100%;
+    margin: 5px 0px 10px 0px;
+    background: #ccc;
+  }
+
+  .pAHeader{    //一级页面一级标题 
+    width: 100%;
+    overflow: hidden;
+    display: flex;
+    height: 35px;
+    justify-content: space-between;
+    margin-bottom: 15px;
+    .pAHeader1{
+      font-weight: 600;
+      font-size: 22px;
+      text-align: left;
+    }
+    
+    [type='button']{
+        background: #0e72e6 !important;
+        color: #fff !important;
+        display: flex;
+        font-size: 14px;
+        align-items: center;
+      }
+      [type='button']:hover{
+        background: #3b85d9 !important;
+      }
+  }
+
+  .pA1Header{   //二级页面一级标题
+    width: 90%;
+    display: flex;
+    height: 35px;
+    justify-content:space-between;
+    margin-bottom: 15px;
+    .pAHeader1{
+      text-align: left;
+      width: 150px;
+      font-weight: 600;
+      font-size: 22px;
+      flex-shrink: 0;
+    }
+    .pAHeader1STit{
+      font-size: 16px;
+      margin-top: 10px;
+    }
+  }
+
+  .tabTit{   //二级页面二级标题
+        width: 100%;
+        font-size: 18px;
+        font-weight:bold;
+        margin-top: 20px;
+        margin-bottom: 5px;
+        display: flex;
+        justify-content: space-between;
+        [type='button']{
+        background: #0e72e6 !important;
+        color: #fff !important;
+        display: flex;
+        justify-content: center;
+        font-size: 16px;
+        width: 100px;
+        height: 30px;
+        align-items: center;
+      }
+    }
+
+
+  .page{  //app最基础页面
+    height: 100%;
+    width: 100%;
+    background: #e6eaf0;
+    img{
+      height: 40px;
+    }
+    .el-header {    //顶部退出区域
+        background-color: #3d67bc;
+        color: #333;
+        text-align: center;
+        display: flex;
+        justify-content: space-between;
+        align-items: center;
+        .homeExitContent{
+          color: #fff;
+          display: flex;
+          justify-content: space-between;
+          width: 150px;
+          .homeExit{
+            background: #ffffff;
+            color: #000;
+            cursor: pointer;
+            width: 90px;
+          }
+        }
+    }
+  }
+
+  .operations{   //所有表格按钮栏
+    display: flex;
+    flex-shrink: 0;
+    [type='button']{
+      font-size: 14px;
+    }
+  }
+  .fontSize{   //所有表格字体大小
+    margin-top: 15px;
+    font-size: 16px !important;
+  }
+  // 滚动条样式
+  .core_dialogue {
+      height: 100%;
+      overflow: scroll;
+    }
+    .core_dialogue::-webkit-scrollbar-track-piece {
+      background-color: #f8f8f800;
+    }
+    .core_dialogue::-webkit-scrollbar {
+      width: 6px;
+      transition: all 2s;
+    }
+    .core_dialogue::-webkit-scrollbar-thumb {
+      background-color: #929292;
+      border-radius: 100px;
+    }
+    .core_dialogue::-webkit-scrollbar-thumb:hover {
+      background-color: #bbb;
+    }
+  .core_dialogue::-webkit-scrollbar-corner {
+    background-color: rgba(255, 255, 255, 0);
+  }
+
+
+  .select{ //活动申请填写信息区域
+          width: 100%;
+          box-sizing: border-box;
+          .label{   //label标签
+            min-width: 98px;
+            margin-right: 5px;
+            display: inline-block;
+            text-align: justify;
+            text-justify:distribute-all-lines;
+            text-align-last: justify;
+            transform: translate(0,22%);
+            padding-right: 15px;
+            font-size: 16px;
+          }
+          .inpBlock{    //一个个输入框小方块
+            display: flex;
+            margin-bottom: 15px;
+          }
+
+          .selectTop{
+            width: 60%;
+            display: flex;
+          }
+
+          .selectMid{
+            display: flex;
+            margin-top: 20px;
+
+            .selectLeft{
+              width: 30%;
+              display: flex;
+              flex-direction: column;
+              margin-right: 70px;
+              
+            }
+            .selectRight{
+              width: 20%;
+              height: 150px;
+              display: flex;
+              flex-direction: column;
+            }
+            
+          }
+    }
+
+  .AppBar{    //横行的跳转导航栏
+    display: flex;
+    margin-top: 15px;
+    margin-bottom: 20px;
+    div{
+      width: 110px;
+      cursor: pointer;
+      font-weight: 550;
+      font-size: 18px;
+    }
+    .pr1TitBass{
+        margin-top: 2px;
+        height: 4px;
+        border-radius: 2px;
+        width: 100%;
+        background: #2a7ea9;
+      }
+  }
 
-.cancelbtnGM:focus,
-.cancelbtnGM:hover {
-  color: rgb(92, 84, 159) !important;
-  border-color: #5c549f !important;
-  background-color: #dbd7ff !important;
-}
 </style>

+ 92 - 0
src/api/userApi.js

@@ -0,0 +1,92 @@
+import axios from "axios";
+import qs from 'qs'
+// let jwt=require('express')
+axios.defaults.timeout=30000;  //响应时间
+axios.defaults.headers.post["Content-Type"]=
+         "application/x-www-form-urlencoded";"charset=UTF-8;"
+   
+    
+axios.defaults.baseURL='http://10.3.16.76:2004'  //接口地址
+
+// 请求拦截
+axios.interceptors.request.use(
+    (config)=>{
+        let token = sessionStorage.getItem('assess_token') || ''; //获取token
+        // console.log(token);
+        if(token !=''){
+            config.headers={
+                // 'assess_token':token,
+                'Authorization':token,
+                "Content-type":"application/x-www-from-urlencoded"
+            };
+            console.log(config.headers);
+        // alert('111')
+
+        }
+        // console.log(config);
+        // config.data=qs.stringify(config.data)  //序列化post参数
+        // console.log(config.data);
+        return config;
+    },
+    (error)=>{
+        console.log("错误的传参");
+        return Promise.reject(error)
+    }
+)
+
+// 响应拦截
+axios.interceptors.response.use(
+     (res)=> {
+        // console.log(res);
+        if (res.data.status==0) {
+            let newToken=res.data.token;//成功后更新token
+            sessionStorage.setItem("assess_token",newToken)
+        }
+    return res;
+  },(error)=>{
+    if(error.res.data.status=="401"){
+        this.$router.push('/login')
+    }
+    return Promise.reject(error);
+  });
+
+  function post(url,params){
+    return new Promise((resolve,reject)=>{
+        console.log(params);
+        axios
+            .post(url,params)
+            .then(
+                (res)=>{
+                    resolve(res)
+                },
+                (err)=>{
+                    reject(err)
+                }
+            )
+            .catch((error)=>{
+                reject(error)
+            });
+    });
+  }
+
+  function get(url,param){
+    return new Promise((resolve,reject)=>{
+        axios
+            .get(url,{params:param})
+            .then((res)=>{
+                resolve(res);
+                },
+                (err)=>{
+                    reject(err)
+                }
+            )
+            .catch((error)=>{
+                    reject(error)
+            });
+    })
+  }
+
+  export default{
+    get,
+    post,
+  }

BIN
src/assets/anliDetail/down.png


BIN
src/assets/anliDetail/expand.png


BIN
src/assets/anliDetail/fileList.png


BIN
src/assets/anliDetail/first.png


BIN
src/assets/anliDetail/five.png


BIN
src/assets/anliDetail/fold.png


BIN
src/assets/anliDetail/fouth.png


BIN
src/assets/anliDetail/jdNavBg.png


BIN
src/assets/anliDetail/jdNewTitle.png


BIN
src/assets/anliDetail/jdTitle.png


BIN
src/assets/anliDetail/learnObj.png


BIN
src/assets/anliDetail/longNavBg.png


BIN
src/assets/anliDetail/navBg.png


BIN
src/assets/anliDetail/noFile.jpg


BIN
src/assets/anliDetail/noFile.png


BIN
src/assets/anliDetail/onePic.png


BIN
src/assets/anliDetail/proEff.png


BIN
src/assets/anliDetail/proEva.png


BIN
src/assets/anliDetail/proOver.png


BIN
src/assets/anliDetail/proOverTwo.png


BIN
src/assets/anliDetail/process.png


BIN
src/assets/anliDetail/rwTitle.png


BIN
src/assets/anliDetail/second.png


BIN
src/assets/anliDetail/six.png


BIN
src/assets/anliDetail/third.png


BIN
src/assets/img/icons.png


BIN
src/assets/img/jj.jpg


BIN
src/assets/img/login-bg-autumn.jpg


BIN
src/assets/img/login-logo.png


BIN
src/assets/img/logo.png


BIN
src/assets/img/qq.png


BIN
src/assets/img/sclogo.png


BIN
src/assets/img/sclogo2.png


BIN
src/assets/img/sclogo3.png


BIN
src/assets/img/weixin.png


BIN
src/assets/logo-mini.png


+ 539 - 0
src/assets/sc/demo.css

@@ -0,0 +1,539 @@
+/* Logo 字体 */
+@font-face {
+  font-family: "iconfont logo";
+  src: url('https://at.alicdn.com/t/font_985780_km7mi63cihi.eot?t=1545807318834');
+  src: url('https://at.alicdn.com/t/font_985780_km7mi63cihi.eot?t=1545807318834#iefix') format('embedded-opentype'),
+    url('https://at.alicdn.com/t/font_985780_km7mi63cihi.woff?t=1545807318834') format('woff'),
+    url('https://at.alicdn.com/t/font_985780_km7mi63cihi.ttf?t=1545807318834') format('truetype'),
+    url('https://at.alicdn.com/t/font_985780_km7mi63cihi.svg?t=1545807318834#iconfont') format('svg');
+}
+
+.logo {
+  font-family: "iconfont logo";
+  font-size: 160px;
+  font-style: normal;
+  -webkit-font-smoothing: antialiased;
+  -moz-osx-font-smoothing: grayscale;
+}
+
+/* tabs */
+.nav-tabs {
+  position: relative;
+}
+
+.nav-tabs .nav-more {
+  position: absolute;
+  right: 0;
+  bottom: 0;
+  height: 42px;
+  line-height: 42px;
+  color: #666;
+}
+
+#tabs {
+  border-bottom: 1px solid #eee;
+}
+
+#tabs li {
+  cursor: pointer;
+  width: 100px;
+  height: 40px;
+  line-height: 40px;
+  text-align: center;
+  font-size: 16px;
+  border-bottom: 2px solid transparent;
+  position: relative;
+  z-index: 1;
+  margin-bottom: -1px;
+  color: #666;
+}
+
+
+#tabs .active {
+  border-bottom-color: #f00;
+  color: #222;
+}
+
+.tab-container .content {
+  display: none;
+}
+
+/* 页面布局 */
+.main {
+  padding: 30px 100px;
+  width: 960px;
+  margin: 0 auto;
+}
+
+.main .logo {
+  color: #333;
+  text-align: left;
+  margin-bottom: 30px;
+  line-height: 1;
+  height: 110px;
+  margin-top: -50px;
+  overflow: hidden;
+  *zoom: 1;
+}
+
+.main .logo a {
+  font-size: 160px;
+  color: #333;
+}
+
+.helps {
+  margin-top: 40px;
+}
+
+.helps pre {
+  padding: 20px;
+  margin: 10px 0;
+  border: solid 1px #e7e1cd;
+  background-color: #fffdef;
+  overflow: auto;
+}
+
+.icon_lists {
+  width: 100% !important;
+  overflow: hidden;
+  *zoom: 1;
+}
+
+.icon_lists li {
+  width: 100px;
+  margin-bottom: 10px;
+  margin-right: 20px;
+  text-align: center;
+  list-style: none !important;
+  cursor: default;
+}
+
+.icon_lists li .code-name {
+  line-height: 1.2;
+}
+
+.icon_lists .icon {
+  display: block;
+  height: 100px;
+  line-height: 100px;
+  font-size: 42px;
+  margin: 10px auto;
+  color: #333;
+  -webkit-transition: font-size 0.25s linear, width 0.25s linear;
+  -moz-transition: font-size 0.25s linear, width 0.25s linear;
+  transition: font-size 0.25s linear, width 0.25s linear;
+}
+
+.icon_lists .icon:hover {
+  font-size: 100px;
+}
+
+.icon_lists .svg-icon {
+  /* 通过设置 font-size 来改变图标大小 */
+  width: 1em;
+  /* 图标和文字相邻时,垂直对齐 */
+  vertical-align: -0.15em;
+  /* 通过设置 color 来改变 SVG 的颜色/fill */
+  fill: currentColor;
+  /* path 和 stroke 溢出 viewBox 部分在 IE 下会显示
+      normalize.css 中也包含这行 */
+  overflow: hidden;
+}
+
+.icon_lists li .name,
+.icon_lists li .code-name {
+  color: #666;
+}
+
+/* markdown 样式 */
+.markdown {
+  color: #666;
+  font-size: 14px;
+  line-height: 1.8;
+}
+
+.highlight {
+  line-height: 1.5;
+}
+
+.markdown img {
+  vertical-align: middle;
+  max-width: 100%;
+}
+
+.markdown h1 {
+  color: #404040;
+  font-weight: 500;
+  line-height: 40px;
+  margin-bottom: 24px;
+}
+
+.markdown h2,
+.markdown h3,
+.markdown h4,
+.markdown h5,
+.markdown h6 {
+  color: #404040;
+  margin: 1.6em 0 0.6em 0;
+  font-weight: 500;
+  clear: both;
+}
+
+.markdown h1 {
+  font-size: 28px;
+}
+
+.markdown h2 {
+  font-size: 22px;
+}
+
+.markdown h3 {
+  font-size: 16px;
+}
+
+.markdown h4 {
+  font-size: 14px;
+}
+
+.markdown h5 {
+  font-size: 12px;
+}
+
+.markdown h6 {
+  font-size: 12px;
+}
+
+.markdown hr {
+  height: 1px;
+  border: 0;
+  background: #e9e9e9;
+  margin: 16px 0;
+  clear: both;
+}
+
+.markdown p {
+  margin: 1em 0;
+}
+
+.markdown>p,
+.markdown>blockquote,
+.markdown>.highlight,
+.markdown>ol,
+.markdown>ul {
+  width: 80%;
+}
+
+.markdown ul>li {
+  list-style: circle;
+}
+
+.markdown>ul li,
+.markdown blockquote ul>li {
+  margin-left: 20px;
+  padding-left: 4px;
+}
+
+.markdown>ul li p,
+.markdown>ol li p {
+  margin: 0.6em 0;
+}
+
+.markdown ol>li {
+  list-style: decimal;
+}
+
+.markdown>ol li,
+.markdown blockquote ol>li {
+  margin-left: 20px;
+  padding-left: 4px;
+}
+
+.markdown code {
+  margin: 0 3px;
+  padding: 0 5px;
+  background: #eee;
+  border-radius: 3px;
+}
+
+.markdown strong,
+.markdown b {
+  font-weight: 600;
+}
+
+.markdown>table {
+  border-collapse: collapse;
+  border-spacing: 0px;
+  empty-cells: show;
+  border: 1px solid #e9e9e9;
+  width: 95%;
+  margin-bottom: 24px;
+}
+
+.markdown>table th {
+  white-space: nowrap;
+  color: #333;
+  font-weight: 600;
+}
+
+.markdown>table th,
+.markdown>table td {
+  border: 1px solid #e9e9e9;
+  padding: 8px 16px;
+  text-align: left;
+}
+
+.markdown>table th {
+  background: #F7F7F7;
+}
+
+.markdown blockquote {
+  font-size: 90%;
+  color: #999;
+  border-left: 4px solid #e9e9e9;
+  padding-left: 0.8em;
+  margin: 1em 0;
+}
+
+.markdown blockquote p {
+  margin: 0;
+}
+
+.markdown .anchor {
+  opacity: 0;
+  transition: opacity 0.3s ease;
+  margin-left: 8px;
+}
+
+.markdown .waiting {
+  color: #ccc;
+}
+
+.markdown h1:hover .anchor,
+.markdown h2:hover .anchor,
+.markdown h3:hover .anchor,
+.markdown h4:hover .anchor,
+.markdown h5:hover .anchor,
+.markdown h6:hover .anchor {
+  opacity: 1;
+  display: inline-block;
+}
+
+.markdown>br,
+.markdown>p>br {
+  clear: both;
+}
+
+
+.hljs {
+  display: block;
+  background: white;
+  padding: 0.5em;
+  color: #333333;
+  overflow-x: auto;
+}
+
+.hljs-comment,
+.hljs-meta {
+  color: #969896;
+}
+
+.hljs-string,
+.hljs-variable,
+.hljs-template-variable,
+.hljs-strong,
+.hljs-emphasis,
+.hljs-quote {
+  color: #df5000;
+}
+
+.hljs-keyword,
+.hljs-selector-tag,
+.hljs-type {
+  color: #a71d5d;
+}
+
+.hljs-literal,
+.hljs-symbol,
+.hljs-bullet,
+.hljs-attribute {
+  color: #0086b3;
+}
+
+.hljs-section,
+.hljs-name {
+  color: #63a35c;
+}
+
+.hljs-tag {
+  color: #333333;
+}
+
+.hljs-title,
+.hljs-attr,
+.hljs-selector-id,
+.hljs-selector-class,
+.hljs-selector-attr,
+.hljs-selector-pseudo {
+  color: #795da3;
+}
+
+.hljs-addition {
+  color: #55a532;
+  background-color: #eaffea;
+}
+
+.hljs-deletion {
+  color: #bd2c00;
+  background-color: #ffecec;
+}
+
+.hljs-link {
+  text-decoration: underline;
+}
+
+/* 代码高亮 */
+/* PrismJS 1.15.0
+https://prismjs.com/download.html#themes=prism&languages=markup+css+clike+javascript */
+/**
+ * prism.js default theme for JavaScript, CSS and HTML
+ * Based on dabblet (http://dabblet.com)
+ * @author Lea Verou
+ */
+code[class*="language-"],
+pre[class*="language-"] {
+  color: black;
+  background: none;
+  text-shadow: 0 1px white;
+  font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
+  text-align: left;
+  white-space: pre;
+  word-spacing: normal;
+  word-break: normal;
+  word-wrap: normal;
+  line-height: 1.5;
+
+  -moz-tab-size: 4;
+  -o-tab-size: 4;
+  tab-size: 4;
+
+  -webkit-hyphens: none;
+  -moz-hyphens: none;
+  -ms-hyphens: none;
+  hyphens: none;
+}
+
+pre[class*="language-"]::-moz-selection,
+pre[class*="language-"] ::-moz-selection,
+code[class*="language-"]::-moz-selection,
+code[class*="language-"] ::-moz-selection {
+  text-shadow: none;
+  background: #b3d4fc;
+}
+
+pre[class*="language-"]::selection,
+pre[class*="language-"] ::selection,
+code[class*="language-"]::selection,
+code[class*="language-"] ::selection {
+  text-shadow: none;
+  background: #b3d4fc;
+}
+
+@media print {
+
+  code[class*="language-"],
+  pre[class*="language-"] {
+    text-shadow: none;
+  }
+}
+
+/* Code blocks */
+pre[class*="language-"] {
+  padding: 1em;
+  margin: .5em 0;
+  overflow: auto;
+}
+
+:not(pre)>code[class*="language-"],
+pre[class*="language-"] {
+  background: #f5f2f0;
+}
+
+/* Inline code */
+:not(pre)>code[class*="language-"] {
+  padding: .1em;
+  border-radius: .3em;
+  white-space: normal;
+}
+
+.token.comment,
+.token.prolog,
+.token.doctype,
+.token.cdata {
+  color: slategray;
+}
+
+.token.punctuation {
+  color: #999;
+}
+
+.namespace {
+  opacity: .7;
+}
+
+.token.property,
+.token.tag,
+.token.boolean,
+.token.number,
+.token.constant,
+.token.symbol,
+.token.deleted {
+  color: #905;
+}
+
+.token.selector,
+.token.attr-name,
+.token.string,
+.token.char,
+.token.builtin,
+.token.inserted {
+  color: #690;
+}
+
+.token.operator,
+.token.entity,
+.token.url,
+.language-css .token.string,
+.style .token.string {
+  color: #9a6e3a;
+  background: hsla(0, 0%, 100%, .5);
+}
+
+.token.atrule,
+.token.attr-value,
+.token.keyword {
+  color: #07a;
+}
+
+.token.function,
+.token.class-name {
+  color: #DD4A68;
+}
+
+.token.regex,
+.token.important,
+.token.variable {
+  color: #e90;
+}
+
+.token.important,
+.token.bold {
+  font-weight: bold;
+}
+
+.token.italic {
+  font-style: italic;
+}
+
+.token.entity {
+  cursor: help;
+}

+ 203 - 0
src/assets/sc/iconfont.css

@@ -0,0 +1,203 @@
+@font-face {
+  font-family: "iconfont"; /* Project id 3913969 */
+  src: url('iconfont.woff2?t=1677202349266') format('woff2'),
+       url('iconfont.woff?t=1677202349266') format('woff'),
+       url('iconfont.ttf?t=1677202349266') format('truetype');
+}
+
+.iconfont {
+  font-family: "iconfont" !important;
+  font-size: 16px;
+  font-style: normal;
+  -webkit-font-smoothing: antialiased;
+  -moz-osx-font-smoothing: grayscale;
+}
+
+.icon-shezhi:before {
+  content: "\e600";
+}
+
+.icon-tongzhi:before {
+  content: "\e601";
+}
+
+.icon-lieri:before {
+  content: "\e602";
+}
+
+.icon-shuben:before {
+  content: "\e625";
+}
+
+.icon-lifangtilitiduomiantifangkuai:before {
+  content: "\e7fa";
+}
+
+.icon-zijinguanli:before {
+  content: "\e61b";
+}
+
+.icon-icon-project:before {
+  content: "\e64a";
+}
+
+.icon-cubelifangti:before {
+  content: "\e6fc";
+}
+
+.icon-yinliang:before {
+  content: "\e87a";
+}
+
+.icon-wenjian:before {
+  content: "\e632";
+}
+
+.icon-project_management:before {
+  content: "\e60c";
+}
+
+.icon-duoren:before {
+  content: "\e6b4";
+}
+
+.icon-xiaoxitongzhi:before {
+  content: "\ec35";
+}
+
+.icon-_yuanhuanchong:before {
+  content: "\e60f";
+}
+
+.icon-xiazai:before {
+  content: "\e63b";
+}
+
+.icon-iconfont_bi_lineBar-:before {
+  content: "\e705";
+}
+
+.icon-xiangmu:before {
+  content: "\e628";
+}
+
+.icon-qushi:before {
+  content: "\e60d";
+}
+
+.icon-xiazai1:before {
+  content: "\e618";
+}
+
+.icon-xiazai2:before {
+  content: "\e631";
+}
+
+.icon-touxiang:before {
+  content: "\e6de";
+}
+
+.icon-touxiang1:before {
+  content: "\e62c";
+}
+
+.icon-biaodan:before {
+  content: "\e635";
+}
+
+.icon-jiegou:before {
+  content: "\e6e4";
+}
+
+.icon-xiaoxi_huaban:before {
+  content: "\e615";
+}
+
+.icon-xiangmuguanli:before {
+  content: "\e617";
+}
+
+.icon--zuozhengcailiao:before {
+  content: "\e692";
+}
+
+.icon-qushi1:before {
+  content: "\e63d";
+}
+
+.icon-lifangxing:before {
+  content: "\e620";
+}
+
+.icon-xiaoxitongzhi1:before {
+  content: "\e69e";
+}
+
+.icon-touxiang2:before {
+  content: "\e65d";
+}
+
+.icon-zijinguanli1:before {
+  content: "\e640";
+}
+
+.icon-baogao:before {
+  content: "\e633";
+}
+
+.icon--zuozhengcailiao1:before {
+  content: "\e613";
+}
+
+.icon-rishi:before {
+  content: "\e896";
+}
+
+.icon-yonghu:before {
+  content: "\e603";
+}
+
+.icon-baogao1:before {
+  content: "\f5c0";
+}
+
+.icon-touxiang21:before {
+  content: "\e616";
+}
+
+.icon-xiaoxitongzhi2:before {
+  content: "\e647";
+}
+
+.icon-biaodan1:before {
+  content: "\e614";
+}
+
+.icon-duoren1:before {
+  content: "\e604";
+}
+
+.icon-xiangmuguanli1:before {
+  content: "\e680";
+}
+
+.icon-zuzhijiegou:before {
+  content: "\e691";
+}
+
+.icon-duoren-copy:before {
+  content: "\e605";
+}
+
+.icon-xiangmuguanli2:before {
+  content: "\e64e";
+}
+
+.icon-zijinguanli2:before {
+  content: "\e803";
+}
+
+.icon-xiaoxitongzhi3:before {
+  content: "\e606";
+}
+

File diff suppressed because it is too large
+ 0 - 0
src/assets/sc/iconfont.js


+ 338 - 0
src/assets/sc/iconfont.json

@@ -0,0 +1,338 @@
+{
+  "id": "3913969",
+  "name": "shuangchuang",
+  "font_family": "iconfont",
+  "css_prefix_text": "icon-",
+  "description": "",
+  "glyphs": [
+    {
+      "icon_id": "1247",
+      "name": "设置",
+      "font_class": "shezhi",
+      "unicode": "e600",
+      "unicode_decimal": 58880
+    },
+    {
+      "icon_id": "1381",
+      "name": "通知",
+      "font_class": "tongzhi",
+      "unicode": "e601",
+      "unicode_decimal": 58881
+    },
+    {
+      "icon_id": "1457",
+      "name": "烈日",
+      "font_class": "lieri",
+      "unicode": "e602",
+      "unicode_decimal": 58882
+    },
+    {
+      "icon_id": "397957",
+      "name": "书本",
+      "font_class": "shuben",
+      "unicode": "e625",
+      "unicode_decimal": 58917
+    },
+    {
+      "icon_id": "689263",
+      "name": "立方体 立体 多面体 方块",
+      "font_class": "lifangtilitiduomiantifangkuai",
+      "unicode": "e7fa",
+      "unicode_decimal": 59386
+    },
+    {
+      "icon_id": "701250",
+      "name": "资金管理",
+      "font_class": "zijinguanli",
+      "unicode": "e61b",
+      "unicode_decimal": 58907
+    },
+    {
+      "icon_id": "712281",
+      "name": "项目管理",
+      "font_class": "icon-project",
+      "unicode": "e64a",
+      "unicode_decimal": 58954
+    },
+    {
+      "icon_id": "792438",
+      "name": "cube-立方体",
+      "font_class": "cubelifangti",
+      "unicode": "e6fc",
+      "unicode_decimal": 59132
+    },
+    {
+      "icon_id": "2076215",
+      "name": "音量",
+      "font_class": "yinliang",
+      "unicode": "e87a",
+      "unicode_decimal": 59514
+    },
+    {
+      "icon_id": "3465022",
+      "name": "项目附件",
+      "font_class": "wenjian",
+      "unicode": "e632",
+      "unicode_decimal": 58930
+    },
+    {
+      "icon_id": "3513168",
+      "name": "项目管理",
+      "font_class": "project_management",
+      "unicode": "e60c",
+      "unicode_decimal": 58892
+    },
+    {
+      "icon_id": "4818877",
+      "name": "多人",
+      "font_class": "duoren",
+      "unicode": "e6b4",
+      "unicode_decimal": 59060
+    },
+    {
+      "icon_id": "5767876",
+      "name": "消息通知",
+      "font_class": "xiaoxitongzhi",
+      "unicode": "ec35",
+      "unicode_decimal": 60469
+    },
+    {
+      "icon_id": "5922285",
+      "name": "151_圆缓冲",
+      "font_class": "_yuanhuanchong",
+      "unicode": "e60f",
+      "unicode_decimal": 58895
+    },
+    {
+      "icon_id": "5943954",
+      "name": "下载",
+      "font_class": "xiazai",
+      "unicode": "e63b",
+      "unicode_decimal": 58939
+    },
+    {
+      "icon_id": "6081761",
+      "name": "iconfont_bi_lineBar-",
+      "font_class": "iconfont_bi_lineBar-",
+      "unicode": "e705",
+      "unicode_decimal": 59141
+    },
+    {
+      "icon_id": "7171160",
+      "name": "项目管理",
+      "font_class": "xiangmu",
+      "unicode": "e628",
+      "unicode_decimal": 58920
+    },
+    {
+      "icon_id": "8156501",
+      "name": "趋势",
+      "font_class": "qushi",
+      "unicode": "e60d",
+      "unicode_decimal": 58893
+    },
+    {
+      "icon_id": "8767555",
+      "name": "下载",
+      "font_class": "xiazai1",
+      "unicode": "e618",
+      "unicode_decimal": 58904
+    },
+    {
+      "icon_id": "9165174",
+      "name": "下载",
+      "font_class": "xiazai2",
+      "unicode": "e631",
+      "unicode_decimal": 58929
+    },
+    {
+      "icon_id": "9874537",
+      "name": "KHCFDC_头像 ",
+      "font_class": "touxiang",
+      "unicode": "e6de",
+      "unicode_decimal": 59102
+    },
+    {
+      "icon_id": "10905612",
+      "name": "头像",
+      "font_class": "touxiang1",
+      "unicode": "e62c",
+      "unicode_decimal": 58924
+    },
+    {
+      "icon_id": "11121432",
+      "name": "表单",
+      "font_class": "biaodan",
+      "unicode": "e635",
+      "unicode_decimal": 58933
+    },
+    {
+      "icon_id": "12592141",
+      "name": "结构",
+      "font_class": "jiegou",
+      "unicode": "e6e4",
+      "unicode_decimal": 59108
+    },
+    {
+      "icon_id": "12752069",
+      "name": "消息",
+      "font_class": "xiaoxi_huaban",
+      "unicode": "e615",
+      "unicode_decimal": 58901
+    },
+    {
+      "icon_id": "12771489",
+      "name": "项目管理",
+      "font_class": "xiangmuguanli",
+      "unicode": "e617",
+      "unicode_decimal": 58903
+    },
+    {
+      "icon_id": "13442444",
+      "name": "-佐证材料",
+      "font_class": "-zuozhengcailiao",
+      "unicode": "e692",
+      "unicode_decimal": 59026
+    },
+    {
+      "icon_id": "14064339",
+      "name": "趋势",
+      "font_class": "qushi1",
+      "unicode": "e63d",
+      "unicode_decimal": 58941
+    },
+    {
+      "icon_id": "15549710",
+      "name": "立方形",
+      "font_class": "lifangxing",
+      "unicode": "e620",
+      "unicode_decimal": 58912
+    },
+    {
+      "icon_id": "16365897",
+      "name": "消息通知",
+      "font_class": "xiaoxitongzhi1",
+      "unicode": "e69e",
+      "unicode_decimal": 59038
+    },
+    {
+      "icon_id": "16372303",
+      "name": "头像",
+      "font_class": "touxiang2",
+      "unicode": "e65d",
+      "unicode_decimal": 58973
+    },
+    {
+      "icon_id": "17343788",
+      "name": "资金管理",
+      "font_class": "zijinguanli1",
+      "unicode": "e640",
+      "unicode_decimal": 58944
+    },
+    {
+      "icon_id": "17771165",
+      "name": "报告",
+      "font_class": "baogao",
+      "unicode": "e633",
+      "unicode_decimal": 58931
+    },
+    {
+      "icon_id": "18821094",
+      "name": "-佐证材料",
+      "font_class": "-zuozhengcailiao1",
+      "unicode": "e613",
+      "unicode_decimal": 58899
+    },
+    {
+      "icon_id": "19213097",
+      "name": "日食",
+      "font_class": "rishi",
+      "unicode": "e896",
+      "unicode_decimal": 59542
+    },
+    {
+      "icon_id": "21703163",
+      "name": "头像",
+      "font_class": "yonghu",
+      "unicode": "e603",
+      "unicode_decimal": 58883
+    },
+    {
+      "icon_id": "21816422",
+      "name": "报告",
+      "font_class": "baogao1",
+      "unicode": "f5c0",
+      "unicode_decimal": 62912
+    },
+    {
+      "icon_id": "23509001",
+      "name": "头像2",
+      "font_class": "touxiang21",
+      "unicode": "e616",
+      "unicode_decimal": 58902
+    },
+    {
+      "icon_id": "23719384",
+      "name": "消息通知",
+      "font_class": "xiaoxitongzhi2",
+      "unicode": "e647",
+      "unicode_decimal": 58951
+    },
+    {
+      "icon_id": "26182278",
+      "name": "表单",
+      "font_class": "biaodan1",
+      "unicode": "e614",
+      "unicode_decimal": 58900
+    },
+    {
+      "icon_id": "26554441",
+      "name": "多人",
+      "font_class": "duoren1",
+      "unicode": "e604",
+      "unicode_decimal": 58884
+    },
+    {
+      "icon_id": "28410707",
+      "name": "项目管理",
+      "font_class": "xiangmuguanli1",
+      "unicode": "e680",
+      "unicode_decimal": 59008
+    },
+    {
+      "icon_id": "28410794",
+      "name": "组织结构",
+      "font_class": "zuzhijiegou",
+      "unicode": "e691",
+      "unicode_decimal": 59025
+    },
+    {
+      "icon_id": "28847497",
+      "name": "多人",
+      "font_class": "duoren-copy",
+      "unicode": "e605",
+      "unicode_decimal": 58885
+    },
+    {
+      "icon_id": "31403621",
+      "name": "项目管理",
+      "font_class": "xiangmuguanli2",
+      "unicode": "e64e",
+      "unicode_decimal": 58958
+    },
+    {
+      "icon_id": "32303154",
+      "name": "资金管理",
+      "font_class": "zijinguanli2",
+      "unicode": "e803",
+      "unicode_decimal": 59395
+    },
+    {
+      "icon_id": "33940370",
+      "name": "消息通知",
+      "font_class": "xiaoxitongzhi3",
+      "unicode": "e606",
+      "unicode_decimal": 58886
+    }
+  ]
+}

BIN
src/assets/sc/iconfont.ttf


BIN
src/assets/sc/iconfont.woff


BIN
src/assets/sc/iconfont.woff2


BIN
src/assets/vector/down.png


BIN
src/assets/vector/expand.png


BIN
src/assets/vector/fileList.png


BIN
src/assets/vector/first.png


BIN
src/assets/vector/five.png


BIN
src/assets/vector/fold.png


BIN
src/assets/vector/fouth.png


BIN
src/assets/vector/jdNavBg.png


BIN
src/assets/vector/jdNewTitle.png


BIN
src/assets/vector/jdTitle.png


BIN
src/assets/vector/learnObj.png


BIN
src/assets/vector/longNavBg.png


BIN
src/assets/vector/navBg.png


BIN
src/assets/vector/noFile.jpg


BIN
src/assets/vector/noFile.png


BIN
src/assets/vector/onePic.png


BIN
src/assets/vector/proEff.png


BIN
src/assets/vector/proEva.png


BIN
src/assets/vector/proOver.png


BIN
src/assets/vector/proOverTwo.png


BIN
src/assets/vector/process.png


BIN
src/assets/vector/rwTitle.png


BIN
src/assets/vector/second.png


BIN
src/assets/vector/six.png


BIN
src/assets/vector/third.png


+ 0 - 174
src/common/Blob.js

@@ -1,174 +0,0 @@
-/* eslint-disable */
-/* Blob.js
- * A Blob implementation.
- * 2014-05-27
- *
- * By Eli Grey, http://eligrey.com
- * By Devin Samarin, https://github.com/eboyjr
- * License: X11/MIT
- *   See LICENSE.md
- */
-
-/*global self, unescape */
-/*jslint bitwise: true, regexp: true, confusion: true, es5: true, vars: true, white: true,
- plusplus: true */
-
-/*! @source http://purl.eligrey.com/github/Blob.js/blob/master/Blob.js */
-
-(function (view) {
-    view.URL = view.URL || view.webkitURL;
-
-    if (view.Blob && view.URL) {
-        try {
-            new Blob;
-            return;
-        } catch (e) { }
-    }
-
-    // Internally we use a BlobBuilder implementation to base Blob off of
-    // in order to support older browsers that only have BlobBuilder
-    var BlobBuilder = view.BlobBuilder || view.WebKitBlobBuilder || view.MozBlobBuilder || (function (view) {
-        var
-            get_class = function (object) {
-                return Object.prototype.toString.call(object).match(/^\[object\s(.*)\]$/)[1];
-            },
-            FakeBlobBuilder = function BlobBuilder() {
-                this.data = [];
-            },
-            FakeBlob = function Blob(data, type, encoding) {
-                this.data = data;
-                this.size = data.length;
-                this.type = type;
-                this.encoding = encoding;
-            },
-            FBB_proto = FakeBlobBuilder.prototype,
-            FB_proto = FakeBlob.prototype,
-            FileReaderSync = view.FileReaderSync,
-            FileException = function (type) {
-                this.code = this[this.name = type];
-            },
-            file_ex_codes = (
-                "NOT_FOUND_ERR SECURITY_ERR ABORT_ERR NOT_READABLE_ERR ENCODING_ERR " +
-                "NO_MODIFICATION_ALLOWED_ERR INVALID_STATE_ERR SYNTAX_ERR"
-            ).split(" "),
-            file_ex_code = file_ex_codes.length,
-            real_URL = view.URL || view.webkitURL || view,
-            real_create_object_URL = real_URL.createObjectURL,
-            real_revoke_object_URL = real_URL.revokeObjectURL,
-            URL = real_URL,
-            btoa = view.btoa,
-            atob = view.atob
-
-            ,
-            ArrayBuffer = view.ArrayBuffer,
-            Uint8Array = view.Uint8Array;
-        FakeBlob.fake = FB_proto.fake = true;
-        while (file_ex_code--) {
-            FileException.prototype[file_ex_codes[file_ex_code]] = file_ex_code + 1;
-        }
-        if (!real_URL.createObjectURL) {
-            URL = view.URL = {};
-        }
-        URL.createObjectURL = function (blob) {
-            var
-                type = blob.type,
-                data_URI_header;
-            if (type === null) {
-                type = "application/octet-stream";
-            }
-            if (blob instanceof FakeBlob) {
-                data_URI_header = "data:" + type;
-                if (blob.encoding === "base64") {
-                    return data_URI_header + ";base64," + blob.data;
-                } else if (blob.encoding === "URI") {
-                    return data_URI_header + "," + decodeURIComponent(blob.data);
-                }
-                if (btoa) {
-                    return data_URI_header + ";base64," + btoa(blob.data);
-                } else {
-                    return data_URI_header + "," + encodeURIComponent(blob.data);
-                }
-            } else if (real_create_object_URL) {
-                return real_create_object_URL.call(real_URL, blob);
-            }
-        };
-        URL.revokeObjectURL = function (object_URL) {
-            if (object_URL.substring(0, 5) !== "data:" && real_revoke_object_URL) {
-                real_revoke_object_URL.call(real_URL, object_URL);
-            }
-        };
-        FBB_proto.append = function (data /*, endings*/) {
-            var bb = this.data;
-            // decode data to a binary string
-            if (Uint8Array && (data instanceof ArrayBuffer || data instanceof Uint8Array)) {
-                var
-                    str = "",
-                    buf = new Uint8Array(data),
-                    i = 0,
-                    buf_len = buf.length;
-                for (; i < buf_len; i++) {
-                    str += String.fromCharCode(buf[i]);
-                }
-                bb.push(str);
-            } else if (get_class(data) === "Blob" || get_class(data) === "File") {
-                if (FileReaderSync) {
-                    var fr = new FileReaderSync;
-                    bb.push(fr.readAsBinaryString(data));
-                } else {
-                    // async FileReader won't work as BlobBuilder is sync
-                    throw new FileException("NOT_READABLE_ERR");
-                }
-            } else if (data instanceof FakeBlob) {
-                if (data.encoding === "base64" && atob) {
-                    bb.push(atob(data.data));
-                } else if (data.encoding === "URI") {
-                    bb.push(decodeURIComponent(data.data));
-                } else if (data.encoding === "raw") {
-                    bb.push(data.data);
-                }
-            } else {
-                if (typeof data !== "string") {
-                    data += ""; // convert unsupported types to strings
-                }
-                // decode UTF-16 to binary string
-                bb.push(unescape(encodeURIComponent(data)));
-            }
-        };
-        FBB_proto.getBlob = function (type) {
-            if (!arguments.length) {
-                type = null;
-            }
-            return new FakeBlob(this.data.join(""), type, "raw");
-        };
-        FBB_proto.toString = function () {
-            return "[object BlobBuilder]";
-        };
-        FB_proto.slice = function (start, end, type) {
-            var args = arguments.length;
-            if (args < 3) {
-                type = null;
-            }
-            return new FakeBlob(
-                this.data.slice(start, args > 1 ? end : this.data.length), type, this.encoding
-            );
-        };
-        FB_proto.toString = function () {
-            return "[object Blob]";
-        };
-        FB_proto.close = function () {
-            this.size = this.data.length = 0;
-        };
-        return FakeBlobBuilder;
-    }(view));
-
-    view.Blob = function Blob(blobParts, options) {
-        var type = options ? (options.type || "") : "";
-        var builder = new BlobBuilder();
-        if (blobParts) {
-            for (var i = 0, len = blobParts.length; i < len; i++) {
-                builder.append(blobParts[i]);
-            }
-        }
-        return builder.getBlob(type);
-    };
-}(typeof self !== "undefined" && self || typeof window !== "undefined" && window || this.content || this));

+ 0 - 178
src/common/Export2Excel.js

@@ -1,178 +0,0 @@
-/* eslint-disable */
-require('script-loader!file-saver');
-require('script-loader!./Blob');
-require('script-loader!xlsx/dist/xlsx.core.min');
-
-function generateArray(table) {
-  var out = [];
-  var rows = table.querySelectorAll('tr');
-  var ranges = [];
-  for (var R = 0; R < rows.length; ++R) {
-    var outRow = [];
-    var row = rows[R];
-    var columns = row.querySelectorAll('td');
-    for (var C = 0; C < columns.length; ++C) {
-      var cell = columns[C];
-      var colspan = cell.getAttribute('colspan');
-      var rowspan = cell.getAttribute('rowspan');
-      var cellValue = cell.innerText;
-      if (cellValue !== "" && cellValue == +cellValue) cellValue = +cellValue;
-
-      //Skip ranges
-      ranges.forEach(function (range) {
-        if (R >= range.s.r && R <= range.e.r && outRow.length >= range.s.c && outRow.length <= range.e.c) {
-          for (var i = 0; i <= range.e.c - range.s.c; ++i) outRow.push(null);
-        }
-      });
-
-      //Handle Row Span
-      if (rowspan || colspan) {
-        rowspan = rowspan || 1;
-        colspan = colspan || 1;
-        ranges.push({
-          s: {
-            r: R,
-            c: outRow.length
-          },
-          e: {
-            r: R + rowspan - 1,
-            c: outRow.length + colspan - 1
-          }
-        });
-      };
-
-      //Handle Value
-      outRow.push(cellValue !== "" ? cellValue : null);
-
-      //Handle Colspan
-      if (colspan)
-        for (var k = 0; k < colspan - 1; ++k) outRow.push(null);
-    }
-    out.push(outRow);
-  }
-  return [out, ranges];
-};
-
-function datenum(v, date1904) {
-  if (date1904) v += 1462;
-  var epoch = Date.parse(v);
-  return (epoch - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000);
-}
-
-function sheet_from_array_of_arrays(data, opts) {
-  var ws = {};
-  var range = {
-    s: {
-      c: 10000000,
-      r: 10000000
-    },
-    e: {
-      c: 0,
-      r: 0
-    }
-  };
-  for (var R = 0; R != data.length; ++R) {
-    for (var C = 0; C != data[R].length; ++C) {
-      if (range.s.r > R) range.s.r = R;
-      if (range.s.c > C) range.s.c = C;
-      if (range.e.r < R) range.e.r = R;
-      if (range.e.c < C) range.e.c = C;
-      var cell = {
-        v: data[R][C]
-      };
-      if (cell.v == null) continue;
-      var cell_ref = XLSX.utils.encode_cell({
-        c: C,
-        r: R
-      });
-
-      if (typeof cell.v === 'number') cell.t = 'n';
-      else if (typeof cell.v === 'boolean') cell.t = 'b';
-      else if (cell.v instanceof Date) {
-        cell.t = 'n';
-        cell.z = XLSX.SSF._table[14];
-        cell.v = datenum(cell.v);
-      } else cell.t = 's';
-
-      ws[cell_ref] = cell;
-    }
-  }
-  if (range.s.c < 10000000) ws['!ref'] = XLSX.utils.encode_range(range);
-  return ws;
-}
-
-function Workbook() {
-  if (!(this instanceof Workbook)) return new Workbook();
-  this.SheetNames = [];
-  this.Sheets = {};
-}
-
-function s2ab(s) {
-  var buf = new ArrayBuffer(s.length);
-  var view = new Uint8Array(buf);
-  for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
-  return buf;
-}
-
-export function export_table_to_excel(id) {
-  var theTable = document.getElementById(id);
-  console.log('a')
-  var oo = generateArray(theTable);
-  var ranges = oo[1];
-
-  /* original data */
-  var data = oo[0];
-  var ws_name = "SheetJS";
-  console.log(data);
-
-  var wb = new Workbook(),
-    ws = sheet_from_array_of_arrays(data);
-
-  /* add ranges to worksheet */
-  // ws['!cols'] = ['apple', 'banan'];
-  ws['!merges'] = ranges;
-
-  /* add worksheet to workbook */
-  wb.SheetNames.push(ws_name);
-  wb.Sheets[ws_name] = ws;
-
-  var wbout = XLSX.write(wb, {
-    bookType: 'xlsx',
-    bookSST: false,
-    type: 'binary'
-  });
-
-  saveAs(new Blob([s2ab(wbout)], {
-    type: "application/octet-stream"
-  }), "test.xlsx")
-}
-
-function formatJson(jsonData) {
-  console.log(jsonData)
-}
-export function export_json_to_excel(th, jsonData, defaultTitle) {
-
-  /* original data */
-
-  var data = jsonData;
-  data.unshift(th);
-  var ws_name = "SheetJS";
-
-  var wb = new Workbook(),
-    ws = sheet_from_array_of_arrays(data);
-
-
-  /* add worksheet to workbook */
-  wb.SheetNames.push(ws_name);
-  wb.Sheets[ws_name] = ws;
-
-  var wbout = XLSX.write(wb, {
-    bookType: 'xlsx',
-    bookSST: false,
-    type: 'binary'
-  });
-  var title = defaultTitle || '列表'
-  saveAs(new Blob([s2ab(wbout)], {
-    type: "application/octet-stream"
-  }), title + ".xlsx")
-}

File diff suppressed because it is too large
+ 0 - 3
src/common/aws-sdk-2.235.1.min.js


+ 0 - 82
src/common/axios.config.js

@@ -1,82 +0,0 @@
-import axios from "axios"
-import qs from "qs"
-axios.defaults.timeout = 30000   //响应时间
-axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';        //配置请求头
-axios.defaults.baseURL = process.env.NODE_HOST;   //配置接口地址
-console.log(process.env)
-//POST传参序列化(添加请求拦截器)
-axios.interceptors.request.use((config) => {
-    //在发送请求之前做某件事
-    let token = sessionStorage.getItem('access_token') || ""  //获取token 
-    console.log(token)
-    if (token != "") {
-        config.headers = {
-            'access-token': token,
-            'Content-Type': 'application/x-www-form-urlencoded'
-        }
-    }
-    // if (config.data && config.data[0].post == '1' && config.method === 'post') {
-    //     // config.headers.post['Content-Type'] = 'application/json;charset=UTF-8';
-    //     // config.data = config.data//序列化post 参数
-    //     config.data = 'mode=' + (Object.values(config.data[0]).join(','))//序列化post 参数
-    // } else if (config.method === 'post') {
-    //     config.data = qs.stringify(config.data)//序列化post 参数
-    // }
-    if (config.data && config.data[0].post == '1' && config.method === 'post') {
-        config.data = 'mode=' + (Object.values(config.data[0]).join(','))//序列化post 参数
-    } else if(config.method === 'post') {
-        config.data = qs.stringify(config.data)//序列化post 参数
-    }
-    return config;
-}, (error) => {
-    console.log('错误的传参')
-
-    return Promise.reject(error);
-});
-//返回状态判断(添加响应拦截器)
-axios.interceptors.response.use((res) => {
-    //对响应数据做些事
-    if (!res.data.success) {
-        let newToken = res.data.token    //成功后更新token 
-        localStorage.setItem('access_token', newToken)
-
-    }
-    return res;
-}, (error) => {
-    if (error.response.data.status == '401') {    //如果token 过期 则跳转到登录页面
-        this.$router.push('/login');
-    }
-    return Promise.reject(error);
-});
-//返回一个Promise(发送post请求)
-function post(url, params) {
-    return new Promise((resolve, reject) => {
-        axios.post(url, params)
-            .then(response => {
-                resolve(response);
-            }, err => {
-                reject(err);
-            })
-            .catch((error) => {
-                reject(error)
-            })
-    })
-}
-////返回一个Promise(发送get请求)
-function get(url, param) {
-    return new Promise((resolve, reject) => {
-        axios.get(url, { params: param })
-            .then(response => {
-                resolve(response)
-            }, err => {
-                reject(err)
-            })
-            .catch((error) => {
-                reject(error)
-            })
-    })
-}
-export default {
-    get,
-    post,
-}

File diff suppressed because it is too large
+ 0 - 7487
src/common/pdf.worker.js


Some files were not shown because too many files changed in this diff