浏览代码

初始化项目

zhy 3 天之前
父节点
当前提交
e61a7984a2
共有 100 个文件被更改,包括 2642 次插入0 次删除
  1. 22 0
      .editorconfig
  2. 11 0
      .env.development
  3. 11 0
      .env.embed
  4. 8 0
      .env.production
  5. 10 0
      .env.staging
  6. 10 0
      .eslintignore
  7. 199 0
      .eslintrc.js
  8. 23 0
      .gitignore
  9. 13 0
      babel.config.js
  10. 12 0
      bin/build.bat
  11. 12 0
      bin/package.bat
  12. 12 0
      bin/run-web.bat
  13. 35 0
      build/index.js
  14. 93 0
      package.json
  15. 二进制
      public/favicon.ico
  16. 46 0
      public/html/ie.html
  17. 208 0
      public/index.html
  18. 2 0
      public/robots.txt
  19. 19 0
      src/App.vue
  20. 54 0
      src/api/cms/index.js
  21. 46 0
      src/api/communityGovernance/exposure.js
  22. 46 0
      src/api/communityGovernance/merchant.js
  23. 11 0
      src/api/communityGovernance/record.js
  24. 20 0
      src/api/feedback/index.js
  25. 54 0
      src/api/files/upload.js
  26. 20 0
      src/api/integral/log.js
  27. 47 0
      src/api/integral/rule.js
  28. 21 0
      src/api/integral/user.js
  29. 59 0
      src/api/login.js
  30. 54 0
      src/api/lostfound/lostfound.js
  31. 9 0
      src/api/menu.js
  32. 57 0
      src/api/monitor/cache.js
  33. 71 0
      src/api/monitor/job.js
  34. 26 0
      src/api/monitor/jobLog.js
  35. 34 0
      src/api/monitor/logininfor.js
  36. 18 0
      src/api/monitor/online.js
  37. 26 0
      src/api/monitor/operlog.js
  38. 9 0
      src/api/monitor/server.js
  39. 127 0
      src/api/questionnaire/index.js
  40. 44 0
      src/api/register/user.js
  41. 61 0
      src/api/report/info.js
  42. 44 0
      src/api/seat/address.js
  43. 44 0
      src/api/seat/estate.js
  44. 44 0
      src/api/seat/gridman.js
  45. 60 0
      src/api/system/config.js
  46. 52 0
      src/api/system/dept.js
  47. 52 0
      src/api/system/dict/data.js
  48. 60 0
      src/api/system/dict/type.js
  49. 60 0
      src/api/system/menu.js
  50. 44 0
      src/api/system/notice.js
  51. 44 0
      src/api/system/post.js
  52. 119 0
      src/api/system/role.js
  53. 135 0
      src/api/system/user.js
  54. 76 0
      src/api/tool/gen.js
  55. 99 0
      src/api/vote/index.js
  56. 二进制
      src/assets/401_images/401.gif
  57. 二进制
      src/assets/404_images/404.png
  58. 二进制
      src/assets/404_images/404_cloud.png
  59. 9 0
      src/assets/icons/index.js
  60. 1 0
      src/assets/icons/svg/404.svg
  61. 1 0
      src/assets/icons/svg/bug.svg
  62. 1 0
      src/assets/icons/svg/build.svg
  63. 1 0
      src/assets/icons/svg/button.svg
  64. 1 0
      src/assets/icons/svg/cascader.svg
  65. 1 0
      src/assets/icons/svg/chart.svg
  66. 1 0
      src/assets/icons/svg/checkbox.svg
  67. 1 0
      src/assets/icons/svg/clipboard.svg
  68. 1 0
      src/assets/icons/svg/code.svg
  69. 1 0
      src/assets/icons/svg/color.svg
  70. 1 0
      src/assets/icons/svg/component.svg
  71. 1 0
      src/assets/icons/svg/dashboard.svg
  72. 1 0
      src/assets/icons/svg/date-range.svg
  73. 1 0
      src/assets/icons/svg/date.svg
  74. 1 0
      src/assets/icons/svg/dict.svg
  75. 1 0
      src/assets/icons/svg/documentation.svg
  76. 1 0
      src/assets/icons/svg/download.svg
  77. 1 0
      src/assets/icons/svg/drag.svg
  78. 1 0
      src/assets/icons/svg/druid.svg
  79. 1 0
      src/assets/icons/svg/edit.svg
  80. 1 0
      src/assets/icons/svg/education.svg
  81. 1 0
      src/assets/icons/svg/email.svg
  82. 1 0
      src/assets/icons/svg/example.svg
  83. 1 0
      src/assets/icons/svg/excel.svg
  84. 1 0
      src/assets/icons/svg/exit-fullscreen.svg
  85. 1 0
      src/assets/icons/svg/eye-open.svg
  86. 1 0
      src/assets/icons/svg/eye.svg
  87. 1 0
      src/assets/icons/svg/form.svg
  88. 1 0
      src/assets/icons/svg/fullscreen.svg
  89. 1 0
      src/assets/icons/svg/github.svg
  90. 1 0
      src/assets/icons/svg/guide.svg
  91. 1 0
      src/assets/icons/svg/icon.svg
  92. 1 0
      src/assets/icons/svg/input.svg
  93. 1 0
      src/assets/icons/svg/international.svg
  94. 1 0
      src/assets/icons/svg/job.svg
  95. 1 0
      src/assets/icons/svg/language.svg
  96. 1 0
      src/assets/icons/svg/link.svg
  97. 1 0
      src/assets/icons/svg/list.svg
  98. 1 0
      src/assets/icons/svg/lock.svg
  99. 1 0
      src/assets/icons/svg/log.svg
  100. 0 0
      src/assets/icons/svg/logininfor.svg

+ 22 - 0
.editorconfig

@@ -0,0 +1,22 @@
+# 告诉EditorConfig插件,这是根文件,不用继续往上查找
+root = true
+
+# 匹配全部文件
+[*]
+# 设置字符集
+charset = utf-8
+# 缩进风格,可选space、tab
+indent_style = space
+# 缩进的空格数
+indent_size = 2
+# 结尾换行符,可选lf、cr、crlf
+end_of_line = lf
+# 在文件结尾插入新行
+insert_final_newline = true
+# 删除一行中的前后空格
+trim_trailing_whitespace = true
+
+# 匹配md结尾的文件
+[*.md]
+insert_final_newline = false
+trim_trailing_whitespace = false

+ 11 - 0
.env.development

@@ -0,0 +1,11 @@
+# 页面标题
+VUE_APP_TITLE = 平信办管理系统
+
+# 开发环境配置
+ENV = 'development'
+
+# 若依管理系统/开发环境
+VUE_APP_BASE_API = '/dev-api'
+
+# 路由懒加载
+VUE_CLI_BABEL_TRANSPILE_MODULES = true

+ 11 - 0
.env.embed

@@ -0,0 +1,11 @@
+# 页面标题
+VUE_APP_TITLE = 平信办管理系统
+
+# 生产环境配置
+ENV = 'production'
+
+# 若依管理系统/生产环境
+VUE_APP_BASE_API = '/'
+
+# 页面baseUrl/嵌入环境
+VUE_APP_BASE_URL = '/admin'

+ 8 - 0
.env.production

@@ -0,0 +1,8 @@
+# 页面标题
+VUE_APP_TITLE = 平信办管理系统
+
+# 生产环境配置
+ENV = 'production'
+
+# 若依管理系统/生产环境
+VUE_APP_BASE_API = '/prod-api'

+ 10 - 0
.env.staging

