haiwei-module-admin 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (100) hide show
  1. package/package.json +54 -0
  2. package/src/api/components/account.js +58 -0
  3. package/src/api/components/auditInfo.js +30 -0
  4. package/src/api/components/auth.js +47 -0
  5. package/src/api/components/cache.js +16 -0
  6. package/src/api/components/config.js +34 -0
  7. package/src/api/components/file.js +41 -0
  8. package/src/api/components/log.js +22 -0
  9. package/src/api/components/menu.js +68 -0
  10. package/src/api/components/mime.js +10 -0
  11. package/src/api/components/module.js +18 -0
  12. package/src/api/components/permission.js +25 -0
  13. package/src/api/components/role.js +73 -0
  14. package/src/api/components/tool.js +29 -0
  15. package/src/api/index.js +13 -0
  16. package/src/components/config-admin/index.vue +47 -0
  17. package/src/components/enum-checkbox/index.vue +31 -0
  18. package/src/components/enum-radio/index.vue +31 -0
  19. package/src/components/enum-select/index.vue +31 -0
  20. package/src/components/file-download/index.vue +81 -0
  21. package/src/components/file-img/index.vue +55 -0
  22. package/src/components/file-upload/index.vue +140 -0
  23. package/src/components/file-upload-img/index.vue +263 -0
  24. package/src/components/index.js +10 -0
  25. package/src/components/login-mode-select/index.vue +11 -0
  26. package/src/components/module-select/index.vue +11 -0
  27. package/src/components/platform-select/index.vue +28 -0
  28. package/src/components/role-select/index.vue +11 -0
  29. package/src/components/upload-mixins.js +127 -0
  30. package/src/config/index.js +18 -0
  31. package/src/index.js +69 -0
  32. package/src/main.js +5 -0
  33. package/src/module.js +10 -0
  34. package/src/routes/index.js +3 -0
  35. package/src/store/index.js +4 -0
  36. package/src/views/account/components/save/index.vue +65 -0
  37. package/src/views/account/index/cols.js +50 -0
  38. package/src/views/account/index/index.vue +127 -0
  39. package/src/views/account/index/page.js +57 -0
  40. package/src/views/auditInfo/components/details/index.vue +64 -0
  41. package/src/views/auditInfo/index/cols.js +63 -0
  42. package/src/views/auditInfo/index/index.vue +118 -0
  43. package/src/views/auditInfo/index/page.js +34 -0
  44. package/src/views/button/permission-bind/index.vue +50 -0
  45. package/src/views/cache/index/cols.js +10 -0
  46. package/src/views/cache/index/index.vue +64 -0
  47. package/src/views/cache/index/page.js +29 -0
  48. package/src/views/config/index.vue +43 -0
  49. package/src/views/config/library/components/auth/index.vue +165 -0
  50. package/src/views/config/library/components/component/index.vue +149 -0
  51. package/src/views/config/library/components/path/index.vue +45 -0
  52. package/src/views/config/library/components/quartz/index.vue +66 -0
  53. package/src/views/config/library/components/system/index.vue +58 -0
  54. package/src/views/config/library/form-mixins.js +25 -0
  55. package/src/views/config/library/index.vue +76 -0
  56. package/src/views/config/module/index.vue +64 -0
  57. package/src/views/config/page.js +21 -0
  58. package/src/views/file/index/cols.js +53 -0
  59. package/src/views/file/index/index.vue +52 -0
  60. package/src/views/file/index/page.js +42 -0
  61. package/src/views/home/components/bottom/index.vue +217 -0
  62. package/src/views/home/components/top-left/index.vue +43 -0
  63. package/src/views/home/components/top-right/index.vue +148 -0
  64. package/src/views/home/index.vue +27 -0
  65. package/src/views/home/page.js +15 -0
  66. package/src/views/icon/index.vue +92 -0
  67. package/src/views/icon/page.js +15 -0
  68. package/src/views/log/login-log/cols.js +43 -0
  69. package/src/views/log/login-log/index.vue +86 -0
  70. package/src/views/log/login-log/page.js +27 -0
  71. package/src/views/menu/components/add/components/link/index.vue +106 -0
  72. package/src/views/menu/components/add/components/mixins.js +83 -0
  73. package/src/views/menu/components/add/components/node/index.vue +53 -0
  74. package/src/views/menu/components/add/components/route/index.vue +122 -0
  75. package/src/views/menu/components/add/index.vue +86 -0
  76. package/src/views/menu/components/edit/components/link/index.vue +106 -0
  77. package/src/views/menu/components/edit/components/mixins.js +80 -0
  78. package/src/views/menu/components/edit/components/node/index.vue +53 -0
  79. package/src/views/menu/components/edit/components/route/index.vue +122 -0
  80. package/src/views/menu/components/edit/index.vue +95 -0
  81. package/src/views/menu/components/tree/index.vue +153 -0
  82. package/src/views/menu/index/cols.js +46 -0
  83. package/src/views/menu/index/index.vue +175 -0
  84. package/src/views/menu/index/page.js +48 -0
  85. package/src/views/mime/components/save/index.vue +45 -0
  86. package/src/views/mime/index/cols.js +16 -0
  87. package/src/views/mime/index/index.vue +55 -0
  88. package/src/views/mime/index/page.js +42 -0
  89. package/src/views/module/components/page-list/index.vue +234 -0
  90. package/src/views/module/components/permission-list/cols.js +36 -0
  91. package/src/views/module/components/permission-list/index.vue +90 -0
  92. package/src/views/module/index/index.vue +226 -0
  93. package/src/views/module/index/page.js +21 -0
  94. package/src/views/role/components/menu-bind/index.vue +85 -0
  95. package/src/views/role/components/page-bind/index.vue +221 -0
  96. package/src/views/role/components/platform-bind/index.vue +105 -0
  97. package/src/views/role/components/save/index.vue +45 -0
  98. package/src/views/role/components/tree/index.vue +112 -0
  99. package/src/views/role/index/index.vue +67 -0
  100. package/src/views/role/index/page.js +64 -0
