@jiangood/open-admin 1.0.0-beta.5

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 (186) hide show
  1. package/config/common-plugin.js +94 -0
  2. package/config/config.js +58 -0
  3. package/config/utils.js +73 -0
  4. package/package.json +42 -0
  5. package/src/.umi-production/appData.json +2365 -0
  6. package/src/.umi-production/core/EmptyRoute.tsx +9 -0
  7. package/src/.umi-production/core/defineApp.ts +16 -0
  8. package/src/.umi-production/core/helmet.ts +10 -0
  9. package/src/.umi-production/core/helmetContext.ts +4 -0
  10. package/src/.umi-production/core/history.ts +72 -0
  11. package/src/.umi-production/core/historyIntelli.ts +132 -0
  12. package/src/.umi-production/core/plugin.ts +40 -0
  13. package/src/.umi-production/core/pluginConfig.ts +324 -0
  14. package/src/.umi-production/core/pluginConfigJoi.d.ts +7 -0
  15. package/src/.umi-production/core/polyfill.ts +220 -0
  16. package/src/.umi-production/core/route.tsx +54 -0
  17. package/src/.umi-production/core/routeProps.js +5 -0
  18. package/src/.umi-production/core/routeProps.ts +6 -0
  19. package/src/.umi-production/core/terminal.ts +37 -0
  20. package/src/.umi-production/exports.ts +17 -0
  21. package/src/.umi-production/testBrowser.tsx +90 -0
  22. package/src/.umi-production/tsconfig.json +44 -0
  23. package/src/.umi-production/typings.d.ts +136 -0
  24. package/src/.umi-production/umi.ts +83 -0
  25. package/src/framework/components/DownloadFileButton/index.d.ts +11 -0
  26. package/src/framework/components/DownloadFileButton/index.jsx +33 -0
  27. package/src/framework/components/Gap/index.d.ts +23 -0
  28. package/src/framework/components/Gap/index.jsx +46 -0
  29. package/src/framework/components/LinkButton/index.d.ts +14 -0
  30. package/src/framework/components/LinkButton/index.jsx +10 -0
  31. package/src/framework/components/NamedIcon/index.d.ts +5 -0
  32. package/src/framework/components/NamedIcon/index.jsx +11 -0
  33. package/src/framework/components/OrgTree/index.d.ts +4 -0
  34. package/src/framework/components/OrgTree/index.jsx +58 -0
  35. package/src/framework/components/Page/index.d.ts +17 -0
  36. package/src/framework/components/Page/index.jsx +30 -0
  37. package/src/framework/components/Page/index.less +10 -0
  38. package/src/framework/components/PageLoading/index.d.ts +1 -0
  39. package/src/framework/components/PageLoading/index.jsx +25 -0
  40. package/src/framework/components/ProModal/index.tsx +66 -0
  41. package/src/framework/components/ProTable/components/ToolBar/index.jsx +123 -0
  42. package/src/framework/components/ProTable/components/ToolBar/index.less +53 -0
  43. package/src/framework/components/ProTable/index.d.ts +42 -0
  44. package/src/framework/components/ProTable/index.jsx +260 -0
  45. package/src/framework/components/ProTable/index.less +14 -0
  46. package/src/framework/components/ProTable/utils/index.js +43 -0
  47. package/src/framework/components/RoleTree/index.d.ts +4 -0
  48. package/src/framework/components/RoleTree/index.jsx +50 -0
  49. package/src/framework/components/ValueType/index.jsx +34 -0
  50. package/src/framework/components/ValueType/registry.jsx +26 -0
  51. package/src/framework/components/ViewRange/index.d.ts +14 -0
  52. package/src/framework/components/ViewRange/index.jsx +20 -0
  53. package/src/framework/components/index.ts +13 -0
  54. package/src/framework/components/system/ButtonList.d.ts +8 -0
  55. package/src/framework/components/system/ButtonList.jsx +42 -0
  56. package/src/framework/components/system/HasPerm.tsx +14 -0
  57. package/src/framework/components/system/index.tsx +29 -0
  58. package/src/framework/fields/FieldBoolean/index.d.ts +9 -0
  59. package/src/framework/fields/FieldBoolean/index.jsx +73 -0
  60. package/src/framework/fields/FieldDate/index.d.ts +23 -0
  61. package/src/framework/fields/FieldDate/index.jsx +116 -0
  62. package/src/framework/fields/FieldDateRange/index.d.ts +22 -0
  63. package/src/framework/fields/FieldDateRange/index.jsx +103 -0
  64. package/src/framework/fields/FieldDictSelect/index.d.ts +12 -0
  65. package/src/framework/fields/FieldDictSelect/index.jsx +16 -0
  66. package/src/framework/fields/FieldEditor/index.d.ts +14 -0
  67. package/src/framework/fields/FieldEditor/index.jsx +59 -0
  68. package/src/framework/fields/FieldNumberRange/index.d.ts +10 -0
  69. package/src/framework/fields/FieldNumberRange/index.jsx +55 -0
  70. package/src/framework/fields/FieldPercent/index.d.ts +8 -0
  71. package/src/framework/fields/FieldPercent/index.jsx +30 -0
  72. package/src/framework/fields/FieldRemoteSelect/index.d.ts +44 -0
  73. package/src/framework/fields/FieldRemoteSelect/index.jsx +125 -0
  74. package/src/framework/fields/FieldRemoteSelectMultiple/index.d.ts +20 -0
  75. package/src/framework/fields/FieldRemoteSelectMultiple/index.jsx +85 -0
  76. package/src/framework/fields/FieldRemoteSelectMultipleInline/index.d.ts +21 -0
  77. package/src/framework/fields/FieldRemoteSelectMultipleInline/index.jsx +88 -0
  78. package/src/framework/fields/FieldRemoteTree/index.d.ts +20 -0
  79. package/src/framework/fields/FieldRemoteTree/index.jsx +50 -0
  80. package/src/framework/fields/FieldRemoteTreeCascader/index.d.ts +18 -0
  81. package/src/framework/fields/FieldRemoteTreeCascader/index.jsx +59 -0
  82. package/src/framework/fields/FieldRemoteTreeSelect/index.d.ts +19 -0
  83. package/src/framework/fields/FieldRemoteTreeSelect/index.jsx +57 -0
  84. package/src/framework/fields/FieldRemoteTreeSelectMultiple/index.d.ts +20 -0
  85. package/src/framework/fields/FieldRemoteTreeSelectMultiple/index.jsx +62 -0
  86. package/src/framework/fields/FieldSysOrgTree/index.d.ts +9 -0
  87. package/src/framework/fields/FieldSysOrgTree/index.jsx +20 -0
  88. package/src/framework/fields/FieldSysOrgTreeSelect/index.d.ts +9 -0
  89. package/src/framework/fields/FieldSysOrgTreeSelect/index.jsx +22 -0
  90. package/src/framework/fields/FieldTable/index.d.ts +14 -0
  91. package/src/framework/fields/FieldTable/index.jsx +108 -0
  92. package/src/framework/fields/FieldTable/styles.less +29 -0
  93. package/src/framework/fields/FieldTableSelect/index.d.ts +19 -0
  94. package/src/framework/fields/FieldTableSelect/index.jsx +60 -0
  95. package/src/framework/fields/FieldUploadFile/index.d.ts +31 -0
  96. package/src/framework/fields/FieldUploadFile/index.jsx +139 -0
  97. package/src/framework/fields/index.ts +22 -0
  98. package/src/framework/fields/types.ts +16 -0
  99. package/src/framework/index.ts +5 -0
  100. package/src/framework/pages/LoginPage.d.ts +16 -0
  101. package/src/framework/pages/LoginPage.jsx +135 -0
  102. package/src/framework/pages/LoginPage.less +53 -0
  103. package/src/framework/pages/LoginPageUtils.ts +36 -0
  104. package/src/framework/pages/index.ts +2 -0
  105. package/src/framework/utils/ArrUtils.ts +229 -0
  106. package/src/framework/utils/ColorsUtils.ts +378 -0
  107. package/src/framework/utils/DateUtils.ts +187 -0
  108. package/src/framework/utils/DeviceUtils.ts +46 -0
  109. package/src/framework/utils/DomUtils.ts +50 -0
  110. package/src/framework/utils/EventBusUtils.ts +144 -0
  111. package/src/framework/utils/Logger.ts +40 -0
  112. package/src/framework/utils/MessageUtils.tsx +170 -0
  113. package/src/framework/utils/ObjectUtils.ts +118 -0
  114. package/src/framework/utils/StorageUtils.ts +50 -0
  115. package/src/framework/utils/StringUtils.ts +436 -0
  116. package/src/framework/utils/TreeUtils.ts +251 -0
  117. package/src/framework/utils/UrlUtils.ts +152 -0
  118. package/src/framework/utils/UuidUtils.ts +88 -0
  119. package/src/framework/utils/ValidateUtils.ts +28 -0
  120. package/src/framework/utils/index.ts +15 -0
  121. package/src/framework/utils/system/DictUtils.ts +97 -0
  122. package/src/framework/utils/system/FormRegistryUtils.ts +77 -0
  123. package/src/framework/utils/system/HttpUtils.ts +247 -0
  124. package/src/framework/utils/system/PageUtils.ts +163 -0
  125. package/src/framework/utils/system/PermUtils.ts +79 -0
  126. package/src/framework/utils/system/SysUtils.ts +97 -0
  127. package/src/framework/utils/system/ThemeUtils.ts +27 -0
  128. package/src/framework/utils/system/index.ts +7 -0
  129. package/src/framework/views/ViewApproveStatus/index.d.ts +3 -0
  130. package/src/framework/views/ViewApproveStatus/index.jsx +21 -0
  131. package/src/framework/views/ViewBoolean/index.d.ts +3 -0
  132. package/src/framework/views/ViewBoolean/index.jsx +4 -0
  133. package/src/framework/views/ViewBooleanEnableDisable/index.d.ts +5 -0
  134. package/src/framework/views/ViewBooleanEnableDisable/index.jsx +15 -0
  135. package/src/framework/views/ViewFile/index.d.ts +10 -0
  136. package/src/framework/views/ViewFile/index.jsx +49 -0
  137. package/src/framework/views/ViewFileButton/index.d.ts +10 -0
  138. package/src/framework/views/ViewFileButton/index.jsx +22 -0
  139. package/src/framework/views/ViewImage/index.d.ts +6 -0
  140. package/src/framework/views/ViewImage/index.jsx +60 -0
  141. package/src/framework/views/ViewPassword/index.d.ts +5 -0
  142. package/src/framework/views/ViewPassword/index.jsx +24 -0
  143. package/src/framework/views/ViewProcessInstanceProgress/index.d.ts +12 -0
  144. package/src/framework/views/ViewProcessInstanceProgress/index.jsx +97 -0
  145. package/src/framework/views/ViewProcessInstanceProgressButton/index.d.ts +6 -0
  146. package/src/framework/views/ViewProcessInstanceProgressButton/index.jsx +24 -0
  147. package/src/framework/views/ViewText/index.d.ts +16 -0
  148. package/src/framework/views/ViewText/index.jsx +42 -0
  149. package/src/framework/views/index.ts +12 -0
  150. package/src/framework/views/types.ts +26 -0
  151. package/src/index.ts +2 -0
  152. package/src/layouts/PageRender.d.ts +22 -0
  153. package/src/layouts/PageRender.jsx +90 -0
  154. package/src/layouts/admin/HeaderRight.jsx +104 -0
  155. package/src/layouts/admin/TabPageRender.jsx +158 -0
  156. package/src/layouts/admin/index.jsx +159 -0
  157. package/src/layouts/admin/index.less +65 -0
  158. package/src/layouts/index.jsx +187 -0
  159. package/src/layouts/index.less +24 -0
  160. package/src/loading.jsx +18 -0
  161. package/src/pages/404.jsx +13 -0
  162. package/src/pages/about.jsx +12 -0
  163. package/src/pages/index.jsx +10 -0
  164. package/src/pages/login.jsx +16 -0
  165. package/src/pages/system/api/ApiDoc.jsx +148 -0
  166. package/src/pages/system/api/index.jsx +267 -0
  167. package/src/pages/system/api/perm.jsx +69 -0
  168. package/src/pages/system/dict/Dict.jsx +67 -0
  169. package/src/pages/system/dict/DictItem.jsx +175 -0
  170. package/src/pages/system/dict/index.jsx +25 -0
  171. package/src/pages/system/file/index.jsx +147 -0
  172. package/src/pages/system/job/index.jsx +324 -0
  173. package/src/pages/system/log/index.jsx +77 -0
  174. package/src/pages/system/org/index.jsx +260 -0
  175. package/src/pages/system/role/index.jsx +302 -0
  176. package/src/pages/system/role/perm.jsx +107 -0
  177. package/src/pages/system/sysManual/index.jsx +126 -0
  178. package/src/pages/system/user/UserPerm.jsx +94 -0
  179. package/src/pages/system/user/index.jsx +253 -0
  180. package/src/pages/test/views.jsx +95 -0
  181. package/src/pages/ureport/index.jsx +16 -0
  182. package/src/pages/userCenter/ChangePassword.jsx +64 -0
  183. package/src/pages/userCenter/index.jsx +90 -0
  184. package/src/pages/userCenter/manual.jsx +57 -0
  185. package/src/pages/userCenter/message.jsx +103 -0
  186. package/src/style/global.less +51 -0