@@ -0,0 +1,10 @@
+# 页面标题
+VUE_APP_TITLE = 平信办管理系统
+
+NODE_ENV = production
+
+# 测试环境配置
+ENV = 'staging'
+
+# 若依管理系统/测试环境
+VUE_APP_BASE_API = '/stage-api'

+ 10 - 0
.eslintignore

@@ -0,0 +1,10 @@
+# 忽略build目录下类型为js的文件的语法检查
+build/*.js
+# 忽略src/assets目录下文件的语法检查
+src/assets
+# 忽略public目录下文件的语法检查
+public
+# 忽略当前目录下为js的文件的语法检查
+*.js
+# 忽略当前目录下为vue的文件的语法检查
+*.vue

+ 199 - 0
.eslintrc.js

@@ -0,0 +1,199 @@
+// ESlint 检查配置
+module.exports = {
+  root: true,
+  parserOptions: {
+    parser: 'babel-eslint',
+    sourceType: 'module'
+  },
+  env: {
+    browser: true,
+    node: true,
+    es6: true,
+  },
+  extends: ['plugin:vue/recommended', 'eslint:recommended'],
+
+  // add your custom rules here
+  //it is base on https://github.com/vuejs/eslint-config-vue
+  rules: {
+    "vue/max-attributes-per-line": [2, {
+      "singleline": 10,
+      "multiline": {
+        "max": 1,
+        "allowFirstLine": false
+      }
+    }],
+    "vue/singleline-html-element-content-newline": "off",
+    "vue/multiline-html-element-content-newline":"off",
+    "vue/name-property-casing": ["error", "PascalCase"],
+    "vue/no-v-html": "off",
+    'accessor-pairs': 2,
+    'arrow-spacing': [2, {
+      'before': true,
+      'after': true
+    }],
+    'block-spacing': [2, 'always'],
+    'brace-style': [2, '1tbs', {
+      'allowSingleLine': true
+    }],
+    'camelcase': [0, {
+      'properties': 'always'
+    }],
+    'comma-dangle': [2, 'never'],
+    'comma-spacing': [2, {
+      'before': false,
+      'after': true
+    }],
+    'comma-style': [2, 'last'],
+    'constructor-super': 2,
+    'curly': [2, 'multi-line'],
+    'dot-location': [2, 'property'],
+    'eol-last': 2,
+    'eqeqeq': ["error", "always", {"null": "ignore"}],
+    'generator-star-spacing': [2, {
+      'before': true,
+      'after': true
+    }],
+    'handle-callback-err': [2, '^(err|error)$'],
+    'indent': [2, 2, {
+      'SwitchCase': 1
+    }],
+    'jsx-quotes': [2, 'prefer-single'],
+    'key-spacing': [2, {
+      'beforeColon': false,
+      'afterColon': true
+    }],
+    'keyword-spacing': [2, {
+      'before': true,
+      'after': true
+    }],
+    'new-cap': [2, {
+      'newIsCap': true,
+      'capIsNew': false
+    }],
+    'new-parens': 2,
+    'no-array-constructor': 2,
+    'no-caller': 2,
+    'no-console': 'off',
+    'no-class-assign': 2,
+    'no-cond-assign': 2,
+    'no-const-assign': 2,
+    'no-control-regex': 0,
+    'no-delete-var': 2,
+    'no-dupe-args': 2,
+    'no-dupe-class-members': 2,
+    'no-dupe-keys': 2,
+    'no-duplicate-case': 2,
+    'no-empty-character-class': 2,
+    'no-empty-pattern': 2,
+    'no-eval': 2,
+    'no-ex-assign': 2,
+    'no-extend-native': 2,
+    'no-extra-bind': 2,
+    'no-extra-boolean-cast': 2,
+    'no-extra-parens': [2, 'functions'],
+    'no-fallthrough': 2,
+    'no-floating-decimal': 2,
+    'no-func-assign': 2,
+    'no-implied-eval': 2,
+    'no-inner-declarations': [2, 'functions'],
+    'no-invalid-regexp': 2,
+    'no-irregular-whitespace': 2,
+    'no-iterator': 2,
+    'no-label-var': 2,
+    'no-labels': [2, {
+      'allowLoop': false,
+      'allowSwitch': false
+    }],
+    'no-lone-blocks': 2,
+    'no-mixed-spaces-and-tabs': 2,
+    'no-multi-spaces': 2,
+    'no-multi-str': 2,
+    'no-multiple-empty-lines': [2, {
+      'max': 1
+    }],
+    'no-native-reassign': 2,
+    'no-negated-in-lhs': 2,
+    'no-new-object': 2,
+    'no-new-require': 2,
+    'no-new-symbol': 2,
+    'no-new-wrappers': 2,
+    'no-obj-calls': 2,
+    'no-octal': 2,
+    'no-octal-escape': 2,
+    'no-path-concat': 2,
+    'no-proto': 2,
+    'no-redeclare': 2,
+    'no-regex-spaces': 2,
+    'no-return-assign': [2, 'except-parens'],
+    'no-self-assign': 2,
+    'no-self-compare': 2,
+    'no-sequences': 2,
+    'no-shadow-restricted-names': 2,
+    'no-spaced-func': 2,
+    'no-sparse-arrays': 2,
+    'no-this-before-super': 2,
+    'no-throw-literal': 2,
+    'no-trailing-spaces': 2,
+    'no-undef': 2,
+    'no-undef-init': 2,
+    'no-unexpected-multiline': 2,
+    'no-unmodified-loop-condition': 2,
+    'no-unneeded-ternary': [2, {
+      'defaultAssignment': false
+    }],
+    'no-unreachable': 2,
+    'no-unsafe-finally': 2,
+    'no-unused-vars': [2, {
+      'vars': 'all',
+      'args': 'none'
+    }],
+    'no-useless-call': 2,
+    'no-useless-computed-key': 2,
+    'no-useless-constructor': 2,
+    'no-useless-escape': 0,
+    'no-whitespace-before-property': 2,
+    'no-with': 2,
+    'one-var': [2, {
+      'initialized': 'never'
+    }],
+    'operator-linebreak': [2, 'after', {
+      'overrides': {
+        '?': 'before',
+        ':': 'before'
+      }
+    }],
+    'padded-blocks': [2, 'never'],
+    'quotes': [2, 'single', {
+      'avoidEscape': true,
+      'allowTemplateLiterals': true
+    }],
+    'semi': [2, 'never'],
+    'semi-spacing': [2, {
+      'before': false,
+      'after': true
+    }],
+    'space-before-blocks': [2, 'always'],
+    'space-before-function-paren': [2, 'never'],
+    'space-in-parens': [2, 'never'],
+    'space-infix-ops': 2,
+    'space-unary-ops': [2, {
+      'words': true,
+      'nonwords': false
+    }],
+    'spaced-comment': [2, 'always', {
+      'markers': ['global', 'globals', 'eslint', 'eslint-disable', '*package', '!', ',']
+    }],
+    'template-curly-spacing': [2, 'never'],
+    'use-isnan': 2,
+    'valid-typeof': 2,
+    'wrap-iife': [2, 'any'],
+    'yield-star-spacing': [2, 'both'],
+    'yoda': [2, 'never'],
+    'prefer-const': 2,
+    'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0,
+    'object-curly-spacing': [2, 'always', {
+      objectsInObjects: false
+    }],
+    'array-bracket-spacing': [2, 'never']
+  }
+}

+ 23 - 0
.gitignore

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

+ 13 - 0
babel.config.js

@@ -0,0 +1,13 @@
+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.
+      'plugins': ['dynamic-import-node']
+    }
+  }
+}

+ 12 - 0
bin/build.bat

@@ -0,0 +1,12 @@
+@echo off
+echo.
+echo [信息] 打包Web工程,生成dist文件。
+echo.
+
+%~d0
+cd %~dp0
+
+cd ..
+npm run build:prod
+
+pause

+ 12 - 0
bin/package.bat

@@ -0,0 +1,12 @@
+@echo off
+echo.
+echo [信息] 安装Web工程,生成node_modules文件。
+echo.
+
+%~d0
+cd %~dp0
+
+cd ..
+npm install --registry=https://registry.npmmirror.com
+
+pause

+ 12 - 0
bin/run-web.bat

@@ -0,0 +1,12 @@
+@echo off
+echo.
+echo [信息] 使用 Vue CLI 命令运行 Web 工程。
+echo.
+
+%~d0
+cd %~dp0
+
+cd ..
+npm run dev
+
+pause

+ 35 - 0
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}`)
+}

+ 93 - 0
package.json

@@ -0,0 +1,93 @@
+{
+  "name": "ruoyi",
+  "version": "3.8.3",
+  "description": "平信办管理系统",
+  "author": "若依",
+  "license": "MIT",
+  "scripts": {
+    "dev": "vue-cli-service serve",
+    "build:prod": "vue-cli-service build",
+    "build:stage": "vue-cli-service build --mode staging",
+    "build:embed": "vue-cli-service build --mode embed",
+    "preview": "node build/index.js --preview",
+    "lint": "eslint --ext .js,.vue src"
+  },
+  "husky": {
+    "hooks": {
+      "pre-commit": "lint-staged"
+    }
+  },
+  "lint-staged": {
+    "src/**/*.{js,vue}": [
+      "eslint --fix",
+      "git add"
+    ]
+  },
+  "keywords": [
+    "vue",
+    "admin",
+    "dashboard",
+    "element-ui",
+    "boilerplate",
+    "admin-template",
+    "management-system"
+  ],
+  "repository": {
+    "type": "git",
+    "url": "https://gitee.com/y_project/RuoYi-Vue.git"
+  },
+  "dependencies": {
+    "@riophae/vue-treeselect": "0.4.0",
+    "@wangeditor/editor": "^5.1.23",
+    "axios": "0.24.0",
+    "clipboard": "2.0.8",
+    "core-js": "3.19.1",
+    "echarts": "4.9.0",
+    "element-ui": "2.15.10",
+    "file-saver": "2.0.5",
+    "fuse.js": "6.4.3",
+    "highlight.js": "9.18.5",
+    "js-beautify": "1.13.0",
+    "js-cookie": "3.0.1",
+    "jsencrypt": "3.0.0-rc.1",
+    "nprogress": "0.2.0",
+    "quill": "1.3.7",
+    "screenfull": "5.0.2",
+    "sortablejs": "1.10.2",
+    "vue": "2.6.12",
+    "vue-count-to": "1.0.13",
+    "vue-cropper": "0.5.5",
+    "vue-meta": "2.4.0",
+    "vue-router": "3.4.9",
+    "vuedraggable": "^2.24.3",
+    "vuex": "3.6.0",
+    "wangeditor": "^4.7.15"
+  },
+  "devDependencies": {
+    "@vue/cli-plugin-babel": "4.4.6",
+    "@vue/cli-plugin-eslint": "4.4.6",
+    "@vue/cli-service": "4.4.6",
+    "babel-eslint": "10.1.0",
+    "babel-plugin-dynamic-import-node": "2.3.3",
+    "chalk": "4.1.0",
+    "compression-webpack-plugin": "5.0.2",
+    "connect": "3.6.6",
+    "eslint": "7.15.0",
+    "eslint-plugin-vue": "7.2.0",
+    "lint-staged": "10.5.3",
+    "runjs": "4.4.2",
+    "sass": "1.32.13",
+    "sass-loader": "10.1.1",
+    "script-ext-html-webpack-plugin": "2.1.5",
+    "svg-sprite-loader": "5.1.1",
+    "vue-template-compiler": "2.6.12"
+  },
+  "engines": {
+    "node": ">=8.9",
+    "npm": ">= 3.0.0"
+  },
+  "browserslist": [
+    "> 1%",
+    "last 2 versions"
+  ]
+}

