diff --git a/packages/gi-site/src/pages/Dataset/Create.tsx b/packages/gi-site/src/pages/Dataset/Create.tsx index a131261b9..ebf9f9c7d 100644 --- a/packages/gi-site/src/pages/Dataset/Create.tsx +++ b/packages/gi-site/src/pages/Dataset/Create.tsx @@ -68,16 +68,19 @@ const DataSource: React.FunctionComponent = props => { //@ts-ignore const [state, setState] = React.useState<{ - active: string; + activeType: string; + activeEngine?: string; engines: Record; isReady: boolean; }>(() => { const { searchParams, path } = getSearchParams(window.location); - const active = searchParams.get('type') || 'FILE'; + const activeType = searchParams.get('type') || 'FILE'; + const activeEngine = searchParams.get('engine') ?? undefined; return { - active, + activeType, engines: {}, isReady: false, + activeEngine, }; }); @@ -136,7 +139,24 @@ const DataSource: React.FunctionComponent = props => { }); })(); }, []); - const { engines, active, isReady } = state; + const { engines, activeType, activeEngine, isReady } = state; + const currentEngines = engines[state.activeType] || []; + + const handleChangeEngine = (value?: string) => { + const { searchParams, path } = getSearchParams(window.location); + if (value) { + searchParams.set('engine', value); + } else { + searchParams.delete('engine'); + } + window.location.hash = `${path}?${searchParams.toString()}`; + setState(preState => { + return { + ...preState, + activeEngine: value, + }; + }); + }; const handleChangeType = value => { const { searchParams, path } = getSearchParams(window.location); @@ -145,74 +165,88 @@ const DataSource: React.FunctionComponent = props => { setState(preState => { return { ...preState, - active: value, + activeType: value, }; }); + + // 切换类型时同时触发更新引擎选择相关数据 + handleChangeEngine(engines[value]?.[0]?.id); }; - const currentEngines = engines[state.active] || []; + const renderEngineTabs = () => { + const content = currentEngines.map(server => { + const { component: ServerComponent, name } = server; + if (!ServerComponent) { + return null; + } + const { icon } = TYPE_ICONS[server.type || 'api']; - const content = currentEngines.map(server => { - const { component: ServerComponent, name } = server; - if (!ServerComponent) { - return null; - } - const { icon } = TYPE_ICONS[server.type || 'api']; + const TabTitle = ( +
+ {name === $i18n.get({ id: 'gi-site.pages.Dataset.Create.OfficialGVpDataService', dm: 'G6VP 官方数据服务' }) + ? 'GraphJSON' + : name} +
+ ); - const TabTitle = ( -
- {name === $i18n.get({ id: 'gi-site.pages.Dataset.Create.OfficialGVpDataService', dm: 'G6VP 官方数据服务' }) - ? 'GraphJSON' - : name} -
- ); + return ( + + {/** @ts-ignore */} + + + ); + }); return ( - - {/** @ts-ignore */} - - + + {content} + ); - }); - const emptyContent = ( - -
- {$i18n.get({ - id: 'gi-site.pages.Dataset.Create.ThisTypeOfDataSource', - dm: '该类型的数据源还在建设中,请关注我们 github 进展:https://github.com/antvis/G6VP', - })} -
-
+ }; + + const emptyTabs = ( + + +
+ {$i18n.get({ + id: 'gi-site.pages.Dataset.Create.ThisTypeOfDataSource', + dm: '该类型的数据源还在建设中,请关注我们 github 进展:https://github.com/antvis/G6VP', + })} +
+
+
); - const loadingContent = ( - -
- - {$i18n.get({ - id: 'gi-site.pages.Dataset.Create.AssetsIsLoading', - dm: 'Please wait while the asset is loading', - })} -
-
+ const loadingTabs = ( + + +
+ + {$i18n.get({ + id: 'gi-site.pages.Dataset.Create.AssetsIsLoading', + dm: 'Please wait while the asset is loading', + })} +
+
+
); - const renderTabContent = () => { + const renderTabs = () => { if (!isReady) { - return loadingContent; + return loadingTabs; } if (currentEngines.length === 0) { - return emptyContent; + return emptyTabs; } - return content; + return renderEngineTabs(); }; return ( @@ -229,12 +263,12 @@ const DataSource: React.FunctionComponent = props => { - +
- {renderTabContent()} + {renderTabs()}
);