@@ -0,0 +1,64 @@
1
+ import React from "react";
2
+ import {Button, Form, Input, Modal} from "antd";
3
+
4
+
5
+ import {history} from 'umi'
6
+ import {HttpUtils} from "../../framework";
7
+
8
+ export default class extends React.Component {
9
+
10
+
11
+ onFinish = (values) => {
12
+ HttpUtils.post('admin/userCenter/updatePwd', values).then(() => {
13
+ Modal.success({
14
+ title: '提示',
15
+ content: '修改密码成功',
16
+ onOk: () => {
17
+ SysUtils.setToken(null)
18
+ history.push('/login')
19
+ }
20
+ })
21
+ })
22
+ }
23
+
24
+ validator = (rule, value) => {
25
+ return new Promise((resolve, reject) => {
26
+ HttpUtils.get("admin/sysUser/pwdStrength", {password: value}).then(response => {
27
+ const rs = response.data
28
+ if (!rs.success) {
29
+ reject(rs.message)
30
+ }
31
+ resolve()
32
+ })
33
+ })
34
+
35
+ }
36
+
37
+ render() {
38
+ return <div>
39
+
40
+ <Form onFinish={this.onFinish} style={{maxWidth: 400}}>
41
+
42
+ <Form.Item name='newPassword'
43
+ label='新密码'
44
+ extra={'请输入字母、数字、特殊字符'}
45
+ rules={[
46
+ {required: true},
47
+ {
48
+ validator: this.validator
49
+ }
50
+ ]}
51
+ >
52
+ <Input.Password></Input.Password>
53
+ </Form.Item>
54
+
55
+ <Form.Item wrapperCol={{offset: 5}} style={{marginTop: 40}}>
56
+ <Button type="primary" htmlType="submit">
57
+ 确定
58
+ </Button>
59
+ </Form.Item>
60
+ </Form>
61
+
62
+ </div>
63
+ }
64
+ }
@@ -0,0 +1,90 @@
1
+ import React from "react";
2
+ import {Avatar, Card, Col, Row, Tabs} from "antd";
3
+ import ChangePassword from "./ChangePassword";
4
+ import {HttpUtils, Page} from "../../framework";
5
+
6
+ export default class extends React.Component {
7
+
8
+ state = {
9
+ info: {}
10
+ }
11
+
12
+ componentDidMount() {
13
+ HttpUtils.get('admin/userCenter/info').then(rs => {
14
+ this.setState({info: rs})
15
+ })
16
+ }
17
+
18
+ render() {
19
+ const {info} = this.state;
20
+ return <Page padding backgroundGray>
21
+ <Row gutter={[16, 16]}>
22
+ <Col md={6} sm={24}>
23
+ <Card title='个人信息'>
24
+
25
+ <div className='flex-center' style={{marginBottom: 32}}>
26
+ <Avatar size={128} title='点击修改头像'/>
27
+ </div>
28
+
29
+
30
+ <table className='tmgg-table'>
31
+ <tbody>
32
+ <tr>
33
+ <td>用户名称</td>
34
+ <td align='right'>{info.name}</td>
35
+ </tr>
36
+ <tr>
37
+ <td>账号</td>
38
+ <td align='right'>{info.account}</td>
39
+ </tr>
40
+ <tr>
41
+ <td>手机号码</td>
42
+ <td>{info.phone}</td>
43
+ </tr>
44
+ <tr>
45
+ <td>用户邮箱</td>
46
+ <td>{info.email}</td>
47
+ </tr>
48
+ <tr>
49
+ <td>所属部门</td>
50
+ <td>{info.unit} {info.dept}</td>
51
+ </tr>
52
+ <tr>
53
+ <td>所属角色</td>
54
+ <td>{info.roles}</td>
55
+ </tr>
56
+ <tr>
57
+ <td>创建日期</td>
58
+ <td>{info.createTime}</td>
59
+ </tr>
60
+ </tbody>
61
+ </table>
62
+ </Card>
63
+ </Col>
64
+ <Col md={18} sm={24}>
65
+ <Card title='个人设置'>
66
+ <Tabs
67
+ items={[
68
+ {
69
+ label: '修改密码', key: 'pwd', children: <div>
70
+ <ChangePassword/>
71
+ </div>
72
+ },
73
+ {
74
+ label: '消息订阅', key: 'topic', children: <div>
75
+ 当账号管理邮箱后,系统消息会发送邮件给您
76
+ </div>
77
+ }
78
+ ]}
79
+ tabPosition='left'
80
+ >
81
+ </Tabs>
82
+ </Card>
83
+ </Col>
84
+ </Row>
85
+
86
+
87
+ </Page>
88
+
89
+ }
90
+ }
@@ -0,0 +1,57 @@
1
+ import React from 'react'
2
+ import {HttpUtils, Page, ProTable} from "../../framework";
3
+
4
+
5
+ export default class extends React.Component {
6
+
7
+
8
+ tableRef = React.createRef()
9
+
10
+ columns = [
11
+
12
+ {
13
+ title: '名称',
14
+ dataIndex: 'name',
15
+
16
+
17
+ },
18
+
19
+ {
20
+ title: '版本',
21
+ dataIndex: 'version',
22
+ render(version) {
23
+ return 'v' + version;
24
+ }
25
+ },
26
+
27
+ {
28
+ title: '文件',
29
+ dataIndex: 'fileId',
30
+ render(id) {
31
+ const url = ('admin/sysFile/preview/' + id);
32
+ return <a href={url} target='_blank'>查看文件</a>
33
+ }
34
+
35
+ },
36
+
37
+ {
38
+ title: '更新时间',
39
+ dataIndex: 'updateTime',
40
+ },
41
+ ]
42
+
43
+
44
+ render() {
45
+ return <Page>
46
+ <ProTable
47
+ actionRef={this.tableRef}
48
+ request={(params) => HttpUtils.get('admin/sysManual/pageForUser', params)}
49
+ columns={this.columns}
50
+ />
51
+ </Page>
52
+
53
+
54
+ }
55
+ }
56
+
57
+
@@ -0,0 +1,103 @@
1
+ import React from "react";
2
+ import {Button, Card, Tabs, Tag} from "antd";
3
+ import {ProTable} from "../../framework";
4
+
5
+ export default class extends React.Component {
6
+
7
+ tableRef = React.createRef()
8
+
9
+ read = (record) => {
10
+ HttpUtils.post("admin/user/msg/read", record).then(rs => {
11
+ this.tableRef.current.reload()
12
+ })
13
+ }
14
+
15
+ columns = [
16
+ {
17
+ title: '时间',
18
+ dataIndex: 'createTime',
19
+ width: 150
20
+ },
21
+ {
22
+ title: '标题',
23
+ dataIndex: 'title',
24
+ },
25
+ {
26
+ title: '内容',
27
+ dataIndex: 'content',
28
+ render(content, row) {
29
+ return <div dangerouslySetInnerHTML={{__html: content}}/>
30
+ }
31
+ },
32
+ {
33
+ title: '已读时间',
34
+ dataIndex: 'readTime',
35
+ width: 150
36
+ },
37
+ {
38
+ title: '状态',
39
+ dataIndex: 'isRead',
40
+ render: (v, row) => {
41
+ return v == true ? <Tag color='green'>已读</Tag> : <Tag color='red'>未读</Tag>;
42
+ },
43
+ width: 80
44
+ },
45
+
46
+ {
47
+ title: '-',
48
+ dataIndex: 'option',
49
+ render: (read, row) => {
50
+ if (!row.isRead)
51
+ return <Button size='small' onClick={() => this.read(row)}> 标记已读 </Button>
52
+ }, width: 80
53
+ }
54
+ ]
55
+
56
+ render() {
57
+ return <Card variant={"borderless"}>
58
+
59
+ <Tabs defaultActiveKey="0" destroyOnHidden
60
+ >
61
+ <Tabs.TabPane key='0' tab='所有消息'>
62
+ <ProTable
63
+ actionRef={this.tableRef}
64
+ request={(params) => HttpUtils.get("admin/user/msg/page", params)}
65
+ columns={this.columns}
66
+ toolbarOptions={{showSearch: false}}
67
+ size='small'
68
+ />
69
+ </Tabs.TabPane>
70
+ <Tabs.TabPane key='1' tab='未读消息'>
71
+ <ProTable
72
+ actionRef={this.tableRef}
73
+ request={(params) => HttpUtils.get("admin/user/msg/page?read=false", params)}
74
+ columns={this.columns}
75
+ rowSelection={false}
76
+ rowKey='id'
77
+ toolbarOptions={{showSearch: false}}
78
+ size='small'
79
+ />
80
+
81
+
82
+ </Tabs.TabPane>
83
+ <Tabs.TabPane key='2' tab='已读消息'>
84
+
85
+ <ProTable
86
+ actionRef={this.tableRef}
87
+ request={(params) => HttpUtils.get("admin/user/msg/page?read=true", params)}
88
+ rowSelection={false}
89
+ rowKey='id'
90
+ toolbarOptions={{showSearch: false}}
91
+ options={false}
92
+ size='small'
93
+ columns={this.columns}
94
+ />
95
+
96
+
97
+ </Tabs.TabPane>
98
+
99
+ </Tabs>
100
+
101
+ </Card>
102
+ }
103
+ }
@@ -0,0 +1,51 @@
1
+ /*主要在layout中导入*/
2
+ table.tmgg-table {
3
+ width: 100%;
4
+ border-collapse: collapse; /* 合并边框 */
5
+ box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1); /* 轻微阴影 */
6
+ table-layout: fixed;
7
+
8
+ th {
9
+ background-color: #f2f2f2; /* 背景色 */
10
+ color: #333; /* 文字颜色 */
11
+ font-weight: bold; /* 加粗 */
12
+ padding: 12px 15px; /* 内边距 */
13
+ text-align: left; /* 文字对齐 */
14
+ border-bottom: 2px solid #ddd; /* 底部边框 */
15
+ }
16
+
17
+ td {
18
+ padding: 10px 15px; /* 内边距 */
19
+ border-bottom: 1px solid #ddd; /* 底部边框 */
20
+ text-align: left; /* 文字对齐 */
21
+ }
22
+
23
+ /* 表格行悬停效果 */
24
+
25
+ tr:hover {
26
+ background-color: #f5f5f5; /* 悬停背景色 */
27
+ }
28
+
29
+ /* 斑马纹效果 - 交替行颜色 */
30
+ tr:nth-child(even) {
31
+ background-color: #f9f9f9;
32
+ }
33
+
34
+ /* 响应式表格 - 在小屏幕上添加水平滚动 */
35
+ @media screen and (max-width: 600px) {
36
+ table {
37
+ display: block;
38
+ overflow-x: auto;
39
+ }
40
+ }
41
+
42
+
43
+ }
44
+ .flex-center {
45
+ display: flex;
46
+ align-items: center;
47
+ justify-content: center;
48
+ width: 100%;
49
+ }
50
+
51
+