二进制
public/favicon.ico


文件差异内容过多而无法显示
+ 46 - 0
public/html/ie.html


+ 208 - 0
public/index.html

@@ -0,0 +1,208 @@
+<!DOCTYPE html>
+<html>
+  <head>
+    <meta charset="utf-8">
+    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
+    <meta name="renderer" content="webkit">
+    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
+    <link rel="icon" href="<%= BASE_URL %>favicon.ico">
+    <title><%= webpackConfig.name %></title>
+    <!--[if lt IE 11]><script>window.location.href='/html/ie.html';</script><![endif]-->
+	  <style>
+    html,
+    body,
+    #app {
+      height: 100%;
+      margin: 0px;
+      padding: 0px;
+    }
+    .chromeframe {
+      margin: 0.2em 0;
+      background: #ccc;
+      color: #000;
+      padding: 0.2em 0;
+    }
+
+    #loader-wrapper {
+      position: fixed;
+      top: 0;
+      left: 0;
+      width: 100%;
+      height: 100%;
+      z-index: 999999;
+    }
+
+    #loader {
+      display: block;
+      position: relative;
+      left: 50%;
+      top: 50%;
+      width: 150px;
+      height: 150px;
+      margin: -75px 0 0 -75px;
+      border-radius: 50%;
+      border: 3px solid transparent;
+      border-top-color: #FFF;
+      -webkit-animation: spin 2s linear infinite;
+      -ms-animation: spin 2s linear infinite;
+      -moz-animation: spin 2s linear infinite;
+      -o-animation: spin 2s linear infinite;
+      animation: spin 2s linear infinite;
+      z-index: 1001;
+    }
+
+    #loader:before {
+      content: "";
+      position: absolute;
+      top: 5px;
+      left: 5px;
+      right: 5px;
+      bottom: 5px;
+      border-radius: 50%;
+      border: 3px solid transparent;
+      border-top-color: #FFF;
+      -webkit-animation: spin 3s linear infinite;
+      -moz-animation: spin 3s linear infinite;
+      -o-animation: spin 3s linear infinite;
+      -ms-animation: spin 3s linear infinite;
+      animation: spin 3s linear infinite;
+    }
+
+    #loader:after {
+      content: "";
+      position: absolute;
+      top: 15px;
+      left: 15px;
+      right: 15px;
+      bottom: 15px;
+      border-radius: 50%;
+      border: 3px solid transparent;
+      border-top-color: #FFF;
+      -moz-animation: spin 1.5s linear infinite;
+      -o-animation: spin 1.5s linear infinite;
+      -ms-animation: spin 1.5s linear infinite;
+      -webkit-animation: spin 1.5s linear infinite;
+      animation: spin 1.5s linear infinite;
+    }
+
+
+    @-webkit-keyframes spin {
+      0% {
+        -webkit-transform: rotate(0deg);
+        -ms-transform: rotate(0deg);
+        transform: rotate(0deg);
+      }
+      100% {
+        -webkit-transform: rotate(360deg);
+        -ms-transform: rotate(360deg);
+        transform: rotate(360deg);
+      }
+    }
+
+    @keyframes spin {
+      0% {
+        -webkit-transform: rotate(0deg);
+        -ms-transform: rotate(0deg);
+        transform: rotate(0deg);
+      }
+      100% {
+        -webkit-transform: rotate(360deg);
+        -ms-transform: rotate(360deg);
+        transform: rotate(360deg);
+      }
+    }
+
+
+    #loader-wrapper .loader-section {
+      position: fixed;
+      top: 0;
+      width: 51%;
+      height: 100%;
+      background: #7171C6;
+      z-index: 1000;
+      -webkit-transform: translateX(0);
+      -ms-transform: translateX(0);
+      transform: translateX(0);
+    }
+
+    #loader-wrapper .loader-section.section-left {
+      left: 0;
+    }
+
+    #loader-wrapper .loader-section.section-right {
+      right: 0;
+    }
+
+
+    .loaded #loader-wrapper .loader-section.section-left {
+      -webkit-transform: translateX(-100%);
+      -ms-transform: translateX(-100%);
+      transform: translateX(-100%);
+      -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
+      transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
+    }
+
+    .loaded #loader-wrapper .loader-section.section-right {
+      -webkit-transform: translateX(100%);
+      -ms-transform: translateX(100%);
+      transform: translateX(100%);
+      -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
+      transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
+    }
+
+    .loaded #loader {
+      opacity: 0;
+      -webkit-transition: all 0.3s ease-out;
+      transition: all 0.3s ease-out;
+    }
+
+    .loaded #loader-wrapper {
+      visibility: hidden;
+      -webkit-transform: translateY(-100%);
+      -ms-transform: translateY(-100%);
+      transform: translateY(-100%);
+      -webkit-transition: all 0.3s 1s ease-out;
+      transition: all 0.3s 1s ease-out;
+    }
+
+    .no-js #loader-wrapper {
+      display: none;
+    }
+
+    .no-js h1 {
+      color: #222222;
+    }
+
+    #loader-wrapper .load_title {
+      font-family: 'Open Sans';
+      color: #FFF;
+      font-size: 19px;
+      width: 100%;
+      text-align: center;
+      z-index: 9999999999999;
+      position: absolute;
+      top: 60%;
+      opacity: 1;
+      line-height: 30px;
+    }
+
+    #loader-wrapper .load_title span {
+      font-weight: normal;
+      font-style: italic;
+      font-size: 13px;
+      color: #FFF;
+      opacity: 0.5;
+    }
+  </style>
+  </head>
+  <body>
+    <div id="app">
+	    <div id="loader-wrapper">
+		    <div id="loader"></div>
+		    <div class="loader-section section-left"></div>
+		    <div class="loader-section section-right"></div>
+		    <div class="load_title">正在加载系统资源,请耐心等待</div>
+        </div>
+	</div>
+  </body>
+</html>

