lupine.api 1.1.44 → 1.1.46
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.
- package/admin/admin-frame-helper.tsx +356 -0
- package/admin/admin-frame.tsx +25 -328
- package/admin/admin-index.tsx +6 -7
- package/admin/admin-login.tsx +39 -27
- package/admin/admin-menu-list.tsx +4 -4
- package/admin/admin-page-list.tsx +4 -4
- package/admin/admin-release.tsx +0 -7
- package/admin/admin-table-data.tsx +2 -2
- package/admin/admin-table-list.tsx +3 -4
- package/admin/design/design-block-box.tsx +2 -2
- package/admin/index.ts +6 -3
- package/package.json +1 -1
- package/src/admin-api/admin-api-helper.ts +205 -0
- package/src/admin-api/admin-api.ts +5 -2
- package/src/admin-api/admin-auth.ts +61 -8
- package/src/admin-api/admin-config.ts +1 -12
- package/src/admin-api/admin-performance.ts +2 -2
- package/src/admin-api/admin-release.ts +2 -2
- package/src/admin-api/admin-resources.ts +3 -3
- package/src/admin-api/admin-token-helper.ts +2 -2
- package/src/admin-api/index.ts +1 -1
- package/src/lang/api-lang-en.ts +0 -1
- package/src/lang/api-lang-zh-cn.ts +0 -1
- package/admin/admin-frame-props.tsx +0 -9
- package/src/admin-api/admin-helper.ts +0 -111
|
@@ -0,0 +1,356 @@
|
|
|
1
|
+
import { VNode, MenuItemProps } from 'lupine.components';
|
|
2
|
+
import { NestMenuItemProps, TabsHookProps } from 'lupine.components';
|
|
3
|
+
import { CreateTablesPage, RunSqlPage } from './admin-db';
|
|
4
|
+
import { TableListPage } from './admin-table-list';
|
|
5
|
+
import { AdminMenuPage } from './admin-menu-list';
|
|
6
|
+
import { TestThemesPage } from './admin-test-themes';
|
|
7
|
+
import { AdminPagePage } from './admin-page-list';
|
|
8
|
+
import { AdminPerformancePage } from './admin-performance';
|
|
9
|
+
import { AdminReleasePage } from './admin-release';
|
|
10
|
+
import { AdminTestAnimationsPage } from './admin-test-animations';
|
|
11
|
+
import { AdminTestEditPage } from './admin-test-edit';
|
|
12
|
+
import { AdminResourcesPage } from './admin-resources';
|
|
13
|
+
import { AdminTokensPage } from './admin-tokens';
|
|
14
|
+
import { TestComponentPage } from './admin-test-component';
|
|
15
|
+
import { AdminConfigPage } from './admin-config';
|
|
16
|
+
import { AdminAboutPage } from './admin-about';
|
|
17
|
+
import { AdminShellPage } from './admin-shell';
|
|
18
|
+
|
|
19
|
+
const chineseMenuText: { text: string; zh: string }[] = [
|
|
20
|
+
{ text: 'Contents', zh: '内容管理' },
|
|
21
|
+
{ text: 'Menu List', zh: '菜单列表' },
|
|
22
|
+
{ text: 'Page List', zh: '页面列表' },
|
|
23
|
+
{ text: 'Process List', zh: '流程列表' },
|
|
24
|
+
|
|
25
|
+
{ text: 'DB', zh: '数据库' },
|
|
26
|
+
{ text: 'Table List', zh: '表' },
|
|
27
|
+
{ text: 'Create Tables', zh: '创建表' },
|
|
28
|
+
{ text: 'Run SQL', zh: '运行 SQL' },
|
|
29
|
+
|
|
30
|
+
{ text: 'Test', zh: '测试' },
|
|
31
|
+
{ text: 'Test Themes', zh: '测试主题' },
|
|
32
|
+
{ text: 'Test Component', zh: '测试组件' },
|
|
33
|
+
{ text: 'Test Animations', zh: '测试动画' },
|
|
34
|
+
{ text: 'Test Edit', zh: '测试编辑' },
|
|
35
|
+
|
|
36
|
+
{ text: 'Access', zh: '管理服务器' },
|
|
37
|
+
{ text: 'Release', zh: '发布' },
|
|
38
|
+
{ text: 'Tokens', zh: '管理令牌' },
|
|
39
|
+
|
|
40
|
+
{ text: 'Server Info', zh: '服务器信息' },
|
|
41
|
+
{ text: 'Resources', zh: '管理资源' },
|
|
42
|
+
{ text: 'Config', zh: '管理配置' },
|
|
43
|
+
{ text: 'Shell', zh: '命令终端' },
|
|
44
|
+
{ text: 'Server Info', zh: '服务器信息' },
|
|
45
|
+
{ text: 'Performance', zh: '性能' },
|
|
46
|
+
|
|
47
|
+
{ text: 'Help', zh: '帮助' },
|
|
48
|
+
{ text: 'About', zh: '关于' },
|
|
49
|
+
];
|
|
50
|
+
const translateMenuToChinese = (text: string) => {
|
|
51
|
+
const menuItem = chineseMenuText.find((item) => item.text === text);
|
|
52
|
+
return menuItem ? menuItem.zh : text;
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
export type AppAdminHookCheckLoginProps = (authResponse: object) => Promise<boolean>;
|
|
56
|
+
export type AppAdminHookLogoutProps = () => Promise<void>;
|
|
57
|
+
export class AdminFrameHelper {
|
|
58
|
+
consoleTitle = 'Welcome to Admin Panel';
|
|
59
|
+
getConsoleTitle() {
|
|
60
|
+
return this.consoleTitle;
|
|
61
|
+
}
|
|
62
|
+
setConsoleTitle(title: string) {
|
|
63
|
+
this.consoleTitle = title;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
isDevAdmin = false;
|
|
67
|
+
getIsDevAdmin() {
|
|
68
|
+
return this.isDevAdmin;
|
|
69
|
+
}
|
|
70
|
+
setIsDevAdmin(isDevAdmin: boolean) {
|
|
71
|
+
this.isDevAdmin = isDevAdmin;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
maxTabsCount = 20;
|
|
75
|
+
setMaxTabsCount(count: number) {
|
|
76
|
+
this.maxTabsCount = count;
|
|
77
|
+
}
|
|
78
|
+
getMaxTabsCount() {
|
|
79
|
+
return this.maxTabsCount;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
tabsHook: TabsHookProps = {} as TabsHookProps;
|
|
83
|
+
setTabsHook(hook: TabsHookProps) {
|
|
84
|
+
this.tabsHook = hook;
|
|
85
|
+
}
|
|
86
|
+
getTabsHook() {
|
|
87
|
+
return this.tabsHook;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
AppAdminHookCheckLogin?: AppAdminHookCheckLoginProps;
|
|
91
|
+
setAppAdminHookCheckLogin(hook: AppAdminHookCheckLoginProps) {
|
|
92
|
+
this.AppAdminHookCheckLogin = hook;
|
|
93
|
+
}
|
|
94
|
+
getAppAdminHookCheckLogin() {
|
|
95
|
+
return this.AppAdminHookCheckLogin;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
AppAdminHookLogout?: AppAdminHookLogoutProps;
|
|
99
|
+
setAppAdminHookLogout(hook: AppAdminHookLogoutProps) {
|
|
100
|
+
this.AppAdminHookLogout = hook;
|
|
101
|
+
}
|
|
102
|
+
getAppAdminHookLogout() {
|
|
103
|
+
return this.AppAdminHookLogout;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
adminTopMenu: NestMenuItemProps[] = [
|
|
107
|
+
// { text: 'Top', url: '/admin' },
|
|
108
|
+
{
|
|
109
|
+
id: 'contents',
|
|
110
|
+
text: 'Contents',
|
|
111
|
+
url: '',
|
|
112
|
+
// hide: true,
|
|
113
|
+
devAdmin: true,
|
|
114
|
+
items: [
|
|
115
|
+
{
|
|
116
|
+
id: 'menu-list',
|
|
117
|
+
text: 'Menu List',
|
|
118
|
+
url: '',
|
|
119
|
+
// hide: true,
|
|
120
|
+
js: () => this.addPanel('Menu', AdminMenuPage()),
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
id: 'page-list',
|
|
124
|
+
text: 'Page List',
|
|
125
|
+
url: '',
|
|
126
|
+
js: () => this.addPanel('Page', AdminPagePage()),
|
|
127
|
+
},
|
|
128
|
+
{
|
|
129
|
+
id: 'process-list',
|
|
130
|
+
text: 'Process List',
|
|
131
|
+
url: '',
|
|
132
|
+
js: () => this.addPanel('Process', <div>new Process</div>),
|
|
133
|
+
},
|
|
134
|
+
],
|
|
135
|
+
},
|
|
136
|
+
// { text: 'menu2', url: '/st_did.l--liangbufan.gunanguanvqingguandeng.html' },
|
|
137
|
+
// {
|
|
138
|
+
// text: 'Admin',
|
|
139
|
+
// url: '',
|
|
140
|
+
// items: [{ text: 'Users', url: '/admin/users' }],
|
|
141
|
+
// },
|
|
142
|
+
{
|
|
143
|
+
id: 'db',
|
|
144
|
+
text: 'DB',
|
|
145
|
+
url: '',
|
|
146
|
+
devAdmin: true,
|
|
147
|
+
items: [
|
|
148
|
+
{
|
|
149
|
+
id: 'table-list',
|
|
150
|
+
text: 'Table List',
|
|
151
|
+
url: '',
|
|
152
|
+
js: () => this.addPanel('Table List', TableListPage()),
|
|
153
|
+
},
|
|
154
|
+
{
|
|
155
|
+
id: 'create-tables',
|
|
156
|
+
text: 'Create Tables',
|
|
157
|
+
url: '',
|
|
158
|
+
js: () => this.addPanel('Create Tables', CreateTablesPage()),
|
|
159
|
+
},
|
|
160
|
+
{
|
|
161
|
+
id: 'run-sql',
|
|
162
|
+
text: 'Run SQL',
|
|
163
|
+
url: '',
|
|
164
|
+
js: () => this.addPanel('Run SQL', RunSqlPage()),
|
|
165
|
+
},
|
|
166
|
+
],
|
|
167
|
+
},
|
|
168
|
+
{
|
|
169
|
+
id: 'test',
|
|
170
|
+
text: 'Test',
|
|
171
|
+
url: '',
|
|
172
|
+
devAdmin: true,
|
|
173
|
+
items: [
|
|
174
|
+
{
|
|
175
|
+
id: 'test-themes',
|
|
176
|
+
text: 'Test Themes',
|
|
177
|
+
url: '',
|
|
178
|
+
js: () => this.addPanel('Test Themes', TestThemesPage()),
|
|
179
|
+
},
|
|
180
|
+
{
|
|
181
|
+
id: 'test-component',
|
|
182
|
+
text: 'Test Component',
|
|
183
|
+
url: '',
|
|
184
|
+
js: () => this.addPanel('Test Component', TestComponentPage()),
|
|
185
|
+
},
|
|
186
|
+
{
|
|
187
|
+
id: 'test-animations',
|
|
188
|
+
text: 'Test Animations',
|
|
189
|
+
url: '',
|
|
190
|
+
js: () => this.addPanel('Test Animations', AdminTestAnimationsPage()),
|
|
191
|
+
},
|
|
192
|
+
{
|
|
193
|
+
id: 'test-edit',
|
|
194
|
+
text: 'Test Edit',
|
|
195
|
+
url: '',
|
|
196
|
+
js: () => this.addPanel('Test Edit', AdminTestEditPage()),
|
|
197
|
+
},
|
|
198
|
+
],
|
|
199
|
+
},
|
|
200
|
+
|
|
201
|
+
{
|
|
202
|
+
id: 'access',
|
|
203
|
+
text: 'Access',
|
|
204
|
+
url: '',
|
|
205
|
+
devAdmin: true,
|
|
206
|
+
items: [
|
|
207
|
+
{
|
|
208
|
+
id: 'release',
|
|
209
|
+
text: 'Release',
|
|
210
|
+
url: '',
|
|
211
|
+
js: () => this.addPanel('Release', AdminReleasePage()),
|
|
212
|
+
},
|
|
213
|
+
{
|
|
214
|
+
id: 'tokens',
|
|
215
|
+
text: 'Tokens',
|
|
216
|
+
url: '',
|
|
217
|
+
js: () => this.addPanel('Tokens', AdminTokensPage()),
|
|
218
|
+
},
|
|
219
|
+
],
|
|
220
|
+
},
|
|
221
|
+
|
|
222
|
+
{
|
|
223
|
+
id: 'server-info',
|
|
224
|
+
text: 'Server Info',
|
|
225
|
+
url: '',
|
|
226
|
+
devAdmin: true,
|
|
227
|
+
items: [
|
|
228
|
+
{
|
|
229
|
+
id: 'performance',
|
|
230
|
+
text: 'Performance',
|
|
231
|
+
url: '',
|
|
232
|
+
js: () => this.addPanel('Performance', AdminPerformancePage()),
|
|
233
|
+
},
|
|
234
|
+
{
|
|
235
|
+
id: 'resources',
|
|
236
|
+
text: 'Resources',
|
|
237
|
+
url: '',
|
|
238
|
+
js: () => this.addPanel('Resources', AdminResourcesPage()),
|
|
239
|
+
},
|
|
240
|
+
{
|
|
241
|
+
id: 'config',
|
|
242
|
+
text: 'Config',
|
|
243
|
+
url: '',
|
|
244
|
+
js: () => this.addPanel('Config', AdminConfigPage()),
|
|
245
|
+
},
|
|
246
|
+
{
|
|
247
|
+
id: 'shell',
|
|
248
|
+
text: 'Shell',
|
|
249
|
+
url: '',
|
|
250
|
+
js: () => this.addPanel('Shell', AdminShellPage()),
|
|
251
|
+
},
|
|
252
|
+
],
|
|
253
|
+
},
|
|
254
|
+
{
|
|
255
|
+
id: 'help',
|
|
256
|
+
text: 'Help',
|
|
257
|
+
url: '',
|
|
258
|
+
devAdmin: true,
|
|
259
|
+
items: [
|
|
260
|
+
{
|
|
261
|
+
id: 'about',
|
|
262
|
+
text: 'About',
|
|
263
|
+
url: '',
|
|
264
|
+
js: () => this.addPanel('About', AdminAboutPage()),
|
|
265
|
+
},
|
|
266
|
+
],
|
|
267
|
+
},
|
|
268
|
+
];
|
|
269
|
+
|
|
270
|
+
hookBeforeShowMenu?: (adminTopMenu: NestMenuItemProps[]) => NestMenuItemProps[];
|
|
271
|
+
// Set a hook to modify the admin top menu dynamically before it is shown
|
|
272
|
+
setHookBeforeShowMenu(hook: (adminTopMenu: NestMenuItemProps[]) => NestMenuItemProps[]) {
|
|
273
|
+
this.hookBeforeShowMenu = hook;
|
|
274
|
+
}
|
|
275
|
+
getAdminTopMenu() {
|
|
276
|
+
if (this.hookBeforeShowMenu) {
|
|
277
|
+
return this.hookBeforeShowMenu(this.adminTopMenu);
|
|
278
|
+
}
|
|
279
|
+
return this.adminTopMenu;
|
|
280
|
+
}
|
|
281
|
+
setAdminTopMenu(adminTopMenu: NestMenuItemProps[]) {
|
|
282
|
+
this.adminTopMenu = adminTopMenu;
|
|
283
|
+
}
|
|
284
|
+
setChineseAdminTopMenu() {
|
|
285
|
+
this.adminTopMenu.forEach((item) => {
|
|
286
|
+
item.text = translateMenuToChinese(item.text);
|
|
287
|
+
item.items?.forEach((subItem) => {
|
|
288
|
+
subItem.text = translateMenuToChinese(subItem.text);
|
|
289
|
+
});
|
|
290
|
+
});
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
mobileMenuMaxWidth = '700px';
|
|
294
|
+
setMobileMenuMaxWidth(maxWidth: string) {
|
|
295
|
+
this.mobileMenuMaxWidth = maxWidth;
|
|
296
|
+
}
|
|
297
|
+
getMobileMenuMaxWidth() {
|
|
298
|
+
return this.mobileMenuMaxWidth;
|
|
299
|
+
}
|
|
300
|
+
|
|
301
|
+
insertMenuItem(item: NestMenuItemProps[], beforeMenuId?: string) {
|
|
302
|
+
let index = -1;
|
|
303
|
+
if (beforeMenuId) {
|
|
304
|
+
index = this.adminTopMenu.findIndex((m) => m.id === beforeMenuId);
|
|
305
|
+
}
|
|
306
|
+
if (index !== -1) {
|
|
307
|
+
this.adminTopMenu.splice(index, 0, ...item);
|
|
308
|
+
} else {
|
|
309
|
+
this.adminTopMenu.push(...item);
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
insertSubMenuItem(item: MenuItemProps[], beforeMenuId: string, beforeSubMenuId?: string) {
|
|
313
|
+
const index = this.adminTopMenu.findIndex((m) => m.id === beforeMenuId);
|
|
314
|
+
if (index !== -1) {
|
|
315
|
+
const subMenu = this.adminTopMenu[index].items || [];
|
|
316
|
+
const subIndex = subMenu.findIndex((s) => s.id === beforeSubMenuId);
|
|
317
|
+
if (subIndex !== -1) {
|
|
318
|
+
subMenu.splice(subIndex, 0, ...item);
|
|
319
|
+
} else {
|
|
320
|
+
subMenu.push(...item);
|
|
321
|
+
}
|
|
322
|
+
// this.adminTopMenu[index].items = subMenu;
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
getMenuItem(menuId: string): NestMenuItemProps | null {
|
|
326
|
+
const index = this.adminTopMenu.findIndex((m) => m.id === menuId);
|
|
327
|
+
if (index !== -1) {
|
|
328
|
+
return this.adminTopMenu[index];
|
|
329
|
+
}
|
|
330
|
+
return null;
|
|
331
|
+
}
|
|
332
|
+
getSubMenuItem(menuId: string, subMenuId: string): MenuItemProps | null {
|
|
333
|
+
const index = this.adminTopMenu.findIndex((m) => m.id === menuId);
|
|
334
|
+
if (index !== -1) {
|
|
335
|
+
const subMenu = this.adminTopMenu[index].items || [];
|
|
336
|
+
const subIndex = subMenu.findIndex((s) => s.id === subMenuId);
|
|
337
|
+
if (subIndex !== -1) {
|
|
338
|
+
return subMenu[subIndex];
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
return null;
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
refUpdate = this.getTabsHook();
|
|
345
|
+
async addPanel(title: string, page: VNode) {
|
|
346
|
+
if (this.getTabsHook().getCount!() > this.getMaxTabsCount()) {
|
|
347
|
+
alert('You are opening too many pages');
|
|
348
|
+
return;
|
|
349
|
+
}
|
|
350
|
+
if (this.getTabsHook().findAndActivate!(title)) {
|
|
351
|
+
return;
|
|
352
|
+
}
|
|
353
|
+
await this.getTabsHook().newPage!(title, page);
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
export const adminFrameHelper = /* @__PURE__ */ new AdminFrameHelper();
|