@maketribe/ms-app 3.0.15 → 3.0.17
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/dist/cjs/components/json-editor/index.js +6 -2
- package/dist/cjs/components/json-editor/index.js.map +1 -1
- package/dist/cjs/components/json-editor/json-editor.js +2 -2
- package/dist/cjs/components/material-select/material-select-type.d.ts +6 -5
- package/dist/cjs/components/new-upload-file/MaterialUploadContext.d.ts +4 -0
- package/dist/cjs/components/new-upload-file/MaterialUploadContext.js +18 -0
- package/dist/cjs/components/new-upload-file/MaterialUploadContext.js.map +1 -0
- package/dist/cjs/components/new-upload-file/UploadContext.d.ts +8 -0
- package/dist/cjs/components/new-upload-file/UploadContext.js +10 -0
- package/dist/cjs/components/new-upload-file/UploadContext.js.map +1 -0
- package/dist/cjs/components/new-upload-file/WebFileUploadContext.d.ts +10 -0
- package/dist/cjs/components/new-upload-file/WebFileUploadContext.js +50 -0
- package/dist/cjs/components/new-upload-file/WebFileUploadContext.js.map +1 -0
- package/dist/cjs/components/new-upload-file/upload-file-options.d.ts +17 -0
- package/dist/cjs/components/new-upload-file/upload-file-options.js +23 -0
- package/dist/cjs/components/new-upload-file/upload-file-options.js.map +1 -0
- package/dist/cjs/components/new-upload-file/upload-file.d.ts +40 -0
- package/dist/cjs/components/new-upload-file/upload-file.js +49 -0
- package/dist/cjs/components/new-upload-file/upload-file.js.map +1 -0
- package/dist/cjs/components/upload-file/upload-file.js +7 -1
- package/dist/cjs/components/upload-file/upload-file.js.map +1 -1
- package/dist/cjs/core/MSAppClient.js +3 -0
- package/dist/cjs/core/MSAppClient.js.map +1 -1
- package/dist/cjs/core/PageManager.js +14 -8
- package/dist/cjs/core/PageManager.js.map +1 -1
- package/dist/cjs/core/Router.js +7 -7
- package/dist/cjs/core/Router.js.map +1 -1
- package/dist/cjs/dataview/route/RouteForm.d.ts +2 -2
- package/dist/cjs/dataview/route/RouteForm.js +2 -2
- package/dist/cjs/dataview/route/RouteForm.js.map +1 -1
- package/dist/cjs/dataview/route/RouteTable.js +1 -1
- package/dist/cjs/dataview/route/RouteTable.js.map +1 -1
- package/dist/cjs/init-application.js +1 -1
- package/dist/cjs/init-application.js.map +1 -1
- package/dist/cjs/router-middleware/auth.js +1 -1
- package/dist/cjs/router-middleware/auth.js.map +1 -1
- package/dist/esm/components/json-editor/index.js +4 -2
- package/dist/esm/components/json-editor/index.js.map +1 -1
- package/dist/esm/components/json-editor/json-editor.js +2 -2
- package/dist/esm/components/material-select/material-select-type.d.ts +6 -5
- package/dist/esm/components/new-upload-file/MaterialUploadContext.d.ts +4 -0
- package/dist/esm/components/new-upload-file/MaterialUploadContext.js +16 -0
- package/dist/esm/components/new-upload-file/MaterialUploadContext.js.map +1 -0
- package/dist/esm/components/new-upload-file/UploadContext.d.ts +8 -0
- package/dist/esm/components/new-upload-file/UploadContext.js +8 -0
- package/dist/esm/components/new-upload-file/UploadContext.js.map +1 -0
- package/dist/esm/components/new-upload-file/WebFileUploadContext.d.ts +10 -0
- package/dist/esm/components/new-upload-file/WebFileUploadContext.js +48 -0
- package/dist/esm/components/new-upload-file/WebFileUploadContext.js.map +1 -0
- package/dist/esm/components/new-upload-file/upload-file-options.d.ts +17 -0
- package/dist/esm/components/new-upload-file/upload-file-options.js +20 -0
- package/dist/esm/components/new-upload-file/upload-file-options.js.map +1 -0
- package/dist/esm/components/new-upload-file/upload-file.d.ts +40 -0
- package/dist/esm/components/new-upload-file/upload-file.js +47 -0
- package/dist/esm/components/new-upload-file/upload-file.js.map +1 -0
- package/dist/esm/components/upload-file/upload-file.js +7 -1
- package/dist/esm/components/upload-file/upload-file.js.map +1 -1
- package/dist/esm/core/MSAppClient.js +4 -1
- package/dist/esm/core/MSAppClient.js.map +1 -1
- package/dist/esm/core/PageManager.js +14 -8
- package/dist/esm/core/PageManager.js.map +1 -1
- package/dist/esm/core/Router.js +7 -7
- package/dist/esm/core/Router.js.map +1 -1
- package/dist/esm/dataview/route/RouteForm.d.ts +2 -2
- package/dist/esm/dataview/route/RouteForm.js +2 -2
- package/dist/esm/dataview/route/RouteForm.js.map +1 -1
- package/dist/esm/dataview/route/RouteTable.js +1 -1
- package/dist/esm/dataview/route/RouteTable.js.map +1 -1
- package/dist/esm/init-application.js +1 -1
- package/dist/esm/init-application.js.map +1 -1
- package/dist/esm/node_modules/.pnpm/@codemirror_language@6.9.3/node_modules/@codemirror/language/dist/index.js +2 -2
- package/dist/esm/router-middleware/auth.js +1 -1
- package/dist/esm/router-middleware/auth.js.map +1 -1
- package/package.json +4 -4
- package/src/components/json-editor/index.ts +4 -2
- package/src/components/material-select/material-select-type.ts +10 -5
- package/src/components/new-upload-file/MaterialUploadContext.ts +14 -0
- package/src/components/new-upload-file/UploadContext.ts +11 -0
- package/src/components/new-upload-file/WebFileUploadContext.ts +58 -0
- package/src/components/new-upload-file/upload-file-options.ts +23 -0
- package/src/components/new-upload-file/upload-file.tsx +61 -0
- package/src/components/upload-file/upload-file.tsx +4 -1
- package/src/core/MSAppClient.ts +10 -1
- package/src/core/PageManager.ts +18 -9
- package/src/core/Router.ts +7 -7
- package/src/dataview/route/RouteForm.ts +4 -4
- package/src/dataview/route/RouteTable.ts +1 -1
- package/src/init-application.ts +1 -1
- package/src/router-middleware/auth.ts +1 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MSAppClient.js","sources":["../../../src/core/MSAppClient.ts"],"sourcesContent":["import {\n createRouter,\n createWebHashHistory,\n Router as VueRouter,\n} from \"vue-router\";\nimport { HttpRequest, R, WebHttpRequest } from \"@maketribe/request\";\nimport { IComponents, DataModel, Components } from \"@maketribe/dm\";\nimport { I18n } from \"@maketribe/locale\";\n\nimport { Event, md5 } from \"@maketribe/utils\";\nimport { UserSession } from \"./UserSession\";\nimport { authBeforeEach } from \"../router-middleware\";\nimport { PageManager } from \"./PageManager\";\nimport { ACCESS_TOKEN_HEADER, X_ACCESS_TOKEN_HEADER } from \"../constants\";\n\nexport type LoginResult = {\n account: string;\n email: string;\n nickName: string;\n avatarPath: string;\n};\n\nexport interface MSAppClientOptions {\n pageManager?: PageManager;\n projectName: string;\n httpRequest?: HttpRequest;\n origin: string;\n appID: string;\n logo?: string;\n locale?: string;\n vueRouter?: VueRouter;\n dataTableComponents?: IComponents;\n dataFormComponents?: IComponents;\n dataFilterComponents?: IComponents;\n whereFilterComponents?: IComponents;\n}\n\nexport class MSAppClient {\n static instance: MSAppClient | null = null;\n\n origin: string = \"\";\n\n private _options: Required<MSAppClientOptions>;\n\n projectName: string;\n\n logo: string;\n\n appID: string;\n\n userSession: UserSession | null = null;\n\n httpRequest: HttpRequest;\n\n ready: boolean = false;\n\n initd: boolean = false;\n\n pageManager: PageManager;\n\n /**\n * @deprecated\n * @description 使用 MSAppClient.instance.userSession.userInfo\n */\n get userInfo() {\n return this.userSession?.userInfo ?? null;\n }\n\n i18n: I18n;\n\n dataTableComponents: IComponents;\n dataFormComponents: IComponents;\n dataFilterComponents: IComponents;\n whereFilterComponents: IComponents;\n\n vueRouter: VueRouter;\n\n beforeInitUserSessionEvent: Event<{ userSession: UserSession }> = new Event();\n\n userSessionChangeEvent: Event<{ userSession: UserSession | null }> =\n new Event();\n\n constructor(options: MSAppClientOptions) {\n this._options = this._normalizeOptions(options);\n\n this.appID = this._options.appID;\n\n this.logo = this._options.logo;\n\n this.projectName = options.projectName;\n\n this.i18n = I18n.instance;\n this.i18n.setCurrentLanguageName(this._options.locale);\n\n this.dataTableComponents = this._options.dataTableComponents;\n this.dataFormComponents = this._options.dataFormComponents;\n this.dataFilterComponents = this._options.dataFilterComponents;\n this.whereFilterComponents = this._options.whereFilterComponents;\n\n this.vueRouter = this._options.vueRouter;\n\n this.pageManager = this._options.pageManager;\n\n HttpRequest.appID = this.appID;\n\n this.httpRequest = this._options.httpRequest;\n\n DataModel.setHttpRequest(this.httpRequest);\n }\n\n setUserSession(userSession: UserSession | null) {\n if (this.userSession) {\n this.userSession.dispose();\n }\n\n this.userSession = userSession;\n\n this.userSessionChangeEvent.emit({ userSession });\n }\n\n private _normalizeOptions(\n options: MSAppClientOptions\n ): Required<MSAppClientOptions> {\n return {\n appID: options.appID,\n projectName: options.projectName,\n httpRequest: options.httpRequest ?? new WebHttpRequest(),\n origin: options.origin,\n logo: options.logo || \"\",\n locale: options.locale || \"zh-cn\",\n vueRouter:\n options.vueRouter ??\n createRouter({\n history: createWebHashHistory(),\n routes: [],\n }),\n pageManager: options.pageManager ?? new PageManager(),\n dataTableComponents: options.dataTableComponents ?? new Components(),\n dataFormComponents: options.dataFormComponents ?? new Components(),\n dataFilterComponents: options.dataFilterComponents ?? new Components(),\n whereFilterComponents: options.whereFilterComponents ?? new Components(),\n };\n }\n getI18n() {\n return this.i18n;\n }\n\n getOptions() {\n return this._options;\n }\n\n async loadCurrentUserSession(options?: {\n accessToken: string;\n xAccessToken: string;\n }) {\n const userSession = (this.userSession = new UserSession({\n msAppClient: this,\n ...options,\n }));\n this.userSession = null;\n\n this.beforeInitUserSessionEvent.emit({ userSession });\n const userSessionInitResult = await userSession.init();\n\n if (userSessionInitResult?.data.code !== 200) {\n userSession.dispose();\n return userSessionInitResult!;\n }\n\n this.setUserSession(userSession);\n }\n\n async init() {\n if (this.initd) {\n return;\n }\n\n this.vueRouter.beforeEach(async (to, from, next) => {\n const route = await authBeforeEach(this, to, from);\n\n if (route) {\n next(route);\n return;\n }\n\n next();\n });\n\n this.pageManager.init();\n this.pageManager.setMSAppCLient(this);\n\n this.httpRequest.getInterceptors().response.use((config) => {\n if (config.data.code === 401) {\n if (this.userSession) {\n this.userSession.lock();\n } else {\n this.vueRouter.push({ name: \"login\" });\n }\n }\n return config;\n });\n\n this.initd = true;\n }\n\n async login(account: string, password: string, code: string) {\n const response = await this.httpRequest.request<R<LoginResult>>({\n url: \"/api/ms-login/login\",\n method: \"POST\",\n data: { account, password: md5(`mkbl#${password}`), vCode: code },\n });\n\n if (response.data.code === 200) {\n await this.loadCurrentUserSession({\n accessToken: response.headers[ACCESS_TOKEN_HEADER],\n xAccessToken: response.headers[X_ACCESS_TOKEN_HEADER],\n });\n }\n\n return response;\n }\n\n formatURL(url: string) {\n return url;\n }\n\n async modifyPassword(account: string, code: string) {\n type LoginResult = {\n account: string;\n email: string;\n nickName: string;\n avatarPath: string;\n };\n\n const response = await this.httpRequest.request<R<LoginResult>>({\n url: \"/api/ms-login/modify-password\",\n method: \"POST\",\n data: { account, vCode: code },\n });\n\n return response;\n }\n\n async logout() {\n this.userSession?.dispose();\n this.setUserSession(null);\n\n return this.httpRequest.get(\"/api/ms-login/logout\");\n }\n}\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"MSAppClient.js","sources":["../../../src/core/MSAppClient.ts"],"sourcesContent":["import {\n createRouter,\n createWebHashHistory,\n Router as VueRouter,\n} from \"vue-router\";\nimport {\n DataViewRequest,\n DVQueryable,\n HttpRequest,\n R,\n WebHttpRequest,\n} from \"@maketribe/request\";\nimport { IComponents, DataModel, Components } from \"@maketribe/dm\";\nimport { I18n } from \"@maketribe/locale\";\n\nimport { Event, md5 } from \"@maketribe/utils\";\nimport { UserSession } from \"./UserSession\";\nimport { authBeforeEach } from \"../router-middleware\";\nimport { PageManager } from \"./PageManager\";\nimport { ACCESS_TOKEN_HEADER, X_ACCESS_TOKEN_HEADER } from \"../constants\";\n\nexport type LoginResult = {\n account: string;\n email: string;\n nickName: string;\n avatarPath: string;\n};\n\nexport interface MSAppClientOptions {\n pageManager?: PageManager;\n projectName: string;\n httpRequest?: HttpRequest;\n origin: string;\n appID: string;\n logo?: string;\n locale?: string;\n vueRouter?: VueRouter;\n dataTableComponents?: IComponents;\n dataFormComponents?: IComponents;\n dataFilterComponents?: IComponents;\n whereFilterComponents?: IComponents;\n}\n\nexport class MSAppClient {\n static instance: MSAppClient | null = null;\n\n origin: string = \"\";\n\n private _options: Required<MSAppClientOptions>;\n\n projectName: string;\n\n logo: string;\n\n appID: string;\n\n userSession: UserSession | null = null;\n\n httpRequest: HttpRequest;\n\n ready: boolean = false;\n\n initd: boolean = false;\n\n pageManager: PageManager;\n\n /**\n * @deprecated\n * @description 使用 MSAppClient.instance.userSession.userInfo\n */\n get userInfo() {\n return this.userSession?.userInfo ?? null;\n }\n\n i18n: I18n;\n\n dataTableComponents: IComponents;\n dataFormComponents: IComponents;\n dataFilterComponents: IComponents;\n whereFilterComponents: IComponents;\n\n vueRouter: VueRouter;\n\n beforeInitUserSessionEvent: Event<{ userSession: UserSession }> = new Event();\n\n userSessionChangeEvent: Event<{ userSession: UserSession | null }> =\n new Event();\n\n constructor(options: MSAppClientOptions) {\n this._options = this._normalizeOptions(options);\n\n this.appID = this._options.appID;\n\n this.logo = this._options.logo;\n\n this.projectName = options.projectName;\n\n this.i18n = I18n.instance;\n this.i18n.setCurrentLanguageName(this._options.locale);\n\n this.dataTableComponents = this._options.dataTableComponents;\n this.dataFormComponents = this._options.dataFormComponents;\n this.dataFilterComponents = this._options.dataFilterComponents;\n this.whereFilterComponents = this._options.whereFilterComponents;\n\n this.vueRouter = this._options.vueRouter;\n\n this.pageManager = this._options.pageManager;\n\n HttpRequest.appID = this.appID;\n\n this.httpRequest = this._options.httpRequest;\n\n DataModel.setHttpRequest(this.httpRequest);\n DVQueryable.setDefaultDataViewRequest(\n new DataViewRequest({ httpRequest: this.httpRequest })\n );\n }\n\n setUserSession(userSession: UserSession | null) {\n if (this.userSession) {\n this.userSession.dispose();\n }\n\n this.userSession = userSession;\n\n this.userSessionChangeEvent.emit({ userSession });\n }\n\n private _normalizeOptions(\n options: MSAppClientOptions\n ): Required<MSAppClientOptions> {\n return {\n appID: options.appID,\n projectName: options.projectName,\n httpRequest: options.httpRequest ?? new WebHttpRequest(),\n origin: options.origin,\n logo: options.logo || \"\",\n locale: options.locale || \"zh-cn\",\n vueRouter:\n options.vueRouter ??\n createRouter({\n history: createWebHashHistory(),\n routes: [],\n }),\n pageManager: options.pageManager ?? new PageManager(),\n dataTableComponents: options.dataTableComponents ?? new Components(),\n dataFormComponents: options.dataFormComponents ?? new Components(),\n dataFilterComponents: options.dataFilterComponents ?? new Components(),\n whereFilterComponents: options.whereFilterComponents ?? new Components(),\n };\n }\n getI18n() {\n return this.i18n;\n }\n\n getOptions() {\n return this._options;\n }\n\n async loadCurrentUserSession(options?: {\n accessToken: string;\n xAccessToken: string;\n }) {\n const userSession = (this.userSession = new UserSession({\n msAppClient: this,\n ...options,\n }));\n this.userSession = null;\n\n this.beforeInitUserSessionEvent.emit({ userSession });\n const userSessionInitResult = await userSession.init();\n\n if (userSessionInitResult?.data.code !== 200) {\n userSession.dispose();\n return userSessionInitResult!;\n }\n\n this.setUserSession(userSession);\n }\n\n async init() {\n if (this.initd) {\n return;\n }\n\n this.vueRouter.beforeEach(async (to, from, next) => {\n const route = await authBeforeEach(this, to, from);\n\n if (route) {\n next(route);\n return;\n }\n\n next();\n });\n\n this.pageManager.init();\n this.pageManager.setMSAppCLient(this);\n\n this.httpRequest.getInterceptors().response.use((config) => {\n if (config.data.code === 401) {\n if (this.userSession) {\n this.userSession.lock();\n } else {\n this.vueRouter.push({ name: \"login\" });\n }\n }\n return config;\n });\n\n this.initd = true;\n }\n\n async login(account: string, password: string, code: string) {\n const response = await this.httpRequest.request<R<LoginResult>>({\n url: \"/api/ms-login/login\",\n method: \"POST\",\n data: { account, password: md5(`mkbl#${password}`), vCode: code },\n });\n\n if (response.data.code === 200) {\n await this.loadCurrentUserSession({\n accessToken: response.headers[ACCESS_TOKEN_HEADER],\n xAccessToken: response.headers[X_ACCESS_TOKEN_HEADER],\n });\n }\n\n return response;\n }\n\n formatURL(url: string) {\n return url;\n }\n\n async modifyPassword(account: string, code: string) {\n type LoginResult = {\n account: string;\n email: string;\n nickName: string;\n avatarPath: string;\n };\n\n const response = await this.httpRequest.request<R<LoginResult>>({\n url: \"/api/ms-login/modify-password\",\n method: \"POST\",\n data: { account, vCode: code },\n });\n\n return response;\n }\n\n async logout() {\n this.userSession?.dispose();\n this.setUserSession(null);\n\n return this.httpRequest.get(\"/api/ms-login/logout\");\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -92,24 +92,30 @@ class PageManager {
|
|
|
92
92
|
if (!userSession) {
|
|
93
93
|
return;
|
|
94
94
|
}
|
|
95
|
+
const router = userSession.router;
|
|
95
96
|
const addedExtendsPageNames = [];
|
|
96
|
-
if (!this.extendsPages.find((page) => page.name === "notFound")) {
|
|
97
|
-
this.addExtendsPage({
|
|
98
|
-
name: "notFound",
|
|
99
|
-
// path: ":pathMatch(.*)*",
|
|
100
|
-
path: "",
|
|
101
|
-
component: () => import('../page/index/404.vue.js')
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
97
|
for (const extendsPage of this.extendsPages) {
|
|
98
|
+
const routeInfo = router.getRouteByName(extendsPage.name);
|
|
99
|
+
if (!routeInfo) {
|
|
100
|
+
continue;
|
|
101
|
+
}
|
|
105
102
|
const vueRoute = vueRoutes.find(
|
|
106
103
|
(vueRoute2) => vueRoute2.name === extendsPage.name
|
|
107
104
|
);
|
|
108
105
|
if (!vueRoute) {
|
|
106
|
+
extendsPage.path = routeInfo.route || extendsPage.path;
|
|
109
107
|
addedExtendsPageNames.push(extendsPage.name);
|
|
110
108
|
vueRouter.addRoute("mk-ms-layout", extendsPage);
|
|
111
109
|
}
|
|
112
110
|
}
|
|
111
|
+
if (!this.extendsPages.find((page) => page.name === "notFound")) {
|
|
112
|
+
this.addExtendsPage({
|
|
113
|
+
name: "notFound",
|
|
114
|
+
// path: ":pathMatch(.*)*",
|
|
115
|
+
path: "",
|
|
116
|
+
component: () => import('../page/index/404.vue.js')
|
|
117
|
+
});
|
|
118
|
+
}
|
|
113
119
|
userSession.register(
|
|
114
120
|
createDisposable(() => {
|
|
115
121
|
for (const addedExtendsPageName of addedExtendsPageNames) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PageManager.js","sources":["../../../src/core/PageManager.ts"],"sourcesContent":["import { RouteRecordRaw } from \"vue-router\";\nimport type { MSAppClient } from \"./MSAppClient\";\nimport { Disposable, Event, createDisposable } from \"@maketribe/utils\";\n\nexport class PageManager {\n normalPages: RouteRecordRaw[] = [];\n\n extendsPages: RouteRecordRaw[] = [];\n\n msAppClient: MSAppClient | null = null;\n\n msAppClientChangeEvent: Event<{ msAppClient: MSAppClient | null }> =\n new Event();\n\n msAppClientDisposable: Disposable | null = null;\n\n setMSAppCLient(msAppClient: MSAppClient | null) {\n this.msAppClientDisposable?.dispose();\n\n this.msAppClientDisposable = new Disposable();\n\n this.msAppClient = msAppClient;\n\n this.msAppClientChangeEvent.emit({ msAppClient });\n }\n\n addNormalPage(normalPage: RouteRecordRaw) {\n this.normalPages.push(normalPage);\n }\n\n addExtendsPage(extendsPage: RouteRecordRaw) {\n this.extendsPages.push(extendsPage);\n }\n\n init() {\n this.addNormalPage({\n name: \"mk-ms-layout\",\n path: \"/\",\n component: () => import(\"../page/index.vue\"),\n });\n\n this.addNormalPage({\n name: \"login\",\n path: \"/login\",\n meta: {\n isAuthorization: false,\n },\n component: () => import(\"../page/login/index.vue\"),\n });\n\n this.addNormalPage({\n name: \"signup\",\n path: \"/signup\",\n meta: {\n isAuthorization: false,\n },\n component: () => import(\"../page/signup/index.vue\"),\n });\n\n this.addExtendsPage({\n name: \"dv/ms-material/list\",\n path: \"/material-list\",\n component: () => import(\"../page/index/material/index.vue\"),\n meta: { name: \"ms-material\" },\n });\n\n this.addExtendsPage({\n name: \"dv/ms-member/single/list/normal\",\n path: \"/dv/ms-member\",\n component: () => import(\"../page/index/dv/ms-member/index.vue\"),\n meta: { name: \"ms-member\" },\n });\n\n this.addExtendsPage({\n name: \"dv/ms-role/single/list/dialog\",\n path: \"/dv/ms-role\",\n component: () => import(\"../page/index/dv/ms-role/index.vue\"),\n meta: { name: \"ms-role\" },\n });\n\n this.addExtendsPage({\n name: \"dv/local-log/single/tree/dialog\",\n path: \"/log/local\",\n component: () => import(\"../page/index/dv/local-log/index.vue\"),\n meta: { name: \"local-log\" },\n });\n\n this.msAppClientChangeEvent.on(({ msAppClient }) => {\n if (!msAppClient) {\n return;\n }\n\n const vueRouter = msAppClient.vueRouter;\n const vueRoutes = vueRouter.getRoutes();\n\n const addedNormalPageNames: string[] = [];\n\n for (const normalPage of this.normalPages) {\n const vueRoute = vueRoutes.find(\n (vueRoute) => vueRoute.name === normalPage.name\n );\n\n if (!vueRoute) {\n addedNormalPageNames.push(normalPage.name as string);\n vueRouter.addRoute(normalPage);\n }\n }\n\n this.msAppClientDisposable?.register(\n createDisposable(() => {\n for (const addedNormalPageName of addedNormalPageNames) {\n vueRouter.removeRoute(addedNormalPageName);\n }\n })\n );\n\n this.msAppClientDisposable?.register(\n msAppClient.beforeInitUserSessionEvent.on(({ userSession }) => {\n if (!userSession) {\n return;\n }\n\n const addedExtendsPageNames: string[] = [];\n\n
|
|
1
|
+
{"version":3,"file":"PageManager.js","sources":["../../../src/core/PageManager.ts"],"sourcesContent":["import { RouteRecordRaw } from \"vue-router\";\nimport type { MSAppClient } from \"./MSAppClient\";\nimport { Disposable, Event, createDisposable } from \"@maketribe/utils\";\n\nexport class PageManager {\n normalPages: RouteRecordRaw[] = [];\n\n extendsPages: RouteRecordRaw[] = [];\n\n msAppClient: MSAppClient | null = null;\n\n msAppClientChangeEvent: Event<{ msAppClient: MSAppClient | null }> =\n new Event();\n\n msAppClientDisposable: Disposable | null = null;\n\n setMSAppCLient(msAppClient: MSAppClient | null) {\n this.msAppClientDisposable?.dispose();\n\n this.msAppClientDisposable = new Disposable();\n\n this.msAppClient = msAppClient;\n\n this.msAppClientChangeEvent.emit({ msAppClient });\n }\n\n addNormalPage(normalPage: RouteRecordRaw) {\n this.normalPages.push(normalPage);\n }\n\n addExtendsPage(extendsPage: RouteRecordRaw) {\n this.extendsPages.push(extendsPage);\n }\n\n init() {\n this.addNormalPage({\n name: \"mk-ms-layout\",\n path: \"/\",\n component: () => import(\"../page/index.vue\"),\n });\n\n this.addNormalPage({\n name: \"login\",\n path: \"/login\",\n meta: {\n isAuthorization: false,\n },\n component: () => import(\"../page/login/index.vue\"),\n });\n\n this.addNormalPage({\n name: \"signup\",\n path: \"/signup\",\n meta: {\n isAuthorization: false,\n },\n component: () => import(\"../page/signup/index.vue\"),\n });\n\n this.addExtendsPage({\n name: \"dv/ms-material/list\",\n path: \"/material-list\",\n component: () => import(\"../page/index/material/index.vue\"),\n meta: { name: \"ms-material\" },\n });\n\n this.addExtendsPage({\n name: \"dv/ms-member/single/list/normal\",\n path: \"/dv/ms-member\",\n component: () => import(\"../page/index/dv/ms-member/index.vue\"),\n meta: { name: \"ms-member\" },\n });\n\n this.addExtendsPage({\n name: \"dv/ms-role/single/list/dialog\",\n path: \"/dv/ms-role\",\n component: () => import(\"../page/index/dv/ms-role/index.vue\"),\n meta: { name: \"ms-role\" },\n });\n\n this.addExtendsPage({\n name: \"dv/local-log/single/tree/dialog\",\n path: \"/log/local\",\n component: () => import(\"../page/index/dv/local-log/index.vue\"),\n meta: { name: \"local-log\" },\n });\n\n this.msAppClientChangeEvent.on(({ msAppClient }) => {\n if (!msAppClient) {\n return;\n }\n\n const vueRouter = msAppClient.vueRouter;\n const vueRoutes = vueRouter.getRoutes();\n\n const addedNormalPageNames: string[] = [];\n\n for (const normalPage of this.normalPages) {\n const vueRoute = vueRoutes.find(\n (vueRoute) => vueRoute.name === normalPage.name\n );\n\n if (!vueRoute) {\n addedNormalPageNames.push(normalPage.name as string);\n vueRouter.addRoute(normalPage);\n }\n }\n\n this.msAppClientDisposable?.register(\n createDisposable(() => {\n for (const addedNormalPageName of addedNormalPageNames) {\n vueRouter.removeRoute(addedNormalPageName);\n }\n })\n );\n\n this.msAppClientDisposable?.register(\n msAppClient.beforeInitUserSessionEvent.on(({ userSession }) => {\n if (!userSession) {\n return;\n }\n\n const router = userSession.router;\n\n const addedExtendsPageNames: string[] = [];\n\n for (const extendsPage of this.extendsPages) {\n const routeInfo = router.getRouteByName(extendsPage.name as string);\n\n if (!routeInfo) {\n continue;\n }\n\n const vueRoute = vueRoutes.find(\n (vueRoute) => vueRoute.name === extendsPage.name\n );\n\n if (!vueRoute) {\n extendsPage.path = routeInfo.route || extendsPage.path;\n addedExtendsPageNames.push(extendsPage.name as string);\n vueRouter.addRoute(\"mk-ms-layout\", extendsPage);\n }\n }\n\n if (!this.extendsPages.find((page) => page.name === \"notFound\")) {\n this.addExtendsPage({\n name: \"notFound\",\n // path: \":pathMatch(.*)*\",\n path: \"\",\n component: () => import(\"../page/index/404.vue\"),\n });\n }\n\n userSession.register(\n createDisposable(() => {\n for (const addedExtendsPageName of addedExtendsPageNames) {\n vueRouter.removeRoute(addedExtendsPageName);\n }\n })\n );\n })\n );\n });\n }\n}\n"],"names":["vueRoute"],"mappings":"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"}
|
package/dist/esm/core/Router.js
CHANGED
|
@@ -31,7 +31,7 @@ class Router extends Disposable {
|
|
|
31
31
|
case "normal":
|
|
32
32
|
vueRouter.addRoute("mk-ms-layout", {
|
|
33
33
|
name: defaultPageRoute.name,
|
|
34
|
-
path: `/dv/${name}`,
|
|
34
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
35
35
|
component: () => import('../page/index/dv/default/single/list/normal.vue.js'),
|
|
36
36
|
meta: { name }
|
|
37
37
|
});
|
|
@@ -39,7 +39,7 @@ class Router extends Disposable {
|
|
|
39
39
|
case "dialog":
|
|
40
40
|
vueRouter.addRoute("mk-ms-layout", {
|
|
41
41
|
name: defaultPageRoute.name,
|
|
42
|
-
path: `/dv/${name}`,
|
|
42
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
43
43
|
component: () => import('../page/index/dv/default/single/list/dialog.vue.js'),
|
|
44
44
|
meta: { name }
|
|
45
45
|
});
|
|
@@ -51,7 +51,7 @@ class Router extends Disposable {
|
|
|
51
51
|
case "dialog":
|
|
52
52
|
vueRouter.addRoute("mk-ms-layout", {
|
|
53
53
|
name: defaultPageRoute.name,
|
|
54
|
-
path: `/dv/${name}`,
|
|
54
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
55
55
|
component: () => import('../page/index/dv/default/single/tree/dialog.vue.js'),
|
|
56
56
|
meta: { name }
|
|
57
57
|
});
|
|
@@ -63,7 +63,7 @@ class Router extends Disposable {
|
|
|
63
63
|
case "dialog":
|
|
64
64
|
vueRouter.addRoute("mk-ms-layout", {
|
|
65
65
|
name: defaultPageRoute.name,
|
|
66
|
-
path: `/dv/${name}`,
|
|
66
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
67
67
|
component: () => import('../page/index/dv/default/single/table-tree/dialog.vue.js'),
|
|
68
68
|
meta: { name }
|
|
69
69
|
});
|
|
@@ -74,7 +74,7 @@ class Router extends Disposable {
|
|
|
74
74
|
case "list":
|
|
75
75
|
vueRouter.addRoute("mk-ms-layout", {
|
|
76
76
|
name: defaultPageRoute.name,
|
|
77
|
-
path: `/dv/${name}`,
|
|
77
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
78
78
|
component: () => import('../page/index/dv/default/table.vue.js'),
|
|
79
79
|
meta: { name }
|
|
80
80
|
});
|
|
@@ -82,7 +82,7 @@ class Router extends Disposable {
|
|
|
82
82
|
case "edit":
|
|
83
83
|
vueRouter.addRoute("mk-ms-layout", {
|
|
84
84
|
name: defaultPageRoute.name,
|
|
85
|
-
path: `/dv/${name}/:id`,
|
|
85
|
+
path: defaultPageRoute.route || `/dv/${name}/:id`,
|
|
86
86
|
component: () => import('../page/index/dv/default/edit.vue.js'),
|
|
87
87
|
meta: { name }
|
|
88
88
|
});
|
|
@@ -90,7 +90,7 @@ class Router extends Disposable {
|
|
|
90
90
|
case "add":
|
|
91
91
|
vueRouter.addRoute("mk-ms-layout", {
|
|
92
92
|
name: defaultPageRoute.name,
|
|
93
|
-
path: `/dv/${name}/add`,
|
|
93
|
+
path: defaultPageRoute.route || `/dv/${name}/add`,
|
|
94
94
|
component: () => import('../page/index/dv/default/add.vue.js'),
|
|
95
95
|
meta: { name }
|
|
96
96
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Router.js","sources":["../../../src/core/Router.ts"],"sourcesContent":["import { Disposable, Event, createDisposable } from \"@maketribe/utils\";\nimport { Route } from \"../dataview\";\nimport type { UserSession } from \"./UserSession\";\n\nconst NORMALIZE_ROUTE_NAME_REG = /^dv\\/([^/]+)\\/([^/]+)(\\/.+)?$/;\n\nexport class Router extends Disposable {\n userSession: UserSession;\n\n routes: Route[] = [];\n\n constructor(userSession: UserSession) {\n super();\n\n this.userSession = userSession;\n }\n\n setRoutes(routes: Route[]) {\n this.routes = routes;\n }\n\n init() {\n const vueRouter = this.userSession.vueRouter;\n const vueRoutes = vueRouter.getRoutes();\n\n // 给有权限访问的页面,注册默认页面\n const defaultPageRoutes = this.routes.filter(\n (route) => !vueRoutes.find((item) => item.name === route.name)\n );\n\n for (const defaultPageRoute of defaultPageRoutes) {\n const match = defaultPageRoute.name.match(NORMALIZE_ROUTE_NAME_REG);\n\n if (match) {\n const name = match[1];\n const action = match[2];\n\n switch (action) {\n case \"single\":\n const [listType, type] = match[3].slice(1).split(\"/\");\n\n switch (listType) {\n case \"list\":\n switch (type) {\n case \"normal\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/list/normal.vue\"\n ),\n meta: { name },\n });\n break;\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/list/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n\n break;\n case \"tree\":\n switch (type) {\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/tree/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n break;\n case \"table-tree\":\n switch (type) {\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/table-tree/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n }\n\n break;\n case \"list\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () => import(\"../page/index/dv/default/table.vue\"),\n meta: { name },\n });\n break;\n case \"edit\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}/:id`,\n component: () => import(\"../page/index/dv/default/edit.vue\"),\n meta: { name },\n });\n break;\n case \"add\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}/add`,\n component: () => import(\"../page/index/dv/default/add.vue\"),\n meta: { name },\n });\n break;\n }\n }\n }\n\n this.register(\n createDisposable(() => {\n for (const defaultPageRoute of defaultPageRoutes) {\n vueRouter.removeRoute(defaultPageRoute.name);\n }\n })\n );\n }\n\n getRouteByName(name: string): Route | null {\n return this.routes.find((route) => route.name === name) ?? null;\n }\n\n getRouteByID(id: string): Route | null {\n return this.routes.find((route) => route.id === id) ?? null;\n }\n\n getRoutesByMenuID(menuId: Route[\"menuId\"]): Route[] {\n return this.routes.filter((route) => route.menuId === menuId);\n }\n}\n"],"names":[],"mappings":";;AAIA,MAAM,wBAA2B,GAAA,+BAAA,CAAA;AAE1B,MAAM,eAAe,UAAW,CAAA;AAAA,EACrC,WAAA,CAAA;AAAA,EAEA,SAAkB,EAAC,CAAA;AAAA,EAEnB,YAAY,WAA0B,EAAA;AACpC,IAAM,KAAA,EAAA,CAAA;AAEN,IAAA,IAAA,CAAK,WAAc,GAAA,WAAA,CAAA;AAAA,GACrB;AAAA,EAEA,UAAU,MAAiB,EAAA;AACzB,IAAA,IAAA,CAAK,MAAS,GAAA,MAAA,CAAA;AAAA,GAChB;AAAA,EAEA,IAAO,GAAA;AACL,IAAM,MAAA,SAAA,GAAY,KAAK,WAAY,CAAA,SAAA,CAAA;AACnC,IAAM,MAAA,SAAA,GAAY,UAAU,SAAU,EAAA,CAAA;AAGtC,IAAM,MAAA,iBAAA,GAAoB,KAAK,MAAO,CAAA,MAAA;AAAA,MACpC,CAAC,KAAU,KAAA,CAAC,SAAU,CAAA,IAAA,CAAK,CAAC,IAAS,KAAA,IAAA,CAAK,IAAS,KAAA,KAAA,CAAM,IAAI,CAAA;AAAA,KAC/D,CAAA;AAEA,IAAA,KAAA,MAAW,oBAAoB,iBAAmB,EAAA;AAChD,MAAA,MAAM,KAAQ,GAAA,gBAAA,CAAiB,IAAK,CAAA,KAAA,CAAM,wBAAwB,CAAA,CAAA;AAElE,MAAA,IAAI,KAAO,EAAA;AACT,QAAM,MAAA,IAAA,GAAO,MAAM,CAAC,CAAA,CAAA;AACpB,QAAM,MAAA,MAAA,GAAS,MAAM,CAAC,CAAA,CAAA;AAEtB,QAAA,QAAQ,MAAQ;AAAA,UACd,KAAK,QAAA;AACH,YAAM,MAAA,CAAC,QAAU,EAAA,IAAI,CAAI,GAAA,KAAA,CAAM,CAAC,CAAA,CAAE,KAAM,CAAA,CAAC,CAAE,CAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAEpD,YAAA,QAAQ,QAAU;AAAA,cAChB,KAAK,MAAA;AACH,gBAAA,QAAQ,IAAM;AAAA,kBACZ,KAAK,QAAA;AACH,oBAAA,SAAA,CAAU,SAAS,cAAgB,EAAA;AAAA,sBACjC,MAAM,gBAAiB,CAAA,IAAA;AAAA,sBACvB,IAAA,
|
|
1
|
+
{"version":3,"file":"Router.js","sources":["../../../src/core/Router.ts"],"sourcesContent":["import { Disposable, Event, createDisposable } from \"@maketribe/utils\";\nimport { Route } from \"../dataview\";\nimport type { UserSession } from \"./UserSession\";\n\nconst NORMALIZE_ROUTE_NAME_REG = /^dv\\/([^/]+)\\/([^/]+)(\\/.+)?$/;\n\nexport class Router extends Disposable {\n userSession: UserSession;\n\n routes: Route[] = [];\n\n constructor(userSession: UserSession) {\n super();\n\n this.userSession = userSession;\n }\n\n setRoutes(routes: Route[]) {\n this.routes = routes;\n }\n\n init() {\n const vueRouter = this.userSession.vueRouter;\n const vueRoutes = vueRouter.getRoutes();\n\n // 给有权限访问的页面,注册默认页面\n const defaultPageRoutes = this.routes.filter(\n (route) => !vueRoutes.find((item) => item.name === route.name)\n );\n\n for (const defaultPageRoute of defaultPageRoutes) {\n const match = defaultPageRoute.name.match(NORMALIZE_ROUTE_NAME_REG);\n\n if (match) {\n const name = match[1];\n const action = match[2];\n\n switch (action) {\n case \"single\":\n const [listType, type] = match[3].slice(1).split(\"/\");\n\n switch (listType) {\n case \"list\":\n switch (type) {\n case \"normal\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: defaultPageRoute.route || `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/list/normal.vue\"\n ),\n meta: { name },\n });\n break;\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: defaultPageRoute.route || `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/list/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n\n break;\n case \"tree\":\n switch (type) {\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: defaultPageRoute.route || `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/tree/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n break;\n case \"table-tree\":\n switch (type) {\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: defaultPageRoute.route || `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/table-tree/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n }\n\n break;\n case \"list\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: defaultPageRoute.route || `/dv/${name}`,\n component: () => import(\"../page/index/dv/default/table.vue\"),\n meta: { name },\n });\n break;\n case \"edit\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: defaultPageRoute.route || `/dv/${name}/:id`,\n component: () => import(\"../page/index/dv/default/edit.vue\"),\n meta: { name },\n });\n break;\n case \"add\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: defaultPageRoute.route || `/dv/${name}/add`,\n component: () => import(\"../page/index/dv/default/add.vue\"),\n meta: { name },\n });\n break;\n }\n }\n }\n\n this.register(\n createDisposable(() => {\n for (const defaultPageRoute of defaultPageRoutes) {\n vueRouter.removeRoute(defaultPageRoute.name);\n }\n })\n );\n }\n\n getRouteByName(name: string): Route | null {\n return this.routes.find((route) => route.name === name) ?? null;\n }\n\n getRouteByID(id: string): Route | null {\n return this.routes.find((route) => route.id === id) ?? null;\n }\n\n getRoutesByMenuID(menuId: Route[\"menuId\"]): Route[] {\n return this.routes.filter((route) => route.menuId === menuId);\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -7,7 +7,7 @@ export type RouteResult = {
|
|
|
7
7
|
type: number;
|
|
8
8
|
menuId: string;
|
|
9
9
|
iconName: string;
|
|
10
|
-
|
|
10
|
+
route?: string;
|
|
11
11
|
};
|
|
12
12
|
export type Route = {
|
|
13
13
|
id: string;
|
|
@@ -16,7 +16,7 @@ export type Route = {
|
|
|
16
16
|
type: RouteType;
|
|
17
17
|
menuId: string;
|
|
18
18
|
iconName: string;
|
|
19
|
-
|
|
19
|
+
route: string;
|
|
20
20
|
};
|
|
21
21
|
export declare class RouteForm extends DataForm<RouteResult, Route> {
|
|
22
22
|
constructor(options?: DataFormOptions);
|
|
@@ -28,7 +28,7 @@ class RouteForm extends DataForm {
|
|
|
28
28
|
label: "\u56FE\u6807",
|
|
29
29
|
componentInfo: "MKFormIconSelect"
|
|
30
30
|
}),
|
|
31
|
-
new FormColumn({ name: "
|
|
31
|
+
new FormColumn({ name: "route", label: "\u8DEF\u5F84" }),
|
|
32
32
|
new FormColumn({
|
|
33
33
|
name: "type",
|
|
34
34
|
label: "\u8DEF\u7531\u7C7B\u578B",
|
|
@@ -60,7 +60,7 @@ class RouteForm extends DataForm {
|
|
|
60
60
|
type: `${item.type}` === RouteType.ROUTE ? RouteType.ROUTE : RouteType.LINK,
|
|
61
61
|
menuId: item.menuId,
|
|
62
62
|
iconName: item.iconName || "",
|
|
63
|
-
|
|
63
|
+
route: item.route || ""
|
|
64
64
|
};
|
|
65
65
|
}
|
|
66
66
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RouteForm.js","sources":["../../../../src/dataview/route/RouteForm.ts"],"sourcesContent":["import { DataForm, DataFormOptions, FormColumn } from \"@maketribe/dm\";\nimport { defineDataForm } from \"../../define-data-form\";\nimport { RouteType } from \"../../constants\";\nimport { MenuTable } from \"../menu/MenuTable\";\n\nexport type RouteResult = {\n id: string;\n name: string;\n title: string;\n type: number;\n menuId: string;\n iconName: string;\n
|
|
1
|
+
{"version":3,"file":"RouteForm.js","sources":["../../../../src/dataview/route/RouteForm.ts"],"sourcesContent":["import { DataForm, DataFormOptions, FormColumn } from \"@maketribe/dm\";\nimport { defineDataForm } from \"../../define-data-form\";\nimport { RouteType } from \"../../constants\";\nimport { MenuTable } from \"../menu/MenuTable\";\n\nexport type RouteResult = {\n id: string;\n name: string;\n title: string;\n type: number;\n menuId: string;\n iconName: string;\n route?: string;\n};\n\nexport type Route = {\n id: string;\n name: string;\n title: string;\n type: RouteType;\n menuId: string;\n iconName: string;\n route: string;\n};\n\nexport class RouteForm extends DataForm<RouteResult, Route> {\n constructor(options: DataFormOptions = {}) {\n super({ name: \"ms-route\", ...options });\n }\n\n protected async initialize() {\n await super.initialize();\n\n this.setColumns([\n new FormColumn({ name: \"id\", label: \"编号\" }),\n new FormColumn({ name: \"name\", label: \"路由名\", required: true }),\n new FormColumn({ name: \"title\", label: \"路由描述\", required: true }),\n new FormColumn({\n name: \"menuId\",\n label: \"所属菜单\",\n componentInfo: \"MKFormDataTableSelect\",\n required: true,\n componentProps: {\n labelFieldName: \"title\",\n dataTable: new MenuTable({ pageSize: 10 }),\n },\n }),\n new FormColumn({\n name: \"iconName\",\n label: \"图标\",\n componentInfo: \"MKFormIconSelect\",\n }),\n new FormColumn({ name: \"route\", label: \"路径\" }),\n new FormColumn({\n name: \"type\",\n label: \"路由类型\",\n defaultValue: RouteType.ROUTE,\n componentInfo: \"MKFormDataSelect\",\n required: true,\n componentProps: {\n options: [\n { value: RouteType.ROUTE, label: \"站内路由\" },\n { value: RouteType.LINK, label: \"站外链接\" },\n ],\n },\n }),\n ]);\n }\n\n formatSubmitData(data: any) {\n const type = Number.parseInt(data.type);\n\n return {\n ...data,\n iconName: data.iconName || null,\n type: Number.isNaN(type) ? RouteType.ROUTE : type,\n };\n }\n\n formatItem(item: RouteResult): Route {\n return {\n id: item.id,\n name: item.name || \"\",\n title: item.title || \"\",\n type:\n `${item.type}` === RouteType.ROUTE ? RouteType.ROUTE : RouteType.LINK,\n menuId: item.menuId,\n iconName: item.iconName || \"\",\n route: item.route || \"\",\n };\n }\n}\n\ndefineDataForm(RouteForm);\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RouteTable.js","sources":["../../../../src/dataview/route/RouteTable.ts"],"sourcesContent":["import {\n DataTable,\n DataTableOptions,\n TableColumn,\n FilterColumn,\n TableActionColumn,\n} from \"@maketribe/dm\";\nimport { defineDataTable } from \"../../define-data-table\";\nimport { Route, RouteResult } from \"./RouteForm\";\nimport { RouteType } from \"../../constants\";\n\nexport class RouteTable extends DataTable<RouteResult, Route> {\n constructor(options: DataTableOptions = {}) {\n super({ name: \"ms-route\", ...options });\n }\n\n protected async initialize() {\n await super.initialize();\n\n this.dataFilter.setColumns([\n new FilterColumn({\n name: \"name\",\n label: \"路由名\",\n componentInfo: \"MKConditionInput\",\n }),\n new FilterColumn({\n name: \"title\",\n label: \"路由描述\",\n componentInfo: \"MKConditionInput\",\n }),\n new FilterColumn({\n name: \"type\",\n label: \"路由类型\",\n componentInfo: \"MKConditionSelect\",\n componentProps: {\n options: [\n { value: 0, label: \"站内路由\" },\n { value: 1, label: \"站外链接\" },\n ],\n },\n }),\n ]);\n\n this.setColumns([\n new TableColumn({ name: \"id\", label: \"编号\", visible: false }),\n new TableColumn({ name: \"name\", label: \"路由名\" }),\n new TableColumn({ name: \"title\", label: \"路由描述\" }),\n new TableColumn({\n name: \"type\",\n label: \"路由类型\",\n componentInfo: \"MKColumnObjectMappingText\",\n componentProps: {\n mapping: { 0: \"站内路由\", 1: \"站外链接\" },\n },\n }),\n new TableActionColumn(),\n ]);\n }\n\n formatItem(item: RouteResult): Route {\n return {\n id: item.id,\n name: item.name || \"\",\n title: item.title || \"\",\n type: item.type === 0 ? RouteType.ROUTE : RouteType.LINK,\n menuId: item.menuId,\n iconName: item.iconName || \"\",\n
|
|
1
|
+
{"version":3,"file":"RouteTable.js","sources":["../../../../src/dataview/route/RouteTable.ts"],"sourcesContent":["import {\n DataTable,\n DataTableOptions,\n TableColumn,\n FilterColumn,\n TableActionColumn,\n} from \"@maketribe/dm\";\nimport { defineDataTable } from \"../../define-data-table\";\nimport { Route, RouteResult } from \"./RouteForm\";\nimport { RouteType } from \"../../constants\";\n\nexport class RouteTable extends DataTable<RouteResult, Route> {\n constructor(options: DataTableOptions = {}) {\n super({ name: \"ms-route\", ...options });\n }\n\n protected async initialize() {\n await super.initialize();\n\n this.dataFilter.setColumns([\n new FilterColumn({\n name: \"name\",\n label: \"路由名\",\n componentInfo: \"MKConditionInput\",\n }),\n new FilterColumn({\n name: \"title\",\n label: \"路由描述\",\n componentInfo: \"MKConditionInput\",\n }),\n new FilterColumn({\n name: \"type\",\n label: \"路由类型\",\n componentInfo: \"MKConditionSelect\",\n componentProps: {\n options: [\n { value: 0, label: \"站内路由\" },\n { value: 1, label: \"站外链接\" },\n ],\n },\n }),\n ]);\n\n this.setColumns([\n new TableColumn({ name: \"id\", label: \"编号\", visible: false }),\n new TableColumn({ name: \"name\", label: \"路由名\" }),\n new TableColumn({ name: \"title\", label: \"路由描述\" }),\n new TableColumn({\n name: \"type\",\n label: \"路由类型\",\n componentInfo: \"MKColumnObjectMappingText\",\n componentProps: {\n mapping: { 0: \"站内路由\", 1: \"站外链接\" },\n },\n }),\n new TableActionColumn(),\n ]);\n }\n\n formatItem(item: RouteResult): Route {\n return {\n id: item.id,\n name: item.name || \"\",\n title: item.title || \"\",\n type: item.type === 0 ? RouteType.ROUTE : RouteType.LINK,\n menuId: item.menuId,\n iconName: item.iconName || \"\",\n route: item.route || \"\",\n };\n }\n}\n\ndefineDataTable(RouteTable);\n"],"names":[],"mappings":";;;;AAWO,MAAM,mBAAmB,SAA8B,CAAA;AAAA,EAC5D,WAAA,CAAY,OAA4B,GAAA,EAAI,EAAA;AAC1C,IAAA,KAAA,CAAM,EAAE,IAAA,EAAM,UAAY,EAAA,GAAG,SAAS,CAAA,CAAA;AAAA,GACxC;AAAA,EAEA,MAAgB,UAAa,GAAA;AAC3B,IAAA,MAAM,MAAM,UAAW,EAAA,CAAA;AAEvB,IAAA,IAAA,CAAK,WAAW,UAAW,CAAA;AAAA,MACzB,IAAI,YAAa,CAAA;AAAA,QACf,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,oBAAA;AAAA,QACP,aAAe,EAAA,kBAAA;AAAA,OAChB,CAAA;AAAA,MACD,IAAI,YAAa,CAAA;AAAA,QACf,IAAM,EAAA,OAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,kBAAA;AAAA,OAChB,CAAA;AAAA,MACD,IAAI,YAAa,CAAA;AAAA,QACf,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,mBAAA;AAAA,QACf,cAAgB,EAAA;AAAA,UACd,OAAS,EAAA;AAAA,YACP,EAAE,KAAA,EAAO,CAAG,EAAA,KAAA,EAAO,0BAAO,EAAA;AAAA,YAC1B,EAAE,KAAA,EAAO,CAAG,EAAA,KAAA,EAAO,0BAAO,EAAA;AAAA,WAC5B;AAAA,SACF;AAAA,OACD,CAAA;AAAA,KACF,CAAA,CAAA;AAED,IAAA,IAAA,CAAK,UAAW,CAAA;AAAA,MACd,IAAI,YAAY,EAAE,IAAA,EAAM,MAAM,KAAO,EAAA,cAAA,EAAM,OAAS,EAAA,KAAA,EAAO,CAAA;AAAA,MAC3D,IAAI,WAAY,CAAA,EAAE,MAAM,MAAQ,EAAA,KAAA,EAAO,sBAAO,CAAA;AAAA,MAC9C,IAAI,WAAY,CAAA,EAAE,MAAM,OAAS,EAAA,KAAA,EAAO,4BAAQ,CAAA;AAAA,MAChD,IAAI,WAAY,CAAA;AAAA,QACd,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,2BAAA;AAAA,QACf,cAAgB,EAAA;AAAA,UACd,OAAS,EAAA,EAAE,CAAG,EAAA,0BAAA,EAAQ,GAAG,0BAAO,EAAA;AAAA,SAClC;AAAA,OACD,CAAA;AAAA,MACD,IAAI,iBAAkB,EAAA;AAAA,KACvB,CAAA,CAAA;AAAA,GACH;AAAA,EAEA,WAAW,IAA0B,EAAA;AACnC,IAAO,OAAA;AAAA,MACL,IAAI,IAAK,CAAA,EAAA;AAAA,MACT,IAAA,EAAM,KAAK,IAAQ,IAAA,EAAA;AAAA,MACnB,KAAA,EAAO,KAAK,KAAS,IAAA,EAAA;AAAA,MACrB,MAAM,IAAK,CAAA,IAAA,KAAS,CAAI,GAAA,SAAA,CAAU,QAAQ,SAAU,CAAA,IAAA;AAAA,MACpD,QAAQ,IAAK,CAAA,MAAA;AAAA,MACb,QAAA,EAAU,KAAK,QAAY,IAAA,EAAA;AAAA,MAC3B,KAAA,EAAO,KAAK,KAAS,IAAA,EAAA;AAAA,KACvB,CAAA;AAAA,GACF;AACF,CAAA;AAEA,eAAA,CAAgB,UAAU,CAAA;;;;"}
|
|
@@ -45,7 +45,7 @@ const initApplication = async (options) => {
|
|
|
45
45
|
})
|
|
46
46
|
);
|
|
47
47
|
for (const route of routes) {
|
|
48
|
-
if (route.key.startsWith("index
|
|
48
|
+
if (route.key.startsWith("index")) {
|
|
49
49
|
msAppClient.pageManager.addExtendsPage(route);
|
|
50
50
|
} else {
|
|
51
51
|
msAppClient.pageManager.addNormalPage(route);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init-application.js","sources":["../../src/init-application.ts"],"sourcesContent":["import { App, reactive } from \"vue\";\nimport {\n createRouter,\n createWebHashHistory,\n Router as VueRouter,\n} from \"vue-router\";\nimport { MSAppClient } from \"./core\";\nimport { HttpRequest, WebHttpRequest } from \"@maketribe/request\";\nimport { MSAPPCLIENT_CONTEXT_KEY } from \"./tokens\";\n\nimport { generateRoutesFromFiles } from \"./utils\";\nimport {\n DataFilterComponents,\n DataFormComponents,\n DataTableComponents,\n} from \"./core\";\n\nexport type InitMsApplicationOptions = {\n routes: any;\n vueRouter?: VueRouter;\n app: App;\n appID: string;\n logo?: string;\n projectName: string;\n locale?: string;\n httpRequest?: HttpRequest;\n};\n\nexport const initApplication = async (options: InitMsApplicationOptions) => {\n const app = options.app;\n\n const vueRouter =\n options.vueRouter ??\n createRouter({\n history: createWebHashHistory(),\n routes: [],\n });\n\n const msAppClient = reactive(\n new MSAppClient({\n appID: options!.appID,\n logo: options!.logo ?? \"\",\n projectName: options!.projectName,\n httpRequest: options.httpRequest ?? new WebHttpRequest(),\n origin: location.origin,\n locale: options!.locale,\n vueRouter,\n dataTableComponents: new DataTableComponents(),\n dataFormComponents: new DataFormComponents(),\n dataFilterComponents: new DataFilterComponents(),\n whereFilterComponents: new DataFilterComponents(),\n })\n ) as unknown as MSAppClient;\n\n app.provide(MSAPPCLIENT_CONTEXT_KEY, { msAppClient });\n\n MSAppClient.instance = msAppClient;\n\n (window as any).msAppClient = msAppClient;\n\n const routes = generateRoutesFromFiles(\n Object.keys(options.routes).map((key) => {\n return {\n path: key.replace(/^\\.\\/pages\\/(.+)\\.vue$/, (_, g) => g),\n module: options.routes[key]?.default || options.routes[key],\n };\n })\n );\n\n for (const route of routes) {\n if (route.key.startsWith(\"index
|
|
1
|
+
{"version":3,"file":"init-application.js","sources":["../../src/init-application.ts"],"sourcesContent":["import { App, reactive } from \"vue\";\nimport {\n createRouter,\n createWebHashHistory,\n Router as VueRouter,\n} from \"vue-router\";\nimport { MSAppClient } from \"./core\";\nimport { HttpRequest, WebHttpRequest } from \"@maketribe/request\";\nimport { MSAPPCLIENT_CONTEXT_KEY } from \"./tokens\";\n\nimport { generateRoutesFromFiles } from \"./utils\";\nimport {\n DataFilterComponents,\n DataFormComponents,\n DataTableComponents,\n} from \"./core\";\n\nexport type InitMsApplicationOptions = {\n routes: any;\n vueRouter?: VueRouter;\n app: App;\n appID: string;\n logo?: string;\n projectName: string;\n locale?: string;\n httpRequest?: HttpRequest;\n};\n\nexport const initApplication = async (options: InitMsApplicationOptions) => {\n const app = options.app;\n\n const vueRouter =\n options.vueRouter ??\n createRouter({\n history: createWebHashHistory(),\n routes: [],\n });\n\n const msAppClient = reactive(\n new MSAppClient({\n appID: options!.appID,\n logo: options!.logo ?? \"\",\n projectName: options!.projectName,\n httpRequest: options.httpRequest ?? new WebHttpRequest(),\n origin: location.origin,\n locale: options!.locale,\n vueRouter,\n dataTableComponents: new DataTableComponents(),\n dataFormComponents: new DataFormComponents(),\n dataFilterComponents: new DataFilterComponents(),\n whereFilterComponents: new DataFilterComponents(),\n })\n ) as unknown as MSAppClient;\n\n app.provide(MSAPPCLIENT_CONTEXT_KEY, { msAppClient });\n\n MSAppClient.instance = msAppClient;\n\n (window as any).msAppClient = msAppClient;\n\n const routes = generateRoutesFromFiles(\n Object.keys(options.routes).map((key) => {\n return {\n path: key.replace(/^\\.\\/pages\\/(.+)\\.vue$/, (_, g) => g),\n module: options.routes[key]?.default || options.routes[key],\n };\n })\n );\n\n for (const route of routes) {\n if (route.key.startsWith(\"index\")) {\n msAppClient.pageManager.addExtendsPage(route);\n } else {\n msAppClient.pageManager.addNormalPage(route);\n }\n }\n\n await msAppClient.init();\n\n app.use(msAppClient.vueRouter);\n\n return msAppClient;\n};\n"],"names":[],"mappings":";;;;;;;;;;;;;;AA4Ba,MAAA,eAAA,GAAkB,OAAO,OAAsC,KAAA;AAC1E,EAAA,MAAM,MAAM,OAAQ,CAAA,GAAA,CAAA;AAEpB,EAAM,MAAA,SAAA,GACJ,OAAQ,CAAA,SAAA,IACR,YAAa,CAAA;AAAA,IACX,SAAS,oBAAqB,EAAA;AAAA,IAC9B,QAAQ,EAAC;AAAA,GACV,CAAA,CAAA;AAEH,EAAA,MAAM,WAAc,GAAA,QAAA;AAAA,IAClB,IAAI,WAAY,CAAA;AAAA,MACd,OAAO,OAAS,CAAA,KAAA;AAAA,MAChB,IAAA,EAAM,QAAS,IAAQ,IAAA,EAAA;AAAA,MACvB,aAAa,OAAS,CAAA,WAAA;AAAA,MACtB,WAAa,EAAA,OAAA,CAAQ,WAAe,IAAA,IAAI,cAAe,EAAA;AAAA,MACvD,QAAQ,QAAS,CAAA,MAAA;AAAA,MACjB,QAAQ,OAAS,CAAA,MAAA;AAAA,MACjB,SAAA;AAAA,MACA,mBAAA,EAAqB,IAAI,mBAAoB,EAAA;AAAA,MAC7C,kBAAA,EAAoB,IAAI,kBAAmB,EAAA;AAAA,MAC3C,oBAAA,EAAsB,IAAI,oBAAqB,EAAA;AAAA,MAC/C,qBAAA,EAAuB,IAAI,oBAAqB,EAAA;AAAA,KACjD,CAAA;AAAA,GACH,CAAA;AAEA,EAAA,GAAA,CAAI,OAAQ,CAAA,uBAAA,EAAyB,EAAE,WAAA,EAAa,CAAA,CAAA;AAEpD,EAAA,WAAA,CAAY,QAAW,GAAA,WAAA,CAAA;AAEvB,EAAC,OAAe,WAAc,GAAA,WAAA,CAAA;AAE9B,EAAA,MAAM,MAAS,GAAA,uBAAA;AAAA,IACb,OAAO,IAAK,CAAA,OAAA,CAAQ,MAAM,CAAE,CAAA,GAAA,CAAI,CAAC,GAAQ,KAAA;AACvC,MAAO,OAAA;AAAA,QACL,MAAM,GAAI,CAAA,OAAA,CAAQ,0BAA0B,CAAC,CAAA,EAAG,MAAM,CAAC,CAAA;AAAA,QACvD,MAAA,EAAQ,QAAQ,MAAO,CAAA,GAAG,GAAG,OAAW,IAAA,OAAA,CAAQ,OAAO,GAAG,CAAA;AAAA,OAC5D,CAAA;AAAA,KACD,CAAA;AAAA,GACH,CAAA;AAEA,EAAA,KAAA,MAAW,SAAS,MAAQ,EAAA;AAC1B,IAAA,IAAI,KAAM,CAAA,GAAA,CAAI,UAAW,CAAA,OAAO,CAAG,EAAA;AACjC,MAAY,WAAA,CAAA,WAAA,CAAY,eAAe,KAAK,CAAA,CAAA;AAAA,KACvC,MAAA;AACL,MAAY,WAAA,CAAA,WAAA,CAAY,cAAc,KAAK,CAAA,CAAA;AAAA,KAC7C;AAAA,GACF;AAEA,EAAA,MAAM,YAAY,IAAK,EAAA,CAAA;AAEvB,EAAI,GAAA,CAAA,GAAA,CAAI,YAAY,SAAS,CAAA,CAAA;AAE7B,EAAO,OAAA,WAAA,CAAA;AACT;;;;"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { NodeType, NodeProp, IterMode, Tree, TreeFragment, Parser } from '../../../../../@lezer_common@1.1.1/node_modules/@lezer/common/dist/index.js';
|
|
2
|
-
import { Facet, StateField, EditorState,
|
|
3
|
-
import { EditorView, ViewPlugin,
|
|
2
|
+
import { Facet, StateField, EditorState, StateEffect, RangeSet, countColumn, combineConfig, RangeSetBuilder, Prec } from '../../../../../@codemirror_state@6.3.2/node_modules/@codemirror/state/dist/index.js';
|
|
3
|
+
import { EditorView, ViewPlugin, logException, gutter, Decoration, WidgetType, GutterMarker } from '../../../../../@codemirror_view@6.22.1/node_modules/@codemirror/view/dist/index.js';
|
|
4
4
|
import { tags, styleTags, tagHighlighter, highlightTree } from '../../../../../@lezer_highlight@1.2.0/node_modules/@lezer/highlight/dist/index.js';
|
|
5
5
|
import { StyleModule } from '../../../../../style-mod@4.1.0/node_modules/style-mod/src/style-mod.js';
|
|
6
6
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.js","sources":["../../../src/router-middleware/auth.ts"],"sourcesContent":["import { RouteLocationNormalized, RouteLocationRaw } from \"vue-router\";\nimport
|
|
1
|
+
{"version":3,"file":"auth.js","sources":["../../../src/router-middleware/auth.ts"],"sourcesContent":["import { RouteLocationNormalized, RouteLocationRaw } from \"vue-router\";\nimport type { MSAppClient } from \"../core\";\n\nexport const authBeforeEach = async (\n msAppClient: MSAppClient,\n to: RouteLocationNormalized,\n from: RouteLocationNormalized\n): Promise<RouteLocationRaw | void> => {\n if (to.meta.isAuthorization === false) {\n return;\n }\n\n let userSession = msAppClient.userSession;\n\n if (!userSession) {\n try {\n await msAppClient.loadCurrentUserSession();\n\n userSession = msAppClient.userSession;\n\n if (!userSession) {\n return { name: \"login\" };\n }\n\n // 因为登陆成功会添加用户可以访问的路由,这里给到vue-router去重新resolve\n return { path: to.fullPath };\n } catch (e) {\n return { name: \"login\" };\n }\n }\n};\n"],"names":[],"mappings":"AAGO,MAAM,cAAiB,GAAA,OAC5B,WACA,EAAA,EAAA,EACA,IACqC,KAAA;AACrC,EAAI,IAAA,EAAA,CAAG,IAAK,CAAA,eAAA,KAAoB,KAAO,EAAA;AACrC,IAAA,OAAA;AAAA,GACF;AAEA,EAAA,IAAI,cAAc,WAAY,CAAA,WAAA,CAAA;AAE9B,EAAA,IAAI,CAAC,WAAa,EAAA;AAChB,IAAI,IAAA;AACF,MAAA,MAAM,YAAY,sBAAuB,EAAA,CAAA;AAEzC,MAAA,WAAA,GAAc,WAAY,CAAA,WAAA,CAAA;AAE1B,MAAA,IAAI,CAAC,WAAa,EAAA;AAChB,QAAO,OAAA,EAAE,MAAM,OAAQ,EAAA,CAAA;AAAA,OACzB;AAGA,MAAO,OAAA,EAAE,IAAM,EAAA,EAAA,CAAG,QAAS,EAAA,CAAA;AAAA,aACpB,CAAG,EAAA;AACV,MAAO,OAAA,EAAE,MAAM,OAAQ,EAAA,CAAA;AAAA,KACzB;AAAA,GACF;AACF;;;;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@maketribe/ms-app",
|
|
3
|
-
"version": "3.0.
|
|
3
|
+
"version": "3.0.17",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "dist/cjs",
|
|
6
6
|
"files": [
|
|
@@ -20,10 +20,10 @@
|
|
|
20
20
|
"vue": "^3.3.4",
|
|
21
21
|
"vue-codemirror": "^6.1.1",
|
|
22
22
|
"vue-router": "^4.2.4",
|
|
23
|
-
"@maketribe/locale": "^1.0.5",
|
|
24
23
|
"@maketribe/dm": "^3.0.9",
|
|
25
|
-
"@maketribe/request": "^1.1.
|
|
26
|
-
"@maketribe/
|
|
24
|
+
"@maketribe/request": "^1.1.11",
|
|
25
|
+
"@maketribe/locale": "^1.0.5",
|
|
26
|
+
"@maketribe/utils": "^1.1.4"
|
|
27
27
|
},
|
|
28
28
|
"scripts": {
|
|
29
29
|
"build": "npm run clean && npm run build:js && npm run build:type && npm run build:style",
|
|
@@ -1,6 +1,8 @@
|
|
|
1
|
+
import { defineAsyncComponent } from "vue";
|
|
1
2
|
import { withInstall } from "@maketribe/utils";
|
|
2
|
-
import JsonEditor from "./json-editor";
|
|
3
3
|
|
|
4
|
-
export const MKJsonEditor = withInstall(
|
|
4
|
+
export const MKJsonEditor = withInstall(
|
|
5
|
+
defineAsyncComponent(() => import("./json-editor"))
|
|
6
|
+
);
|
|
5
7
|
|
|
6
8
|
export default MKJsonEditor;
|
|
@@ -6,11 +6,16 @@ export interface MKMaterialSelectOptions {
|
|
|
6
6
|
allowMaterialTypeValues: MaterialType["value"][];
|
|
7
7
|
}
|
|
8
8
|
|
|
9
|
+
export type MaterialSelectResult = {
|
|
10
|
+
success: boolean;
|
|
11
|
+
data: Material | null;
|
|
12
|
+
path: string;
|
|
13
|
+
};
|
|
14
|
+
|
|
9
15
|
export interface IMKMaterialSelect {
|
|
10
|
-
(
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
}>;
|
|
16
|
+
(
|
|
17
|
+
options?: MKMaterialSelectOptions,
|
|
18
|
+
appContext?: AppContext
|
|
19
|
+
): Promise<MaterialSelectResult>;
|
|
15
20
|
_context: AppContext | null;
|
|
16
21
|
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { MKMaterialSelect, MaterialSelectResult } from "../material-select";
|
|
2
|
+
import { UploadContext, UploadResult } from "./UploadContext";
|
|
3
|
+
|
|
4
|
+
export class MaterialUploadContext extends UploadContext {
|
|
5
|
+
async selectFile(): Promise<UploadResult> {
|
|
6
|
+
const materialSelectResult = await MKMaterialSelect();
|
|
7
|
+
|
|
8
|
+
return {
|
|
9
|
+
success: materialSelectResult.success,
|
|
10
|
+
path: materialSelectResult.path,
|
|
11
|
+
msg: "",
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { WebFileUpload } from "@maketribe/request";
|
|
2
|
+
import { UploadContext, UploadResult } from "./UploadContext";
|
|
3
|
+
import { MSAppClient } from "../../core";
|
|
4
|
+
|
|
5
|
+
export type WebFileUploadContextOptions = {
|
|
6
|
+
webFileUpload?: WebFileUpload;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
export class WebFileUploadContext extends UploadContext {
|
|
10
|
+
webFileUpload: WebFileUpload;
|
|
11
|
+
|
|
12
|
+
constructor(options: WebFileUploadContextOptions = {}) {
|
|
13
|
+
super();
|
|
14
|
+
|
|
15
|
+
this.webFileUpload =
|
|
16
|
+
options.webFileUpload ??
|
|
17
|
+
new WebFileUpload({
|
|
18
|
+
httpRequest: MSAppClient.instance!.httpRequest,
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
async selectFile(): Promise<UploadResult> {
|
|
23
|
+
const input = document.createElement("input");
|
|
24
|
+
|
|
25
|
+
input.type = "file";
|
|
26
|
+
Object.assign(input.style, {
|
|
27
|
+
width: "1px",
|
|
28
|
+
height: "1px",
|
|
29
|
+
display: "none",
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
const file: File | null = await new Promise((resolve) => {
|
|
33
|
+
const handleFileChange = (event: Event) => {
|
|
34
|
+
const files = input.files;
|
|
35
|
+
|
|
36
|
+
input.parentElement?.removeChild(input);
|
|
37
|
+
|
|
38
|
+
resolve(files?.length ? files[0] : null);
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
input.addEventListener("change", handleFileChange);
|
|
42
|
+
|
|
43
|
+
document.body.append(input);
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
if (!file) {
|
|
47
|
+
return { success: true, path: "", msg: "" };
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
const response = await this.webFileUpload.upload(file);
|
|
51
|
+
|
|
52
|
+
return {
|
|
53
|
+
success: response.data.code === 200,
|
|
54
|
+
path: response.data.data.path,
|
|
55
|
+
msg: response.data.msg,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ExtractPropTypes } from "vue";
|
|
2
|
+
import { buildProps } from "@maketribe/utils";
|
|
3
|
+
import { UploadContext } from "./UploadContext";
|
|
4
|
+
import { MaterialUploadContext } from "./MaterialUploadContext";
|
|
5
|
+
|
|
6
|
+
export const uploadFileProps = buildProps({
|
|
7
|
+
modelValue: {
|
|
8
|
+
type: String,
|
|
9
|
+
required: true,
|
|
10
|
+
},
|
|
11
|
+
uploadContext: {
|
|
12
|
+
type: UploadContext,
|
|
13
|
+
default: () => new MaterialUploadContext(),
|
|
14
|
+
},
|
|
15
|
+
} as const);
|
|
16
|
+
|
|
17
|
+
export type UploadFileProps = ExtractPropTypes<typeof uploadFileProps>;
|
|
18
|
+
|
|
19
|
+
export const uploadFileEmits = {
|
|
20
|
+
"upload:modelValue": (path: string) => true,
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
export type UploadFileEmits = typeof uploadFileEmits;
|