+ 2 - 0
public/robots.txt

@@ -0,0 +1,2 @@
+User-agent: *
+Disallow: /

+ 19 - 0
src/App.vue

@@ -0,0 +1,19 @@
+<template>
+  <div id="app">
+    <router-view />
+  </div>
+</template>
+
+<script>
+export default  {
+  name:  'App',
+    metaInfo() {
+        return {
+            title: this.$store.state.settings.dynamicTitle && this.$store.state.settings.title,
+            titleTemplate: title => {
+                return title ? `${title} - ${process.env.VUE_APP_TITLE}` : process.env.VUE_APP_TITLE
+            }
+        }
+    }
+}
+</script>

+ 54 - 0
src/api/cms/index.js

@@ -0,0 +1,54 @@
+
+import request from '@/utils/request'
+
+// 新增
+export function cmsAdd(data, type) {
+  return request({
+    url: `/cms/${type}`,
+    method: 'post',
+    data
+  })
+}
+
+// 删除
+export function cmsDel(type, id) {
+  return request({
+      url: `/cms/${type}/${id}`,
+      method: 'delete'
+  })
+}
+
+// 修改
+export function cmsUpdate(data, type) {
+  return request({
+    url: `/cms/${type}`,
+    method: 'put',
+    data: data
+  })
+}
+
+// 查询List
+export function cmsQuery(query, type, alias) {
+  return request({
+    url: `/cms/${type}${alias ? '/' + alias : ''}/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询详情
+export function cmsFetch(suffix, type) {
+  return request({
+    url: `/cms/${type}/${suffix}`,
+    method: 'get'
+  })
+}
+
+// 审核
+export function cmsReview(data) {
+  return request({
+    url: `/cms/custom/review/${data.postId}`,
+    method: 'post',
+    data
+  })
+}

+ 46 - 0
src/api/communityGovernance/exposure.js

@@ -0,0 +1,46 @@
+
+import request from '@/utils/request'
+
+// 新增
+export function businessAdd(data) {
+  return request({
+    url: `/community/business/exposed`,
+    method: 'post',
+    data
+  })
+}
+
+// 删除
+export function businessDel(data) {
+  return request({
+      url: `/community/business/exposed`,
+      method: 'delete',
+      data
+  })
+}
+
+// 修改
+export function businessUpdate(data) {
+  return request({
+    url: `/community/business/exposed/${data.id}`,
+    method: 'put',
+    data: data
+  })
+}
+
+// 查询List
+export function businessQuery(query, type, alias) {
+  return request({
+    url: `/community/business/exposed/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询详情
+export function businessFetch(id) {
+  return request({
+    url: `/community/business/exposed/${id}`,
+    method: 'get'
+  })
+}

+ 46 - 0
src/api/communityGovernance/merchant.js

@@ -0,0 +1,46 @@
+
+import request from '@/utils/request'
+
+// 新增
+export function businessAdd(data) {
+  return request({
+    url: `/community/business/info`,
+    method: 'post',
+    data
+  })
+}
+
+// 删除
+export function businessDel(data) {
+  return request({
+      url: `/community/business/info`,
+      method: 'delete',
+      data
+  })
+}
+
+// 修改
+export function businessUpdate(data) {
+  return request({
+    url: `/community/business/info/${data.id}`,
+    method: 'put',
+    data: data
+  })
+}
+
+// 查询List
+export function businessQuery(query, type, alias) {
+  return request({
+    url: `/community/business/info/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询详情
+export function businessFetch(id) {
+  return request({
+    url: `/community/business/info/${id}`,
+    method: 'get'
+  })
+}

+ 11 - 0
src/api/communityGovernance/record.js

@@ -0,0 +1,11 @@
+
+import request from '@/utils/request'
+
+// 查询List
+export function recordQuery(query, type, alias) {
+  return request({
+    url: `/community/business/point/list`,
+    method: 'get',
+    params: query
+  })
+}

+ 20 - 0
src/api/feedback/index.js

@@ -0,0 +1,20 @@
+import request from '@/utils/request'
+
+// 查询
+export function getFeedback(query) {
+  return request({
+    url: '/biz/feedback/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 修改
+export function updateFeedback(data) {
+  return request({
+    url: `/biz/feedback`,
+    method: 'put',
+    data: data
+  })
+}
+

+ 54 - 0
src/api/files/upload.js

@@ -0,0 +1,54 @@
+import request from '@/utils/request'
+// 文件上传
+export function upload(data) {
+    return request({
+      url: '/common/upload',
+      method: 'post',
+      data: data
+    })
+  }
+
+  // 文件查询
+  export function openFiles(query) {
+    return request({
+      url: '/file-manager/open',
+      method: 'get',
+      params: query
+    })
+  }
+
+  // 创建文件夹
+  export function addFile(data) {
+    return request({
+      url: `/file-manager/create?path=${data.path}&dirName=${data.dirName}`,
+      method: 'post',
+      data
+    })
+  }
+
+  // 修改文件夹或文件名称
+  export function editFile(data) {
+    return request({
+      url: `/file-manager/rename?path=${data.path}&originName=${data.originName}&newName=${data.newName}`,
+      method: 'post',
+      data
+    })
+  }
+
+   // 删除文件夹或文件名称
+   export function delFile(data) {
+    return request({
+      url: `/file-manager/delete?path=${data.path}&name=${data.name}`,
+      method: 'delete',
+      data
+    })
+  }
+
+  // 资源文件上传
+export function managerUpload(data) {
+  return request({
+    url: '/file-manager/upload',
+    method: 'post',
+    data: data
+  })
+}

+ 20 - 0
src/api/integral/log.js

@@ -0,0 +1,20 @@
+import request from '@/utils/request'
+
+// 修改
+export function logQuery(data) {
+  return request({
+    url: `/point/log/list`,
+    method: 'get',
+    data: data
+  })
+}
+
+// 查询List
+export function logDetails(id) {
+  return request({
+    url: `/point/log/${id}`,
+    method: 'get',
+  })
+}
+
+

+ 47 - 0
src/api/integral/rule.js

@@ -0,0 +1,47 @@
+
+import request from '@/utils/request'
+
+// 新增
+export function ruleAdd(data) {
+  return request({
+    url: `/point/rule`,
+    method: 'post',
+    data
+  })
+}
+
+// 删除
+export function ruleDel(data) {
+  return request({
+      url: `/point/rule`,
+      method: 'delete',
+      data
+  })
+}
+
+// 修改
+export function ruleUpdate(data, id) {
+  return request({
+    url: `/point/rule/${id}`,
+    method: 'put',
+    data: data
+  })
+}
+
+// 查询List
+export function ruleQuery(query) {
+  return request({
+    url: `/point/rule/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询详情
+export function ruleFetch(id) {
+  return request({
+    url: `/point/rule/${id}`,
+    method: 'get'
+  })
+}
+

+ 21 - 0
src/api/integral/user.js

@@ -0,0 +1,21 @@
+import request from '@/utils/request'
+
+// 修改
+export function userUpdate(data, id) {
+  return request({
+    url: `/point/info/change`,
+    method: 'post',
+    data: data
+  })
+}
+
+// 查询List
+export function userQuery(query) {
+  return request({
+    url: `/point/info/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+

+ 59 - 0
src/api/login.js

@@ -0,0 +1,59 @@
+import request from '@/utils/request'
+
+// 登录方法
+export function login(username, password, code, uuid) {
+  const data = {
+    username,
+    password,
+    code,
+    uuid
+  }
+  return request({
+    url: '/login',
+    headers: {
+      isToken: false
+    },
+    method: 'post',
+    data: data
+  })
+}
+
+// 注册方法
+export function register(data) {
+  return request({
+    url: '/register',
+    headers: {
+      isToken: false
+    },
+    method: 'post',
+    data: data
+  })
+}
+
+// 获取用户详细信息
+export function getInfo() {
+  return request({
+    url: '/getInfo',
+    method: 'get'
+  })
+}
+
+// 退出方法
+export function logout() {
+  return request({
+    url: '/logout',
+    method: 'post'
+  })
+}
+
+// 获取验证码
+export function getCodeImg() {
+  return request({
+    url: '/captchaImage',
+    headers: {
+      isToken: false
+    },
+    method: 'get',
+    timeout: 20000
+  })
+}

+ 54 - 0
src/api/lostfound/lostfound.js

@@ -0,0 +1,54 @@
+import request from '@/utils/request'
+
+// 查询失物寻物列表
+export function listLostfound(query) {
+  return request({
+    url: `/biz/lost-found${query.type ? '/'+query.type : ''}/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询失物寻物详细
+export function getLostfound(query) {
+  return request({
+    url: `/biz/lost-found${query.type ? '/'+query.type : ''}/` + query.id,
+    method: 'get'
+  })
+}
+
+// 新增失物寻物
+export function addLostfound(data) {
+  return request({
+    url: `/biz/lost-found${data.type ? '/'+data.type : ''}/info`,
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改失物寻物
+export function updateLostfound(data) {
+  return request({
+    url: `/biz/lost-found${data.type ? '/'+data.type : ''}/info/${data.id}`,
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除失物寻物
+export function delLostfound(data) {
+  return request({
+    url: `/biz/lost-found${data.type ? '/'+data.type : ''}/` + data.id,
+    method: 'delete'
+  })
+}
+
+// 审核
+export function verifyLostfound(data) {
+  console.log(data, 'data');
+  return request({
+    url: `/biz/lost-found${data.type ? '/'+data.type : ''}/status/${data.id}`,
+    method: 'put',
+    data: data
+  })
+}

+ 9 - 0
src/api/menu.js

@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+// 获取路由
+export const getRouters = () => {
+  return request({
+    url: '/getRouters',
+    method: 'get'
+  })
+}

+ 57 - 0
src/api/monitor/cache.js

@@ -0,0 +1,57 @@
+import request from '@/utils/request'
+
+// 查询缓存详细
+export function getCache() {
+  return request({
+    url: '/monitor/cache',
+    method: 'get'
+  })
+}
+
+// 查询缓存名称列表
+export function listCacheName() {
+  return request({
+    url: '/monitor/cache/getNames',
+    method: 'get'
+  })
+}
+
+// 查询缓存键名列表
+export function listCacheKey(cacheName) {
+  return request({
+    url: '/monitor/cache/getKeys/' + cacheName,
+    method: 'get'
+  })
+}
+
+// 查询缓存内容
+export function getCacheValue(cacheName, cacheKey) {
+  return request({
+    url: '/monitor/cache/getValue/' + cacheName + '/' + cacheKey,
+    method: 'get'
+  })
+}
+
+// 清理指定名称缓存
+export function clearCacheName(cacheName) {
+  return request({
+    url: '/monitor/cache/clearCacheName/' + cacheName,
+    method: 'delete'
+  })
+}
+
+// 清理指定键名缓存
+export function clearCacheKey(cacheKey) {
+  return request({
+    url: '/monitor/cache/clearCacheKey/' + cacheKey,
+    method: 'delete'
+  })
+}
+
+// 清理全部缓存
+export function clearCacheAll() {
+  return request({
+    url: '/monitor/cache/clearCacheAll',
+    method: 'delete'
+  })
+}

+ 71 - 0
src/api/monitor/job.js

@@ -0,0 +1,71 @@
+import request from '@/utils/request'
+
+// 查询定时任务调度列表
+export function listJob(query) {
+  return request({
+    url: '/monitor/job/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询定时任务调度详细
+export function getJob(jobId) {
+  return request({
+    url: '/monitor/job/' + jobId,
+    method: 'get'
+  })
+}
+
+// 新增定时任务调度
+export function addJob(data) {
+  return request({
+    url: '/monitor/job',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改定时任务调度
+export function updateJob(data) {
+  return request({
+    url: '/monitor/job',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除定时任务调度
+export function delJob(jobId) {
+  return request({
+    url: '/monitor/job/' + jobId,
+    method: 'delete'
+  })
+}
+
+// 任务状态修改
+export function changeJobStatus(jobId, status) {
+  const data = {
+    jobId,
+    status
+  }
+  return request({
+    url: '/monitor/job/changeStatus',
+    method: 'put',
+    data: data
+  })
+}
+
+
+// 定时任务立即执行一次
+export function runJob(jobId, jobGroup) {
+  const data = {
+    jobId,
+    jobGroup
+  }
+  return request({
+    url: '/monitor/job/run',
+    method: 'put',
+    data: data
+  })
+}

+ 26 - 0
src/api/monitor/jobLog.js

@@ -0,0 +1,26 @@
+import request from '@/utils/request'
+
+// 查询调度日志列表
+export function listJobLog(query) {
+  return request({
+    url: '/monitor/jobLog/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 删除调度日志
+export function delJobLog(jobLogId) {
+  return request({
+    url: '/monitor/jobLog/' + jobLogId,
+    method: 'delete'
+  })
+}
+
+// 清空调度日志
+export function cleanJobLog() {
+  return request({
+    url: '/monitor/jobLog/clean',
+    method: 'delete'
+  })
+}

+ 34 - 0
src/api/monitor/logininfor.js

@@ -0,0 +1,34 @@
+import request from '@/utils/request'
+
+// 查询登录日志列表
+export function list(query) {
+  return request({
+    url: '/monitor/logininfor/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 删除登录日志
+export function delLogininfor(infoId) {
+  return request({
+    url: '/monitor/logininfor/' + infoId,
+    method: 'delete'
+  })
+}
+
+// 解锁用户登录状态
+export function unlockLogininfor(userName) {
+  return request({
+    url: '/monitor/logininfor/unlock/' + userName,
+    method: 'get'
+  })
+}
+
+// 清空登录日志
+export function cleanLogininfor() {
+  return request({
+    url: '/monitor/logininfor/clean',
+    method: 'delete'
+  })
+}

+ 18 - 0
src/api/monitor/online.js

@@ -0,0 +1,18 @@
+import request from '@/utils/request'
+
+// 查询在线用户列表
+export function list(query) {
+  return request({
+    url: '/monitor/online/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 强退用户
+export function forceLogout(tokenId) {
+  return request({
+    url: '/monitor/online/' + tokenId,
+    method: 'delete'
+  })
+}

+ 26 - 0
src/api/monitor/operlog.js

@@ -0,0 +1,26 @@
+import request from '@/utils/request'
+
+// 查询操作日志列表
+export function list(query) {
+  return request({
+    url: '/monitor/operlog/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 删除操作日志
+export function delOperlog(operId) {
+  return request({
+    url: '/monitor/operlog/' + operId,
+    method: 'delete'
+  })
+}
+
+// 清空操作日志
+export function cleanOperlog() {
+  return request({
+    url: '/monitor/operlog/clean',
+    method: 'delete'
+  })
+}

+ 9 - 0
src/api/monitor/server.js

@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+// 获取服务信息
+export function getServer() {
+  return request({
+    url: '/monitor/server',
+    method: 'get'
+  })
+}

+ 127 - 0
src/api/questionnaire/index.js

@@ -0,0 +1,127 @@
+import request from '@/utils/request'
+// 查询
+export function getQuestionnaire(query) {
+  return request({
+    url: `/survey/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 新增
+export function addQuestionnaire(data) {
+  return request({
+    url: `/survey/info`,
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改
+export function updateQuestionnaire(data) {
+  return request({
+    url: `/survey/info/${data.surveyId}`,
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除
+export function delQuestionnaire(data) {
+  return request({
+    url: `/survey/info`,
+    method: 'delete',
+    data
+  })
+}
+// 修改状态
+export function setQuestionnaireStatus(data) {
+  return request({
+    url: `/survey/status`,
+    method: 'post',
+    data
+  })
+}
+
+
+
+// 问题
+// 查询
+export function getQuestion(query) {
+  return request({
+    url: `/survey/question`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 新增
+export function addQuestion(data) {
+  return request({
+    url: `/survey/question`,
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改
+export function updateQuestion(data) {
+  return request({
+    url: `/survey/question/${data.questionId}`,
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除
+export function delQuestion(data) {
+  return request({
+    url: `/survey/question`,
+    method: 'delete',
+    data
+  })
+}
+
+// 详情
+export function getQuestionFach(query) {
+  return request({
+    url: `/survey/question/${query.questionId}`,
+    method: 'delete',
+    params: query
+  })
+}
+
+
+// 记录
+// 查询
+export function getRecord(query) {
+  return request({
+    url: `/survey/record`,
+    method: 'get',
+    params: query
+  })
+}
+// 删除
+export function delRecord(recordId) {
+  return request({
+    url: `/survey/record/${recordId}`,
+    method: 'delete'
+  })
+}
+
+// 获取调查问卷问题及问题选项信息
+export function getDetail(surveyId) {
+  return request({
+    url: `/survey/detail/${surveyId}`,
+    method: 'get'
+  })
+}
+
+// 获取调查问卷填写结果
+export function getResult(query) {
+  return request({
+    url: `/survey/result/${query.surveyId}`,
+    method: 'get',
+    params: query
+  })
+}

+ 44 - 0
src/api/register/user.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询微信用户管理列表
+export function listUser(query) {
+  return request({
+    url: '/register/user/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询微信用户管理详细
+export function getUser(userId) {
+  return request({
+    url: '/register/user/' + userId,
+    method: 'get'
+  })
+}
+
+// 新增微信用户管理
+export function addUser(data) {
+  return request({
+    url: '/register/user',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改微信用户管理
+export function updateUser(data) {
+  return request({
+    url: '/register/user',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除微信用户管理
+export function delUser(userId) {
+  return request({
+    url: '/register/user/' + userId,
+    method: 'delete'
+  })
+}

+ 61 - 0
src/api/report/info.js

@@ -0,0 +1,61 @@
+import request from '@/utils/request'
+
+// 查询事件上报管理列表
+export function listInfo(query) {
+  return request({
+    url: '/report/info/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询事件上报管理详细
+export function getInfo(reportId) {
+  return request({
+    url: '/report/info/' + reportId,
+    method: 'get'
+  })
+}
+
+// 新增事件上报管理
+export function addInfo(data) {
+  return request({
+    url: '/report/info',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改事件上报管理
+export function updateInfo(data) {
+  return request({
+    url: '/report/info',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除事件上报管理
+export function delInfo(reportId) {
+  return request({
+    url: '/report/info/' + reportId,
+    method: 'delete'
+  })
+}
+
+// 事件上报类型查询
+export function typeList() {
+  return request({
+    url: '/report/type/list',
+    method: 'get'
+  })
+}
+
+// 同步事件上报管理
+export function syncInfo(data) {
+  return request({
+    url: '/report/info/sync-reset',
+    method: 'post',
+    data: data
+  })
+}

+ 44 - 0
src/api/seat/address.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询地址管理列表
+export function listaddress(query) {
+  return request({
+    url: '/address/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询地址管理详细
+export function getaddress(addressId) {
+  return request({
+    url: '/address/' + addressId,
+    method: 'get'
+  })
+}
+
+// 新增地址管理
+export function addaddress(data) {
+  return request({
+    url: '/address',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改地址管理
+export function updateaddress(data) {
+  return request({
+    url: '/address',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除地址管理
+export function deladdress(addressId) {
+  return request({
+    url: '/address/' + addressId,
+    method: 'delete'
+  })
+}

+ 44 - 0
src/api/seat/estate.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询小区管理列表
+export function listestate(query) {
+  return request({
+    url: '/estate/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询小区管理详细
+export function getestate(estateId) {
+  return request({
+    url: '/estate/' + estateId,
+    method: 'get'
+  })
+}
+
+// 新增小区管理
+export function addestate(data) {
+  return request({
+    url: '/estate',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改小区管理
+export function updateestate(data) {
+  return request({
+    url: '/estate',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除小区管理
+export function delestate(estateId) {
+  return request({
+    url: '/estate/' + estateId,
+    method: 'delete'
+  })
+}

+ 44 - 0
src/api/seat/gridman.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询网格员管理列表
+export function listgridman(query) {
+  return request({
+    url: '/gridman/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询网格员管理详细
+export function getgridman(id) {
+  return request({
+    url: '/gridman/' + id,
+    method: 'get'
+  })
+}
+
+// 新增网格员管理
+export function addgridman(data) {
+  return request({
+    url: `/gridman?grid=${data.grid}`,
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改网格员管理
+export function updategridman(data) {
+  return request({
+    url: '/gridman',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除网格员管理
+export function delgridman(id) {
+  return request({
+    url: '/gridman/' + id,
+    method: 'delete'
+  })
+}

+ 60 - 0
src/api/system/config.js

@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询参数列表
+export function listConfig(query) {
+  return request({
+    url: '/system/config/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询参数详细
+export function getConfig(configId) {
+  return request({
+    url: '/system/config/' + configId,
+    method: 'get'
+  })
+}
+
+// 根据参数键名查询参数值
+export function getConfigKey(configKey) {
+  return request({
+    url: '/system/config/configKey/' + configKey,
+    method: 'get'
+  })
+}
+
+// 新增参数配置
+export function addConfig(data) {
+  return request({
+    url: '/system/config',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改参数配置
+export function updateConfig(data) {
+  return request({
+    url: '/system/config',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除参数配置
+export function delConfig(configId) {
+  return request({
+    url: '/system/config/' + configId,
+    method: 'delete'
+  })
+}
+
+// 刷新参数缓存
+export function refreshCache() {
+  return request({
+    url: '/system/config/refreshCache',
+    method: 'delete'
+  })
+}

+ 52 - 0
src/api/system/dept.js

@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询部门列表
+export function listDept(query) {
+  return request({
+    url: '/system/dept/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询部门列表(排除节点)
+export function listDeptExcludeChild(deptId) {
+  return request({
+    url: '/system/dept/list/exclude/' + deptId,
+    method: 'get'
+  })
+}
+
+// 查询部门详细
+export function getDept(deptId) {
+  return request({
+    url: '/system/dept/' + deptId,
+    method: 'get'
+  })
+}
+
+// 新增部门
+export function addDept(data) {
+  return request({
+    url: '/system/dept',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改部门
+export function updateDept(data) {
+  return request({
+    url: '/system/dept',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除部门
+export function delDept(deptId) {
+  return request({
+    url: '/system/dept/' + deptId,
+    method: 'delete'
+  })
+}

+ 52 - 0
src/api/system/dict/data.js

@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询字典数据列表
+export function listData(query) {
+  return request({
+    url: '/system/dict/data/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询字典数据详细
+export function getData(dictCode) {
+  return request({
+    url: '/system/dict/data/' + dictCode,
+    method: 'get'
+  })
+}
+
+// 根据字典类型查询字典数据信息
+export function getDicts(dictType) {
+  return request({
+    url: '/system/dict/data/type/' + dictType,
+    method: 'get'
+  })
+}
+
+// 新增字典数据
+export function addData(data) {
+  return request({
+    url: '/system/dict/data',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改字典数据
+export function updateData(data) {
+  return request({
+    url: '/system/dict/data',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除字典数据
+export function delData(dictCode) {
+  return request({
+    url: '/system/dict/data/' + dictCode,
+    method: 'delete'
+  })
+}

+ 60 - 0
src/api/system/dict/type.js

@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询字典类型列表
+export function listType(query) {
+  return request({
+    url: '/system/dict/type/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询字典类型详细
+export function getType(dictId) {
+  return request({
+    url: '/system/dict/type/' + dictId,
+    method: 'get'
+  })
+}
+
+// 新增字典类型
+export function addType(data) {
+  return request({
+    url: '/system/dict/type',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改字典类型
+export function updateType(data) {
+  return request({
+    url: '/system/dict/type',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除字典类型
+export function delType(dictId) {
+  return request({
+    url: '/system/dict/type/' + dictId,
+    method: 'delete'
+  })
+}
+
+// 刷新字典缓存
+export function refreshCache() {
+  return request({
+    url: '/system/dict/type/refreshCache',
+    method: 'delete'
+  })
+}
+
+// 获取字典选择框列表
+export function optionselect() {
+  return request({
+    url: '/system/dict/type/optionselect',
+    method: 'get'
+  })
+}

+ 60 - 0
src/api/system/menu.js

@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询菜单列表
+export function listMenu(query) {
+  return request({
+    url: '/system/menu/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询菜单详细
+export function getMenu(menuId) {
+  return request({
+    url: '/system/menu/' + menuId,
+    method: 'get'
+  })
+}
+
+// 查询菜单下拉树结构
+export function treeselect() {
+  return request({
+    url: '/system/menu/treeselect',
+    method: 'get'
+  })
+}
+
+// 根据角色ID查询菜单下拉树结构
+export function roleMenuTreeselect(roleId) {
+  return request({
+    url: '/system/menu/roleMenuTreeselect/' + roleId,
+    method: 'get'
+  })
+}
+
+// 新增菜单
+export function addMenu(data) {
+  return request({
+    url: '/system/menu',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改菜单
+export function updateMenu(data) {
+  return request({
+    url: '/system/menu',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除菜单
+export function delMenu(menuId) {
+  return request({
+    url: '/system/menu/' + menuId,
+    method: 'delete'
+  })
+}

+ 44 - 0
src/api/system/notice.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询公告列表
+export function listNotice(query) {
+  return request({
+    url: '/system/notice/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询公告详细
+export function getNotice(noticeId) {
+  return request({
+    url: '/system/notice/' + noticeId,
+    method: 'get'
+  })
+}
+
+// 新增公告
+export function addNotice(data) {
+  return request({
+    url: '/system/notice',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改公告
+export function updateNotice(data) {
+  return request({
+    url: '/system/notice',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除公告
+export function delNotice(noticeId) {
+  return request({
+    url: '/system/notice/' + noticeId,
+    method: 'delete'
+  })
+}

+ 44 - 0
src/api/system/post.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询岗位列表
+export function listPost(query) {
+  return request({
+    url: '/system/post/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询岗位详细
+export function getPost(postId) {
+  return request({
+    url: '/system/post/' + postId,
+    method: 'get'
+  })
+}
+
+// 新增岗位
+export function addPost(data) {
+  return request({
+    url: '/system/post',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改岗位
+export function updatePost(data) {
+  return request({
+    url: '/system/post',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除岗位
+export function delPost(postId) {
+  return request({
+    url: '/system/post/' + postId,
+    method: 'delete'
+  })
+}

+ 119 - 0
src/api/system/role.js

@@ -0,0 +1,119 @@
+import request from '@/utils/request'
+
+// 查询角色列表
+export function listRole(query) {
+  return request({
+    url: '/system/role/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询角色详细
+export function getRole(roleId) {
+  return request({
+    url: '/system/role/' + roleId,
+    method: 'get'
+  })
+}
+
+// 新增角色
+export function addRole(data) {
+  return request({
+    url: '/system/role',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改角色
+export function updateRole(data) {
+  return request({
+    url: '/system/role',
+    method: 'put',
+    data: data
+  })
+}
+
+// 角色数据权限
+export function dataScope(data) {
+  return request({
+    url: '/system/role/dataScope',
+    method: 'put',
+    data: data
+  })
+}
+
+// 角色状态修改
+export function changeRoleStatus(roleId, status) {
+  const data = {
+    roleId,
+    status
+  }
+  return request({
+    url: '/system/role/changeStatus',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除角色
+export function delRole(roleId) {
+  return request({
+    url: '/system/role/' + roleId,
+    method: 'delete'
+  })
+}
+
+// 查询角色已授权用户列表
+export function allocatedUserList(query) {
+  return request({
+    url: '/system/role/authUser/allocatedList',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询角色未授权用户列表
+export function unallocatedUserList(query) {
+  return request({
+    url: '/system/role/authUser/unallocatedList',
+    method: 'get',
+    params: query
+  })
+}
+
+// 取消用户授权角色
+export function authUserCancel(data) {
+  return request({
+    url: '/system/role/authUser/cancel',
+    method: 'put',
+    data: data
+  })
+}
+
+// 批量取消用户授权角色
+export function authUserCancelAll(data) {
+  return request({
+    url: '/system/role/authUser/cancelAll',
+    method: 'put',
+    params: data
+  })
+}
+
+// 授权用户选择
+export function authUserSelectAll(data) {
+  return request({
+    url: '/system/role/authUser/selectAll',
+    method: 'put',
+    params: data
+  })
+}
+
+// 根据角色ID查询部门树结构
+export function deptTreeSelect(roleId) {
+  return request({
+    url: '/system/role/deptTree/' + roleId,
+    method: 'get'
+  })
+}

+ 135 - 0
src/api/system/user.js

@@ -0,0 +1,135 @@
+import request from '@/utils/request'
+import { parseStrEmpty } from "@/utils/ruoyi";
+
+// 查询用户列表
+export function listUser(query) {
+  return request({
+    url: '/system/user/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询用户详细
+export function getUser(userId) {
+  return request({
+    url: '/system/user/' + parseStrEmpty(userId),
+    method: 'get'
+  })
+}
+
+// 新增用户
+export function addUser(data) {
+  return request({
+    url: '/system/user',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改用户
+export function updateUser(data) {
+  return request({
+    url: '/system/user',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除用户
+export function delUser(userId) {
+  return request({
+    url: '/system/user/' + userId,
+    method: 'delete'
+  })
+}
+
+// 用户密码重置
+export function resetUserPwd(userId, password) {
+  const data = {
+    userId,
+    password
+  }
+  return request({
+    url: '/system/user/resetPwd',
+    method: 'put',
+    data: data
+  })
+}
+
+// 用户状态修改
+export function changeUserStatus(userId, status) {
+  const data = {
+    userId,
+    status
+  }
+  return request({
+    url: '/system/user/changeStatus',
+    method: 'put',
+    data: data
+  })
+}
+
+// 查询用户个人信息
+export function getUserProfile() {
+  return request({
+    url: '/system/user/profile',
+    method: 'get'
+  })
+}
+
+// 修改用户个人信息
+export function updateUserProfile(data) {
+  return request({
+    url: '/system/user/profile',
+    method: 'put',
+    data: data
+  })
+}
+
+// 用户密码重置
+export function updateUserPwd(oldPassword, newPassword) {
+  const data = {
+    oldPassword,
+    newPassword
+  }
+  return request({
+    url: '/system/user/profile/updatePwd',
+    method: 'put',
+    params: data
+  })
+}
+
+// 用户头像上传
+export function uploadAvatar(data) {
+  return request({
+    url: '/system/user/profile/avatar',
+    method: 'post',
+    data: data
+  })
+}
+
+// 查询授权角色
+export function getAuthRole(userId) {
+  return request({
+    url: '/system/user/authRole/' + userId,
+    method: 'get'
+  })
+}
+
+// 保存授权角色
+export function updateAuthRole(data) {
+  return request({
+    url: '/system/user/authRole',
+    method: 'put',
+    params: data
+  })
+}
+
+// 查询部门下拉树结构
+export function deptTreeSelect() {
+  return request({
+    url: '/system/user/deptTree',
+    method: 'get'
+  })
+}

+ 76 - 0
src/api/tool/gen.js

@@ -0,0 +1,76 @@
+import request from '@/utils/request'
+
+// 查询生成表数据
+export function listTable(query) {
+  return request({
+    url: '/tool/gen/list',
+    method: 'get',
+    params: query
+  })
+}
+// 查询db数据库列表
+export function listDbTable(query) {
+  return request({
+    url: '/tool/gen/db/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询表详细信息
+export function getGenTable(tableId) {
+  return request({
+    url: '/tool/gen/' + tableId,
+    method: 'get'
+  })
+}
+
+// 修改代码生成信息
+export function updateGenTable(data) {
+  return request({
+    url: '/tool/gen',
+    method: 'put',
+    data: data
+  })
+}
+
+// 导入表
+export function importTable(data) {
+  return request({
+    url: '/tool/gen/importTable',
+    method: 'post',
+    params: data
+  })
+}
+
+// 预览生成代码
+export function previewTable(tableId) {
+  return request({
+    url: '/tool/gen/preview/' + tableId,
+    method: 'get'
+  })
+}
+
+// 删除表数据
+export function delTable(tableId) {
+  return request({
+    url: '/tool/gen/' + tableId,
+    method: 'delete'
+  })
+}
+
+// 生成代码(自定义路径)
+export function genCode(tableName) {
+  return request({
+    url: '/tool/gen/genCode/' + tableName,
+    method: 'get'
+  })
+}
+
+// 同步数据库
+export function synchDb(tableName) {
+  return request({
+    url: '/tool/gen/synchDb/' + tableName,
+    method: 'get'
+  })
+}

+ 99 - 0
src/api/vote/index.js

@@ -0,0 +1,99 @@
+
+import request from '@/utils/request'
+
+// 新增
+export function voteAdd(data) {
+  return request({
+    url: `/vote/activity`,
+    method: 'post',
+    data
+  })
+}
+
+// 删除
+export function voteDel(data) {
+  return request({
+      url: `/vote/activity`,
+      method: 'delete',
+      data: data
+  })
+}
+
+// 修改
+export function voteUpdate(data) {
+  return request({
+    url: `/vote/activity/${data.activityId}`,
+    method: 'put',
+    data: data
+  })
+}
+
+// 查询List
+export function voteQuery(query) {
+  return request({
+    url: `/vote/activity/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询详情
+export function voteFetch(id) {
+  return request({
+    url: `/vote/activity/${id}`,
+    method: 'get'
+  })
+}
+
+// 审核列表
+export function enlistsList(query) {
+  return request({
+    url: `/vote/enlists/list`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 审核详情
+export function enlistsInfo(enlistId) {
+  return request({
+    url: `/vote/enlists/${enlistId}`,
+    method: 'get'
+  })
+}
+
+// 审核
+export function enlistsReview(data) {
+  return request({
+    url: `/vote/enlists/review/${data.enlistsId}`,
+    method: 'post',
+    data
+  })
+}
+
+// 统计
+export function rankings(query) {
+  return request({
+    url: `/vote/enlists/rankings/${query.activityId}`,
+    method: 'get',
+    params: query
+  })
+}
+
+// 增加报名
+export function enlistsAdd(data) {
+  return request({
+    url: `/vote/enlists`,
+    method: 'post',
+    data
+  })
+}
+
+// 修改报名
+export function enlistsUpdata(data) {
+  return request({
+    url: `/vote/enlists/${data.enlistsId}`,
+    method: 'put',
+    data
+  })
+}

二进制
src/assets/401_images/401.gif


二进制
src/assets/404_images/404.png


二进制
src/assets/404_images/404_cloud.png


+ 9 - 0
src/assets/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
src/assets/icons/svg/404.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/bug.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/build.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/button.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/cascader.svg


+ 1 - 0
src/assets/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
src/assets/icons/svg/checkbox.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/clipboard.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/code.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/color.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/component.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/dashboard.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/date-range.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/date.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/dict.svg


+ 1 - 0
src/assets/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
src/assets/icons/svg/download.svg


+ 1 - 0
src/assets/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
src/assets/icons/svg/druid.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/edit.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/education.svg


+ 1 - 0
src/assets/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
src/assets/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
src/assets/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
src/assets/icons/svg/exit-fullscreen.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/eye-open.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/eye.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/form.svg


+ 1 - 0
src/assets/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
src/assets/icons/svg/github.svg


+ 1 - 0
src/assets/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
src/assets/icons/svg/icon.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/input.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/international.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/job.svg


文件差异内容过多而无法显示
+ 1 - 0
src/assets/icons/svg/language.svg


+ 1 - 0
src/assets/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
src/assets/icons/svg/list.svg


+ 1 - 0
src/assets/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
src/assets/icons/svg/log.svg


+ 0 - 0
src/assets/icons/svg/logininfor.svg


部分文件因为文件数量过多而无法显示