Browse Source

新增管理后台模板

panyong 1 year ago
parent
commit
c435a04ee2
100 changed files with 2445 additions and 0 deletions
  1. 14 0
      htmldev/manageTemplate/.editorconfig
  2. 6 0
      htmldev/manageTemplate/.env.development
  3. 6 0
      htmldev/manageTemplate/.env.production
  4. 4 0
      htmldev/manageTemplate/.eslintignore
  5. 27 0
      htmldev/manageTemplate/.eslintrc.js
  6. 16 0
      htmldev/manageTemplate/.gitignore
  7. 7 0
      htmldev/manageTemplate/.prettierrc
  8. 196 0
      htmldev/manageTemplate/README.md
  9. 14 0
      htmldev/manageTemplate/babel.config.js
  10. 35 0
      htmldev/manageTemplate/build/index.js
  11. 8 0
      htmldev/manageTemplate/config/dev.env.js
  12. 6 0
      htmldev/manageTemplate/config/prod.env.js
  13. 9 0
      htmldev/manageTemplate/jsconfig.json
  14. 57 0
      htmldev/manageTemplate/mock/index.js
  15. 81 0
      htmldev/manageTemplate/mock/mock-server.js
  16. 29 0
      htmldev/manageTemplate/mock/table.js
  17. 84 0
      htmldev/manageTemplate/mock/user.js
  18. 25 0
      htmldev/manageTemplate/mock/utils.js
  19. 61 0
      htmldev/manageTemplate/package.json
  20. 8 0
      htmldev/manageTemplate/postcss.config.js
  21. BIN
      htmldev/manageTemplate/public/ico0/favicon.ico
  22. 18 0
      htmldev/manageTemplate/public/index.html
  23. 58 0
      htmldev/manageTemplate/src/App.vue
  24. 67 0
      htmldev/manageTemplate/src/api/index.js
  25. BIN
      htmldev/manageTemplate/src/assets/404_images/404.png
  26. BIN
      htmldev/manageTemplate/src/assets/404_images/404_cloud.png
  27. BIN
      htmldev/manageTemplate/src/assets/font/icon-language.ttf
  28. BIN
      htmldev/manageTemplate/src/assets/img/common/69a1c46c-eb1c-4b46-8bd4-e9e686ef5251.png
  29. BIN
      htmldev/manageTemplate/src/assets/img/common/840702eef7eb4f6196853a99323c87cb.png
  30. 40 0
      htmldev/manageTemplate/src/assets/style/public.scss
  31. 78 0
      htmldev/manageTemplate/src/components/Breadcrumb/index.vue
  32. 44 0
      htmldev/manageTemplate/src/components/Hamburger/index.vue
  33. 62 0
      htmldev/manageTemplate/src/components/SvgIcon/index.vue
  34. 65 0
      htmldev/manageTemplate/src/components/_dialog/exampleDialog.vue
  35. 67 0
      htmldev/manageTemplate/src/components/_dialog/modPassword.vue
  36. 88 0
      htmldev/manageTemplate/src/components/upload/index.vue
  37. 13 0
      htmldev/manageTemplate/src/directive/permission/index.js
  38. 20 0
      htmldev/manageTemplate/src/directive/permission/permission.js
  39. 102 0
      htmldev/manageTemplate/src/i18n/config/ar.js
  40. 102 0
      htmldev/manageTemplate/src/i18n/config/en.js
  41. 102 0
      htmldev/manageTemplate/src/i18n/config/id.js
  42. 93 0
      htmldev/manageTemplate/src/i18n/config/zh.js
  43. 22 0
      htmldev/manageTemplate/src/i18n/index.js
  44. 9 0
      htmldev/manageTemplate/src/icons/index.js
  45. 1 0
      htmldev/manageTemplate/src/icons/svg/404.svg
  46. 1 0
      htmldev/manageTemplate/src/icons/svg/bug.svg
  47. 1 0
      htmldev/manageTemplate/src/icons/svg/chart.svg
  48. 1 0
      htmldev/manageTemplate/src/icons/svg/clipboard.svg
  49. 1 0
      htmldev/manageTemplate/src/icons/svg/component.svg
  50. 0 0
      htmldev/manageTemplate/src/icons/svg/dashboard.svg
  51. 1 0
      htmldev/manageTemplate/src/icons/svg/documentation.svg
  52. 1 0
      htmldev/manageTemplate/src/icons/svg/drag.svg
  53. 1 0
      htmldev/manageTemplate/src/icons/svg/edit.svg
  54. 1 0
      htmldev/manageTemplate/src/icons/svg/education.svg
  55. 1 0
      htmldev/manageTemplate/src/icons/svg/email.svg
  56. 1 0
      htmldev/manageTemplate/src/icons/svg/example.svg
  57. 1 0
      htmldev/manageTemplate/src/icons/svg/excel.svg
  58. 1 0
      htmldev/manageTemplate/src/icons/svg/exit-fullscreen.svg
  59. 1 0
      htmldev/manageTemplate/src/icons/svg/eye-open.svg
  60. 1 0
      htmldev/manageTemplate/src/icons/svg/eye.svg
  61. 0 0
      htmldev/manageTemplate/src/icons/svg/form.svg
  62. 1 0
      htmldev/manageTemplate/src/icons/svg/fullscreen.svg
  63. 1 0
      htmldev/manageTemplate/src/icons/svg/guide.svg
  64. 1 0
      htmldev/manageTemplate/src/icons/svg/icon.svg
  65. 1 0
      htmldev/manageTemplate/src/icons/svg/international.svg
  66. 1 0
      htmldev/manageTemplate/src/icons/svg/language.svg
  67. 1 0
      htmldev/manageTemplate/src/icons/svg/link.svg
  68. 1 0
      htmldev/manageTemplate/src/icons/svg/list.svg
  69. 1 0
      htmldev/manageTemplate/src/icons/svg/lock.svg
  70. 1 0
      htmldev/manageTemplate/src/icons/svg/message.svg
  71. 1 0
      htmldev/manageTemplate/src/icons/svg/money.svg
  72. 1 0
      htmldev/manageTemplate/src/icons/svg/nested.svg
  73. 1 0
      htmldev/manageTemplate/src/icons/svg/password.svg
  74. 1 0
      htmldev/manageTemplate/src/icons/svg/pdf.svg
  75. 1 0
      htmldev/manageTemplate/src/icons/svg/people.svg
  76. 1 0
      htmldev/manageTemplate/src/icons/svg/peoples.svg
  77. 0 0
      htmldev/manageTemplate/src/icons/svg/qq.svg
  78. 1 0
      htmldev/manageTemplate/src/icons/svg/search.svg
  79. 0 0
      htmldev/manageTemplate/src/icons/svg/shopping.svg
  80. 1 0
      htmldev/manageTemplate/src/icons/svg/size.svg
  81. 1 0
      htmldev/manageTemplate/src/icons/svg/skill.svg
  82. 1 0
      htmldev/manageTemplate/src/icons/svg/star.svg
  83. 1 0
      htmldev/manageTemplate/src/icons/svg/tab.svg
  84. 1 0
      htmldev/manageTemplate/src/icons/svg/table.svg
  85. 1 0
      htmldev/manageTemplate/src/icons/svg/theme.svg
  86. 1 0
      htmldev/manageTemplate/src/icons/svg/tree-table.svg
  87. 1 0
      htmldev/manageTemplate/src/icons/svg/tree.svg
  88. 1 0
      htmldev/manageTemplate/src/icons/svg/user.svg
  89. 1 0
      htmldev/manageTemplate/src/icons/svg/wechat.svg
  90. 1 0
      htmldev/manageTemplate/src/icons/svg/zip.svg
  91. 22 0
      htmldev/manageTemplate/src/icons/svgo.yml
  92. 46 0
      htmldev/manageTemplate/src/layout/components/AppMain.vue
  93. 152 0
      htmldev/manageTemplate/src/layout/components/Navbar.vue
  94. 26 0
      htmldev/manageTemplate/src/layout/components/Sidebar/FixiOSBug.js
  95. 41 0
      htmldev/manageTemplate/src/layout/components/Sidebar/Item.vue
  96. 43 0
      htmldev/manageTemplate/src/layout/components/Sidebar/Link.vue
  97. 82 0
      htmldev/manageTemplate/src/layout/components/Sidebar/Logo.vue
  98. 95 0
      htmldev/manageTemplate/src/layout/components/Sidebar/SidebarItem.vue
  99. 57 0
      htmldev/manageTemplate/src/layout/components/Sidebar/index.vue
  100. 96 0
      htmldev/manageTemplate/src/layout/components/TagsView/ScrollPane.vue

+ 14 - 0
htmldev/manageTemplate/.editorconfig

@@ -0,0 +1,14 @@
+# http://editorconfig.org
+root = true
+
+[*]
+charset = utf-8
+indent_style = space
+indent_size = 2
+end_of_line = lf
+insert_final_newline = true
+trim_trailing_whitespace = true
+
+[*.md]
+insert_final_newline = false
+trim_trailing_whitespace = false

+ 6 - 0
htmldev/manageTemplate/.env.development

@@ -0,0 +1,6 @@
+# just a flag
+ENV = 'development'
+
+# base api
+VUE_APP_BASE_API = '/dev-api'
+VUE_APP_ISPROXY=1

+ 6 - 0
htmldev/manageTemplate/.env.production

@@ -0,0 +1,6 @@
+# just a flag
+ENV = 'production'
+
+# base api
+VUE_APP_BASE_API = '/prod-api'
+VUE_APP_ISPROXY=0

+ 4 - 0
htmldev/manageTemplate/.eslintignore

@@ -0,0 +1,4 @@
+build/*.js
+src/assets
+public
+dist

+ 27 - 0
htmldev/manageTemplate/.eslintrc.js

@@ -0,0 +1,27 @@
+module.exports = {
+  root: true,
+  env: {
+    node: true,
+    browser: true
+  },
+  parserOptions: {
+    // ecmaVersion: 7,
+    // sourceType: "module",
+    parser: "babel-eslint"
+  },
+  extends: [
+    'plugin:vue/essential'
+  ],
+  plugins: [
+    'vue'
+  ],
+  // 添加自定义规则
+  rules: {
+    // allow async-await
+    'generator-star-spacing': 'off',
+    // allow debugger during development
+    indent: 0,
+    'no-useless-escape': 0,
+    'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off'
+  }
+}

+ 16 - 0
htmldev/manageTemplate/.gitignore

@@ -0,0 +1,16 @@
+.DS_Store
+node_modules/
+dist/
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+package-lock.json
+tests/**/coverage/
+
+# Editor directories and files
+.idea
+.vscode
+*.suo
+*.ntvs*
+*.njsproj
+*.sln

+ 7 - 0
htmldev/manageTemplate/.prettierrc

@@ -0,0 +1,7 @@
+{
+    "printWidth": 160,
+    "tabWidth": 4,
+    "singleQuote": true,
+    "semi": false,
+    "arrowParens": "avoid"
+}

+ 196 - 0
htmldev/manageTemplate/README.md

@@ -0,0 +1,196 @@
+# vue admin template
+
+自己不断修改的vue admin 模板
+
+## 全局的form表单验证
+
+```html
+<!-- 验证方法在@/utils/rules里面 -->
+<el-form :model="loginForm" :rules="formRules" ref="loginForm" label-position="top">
+  <el-form-item prop="username" :rules="formRules.required">
+    <el-input placeholder="用户名" v-model="loginForm.username" size="default"><i slot="prepend"
+                                                                               class="el-icon-user-solid"></i>
+    </el-input>
+  </el-form-item>
+  <el-form-item prop="password" :rules="formRules.password">
+    <el-input show-password placeholder="密码" v-model="loginForm.password" size="default"
+              @keydown.enter.native="handleSubmit"><i slot="prepend" class="el-icon-lock"></i></el-input>
+  </el-form-item>
+  <el-button @click="handleSubmit" type="primary" class="button-login" size="default">提交</el-button>
+</el-form>
+
+<!-- 传其余参数可以使用下面的方法 -->
+<el-form-item prop="confirmPassword" :rules="formRules.confirmPassword(registerForm)">
+  <el-input show-password placeholder="再次输入密码" v-model="registerForm.confirmPassword" size="default">
+    <i slot="prepend" class="el-icon-lock"></i>
+  </el-input>
+</el-form-item>
+```
+
+## 需要共享的全局枚举参数
+
+> 全部放在`@/utils/enum.js`里面,已全部挂载到Vue.prototype下面
+
+## 需要共享的全局方法
+
+> 全部放在`@/utils/filter.js`里面,已全部挂载到Vue.prototype下面
+
+## 所有的api请求
+
+> 统一的axios参数在`@/api/index.js`下面,已全部挂载到Vue.prototype下面
+
+```js
+// 具体使用方法,例:
+// 
+methods: {
+  async
+  handleSubmit()
+  {
+    this.$refs.form.validate(async valid => {
+      if (valid) {
+        // this.$fetch第三个参数可选,默认'post',如果是使用get方法,第三个参数传'get'
+        const data = await this.$fetch('/v1/front/otherApi', { ...this.form })
+        if (data.code === 0) {
+          this.$message.success('提交成功')
+          this.$emit('success')
+          this.dialog = false
+        } else {
+          this.reloadImg()
+        }
+      }
+
+    })
+  }
+}
+```
+
+## dialog弹窗
+
+> dialog弹窗尽量使用组件引入,dialog例子在`@/components/_dialog/exampleDialog`里面
+
+```html
+<!-- 应用例子 -->
+<template>
+  <exampleDialog v-if="exampleDialog.show" v-model="exampleDialog.show" :exampleData="exampleDialog.data"
+                 @success="searchSubmit"></exampleDialog>
+</template>
+```
+
+## 表格统一分页,统一风格
+
+> 使用`@/mixin/page.js` 使用前最好看一下
+
+> 下面例子包含了表格统一和全局枚举(enum)的应用
+
+```js
+// 页面引用js部分
+import page from '@/mixin/page'
+
+export default {
+  mixins: [page],
+  data() {
+    return {
+      time: [],
+      searchForm: {},
+      tableData: [],
+      tableUrl: '/v1/front/user/list'
+    }
+  },
+  methods: {},
+  mounted() {
+    this.init()
+  },
+}
+```
+
+```html
+<!-- template部分 -->
+<template>
+  <div>
+    <div class="search-box">
+      <el-form ref="form" :inline="true" :model="searchForm" clearable label-width="100px">
+        <el-form-item label="变更时间:">
+          <el-date-picker
+            :editable="false"
+            v-model="time"
+            @change="timearr => {timearr ? (searchForm.create_time_start = timearr[0], searchForm.create_time_end = timearr[1]) : searchForm.create_time_start = searchForm.create_time_end = undefined}"
+            type="daterange"
+            value-format="yyyy-MM-dd"
+            start-placeholder="开始时间"
+            end-placeholder="结束时间"
+          ></el-date-picker>
+        </el-form-item>
+        <el-form-item label="收支状态:">
+          <el-select v-model="searchForm.budget_type" placeholder="全部">
+            <el-option label="全部" value></el-option>
+            <!-- 注意,这里budget_type就是放在全局enum中的参数 -->
+            <el-option v-for="(item, index) in budget_type" :key="index" :label="item" :value="index"></el-option>
+          </el-select>
+        </el-form-item>
+        <el-form-item class="ml-10">
+          <el-button class type="primary" @click="searchSubmit">查询</el-button>
+        </el-form-item>
+      </el-form>
+    </div>
+    <!-- 这里的vheight根据实际情况来 -->
+    <el-table :data="tableData" stripe v-loading="tableLoading" fit class="marginT-10 order-table" border
+              :max-height="vheight">
+      <el-table-column label="创建时间" prop="create_time"></el-table-column>
+      <el-table-column label="收支类型" align="center" prop="budget_type"
+                       :formatter="row => budget_type[row.budget_type]"></el-table-column>
+      <el-table-column label="变更类型" align="center" prop="change_type"
+                       :formatter="row => $store.getters.enum.coin_change_type_arr[row.change_type]"></el-table-column>
+      <el-table-column label="变更数目" align="center" prop="coin_change_number"
+                       :formatter="row => row.coin_change_number + '金币'"></el-table-column>
+      <el-table-column label="变更后数目" align="center" prop="after_change_remain_coins"
+                       :formatter="row => row.after_change_remain_coins + '金币'"></el-table-column>
+      <el-table-column label="备注" prop="remarks"></el-table-column>
+    </el-table>
+    <el-pagination
+      class="marginT-20"
+      @size-change="handleSizeChange"
+      @current-change="handleCurrentChange"
+      :hide-on-single-page="true"
+      :current-page="page"
+      :page-size="page_size"
+      :page-sizes="[10, 20, 100, 200, 300, 400]"
+      background
+      layout="total, sizes, prev, pager, next, jumper"
+      :total="totalCount"/>
+  </div>
+</template>
+```
+
+## other
+
+1. 有一些不需要放在vuex下面的,可以使用事件总线$bus,在`@/utils/vue-bus.js`里面。
+
+## 需要node环境,最好在v10以上
+
+### 安装依赖
+
+```bash
+yarn
+## or
+npm i
+```
+
+
+### 最后 打包
+
+```bash
+npm run build
+## or
+yarn build
+```
+
+### 项目原型
+
+### 接口地址
+
+[API]()
+
+### 页面地址
+
+[测试]()
+[生产]()

