From 6e5afef4dbc6b4b7603a3be753c0d11243695b44 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A4=9C=E9=B9=B0?= <17kungfuboy@gmail.com> Date: Fri, 17 Jun 2022 17:20:28 +0800 Subject: [PATCH] Refactor/import (#75) * feat: delete useless code * feat: projectExport error * feat: delete useless code * feat: projectExport error * feat: update code --- src/app/electron-main/main.ts | 2 + .../group/tree/api-group-tree.component.ts | 32 ++------- .../extension-select.component.html | 3 +- .../extension-select.component.ts | 4 +- .../import-api/import-api.component.ts | 69 ++++++++++--------- .../services/storage/IndexedDB/lib/index.ts | 6 +- .../shared/services/storage/http/lib/index.ts | 1 + .../services/storage/storage.service.ts | 5 +- src/workbench/browser/src/app/utils/index.ts | 4 +- 9 files changed, 58 insertions(+), 68 deletions(-) diff --git a/src/app/electron-main/main.ts b/src/app/electron-main/main.ts index fbd98fd80..678a5bd61 100644 --- a/src/app/electron-main/main.ts +++ b/src/app/electron-main/main.ts @@ -42,6 +42,8 @@ function createWindow(): BrowserWindow { win = new BrowserWindow({ width: Math.round(size.width * 0.85), height: Math.round(size.height * 0.85), + minWidth: 1280, + minHeight: 720, useContentSize: true, // 这个要设置,不然计算显示区域尺寸不准 frame: os.type() === 'Darwin' ? true : false, //mac use default frame webPreferences: { diff --git a/src/workbench/browser/src/app/pages/api/group/tree/api-group-tree.component.ts b/src/workbench/browser/src/app/pages/api/group/tree/api-group-tree.component.ts index f7c922a87..5a505b0a1 100644 --- a/src/workbench/browser/src/app/pages/api/group/tree/api-group-tree.component.ts +++ b/src/workbench/browser/src/app/pages/api/group/tree/api-group-tree.component.ts @@ -160,30 +160,11 @@ export class ApiGroupTreeComponent implements OnInit, OnDestroy { ...(getExpandGroupByKey(this.apiGroup, this.route.snapshot.queryParams.uuid) || []), ]; } - // 重新构建整个group - async rebuildGroupTree(result) { - this.storageInstance.apiData.clear(); - this.storageInstance.group.clear(); + async createGroup({ name, projectID, content }) { + const groupID = await this.storageInstance.group.add({ name, projectID }); + const result = content.apiData.map((it, index) => ({ ...it, groupID, uuid: Date.now() + index })); await this.storageInstance.apiData.bulkAdd(result); - const apiItems = {}; - this.treeItems = []; - result.forEach((item: ApiData) => { - delete item.updatedAt; - apiItems[item.uuid] = item; - this.treeItems.push({ - title: item.name, - key: item.uuid.toString(), - weight: item.weight || 0, - parentID: item.groupID ? `group-${item.groupID}` : '0', - method: item.method, - isLeaf: true, - }); - }); - this.apiDataItems = apiItems; - this.messageService.send({ type: 'loadApi', data: this.apiDataItems }); - this.setSelectedKeys(); - this.generateGroupTreeData(); - this.restoreExpandStatus(); + this.buildGroupTreeData(); } /** @@ -205,8 +186,7 @@ export class ApiGroupTreeComponent implements OnInit, OnDestroy { break; } case 'importSuccess': { - const { apiData } = JSON.parse(inArg.data); - this.rebuildGroupTree(apiData); + this.createGroup({ projectID: 1, ...inArg.data }); } } }); @@ -349,7 +329,7 @@ export class ApiGroupTreeComponent implements OnInit, OnDestroy { 'groupBulkUpdate', [ data.group.map((val) => { - return { ...val, uuid: val.uuid.replace('group-',''), parentID: val.parentID.replace('group-','') }; + return { ...val, uuid: val.uuid.replace('group-', ''), parentID: val.parentID.replace('group-', '') }; }), ], (result: StorageRes) => {} diff --git a/src/workbench/browser/src/app/shared/components/extension-select/extension-select.component.html b/src/workbench/browser/src/app/shared/components/extension-select/extension-select.component.html index 67e57db53..49edc1ec3 100644 --- a/src/workbench/browser/src/app/shared/components/extension-select/extension-select.component.html +++ b/src/workbench/browser/src/app/shared/components/extension-select/extension-select.component.html @@ -35,11 +35,12 @@
- +

点击或直接拖拽文件至此区域

仅支持JSON格式的单个文件导入

+
{{ filename }}
diff --git a/src/workbench/browser/src/app/shared/components/extension-select/extension-select.component.ts b/src/workbench/browser/src/app/shared/components/extension-select/extension-select.component.ts index 298dec609..8dcc83f4e 100644 --- a/src/workbench/browser/src/app/shared/components/extension-select/extension-select.component.ts +++ b/src/workbench/browser/src/app/shared/components/extension-select/extension-select.component.ts @@ -20,6 +20,7 @@ export class ExtensionSelectComponent { @Output() extensionChange = new EventEmitter(); @Output() currentOptionChange = new EventEmitter(); @Output() uploadChange = new EventEmitter(); + filename = ''; selectExtension({ key, properties }) { this.extensionChange.emit(key); @@ -36,7 +37,8 @@ export class ExtensionSelectComponent { parserFile = (file) => new Observable((observer: Observer) => { - parserJsonFile(file).then((result) => { + parserJsonFile(file).then((result: { name: string }) => { + this.filename = result.name; this.uploadChange.emit(result); observer.complete(); }); diff --git a/src/workbench/browser/src/app/shared/components/import-api/import-api.component.ts b/src/workbench/browser/src/app/shared/components/import-api/import-api.component.ts index 3e83e112e..98601847b 100644 --- a/src/workbench/browser/src/app/shared/components/import-api/import-api.component.ts +++ b/src/workbench/browser/src/app/shared/components/import-api/import-api.component.ts @@ -1,17 +1,42 @@ import { Component, OnInit } from '@angular/core'; -import { StorageRes, StorageResStatus } from 'eo/workbench/browser/src/app/shared/services/storage/index.model'; -import { EoMessageService } from 'eo/workbench/browser/src/app/eoui/message/eo-message.service'; -import { StorageService } from '../../../shared/services/storage'; import { FeatureType } from '../../types'; -import { parserProperties, getDefaultValue } from '../../../utils'; import { MessageService } from 'eo/workbench/browser/src/app/shared/services/message/message.service'; +// const optionList = [ +// { +// value: 'import', +// type: 'string', +// default: '', +// label: '直接导入', +// description: '直接导入', +// }, +// { +// value: 'add', +// type: 'string', +// default: true, +// label: '增量更新[推荐]', +// description: '增量更新', +// }, +// { +// value: 'all', +// type: 'string', +// default: '', +// label: '全量更新[慎用]', +// description: '全量更新', +// }, +// { +// value: 'new', +// type: 'string', +// default: '', +// label: '仅添加新 API', +// description: '仅添加新 API', +// }, +// ]; + @Component({ selector: 'eo-import-api', template: ` = []; currentExtension = ''; - currentOption = ''; - optionList = []; uploadData = null; featureMap = window.eo.getFeature('apimanage.import'); - constructor( - private storage: StorageService, - private message: EoMessageService, - private messageService: MessageService - ) {} + constructor(private messageService: MessageService) {} ngOnInit(): void { this.featureMap?.forEach((data: FeatureType, key: string) => { this.supportList.push({ @@ -37,39 +56,25 @@ export class ImportApiComponent implements OnInit { }); }); { - const { key, properties } = this.supportList.at(0); + const { key } = this.supportList.at(0); this.currentExtension = key || ''; - this.optionList = parserProperties(properties || ''); - this.currentOption = getDefaultValue(this.optionList, 'value'); } } - getEoapiData() { - return new Promise((resolve) => { - this.storage.run('projectExport', [], (result: StorageRes) => { - const isOk = result.status === StorageResStatus.success; - resolve(isOk ? [result.data, null] : [null, true]); - }); - }); - } uploadChange(data) { this.uploadData = data; } async submit(callback) { - const [eoapiData, err]: any = await this.getEoapiData(); - if (err) { - this.message.error('获取本地数据失败'); - return; - } // * this.currentExtension is extension's key, like 'eoapi-import-openapi' const feature = this.featureMap.get(this.currentExtension); const action = feature.action || null; const module = window.eo.loadFeatureModule(this.currentExtension); - const data = module[action](eoapiData, this.uploadData, this.currentOption); + const { name, content } = this.uploadData; + const data = module[action](content); + // console.log(JSON.stringify(data, null, 2)); this.messageService.send({ type: 'importSuccess', - data: JSON.stringify(data), + data: { name, content: data }, }); - // console.log(JSON.stringify(data)); callback(true); } } diff --git a/src/workbench/browser/src/app/shared/services/storage/IndexedDB/lib/index.ts b/src/workbench/browser/src/app/shared/services/storage/IndexedDB/lib/index.ts index 29405231d..68c9fd369 100644 --- a/src/workbench/browser/src/app/shared/services/storage/IndexedDB/lib/index.ts +++ b/src/workbench/browser/src/app/shared/services/storage/IndexedDB/lib/index.ts @@ -322,11 +322,11 @@ export class IndexedDBStorage extends Dexie implements StorageInterface { } apiDataLoadAllByGroupID(groupID: number | string): Observable { - return this.loadAllByConditions(this.apiData, { groupID: groupID }); + return this.loadAllByConditions(this.apiData, { groupID }); } apiDataLoadAllByProjectID(projectID: number | string): Observable { - return this.loadAllByConditions(this.apiData, { projectID: projectID }); + return this.loadAllByConditions(this.apiData, { projectID }); } /** @@ -335,7 +335,7 @@ export class IndexedDBStorage extends Dexie implements StorageInterface { * @param groupID */ apiDataLoadAllByProjectIDAndGroupID(projectID: number | string, groupID: number | string): Observable { - return this.loadAllByConditions(this.apiData, { projectID: projectID, groupID: groupID }); + return this.loadAllByConditions(this.apiData, { projectID, groupID }); } /** diff --git a/src/workbench/browser/src/app/shared/services/storage/http/lib/index.ts b/src/workbench/browser/src/app/shared/services/storage/http/lib/index.ts index 671889341..f220c33fe 100644 --- a/src/workbench/browser/src/app/shared/services/storage/http/lib/index.ts +++ b/src/workbench/browser/src/app/shared/services/storage/http/lib/index.ts @@ -54,6 +54,7 @@ export class HttpStorage implements StorageInterface { projectLoad: (uuid: number | string) => Observable; projectBulkLoad: (uuids: Array) => Observable; projectExport() { + console.log('lo', new Error()); return this.http.get(`/project/export`) as Observable; } // Environment diff --git a/src/workbench/browser/src/app/shared/services/storage/storage.service.ts b/src/workbench/browser/src/app/shared/services/storage/storage.service.ts index 1555dd80c..8d0387c63 100644 --- a/src/workbench/browser/src/app/shared/services/storage/storage.service.ts +++ b/src/workbench/browser/src/app/shared/services/storage/storage.service.ts @@ -26,7 +26,8 @@ export class StorageService { * * @param args */ - run = (action: string, params: Array, callback) => { + run(action: string, params: Array, callback): void { + console.log('koko'); const handleResult = { status: StorageResStatus.invalid, data: undefined, @@ -47,7 +48,7 @@ export class StorageService { callback(handleResult); } ); - }; + } setStorage = (type: DataSourceType = 'local', options = {}) => { switch (type) { case 'local': { diff --git a/src/workbench/browser/src/app/utils/index.ts b/src/workbench/browser/src/app/utils/index.ts index 49713503f..fcf45b7d7 100644 --- a/src/workbench/browser/src/app/utils/index.ts +++ b/src/workbench/browser/src/app/utils/index.ts @@ -82,7 +82,7 @@ export const parserJsonFile = (file, type = 'UTF-8') => reader.onload = (ev) => { const fileString: string = ev.target.result as string; const json = JSON.parse(fileString); - resolve(json); + resolve({ name: file.name, content: json }); }; }); @@ -93,5 +93,3 @@ export const getDefaultValue = (list: any[], key) => { const [target] = list.filter((it) => it.default); return target[key] || ''; }; - -export const parserProperties = (properties) => Object.keys(properties).map((it) => ({ value: it, ...properties[it] }));