@@ -0,0 +1,45 @@
1
+ <template>
2
+ <nm-form-page v-bind="form">
3
+ <el-row>
4
+ <el-col :span="22">
5
+ <el-form-item labelWidth="200px" prop="uploadPath">
6
+ <template v-slot:label>
7
+ <el-tooltip effect="dark" content="默认是应用根目录下的Upload目录" placement="top">
8
+ <nm-icon class="nm-size-20 nm-text-warning" name="warning" />
9
+ </el-tooltip>
10
+ 文件上传存储根路径:
11
+ </template>
12
+ <el-input v-model="form.model.uploadPath" />
13
+ </el-form-item>
14
+ </el-col>
15
+ <el-col :span="22">
16
+ <el-form-item labelWidth="200px" prop="tempPath">
17
+ <template v-slot:label>
18
+ <el-tooltip effect="dark" content="默认是应用根目录下的Temp目录" placement="top">
19
+ <nm-icon class="nm-size-20 nm-text-warning" name="warning" />
20
+ </el-tooltip>
21
+ 临时文件存储根路径:
22
+ </template>
23
+ <el-input v-model="form.model.tempPath" />
24
+ </el-form-item>
25
+ </el-col>
26
+ </el-row>
27
+ </nm-form-page>
28
+ </template>
29
+ <script>
30
+ import mixins from '../../form-mixins'
31
+ export default {
32
+ mixins: [mixins],
33
+ data() {
34
+ return {
35
+ code: 'Path',
36
+ form: {
37
+ model: {
38
+ uploadPath: '',
39
+ tempPath: ''
40
+ }
41
+ }
42
+ }
43
+ }
44
+ }
45
+ </script>
@@ -0,0 +1,66 @@
1
+ <template>
2
+ <nm-form-page v-bind="form">
3
+ <el-row>
4
+ <el-col :span="10" :offset="1">
5
+ <el-form-item label="开启:" prop="enabled">
6
+ <el-switch v-model="form.model.enabled" />
7
+ </el-form-item>
8
+ </el-col>
9
+ <el-col :span="10">
10
+ <el-form-item label="日志:" prop="logger">
11
+ <el-switch v-model="form.model.logger" />
12
+ </el-form-item>
13
+ </el-col>
14
+ </el-row>
15
+ <el-row>
16
+ <el-col :span="10" :offset="1">
17
+ <el-form-item label="实例名称:" prop="instanceName">
18
+ <el-input v-model="form.model.instanceName" />
19
+ </el-form-item>
20
+ </el-col>
21
+ <el-col :span="10">
22
+ <el-form-item label="表前缀:" prop="tablePrefix">
23
+ <el-input v-model="form.model.tablePrefix" />
24
+ </el-form-item>
25
+ </el-col>
26
+ </el-row>
27
+ <el-divider content-position="center"><span class="nm-text-warning">Quartz的数据库配置与任务调度模块保持一致</span></el-divider>
28
+ <el-row>
29
+ <el-col :span="10" :offset="1">
30
+ <el-form-item label="数据库类型:">
31
+ <el-select disabled v-model="form.model.provider">
32
+ <el-option label="SqlServer" :value="0"> </el-option>
33
+ <el-option label="MySql" :value="1"> </el-option>
34
+ <el-option label="SQLite" :value="2"> </el-option>
35
+ <el-option label="Oracle" :value="3"> </el-option>
36
+ <el-option label="PostgreSQL" :value="4"> </el-option>
37
+ </el-select>
38
+ </el-form-item>
39
+ </el-col>
40
+ </el-row>
41
+ </nm-form-page>
42
+ </template>
43
+ <script>
44
+ import mixins from '../../form-mixins'
45
+ export default {
46
+ mixins: [mixins],
47
+ data() {
48
+ return {
49
+ code: 'Quartz',
50
+ form: {
51
+ labelWidth: '200px',
52
+ model: {
53
+ enabled: false,
54
+ logger: false,
55
+ instanceName: '',
56
+ tablePrefix: '',
57
+ provider: 0
58
+ },
59
+ rules: {
60
+ instanceName: [{ required: true, message: '实例名称不能为空' }]
61
+ }
62
+ }
63
+ }
64
+ }
65
+ }
66
+ </script>
@@ -0,0 +1,58 @@
1
+ <template>
2
+ <nm-form-page v-bind="form" @success="onSuccess">
3
+ <el-row>
4
+ <el-col :span="13" :offset="1">
5
+ <el-form-item label="标题:" prop="title">
6
+ <el-input v-model="form.model.title" />
7
+ </el-form-item>
8
+ <el-form-item label="版权申明:" prop="copyright">
9
+ <el-input v-model="form.model.copyright" placeholder="版权所有:XXXXXX" />
10
+ </el-form-item>
11
+ </el-col>
12
+ <el-col :span="7">
13
+ <el-form-item label="Logo:" prop="logo">
14
+ <nm-file-upload-img v-model="form.model.logo" module="Admin" group="Logo" :access-mode="1" width="75px" height="75px" no-text icon-size="3em" @success="onSuccess" />
15
+ </el-form-item>
16
+ </el-col>
17
+ </el-row>
18
+ <el-row>
19
+ <el-col :span="13" :offset="1">
20
+ <el-form-item label="账户信息页:" prop="userPage">
21
+ <el-input v-model="form.model.userPage" placeholder="请填写前端路由名称,默认使用系统自带的userinfo" />
22
+ </el-form-item>
23
+ </el-col>
24
+ </el-row>
25
+ </nm-form-page>
26
+ </template>
27
+ <script>
28
+ import mixins from '../../form-mixins'
29
+ export default {
30
+ mixins: [mixins],
31
+ data() {
32
+ return {
33
+ code: 'System',
34
+ form: {
35
+ model: {
36
+ title: '',
37
+ logo: '',
38
+ copyright: '',
39
+ userPage: ''
40
+ }
41
+ }
42
+ }
43
+ },
44
+ methods: {
45
+ onSuccess(data) {
46
+ const { title, copyright, userPage } = this.form.model
47
+ this.setUIConfig({
48
+ system: {
49
+ title,
50
+ logo: data.url,
51
+ copyright,
52
+ userPage
53
+ }
54
+ })
55
+ }
56
+ }
57
+ }
58
+ </script>
@@ -0,0 +1,25 @@
1
+ import { mapMutations } from 'vuex'
2
+ const { edit, update } = $api.admin.config
3
+ export default {
4
+ data() {
5
+ return {
6
+ type: 0,
7
+ code: '',
8
+ form: {
9
+ header: false,
10
+ action: this.update
11
+ }
12
+ }
13
+ },
14
+ methods: {
15
+ ...mapMutations('app/config', { setUIConfig: 'init' }),
16
+ update() {
17
+ return update({ type: this.type, code: this.code, json: JSON.stringify(this.form.model) })
18
+ }
19
+ },
20
+ created() {
21
+ edit({ type: this.type, code: this.code }).then(data => {
22
+ this.form.model = data
23
+ })
24
+ }
25
+ }
@@ -0,0 +1,76 @@
1
+ <template>
2
+ <el-tabs class="nm-admin-config-library page" v-model="tab" tab-position="left" type="border-card">
3
+ <!--系统信息-->
4
+ <el-tab-pane name="system">
5
+ <span slot="label"> <nm-icon name="system"></nm-icon>系统信息 </span>
6
+ <system-config />
7
+ </el-tab-pane>
8
+ <!--前端组件-->
9
+ <el-tab-pane name="component" lazy>
10
+ <span slot="label"> <nm-icon name="table"></nm-icon>前端组件 </span>
11
+ <component-config />
12
+ </el-tab-pane>
13
+ <!--通用路径-->
14
+ <el-tab-pane name="path" lazy>
15
+ <span slot="label"> <nm-icon name="attachment"></nm-icon>通用路径 </span>
16
+ <path-config />
17
+ </el-tab-pane>
18
+ <!--认证授权-->
19
+ <el-tab-pane name="auth" lazy>
20
+ <span slot="label"> <nm-icon name="verifycode"></nm-icon>认证授权 </span>
21
+ <auth-config />
22
+ </el-tab-pane>
23
+ <!--Quartz-->
24
+ <el-tab-pane v-if="hasQuartz" name="quartz" lazy>
25
+ <span slot="label"> <nm-icon name="timer"></nm-icon>Quartz </span>
26
+ <quartz-config />
27
+ </el-tab-pane>
28
+ </el-tabs>
29
+ </template>
30
+ <script>
31
+ import SystemConfig from './components/system'
32
+ import ComponentConfig from './components/component'
33
+ import PathConfig from './components/path'
34
+ import AuthConfig from './components/auth'
35
+ import QuartzConfig from './components/quartz'
36
+ export default {
37
+ components: { SystemConfig, ComponentConfig, PathConfig, AuthConfig, QuartzConfig },
38
+ data() {
39
+ return {
40
+ tab: 'system'
41
+ }
42
+ },
43
+ props: {
44
+ descriptors: Array
45
+ },
46
+ computed: {
47
+ hasQuartz() {
48
+ return this.has('Quartz')
49
+ }
50
+ },
51
+ methods: {
52
+ has(code) {
53
+ return this.descriptors.findIndex(m => m.code.toLowerCase() === code.toLowerCase()) > -1
54
+ }
55
+ }
56
+ }
57
+ </script>
58
+ <style lang="scss">
59
+ .nm-admin-config-library {
60
+ .el-tabs__header {
61
+ margin-right: 0 !important;
62
+ }
63
+ .el-tabs__item {
64
+ text-align: left !important;
65
+
66
+ &.is-active {
67
+ color: #67c23a !important;
68
+ }
69
+ }
70
+ .el-tabs__content {
71
+ .nm-box {
72
+ border-left: none !important;
73
+ }
74
+ }
75
+ }
76
+ </style>
@@ -0,0 +1,64 @@
1
+ <template>
2
+ <el-tabs class="nm-admin-config-module page" v-model="tab" tab-position="left" type="border-card">
3
+ <el-tab-pane v-for="item in modules" :key="item.name" :name="item.name" lazy>
4
+ <span slot="label"><nm-icon :name="item.icon"></nm-icon>{{ getNo(item) }}_{{ item.label }} </span>
5
+ <component :is="item.name"></component>
6
+ </el-tab-pane>
7
+ </el-tabs>
8
+ </template>
9
+ <script>
10
+ import { mapState } from 'vuex'
11
+ const { select } = $api.admin.module
12
+ export default {
13
+ data() {
14
+ return {
15
+ tab: '',
16
+ modules: []
17
+ }
18
+ },
19
+ computed: {
20
+ ...mapState('app/system', ['globalComponents'])
21
+ },
22
+ methods: {
23
+ getNo(item) {
24
+ return item.id < 10 ? '0' + item.id : '' + item.id
25
+ }
26
+ },
27
+ created() {
28
+ select().then(data => {
29
+ data.forEach(m => {
30
+ let module = {
31
+ id: m.data.id,
32
+ label: m.label,
33
+ name: `nm-config-${m.value.toLowerCase()}`,
34
+ icon: m.data.icon
35
+ }
36
+ if (this.globalComponents.includes(module.name)) {
37
+ this.modules.push(module)
38
+ }
39
+ })
40
+ if (this.modules.length > 0) this.tab = this.modules[0].name
41
+ })
42
+ }
43
+ }
44
+ </script>
45
+
46
+ <style lang="scss">
47
+ .nm-admin-config-module {
48
+ .el-tabs__header {
49
+ margin-right: 0 !important;
50
+ }
51
+ .el-tabs__item {
52
+ text-align: left !important;
53
+
54
+ &.is-active {
55
+ color: #67c23a !important;
56
+ }
57
+ }
58
+ .el-tabs__content {
59
+ .nm-box {
60
+ border-left: none !important;
61
+ }
62
+ }
63
+ }
64
+ </style>
@@ -0,0 +1,21 @@
1
+ /** 页面信息 */
2
+ const page = new (function() {
3
+ this.title = '配置中心'
4
+ this.icon = 'tools'
5
+ this.name = 'admin_config'
6
+ this.path = '/admin/config'
7
+
8
+ // 关联权限
9
+ this.permissions = [`${this.name}_edit_get`, `${this.name}_update_post`, `${this.name}_UploadLogo_post`, `${this.name}_LogoUrl_get`, `${this.name}_Descriptors_get`]
10
+
11
+ // 按钮
12
+ this.buttons = {}
13
+ })()
14
+
15
+ /** 路由信息 */
16
+ export const route = {
17
+ page,
18
+ component: () => import(/* webpackChunkName: "admin.config" */ './index')
19
+ }
20
+
21
+ export default page
@@ -0,0 +1,53 @@
1
+ export default [
2
+ {
3
+ name: 'id',
4
+ label: '编号',
5
+ width: 0,
6
+ show: false
7
+ },
8
+ {
9
+ name: 'moduleName',
10
+ label: '模块',
11
+ width: '100'
12
+ },
13
+ {
14
+ name: 'group',
15
+ label: '分组',
16
+ width: '100'
17
+ },
18
+ {
19
+ name: 'saveId',
20
+ label: '存储编号',
21
+ width: '240'
22
+ },
23
+ {
24
+ name: 'fileName',
25
+ label: '文件名'
26
+ },
27
+ {
28
+ name: 'ext',
29
+ label: '扩展名'
30
+ },
31
+ {
32
+ name: 'sizeName',
33
+ label: '大小'
34
+ },
35
+ {
36
+ name: 'fullPath',
37
+ label: '路径'
38
+ },
39
+ {
40
+ name: 'accessModeName',
41
+ label: '访问方式'
42
+ },
43
+ {
44
+ name: 'mime',
45
+ label: 'MIME',
46
+ show: false
47
+ },
48
+ {
49
+ name: 'md5',
50
+ label: 'MD5',
51
+ show: false
52
+ }
53
+ ]
@@ -0,0 +1,52 @@
1
+ <template>
2
+ <nm-container>
3
+ <nm-list ref="list" v-bind="list">
4
+ <!--查询条件-->
5
+ <template v-slot:querybar>
6
+ <el-form-item label="模块:" prop="moduleCode">
7
+ <nm-module-select v-model="list.model.moduleCode" clearable />
8
+ </el-form-item>
9
+ <el-form-item label="文件名:" prop="fileName">
10
+ <el-input v-model="list.model.fileName" clearable />
11
+ </el-form-item>
12
+ </template>
13
+
14
+ <!--操作列-->
15
+ <template v-slot:col-operation="{ row }">
16
+ <nm-file-download v-bind="buttons.export" :url="row.url" :private="row.accessMode !== 1" @success="refresh" />
17
+ <nm-button-delete v-bind="buttons.del" :id="row.id" :action="removeAction" @success="refresh" />
18
+ <nm-button-delete v-bind="buttons.hardDel" :id="row.id" :action="hardRemoveAction" @success="refresh" />
19
+ </template>
20
+ </nm-list>
21
+ </nm-container>
22
+ </template>
23
+ <script>
24
+ import { mixins } from 'netmodular-ui'
25
+ import page from './page'
26
+ import cols from './cols'
27
+
28
+ // 接口
29
+ const api = $api.admin.file
30
+
31
+ export default {
32
+ name: page.name,
33
+ mixins: [mixins.list],
34
+ data() {
35
+ return {
36
+ list: {
37
+ title: page.title,
38
+ cols,
39
+ action: api.query,
40
+ operationWidth: '200',
41
+ model: {
42
+ moduleCode: '',
43
+ fileName: ''
44
+ }
45
+ },
46
+ removeAction: api.remove,
47
+ hardRemoveAction: api.hardDelete,
48
+ buttons: page.buttons
49
+ }
50
+ }
51
+ }
52
+ </script>
@@ -0,0 +1,42 @@
1
+ /** 页面信息 */
2
+ const page = new (function() {
3
+ this.title = '文件管理'
4
+ this.icon = 'attachment'
5
+ this.name = 'admin_file'
6
+ this.path = '/admin/file'
7
+
8
+ // 关联权限
9
+ this.permissions = [`${this.name}_query_get`]
10
+
11
+ this.buttons = {
12
+ export: {
13
+ text: '导出',
14
+ type: 'text',
15
+ icon: 'export',
16
+ code: `${this.name}_export`,
17
+ permissions: [`${this.name}_export_get`]
18
+ },
19
+ del: {
20
+ text: '删除',
21
+ type: 'text',
22
+ icon: 'delete',
23
+ code: `${this.name}_del`,
24
+ permissions: [`${this.name}_delete_delete`]
25
+ },
26
+ hardDel: {
27
+ text: '物理删除',
28
+ type: 'text',
29
+ icon: 'delete',
30
+ code: `${this.name}_harddel`,
31
+ permissions: [`${this.name}_hardDelete_delete`]
32
+ }
33
+ }
34
+ })()
35
+
36
+ /** 路由信息 */
37
+ export const route = {
38
+ page,
39
+ component: () => import(/* webpackChunkName: "Admin.File" */ './index')
40
+ }
41
+
42
+ export default page