+ 14 - 0
htmldev/manageTemplate/babel.config.js

@@ -0,0 +1,14 @@
+module.exports = {
+  presets: [
+    // https://github.com/vuejs/vue-cli/tree/master/packages/@vue/babel-preset-app
+    '@vue/cli-plugin-babel/preset'
+  ],
+  'env': {
+    'development': {
+      // babel-plugin-dynamic-import-node plugin only does one thing by converting all import() to require().
+      // This plugin can significantly increase the speed of hot updates, when you have a large number of pages.
+      // https://panjiachen.github.io/vue-element-admin-site/guide/advanced/lazy-loading.html
+      'plugins': ['dynamic-import-node']
+    }
+  }
+}

+ 35 - 0
htmldev/manageTemplate/build/index.js

@@ -0,0 +1,35 @@
+const { run } = require('runjs')
+const chalk = require('chalk')
+const config = require('../vue.config.js')
+const rawArgv = process.argv.slice(2)
+const args = rawArgv.join(' ')
+
+if (process.env.npm_config_preview || rawArgv.includes('--preview')) {
+  const report = rawArgv.includes('--report')
+
+  run(`vue-cli-service build ${args}`)
+
+  const port = 9526
+  const publicPath = config.publicPath
+
+  var connect = require('connect')
+  var serveStatic = require('serve-static')
+  const app = connect()
+
+  app.use(
+    publicPath,
+    serveStatic('./dist', {
+      index: ['index.html', '/']
+    })
+  )
+
+  app.listen(port, function () {
+    console.log(chalk.green(`> Preview at  http://localhost:${port}${publicPath}`))
+    if (report) {
+      console.log(chalk.green(`> Report at  http://localhost:${port}${publicPath}report.html`))
+    }
+
+  })
+} else {
+  run(`vue-cli-service build ${args}`)
+}

+ 8 - 0
htmldev/manageTemplate/config/dev.env.js

@@ -0,0 +1,8 @@
+'use strict'
+const merge = require('webpack-merge')
+const prodEnv = require('./prod.env')
+
+module.exports = merge(prodEnv, {
+  NODE_ENV: '"development"',
+  API_DOMAIN: '"http://swago-admin.codedreamit.com"'
+})

+ 6 - 0
htmldev/manageTemplate/config/prod.env.js

@@ -0,0 +1,6 @@
+'use strict'
+
+module.exports = {
+  NODE_ENV: '"production"',
+  API_DOMAIN: '"http://swago-admin.codedreamit.com"'
+}

+ 9 - 0
htmldev/manageTemplate/jsconfig.json

@@ -0,0 +1,9 @@
+{
+  "compilerOptions": {
+    "baseUrl": "./",
+    "paths": {
+        "@/*": ["src/*"]
+    }
+  },
+  "exclude": ["node_modules", "dist"]
+}

+ 57 - 0
htmldev/manageTemplate/mock/index.js

@@ -0,0 +1,57 @@
+const Mock = require('mockjs')
+const { param2Obj } = require('./utils')
+
+const user = require('./user')
+const table = require('./table')
+
+const mocks = [
+  ...user,
+  ...table
+]
+
+// for front mock
+// please use it cautiously, it will redefine XMLHttpRequest,
+// which will cause many of your third-party libraries to be invalidated(like progress event).
+function mockXHR() {
+  // mock patch
+  // https://github.com/nuysoft/Mock/issues/300
+  Mock.XHR.prototype.proxy_send = Mock.XHR.prototype.send
+  Mock.XHR.prototype.send = function() {
+    if (this.custom.xhr) {
+      this.custom.xhr.withCredentials = this.withCredentials || false
+
+      if (this.responseType) {
+        this.custom.xhr.responseType = this.responseType
+      }
+    }
+    this.proxy_send(...arguments)
+  }
+
+  function XHR2ExpressReqWrap(respond) {
+    return function(options) {
+      let result = null
+      if (respond instanceof Function) {
+        const { body, type, url } = options
+        // https://expressjs.com/en/4x/api.html#req
+        result = respond({
+          method: type,
+          body: JSON.parse(body),
+          query: param2Obj(url)
+        })
+      } else {
+        result = respond
+      }
+      return Mock.mock(result)
+    }
+  }
+
+  for (const i of mocks) {
+    Mock.mock(new RegExp(i.url), i.type || 'get', XHR2ExpressReqWrap(i.response))
+  }
+}
+
+module.exports = {
+  mocks,
+  mockXHR
+}
+

+ 81 - 0
htmldev/manageTemplate/mock/mock-server.js

@@ -0,0 +1,81 @@
+const chokidar = require('chokidar')
+const bodyParser = require('body-parser')
+const chalk = require('chalk')
+const path = require('path')
+const Mock = require('mockjs')
+
+const mockDir = path.join(process.cwd(), 'mock')
+
+function registerRoutes(app) {
+  let mockLastIndex
+  const { mocks } = require('./index.js')
+  const mocksForServer = mocks.map(route => {
+    return responseFake(route.url, route.type, route.response)
+  })
+  for (const mock of mocksForServer) {
+    app[mock.type](mock.url, mock.response)
+    mockLastIndex = app._router.stack.length
+  }
+  const mockRoutesLength = Object.keys(mocksForServer).length
+  return {
+    mockRoutesLength: mockRoutesLength,
+    mockStartIndex: mockLastIndex - mockRoutesLength
+  }
+}
+
+function unregisterRoutes() {
+  Object.keys(require.cache).forEach(i => {
+    if (i.includes(mockDir)) {
+      delete require.cache[require.resolve(i)]
+    }
+  })
+}
+
+// for mock server
+const responseFake = (url, type, respond) => {
+  return {
+    url: new RegExp(`${process.env.VUE_APP_BASE_API}${url}`),
+    type: type || 'get',
+    response(req, res) {
+      console.log('request invoke:' + req.path)
+      res.json(Mock.mock(respond instanceof Function ? respond(req, res) : respond))
+    }
+  }
+}
+
+module.exports = app => {
+  // parse app.body
+  // https://expressjs.com/en/4x/api.html#req.body
+  app.use(bodyParser.json())
+  app.use(bodyParser.urlencoded({
+    extended: true
+  }))
+
+  const mockRoutes = registerRoutes(app)
+  var mockRoutesLength = mockRoutes.mockRoutesLength
+  var mockStartIndex = mockRoutes.mockStartIndex
+
+  // watch files, hot reload mock server
+  chokidar.watch(mockDir, {
+    ignored: /mock-server/,
+    ignoreInitial: true
+  }).on('all', (event, path) => {
+    if (event === 'change' || event === 'add') {
+      try {
+        // remove mock routes stack
+        app._router.stack.splice(mockStartIndex, mockRoutesLength)
+
+        // clear routes cache
+        unregisterRoutes()
+
+        const mockRoutes = registerRoutes(app)
+        mockRoutesLength = mockRoutes.mockRoutesLength
+        mockStartIndex = mockRoutes.mockStartIndex
+
+        console.log(chalk.magentaBright(`\n > Mock Server hot reload success! changed  ${path}`))
+      } catch (error) {
+        console.log(chalk.redBright(error))
+      }
+    }
+  })
+}

+ 29 - 0
htmldev/manageTemplate/mock/table.js

@@ -0,0 +1,29 @@
+const Mock = require('mockjs')
+
+const data = Mock.mock({
+  'items|30': [{
+    id: '@id',
+    title: '@sentence(10, 20)',
+    'status|1': ['published', 'draft', 'deleted'],
+    author: 'name',
+    display_time: '@datetime',
+    pageviews: '@integer(300, 5000)'
+  }]
+})
+
+module.exports = [
+  {
+    url: '/vue-admin-template/table/list',
+    type: 'get',
+    response: config => {
+      const items = data.items
+      return {
+        code: 20000,
+        data: {
+          total: items.length,
+          items: items
+        }
+      }
+    }
+  }
+]

+ 84 - 0
htmldev/manageTemplate/mock/user.js

@@ -0,0 +1,84 @@
+
+const tokens = {
+  admin: {
+    token: 'admin-token'
+  },
+  editor: {
+    token: 'editor-token'
+  }
+}
+
+const users = {
+  'admin-token': {
+    roles: ['admin'],
+    introduction: 'I am a super administrator',
+    avatar: 'https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif',
+    name: 'Super Admin'
+  },
+  'editor-token': {
+    roles: ['editor'],
+    introduction: 'I am an editor',
+    avatar: 'https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif',
+    name: 'Normal Editor'
+  }
+}
+
+module.exports = [
+  // user login
+  {
+    url: '/vue-admin-template/user/login',
+    type: 'post',
+    response: config => {
+      const { username } = config.body
+      const token = tokens[username]
+
+      // mock error
+      if (!token) {
+        return {
+          code: 60204,
+          message: 'Account and password are incorrect.'
+        }
+      }
+
+      return {
+        code: 20000,
+        data: token
+      }
+    }
+  },
+
+  // get user info
+  {
+    url: '/vue-admin-template/user/info\.*',
+    type: 'get',
+    response: config => {
+      const { token } = config.query
+      const info = users[token]
+
+      // mock error
+      if (!info) {
+        return {
+          code: 50008,
+          message: 'Login failed, unable to get user details.'
+        }
+      }
+
+      return {
+        code: 20000,
+        data: info
+      }
+    }
+  },
+
+  // user logout
+  {
+    url: '/vue-admin-template/user/logout',
+    type: 'post',
+    response: _ => {
+      return {
+        code: 20000,
+        data: 'success'
+      }
+    }
+  }
+]

+ 25 - 0
htmldev/manageTemplate/mock/utils.js

@@ -0,0 +1,25 @@
+/**
+ * @param {string} url
+ * @returns {Object}
+ */
+function param2Obj(url) {
+  const search = decodeURIComponent(url.split('?')[1]).replace(/\+/g, ' ')
+  if (!search) {
+    return {}
+  }
+  const obj = {}
+  const searchArr = search.split('&')
+  searchArr.forEach(v => {
+    const index = v.indexOf('=')
+    if (index !== -1) {
+      const name = v.substring(0, index)
+      const val = v.substring(index + 1, v.length)
+      obj[name] = val
+    }
+  })
+  return obj
+}
+
+module.exports = {
+  param2Obj
+}

+ 61 - 0
htmldev/manageTemplate/package.json

@@ -0,0 +1,61 @@
+{
+  "name": "vue-admin-base",
+  "version": "4.4.0",
+  "description": "A vue admin base",
+  "author": "shengchao <749312025@qq.com>",
+  "scripts": {
+    "dev": "vue-cli-service serve",
+    "serve": "vue-cli-service serve",
+    "build": "npm run build:test",
+    "build:test": "cross-env BUILD_ENV=develop vue-cli-service build",
+    "build:pro": "cross-env BUILD_ENV=production vue-cli-service build",
+    "preview": "node build/index.js --preview"
+  },
+  "dependencies": {
+    "axios": "^0.24.0",
+    "core-js": "3.6.5",
+    "element-ui": "2.13.2",
+    "js-cookie": "2.2.0",
+    "normalize.css": "7.0.0",
+    "nprogress": "0.2.0",
+    "path-to-regexp": "2.4.0",
+    "vue": "2.6.10",
+    "vue-i18n": "8.27.0",
+    "vue-router": "3.0.6",
+    "vuex": "3.1.0"
+  },
+  "devDependencies": {
+    "@vue/cli-plugin-babel": "4.4.4",
+    "@vue/cli-plugin-eslint": "4.4.4",
+    "@vue/cli-service": "4.4.4",
+    "autoprefixer": "9.5.1",
+    "babel-eslint": "10.1.0",
+    "babel-plugin-dynamic-import-node": "2.3.3",
+    "chalk": "2.4.2",
+    "connect": "3.6.6",
+    "cross-env": "^7.0.3",
+    "dayjs": "^1.8.29",
+    "eslint": "6.7.2",
+    "eslint-plugin-vue": "6.2.2",
+    "html-webpack-plugin": "3.2.0",
+    "mockjs": "1.0.1-beta3",
+    "pl-table": "^2.7.5",
+    "runjs": "4.3.2",
+    "sass": "1.26.8",
+    "sass-loader": "8.0.2",
+    "script-ext-html-webpack-plugin": "2.1.3",
+    "serve-static": "1.13.2",
+    "svg-sprite-loader": "4.1.3",
+    "svgo": "1.2.2",
+    "vue-template-compiler": "2.6.10"
+  },
+  "browserslist": [
+    "> 1%",
+    "last 2 versions"
+  ],
+  "engines": {
+    "node": ">=8.9",
+    "npm": ">= 3.0.0"
+  },
+  "license": "MIT"
+}

+ 8 - 0
htmldev/manageTemplate/postcss.config.js

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

BIN
htmldev/manageTemplate/public/ico0/favicon.ico


+ 18 - 0
htmldev/manageTemplate/public/index.html

@@ -0,0 +1,18 @@
+<!DOCTYPE html>
+<html>
+<head>
+  <meta charset="utf-8">
+  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
+  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
+  <link rel="icon" href="<%= BASE_URL %>ico0/favicon.ico">
+  <title><%= webpackConfig.name %></title>
+</head>
+<body>
+<noscript>
+  <strong>We're sorry but <%= webpackConfig.name %> 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>

+ 58 - 0
htmldev/manageTemplate/src/App.vue

@@ -0,0 +1,58 @@
+<template>
+  <div id="app">
+    <router-view/>
+  </div>
+</template>
+
+<script>
+export default {
+  name: 'App'
+}
+</script>
+<style lang="scss">
+* {
+  margin: 0;
+  padding: 0;
+}
+
+.el-table {
+  .el-table__body-wrapper {
+    &::-webkit-scrollbar {
+      background: #d3dce6;
+    }
+
+    &::-webkit-scrollbar-thumb {
+      background: #99a9bf;
+      border-radius: 10px;
+    }
+  }
+}
+
+@media screen and (max-width: 768px) {
+  .el-message {
+    min-width: 300px !important;
+  }
+  .el-message-box {
+    width: 300px !important;
+  }
+  .el-dialog__wrapper .el-dialog {
+    width: 95% !important;
+
+    .el-dialog__body {
+      padding: 10px 20px !important;
+    }
+  }
+  .el-date-range-picker {
+    left: 0 !important;
+  }
+
+  .el-form-item__label {
+    display: block;
+    width: 100% !important;
+    text-align: left;
+  }
+  .el-form-item__content {
+    margin-left: 0 !important;
+  }
+}
+</style>

+ 67 - 0
htmldev/manageTemplate/src/api/index.js

@@ -0,0 +1,67 @@
+import Vue from 'vue'
+import axios from 'axios'
+import i18n from '../i18n'
+import { Message } from 'element-ui'
+import store from '../store/index'
+import { getToken, getLocale } from '@/utils/auth'
+
+// axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'
+// axios.defaults.withCredentials = false
+axios.defaults.timeout = 20000
+
+axios.interceptors.request.use(config => {
+    if (getToken()) {
+      config.headers['token'] = getToken()
+    }
+    if (getLocale()) {
+      config.headers['locale'] = getLocale()
+    }
+    if (config.method === 'post') {
+      config.params = undefined
+    }
+    // 临时打补丁
+    if (/^\/v1\//.test(config.url)) {
+      config.url = '/api/admin' + config.url
+    }
+    return config
+  }, error => Promise.resolve(error.response || error)
+)
+
+axios.interceptors.response.use(response => {
+    if (response.data && response.data.code !== 200 && response.data.msg) {
+      Message.error(response.data.msg)
+    }
+    if (response.data && (response.data.code === 403 || response.data.code === 401)) {
+      store.dispatch('user/logout')
+      setTimeout(() => {
+        location.href = '/login'
+      }, 200)
+
+    }
+    return response
+  }, error => {
+    if (error.response && error.response.data.msg) {
+      Message.error(error.response.data.msg)
+    } else if (error.message) {
+      if (error.code && error.code === 'ECONNABORTED') {
+        Message.error(i18n.t('request.timeout'))
+      } else {
+        Message.error(error.message)
+      }
+    }
+    return Promise.resolve(error.response || error)
+  }
+)
+
+export const fetch = (url, data = {}, method = 'post') => {
+  return new Promise((resolve, reject) => {
+    axios({
+      url,
+      data: method === 'post' ? data : {},
+      params: method === 'post' ? {} : data,
+      method
+    }).then(res => resolve(res.data))
+  })
+}
+
+Vue.prototype.$fetch = fetch

BIN
htmldev/manageTemplate/src/assets/404_images/404.png


BIN
htmldev/manageTemplate/src/assets/404_images/404_cloud.png


BIN
htmldev/manageTemplate/src/assets/font/icon-language.ttf


BIN
htmldev/manageTemplate/src/assets/img/common/69a1c46c-eb1c-4b46-8bd4-e9e686ef5251.png


BIN
htmldev/manageTemplate/src/assets/img/common/840702eef7eb4f6196853a99323c87cb.png


+ 40 - 0
htmldev/manageTemplate/src/assets/style/public.scss

@@ -0,0 +1,40 @@
+// 禁止用户选中 鼠标变为手形
+%unable-select {
+    user-select: none;
+    cursor: pointer;
+}
+
+// 填满父元素
+// 组要父元素 position: relative | absolute;
+%full {
+    position: absolute;
+    top: 0;
+    right: 0;
+    left: 0;
+    bottom: 0;
+}
+
+// flex 垂直水平居中
+%flex-center-row {
+    display: flex;
+    justify-content: center;
+    align-items: center;
+    flex-direction: row;
+}
+
+%flex-center-column {
+    display: flex;
+    justify-content: center;
+    align-items: center;
+    flex-direction: column;
+}
+
+// 将元素模拟成卡片外观
+%card {
+    border: 1px solid #dddee1;
+    border-color: #e9eaec;
+    background: #fff;
+    border-radius: 4px;
+    font-size: 14px;
+    position: relative;
+}

+ 78 - 0
htmldev/manageTemplate/src/components/Breadcrumb/index.vue

@@ -0,0 +1,78 @@
+<template>
+  <el-breadcrumb class="app-breadcrumb" separator="/">
+    <transition-group name="breadcrumb">
+      <el-breadcrumb-item v-for="(item,index) in levelList" :key="item.path">
+        <span v-if="item.redirect==='noRedirect'||index==levelList.length-1" class="no-redirect">{{ item.meta.title }}</span>
+        <a v-else @click.prevent="handleLink(item)">{{ item.meta.title }}</a>
+      </el-breadcrumb-item>
+    </transition-group>
+  </el-breadcrumb>
+</template>
+
+<script>
+import pathToRegexp from 'path-to-regexp'
+
+export default {
+  data() {
+    return {
+      levelList: null
+    }
+  },
+  watch: {
+    $route() {
+      this.getBreadcrumb()
+    }
+  },
+  created() {
+    this.getBreadcrumb()
+  },
+  methods: {
+    getBreadcrumb() {
+      // only show routes with meta.title
+      let matched = this.$route.matched.filter(item => item.meta && item.meta.title)
+      const first = matched[0]
+
+      if (!this.isDashboard(first)) {
+        matched = [{ path: '/dashboard', meta: { title: this.$t('route.dashboard') }}].concat(matched)
+      }
+
+      this.levelList = matched.filter(item => item.meta && item.meta.title && item.meta.breadcrumb !== false)
+    },
+    isDashboard(route) {
+      const name = route && route.name
+      if (!name) {
+        return false
+      }
+      return name.trim().toLocaleLowerCase() === 'Dashboard'.toLocaleLowerCase()
+    },
+    pathCompile(path) {
+      // To solve this problem https://github.com/PanJiaChen/vue-element-admin/issues/561
+      const { params } = this.$route
+      var toPath = pathToRegexp.compile(path)
+      return toPath(params)
+    },
+    handleLink(item) {
+      const { redirect, path } = item
+      if (redirect) {
+        this.$router.push(redirect)
+        return
+      }
+      this.$router.push(this.pathCompile(path))
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.app-breadcrumb.el-breadcrumb {
+  display: inline-block;
+  font-size: 14px;
+  line-height: 50px;
+  margin-left: 8px;
+
+  .no-redirect {
+    color: #97a8be;
+    cursor: text;
+  }
+}
+</style>

+ 44 - 0
htmldev/manageTemplate/src/components/Hamburger/index.vue

@@ -0,0 +1,44 @@
+<template>
+  <div style="padding: 0 15px;" @click="toggleClick">
+    <svg
+      :class="{'is-active':isActive}"
+      class="hamburger"
+      viewBox="0 0 1024 1024"
+      xmlns="http://www.w3.org/2000/svg"
+      width="64"
+      height="64"
+    >
+      <path d="M408 442h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-8 204c0 4.4 3.6 8 8 8h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56zm504-486H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 632H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM142.4 642.1L298.7 519a8.84 8.84 0 0 0 0-13.9L142.4 381.9c-5.8-4.6-14.4-.5-14.4 6.9v246.3a8.9 8.9 0 0 0 14.4 7z" />
+    </svg>
+  </div>
+</template>
+
+<script>
+export default {
+  name: 'Hamburger',
+  props: {
+    isActive: {
+      type: Boolean,
+      default: false
+    }
+  },
+  methods: {
+    toggleClick() {
+      this.$emit('toggleClick')
+    }
+  }
+}
+</script>
+
+<style scoped>
+.hamburger {
+  display: inline-block;
+  vertical-align: middle;
+  width: 20px;
+  height: 20px;
+}
+
+.hamburger.is-active {
+  transform: rotate(180deg);
+}
+</style>

+ 62 - 0
htmldev/manageTemplate/src/components/SvgIcon/index.vue

@@ -0,0 +1,62 @@
+<template>
+  <div v-if="isExternal" :style="styleExternalIcon" class="svg-external-icon svg-icon" v-on="$listeners" />
+  <svg v-else :class="svgClass" aria-hidden="true" v-on="$listeners">
+    <use :xlink:href="iconName" />
+  </svg>
+</template>
+
+<script>
+// doc: https://panjiachen.github.io/vue-element-admin-site/feature/component/svg-icon.html#usage
+import { isExternal } from '@/utils/validate'
+
+export default {
+  name: 'SvgIcon',
+  props: {
+    iconClass: {
+      type: String,
+      required: true
+    },
+    className: {
+      type: String,
+      default: ''
+    }
+  },
+  computed: {
+    isExternal() {
+      return isExternal(this.iconClass)
+    },
+    iconName() {
+      return `#icon-${this.iconClass}`
+    },
+    svgClass() {
+      if (this.className) {
+        return 'svg-icon ' + this.className
+      } else {
+        return 'svg-icon'
+      }
+    },
+    styleExternalIcon() {
+      return {
+        mask: `url(${this.iconClass}) no-repeat 50% 50%`,
+        '-webkit-mask': `url(${this.iconClass}) no-repeat 50% 50%`
+      }
+    }
+  }
+}
+</script>
+
+<style scoped>
+.svg-icon {
+  width: 1em;
+  height: 1em;
+  vertical-align: -0.15em;
+  fill: currentColor;
+  overflow: hidden;
+}
+
+.svg-external-icon {
+  background-color: currentColor;
+  mask-size: cover!important;
+  display: inline-block;
+}
+</style>

+ 65 - 0
htmldev/manageTemplate/src/components/_dialog/exampleDialog.vue

@@ -0,0 +1,65 @@
+<template>
+    <div>
+        <el-dialog title="test" :visible.sync="dialog" width="450px" :close-on-click-modal="false" top="50px">
+            <p class="top-tip fc-theme">这是个例子</p>
+            <el-form ref="form" :model="form" label-width="80px" class="bind-phone">
+                <el-form-item label="充值金额:" label-width="150px" >
+                    <el-input v-model="form.amount" placeholder="请输入充值金额"> </el-input>
+                </el-form-item>
+                <el-form-item label="充值订单号:" label-width="150px">
+                    <el-input placeholder="请输入订单号" @keyup.enter.native="handleSubmit" v-model="form.trade_sn"></el-input>
+                </el-form-item>
+            </el-form>
+            <div slot="footer" class="dialog-footer text-center">
+                <el-button @click="dialog = false">取 消</el-button>
+                <el-button type="danger" @click="handleSubmit">确 定</el-button>
+            </div>
+        </el-dialog>
+    </div>
+</template>
+
+<script>
+export default {
+    props: {
+        value: {
+            type: Boolean,
+            default: true
+        },
+        exampleData: {
+            type: Object,
+            default: {}
+        }
+    },
+    data() {
+        return {
+            dialog: !!this.value,
+            form: {
+                amount: '',
+                trade_sn: ''
+            }
+        }
+    },
+    methods: {
+        async handleSubmit() {
+            const data = await this.$fetch('/recharge_query', {...this.form})
+            if (data.code === 200) {
+                this.$message.success('提交成功')
+                this.$emit('success')
+                this.dialog = false
+            }
+        }
+    },
+    watch: {
+        dialog(val) {
+            if (!val) this.$emit('input', val)
+        }
+    }
+}
+</script>
+
+<style lang="scss" scoped>
+.top-tip {
+    margin-top: -20px;
+    margin-bottom: 20px;
+}
+</style>

+ 67 - 0
htmldev/manageTemplate/src/components/_dialog/modPassword.vue

@@ -0,0 +1,67 @@
+<template>
+    <div>
+        <el-dialog title="修改密码" :visible.sync="dialog" width="450px" :close-on-click-modal="false" top="50px">
+            <el-form ref="form" :model="form" :rules="formRules" label-width="80px" class="bind-phone">
+                <el-form-item label="旧密码:" label-width="150px" prop="old_password" :rules="formRules.password">
+                    <el-input v-model="form.old_password" placeholder="请输入旧密码"> </el-input>
+                </el-form-item>
+                <el-form-item label="新密码:" label-width="150px" prop="new_password" :rules="formRules.password">
+                    <el-input placeholder="请输入新密码" @keyup.enter.native="handleSubmit" v-model="form.new_password"></el-input>
+                </el-form-item>
+            </el-form>
+            <div slot="footer" class="dialog-footer text-center">
+                <el-button @click="dialog = false">取 消</el-button>
+                <el-button type="danger" @click="handleSubmit">确 定</el-button>
+            </div>
+        </el-dialog>
+    </div>
+</template>
+
+<script>
+export default {
+    props: {
+        value: {
+            type: Boolean,
+            default: true
+        }
+    },
+    data() {
+        return {
+            dialog: !!this.value,
+            form: {
+                old_password: '',
+                new_password: ''
+            }
+        }
+    },
+    methods: {
+        async handleSubmit() {
+            this.$refs.form.validate(async valid => {
+                if (valid) {
+                    const data = await this.$fetch('/user/set_me_password', this.form)
+                    if (data.code == 200) {
+                        await this.$store.dispatch('user/logout')
+                        this.$router.push(`/login`)
+                    }
+                } else {
+                    console.log('error submit!!')
+                    return false
+                }
+            })
+            
+        }
+    },
+    watch: {
+        dialog(val) {
+            if (!val) this.$emit('input', val)
+        }
+    }
+}
+</script>
+
+<style lang="scss" scoped>
+.top-tip {
+    margin-top: -20px;
+    margin-bottom: 20px;
+}
+</style>

+ 88 - 0
htmldev/manageTemplate/src/components/upload/index.vue

@@ -0,0 +1,88 @@
+<template>
+    <div class="upload-wrapper">
+        <el-upload
+            class="avatar-uploader"
+            action="/api/uploadFile"
+            accept="image/*"
+            :show-file-list="false"
+            :headers="header"
+            name="imgFile"
+            :on-success="handleAvatarSuccess"
+            :before-upload="beforeAvatarUpload">
+            <img v-if="imageUrl" :src="imageUrl" class="avatar">
+            <i v-else class="el-icon-plus avatar-uploader-icon"></i>
+        </el-upload>
+    </div>
+</template>
+
+<script>
+import {getToken} from '@/utils/auth'
+export default {
+    props: {
+        type: {
+            type: String,
+            default: 'qrcode'
+        },
+        value: {
+            type: String,
+            default: ''
+        },
+    },
+    data() {
+        return {
+            imageUrl: this.value,
+            header: {
+                'token': getToken(),
+            },
+        }
+    },
+    methods: {
+        handleAvatarSuccess(res, file) {
+            console.log(res);
+            if (res.code == 200) {
+                this.$emit('input', res.data.path)
+            }
+            // this.imageUrl = URL.createObjectURL(file.raw);
+        },
+        beforeAvatarUpload(file) {
+            const isLt2M = file.size / 1024 / 1024 < 5;
+            if (!isLt2M) {
+            this.$message.error('上传头像图片大小不能超过 5MB!');
+            }
+            return isLt2M;
+        },
+    },
+    watch: {
+        value(n, o) {
+            // this.imageUrl = n ? ('http://' + this.configData.static_url + '/' + n) : ''
+            this.imageUrl = n
+        }
+    }
+}
+</script>
+
+<style lang="scss">
+.avatar-uploader .el-upload {
+    border: 1px dashed #d9d9d9;
+    border-radius: 6px;
+    cursor: pointer;
+    position: relative;
+    overflow: hidden;
+}
+.avatar-uploader .el-upload:hover {
+    border-color: #409eff;
+}
+.avatar-uploader-icon {
+    font-size: 28px;
+    color: #8c939d;
+    width: 178px;
+    height: 178px;
+    line-height: 178px;
+    text-align: center;
+}
+.avatar {
+    width: 178px;
+    height: 178px;
+    display: block;
+}
+</style>

+ 13 - 0
htmldev/manageTemplate/src/directive/permission/index.js

@@ -0,0 +1,13 @@
+import permission from './permission';
+// eslint-disable-next-line func-names
+const install = function(Vue) {
+  Vue.directive('permission', permission);
+};
+
+if (window.Vue) {
+  window.permission = permission;
+  Vue.use(install); // eslint-disable-line
+}
+
+permission.install = install;
+export default permission;

+ 20 - 0
htmldev/manageTemplate/src/directive/permission/permission.js

@@ -0,0 +1,20 @@
+import store from "@/store"
+
+export default {
+  inserted(el, binding, vnode) {
+    const { value } = binding;
+    const permissions = store.getters.pageRoleArray || []
+    // console.log('permissionList---', permissions)
+    const hasPermission = permissions.includes(value)
+    if (!hasPermission) {
+      // eslint-disable-next-line no-unused-expressions
+      if (el.parentNode) {
+        el.parentNode.removeChild(el);
+      } else {
+        el.innerHTML = "";
+      }
+    } else {
+      el && el.setAttribute("code", value);
+    }
+  },
+};

+ 102 - 0
htmldev/manageTemplate/src/i18n/config/ar.js

@@ -0,0 +1,102 @@
+// 阿拉伯语
+import arLocale from 'element-ui/lib/locale/lang/ar'
+
+const ar = {
+  request: {
+    loading: 'جار التحميل',
+    timeout: 'الطلب منتهي المدة',
+    fail: 'فشل في الحصول على البيانات'
+  },
+  route: {
+    dashboard: 'الصفحة الرئيسية',
+    bcms: 'إدارة المضيف',
+    broadcast: 'قائمة المضيف',
+    liveDuration: 'إحصائيات البث المباشر',
+    liveDurationDetail: 'تفاصيل بيانات البث المباشر الفردي',
+    agentms: 'إدارة الوكالة',
+    agent: 'قائمة الوكالة',
+    anchor: 'قائمة المضيف التابعة للوكالة',
+    bms: 'إحصاءات النقدية',
+    pearl: 'إجمالي إحصاءات اللؤلؤ'
+  },
+  mod_password: 'غير كلمة السر',
+  logout: 'تسجيل الخروج',
+  welcome: 'مرحبًا بك في نظام الإدارة!',
+  // *********按钮区***********
+  search_btn: 'استعلام',
+  export_excel_btn: 'تصدير إكسل',
+  mod_btn: 'تعديل',
+  add_btn: 'الجديد',
+  cancel_btn: 'يلغي',
+  save_btn: 'حفظ',
+  confirm_btn: 'تأكد',
+  main_btn: 'العمل',
+  day_1: 'يوم 1',
+  day_3: '3 أيام',
+  day_7: '7 أيام',
+  lately_week: 'الأسبوع الماضي',
+  lately_one_month: 'الشهر الماضي',
+  lately_three_month: 'الأشهر الثلاثة الماضية',
+  day_infinitely: 'فرض حظر دائم',
+  day: 'يوم',
+  hour: 'ساعة',
+  minute: 'دقيقة',
+  // *********常用输入限制***********
+  maxlength_20: 'ما يصل إلى 20 حرفًا',
+  maxlength_50: 'ما يصل إلى 50 حرفًا',
+  // **********消息提示**********
+  modify_success_message: 'تم التعديل بنجاح',
+  submit_success_message: 'تم الإرسال بنجاح',
+  user_type: {
+    name_0: 'المستخدم',
+    name_1: 'مضيف',
+    name_2: 'وكيل'
+  },
+  user_new: {
+    name_0: 'لا',
+    name_1: 'نعم'
+  },
+  ...arLocale,
+  user_id: 'ايدي المستخدم',
+  user_id_placeholder: 'الرجاء إدخال ايدي المستخدم',
+  user_name: 'اسم',
+  user_name_placeholder: 'الرجاء إدخال لقب المستخدم',
+  user_real_name: 'الاسم الفعلي',
+  user_phone: 'رقم الهاتف',
+  order_by_desc_placeholder: 'الرجاء تحديد طريقة الترتيب',
+  idcard: 'رقم الهوية',
+  close: 'إغلاق',
+  checkAll: 'اختار الكل',
+  user_language_lable_option_1: 'الصينية',
+  user_language_lable_option_2: 'الانجليزية',
+  user_language_lable_option_3: 'إندونيسيا',
+  user_language_lable_option_0: 'العالمية',
+  user_language_lable_option_4: 'الملايو',
+  user_language_lable_option_5: 'بالعربية',
+  diamond_type_option_1: 'الدخل',
+  diamond_type_option_2: 'المصروفات',
+  pay_at: 'ساعة الصفقة',
+  log_change_type: 'نوع التدفق',
+  diamond_type: 'نوع المعاملة',
+  id_type_placeholder: 'الرجاء اختيار',
+  form_rules_required: 'مطلوب',
+  rule_not_empty: 'لايمكن ان يكون فارغا',
+  rule_mobile: 'الرجاء إدخال رقم الهاتف الصحيح',
+  rule_email: 'الرجاء إدخال البريد الإلكتروني الصحيح',
+  rule_start_date: 'الرجاء تحديد تاريخ البدء',
+  rule_end_date: 'الرجاء تحديد تاريخ الانتهاء',
+  rule_date: 'الرجاء تحديد تاريخ',
+  rule_select: 'الرجاء اختيار واحدا',
+  rule_number: 'الرجاء إدخال قيمة عددية',
+  rule_number_pot: 'يرجى ملء الرقم حتى منزلتين عشريتين',
+  rule_id_number_empty: 'لا يمكن أن يكون رقم الهوية فارغًا',
+  rule_id_number_error: 'رقم الهوية غير صحيح',
+  rule_int_number: 'الرجاء إدخال عدد صحيح',
+  rule_confirm_password: 'تم إدخال كلمة مرور غير متسقة مرتين',
+  rule_code: 'رمز التحقق المحمول',
+  rule_zh_mobile: 'حاليًا يتم دعم أرقام الهواتف المحمولة في الصين القارية فقط',
+  rule_password: 'يجب أن يتراوح الطول بين 6 و 18 حرفًا',
+  rule_upload_imgs: 'الرجاء تحديد صورة'
+}
+
+export default ar

+ 102 - 0
htmldev/manageTemplate/src/i18n/config/en.js

@@ -0,0 +1,102 @@
+// 英文
+import enLocale from 'element-ui/lib/locale/lang/en'
+
+const en = {
+  request: {
+    loading: 'Loading',
+    timeout: 'Request timed out',
+    fail: 'Failed to get data'
+  },
+  route: {
+    dashboard: 'front page',
+    bcms: 'host management',
+    broadcast: 'host list',
+    liveDuration: 'Live streaming statistics',
+    liveDurationDetail: 'Single live broadcast data details',
+    agentms: 'agency management',
+    agent: 'agency list',
+    anchor: 'agency subordinate host list',
+    bms: 'cash statistics',
+    pearl: 'total pearl statistics'
+  },
+  mod_password: 'change Password',
+  logout: 'sign out',
+  welcome: 'Welcome to the management system!',
+  // *********按钮区***********
+  search_btn: 'Inquire',
+  export_excel_btn: 'Export to Excel',
+  mod_btn: 'edit',
+  add_btn: 'new',
+  cancel_btn: 'Cancel',
+  save_btn: 'save',
+  confirm_btn: 'confirm',
+  main_btn: 'operate',
+  day_1: '1 day',
+  day_3: '3 days',
+  day_7: '7 days',
+  lately_week: ' last week',
+  lately_one_month: 'last month',
+  lately_three_month: 'last three months',
+  day_infinitely: 'Permanent ban',
+  day: 'day',
+  hour: 'hour',
+  minute: 'minute',
+  // *********常用输入限制***********
+  maxlength_20: 'Up to 20 characters',
+  maxlength_50: 'Up to 50 characters',
+  // **********消息提示**********
+  modify_success_message: 'Successfully modified',
+  submit_success_message: 'Submitted successfully',
+  user_type: {
+    name_0: 'user',
+    name_1: 'host',
+    name_2: 'agent'
+  },
+  user_new: {
+    name_0: 'no',
+    name_1: 'yes'
+  },
+  ...enLocale,
+  user_id: 'User ID',
+  user_id_placeholder: 'Please enter user ID',
+  user_name: 'Nickname',
+  user_name_placeholder: 'Please enter user nickname',
+  user_real_name: 'actual name',
+  user_phone: 'Phone number',
+  order_by_desc_placeholder: 'Please select a sorting method',
+  idcard: 'identity number',
+  close: 'close',
+  checkAll: 'select all',
+  user_language_lable_option_1: 'Chinese',
+  user_language_lable_option_2: 'English',
+  user_language_lable_option_3: 'Indonesia',
+  user_language_lable_option_0: 'Global',
+  user_language_lable_option_4: 'Malay',
+  user_language_lable_option_5: 'Arabic',
+  diamond_type_option_1: 'income',
+  diamond_type_option_2: 'expenditure',
+  pay_at: 'transaction hour',
+  log_change_type: 'Flow type',
+  diamond_type: 'Transaction Type',
+  id_type_placeholder: 'please choose',
+  form_rules_required: 'Required',
+  rule_not_empty: 'Can not be empty',
+  rule_mobile: 'please enter the correct phone number',
+  rule_email: 'Please enter correct email',
+  rule_start_date: 'Please select a start date',
+  rule_end_date: 'Please select an end date',
+  rule_date: 'Please select a date',
+  rule_select: 'Please choose one',
+  rule_number: 'Please enter a numeric value',
+  rule_number_pot: 'Please fill in the number, up to 2 decimal places',
+  rule_id_number_empty: 'ID number cannot be empty',
+  rule_id_number_error: 'ID number is incorrect',
+  rule_int_number: 'Please enter an integer',
+  rule_confirm_password: 'Inconsistent password entered twice',
+  rule_code: 'Mobile verification code',
+  rule_zh_mobile: 'Currently only mobile phone numbers in mainland China are supported',
+  rule_password: 'Length must between 6 and 18 characters',
+  rule_upload_imgs: 'Please select an image'
+}
+
+export default en

+ 102 - 0
htmldev/manageTemplate/src/i18n/config/id.js

@@ -0,0 +1,102 @@
+// 印尼
+import idLocale from 'element-ui/lib/locale/lang/id'
+
+const id = {
+  request: {
+    loading: 'Memuat',
+    timeout: 'Waktu permintaan habis',
+    fail: 'Mengambil data gagal'
+  },
+  route: {
+    dashboard: 'Beranda',
+    bcms: 'Manajemen host',
+    broadcast: 'Daftar host',
+    liveDuration: 'Data live streaming',
+    liveDurationDetail: 'Data detail live streaming perkali',
+    agentms: 'Manajemen Agency',
+    agent: 'Daftar Agency',
+    anchor: 'Daftar host di bawah agency',
+    bms: 'data cash',
+    pearl: 'Total data berlian'
+  },
+  mod_password: 'Ganti password',
+  logout: 'Keluar',
+  welcome: 'Selamat datang sistem manajemen!',
+  // *********按钮区***********
+  search_btn: 'Cek',
+  export_excel_btn: 'Ekspor ke Excel',
+  mod_btn: 'Edit',
+  add_btn: 'Baru',
+  cancel_btn: 'Batal',
+  save_btn: 'Simpan',
+  confirm_btn: 'Comfirm',
+  main_btn: 'Beroperasi',
+  day_1: '1 hari',
+  day_3: '3 hari',
+  day_7: '7 hari',
+  lately_week: 'Minggu lalu',
+  lately_one_month: 'Bulan lalu',
+  lately_three_month: 'Tiga bulan terakhir',
+  day_infinitely: 'Ban permanen',
+  day: 'Hari',
+  hour: 'Jam',
+  minute: 'Menit',
+  // *********常用输入限制***********
+  maxlength_20: 'Maksimal 20 karakter',
+  maxlength_50: 'Maksimal 50 karakter',
+  // **********消息提示**********
+  modify_success_message: 'Merubah sukses',
+  submit_success_message: 'Dikirim dengan sukses',
+  user_type: {
+    name_0: 'User',
+    name_1: 'Host',
+    name_2: 'Agency'
+  },
+  user_new: {
+    name_0: 'Tidak',
+    name_1: 'Ya'
+  },
+  ...idLocale,
+  user_id: 'ID pengguna',
+  user_id_placeholder: 'Silakan memasukkan ID user',
+  user_name: 'Nickname',
+  user_name_placeholder: 'Silakan memasukkan nickname User',
+  user_real_name: 'Nama sebenarnya',
+  user_phone: 'nomor HP',
+  order_by_desc_placeholder: 'Silakan pilih metode penyortiran',
+  idcard: 'KTP',
+  close: 'Tutup',
+  checkAll: 'Pilih semua',
+  user_language_lable_option_1: 'Mandarin',
+  user_language_lable_option_2: 'Inggris',
+  user_language_lable_option_3: 'Indonesia',
+  user_language_lable_option_0: 'Global',
+  user_language_lable_option_4: 'Malay',
+  user_language_lable_option_5: 'Arab',
+  diamond_type_option_1: 'Pendapatan',
+  diamond_type_option_2: 'Pengeluaran',
+  pay_at: 'Waktu transaksi',
+  log_change_type: 'Type aliran',
+  diamond_type: 'Type transaksi',
+  id_type_placeholder: 'silakan pilih',
+  form_rules_required: 'Diperlukan',
+  rule_not_empty: 'Tidak bisa kosong',
+  rule_mobile: 'Silakan masukkan nomor HP benar',
+  rule_email: 'Silakan masukkan email benar',
+  rule_start_date: 'Silakan pilih waktu mulai',
+  rule_end_date: 'Silakan pilih waktu henti',
+  rule_date: 'Silakan pilih waktu',
+  rule_select: 'Silakan pilih satu',
+  rule_number: 'Silakan masukkan value',
+  rule_number_pot: 'Silakan isi angkanya, maksimal 2 tempat desimal',
+  rule_id_number_empty: 'Nomor KTP tidak bisa kosong',
+  rule_id_number_error: 'Nomor KTP salah',
+  rule_int_number: 'Harap masukkan bilangan bulat',
+  rule_confirm_password: 'Kata sandi yang tidak konsisten dimasukkan dua kali',
+  rule_code: 'Kode verifikasi seluler',
+  rule_zh_mobile: 'Saat ini hanya nomor ponsel di Cina daratan yang didukung',
+  rule_password: 'Panjangnya harus antara 6 dan 18 karakter',
+  rule_upload_imgs: 'Silakan pilih foto'
+}
+
+export default id

+ 93 - 0
htmldev/manageTemplate/src/i18n/config/zh.js

@@ -0,0 +1,93 @@
+// 中文
+import zhLocale from 'element-ui/lib/locale/lang/zh-CN'
+
+const zh = {
+  request: {
+    loading: '拼命获取中',
+    timeout: '请求超时',
+    fail: '数据获取失败'
+  },
+  route: {
+    dashboard: '首页'
+  },
+  mod_password: '修改密码',
+  logout: '退出登录',
+  welcome: '欢迎来到管理系统!',
+  // *********按钮区***********
+  search_btn: '查询',
+  export_excel_btn: '导出Excel',
+  mod_btn: '编辑',
+  add_btn: '新增',
+  cancel_btn: '取消',
+  save_btn: '保存',
+  confirm_btn: '确认',
+  main_btn: '操作',
+  day_1: '1天',
+  day_3: '3天',
+  day_7: '7天',
+  lately_week: '最近一周',
+  lately_one_month: '最近一个月',
+  lately_three_month: '最近三个月',
+  day_infinitely: '永久封禁',
+  day: '天',
+  hour: '小时',
+  minute: '分钟',
+  // *********常用输入限制***********
+  maxlength_20: '上限20个字符',
+  maxlength_50: '上限50个字符',
+  // **********消息提示**********
+  modify_success_message: '修改成功',
+  submit_success_message: '提交成功',
+  user_type: {
+    name_0: '用户',
+    name_1: '主播',
+    name_2: '家族长'
+  },
+  user_new: {
+    name_0: '否',
+    name_1: '是'
+  },
+  ...zhLocale,
+  user_id: '用户id',
+  user_id_placeholder: '请输入用户ID',
+  user_name: '昵称',
+  user_name_placeholder: '请输入用户昵称',
+  user_real_name: '真实姓名',
+  user_phone: '手机号',
+  order_by_desc_placeholder: '请选择排序方式',
+  idcard: '身份证号',
+  close: '关闭',
+  checkAll: '全选',
+  user_language_lable_option_1: '中文',
+  user_language_lable_option_2: '英语',
+  user_language_lable_option_3: '印尼',
+  user_language_lable_option_0: '全球',
+  user_language_lable_option_4: '马来语',
+  user_language_lable_option_5: '阿拉伯语',
+  diamond_type_option_1: '收入',
+  diamond_type_option_2: '支出',
+  pay_at: '交易时间',
+  log_change_type: '流水类型',
+  diamond_type: '交易类型',
+  id_type_placeholder: '请选择',
+  form_rules_required: '必填',
+  rule_not_empty: '不能为空',
+  rule_mobile: '请输入正确手机号',
+  rule_email: '请输入正确邮箱',
+  rule_start_date: '请选择开始日期',
+  rule_end_date: '请选择结束日期',
+  rule_date: '请选择日期',
+  rule_select: '请选择一个',
+  rule_number: '请输入数字值',
+  rule_number_pot: '请填写数字,最多2位小数',
+  rule_id_number_empty: '证件号码不能为空',
+  rule_id_number_error: '证件号码不正确',
+  rule_int_number: '请输入整数',
+  rule_confirm_password: '两次密码输入不一致',
+  rule_code: '手机验证码',
+  rule_zh_mobile: '目前只支持中国大陆的手机号码',
+  rule_password: '长度必须大于6位长度在 6 到 18 个字符之间',
+  rule_upload_imgs: '请选择图片'
+}
+
+export default zh

+ 22 - 0
htmldev/manageTemplate/src/i18n/index.js

@@ -0,0 +1,22 @@
+import Vue from 'vue'
+import locale from 'element-ui/lib/locale'
+import VueI18n from 'vue-i18n'
+import zh from './config/zh'
+import en from './config/en'
+import id from './config/id'
+import ar from './config/ar'
+import { getLocale } from '@/utils/auth'
+
+Vue.use(VueI18n)
+const i18n = new VueI18n({
+  locale: getLocale(),
+  messages: {
+    zh, // 中文
+    en, // 英文
+    id, // 印尼
+    ar // 阿拉伯语
+  }
+})
+locale.i18n((key, value) => i18n.t(key, value))
+
+export default i18n

+ 9 - 0
htmldev/manageTemplate/src/icons/index.js

@@ -0,0 +1,9 @@
+import Vue from 'vue'
+import SvgIcon from '@/components/SvgIcon'// svg component
+
+// register globally
+Vue.component('svg-icon', SvgIcon)
+
+const req = require.context('./svg', false, /\.svg$/)
+const requireAll = requireContext => requireContext.keys().map(requireContext)
+requireAll(req)

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/404.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M121.718 73.272v9.953c3.957-7.584 6.199-16.05 6.199-24.995C127.917 26.079 99.273 0 63.958 0 28.644 0 0 26.079 0 58.23c0 .403.028.806.028 1.21l22.97-25.953h13.34l-19.76 27.187h6.42V53.77l13.728-19.477v49.361H22.998V73.272H2.158c5.951 20.284 23.608 36.208 45.998 41.399-1.44 3.3-5.618 11.263-12.565 12.674-8.607 1.764 23.358.428 46.163-13.178 17.519-4.611 31.938-15.849 39.77-30.513h-13.506V73.272H85.02V59.464l22.998-25.977h13.008l-19.429 27.187h6.421v-7.433l13.727-19.402v39.433h-.027zm-78.24 2.822a10.516 10.516 0 0 1-.996-4.535V44.548c0-1.613.332-3.124.996-4.535a11.66 11.66 0 0 1 2.713-3.68c1.134-1.032 2.49-1.864 4.04-2.468 1.55-.605 3.21-.908 4.982-.908h11.292c1.77 0 3.431.303 4.981.908 1.522.604 2.85 1.41 3.986 2.418l-12.26 16.303v-2.898a1.96 1.96 0 0 0-.665-1.512c-.443-.403-.996-.604-1.66-.604-.665 0-1.218.201-1.661.604a1.96 1.96 0 0 0-.664 1.512v9.071L44.364 77.606a10.556 10.556 0 0 1-.886-1.512zm35.73-4.535c0 1.613-.332 3.124-.997 4.535a11.66 11.66 0 0 1-2.712 3.68c-1.134 1.032-2.49 1.864-4.04 2.469-1.55.604-3.21.907-4.982.907H55.185c-1.77 0-3.431-.303-4.981-.907-1.55-.605-2.906-1.437-4.041-2.47a12.49 12.49 0 0 1-1.384-1.512l13.727-18.217v6.375c0 .605.222 1.109.665 1.512.442.403.996.604 1.66.604.664 0 1.218-.201 1.66-.604a1.96 1.96 0 0 0 .665-1.512V53.87L75.97 36.838c.913.932 1.66 1.99 2.214 3.175.664 1.41.996 2.922.996 4.535v27.011h.028z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/bug.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M127.88 73.143c0 1.412-.506 2.635-1.518 3.669-1.011 1.033-2.209 1.55-3.592 1.55h-17.887c0 9.296-1.783 17.178-5.35 23.645l16.609 17.044c1.011 1.034 1.517 2.257 1.517 3.67 0 1.412-.506 2.635-1.517 3.668-.958 1.033-2.155 1.55-3.593 1.55-1.438 0-2.635-.517-3.593-1.55l-15.811-16.063a15.49 15.49 0 0 1-1.196 1.06c-.532.434-1.65 1.208-3.353 2.322a50.104 50.104 0 0 1-5.192 2.974c-1.758.87-3.94 1.658-6.546 2.364-2.607.706-5.189 1.06-7.748 1.06V47.044H58.89v73.062c-2.716 0-5.417-.367-8.106-1.102-2.688-.734-5.003-1.631-6.945-2.692a66.769 66.769 0 0 1-5.268-3.179c-1.571-1.057-2.73-1.94-3.476-2.65L33.9 109.34l-14.611 16.877c-1.066 1.14-2.344 1.711-3.833 1.711-1.277 0-2.422-.434-3.434-1.304-1.012-.978-1.557-2.187-1.635-3.627-.079-1.44.333-2.705 1.236-3.794l16.129-18.51c-3.087-6.197-4.63-13.644-4.63-22.342H5.235c-1.383 0-2.58-.517-3.592-1.55S.125 74.545.125 73.132c0-1.412.506-2.635 1.518-3.668 1.012-1.034 2.21-1.55 3.592-1.55h17.887V43.939L9.308 29.833c-1.012-1.033-1.517-2.256-1.517-3.669 0-1.412.505-2.635 1.517-3.668 1.012-1.034 2.21-1.55 3.593-1.55s2.58.516 3.593 1.55l13.813 14.106h67.396l13.814-14.106c1.012-1.034 2.21-1.55 3.592-1.55 1.384 0 2.581.516 3.593 1.55 1.012 1.033 1.518 2.256 1.518 3.668 0 1.413-.506 2.636-1.518 3.67l-13.814 14.105v23.975h17.887c1.383 0 2.58.516 3.593 1.55 1.011 1.033 1.517 2.256 1.517 3.668l-.005.01zM89.552 26.175H38.448c0-7.23 2.489-13.386 7.466-18.469C50.892 2.623 56.92.082 64 .082c7.08 0 13.108 2.541 18.086 7.624 4.977 5.083 7.466 11.24 7.466 18.469z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/chart.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M0 54.857h36.571V128H0V54.857zM91.429 27.43H128V128H91.429V27.429zM45.714 0h36.572v128H45.714V0z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/clipboard.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M54.857 118.857h64V73.143H89.143c-1.902 0-3.52-.668-4.855-2.002-1.335-1.335-2.002-2.954-2.002-4.855V36.57H54.857v82.286zM73.143 16v-4.571a2.2 2.2 0 0 0-.677-1.61 2.198 2.198 0 0 0-1.609-.676H20.571c-.621 0-1.158.225-1.609.676a2.198 2.198 0 0 0-.676 1.61V16a2.2 2.2 0 0 0 .676 1.61c.451.45.988.676 1.61.676h50.285c.622 0 1.158-.226 1.61-.677.45-.45.676-.987.676-1.609zm18.286 48h21.357L91.43 42.642V64zM128 73.143v48c0 1.902-.667 3.52-2.002 4.855-1.335 1.335-2.953 2.002-4.855 2.002H52.57c-1.901 0-3.52-.667-4.854-2.002-1.335-1.335-2.003-2.953-2.003-4.855v-11.429H6.857c-1.902 0-3.52-.667-4.855-2.002C.667 106.377 0 104.759 0 102.857v-96c0-1.902.667-3.52 2.002-4.855C3.337.667 4.955 0 6.857 0h77.714c1.902 0 3.52.667 4.855 2.002 1.335 1.335 2.003 2.953 2.003 4.855V30.29c1 .622 1.856 1.29 2.569 2.003l29.147 29.147c1.335 1.335 2.478 3.145 3.429 5.43.95 2.287 1.426 4.383 1.426 6.291v-.018z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/component.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M0 0h54.857v54.857H0V0zm0 73.143h54.857V128H0V73.143zm73.143 0H128V128H73.143V73.143zm27.428-18.286C115.72 54.857 128 42.577 128 27.43 128 12.28 115.72 0 100.571 0 85.423 0 73.143 12.28 73.143 27.429c0 15.148 12.28 27.428 27.428 27.428z"/></svg>

File diff suppressed because it is too large
+ 0 - 0
htmldev/manageTemplate/src/icons/svg/dashboard.svg


+ 1 - 0
htmldev/manageTemplate/src/icons/svg/documentation.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M71.984 44.815H115.9L71.984 9.642v35.173zM16.094.05h63.875l47.906 38.37v76.74c0 3.392-1.682 6.645-4.677 9.044-2.995 2.399-7.056 3.746-11.292 3.746H16.094c-4.236 0-8.297-1.347-11.292-3.746-2.995-2.399-4.677-5.652-4.677-9.044V12.84C.125 5.742 7.23.05 16.094.05zm71.86 102.32V89.58h-71.86v12.79h71.86zm23.952-25.58V64H16.094v12.79h95.812z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/drag.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M73.137 29.08h-9.209 29.7L63.886.093 34.373 29.08h20.49v27.035H27.238v17.948h27.625v27.133h18.274V74.063h27.41V56.115h-27.41V29.08zm-9.245 98.827l27.518-26.711H36.59l27.302 26.71zM.042 64.982l27.196 27.029V38.167L.042 64.982zm100.505-26.815V92.01l27.41-27.029-27.41-26.815z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/edit.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M106.133 67.2a4.797 4.797 0 0 0-4.8 4.8c0 .187.014.36.027.533h-.027V118.4H9.6V26.667h50.133c2.654 0 4.8-2.147 4.8-4.8 0-2.654-2.146-4.8-4.8-4.8H9.6a9.594 9.594 0 0 0-9.6 9.6V118.4c0 5.307 4.293 9.6 9.6 9.6h91.733c5.307 0 9.6-4.293 9.6-9.6V72.533h-.026c.013-.173.026-.346.026-.533 0-2.653-2.146-4.8-4.8-4.8z"/><path d="M125.16 13.373L114.587 2.8c-3.747-3.747-9.854-3.72-13.6.027l-52.96 52.96a4.264 4.264 0 0 0-.907 1.36L33.813 88.533c-.746 1.76-.226 3.534.907 4.68 1.133 1.147 2.92 1.667 4.693.92l31.4-13.293c.507-.213.96-.52 1.36-.907l52.96-52.96c3.747-3.746 3.774-9.853.027-13.6zM66.107 72.4l-18.32 7.76 7.76-18.32L92.72 24.667l10.56 10.56L66.107 72.4zm52.226-52.227l-8.266 8.267-10.56-10.56 8.266-8.267.027-.026 10.56 10.56-.027.026z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/education.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M88.883 119.565c-7.284 0-19.434 2.495-21.333 8.25v.127c-4.232.13-5.222 0-7.108 0-1.895-5.76-14.045-8.256-21.333-8.256H0V0h42.523c9.179 0 17.109 5.47 21.47 13.551C68.352 5.475 76.295 0 85.478 0H128v119.57l-39.113-.005h-.004zM60.442 24.763c0-9.651-8.978-16.507-17.777-16.507H7.108V111.43H39.11c7.054-.14 18.177.082 21.333 6.12v-4.628c-.134-5.722-.004-13.522 0-13.832V27.413l.004-2.655-.004.005zm60.442-16.517h-35.55c-8.802 0-17.78 6.856-17.78 16.493v74.259c.004.32.138 8.115 0 13.813v4.627c3.155-6.022 14.279-6.26 21.333-6.114h32V8.25l-.003-.005z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/email.svg

@@ -0,0 +1 @@
+<svg width="128" height="96" xmlns="http://www.w3.org/2000/svg"><path d="M64.125 56.975L120.188.912A12.476 12.476 0 0 0 115.5 0h-103c-1.588 0-3.113.3-4.513.838l56.138 56.137z"/><path d="M64.125 68.287l-62.3-62.3A12.42 12.42 0 0 0 0 12.5v71C0 90.4 5.6 96 12.5 96h103c6.9 0 12.5-5.6 12.5-12.5v-71a12.47 12.47 0 0 0-1.737-6.35L64.125 68.287z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/example.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M96.258 57.462h31.421C124.794 27.323 100.426 2.956 70.287.07v31.422a32.856 32.856 0 0 1 25.971 25.97zm-38.796-25.97V.07C27.323 2.956 2.956 27.323.07 57.462h31.422a32.856 32.856 0 0 1 25.97-25.97zm12.825 64.766v31.421c30.46-2.885 54.507-27.253 57.713-57.712H96.579c-2.886 13.466-13.146 23.726-26.292 26.291zM31.492 70.287H.07c2.886 30.46 27.253 54.507 57.713 57.713V96.579c-13.466-2.886-23.726-13.146-26.291-26.292z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/excel.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M78.208 16.576v8.384h38.72v5.376h-38.72v8.704h38.72v5.376h-38.72v8.576h38.72v5.376h-38.72v8.576h38.72v5.376h-38.72v8.576h38.72v5.376h-38.72v8.512h38.72v5.376h-38.72v11.136H128v-94.72H78.208zM0 114.368L72.128 128V0L0 13.632v100.736z"/><path d="M28.672 82.56h-11.2l14.784-23.488-14.08-22.592h11.52l8.192 14.976 8.448-14.976h11.136l-14.08 22.208L58.368 82.56H46.656l-8.768-15.68z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/exit-fullscreen.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M49.217 41.329l-.136-35.24c-.06-2.715-2.302-4.345-5.022-4.405h-3.65c-2.712-.06-4.866 2.303-4.806 5.016l.152 19.164-24.151-23.79a6.698 6.698 0 0 0-9.499 0 6.76 6.76 0 0 0 0 9.526l23.93 23.713-18.345.074c-2.712-.069-5.228 1.813-5.64 5.02v3.462c.069 2.721 2.31 4.97 5.022 5.03l35.028-.207c.052.005.087.025.133.025l2.457.054a4.626 4.626 0 0 0 3.436-1.38c.88-.874 1.205-2.096 1.169-3.462l-.262-2.465c0-.048.182-.081.182-.136h.002zm52.523 51.212l18.32-.073c2.713.06 5.224-1.609 5.64-4.815v-3.462c-.068-2.722-2.317-4.97-5.021-5.04l-34.58.21c-.053 0-.086-.021-.138-.021l-2.451-.06a4.64 4.64 0 0 0-3.445 1.381c-.885.868-1.201 2.094-1.174 3.46l.27 2.46c.005.06-.177.095-.177.141l.141 34.697c.069 2.713 2.31 4.338 5.022 4.397l3.45.006c2.705.062 4.867-2.31 4.8-5.026l-.153-18.752 24.151 23.946a6.69 6.69 0 0 0 9.494 0 6.747 6.747 0 0 0 0-9.523L101.74 92.54v.001zM48.125 80.662a4.636 4.636 0 0 0-3.437-1.382l-2.457.06c-.05 0-.082.022-.137.022l-35.025-.21c-2.712.07-4.957 2.318-5.022 5.04v3.462c.409 3.206 2.925 4.874 5.633 4.814l18.554.06-24.132 23.928c-2.62 2.626-2.62 6.89 0 9.524a6.694 6.694 0 0 0 9.496 0l24.155-23.79-.155 18.866c-.06 2.722 2.094 5.093 4.801 5.025h3.65c2.72-.069 4.962-1.685 5.022-4.406l.141-34.956c0-.05-.182-.082-.182-.136l.262-2.46c.03-1.366-.286-2.592-1.166-3.46h-.001zM80.08 47.397a4.62 4.62 0 0 0 3.443 1.374l2.45-.054c.055 0 .088-.02.143-.028l35.08.21c2.712-.062 4.953-2.312 5.021-5.033l.009-3.463c-.417-3.211-2.937-5.084-5.64-5.025l-18.615-.073 23.917-23.715c2.63-2.623 2.63-6.879.008-9.513a6.691 6.691 0 0 0-9.494 0L92.251 26.016l.155-19.312c.065-2.713-2.097-5.085-4.802-5.025h-3.45c-2.713.069-4.954 1.693-5.022 4.406l-.139 35.247c0 .054.18.088.18.136l-.267 2.465c-.028 1.366.288 2.588 1.174 3.463v.001z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/eye-open.svg

@@ -0,0 +1 @@
+<svg class="icon" viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="128" height="128"><defs><style/></defs><path d="M512 128q69.675 0 135.51 21.163t115.498 54.997 93.483 74.837 73.685 82.006 51.67 74.837 32.17 54.827L1024 512q-2.347 4.992-6.315 13.483T998.87 560.17t-31.658 51.669-44.331 59.99-56.832 64.34-69.504 60.16-82.347 51.5-94.848 34.687T512 896q-69.675 0-135.51-21.163t-115.498-54.826-93.483-74.326-73.685-81.493-51.67-74.496-32.17-54.997L0 513.707q2.347-4.992 6.315-13.483t18.816-34.816 31.658-51.84 44.331-60.33 56.832-64.683 69.504-60.331 82.347-51.84 94.848-34.816T512 128.085zm0 85.333q-46.677 0-91.648 12.331t-81.152 31.83-70.656 47.146-59.648 54.485-48.853 57.686-37.675 52.821-26.325 43.99q12.33 21.674 26.325 43.52t37.675 52.351 48.853 57.003 59.648 53.845T339.2 767.02t81.152 31.488T512 810.667t91.648-12.331 81.152-31.659 70.656-46.848 59.648-54.186 48.853-57.344 37.675-52.651T927.957 512q-12.33-21.675-26.325-43.648t-37.675-52.65-48.853-57.345-59.648-54.186-70.656-46.848-81.152-31.659T512 213.334zm0 128q70.656 0 120.661 50.006T682.667 512 632.66 632.661 512 682.667 391.339 632.66 341.333 512t50.006-120.661T512 341.333zm0 85.334q-35.328 0-60.33 25.002T426.666 512t25.002 60.33T512 597.334t60.33-25.002T597.334 512t-25.002-60.33T512 426.666z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/eye.svg

@@ -0,0 +1 @@
+<svg width="128" height="64" xmlns="http://www.w3.org/2000/svg"><path d="M127.072 7.994c1.37-2.208.914-5.152-.914-6.87-2.056-1.717-4.797-1.226-6.396.982-.229.245-25.586 32.382-55.74 32.382-29.24 0-55.74-32.382-55.968-32.627-1.6-1.963-4.57-2.208-6.397-.49C-.17 3.086-.399 6.275 1.2 8.238c.457.736 5.94 7.36 14.62 14.72L4.17 35.96c-1.828 1.963-1.6 5.152.228 6.87.457.98 1.6 1.471 2.742 1.471s2.284-.49 3.198-1.472l12.564-13.983c5.94 4.416 13.021 8.587 20.788 11.53l-4.797 17.418c-.685 2.699.686 5.397 3.198 6.133h1.37c2.057 0 3.884-1.472 4.341-3.68L52.6 42.83c3.655.736 7.538 1.227 11.422 1.227 3.883 0 7.767-.49 11.422-1.227l4.797 17.173c.457 2.208 2.513 3.68 4.34 3.68.457 0 .914 0 1.143-.246 2.513-.736 3.883-3.434 3.198-6.133l-4.797-17.172c7.767-2.944 14.848-7.114 20.788-11.53l12.336 13.738c.913.981 2.056 1.472 3.198 1.472s2.284-.49 3.198-1.472c1.828-1.963 1.828-4.906.228-6.87l-11.65-13.001c9.366-7.36 14.849-14.474 14.849-14.474z"/></svg>

File diff suppressed because it is too large
+ 0 - 0
htmldev/manageTemplate/src/icons/svg/form.svg


+ 1 - 0
htmldev/manageTemplate/src/icons/svg/fullscreen.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M38.47 52L52 38.462l-23.648-23.67L43.209 0H.035L0 43.137l14.757-14.865L38.47 52zm74.773 47.726L89.526 76 76 89.536l23.648 23.672L84.795 128h43.174L128 84.863l-14.757 14.863zM89.538 52l23.668-23.648L128 43.207V.038L84.866 0 99.73 14.76 76 38.472 89.538 52zM38.46 76L14.792 99.651 0 84.794v43.173l43.137.033-14.865-14.757L52 89.53 38.46 76z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/guide.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M1.482 70.131l36.204 16.18 69.932-65.485-61.38 70.594 46.435 18.735c1.119.425 2.397-.17 2.797-1.363v-.085L127.998.047 1.322 65.874c-1.12.597-1.519 1.959-1.04 3.151.32.511.72.937 1.2 1.107zm44.676 57.821L64.22 107.26l-18.062-7.834v28.527z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/icon.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M115.147.062a13 13 0 0 1 4.94.945c1.55.63 2.907 1.526 4.069 2.688a13.148 13.148 0 0 1 2.761 4.069c.678 1.55 1.017 3.245 1.017 5.086v102.3c0 3.681-1.187 6.733-3.56 9.155-2.373 2.422-5.352 3.633-8.937 3.633H12.992c-3.875 0-7-1.26-9.373-3.779-2.373-2.518-3.56-5.667-3.56-9.445V12.704c0-3.39 1.163-6.345 3.488-8.863C5.872 1.32 8.972.062 12.847.062h102.3zM81.434 109.047c1.744 0 3.003-.412 3.778-1.235.775-.824 1.163-1.914 1.163-3.27 0-1.26-.388-2.325-1.163-3.197-.775-.872-2.034-1.307-3.778-1.307H72.57c.097-.194.145-.485.145-.872V27.09h9.01c1.743 0 2.954-.436 3.633-1.308.678-.872 1.017-1.938 1.017-3.197 0-1.26-.34-2.325-1.017-3.197-.679-.872-1.89-1.308-3.633-1.308H46.268c-1.743 0-2.954.436-3.632 1.308-.678.872-1.018 1.938-1.018 3.197 0 1.26.34 2.325 1.018 3.197.678.872 1.889 1.308 3.632 1.308h8.138v72.075c0 .193.024.339.073.436.048.096.072.242.072.436H46.56c-1.744 0-3.003.435-3.778 1.307-.775.872-1.163 1.938-1.163 3.197 0 1.356.388 2.446 1.163 3.27.775.823 2.034 1.235 3.778 1.235h34.875z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/international.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M83.287 103.01c-1.57-3.84-6.778-10.414-15.447-19.548-2.327-2.444-2.182-4.306-1.338-9.862v-.64c.553-3.81 1.513-6.05 14.313-8.087 6.516-1.018 8.203 1.57 10.589 5.178l.785 1.193a12.625 12.625 0 0 0 6.43 5.207c1.134.524 2.53 1.164 4.421 2.24 4.596 2.53 4.596 5.41 4.596 11.753v.727a26.91 26.91 0 0 1-5.178 17.454 59.055 59.055 0 0 1-19.025 11.026c3.49-6.546.814-14.313 0-16.553l-.146-.087zM64 5.12a58.502 58.502 0 0 1 25.484 5.818 54.313 54.313 0 0 0-12.859 10.327c-.93 1.28-1.716 2.473-2.472 3.579-2.444 3.694-3.637 5.352-5.818 5.614a25.105 25.105 0 0 1-4.219 0c-4.276-.29-10.094-.64-11.956 4.422-1.193 3.23-1.396 11.956 2.444 16.495.66 1.077.778 2.4.32 3.578a7.01 7.01 0 0 1-2.066 3.229 18.938 18.938 0 0 1-2.909-2.91 18.91 18.91 0 0 0-8.32-6.603c-1.25-.349-2.647-.64-3.985-.93-3.782-.786-8.03-1.688-9.019-3.812a14.895 14.895 0 0 1-.727-5.818 21.935 21.935 0 0 0-1.396-9.25 8.873 8.873 0 0 0-5.557-4.946A58.705 58.705 0 0 1 64 5.12zM0 64c0 35.346 28.654 64 64 64 35.346 0 64-28.654 64-64 0-35.346-28.654-64-64-64C28.654 0 0 28.654 0 64z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/language.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M84.742 36.8c2.398 7.2 5.595 12.8 11.19 18.4 4.795-4.8 7.992-11.2 10.39-18.4h-21.58zm-52.748 40h20.78l-10.39-28-10.39 28z"/><path d="M111.916 0H16.009C7.218 0 .025 7.2.025 16v96c0 8.8 7.193 16 15.984 16h95.907c8.791 0 15.984-7.2 15.984-16V16c0-8.8-6.394-16-15.984-16zM72.754 103.2c-1.598 1.6-3.197 1.6-4.795 1.6-.8 0-2.398 0-3.197-.8-.8-.8-1.599 0-1.599-.8s-.799-1.6-1.598-3.2c-.8-1.6-.8-2.4-1.599-4l-3.196-8.8H28.797L25.6 96c-1.598 3.2-2.398 5.6-3.197 7.2-.8 1.6-2.398 1.6-4.795 1.6-1.599 0-3.197-.8-4.796-1.6-1.598-1.6-2.397-2.4-2.397-4 0-.8 0-1.6.799-3.2.8-1.6.8-2.4 1.598-4l17.583-44.8c.8-1.6.8-3.2 1.599-4.8.799-1.6 1.598-3.2 2.397-4 .8-.8 1.599-2.4 3.197-3.2 1.599-.8 3.197-.8 4.796-.8 1.598 0 3.196 0 4.795.8 1.598.8 2.398 1.6 3.197 3.2.799.8 1.598 2.4 2.397 4 .8 1.6 1.599 3.2 2.398 5.6l17.583 44c1.598 3.2 2.398 5.6 2.398 7.2-.8.8-1.599 2.4-2.398 4zM116.711 72c-8.791-3.2-15.185-7.2-20.78-12-5.594 5.6-12.787 9.6-21.579 12l-2.397-4c8.791-2.4 15.984-5.6 21.579-11.2C87.939 51.2 83.144 44 81.545 36h-7.992v-3.2h21.58c-1.6-2.4-3.198-5.6-4.796-8l2.397-.8c1.599 2.4 3.997 5.6 5.595 8.8h19.98v4h-7.992c-2.397 8-6.393 15.2-11.189 20 5.595 4.8 11.988 8.8 20.78 11.2l-3.197 4z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/link.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M115.625 127.937H.063V12.375h57.781v12.374H12.438v90.813h90.813V70.156h12.374z"/><path d="M116.426 2.821l8.753 8.753-56.734 56.734-8.753-8.745z"/><path d="M127.893 37.982h-12.375V12.375H88.706V0h39.187z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/list.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M1.585 12.087c0 6.616 3.974 11.98 8.877 11.98 4.902 0 8.877-5.364 8.877-11.98 0-6.616-3.975-11.98-8.877-11.98-4.903 0-8.877 5.364-8.877 11.98zM125.86.107H35.613c-1.268 0-2.114 1.426-2.114 2.852v18.255c0 1.712 1.057 2.853 2.114 2.853h90.247c1.268 0 2.114-1.426 2.114-2.853V2.96c0-1.711-1.057-2.852-2.114-2.852zM.106 62.86c0 6.615 3.974 11.979 8.876 11.979 4.903 0 8.877-5.364 8.877-11.98 0-6.616-3.974-11.98-8.877-11.98-4.902 0-8.876 5.364-8.876 11.98zM124.17 50.88H33.921c-1.268 0-2.114 1.425-2.114 2.851v18.256c0 1.711 1.057 2.852 2.114 2.852h90.247c1.268 0 2.114-1.426 2.114-2.852V53.73c0-1.426-.846-2.852-2.114-2.852zM.106 115.913c0 6.616 3.974 11.98 8.876 11.98 4.903 0 8.877-5.364 8.877-11.98 0-6.616-3.974-11.98-8.877-11.98-4.902 0-8.876 5.364-8.876 11.98zm124.064-11.98H33.921c-1.268 0-2.114 1.426-2.114 2.853v18.255c0 1.711 1.057 2.852 2.114 2.852h90.247c1.268 0 2.114-1.426 2.114-2.852v-18.255c0-1.427-.846-2.853-2.114-2.853z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/lock.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M119.88 49.674h-7.987V39.52C111.893 17.738 90.45.08 63.996.08 37.543.08 16.1 17.738 16.1 39.52v10.154H8.113c-4.408 0-7.987 2.94-7.987 6.577v65.13c0 3.637 3.57 6.577 7.987 6.577H119.88c4.407 0 7.987-2.94 7.987-6.577v-65.13c-.008-3.636-3.58-6.577-7.987-6.577zm-23.953 0H32.065V39.52c0-14.524 14.301-26.295 31.931-26.295 17.63 0 31.932 11.777 31.932 26.295v10.153z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/message.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M0 20.967v59.59c0 11.59 8.537 20.966 19.075 20.966h28.613l1 26.477L76.8 101.523h32.125c10.538 0 19.075-9.377 19.075-20.966v-59.59C128 9.377 119.463 0 108.925 0h-89.85C8.538 0 0 9.377 0 20.967zm82.325 33.1c0-5.524 4.013-9.935 9.037-9.935 5.026 0 9.038 4.41 9.038 9.934 0 5.524-4.025 9.934-9.038 9.934-5.024 0-9.037-4.41-9.037-9.934zm-27.613 0c0-5.524 4.013-9.935 9.038-9.935s9.037 4.41 9.037 9.934c0 5.524-4.025 9.934-9.037 9.934-5.025 0-9.038-4.41-9.038-9.934zm-27.1 0c0-5.524 4.013-9.935 9.038-9.935s9.038 4.41 9.038 9.934c0 5.524-4.026 9.934-9.05 9.934-5.013 0-9.025-4.41-9.025-9.934z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/money.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M54.122 127.892v-28.68H7.513V87.274h46.609v-12.4H7.513v-12.86h38.003L.099 0h22.6l32.556 45.07c3.617 5.144 6.44 9.611 8.487 13.385 1.788-3.05 4.89-7.779 9.301-14.186L103.93 0h24.01L82.385 62.013h38.34v12.862h-46.41v12.4h46.41v11.937h-46.41v28.68H54.123z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/nested.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M.002 9.2c0 5.044 3.58 9.133 7.998 9.133 4.417 0 7.997-4.089 7.997-9.133 0-5.043-3.58-9.132-7.997-9.132S.002 4.157.002 9.2zM31.997.066h95.981V18.33H31.997V.066zm0 45.669c0 5.044 3.58 9.132 7.998 9.132 4.417 0 7.997-4.088 7.997-9.132 0-3.263-1.524-6.278-3.998-7.91-2.475-1.63-5.524-1.63-7.998 0-2.475 1.632-4 4.647-4 7.91zM63.992 36.6h63.986v18.265H63.992V36.6zm-31.995 82.2c0 5.043 3.58 9.132 7.998 9.132 4.417 0 7.997-4.089 7.997-9.132 0-5.044-3.58-9.133-7.997-9.133s-7.998 4.089-7.998 9.133zm31.995-9.131h63.986v18.265H63.992V109.67zm0-27.404c0 5.044 3.58 9.133 7.998 9.133 4.417 0 7.997-4.089 7.997-9.133 0-3.263-1.524-6.277-3.998-7.909-2.475-1.631-5.524-1.631-7.998 0-2.475 1.632-4 4.646-4 7.91zm31.995-9.13h31.991V91.4H95.987V73.135z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/password.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M108.8 44.322H89.6v-5.36c0-9.04-3.308-24.163-25.6-24.163-23.145 0-25.6 16.881-25.6 24.162v5.361H19.2v-5.36C19.2 15.281 36.798 0 64 0c27.202 0 44.8 15.281 44.8 38.961v5.361zm-32 39.356c0-5.44-5.763-9.832-12.8-9.832-7.037 0-12.8 4.392-12.8 9.832 0 3.682 2.567 6.808 6.407 8.477v11.205c0 2.718 2.875 4.962 6.4 4.962 3.524 0 6.4-2.244 6.4-4.962V92.155c3.833-1.669 6.393-4.795 6.393-8.477zM128 64v49.201c0 8.158-8.645 14.799-19.2 14.799H19.2C8.651 128 0 121.359 0 113.201V64c0-8.153 8.645-14.799 19.2-14.799h89.6c10.555 0 19.2 6.646 19.2 14.799z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/pdf.svg

@@ -0,0 +1 @@
+<svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="128" height="128"><path d="M869.073 277.307H657.111V65.344l211.962 211.963zm-238.232 26.27V65.344l-476.498-.054v416.957h714.73v-178.67H630.841zm-335.836 360.57c-5.07-3.064-10.944-5.133-17.61-6.201-6.67-1.064-13.603-1.6-20.81-1.6h-48.821v85.641h48.822c7.206 0 14.14-.532 20.81-1.6 6.665-1.065 12.54-3.133 17.609-6.202 5.064-3.063 9.134-7.406 12.208-13.007 3.065-5.602 4.6-12.937 4.6-22.011 0-9.07-1.535-16.408-4.6-22.01-3.074-5.603-7.144-9.94-12.208-13.01zM35.82 541.805v416.904h952.358V541.805H35.821zm331.421 191.179c-3.6 11.071-9.343 20.879-17.209 29.413-7.874 8.542-18.078 15.408-30.617 20.61-12.544 5.206-27.747 7.807-45.621 7.807h-66.036v102.45h-62.831V607.517h128.867c17.874 0 33.077 2.6 45.62 7.802 12.541 5.207 22.745 12.076 30.618 20.615 7.866 8.538 13.604 18.277 17.21 29.212 3.6 10.943 5.401 22.278 5.401 34.018 0 11.477-1.8 22.752-5.402 33.819zM644.9 806.417c-5.343 17.61-13.408 32.818-24.212 45.627-10.807 12.803-24.283 22.879-40.423 30.213-16.146 7.343-35.155 11.007-57.03 11.007h-123.26V607.518h123.26c18.41 0 35.552 2.941 51.428 8.808 15.873 5.869 29.618 14.671 41.22 26.412 11.608 11.744 20.674 26.411 27.217 44.02 6.535 17.61 9.803 38.288 9.803 62.035 0 20.81-2.67 40.02-8.003 57.624zm245.362-146.07h-138.07v66.03h119.66v48.829h-119.66v118.058h-62.83V607.518h200.9v52.829h-.001zm-318.2 25.611c-6.402-8.266-14.877-14.604-25.412-19.01-10.544-4.402-23.551-6.602-39.019-6.602h-44.825v180.088h56.029c9.07 0 17.872-1.463 26.415-4.401 8.535-2.932 16.14-7.802 22.812-14.609 6.665-6.8 12.007-15.667 16.007-26.61 4.003-10.94 6.003-24.275 6.003-40.021 0-14.408-1.4-27.416-4.202-39.019-2.8-11.607-7.406-21.542-13.808-29.816zm0 0"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/people.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M104.185 95.254c8.161 7.574 13.145 17.441 13.145 28.28 0 1.508-.098 2.998-.285 4.466h-10.784c.238-1.465.403-2.948.403-4.465 0-8.983-4.36-17.115-11.419-23.216C86 104.66 75.355 107.162 64 107.162c-11.344 0-21.98-2.495-31.22-6.83-7.064 6.099-11.444 14.218-11.444 23.203 0 1.517.165 3 .403 4.465H10.955a35.444 35.444 0 0 1-.285-4.465c0-10.838 4.974-20.713 13.127-28.291C9.294 85.42.003 70.417.003 53.58.003 23.99 28.656.001 64 .001s63.997 23.988 63.997 53.58c0 16.842-9.299 31.85-23.812 41.673zM64 36.867c-29.454 0-53.33-10.077-53.33 15.342 0 25.418 23.876 46.023 53.33 46.023 29.454 0 53.33-20.605 53.33-46.023 0-25.419-23.876-15.342-53.33-15.342zm24.888 25.644c-3.927 0-7.111-2.665-7.111-5.953 0-3.288 3.184-5.954 7.11-5.954 3.928 0 7.111 2.666 7.111 5.954s-3.183 5.953-7.11 5.953zm-3.556 16.372c0 4.11-9.55 7.442-21.332 7.442-11.781 0-21.332-3.332-21.332-7.442 0-1.06.656-2.064 1.8-2.976 3.295 2.626 10.79 4.465 19.532 4.465 8.743 0 16.237-1.84 19.531-4.465 1.145.912 1.801 1.916 1.801 2.976zm-46.22-16.372c-3.927 0-7.11-2.665-7.11-5.953 0-3.288 3.183-5.954 7.11-5.954 3.927 0 7.111 2.666 7.111 5.954s-3.184 5.953-7.11 5.953z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/peoples.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M95.648 118.762c0 5.035-3.563 9.121-7.979 9.121H7.98c-4.416 0-7.979-4.086-7.979-9.121C0 100.519 15.408 83.47 31.152 76.75c-9.099-6.43-15.216-17.863-15.216-30.987v-9.128c0-20.16 14.293-36.518 31.893-36.518s31.894 16.358 31.894 36.518v9.122c0 13.137-6.123 24.556-15.216 30.993 15.738 6.726 31.141 23.769 31.141 42.012z"/><path d="M106.032 118.252h15.867c3.376 0 6.101-3.125 6.101-6.972 0-13.957-11.787-26.984-23.819-32.123 6.955-4.919 11.638-13.66 11.638-23.704v-6.985c0-15.416-10.928-27.926-24.39-27.926-1.674 0-3.306.193-4.89.561 1.936 4.713 3.018 9.974 3.018 15.526v9.121c0 13.137-3.056 23.111-11.066 30.993 14.842 4.41 27.312 23.42 27.541 41.509z"/></svg>

File diff suppressed because it is too large
+ 0 - 0
htmldev/manageTemplate/src/icons/svg/qq.svg


+ 1 - 0
htmldev/manageTemplate/src/icons/svg/search.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M124.884 109.812L94.256 79.166c-.357-.357-.757-.629-1.129-.914a50.366 50.366 0 0 0 8.186-27.59C101.327 22.689 78.656 0 50.67 0 22.685 0 0 22.688 0 50.663c0 27.989 22.685 50.663 50.656 50.663 10.186 0 19.643-3.03 27.6-8.201.286.385.557.771.9 1.114l30.628 30.632a10.633 10.633 0 0 0 7.543 3.129c2.728 0 5.457-1.043 7.543-3.115 4.171-4.157 4.171-10.915.014-15.073M50.671 85.338C31.557 85.338 16 69.78 16 50.663c0-19.102 15.557-34.661 34.67-34.661 19.115 0 34.657 15.559 34.657 34.675 0 19.102-15.557 34.661-34.656 34.661"/></svg>

File diff suppressed because it is too large
+ 0 - 0
htmldev/manageTemplate/src/icons/svg/shopping.svg


+ 1 - 0
htmldev/manageTemplate/src/icons/svg/size.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M0 54.857h54.796v18.286H36.531V128H18.265V73.143H0V54.857zm127.857-36.571H91.935V128H72.456V18.286H36.534V0h91.326l-.003 18.286z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/skill.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M31.652 93.206h33.401c1.44 2.418 3.077 4.663 4.93 6.692h-38.33v-6.692zm0-10.586h28.914a44.8 44.8 0 0 1-1.264-6.688h-27.65v6.688zm0-17.27H59.39c.288-2.286.714-4.532 1.34-6.687H31.65v6.687h.003zm53.913 44.84v5.85c0 2.798-2.095 5.075-4.667 5.075h-70.07c-2.576 0-4.663-2.277-4.663-5.075V31.26l23.22-20.96v22.25H17.16v6.688h18.39V6.688h45.348c2.576 0 4.667 2.277 4.667 5.066v20.009c1.987-.675 4.053-1.128 6.17-1.445v-18.56C91.738 5.28 86.874 0 80.902 0H31.15L0 28.118v87.917c0 6.48 4.859 11.759 10.832 11.759h70.07c5.974 0 10.837-5.27 10.837-11.759v-4.41c-2.117-.312-4.183-.765-6.17-1.435h-.004zM23.279 58.667h-7.96v6.688h7.96v-6.688zm-7.956 41.23h7.96v-6.691h-7.96v6.692zm7.956-23.96h-7.96v6.687h7.96v-6.688zm89.718-15.042l-4.896-4.07-12.447 17.613-11.19-9.305-3.762 5.311 16.091 13.38 16.204-22.929zM128 70.978c0-18.632-13.97-33.782-31.147-33.782-17.168 0-31.135 15.155-31.135 33.782 0 18.628 13.97 33.783 31.135 33.783 17.172 0 31.143-15.15 31.143-33.783H128zm-6.17 0c0 14.933-11.203 27.1-24.981 27.1-13.77 0-24.987-12.158-24.987-27.1 0-14.941 11.195-27.099 24.987-27.099 13.778 0 24.982 12.158 24.982 27.1z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/star.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M70.66 4.328l14.01 29.693c1.088 2.29 3.177 3.882 5.603 4.25l31.347 4.76c6.087.926 8.528 8.756 4.117 13.247L103.05 79.395c-1.75 1.78-2.544 4.352-2.132 6.867l5.352 32.641c1.043 6.337-5.33 11.182-10.778 8.19l-28.039-15.409a7.13 7.13 0 0 0-6.91 0l-28.039 15.41c-5.448 2.99-11.821-1.854-10.777-8.19l5.352-32.642c.415-2.515-.387-5.088-2.136-6.867L2.264 56.278C-2.146 51.787.286 43.957 6.38 43.031l31.343-4.76c2.419-.368 4.51-1.96 5.595-4.25L57.334 4.328c2.728-5.77 10.605-5.77 13.325 0z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/tab.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M78.921.052H49.08c-1.865 0-3.198 1.599-3.198 3.464v6.661c0 1.865 1.6 3.464 3.198 3.464h29.84c1.865 0 3.198-1.599 3.198-3.464V3.516C82.385 1.65 80.786.052 78.92.052zm45.563 0H94.642c-1.865 0-3.464 1.599-3.464 3.464v6.661c0 1.865 1.599 3.464 3.464 3.464h29.842c1.865-.266 3.464-1.599 3.464-3.464V3.516c0-1.865-1.599-3.464-3.464-3.464zm0 22.382H40.02c-1.866 0-3.464-1.599-3.464-3.464V3.516c0-1.865-1.599-3.464-3.464-3.464H3.516C1.65.052.052 1.651.052 3.516V124.75c0 1.598 1.599 3.197 3.464 3.197h120.968c1.865 0 3.464-1.599 3.464-3.464V25.898c0-1.865-1.599-3.464-3.464-3.464z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/table.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M.006.064h127.988v31.104H.006V.064zm0 38.016h38.396v41.472H.006V38.08zm0 48.384h38.396v41.472H.006V86.464zM44.802 38.08h38.396v41.472H44.802V38.08zm0 48.384h38.396v41.472H44.802V86.464zM89.598 38.08h38.396v41.472H89.598zm0 48.384h38.396v41.472H89.598z"/><path d="M.006.064h127.988v31.104H.006V.064zm0 38.016h38.396v41.472H.006V38.08zm0 48.384h38.396v41.472H.006V86.464zM44.802 38.08h38.396v41.472H44.802V38.08zm0 48.384h38.396v41.472H44.802V86.464zM89.598 38.08h38.396v41.472H89.598zm0 48.384h38.396v41.472H89.598z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/theme.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M125.5 36.984L95.336 2.83C93.735 1.018 91.565 0 89.3 0c-2.263 0-4.433 1.018-6.033 2.83l-3.786 4.286c-1.6 1.812-3.77 2.83-6.032 2.831H54.553c-2.263 0-4.434-1.018-6.033-2.83L44.734 2.83C43.134 1.018 40.964 0 38.701 0c-2.263 0-4.434 1.018-6.034 2.83L2.5 36.984C.9 38.796 0 41.254 0 43.815c0 2.562.899 5.02 2.5 6.831L14.565 64.31c2.178 2.468 5.367 3.403 8.33 2.444 1.35-.435 2.709.592 2.709 2.18v49.407c0 5.313 3.84 9.66 8.532 9.66h59.726c4.693 0 8.532-4.347 8.532-9.66V68.934c0-1.59 1.36-2.616 2.71-2.181 2.962.96 6.15.024 8.329-2.444L125.5 50.646c1.6-1.811 2.499-4.269 2.499-6.83 0-2.563-.899-5.02-2.5-6.832z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/tree-table.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M44.8 0h79.543C126.78 0 128 1.422 128 4.267v23.466c0 2.845-1.219 4.267-3.657 4.267H44.8c-2.438 0-3.657-1.422-3.657-4.267V4.267C41.143 1.422 42.362 0 44.8 0zm22.857 48h56.686c2.438 0 3.657 1.422 3.657 4.267v23.466c0 2.845-1.219 4.267-3.657 4.267H67.657C65.22 80 64 78.578 64 75.733V52.267C64 49.422 65.219 48 67.657 48zm0 48h56.686c2.438 0 3.657 1.422 3.657 4.267v23.466c0 2.845-1.219 4.267-3.657 4.267H67.657C65.22 128 64 126.578 64 123.733v-23.466C64 97.422 65.219 96 67.657 96zM50.286 68.267c2.02 0 3.657-1.91 3.657-4.267 0-2.356-1.638-4.267-3.657-4.267H17.37V32h6.4c2.02 0 3.658-1.91 3.658-4.267V4.267C27.429 1.91 25.79 0 23.77 0H3.657C1.637 0 0 1.91 0 4.267v23.466C0 30.09 1.637 32 3.657 32h6.4v80c0 2.356 1.638 4.267 3.657 4.267h36.572c2.02 0 3.657-1.91 3.657-4.267 0-2.356-1.638-4.267-3.657-4.267H17.37V68.267h32.915z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/tree.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M126.713 90.023c.858.985 1.287 2.134 1.287 3.447v29.553c0 1.423-.429 2.6-1.287 3.53-.858.93-1.907 1.395-3.146 1.395H97.824c-1.145 0-2.146-.465-3.004-1.395-.858-.93-1.287-2.107-1.287-3.53V93.47c0-.875.19-1.696.572-2.462.382-.766.906-1.368 1.573-1.806a3.84 3.84 0 0 1 2.146-.657h9.725V69.007a3.84 3.84 0 0 0-.43-1.806 3.569 3.569 0 0 0-1.143-1.313 2.714 2.714 0 0 0-1.573-.492h-36.47v23.149h9.725c1.144 0 2.145.492 3.004 1.478.858.985 1.287 2.134 1.287 3.447v29.553c0 .876-.191 1.696-.573 2.463-.38.766-.905 1.368-1.573 1.806a3.84 3.84 0 0 1-2.145.656H51.915a3.84 3.84 0 0 1-2.145-.656c-.668-.438-1.216-1.04-1.645-1.806a4.96 4.96 0 0 1-.644-2.463V93.47c0-1.313.43-2.462 1.288-3.447.858-.986 1.907-1.478 3.146-1.478h9.582v-23.15h-37.9c-.953 0-1.74.356-2.359 1.068-.62.711-.93 1.56-.93 2.544v19.538h9.726c1.239 0 2.264.492 3.074 1.478.81.985 1.216 2.134 1.216 3.447v29.553c0 1.423-.405 2.6-1.216 3.53-.81.93-1.835 1.395-3.074 1.395H4.29c-.476 0-.93-.082-1.358-.246a4.1 4.1 0 0 1-1.144-.657 4.658 4.658 0 0 1-.93-1.067 5.186 5.186 0 0 1-.643-1.395 5.566 5.566 0 0 1-.215-1.56V93.47c0-.437.048-.875.143-1.313a3.95 3.95 0 0 1 .429-1.15c.19-.328.429-.656.715-.984.286-.329.572-.602.858-.821.286-.22.62-.383 1.001-.493.382-.11.763-.164 1.144-.164h9.726V61.619c0-.985.31-1.833.93-2.544.619-.712 1.358-1.068 2.216-1.068h44.335V39.62h-9.582c-1.24 0-2.288-.492-3.146-1.477a5.09 5.09 0 0 1-1.287-3.448V5.14c0-1.423.429-2.627 1.287-3.612.858-.985 1.907-1.477 3.146-1.477h25.743c.763 0 1.478.246 2.145.739a5.17 5.17 0 0 1 1.573 1.888c.382.766.573 1.587.573 2.462v29.553c0 1.313-.43 2.463-1.287 3.448-.859.985-1.86 1.477-3.004 1.477h-9.725v18.389h42.762c.954 0 1.74.355 2.36 1.067.62.711.93 1.56.93 2.545v26.925h9.582c1.239 0 2.288.492 3.146 1.478z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/user.svg

@@ -0,0 +1 @@
+<svg width="130" height="130" xmlns="http://www.w3.org/2000/svg"><path d="M63.444 64.996c20.633 0 37.359-14.308 37.359-31.953 0-17.649-16.726-31.952-37.359-31.952-20.631 0-37.36 14.303-37.358 31.952 0 17.645 16.727 31.953 37.359 31.953zM80.57 75.65H49.434c-26.652 0-48.26 18.477-48.26 41.27v2.664c0 9.316 21.608 9.325 48.26 9.325H80.57c26.649 0 48.256-.344 48.256-9.325v-2.663c0-22.794-21.605-41.271-48.256-41.271z" stroke="#979797"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/wechat.svg

@@ -0,0 +1 @@
+<svg width="128" height="110" xmlns="http://www.w3.org/2000/svg"><path d="M86.635 33.334c1.467 0 2.917.113 4.358.283C87.078 14.392 67.58.111 45.321.111 20.44.111.055 17.987.055 40.687c0 13.104 6.781 23.863 18.115 32.209l-4.527 14.352 15.82-8.364c5.666 1.182 10.207 2.395 15.858 2.395 1.42 0 2.829-.073 4.227-.189-.886-3.19-1.398-6.53-1.398-9.996 0-20.845 16.98-37.76 38.485-37.76zm-24.34-12.936c3.407 0 5.665 2.363 5.665 5.954 0 3.576-2.258 5.97-5.666 5.97-3.392 0-6.795-2.395-6.795-5.97 0-3.591 3.403-5.954 6.795-5.954zM30.616 32.323c-3.393 0-6.818-2.395-6.818-5.971 0-3.591 3.425-5.954 6.818-5.954 3.392 0 5.65 2.363 5.65 5.954 0 3.576-2.258 5.97-5.65 5.97z"/><path d="M127.945 70.52c0-19.075-18.108-34.623-38.448-34.623-21.537 0-38.5 15.548-38.5 34.623 0 19.108 16.963 34.622 38.5 34.622 4.508 0 9.058-1.2 13.584-2.395l12.414 7.167-3.404-11.923c9.087-7.184 15.854-16.712 15.854-27.471zm-50.928-5.97c-2.254 0-4.53-2.362-4.53-4.773 0-2.378 2.276-4.771 4.53-4.771 3.422 0 5.665 2.393 5.665 4.771 0 2.41-2.243 4.773-5.665 4.773zm24.897 0c-2.24 0-4.498-2.362-4.498-4.773 0-2.378 2.258-4.771 4.498-4.771 3.392 0 5.665 2.393 5.665 4.771 0 2.41-2.273 4.773-5.665 4.773z"/></svg>

+ 1 - 0
htmldev/manageTemplate/src/icons/svg/zip.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M78.527 116.793c.178.008.348.024.527.024h40.233c4.711-.005 8.53-3.677 8.534-8.21V18.895c-.004-4.532-3.823-8.204-8.534-8.209H79.054c-.179 0-.353.016-.527.024V0L0 10.082v107.406l78.527 10.342v-11.037zm0-101.362c.174-.024.348-.052.527-.052h40.233c2.018 0 3.659 1.578 3.659 3.52v89.713c-.003 1.942-1.64 3.517-3.659 3.519H79.054c-.179 0-.353-.028-.527-.052V15.431zM30.262 75.757l-18.721-.46V72.37l11.3-16.673v-.148l-10.266.164v-4.51l17.504-.44v3.264L18.696 70.76v.144l11.566.176v4.678zm9.419.231l-5.823-.144V50.671l5.823-.144v25.461zm22.255-11.632c-2.168 1.922-5.353 2.76-9.02 2.736-.702.004-1.402-.04-2.097-.131v9.303l-5.997-.148V50.743c1.852-.352 4.473-.647 8.218-.743 3.838-.096 6.608.539 8.48 1.913 1.807 1.306 3.032 3.5 3.032 6.112s-.926 4.833-2.612 6.331h-.004zM53.36 54.45c-.856-.01-1.71.083-2.541.275v7.682c.523.116 1.167.152 2.06.152 3.301-.004 5.36-1.614 5.36-4.314 0-2.425-1.772-3.843-4.875-3.791l-.004-.004zm39.847-37.066h9.564v3.795h-9.564v-3.795zm-9.568 5.68h9.564v3.8h-9.564v-3.8zm9.568 6.216h9.564v3.799h-9.564V29.28zm0 12h9.564v3.794h-9.564V41.28zm-9.568-6.096h9.564v3.795h-9.564v-3.795zm9.472 47.064c2.512 0 4.921-.96 6.697-2.67 1.776-1.708 2.773-4.026 2.772-6.442l-1.748-15.263c0-5.033-2.492-9.112-7.725-9.112-5.232 0-7.72 4.079-7.72 9.112l-1.752 15.263c-.001 2.417.996 4.735 2.773 6.444 1.777 1.71 4.187 2.669 6.7 2.668h.003zm-3.135-16.75h6.27v12.743h-6.27V65.5z"/></svg>

+ 22 - 0
htmldev/manageTemplate/src/icons/svgo.yml

@@ -0,0 +1,22 @@
+# replace default config
+
+# multipass: true
+# full: true
+
+plugins:
+
+  # - name
+  #
+  # or:
+  # - name: false
+  # - name: true
+  #
+  # or:
+  # - name:
+  #     param1: 1
+  #     param2: 2
+
+- removeAttrs:
+    attrs:
+      - 'fill'
+      - 'fill-rule'

+ 46 - 0
htmldev/manageTemplate/src/layout/components/AppMain.vue

@@ -0,0 +1,46 @@
+<template>
+  <section class="app-main">
+    <transition name="fade-transform" mode="out-in">
+      <keep-alive :include="cachedViews">
+        <router-view :key="key"/>
+      </keep-alive>
+    </transition>
+  </section>
+</template>
+
+<script>
+export default {
+  name: 'AppMain',
+  computed: {
+    cachedViews() {
+      return this.$store.state.tagsView.cachedViews
+    },
+    key() {
+      return this.$route.path
+    }
+  }
+}
+</script>
+
+<style scoped>
+.app-main {
+  /*50 = navbar  */
+  min-height: calc(100vh - 50px);
+  width: 100%;
+  position: relative;
+  overflow: hidden;
+}
+
+.fixed-header + .app-main {
+  padding-top: 50px;
+}
+</style>
+
+<style lang="scss">
+// fix css style bug in open el-dialog
+.el-popup-parent--hidden {
+  .fixed-header {
+    padding-right: 15px;
+  }
+}
+</style>

+ 152 - 0
htmldev/manageTemplate/src/layout/components/Navbar.vue

@@ -0,0 +1,152 @@
+<template>
+  <div class="navbar">
+    <hamburger :is-active="sidebar.opened" class="hamburger-container" @toggleClick="toggleSideBar" />
+
+    <breadcrumb class="breadcrumb-container hidden-sm-and-down" />
+
+    <div class="right-menu">
+      <el-dropdown class="avatar-container" trigger="click">
+        <div class="avatar-wrapper">
+          <img src="../../assets/img/common/840702eef7eb4f6196853a99323c87cb.png" class="user-avatar">
+          <i class="el-icon-caret-bottom" />
+        </div>
+        <el-dropdown-menu slot="dropdown" class="user-dropdown">
+          <router-link to="/">
+            <el-dropdown-item>
+              {{$t('route.dashboard')}}
+            </el-dropdown-item>
+          </router-link>
+          <el-dropdown-item @click.native="modPassword" v-if="!isOnLineOperation">
+            <span style="display:block;">{{$t('mod_password')}}</span>
+          </el-dropdown-item>
+          <el-dropdown-item divided @click.native="logout">
+            <span style="display:block;">{{$t('logout')}}</span>
+          </el-dropdown-item>
+        </el-dropdown-menu>
+      </el-dropdown>
+    </div>
+    <modPassword v-if="modPasswordDialog.show" v-model="modPasswordDialog.show"></modPassword>
+  </div>
+</template>
+
+<script>
+import { mapGetters } from 'vuex'
+import Breadcrumb from '@/components/Breadcrumb'
+import Hamburger from '@/components/Hamburger'
+import modPassword from '@/components/_dialog/modPassword';
+
+export default {
+  components: {
+    Breadcrumb,
+    Hamburger,
+    modPassword
+  },
+  computed: {
+    ...mapGetters([
+      'sidebar',
+      'avatar'
+    ]),
+    isOnLineOperation() {
+      return this.$store.getters['user/isOnLineOperation']
+    }
+  },
+  data() {
+    return {
+      modPasswordDialog: {
+        show: false,
+      }
+    }
+  },
+  methods: {
+    modPassword() {
+      this.modPasswordDialog.show = true
+    },
+    toggleSideBar() {
+      this.$store.dispatch('app/toggleSideBar')
+    },
+    async logout() {
+      await this.$store.dispatch('user/logout')
+      this.$router.push(`/login`)
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.navbar {
+  height: 50px;
+  overflow: hidden;
+  position: relative;
+  background: #fff;
+  box-shadow: 0 1px 4px rgba(0,21,41,.08);
+
+  .hamburger-container {
+    line-height: 46px;
+    height: 100%;
+    float: left;
+    cursor: pointer;
+    transition: background .3s;
+    -webkit-tap-highlight-color:transparent;
+
+    &:hover {
+      background: rgba(0, 0, 0, .025)
+    }
+  }
+
+  .breadcrumb-container {
+    float: left;
+  }
+
+  .right-menu {
+    float: right;
+    height: 100%;
+    line-height: 50px;
+
+    &:focus {
+      outline: none;
+    }
+
+    .right-menu-item {
+      display: inline-block;
+      padding: 0 8px;
+      height: 100%;
+      font-size: 18px;
+      color: #5a5e66;
+      vertical-align: text-bottom;
+
+      &.hover-effect {
+        cursor: pointer;
+        transition: background .3s;
+
+        &:hover {
+          background: rgba(0, 0, 0, .025)
+        }
+      }
+    }
+
+    .avatar-container {
+      margin-right: 30px;
+
+      .avatar-wrapper {
+        margin-top: 5px;
+        position: relative;
+
+        .user-avatar {
+          cursor: pointer;
+          width: 40px;
+          height: 40px;
+          border-radius: 10px;
+        }
+
+        .el-icon-caret-bottom {
+          cursor: pointer;
+          position: absolute;
+          right: -20px;
+          top: 25px;
+          font-size: 12px;
+        }
+      }
+    }
+  }
+}
+</style>

+ 26 - 0
htmldev/manageTemplate/src/layout/components/Sidebar/FixiOSBug.js

@@ -0,0 +1,26 @@
+export default {
+  computed: {
+    device() {
+      return this.$store.state.app.device
+    }
+  },
+  mounted() {
+    // In order to fix the click on menu on the ios device will trigger the mouseleave bug
+    // https://github.com/PanJiaChen/vue-element-admin/issues/1135
+    this.fixBugIniOS()
+  },
+  methods: {
+    fixBugIniOS() {
+      const $subMenu = this.$refs.subMenu
+      if ($subMenu) {
+        const handleMouseleave = $subMenu.handleMouseleave
+        $subMenu.handleMouseleave = (e) => {
+          if (this.device === 'mobile') {
+            return
+          }
+          handleMouseleave(e)
+        }
+      }
+    }
+  }
+}

+ 41 - 0
htmldev/manageTemplate/src/layout/components/Sidebar/Item.vue

@@ -0,0 +1,41 @@
+<script>
+export default {
+  name: 'MenuItem',
+  functional: true,
+  props: {
+    icon: {
+      type: String,
+      default: ''
+    },
+    title: {
+      type: String,
+      default: ''
+    }
+  },
+  render(h, context) {
+    const { icon, title } = context.props
+    const vnodes = []
+
+    if (icon) {
+      if (icon.includes('el-icon')) {
+        vnodes.push(<i class={[icon, 'sub-el-icon']} />)
+      } else {
+        vnodes.push(<svg-icon icon-class={icon}/>)
+      }
+    }
+
+    if (title) {
+      vnodes.push(<span slot='title'>{(title)}</span>)
+    }
+    return vnodes
+  }
+}
+</script>
+
+<style scoped>
+.sub-el-icon {
+  color: currentColor;
+  width: 1em;
+  height: 1em;
+}
+</style>

+ 43 - 0
htmldev/manageTemplate/src/layout/components/Sidebar/Link.vue

@@ -0,0 +1,43 @@
+<template>
+  <component :is="type" v-bind="linkProps(to)">
+    <slot />
+  </component>
+</template>
+
+<script>
+import { isExternal } from '@/utils/validate'
+
+export default {
+  props: {
+    to: {
+      type: String,
+      required: true
+    }
+  },
+  computed: {
+    isExternal() {
+      return isExternal(this.to)
+    },
+    type() {
+      if (this.isExternal) {
+        return 'a'
+      }
+      return 'router-link'
+    }
+  },
+  methods: {
+    linkProps(to) {
+      if (this.isExternal) {
+        return {
+          href: to,
+          target: '_blank',
+          rel: 'noopener'
+        }
+      }
+      return {
+        to: to
+      }
+    }
+  }
+}
+</script>

+ 82 - 0
htmldev/manageTemplate/src/layout/components/Sidebar/Logo.vue

@@ -0,0 +1,82 @@
+<template>
+  <div class="sidebar-logo-container" :class="{'collapse':collapse}">
+    <transition name="sidebarLogoFade">
+      <router-link v-if="collapse" key="collapse" class="sidebar-logo-link" to="/">
+        <img v-if="logo" :src="logo" class="sidebar-logo">
+        <h1 v-else class="sidebar-title">{{ title }} </h1>
+      </router-link>
+      <router-link v-else key="expand" class="sidebar-logo-link" to="/">
+        <img v-if="logo" :src="logo" class="sidebar-logo">
+        <h1 class="sidebar-title">{{ title }} </h1>
+      </router-link>
+    </transition>
+  </div>
+</template>
+
+<script>
+export default {
+  name: 'SidebarLogo',
+  props: {
+    collapse: {
+      type: Boolean,
+      required: true
+    }
+  },
+  data() {
+    return {
+      title: 'Vue Admin Template',
+      logo: require('../../../assets/img/common/69a1c46c-eb1c-4b46-8bd4-e9e686ef5251.png')
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.sidebarLogoFade-enter-active {
+  transition: opacity 1.5s;
+}
+
+.sidebarLogoFade-enter,
+.sidebarLogoFade-leave-to {
+  opacity: 0;
+}
+
+.sidebar-logo-container {
+  position: relative;
+  width: 100%;
+  height: 50px;
+  line-height: 50px;
+  background: #2b2f3a;
+  text-align: center;
+  overflow: hidden;
+
+  & .sidebar-logo-link {
+    height: 100%;
+    width: 100%;
+
+    & .sidebar-logo {
+      width: 32px;
+      height: 32px;
+      vertical-align: middle;
+      margin-right: 12px;
+    }
+
+    & .sidebar-title {
+      display: inline-block;
+      margin: 0;
+      color: #fff;
+      font-weight: 600;
+      line-height: 50px;
+      font-size: 14px;
+      font-family: Avenir, Helvetica Neue, Arial, Helvetica, sans-serif;
+      vertical-align: middle;
+    }
+  }
+
+  &.collapse {
+    .sidebar-logo {
+      margin-right: 0px;
+    }
+  }
+}
+</style>

+ 95 - 0
htmldev/manageTemplate/src/layout/components/Sidebar/SidebarItem.vue

@@ -0,0 +1,95 @@
+<template>
+  <div v-if="!item.hidden">
+    <template v-if="hasOneShowingChild(item.children,item) && (!onlyOneChild.children||onlyOneChild.noShowingChildren)&&!item.alwaysShow">
+      <app-link v-if="onlyOneChild.meta" :to="resolvePath(onlyOneChild.path)">
+        <el-menu-item :index="resolvePath(onlyOneChild.path)" :class="{'submenu-title-noDropdown':!isNest}">
+          <item :icon="onlyOneChild.meta.icon||(item.meta&&item.meta.icon)" :title="onlyOneChild.meta.title" />
+        </el-menu-item>
+      </app-link>
+    </template>
+
+    <el-submenu v-else ref="subMenu" :index="resolvePath(item.path)" popper-append-to-body>
+      <template slot="title">
+        <item v-if="item.meta" :icon="item.meta && item.meta.icon" :title="item.meta.title" />
+      </template>
+      <sidebar-item
+        v-for="child in item.children"
+        :key="child.path"
+        :is-nest="true"
+        :item="child"
+        :base-path="resolvePath(child.path)"
+        class="nest-menu"
+      />
+    </el-submenu>
+  </div>
+</template>
+
+<script>
+import path from 'path'
+import { isExternal } from '@/utils/validate'
+import Item from './Item'
+import AppLink from './Link'
+import FixiOSBug from './FixiOSBug'
+
+export default {
+  name: 'SidebarItem',
+  components: { Item, AppLink },
+  mixins: [FixiOSBug],
+  props: {
+    // route object
+    item: {
+      type: Object,
+      required: true
+    },
+    isNest: {
+      type: Boolean,
+      default: false
+    },
+    basePath: {
+      type: String,
+      default: ''
+    }
+  },
+  data() {
+    // To fix https://github.com/PanJiaChen/vue-admin-template/issues/237
+    // TODO: refactor with render function
+    this.onlyOneChild = null
+    return {}
+  },
+  methods: {
+    hasOneShowingChild(children = [], parent) {
+      const showingChildren = children.filter(item => {
+        if (item.hidden) {
+          return false
+        } else {
+          // Temp set(will be used if only has one showing child)
+          this.onlyOneChild = item
+          return true
+        }
+      })
+
+      // When there is only one child router, the child router is displayed by default
+      if (showingChildren.length === 1) {
+        return true
+      }
+
+      // Show parent if there are no child router to display
+      if (showingChildren.length === 0) {
+        this.onlyOneChild = { ... parent, path: '', noShowingChildren: true }
+        return true
+      }
+
+      return false
+    },
+    resolvePath(routePath) {
+      if (isExternal(routePath)) {
+        return routePath
+      }
+      if (isExternal(this.basePath)) {
+        return this.basePath
+      }
+      return path.resolve(this.basePath, routePath)
+    }
+  }
+}
+</script>

+ 57 - 0
htmldev/manageTemplate/src/layout/components/Sidebar/index.vue

@@ -0,0 +1,57 @@
+<template>
+  <div :class="{'has-logo':showLogo}">
+    <logo v-if="showLogo" :collapse="isCollapse" />
+    <el-scrollbar wrap-class="scrollbar-wrapper">
+      <el-menu
+        :default-active="activeMenu"
+        :collapse="isCollapse"
+        :background-color="variables.menuBg"
+        :text-color="variables.menuText"
+        :unique-opened="false"
+        :active-text-color="variables.menuActiveText"
+        :collapse-transition="false"
+        mode="vertical"
+      >
+        <sidebar-item v-for="route in permission_routes" :key="route.path" :item="route" :base-path="route.path" />
+      </el-menu>
+    </el-scrollbar>
+  </div>
+</template>
+
+<script>
+import { mapGetters } from 'vuex'
+import Logo from './Logo'
+import SidebarItem from './SidebarItem'
+import variables from '@/styles/variables.scss'
+
+export default {
+  components: { SidebarItem, Logo },
+  computed: {
+    ...mapGetters([
+      'sidebar',
+      'permission_routes'
+    ]),
+    routes() {
+      return this.$router.options.routes
+    },
+    activeMenu() {
+      const route = this.$route
+      const { meta, path } = route
+      // if set path, the sidebar will highlight the path you set
+      if (meta.activeMenu) {
+        return meta.activeMenu
+      }
+      return path
+    },
+    showLogo() {
+      return this.$store.state.settings.sidebarLogo
+    },
+    variables() {
+      return variables
+    },
+    isCollapse() {
+      return !this.sidebar.opened
+    }
+  }
+}
+</script>

+ 96 - 0
htmldev/manageTemplate/src/layout/components/TagsView/ScrollPane.vue

@@ -0,0 +1,96 @@
+<template>
+  <el-scrollbar ref="scrollContainer" :vertical="false" class="scroll-container" @wheel.native.prevent="handleScroll">
+    <slot/>
+  </el-scrollbar>
+</template>
+
+<script>
+const tagAndTagSpacing = 4 // tagAndTagSpacing
+
+export default {
+  name: 'ScrollPane',
+  data () {
+    return {
+      left: 0
+    }
+  },
+  computed: {
+    scrollWrapper () {
+      return this.$refs.scrollContainer.$refs.wrap
+    }
+  },
+  mounted () {
+    this.scrollWrapper.addEventListener('scroll', this.emitScroll, true)
+  },
+  beforeDestroy () {
+    this.scrollWrapper.removeEventListener('scroll', this.emitScroll)
+  },
+  methods: {
+    handleScroll (e) {
+      const eventDelta = e.wheelDelta || -e.deltaY * 40
+      const $scrollWrapper = this.scrollWrapper
+      $scrollWrapper.scrollLeft = $scrollWrapper.scrollLeft + eventDelta / 4
+    },
+    emitScroll () {
+      this.$emit('scroll')
+    },
+    moveToTarget (currentTag) {
+      const $container = this.$refs.scrollContainer.$el
+      const $containerWidth = $container.offsetWidth
+      const $scrollWrapper = this.scrollWrapper
+      const tagList = this.$parent.$refs.tag
+
+      let firstTag = null
+      let lastTag = null
+
+      // find first tag and last tag
+      if (tagList.length > 0) {
+        firstTag = tagList[0]
+        lastTag = tagList[tagList.length - 1]
+      }
+
+      if (firstTag === currentTag) {
+        $scrollWrapper.scrollLeft = 0
+      } else if (lastTag === currentTag) {
+        $scrollWrapper.scrollLeft = $scrollWrapper.scrollWidth - $containerWidth
+      } else {
+        // find preTag and nextTag
+        const currentIndex = tagList.findIndex(item => item === currentTag)
+        const prevTag = tagList[currentIndex - 1]
+        const nextTag = tagList[currentIndex + 1]
+
+        // the tag's offsetLeft after of nextTag
+        const afterNextTagOffsetLeft = nextTag.$el.offsetLeft + nextTag.$el.offsetWidth + tagAndTagSpacing
+
+        // the tag's offsetLeft before of prevTag
+        const beforePrevTagOffsetLeft = prevTag.$el.offsetLeft - tagAndTagSpacing
+
+        if (afterNextTagOffsetLeft > $scrollWrapper.scrollLeft + $containerWidth) {
+          $scrollWrapper.scrollLeft = afterNextTagOffsetLeft - $containerWidth
+        } else if (beforePrevTagOffsetLeft < $scrollWrapper.scrollLeft) {
+          $scrollWrapper.scrollLeft = beforePrevTagOffsetLeft
+        }
+      }
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.scroll-container {
+  white-space: nowrap;
+  position: relative;
+  overflow: hidden;
+  width: 100%;
+
+  ::v-deep {
+    .el-scrollbar__bar {
+      bottom: 0px;
+    }
+
+    .el-scrollbar__wrap {
+      height: 49px;
+    }
+  }
+}
+</style>

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