@next-bricks/nav 0.0.19 → 0.0.21
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/bricks.json +1 -1
- package/dist/chunks/{1646.c102b041.js → 1646.d14961f9.js} +2 -2
- package/dist/chunks/{1646.c102b041.js.map → 1646.d14961f9.js.map} +1 -1
- package/dist/chunks/2784.e2a0bd53.js +1 -0
- package/dist/chunks/{4625.77cc615f.js → 4625.c8be40c2.js} +3 -3
- package/dist/chunks/{4625.77cc615f.js.map → 4625.c8be40c2.js.map} +1 -1
- package/dist/chunks/{752.f1bb3fce.js → 752.ca4288fe.js} +2 -2
- package/dist/chunks/{752.f1bb3fce.js.map → 752.ca4288fe.js.map} +1 -1
- package/dist/chunks/{7746.2d1f8ae8.js → 7746.c6b6602c.js} +2 -2
- package/dist/chunks/{7746.2d1f8ae8.js.map → 7746.c6b6602c.js.map} +1 -1
- package/dist/chunks/9549.706646b9.js +2 -0
- package/dist/chunks/9549.706646b9.js.map +1 -0
- package/dist/chunks/{eo-launchpad-button.62c3c791.js → eo-launchpad-button.31102b8e.js} +2 -2
- package/dist/chunks/{eo-launchpad-button.62c3c791.js.map → eo-launchpad-button.31102b8e.js.map} +1 -1
- package/dist/chunks/{eo-nav-menu.c2b8c2a9.js → eo-nav-menu.cb6f23dd.js} +3 -3
- package/dist/chunks/{eo-nav-menu.c2b8c2a9.js.map → eo-nav-menu.cb6f23dd.js.map} +1 -1
- package/dist/chunks/{main.5e777d0d.js → main.006df992.js} +2 -2
- package/dist/chunks/{main.5e777d0d.js.map → main.006df992.js.map} +1 -1
- package/dist/{index.a4e495e1.js → index.f5000ff9.js} +2 -2
- package/dist/{index.a4e495e1.js.map → index.f5000ff9.js.map} +1 -1
- package/package.json +2 -2
- package/dist/chunks/2784.2d24a0c4.js +0 -1
- package/dist/chunks/9549.bcc281ad.js +0 -2
- package/dist/chunks/9549.bcc281ad.js.map +0 -1
- /package/dist/chunks/{4625.77cc615f.js.LICENSE.txt → 4625.c8be40c2.js.LICENSE.txt} +0 -0
- /package/dist/chunks/{eo-nav-menu.c2b8c2a9.js.LICENSE.txt → eo-nav-menu.cb6f23dd.js.LICENSE.txt} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/4625.77cc615f.js","mappings":"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","sources":["webpack:///./src/nav-menu/ThreeLevelMenuPopoverContent.tsx","webpack:///./src/nav-menu/i18n.ts","webpack:///../../node_modules/@next-api-sdk/user-service-sdk/dist/esm/api/user_service/my_collection/listMyCollection.js","webpack:///./src/nav-menu/site-map/constants.ts","webpack:///./src/nav-menu/site-map/CollectService.ts","webpack:///../../node_modules/@next-api-sdk/user-service-sdk/dist/esm/api/user_service/my_collection/upsertMyCollection.js","webpack:///./src/nav-menu/site-map/ItemTag.tsx","webpack:///./src/nav-menu/site-map/processor.ts","webpack:///./src/nav-menu/site-map/GroupItem.tsx","webpack:///./src/nav-menu/site-map/SiteMapItem.tsx","webpack:///./src/nav-menu/utils.tsx","webpack:///./src/nav-menu/nav-menu.shadow.css","webpack:///./src/nav-menu/site-map/GroupItem.shadow.css","webpack:///./src/nav-menu/site-map/ItemTag.shadow.css","webpack:///./src/nav-menu/site-map/SiteMapItem.shadow.css","webpack:///../../node_modules/@babel/runtime/helpers/esm/checkPrivateRedeclaration.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classExtractFieldDescriptor.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldGet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classApplyDescriptorGet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldSet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classApplyDescriptorSet.js","webpack:///../../src/menu.ts"],"sourcesContent":["import React, { useMemo, useState, useRef } from \"react\";\nimport classnames from \"classnames\";\nimport { renderLinkCom } from \"./utils.js\";\nimport { uniq } from \"lodash\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuItem,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type { ReactNextElement } from \"@next-core/react-element\";\nimport type { Popover, PopoverProps } from \"@next-bricks/basic/popover\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { JsonStorage } from \"@next-shared/general/JsonStorage\";\nimport { K, NS, locales } from \"./i18n.js\";\nimport { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\n\ninitializeReactI18n(NS, locales);\nconst WrappedPopover = wrapBrick<Popover, PopoverProps>(\"eo-popover\");\ninterface SearchProps {\n value?: string;\n placeholder?: string;\n autoFocus?: boolean;\n clearable?: boolean;\n trim?: boolean;\n debounceTime?: number;\n}\n\ninterface SearchEvents {\n change: CustomEvent<string>;\n search: CustomEvent<string>;\n}\n\ninterface SearchEventsMap {\n onChange: \"change\";\n onSearch: \"search\";\n}\nconst WrappedSearch = wrapBrick<\n ReactNextElement,\n SearchProps,\n SearchEvents,\n SearchEventsMap\n>(\"eo-search\", {\n onChange: \"change\",\n onSearch: \"search\",\n});\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\ninterface ThreeLevelMenuPopoverContentProps {\n menuItem: SidebarMenuGroup;\n selectedKey: string[];\n}\nconst LOCAL_STORAGE_PREFIX = \"threeLevelCategoryMenu\";\nconst maxVisitorLength = 6;\nexport function ThreeLevelMenuPopoverContent(\n props: ThreeLevelMenuPopoverContentProps\n): React.ReactElement {\n const { t } = useTranslation(NS);\n const { menuItem, selectedKey } = props;\n const items = menuItem.items as SidebarMenuGroup[];\n const [searchResult, setSearchResult] = useState<SidebarMenuSimpleItem[]>([]);\n const [searchKey, setSearchKey] = useState(\"\");\n const triggerRef = useRef<HTMLDivElement>(null);\n const nameSpace = `${LOCAL_STORAGE_PREFIX}_${menuItem.title}`;\n const storage = useMemo(() => new JsonStorage(localStorage), []);\n const searchHistory = (storage.getItem(nameSpace) as string[]) || [];\n\n const handleSearch = (e: CustomEvent<string>) => {\n setSearchKey(e.detail);\n if (e.detail) {\n const list = uniq([e.detail, ...searchHistory]);\n if (list.length > maxVisitorLength) {\n list.pop();\n }\n storage.setItem(nameSpace, list);\n setSearchResult(\n items\n .flatMap((i) => (i.items as SidebarMenuSimpleItem[]) || [])\n .filter((i) =>\n (i.text as string)\n .toLowerCase()\n .includes((e.detail as string).trim().toLowerCase())\n )\n );\n } else {\n setSearchResult([]);\n }\n };\n\n const popoverTriggerClick = () => {\n triggerRef.current?.click();\n };\n\n return (\n <div className={\"three-level-menu-container\"}>\n <div\n className=\"three-level-menu-search-container\"\n onClick={(e) => {\n e.stopPropagation();\n }}\n >\n <WrappedSearch\n placeholder={t(K.SEARCH_BY_MENU_NAME) as string}\n onSearch={handleSearch}\n onFocus={popoverTriggerClick}\n onBlur={popoverTriggerClick}\n />\n <WrappedPopover\n trigger=\"click\"\n placement={\"bottom-start\"}\n anchorDisplay=\"block\"\n distance={0}\n >\n <div slot=\"anchor\" ref={triggerRef}></div>\n {\n <div className=\"three-level-menu-search-result\">\n {!!searchResult.length &&\n searchResult.map((i) => renderLinkCom(i, { width: \"100%\" }))}\n {searchKey && !searchResult.length && (\n <div\n style={{\n height: \"100px\",\n textAlign: \"center\",\n lineHeight: \"100px\",\n }}\n >\n {t(K.NO_DATA)}\n </div>\n )}\n </div>\n }\n </WrappedPopover>\n </div>\n {!!searchHistory.length && (\n <div className=\"three-level-menu-search-history-container\">\n <div className=\"three-level-menu-search-history-title\">\n {t(K.SEARCH_HISTORY)}\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"delete\"\n className=\"three-level-menu-search-history-icon\"\n />\n </div>\n <div>\n {searchHistory.map((h) => (\n <span key={h} className=\"three-level-menu-search-history-text\">\n {h}\n </span>\n ))}\n </div>\n </div>\n )}\n <div\n className={\"three-level-menu-item-container\"}\n style={{\n gridTemplateColumns: `repeat(${\n items.length > 4 ? 4 : items.length\n },1fr)`,\n }}\n >\n {items.map((item: SidebarMenuGroup, index: number) => (\n <div key={index}>\n <div className=\"three-level-menu-item-title-container\">\n <span className=\"three-level-menu-item-title-icon\"></span>\n <span className=\"three-level-menu-item-title\">{item.title}</span>\n </div>\n {item.items?.map((i) => (\n <span\n key={i.key}\n className={classnames({\n active: i.key ? selectedKey.includes(i.key) : false,\n })}\n >\n {renderLinkCom(i as SidebarMenuSimpleItem, { width: \"100%\" })}\n </span>\n ))}\n </div>\n ))}\n </div>\n </div>\n );\n}\n","export enum K {\n SEARCH_BY_MENU_NAME = \"SEARCH_BY_MENU_NAME\",\n SEARCH_HISTORY = \"SEARCH_HISTORY\",\n NO_DATA = \"NO_DATA\",\n QUICK_ACCESS = \"QUICK_ACCESS\",\n REMOVE_ITEM_FROM_QUICK_ACCESS = \"REMOVE_ITEM_FROM_QUICK_ACCESS\",\n ADD_ITEM_TO_QUICK_ACCESS = \"ADD_ITEM_TO_QUICK_ACCESS\",\n NO_DATA_TIPS_IN_QUICK_ACCESS = \"NO_DATA_TIPS_IN_QUICK_ACCESS\",\n SITE_MAP_SEARCH_RECOMMEND = \"SITE_MAP_SEARCH_RECOMMEND\",\n MAX_COLLECT_COUNT_TIPS = \"MAX_COLLECT_COUNT_TIPS\",\n NO_DATA_SEARCH_INFO = \"NO_DATA_SEARCH_INFO\",\n SEARCH_ITEM_PLACEHOLDER = \"SEARCH_ITEM_PLACEHOLDER\",\n}\n\nconst en: Locale = {\n SEARCH_BY_MENU_NAME: \"Search by menu name\",\n SEARCH_HISTORY: \"Search history\",\n NO_DATA: \"No data\",\n QUICK_ACCESS: \"Quick Access\",\n REMOVE_ITEM_FROM_QUICK_ACCESS: \"Remove from Quick Access\",\n ADD_ITEM_TO_QUICK_ACCESS: \"Add to Quick Access\",\n NO_DATA_TIPS_IN_QUICK_ACCESS:\n \"No quick access resources have been added yet. Please add from the list below or after searching\",\n SITE_MAP_SEARCH_RECOMMEND: \"Search recommend\",\n MAX_COLLECT_COUNT_TIPS: \"Need to delete some favorites in order to add\",\n NO_DATA_SEARCH_INFO: \"The search result is empty, please enter again\",\n SEARCH_ITEM_PLACEHOLDER: \"Please enter keywords to search\",\n};\n\nconst zh: Locale = {\n SEARCH_BY_MENU_NAME: \"通过菜单名称搜索\",\n SEARCH_HISTORY: \"历史搜索\",\n NO_DATA: \"暂无数据\",\n QUICK_ACCESS: \"快捷访问\",\n REMOVE_ITEM_FROM_QUICK_ACCESS: \"从快捷访问移除\",\n ADD_ITEM_TO_QUICK_ACCESS: \"添加至快捷访问\",\n NO_DATA_TIPS_IN_QUICK_ACCESS: \"暂未添加快捷访问资源,从下方列表或搜索后添加\",\n SITE_MAP_SEARCH_RECOMMEND: \"搜索推荐\",\n MAX_COLLECT_COUNT_TIPS: \"需删除部分收藏,才能添加\",\n NO_DATA_SEARCH_INFO: \"搜索结果为空,请重新输入\",\n SEARCH_ITEM_PLACEHOLDER: \"请输入关键词搜索\",\n};\n\nexport const NS = \"bricks/nav/nav-menu\";\n\nexport const locales = { en, zh };\n\ntype Locale = { [key in K]: string };\n","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport { http } from \"@next-core/http\";\n/**\n * @description 获取我的收藏列表\n * @endpoint GET /api/v1/user_service/my_collection/collections\n */\nexport var MyCollectionApi_listMyCollection = /*#__PURE__*/function () {\n var _ref = _asyncToGenerator(function* (params, options) {\n return (/**! @contract easyops.api.user_service.my_collection.ListMyCollection@1.0.0 */(yield http.get(\"api/gateway/user_service.my_collection.ListMyCollection/api/v1/user_service/my_collection/collections\", _objectSpread(_objectSpread({}, options), {}, {\n params\n }))).data\n );\n });\n return function MyCollectionApi_listMyCollection(_x, _x2) {\n return _ref.apply(this, arguments);\n };\n}();\n//# sourceMappingURL=listMyCollection.js.map","import React from \"react\";\n\nexport enum DRAG_DIRECTION {\n Left = \"left\",\n Right = \"right\",\n}\n\nexport interface ContextOfDragProps {\n groupId: string;\n direction?: DRAG_DIRECTION;\n overElement?: HTMLElement;\n allowDrag?: boolean;\n onAllowDrag?: (enable: boolean) => void;\n onDragStart?: (e: React.DragEvent) => void;\n onDragOver?: (e: React.DragEvent) => void;\n onDragEnd?: (e: React.DragEvent) => void;\n onFavoriteUpdate?: (list: any[]) => void;\n}\n\nexport const collectModule = \"sidebarMenuCollect\";\n\nexport const DragContext = React.createContext<ContextOfDragProps>(\n {} as ContextOfDragProps\n);\n","import { JsonStorage } from \"@next-shared/general/JsonStorage\";\nimport type { SidebarMenuSimpleItem } from \"@next-shared/general/types\";\nimport {\n MyCollectionApi_listMyCollection,\n MyCollectionApi_ListMyCollectionResponseBody,\n MyCollectionApi_upsertMyCollection,\n} from \"@next-api-sdk/user-service-sdk\";\nimport { DRAG_DIRECTION, collectModule } from \"./constants.js\";\nimport { cloneDeep, isEmpty } from \"lodash\";\nimport { handleHttpError } from \"@next-core/runtime\";\n\nexport class CollectService {\n private maxCollectLength: number;\n private collectMap: Map<string, SidebarMenuSimpleItem[]> = new Map();\n\n constructor(maxCollectLength?: number) {\n this.maxCollectLength = maxCollectLength ?? 10;\n }\n\n public getFavoritesById(id: string): SidebarMenuSimpleItem[] {\n return cloneDeep(this.collectMap.get(id)) ?? [];\n }\n\n public async fetchFavorites(id: string): Promise<SidebarMenuSimpleItem[]> {\n if (!isEmpty(this.getFavoritesById(id))) {\n return this.getFavoritesById(id);\n }\n\n const favorites = (\n await MyCollectionApi_listMyCollection({\n module: collectModule,\n collectionName: id,\n })\n ).payloads\n ?.map((item) => item.extInfo)\n .filter(Boolean) as SidebarMenuSimpleItem[];\n\n this.collectMap.set(id, favorites);\n\n return favorites;\n }\n\n public setItemAsFavorite(id: string, item: SidebarMenuSimpleItem): void {\n const list = this.getFavoritesById(id);\n\n if (list.length >= this.maxCollectLength) {\n list.pop();\n }\n\n list.unshift(item);\n this.updateFavoriteItems(id, list);\n }\n\n public updateFavoriteItems(id: string, list: SidebarMenuSimpleItem[]): void {\n try {\n this.collectMap.set(id, list);\n MyCollectionApi_upsertMyCollection({\n module: collectModule,\n collectionName: id,\n payloads: list?.map((item) => ({\n name: item.text,\n url: item.to,\n extInfo: item,\n })) as MyCollectionApi_ListMyCollectionResponseBody[\"payloads\"],\n });\n } catch (error) {\n // istanbul ignore next\n handleHttpError(error);\n }\n }\n\n private equalItem(\n prevItem: SidebarMenuSimpleItem,\n item: SidebarMenuSimpleItem\n ): boolean {\n return prevItem.text === item.text && prevItem.to === item.to;\n }\n\n public removeItemFromFavorite(id: string, item: SidebarMenuSimpleItem): void {\n const list = this.getFavoritesById(id);\n const index = list.findIndex((row) => this.equalItem(row, item));\n // istanbul ignore else\n if (index !== -1) {\n list.splice(index, 1);\n this.updateFavoriteItems(id, list);\n }\n }\n\n public isCollected(id: string, item: SidebarMenuSimpleItem): boolean {\n const list = this.getFavoritesById(id);\n return list.some((row) => this.equalItem(row, item));\n }\n\n public toggleFavorite(id: string, item: SidebarMenuSimpleItem): void {\n if (this.isCollected(id, item)) {\n this.removeItemFromFavorite(id, item);\n } else {\n if (this.checkMaxCapacity(id)) return;\n this.setItemAsFavorite(id, item);\n }\n }\n\n public moveFavoriteTo(\n id: string,\n option: {\n from: SidebarMenuSimpleItem;\n to: SidebarMenuSimpleItem;\n direction: DRAG_DIRECTION;\n }\n ): SidebarMenuSimpleItem[] {\n const { from, to, direction } = option;\n\n const list = this.getFavoritesById(id);\n if (this.equalItem(from, to)) return list;\n\n const fromIndex = list.findIndex((row) => this.equalItem(row, from));\n\n // istanbul ignore else\n if (fromIndex !== -1) {\n list.splice(fromIndex, 1);\n\n const toIndex = list.findIndex((row) => this.equalItem(row, to));\n\n // istanbul ignore else\n if (toIndex !== -1) {\n if (direction === DRAG_DIRECTION.Left) {\n list.splice(toIndex, 0, from);\n } else {\n list.splice(toIndex + 1, 0, from);\n }\n\n this.updateFavoriteItems(id, list);\n }\n }\n\n return list;\n }\n\n checkMaxCapacity(groupId: string): boolean {\n return this.getFavoritesById(groupId).length >= this.maxCollectLength;\n }\n}\n\nexport const collectService = new CollectService();\n","import { http } from \"@next-core/http\";\n/**\n * @description 更新/新增我的收藏,这个接口用于全量更新单实例\n * @endpoint POST /api/v1/user_service/my_collection/upsert_collections\n */\nexport var MyCollectionApi_upsertMyCollection = (data, options) => /**! @contract easyops.api.user_service.my_collection.UpsertMyCollection@1.0.0 */http.post(\"api/gateway/user_service.my_collection.UpsertMyCollection/api/v1/user_service/my_collection/upsert_collections\", data, options);\n//# sourceMappingURL=upsertMyCollection.js.map","import React, {\n useMemo,\n useCallback,\n forwardRef,\n useRef,\n useState,\n useEffect,\n useContext,\n DragEvent,\n} from \"react\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { Link, LinkProps } from \"@next-bricks/basic/link\";\n\nimport { EoTooltip, ToolTipProps } from \"@next-bricks/basic/tooltip\";\nimport classNames from \"classnames\";\nimport { SidebarMenuSimpleItem } from \"@next-shared/general/types\";\nimport { K, NS, locales } from \"../i18n.js\";\nimport { collectService } from \"./CollectService.js\";\nimport { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\nimport { DRAG_DIRECTION, DragContext } from \"./constants.js\";\n\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\ninitializeReactI18n(NS, locales);\nconst WrappedLink = wrapBrick<Link, LinkProps>(\"eo-link\");\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nconst WrappedTooltip = wrapBrick<EoTooltip, ToolTipProps>(\"eo-tooltip\");\n\ninterface CellItemProps {\n data: SidebarMenuSimpleItem;\n suffix?: React.ReactNode;\n className?: string;\n}\n\nexport type OnFavoriteCallback = (collectList: SidebarMenuSimpleItem[]) => void;\n\ninterface PlaceholderCompProps {\n data: SidebarMenuSimpleItem;\n direction: DRAG_DIRECTION;\n onDragOver?: (e: DragEvent) => void;\n}\nexport function PlaceholderDropComp({\n data,\n onDragOver,\n direction,\n}: PlaceholderCompProps) {\n const { groupId, onFavoriteUpdate } = useContext(DragContext);\n const handleDrop = (e: DragEvent) => {\n const formData = JSON.parse(e.dataTransfer.getData(\"application/json\"));\n\n const newDataList = collectService.moveFavoriteTo(groupId, {\n from: formData,\n to: data,\n direction,\n });\n\n onFavoriteUpdate?.(newDataList);\n };\n\n return (\n <div\n className=\"indicate-wrapper\"\n data-direction={direction}\n data-to={data.to}\n onDragEnter={(e) =>\n ((e.target as HTMLElement).style.background = \"var(--palette-blue-1)\")\n }\n onDragLeave={(e) =>\n ((e.target as HTMLElement).style.background = \"transparent\")\n }\n data-text={data.text}\n onDragOver={onDragOver}\n onDrop={handleDrop}\n />\n );\n}\n\nexport function ItemTag(props: CellItemProps): React.ReactElement {\n const { data, suffix, className } = props;\n\n const {\n allowDrag,\n onDragStart,\n overElement,\n direction,\n onDragEnd,\n onDragOver,\n } = useContext(DragContext);\n const containerRef = useRef<any>(null);\n\n const [isDragIng, setIsDragIng] = useState(false);\n\n const isActive = useMemo(\n () =>\n overElement &&\n overElement.dataset.to == data.to &&\n overElement.dataset.text === overElement.dataset.text,\n [overElement, data]\n );\n\n const handleDragStart = (e: React.DragEvent) => {\n if (!allowDrag) {\n e.preventDefault();\n } else {\n setIsDragIng(true);\n e.dataTransfer?.setData(\"application/json\", JSON.stringify(data));\n onDragStart?.(e);\n }\n };\n\n const handleDragEnd = (e: React.DragEvent) => {\n setIsDragIng(false);\n onDragEnd?.(e);\n };\n\n const handleOver = (e: React.DragEvent) => {\n e.dataTransfer.dropEffect = \"none\";\n onDragOver?.(e);\n };\n\n return (\n <>\n {isActive && direction === DRAG_DIRECTION.Left && (\n <PlaceholderDropComp\n data={data}\n onDragOver={onDragOver}\n direction={DRAG_DIRECTION.Left}\n />\n )}\n <WrappedLink\n data-to={data.to}\n data-text={data.text}\n ref={containerRef}\n draggable\n onDragStart={handleDragStart}\n onDragEnd={handleDragEnd}\n onDragOver={handleOver}\n className={classNames(\"tag-container\", className, {\n \"is-drag\": isDragIng,\n })}\n url={data.to as string}\n href={data.href}\n target={data.target as LinkProps[\"target\"]}\n >\n <span className=\"tag-text ellipsis\" title={data.text}>\n {data.text}\n </span>\n <span className=\"tag-suffix\" onClick={(e) => e.preventDefault()}>\n {suffix}\n </span>\n </WrappedLink>\n\n {isActive && direction === DRAG_DIRECTION.Right && (\n <PlaceholderDropComp\n data={data}\n onDragOver={onDragOver}\n direction={DRAG_DIRECTION.Right}\n />\n )}\n </>\n );\n}\n\ninterface QuickVisitTagProps extends CellItemProps {\n groupId: string;\n onFavorite?: OnFavoriteCallback;\n}\n\nexport function QuickVisitItem(props: QuickVisitTagProps): React.ReactElement {\n const { t } = useTranslation(NS);\n const { onAllowDrag } = useContext(DragContext);\n const { data, onFavorite, groupId } = props;\n const suffixRef = useRef<any>();\n\n const handleRemove = useCallback(() => {\n collectService.removeItemFromFavorite(groupId, data);\n onFavorite?.(collectService.getFavoritesById(groupId));\n }, [groupId, data, onFavorite]);\n\n const handleMouseDown = () => {\n onAllowDrag?.(true);\n };\n\n useEffect(() => {\n const suffix = suffixRef.current;\n const handleClick = (e: MouseEvent) => {\n e.preventDefault();\n };\n suffix.addEventListener(\"click\", handleClick);\n\n return () => {\n suffix.removeEventListener(\"click\", handleClick);\n };\n }, []);\n\n const suffixGroups = useMemo(\n () => (\n <div className=\"operation\" ref={suffixRef}>\n <WrappedTooltip\n content={t(K.REMOVE_ITEM_FROM_QUICK_ACCESS)}\n hoist\n placement=\"bottom\"\n className=\"close\"\n onClick={handleRemove}\n >\n <WrappedIcon lib=\"antd\" icon=\"close\" />\n </WrappedTooltip>\n <span className=\"drag-wrapper\" onMouseDown={handleMouseDown}>\n :::\n </span>\n </div>\n ),\n [t, handleRemove]\n );\n\n return (\n <ItemTag className=\"visit-container\" suffix={suffixGroups} data={data} />\n );\n}\n\ninterface StarIconProps {\n onFavorite?: OnFavoriteCallback;\n className?: string;\n groupId: string;\n data: SidebarMenuSimpleItem;\n active?: boolean;\n}\n\nexport function StarIcon({\n onFavorite,\n className,\n groupId,\n data,\n active,\n}: StarIconProps): React.ReactElement {\n const { t } = useTranslation(NS);\n const iconRef = useRef<any>();\n\n const handleClick = (e: React.MouseEvent) => {\n e.preventDefault();\n collectService.toggleFavorite(groupId, data);\n onFavorite?.(collectService.getFavoritesById(groupId));\n };\n\n useEffect(() => {\n // workaround for prevent Link jump when click.\n const icon = iconRef.current;\n icon.addEventListener(\"click\", handleClick);\n\n return () => {\n icon.removeEventListener(\"click\", handleClick);\n };\n }, []);\n\n return (\n <WrappedTooltip\n content={\n active\n ? t(K.REMOVE_ITEM_FROM_QUICK_ACCESS)\n : collectService.checkMaxCapacity(groupId)\n ? t(K.MAX_COLLECT_COUNT_TIPS)\n : t(K.ADD_ITEM_TO_QUICK_ACCESS)\n }\n className={classNames(\"star-icon\", className)}\n >\n <WrappedIcon\n ref={iconRef}\n className={classNames({ active })}\n lib=\"antd\"\n icon=\"star\"\n {...(active ? { theme: \"filled\" } : {})}\n />\n </WrappedTooltip>\n );\n}\n\ninterface RecommendItemProps extends CellItemProps {\n active?: boolean;\n groupId: string;\n onFavorite?: OnFavoriteCallback;\n}\n\nexport function RecommendItem(props: RecommendItemProps): React.ReactElement {\n const { data, className, groupId, onFavorite, active } = props;\n\n const suffixGroups = useMemo(\n () => (\n <StarIcon\n groupId={groupId}\n active={active}\n className=\"star\"\n data={data}\n onFavorite={onFavorite}\n />\n ),\n [data, groupId, onFavorite, active]\n );\n\n return (\n <ItemTag\n className={classNames(\"recommend-container\", className)}\n suffix={suffixGroups}\n data={data}\n />\n );\n}\n","import {\n SidebarMenuItem,\n SidebarMenuGroup,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\n\nfunction walkMenuItem(item: SidebarMenuItem, list: SidebarMenuSimpleItem[]) {\n if (\n (item as SidebarMenuGroup).type === \"group\" &&\n Array.isArray((item as SidebarMenuGroup).items)\n ) {\n walkMenuItems((item as SidebarMenuGroup).items, list);\n } else {\n list.push(item as SidebarMenuSimpleItem);\n }\n}\n\nfunction walkMenuItems(\n items: SidebarMenuItem[],\n list: SidebarMenuSimpleItem[]\n): void {\n for (const item of items) {\n walkMenuItem(item, list);\n }\n}\n\nexport function flatMenuItems(item: SidebarMenuItem): SidebarMenuSimpleItem[] {\n const list: SidebarMenuSimpleItem[] = [];\n\n walkMenuItem(item, list);\n\n return list;\n}\n\nexport function processGroupItems(groups: SidebarMenuGroup[]): Array<{\n groupFrom: string;\n groups: SidebarMenuGroup[];\n}> {\n const groupCategoryMap = new Map<string, SidebarMenuGroup[]>();\n const categoryOrder = new Set<string>();\n\n groups?.forEach((item) => {\n const from = item.groupFrom ?? \"default\";\n categoryOrder.add(from);\n\n const value = groupCategoryMap.get(from);\n\n if (!value) {\n groupCategoryMap.set(from, [item]);\n } else {\n value!.push(item);\n }\n });\n\n return Array.from(categoryOrder).map((key) => ({\n groupFrom: key,\n groups: groupCategoryMap!.get(key)!,\n }));\n}\n","import React, { useEffect, useState } from \"react\";\nimport type {\n SidebarMenuSimpleItem,\n SidebarMenuGroup,\n} from \"@next-shared/general/types\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { StarIcon, OnFavoriteCallback } from \"./ItemTag.js\";\nimport { Link, LinkProps } from \"@next-bricks/basic/link\";\nimport { collectService } from \"./CollectService.js\";\nimport { processGroupItems } from \"./processor.js\";\nimport classNames from \"classnames\";\n\nconst WrappedLink = wrapBrick<Link, LinkProps>(\"eo-link\");\n\ninterface GroupViewProps {\n groups: SidebarMenuGroup[];\n groupId: string;\n selectedKey?: string[];\n onFavorite: OnFavoriteCallback;\n}\n\nexport const itemColumnWidth = 240;\n\nexport function GroupView(props: GroupViewProps): React.ReactElement {\n const { groupId, selectedKey, onFavorite } = props;\n const groupMenus = processGroupItems(props.groups);\n\n return (\n <div className=\"group-view\">\n {groupMenus.map((item, index) => {\n return (\n <div key={index}>\n {index !== 0 && <div className=\"divider\" />}\n {item.groupFrom === \"default\" ? (\n <DefaultGroup\n groupId={groupId}\n selectedKey={selectedKey}\n groups={item.groups}\n onFavorite={onFavorite}\n />\n ) : (\n <CustomGroup\n groupId={groupId}\n selectedKey={selectedKey}\n groups={item.groups}\n onFavorite={onFavorite}\n />\n )}\n </div>\n );\n })}\n </div>\n );\n}\n\ninterface BaseGroupProps {\n groupId: string;\n selectedKey?: string[];\n onFavorite: OnFavoriteCallback;\n groups: SidebarMenuGroup[];\n}\nexport function DefaultGroup(props: BaseGroupProps): React.ReactElement {\n const { groupId, onFavorite, selectedKey, groups } = props;\n\n const groupRef = React.useRef<HTMLDivElement>(null);\n const [columnCount, setColumnCount] = useState<number>();\n\n useEffect(() => {\n // istanbul ignore next\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n if (entry.target === groupRef.current) {\n const width = entry.contentRect.width;\n\n setColumnCount(Math.floor(width / itemColumnWidth));\n }\n }\n });\n\n resizeObserver.observe(groupRef.current as HTMLDivElement);\n\n return () => resizeObserver.disconnect();\n }, []);\n\n return (\n <div\n className=\"group\"\n ref={groupRef}\n style={\n (columnCount as number) < groups?.length\n ? { columnCount, columnWidth: itemColumnWidth }\n : {\n display: \"grid\",\n gridTemplateColumns: `repeat(auto-fit, ${itemColumnWidth}px)`,\n }\n }\n >\n {groups.map((group) => (\n <div key={group.key} className=\"group-item\">\n <div className=\"title\">{group.title}</div>\n <div className=\"content\">\n {group.items.map((item) => (\n <GroupItem\n key={item.key}\n groupId={groupId}\n selectedKey={selectedKey}\n data={item as SidebarMenuSimpleItem}\n onFavorite={onFavorite}\n />\n ))}\n </div>\n </div>\n ))}\n </div>\n );\n}\n\nexport function CustomGroup(props: BaseGroupProps): React.ReactElement {\n const { groupId, onFavorite, selectedKey, groups } = props;\n\n return (\n <div className=\"custom-group\">\n {groups.map((group) => (\n <div key={group.key}>\n <div className=\"title\">{group.title}</div>\n <div\n className=\"custom-content\"\n style={{\n display: \"grid\",\n gridTemplateColumns: `repeat(auto-fit, ${itemColumnWidth}px)`,\n }}\n >\n {group.items.map((item) => (\n <GroupItem\n key={item.key}\n selectedKey={selectedKey}\n groupId={groupId}\n data={item as SidebarMenuSimpleItem}\n onFavorite={onFavorite}\n />\n ))}\n </div>\n </div>\n ))}\n </div>\n );\n}\n\ninterface GroupItemProps {\n data: SidebarMenuSimpleItem;\n selectedKey?: string[];\n groupId: string;\n onFavorite: OnFavoriteCallback;\n}\nexport function GroupItem(props: GroupItemProps): React.ReactElement {\n const { data, groupId, onFavorite, selectedKey } = props;\n\n return (\n <WrappedLink\n key={data.key}\n icon={data.icon}\n url={data.to as string}\n href={data.href}\n target={data.target as LinkProps[\"target\"]}\n className={classNames(\"item-link\", {\n active: selectedKey?.includes(data.key as string),\n })}\n >\n <span className=\"ellipsis\" title={data.text}>\n {data.text}\n </span>\n <span className=\"icon-wrapper\">\n <StarIcon\n active={collectService.isCollected(groupId, data)}\n groupId={groupId}\n data={data}\n onFavorite={onFavorite}\n />\n </span>\n </WrappedLink>\n );\n}\n","import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { QuickVisitItem, RecommendItem } from \"./ItemTag.js\";\nimport { GroupView } from \"./GroupItem.js\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { K, NS } from \"../i18n.js\";\nimport { DragContext } from \"./constants.js\";\nimport { useTranslation } from \"@next-core/i18n/react\";\nimport { collectService } from \"./CollectService.js\";\nimport { flatMenuItems } from \"./processor.js\";\nimport { DRAG_DIRECTION } from \"./constants.js\";\nimport classNames from \"classnames\";\nimport { throttle, debounce } from \"lodash\";\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nexport interface InputEvents {\n change: CustomEvent<string>;\n}\n\nexport interface InputEventsMap {\n onValueChange: \"change\";\n}\n\nconst WrappedInput = wrapBrick<any, any, InputEvents, InputEventsMap>(\n \"eo-input\",\n {\n onValueChange: \"change\",\n }\n);\n\ninterface SiteMapItemProps {\n menuGroup: SidebarMenuGroup;\n selectedKey?: string[];\n visible?: boolean;\n}\n\nexport function findDropElement(element: HTMLElement): HTMLElement | undefined {\n let node = element;\n\n while (node) {\n if (node.draggable || node.className === \"indicate-wrapper\") {\n return node;\n }\n\n node = node.parentElement as HTMLElement;\n }\n}\n\nexport function isValidDragAction(\n dragElement: HTMLElement,\n dropElement: HTMLElement\n): boolean {\n return (\n dragElement &&\n dropElement &&\n !(\n dragElement.dataset.to === dropElement.dataset.to &&\n dragElement.dataset.text === dropElement.dataset.text\n )\n );\n}\n\nexport function SiteMapItem(props: SiteMapItemProps) {\n const { t } = useTranslation(NS);\n const { menuGroup, selectedKey, visible } = props;\n const groupId = menuGroup.groupId as string;\n\n const [favoriteList, setFavoriteList] = useState<SidebarMenuSimpleItem[]>([]);\n const flatItems = useMemo(() => flatMenuItems(menuGroup), [menuGroup]);\n const [q, setQ] = useState<string>();\n const [filter, setFilters] = useState<SidebarMenuSimpleItem[]>([]);\n const [dragElement, setDragElement] = useState<HTMLElement>();\n const [overElement, setOverElement] = useState<HTMLElement>();\n const [allowDrag, setAllowDrag] = useState<boolean>();\n const [direction, setDirection] = useState<DRAG_DIRECTION>();\n\n const handleFavorite = (collectList: SidebarMenuSimpleItem[]) => {\n setFavoriteList(collectList);\n };\n\n const handleSearch = useCallback(\n (e: CustomEvent<string>): void => {\n const v = e.detail;\n setQ(e.detail);\n\n setFilters(\n !v\n ? flatItems\n : flatItems.filter((item) =>\n item.text.toLowerCase().includes(e.detail.toLowerCase())\n )\n );\n },\n [flatItems]\n );\n\n const debouncedHandleSearch = useMemo(\n () => debounce(handleSearch, 200),\n [handleSearch]\n );\n\n const handleDragStart = (e: React.DragEvent): void => {\n setDragElement(e.target as HTMLElement);\n };\n\n const handleDragOver = useMemo(\n () =>\n throttle((e: React.DragEvent): void => {\n e.preventDefault();\n\n const dropElement = findDropElement(e.target as HTMLElement);\n setOverElement(dropElement);\n\n if (\n dropElement &&\n isValidDragAction(dropElement, dragElement as HTMLElement)\n ) {\n if (dropElement.className === \"indicate-wrapper\") {\n setDirection(dropElement.dataset.direction as DRAG_DIRECTION);\n } else {\n const { width, left } = dropElement.getBoundingClientRect();\n\n const right = e.clientX > left + width / 2;\n setDirection(right ? DRAG_DIRECTION.Right : DRAG_DIRECTION.Left);\n }\n } else {\n setDirection(undefined);\n }\n }),\n [dragElement]\n );\n\n const handleDragEnd = (): void => {\n setDragElement(undefined);\n setDirection(undefined);\n setAllowDrag(false);\n };\n\n const handleAllowDrag = (enable: boolean): void => {\n setAllowDrag(enable);\n };\n\n useEffect(() => {\n (async () => {\n if (visible) {\n const list = await collectService.fetchFavorites(groupId);\n setFavoriteList(list);\n }\n })();\n }, [groupId, visible]);\n\n return (\n <div className=\"site-map\">\n <div className=\"search-wrapper\">\n <WrappedInput\n className=\"search-input\"\n style={{ width: \"100%\" }}\n onValueChange={debouncedHandleSearch}\n placeholder={t(K.SEARCH_ITEM_PLACEHOLDER)}\n >\n <WrappedIcon slot=\"prefix\" lib=\"antd\" icon=\"search\" />\n </WrappedInput>\n </div>\n\n {!q && (\n <div>\n {favoriteList.length !== 0 && (\n <div\n className={classNames(\"visit-access\", {\n hasData: favoriteList.length,\n })}\n >\n <span className=\"title\">{t(K.QUICK_ACCESS)}</span>\n <DragContext.Provider\n value={{\n groupId,\n overElement,\n direction,\n allowDrag,\n onDragStart: handleDragStart,\n onDragOver: handleDragOver,\n onDragEnd: handleDragEnd,\n onAllowDrag: handleAllowDrag,\n onFavoriteUpdate: handleFavorite,\n }}\n >\n <div className=\"tag-wrapper\">\n {favoriteList.map((item) => (\n <QuickVisitItem\n onFavorite={handleFavorite}\n groupId={groupId}\n key={item.key}\n data={item}\n />\n ))}\n </div>\n </DragContext.Provider>\n </div>\n )}\n\n <GroupView\n groupId={groupId}\n selectedKey={selectedKey}\n groups={menuGroup.items as SidebarMenuGroup[]}\n onFavorite={handleFavorite}\n />\n </div>\n )}\n\n {q && (\n <div className=\"search-panel\">\n <span className=\"title\">{t(K.SITE_MAP_SEARCH_RECOMMEND)}</span>\n {filter.length ? (\n <div className=\"recommend-wrapper\">\n {filter.map((item) => (\n <RecommendItem\n key={item.key}\n groupId={groupId}\n data={item}\n onFavorite={handleFavorite}\n active={collectService.isCollected(groupId, item)}\n />\n ))}\n </div>\n ) : (\n <div className=\"no-data-tips\">{t(K.NO_DATA_SEARCH_INFO)}</div>\n )}\n </div>\n )}\n </div>\n );\n}\n","import React from \"react\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuItem,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport type { Link, LinkProps } from \"@next-bricks/basic/link\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nconst WrappedLinkItem = wrapBrick<Link, LinkProps>(\"eo-link\");\n\nexport function isGroup(item: SidebarMenuItem): item is SidebarMenuGroup {\n return item.type === \"group\";\n}\n\nexport function isSubMenu(\n item: SidebarMenuGroup,\n groupAsSubMenu?: boolean\n): item is SidebarMenuGroup {\n return Boolean(\n item.type === \"subMenu\" || (groupAsSubMenu && item.type === \"group\")\n );\n}\n\nexport function isSimple(item: SidebarMenuItem): item is SidebarMenuSimpleItem {\n return item.type === \"default\" || !item.type;\n}\n\nexport const renderLinkCom = (\n item: SidebarMenuSimpleItem,\n linkStyle?: React.CSSProperties\n): React.ReactElement => {\n return (\n <WrappedLinkItem\n key={item.key}\n url={item.to as string}\n href={item.href}\n target={item.target as LinkProps[\"target\"]}\n style={linkStyle}\n >\n <span className=\"menu-item-label\">{item.text}</span>\n </WrappedLinkItem>\n );\n};\n\nexport const renderSpanCom = (\n item: SidebarMenuGroup,\n subMenu?: boolean\n): React.ReactElement => {\n return (\n <span key={item.key} className=\"menu-item-label\">\n {item.title}\n {subMenu && <WrappedIcon lib=\"fa\" icon=\"angle-right\" />}\n </span>\n );\n};\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block;background:none;--three-level-menu-search-input-background:linear-gradient(90deg,#e8eef6 0%,rgba(233,234,243,0) 100%);--three-level-menu-hover-color:#6bb3ff;--three-level-menu-title-color:#0b5ad9;--three-level-menu-active-color:#1a7aff;--three-level-menu-search-tag-color:rgb(89,89,89);--three-level-menu-search-tag-background:rgb(245,245,245)}:host::part(menu-item),\neo-link{display:block;padding:2px 0px}:host-context(html[data-theme=\"dark-v2\"]),\n:host-context([data-override-theme=\"dark-v2\"]){--three-level-menu-search-input-background:linear-gradient(124deg,rgba(255,255,255,0.36) 0%,rgba(255,255,255,0) 100%);--three-level-menu-hover-color:rgba(54,95,175,0.85);--three-level-menu-title-color:#6597e8;--three-level-menu-active-color:#3f75dd;--three-level-menu-search-tag-color:rgb(140,140,140);--three-level-menu-search-tag-background:rgb(107,107,107)}.nav-menu-wrapper{display:flex}.nav-menu-wrapper > eo-menu-item{padding:2px 14px}.nav-menu-wrapper > eo-popover{padding:2px 6px}.popover .sub-menu-item-label{padding:2px 0px;color:var(--color-normal-text)}.popover.subprime{display:inline-block;width:100%}.sub-menu-wrapper{min-width:160px;max-height:calc(100vh - 100px);background-color:var(--antd-dropdown-menu-bg);padding:4px 0;border-radius:6px;box-shadow:0px 4px 12px 0px rgba(17,37,64,0.08);overflow-x:hidden;overflow-y:auto}.sub-menu-wrapper > eo-menu-item{display:block;width:100%}.sub-menu-wrapper > eo-menu-item .menu-item-label,\n.sub-menu-wrapper > eo-popover .menu-item-label,\n.sub-menu-wrapper > .group-wrapper > eo-popover .menu-item-label,\n.sub-menu-wrapper > .group-wrapper > eo-menu-item .menu-item-label{display:block;width:100%;padding:6px 24px;box-sizing:border-box;color:var(--color-normal-text)}.sub-menu-wrapper > eo-popover.subprime .menu-item-label,\n.sub-menu-wrapper > .group-wrapper > eo-popover.subprime .menu-item-label{display:flex;justify-content:space-between;align-items:center}.sub-menu-wrapper .menu-item-label{border-radius:0}.menu-item-label{display:inline-block;cursor:pointer;border-radius:4px;padding:5px 10px;color:var(--color-normal-text)}.menu-item-label:hover{background-color:var(--v8-top-menu-item-hover)}.group-label{padding-left:16px;font-size:12px;color:var(--palette-gray-7)}eo-menu-item[active] .menu-item-label{background:var(--v8-top-menu-item-selected-bg);color:var(--color-brand)!important;font-weight:500}.three-level-menu-container{max-width:980px;max-height:510px;overflow:auto;min-width:160px}.three-level-menu-item-container{display:grid;grid-gap:20px;gap:20px;margin-top:13px;padding:5px 10px}.three-level-menu-item-title-container{display:flex;align-items:center}.three-level-menu-item-title-icon{width:4px;height:4px;background-color:var(--three-level-menu-title-color);margin-right:4px;transform:rotate(45deg)}.three-level-menu-item-title{font-size:14px;font-family:PingFang-SC-Medium,PingFang-SC;font-weight:500;color:var(--three-level-menu-title-color)}.three-level-menu-container .menu-item-label{margin-top:4px;margin-left:4px;padding:4px;width:100%}.three-level-menu-container .active .menu-item-label{color:var(--three-level-menu-active-color)}.three-level-menu-search-result .menu-item-label{margin:0px}.three-level-menu-container .menu-item-label:hover{color:var(--three-level-menu-hover-color)}.three-level-menu-popover .sub-menu-wrapper{padding-top:0px}.three-level-menu-search-container{background:var(--three-level-menu-search-input-background);padding:5px 10px}.three-level-menu-search-result{min-width:187px;max-width:328px;max-height:324px;background-color:var(--antd-dropdown-menu-bg);box-shadow:0px 4px 12px 0px rgba(17,37,64,0.08);overflow:scroll}.three-level-menu-search-history-container{padding:5px 10px}.three-level-menu-search-history-text{background:var(--three-level-menu-search-tag-background);border-radius:2px;font-size:7px;line-height:11px;display:inline-block;height:11px;padding:4px;color:var(--three-level-menu-search-tag-color);margin-right:8px}.three-level-menu-search-history-title{color:#8c8c8c;margin:10px 0;display:flex;align-items:center}.three-level-menu-search-history-icon{margin-left:5px}.sub-menu-sit-map-wrapper{box-sizing:border-box;width:calc(100vw);padding:0 120px 24px;max-height:520px;background-color:var(--antd-dropdown-menu-bg);border-radius:6px;box-shadow:0px 4px 12px 0px rgba(17,37,64,0.08);overflow-x:hidden;overflow-y:auto}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.group .item-link, .custom-group .item-link{font-weight:400}.group .item-link:hover, .custom-group .item-link:hover{background-color:var(--color-fill-bg-base-1)}.group .item-link:hover::part(link), .custom-group .item-link:hover::part(link){color:var(--color-brand-hover)}.group .item-link:hover::part(icon), .custom-group .item-link:hover::part(icon){color:var(--color-brand-hover)}.group .item-link.active::part(link),\n .custom-group .item-link.active::part(link),\n .group .item-link.active::part(icon),\n .custom-group .item-link.active::part(icon){color:var(--palette-blue-8)}.group .item-link::part(link), .custom-group .item-link::part(link){padding:8px 12px;display:flex;gap:4px;color:var(--color-header-text)}.group .item-link::part(icon), .custom-group .item-link::part(icon){color:var(--color-normal-text)}.group .title, .custom-group .title{padding:8px 16px;font-size:16px;font-weight:500;position:relative}.group .title::before, .custom-group .title::before{content:\"\";position:absolute;width:6px;height:6px;top:17px;left:1px;transform:rotate(45deg);background:var(--color-secondary-text)}.group .content .icon-wrapper, .custom-group .content .icon-wrapper, .group .custom-content .icon-wrapper, .custom-group .custom-content .icon-wrapper{color:var(--color-secondary-text);font-size:16px;display:none;margin-left:auto}.group .content .item-link:hover .icon-wrapper, .custom-group .content .item-link:hover .icon-wrapper, .group .custom-content .item-link:hover .icon-wrapper, .custom-group .custom-content .item-link:hover .icon-wrapper{display:block}.group .content .item-link:hover .icon-wrapper:hover, .custom-group .content .item-link:hover .icon-wrapper:hover, .group .custom-content .item-link:hover .icon-wrapper:hover, .custom-group .custom-content .item-link:hover .icon-wrapper:hover{color:var(--color-brand-hover)}.group .content, .custom-group .content{display:flex;flex-direction:column}.group .group-item, .custom-group .group-item{page-break-inside:avoid;break-inside:avoid}.group-view{min-height:300px}.group-view .divider{height:2px;background:var(--color-text-divider-line);margin:16px 0}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.tag-container::part(link){display:flex;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;-moz-user-select:none;justify-content:space-between;background-color:var(--color-fill-bg-base-1);border-radius:2px;padding:1px 6px}.tag-container .tag-text{color:var(--color-normal-text);font-weight:400}.tag-container:hover .tag-text{color:var(--color-brand-hover)}.tag-container .tag-suffix{display:inline-flex;font-size:12px;gap:4px;align-items:center;color:var(--color-secondary-text)}.tag-container.is-drag{opacity:0.4}.indicate-wrapper{border:1px dashed var(--color-brand-hover);border-radius:4px;height:20px;margin:2px 0}.close{display:inline-flex;margin-top:2px;padding:0 2px}.close:hover{color:var(--color-error)}.drag-wrapper{cursor:move}.drag-wrapper:hover{color:var(--color-brand-hover)}.star-icon{display:flex;alignitems:center;color:var(--color-secondary-text)}.star-icon:hover{color:var(--color-brand-hover)}.star-icon .active{color:var(--palette-yellow-6)}.recommend-container:hover .star{display:inline-flex}.recommend-container .star{font-size:13px;display:none}.visit-container:hover .operation{display:inline-flex;align-items:center}.visit-container .operation{display:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.site-map .search-wrapper{position:-webkit-sticky;position:sticky;top:0;z-index:9999;padding-top:24px;padding-bottom:16px;background:var(--antd-dropdown-menu-bg)}.site-map .search-input::part(affix-wrapper){border:none;border-bottom:1px solid var(--antd-input-border-color);border-radius:0px}.site-map .visit-access .title, .site-map .search-panel .title{display:inline-block;padding:2px 16px;font-weight:500;line-height:24px;position:relative}.site-map .visit-access .title::before, .site-map .search-panel .title::before{content:\"\";position:absolute;width:6px;height:6px;top:10px;left:1px;border-radius:50%;background:var(--color-secondary-text)}.site-map .visit-access .no-data-tips, .site-map .search-panel .no-data-tips{display:flex;margin:16px 0 32px;align-items:center;justify-content:center;color:var(--color-secondary-text)}.site-map .visit-access{margin-bottom:8px}.site-map .visit-access.hasData{display:flex}.site-map .visit-access .tag-wrapper{flex:1;display:grid;grid-template-columns:repeat(auto-fit,200px);grid-gap:8px;gap:8px}.site-map .ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.site-map .search-panel .recommend-wrapper{margin-top:16px;display:grid;grid-template-columns:repeat(auto-fit,200px);grid-gap:8px;gap:8px}:host-context(html[data-theme=\"dark-v2\"]) .site-map .search-input::part(affix-wrapper), :host-context([data-override-theme=\"dark-v2\"]) .site-map .search-input::part(affix-wrapper){background:var(--antd-dropdown-menu-bg)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","export default function _checkPrivateRedeclaration(obj, privateCollection) {\n if (privateCollection.has(obj)) {\n throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n }\n}","export default function _classExtractFieldDescriptor(receiver, privateMap, action) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to \" + action + \" private field on non-instance\");\n }\n return privateMap.get(receiver);\n}","import classApplyDescriptorGet from \"./classApplyDescriptorGet.js\";\nimport classExtractFieldDescriptor from \"./classExtractFieldDescriptor.js\";\nexport default function _classPrivateFieldGet(receiver, privateMap) {\n var descriptor = classExtractFieldDescriptor(receiver, privateMap, \"get\");\n return classApplyDescriptorGet(receiver, descriptor);\n}","export default function _classApplyDescriptorGet(receiver, descriptor) {\n if (descriptor.get) {\n return descriptor.get.call(receiver);\n }\n return descriptor.value;\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateFieldInitSpec(obj, privateMap, value) {\n checkPrivateRedeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}","import classApplyDescriptorSet from \"./classApplyDescriptorSet.js\";\nimport classExtractFieldDescriptor from \"./classExtractFieldDescriptor.js\";\nexport default function _classPrivateFieldSet(receiver, privateMap, value) {\n var descriptor = classExtractFieldDescriptor(receiver, privateMap, \"set\");\n classApplyDescriptorSet(receiver, descriptor, value);\n return value;\n}","export default function _classApplyDescriptorSet(receiver, descriptor, value) {\n if (descriptor.set) {\n descriptor.set.call(receiver, value);\n } else {\n if (!descriptor.writable) {\n throw new TypeError(\"attempted to set read only private field\");\n }\n descriptor.value = value;\n }\n}","import { Location, parsePath } from \"history\";\nimport { matchPath } from \"@next-core/runtime\";\nimport type {\n SidebarMenuSimpleItem,\n SidebarMenuItem,\n SidebarMenuGroup,\n} from \"./types.js\";\n\nexport function isGroup(item: SidebarMenuItem): item is SidebarMenuGroup {\n return item.type === \"group\";\n}\n\nexport function isSubMenu(\n item: SidebarMenuItem,\n groupAsSubMenu?: boolean\n): item is SidebarMenuGroup {\n return Boolean(\n item.type === \"subMenu\" || (groupAsSubMenu && item.type === \"group\")\n );\n}\n\nexport function initMenuItemAndMatchCurrentPathKeys(\n menuItems: SidebarMenuItem[],\n pathname: string,\n search: string,\n parentCursor: string\n): {\n selectedKeys: string[];\n openedKeys: string[];\n} {\n const selectedKeys: string[] = [];\n const openedKeys: string[] = [];\n\n let cursor = 0;\n menuItems.forEach((item) => {\n // key的格式最终为0,1,2,0.1,0.2,0.1.1,0.1.2\n item.key = parentCursor === \"\" ? `${cursor}` : `${parentCursor}.${cursor}`;\n if (isGroup(item) || isSubMenu(item)) {\n const tmp = initMenuItemAndMatchCurrentPathKeys(\n item.items,\n pathname,\n search,\n item.key\n );\n selectedKeys.push(...tmp.selectedKeys);\n if (tmp.selectedKeys.length || item.defaultExpanded) {\n openedKeys.push(item.key);\n }\n openedKeys.push(...tmp.openedKeys);\n } else {\n if (matchMenuItem(item, pathname, search)) {\n selectedKeys.push(String(item.key));\n }\n }\n cursor += 1;\n });\n if (selectedKeys.length && parentCursor !== \"\") {\n openedKeys.push(parentCursor);\n }\n return {\n selectedKeys: selectedKeys,\n openedKeys: openedKeys,\n };\n}\n\nfunction getMatchOfSearch(\n currentSearch: string,\n toSearch: string | undefined\n): boolean {\n const current = new URLSearchParams(currentSearch);\n const to = new URLSearchParams(toSearch);\n for (const [key, value] of to.entries()) {\n if (current.get(key) !== value) {\n return false;\n }\n }\n return true;\n}\n\nexport function matchMenuItem(\n item: SidebarMenuSimpleItem,\n pathname: string,\n search: string\n): boolean {\n if (!item.to) return false;\n const to = typeof item.to === \"object\" ? item.to : parsePath(item.to);\n\n // Regex taken from: https://github.com/pillarjs/path-to-regexp/blob/master/index.js#L202\n const escapedPath = to.pathname!.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, \"\\\\$1\");\n\n let match = !!matchPath(pathname, {\n path: escapedPath,\n exact: item.exact,\n });\n\n if (!match && Array.isArray(item.activeIncludes)) {\n for (const include of item.activeIncludes) {\n let parseInclude: Location | undefined;\n const hasSearch = include.includes(\"?\");\n\n if (hasSearch) {\n parseInclude = parsePath(include);\n }\n match = !!matchPath(pathname, {\n path: hasSearch ? parseInclude!.pathname : include,\n exact: true,\n });\n\n if (match && parseInclude?.search) {\n match = getMatchOfSearch(search, parseInclude.search);\n }\n\n if (match) {\n break;\n }\n }\n }\n\n if (match && Array.isArray(item.activeExcludes)) {\n for (const include of item.activeExcludes) {\n match = !matchPath(pathname, {\n path: include,\n exact: true,\n });\n if (!match) {\n break;\n }\n }\n }\n\n if (match && (item as any).activeMatchSearch) {\n match = getMatchOfSearch(search, to.search);\n }\n\n return match;\n}\n"],"names":["initializeReactI18n","NS","locales","WrappedPopover","wrapBrick","WrappedSearch","onChange","onSearch","WrappedIcon","LOCAL_STORAGE_PREFIX","maxVisitorLength","ThreeLevelMenuPopoverContent","props","useTranslation","menuItem","selectedKey","items","searchResult","setSearchResult","useState","searchKey","setSearchKey","triggerRef","useRef","nameSpace","concat","title","storage","useMemo","JsonStorage","localStorage","searchHistory","getItem","popoverTriggerClick","_triggerRef$current","current","click","React","className","onClick","e","stopPropagation","placeholder","t","K","SEARCH_BY_MENU_NAME","detail","list","uniq","length","pop","setItem","flatMap","i","filter","text","toLowerCase","includes","trim","onFocus","onBlur","trigger","placement","anchorDisplay","distance","slot","ref","map","renderLinkCom","width","style","height","textAlign","lineHeight","NO_DATA","SEARCH_HISTORY","lib","theme","icon","h","key","gridTemplateColumns","item","index","_item$items","classnames","active","en","QUICK_ACCESS","REMOVE_ITEM_FROM_QUICK_ACCESS","ADD_ITEM_TO_QUICK_ACCESS","NO_DATA_TIPS_IN_QUICK_ACCESS","SITE_MAP_SEARCH_RECOMMEND","MAX_COLLECT_COUNT_TIPS","NO_DATA_SEARCH_INFO","SEARCH_ITEM_PLACEHOLDER","zh","MyCollectionApi_listMyCollection","_ref","params","options","http","get","_x","_x2","apply","this","arguments","DRAG_DIRECTION","collectModule","DragContext","collectService","constructor","maxCollectLength","_defineProperty","Map","getFavoritesById","id","_cloneDeep","cloneDeep","collectMap","fetchFavorites","_this","_asyncToGenerator","_yield$MyCollectionAp","isEmpty","favorites","module","collectionName","payloads","extInfo","Boolean","set","setItemAsFavorite","unshift","updateFavoriteItems","data","name","url","to","post","error","handleHttpError","equalItem","prevItem","removeItemFromFavorite","findIndex","row","splice","isCollected","some","toggleFavorite","checkMaxCapacity","moveFavoriteTo","option","from","direction","fromIndex","toIndex","Left","groupId","WrappedLink","WrappedTooltip","PlaceholderDropComp","onDragOver","onFavoriteUpdate","useContext","onDragEnter","target","background","onDragLeave","onDrop","formData","JSON","parse","dataTransfer","getData","newDataList","ItemTag","suffix","allowDrag","onDragStart","overElement","onDragEnd","containerRef","isDragIng","setIsDragIng","isActive","dataset","draggable","_e$dataTransfer","setData","stringify","preventDefault","dropEffect","classNames","href","Right","QuickVisitItem","onAllowDrag","onFavorite","suffixRef","handleRemove","useCallback","handleMouseDown","useEffect","handleClick","addEventListener","removeEventListener","suffixGroups","content","hoist","onMouseDown","StarIcon","_ref2","iconRef","_extends","RecommendItem","walkMenuItem","type","Array","isArray","walkMenuItems","push","itemColumnWidth","GroupView","groups","groupCategoryMap","categoryOrder","groupMenus","Set","forEach","_item$groupFrom","groupFrom","add","value","DefaultGroup","CustomGroup","groupRef","columnCount","setColumnCount","resizeObserver","ResizeObserver","entries","entry","contentRect","Math","floor","observe","disconnect","columnWidth","display","group","GroupItem","WrappedInput","onValueChange","SiteMapItem","menuGroup","visible","favoriteList","setFavoriteList","flatItems","flatMenuItems","q","setQ","setFilters","dragElement","setDragElement","setOverElement","setAllowDrag","setDirection","handleFavorite","collectList","handleSearch","v","debouncedHandleSearch","debounce","handleDragOver","throttle","dropElement","element","node","parentElement","findDropElement","isValidDragAction","left","getBoundingClientRect","right","clientX","undefined","hasData","Provider","handleDragEnd","enable","WrappedLinkItem","isGroup","isSubMenu","groupAsSubMenu","linkStyle","renderSpanCom","subMenu","___CSS_LOADER_EXPORT___","toString","_checkPrivateRedeclaration","obj","privateCollection","has","TypeError","_classExtractFieldDescriptor","receiver","privateMap","action","_classPrivateFieldGet","descriptor","call","classExtractFieldDescriptor","_classPrivateFieldInitSpec","_classPrivateFieldSet","writable","initMenuItemAndMatchCurrentPathKeys","menuItems","pathname","search","parentCursor","selectedKeys","openedKeys","cursor","tmp","defaultExpanded","parsePath","escapedPath","replace","match","matchPath","path","exact","activeIncludes","include","_parseInclude","parseInclude","hasSearch","getMatchOfSearch","activeExcludes","_include","activeMatchSearch","matchMenuItem","String","currentSearch","toSearch","URLSearchParams"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"chunks/4625.c8be40c2.js","mappings":";2OAoBAA,EAAAA,EAAAA,qBAAoBC,EAAAA,GAAIC,EAAAA,GACxB,IAAMC,GAAiBC,EAAAA,EAAAA,WAAiC,cAmBlDC,GAAgBD,EAAAA,EAAAA,WAKpB,YAAa,CACbE,SAAU,SACVC,SAAU,WAGNC,GAAcJ,EAAAA,EAAAA,WAAyC,WAMvDK,EAAuB,yBACvBC,EAAmB,EAClB,SAASC,EACdC,GAEA,IAAM,IAAQC,EAAAA,EAAAA,gBAAeZ,EAAAA,KACvB,SAAEa,EAAQ,YAAEC,GAAgBH,EAC5BI,EAAQF,EAASE,OAChBC,EAAcC,IAAmBC,EAAAA,EAAAA,UAAkC,KACnEC,EAAWC,IAAgBF,EAAAA,EAAAA,UAAS,IACrCG,GAAaC,EAAAA,EAAAA,QAAuB,MACpCC,EAAY,GAAHC,OAAMhB,EAAoB,KAAAgB,OAAIX,EAASY,OAChDC,GAAUC,EAAAA,EAAAA,UAAQ,IAAM,IAAIC,EAAAA,EAAYC,eAAe,IACvDC,EAAiBJ,EAAQK,QAAQR,IAA2B,GAwB5DS,EAAsBA,KAAM,IAAAC,EACd,QAAlBA,EAAAZ,EAAWa,eAAO,IAAAD,GAAlBA,EAAoBE,OAAO,EAG7B,OACEC,IAAAA,cAAA,OAAKC,UAAW,8BACdD,IAAAA,cAAA,OACEC,UAAU,oCACVC,QAAUC,IACRA,EAAEC,iBAAiB,GAGrBJ,IAAAA,cAAChC,EAAa,CACZqC,YAAaC,EAAEC,EAAAA,EAAEC,qBACjBtC,SApCciC,IAEpB,GADAnB,EAAamB,EAAEM,QACXN,EAAEM,OAAQ,CACZ,IAAMC,GAAOC,EAAAA,EAAAA,MAAK,CAACR,EAAEM,UAAWf,IAC5BgB,EAAKE,OAASvC,GAChBqC,EAAKG,MAEPvB,EAAQwB,QAAQ3B,EAAWuB,GAC3B7B,EACEF,EACGoC,SAASC,GAAOA,EAAErC,OAAqC,KACvDsC,QAAQD,GACNA,EAAEE,KACAC,cACAC,SAAUjB,EAAEM,OAAkBY,OAAOF,iBAGhD,MACEtC,EAAgB,GAClB,EAkBMyC,QAAS1B,EACT2B,OAAQ3B,IAEVI,IAAAA,cAAClC,EAAc,CACb0D,QAAQ,QACRC,UAAW,eACXC,cAAc,QACdC,SAAU,GAEV3B,IAAAA,cAAA,OAAK4B,KAAK,SAASC,IAAK5C,IAEtBe,IAAAA,cAAA,OAAKC,UAAU,oCACVrB,EAAagC,QACdhC,EAAakD,KAAKd,IAAMe,EAAAA,EAAAA,IAAcf,EAAG,CAAEgB,MAAO,WACnDjD,IAAcH,EAAagC,QAC1BZ,IAAAA,cAAA,OACEiC,MAAO,CACLC,OAAQ,QACRC,UAAW,SACXC,WAAY,UAGb9B,EAAEC,EAAAA,EAAE8B,eAOd3C,EAAckB,QACfZ,IAAAA,cAAA,OAAKC,UAAU,6CACbD,IAAAA,cAAA,OAAKC,UAAU,yCACZK,EAAEC,EAAAA,EAAE+B,gBACLtC,IAAAA,cAAC7B,EAAW,CACVoE,IAAI,OACJC,MAAM,WACNC,KAAK,SACLxC,UAAU,0CAGdD,IAAAA,cAAA,WACGN,EAAcoC,KAAKY,GAClB1C,IAAAA,cAAA,QAAM2C,IAAKD,EAAGzC,UAAU,wCACrByC,OAMX1C,IAAAA,cAAA,OACEC,UAAW,kCACXgC,MAAO,CACLW,oBAAqB,UAAFxD,OACjBT,EAAMiC,OAAS,EAAI,EAAIjC,EAAMiC,OAAM,WAItCjC,EAAMmD,KAAI,CAACe,EAAwBC,KAAa,IAAAC,EAAA,OAC/C/C,IAAAA,cAAA,OAAK2C,IAAKG,GACR9C,IAAAA,cAAA,OAAKC,UAAU,yCACbD,IAAAA,cAAA,QAAMC,UAAU,qCAChBD,IAAAA,cAAA,QAAMC,UAAU,+BAA+B4C,EAAKxD,QAE3C,QADL0D,EACLF,EAAKlE,aAAK,IAAAoE,OAAA,EAAVA,EAAYjB,KAAKd,GAChBhB,IAAAA,cAAA,QACE2C,IAAK3B,EAAE2B,IACP1C,UAAW+C,IAAW,CACpBC,SAAQjC,EAAE2B,KAAMjE,EAAY0C,SAASJ,EAAE2B,SAGxCZ,EAAAA,EAAAA,IAAcf,EAA4B,CAAEgB,MAAO,YAGpD,KAKhB,oDC1LO,IAAKzB,EAAC,SAADA,GAAC,OAADA,EAAC,0CAADA,EAAC,gCAADA,EAAC,kBAADA,EAAC,4BAADA,EAAC,8DAADA,EAAC,oDAADA,EAAC,4DAADA,EAAC,sDAADA,EAAC,gDAADA,EAAC,0CAADA,EAAC,kDAADA,CAAC,MA2CA3C,EAAK,sBAELC,EAAU,CAAEqF,GA/BN,CACjB1C,oBAAqB,sBACrB8B,eAAgB,iBAChBD,QAAS,UACTc,aAAc,eACdC,8BAA+B,2BAC/BC,yBAA0B,sBAC1BC,6BACE,mGACFC,0BAA2B,mBAC3BC,uBAAwB,gDACxBC,oBAAqB,iDACrBC,wBAAyB,mCAmBEC,GAhBV,CACjBnD,oBAAqB,WACrB8B,eAAgB,OAChBD,QAAS,OACTc,aAAc,OACdC,8BAA+B,UAC/BC,yBAA0B,UAC1BC,6BAA8B,yBAC9BC,0BAA2B,OAC3BC,uBAAwB,eACxBC,oBAAqB,eACrBC,wBAAyB,+JCjChBE,EAAgD,WACzD,IAAIC,GAAO,QAAkB,UAAWC,EAAQC,GAC9C,aAA8F,EAAAC,KAAKC,IAAI,yGAAyG,QAAc,OAAc,CAAC,EAAGF,GAAU,CAAC,EAAG,CAC1PD,aAEJ,IACF,IACA,OAAO,SAA0CI,EAAIC,GACnD,OAAON,EAAKO,MAAMC,KAAMC,UAC1B,CACF,CAV2D,GCL/CC,EAAc,SAAdA,GAAc,OAAdA,EAAc,YAAdA,EAAc,cAAdA,CAAc,MAiBbC,EAAgB,qBAEhBC,EAAczE,IAAAA,cACzB,CAAC,uBCyHU0E,EAAiB,IApIvB,MAILC,YAAYC,IAA2BC,EAAAA,EAAAA,GAAA,iCAAAA,EAAAA,EAAAA,GAAA,kBAFoB,IAAIC,KAG7DT,KAAKO,iBAAmBA,QAAAA,EAAoB,EAC9C,CAEOG,iBAAiBC,GAAqC,IAAAC,EAC3D,OAAyC,QAAzCA,GAAOC,EAAAA,EAAAA,WAAUb,KAAKc,WAAWlB,IAAIe,WAAI,IAAAC,EAAAA,EAAI,EAC/C,CAEaG,eAAeJ,GAA8C,IAAAK,EAAA,YAAAC,EAAAA,EAAAA,IAAA,gBAAAC,EACxE,KAAKC,EAAAA,EAAAA,SAAQH,EAAKN,iBAAiBC,IACjC,OAAOK,EAAKN,iBAAiBC,GAG/B,IAAMS,EAKI,QALKF,SACP3B,EAAiC,CACrC8B,OAAQlB,EACRmB,eAAgBX,KAElBY,gBAAQ,IAAAL,OAAA,EALQA,EAMdzD,KAAKe,GAASA,EAAKgD,UACpB5E,OAAO6E,SAIV,OAFAT,EAAKF,WAAWY,IAAIf,EAAIS,GAEjBA,CAAU,GAhBuDH,EAiB1E,CAEOU,kBAAkBhB,EAAYnC,GACnC,IAAMnC,EAAO2D,KAAKU,iBAAiBC,GAE/BtE,EAAKE,QAAUyD,KAAKO,kBACtBlE,EAAKG,MAGPH,EAAKuF,QAAQpD,GACbwB,KAAK6B,oBAAoBlB,EAAItE,EAC/B,CAEOwF,oBAAoBlB,EAAYtE,GACrC,IACE2D,KAAKc,WAAWY,IAAIf,EAAItE,GClDmByF,EDmDR,CACjCT,OAAQlB,EACRmB,eAAgBX,EAChBY,SAAUlF,aAAI,EAAJA,EAAMoB,KAAKe,IAAI,CACvBuD,KAAMvD,EAAK3B,KACXmF,IAAKxD,EAAKyD,GACVT,QAAShD,OCzDiI,EAAAmB,KAAKuC,KAAK,iHAAkHJ,EAAzNpC,UD4DnD,CAAE,MAAOyC,IAEPC,EAAAA,EAAAA,iBAAgBD,EAClB,CC/D4C,IAACL,CDgE/C,CAEQO,UACNC,EACA9D,GAEA,OAAO8D,EAASzF,OAAS2B,EAAK3B,MAAQyF,EAASL,KAAOzD,EAAKyD,EAC7D,CAEOM,uBAAuB5B,EAAYnC,GACxC,IAAMnC,EAAO2D,KAAKU,iBAAiBC,GAC7BlC,EAAQpC,EAAKmG,WAAWC,GAAQzC,KAAKqC,UAAUI,EAAKjE,MAE3C,IAAXC,IACFpC,EAAKqG,OAAOjE,EAAO,GACnBuB,KAAK6B,oBAAoBlB,EAAItE,GAEjC,CAEOsG,YAAYhC,EAAYnC,GAE7B,OADawB,KAAKU,iBAAiBC,GACvBiC,MAAMH,GAAQzC,KAAKqC,UAAUI,EAAKjE,IAChD,CAEOqE,eAAelC,EAAYnC,GAChC,GAAIwB,KAAK2C,YAAYhC,EAAInC,GACvBwB,KAAKuC,uBAAuB5B,EAAInC,OAC3B,CACL,GAAIwB,KAAK8C,iBAAiBnC,GAAK,OAC/BX,KAAK2B,kBAAkBhB,EAAInC,EAC7B,CACF,CAEOuE,eACLpC,EACAqC,GAMA,IAAM,KAAEC,EAAI,GAAEhB,EAAE,UAAEiB,GAAcF,EAE1B3G,EAAO2D,KAAKU,iBAAiBC,GACnC,GAAIX,KAAKqC,UAAUY,EAAMhB,GAAK,OAAO5F,EAErC,IAAM8G,EAAY9G,EAAKmG,WAAWC,GAAQzC,KAAKqC,UAAUI,EAAKQ,KAG9D,IAAmB,IAAfE,EAAkB,CACpB9G,EAAKqG,OAAOS,EAAW,GAEvB,IAAMC,EAAU/G,EAAKmG,WAAWC,GAAQzC,KAAKqC,UAAUI,EAAKR,MAG3C,IAAbmB,IACEF,IAAchD,EAAemD,KAC/BhH,EAAKqG,OAAOU,EAAS,EAAGH,GAExB5G,EAAKqG,OAAOU,EAAU,EAAG,EAAGH,GAG9BjD,KAAK6B,oBAAoBlB,EAAItE,GAEjC,CAEA,OAAOA,CACT,CAEAyG,iBAAiBQ,GACf,OAAOtD,KAAKU,iBAAiB4C,GAAS/G,QAAUyD,KAAKO,gBACvD,aEnHFjH,EAAAA,EAAAA,qBAAoBC,EAAAA,GAAIC,EAAAA,GACxB,IAAM+J,GAAc7J,EAAAA,EAAAA,WAA2B,WACzCI,GAAcJ,EAAAA,EAAAA,WAAyC,WACvD8J,GAAiB9J,EAAAA,EAAAA,WAAmC,cAenD,SAAS+J,EAAmBjE,GAIV,IAJW,KAClCsC,EAAI,WACJ4B,EAAU,UACVR,GACqB1D,GACf,QAAE8D,EAAO,iBAAEK,IAAqBC,EAAAA,EAAAA,YAAWxD,GAajD,OACEzE,IAAAA,cAAA,OACEC,UAAU,mBACV,iBAAgBsH,EAChB,UAASpB,EAAKG,GACd4B,YAAc/H,GACVA,EAAEgI,OAAuBlG,MAAMmG,WAAa,wBAEhDC,YAAclI,GACVA,EAAEgI,OAAuBlG,MAAMmG,WAAa,cAEhD,YAAWjC,EAAKjF,KAChB6G,WAAYA,EACZO,OAzBgBnI,IAClB,IAAMoI,EAAWC,KAAKC,MAAMtI,EAAEuI,aAAaC,QAAQ,qBAE7CC,EAAclE,EAAe0C,eAAeO,EAAS,CACzDL,KAAMiB,EACNjC,GAAIH,EACJoB,cAGFS,SAAAA,EAAmBY,EAAY,GAmBnC,CAEO,SAASC,EAAQtK,GACtB,IAAM,KAAE4H,EAAI,OAAE2C,EAAM,UAAE7I,GAAc1B,GAE9B,UACJwK,EAAS,YACTC,EAAW,YACXC,EAAW,UACX1B,EAAS,UACT2B,EAAS,WACTnB,IACEE,EAAAA,EAAAA,YAAWxD,GACT0E,GAAejK,EAAAA,EAAAA,QAAY,OAE1BkK,EAAWC,IAAgBvK,EAAAA,EAAAA,WAAS,GAErCwK,GAAW/J,EAAAA,EAAAA,UACf,IACE0J,GACAA,EAAYM,QAAQjD,IAAMH,EAAKG,IAC/B2C,EAAYM,QAAQrI,MAAS+H,EAAYM,QAAQrI,MACnD,CAAC+H,EAAa9C,IAuBhB,OACEnG,IAAAA,cAAAA,IAAAA,SAAA,KACGsJ,GAAY/B,IAAchD,EAAemD,MACxC1H,IAAAA,cAAC8H,EAAmB,CAClB3B,KAAMA,EACN4B,WAAYA,EACZR,UAAWhD,EAAemD,OAG9B1H,IAAAA,cAAC4H,EAAW,CACV,UAASzB,EAAKG,GACd,YAAWH,EAAKjF,KAChBW,IAAKsH,EACLK,WAAS,EACTR,YAlCmB7I,IAGhB,IAAAsJ,EAFFV,GAGHM,GAAa,GACC,QAAdI,EAAAtJ,EAAEuI,oBAAY,IAAAe,GAAdA,EAAgBC,QAAQ,mBAAoBlB,KAAKmB,UAAUxD,IAC3D6C,SAAAA,EAAc7I,IAJdA,EAAEyJ,gBAKJ,EA4BIV,UAzBiB/I,IACrBkJ,GAAa,GACbH,SAAAA,EAAY/I,EAAE,EAwBV4H,WArBc5H,IAClBA,EAAEuI,aAAamB,WAAa,OAC5B9B,SAAAA,EAAa5H,EAAE,EAoBXF,UAAW6J,IAAW,gBAAiB7J,EAAW,CAChD,UAAWmJ,IAEb/C,IAAKF,EAAKG,GACVyD,KAAM5D,EAAK4D,KACX5B,OAAQhC,EAAKgC,QAEbnI,IAAAA,cAAA,QAAMC,UAAU,oBAAoBZ,MAAO8G,EAAKjF,MAC7CiF,EAAKjF,MAERlB,IAAAA,cAAA,QAAMC,UAAU,aAAaC,QAAUC,GAAMA,EAAEyJ,kBAC5Cd,IAIJQ,GAAY/B,IAAchD,EAAeyF,OACxChK,IAAAA,cAAC8H,EAAmB,CAClB3B,KAAMA,EACN4B,WAAYA,EACZR,UAAWhD,EAAeyF,QAKpC,CAOO,SAASC,EAAe1L,GAC7B,IAAM,IAAQC,EAAAA,EAAAA,gBAAeZ,EAAAA,KACvB,YAAEsM,IAAgBjC,EAAAA,EAAAA,YAAWxD,IAC7B,KAAE0B,EAAI,WAAEgE,EAAU,QAAExC,GAAYpJ,EAChC6L,GAAYlL,EAAAA,EAAAA,UAEZmL,GAAeC,EAAAA,EAAAA,cAAY,KAC/B5F,EAAekC,uBAAuBe,EAASxB,GAC/CgE,SAAAA,EAAazF,EAAeK,iBAAiB4C,GAAS,GACrD,CAACA,EAASxB,EAAMgE,IAEbI,EAAkBA,KACtBL,SAAAA,GAAc,EAAK,GAGrBM,EAAAA,EAAAA,YAAU,KACR,IAAM1B,EAASsB,EAAUtK,QACnB2K,EAAetK,IACnBA,EAAEyJ,gBAAgB,EAIpB,OAFAd,EAAO4B,iBAAiB,QAASD,GAE1B,KACL3B,EAAO6B,oBAAoB,QAASF,EAAY,CACjD,GACA,IAEH,IAAMG,GAAerL,EAAAA,EAAAA,UACnB,IACES,IAAAA,cAAA,OAAKC,UAAU,YAAY4B,IAAKuI,GAC9BpK,IAAAA,cAAC6H,EAAc,CACbgD,QAASvK,EAAEC,EAAAA,EAAE6C,+BACb0H,OAAK,EACLrJ,UAAU,SACVxB,UAAU,QACVC,QAASmK,GAETrK,IAAAA,cAAC7B,EAAW,CAACoE,IAAI,OAAOE,KAAK,WAE/BzC,IAAAA,cAAA,QAAMC,UAAU,eAAe8K,YAAaR,GAAiB,SAKjE,CAACjK,EAAG+J,IAGN,OACErK,IAAAA,cAAC6I,EAAO,CAAC5I,UAAU,kBAAkB6I,OAAQ8B,EAAczE,KAAMA,GAErE,CAUO,SAAS6E,EAAQC,GAMc,IANb,WACvBd,EAAU,UACVlK,EAAS,QACT0H,EAAO,KACPxB,EAAI,OACJlD,GACcgI,GACR,EAAE3K,IAAM9B,EAAAA,EAAAA,gBAAeZ,EAAAA,IACvBsN,GAAUhM,EAAAA,EAAAA,UAEVuL,EAAetK,IACnBA,EAAEyJ,iBACFlF,EAAewC,eAAeS,EAASxB,GACvCgE,SAAAA,EAAazF,EAAeK,iBAAiB4C,GAAS,EAaxD,OAVA6C,EAAAA,EAAAA,YAAU,KAER,IAAM/H,EAAOyI,EAAQpL,QAGrB,OAFA2C,EAAKiI,iBAAiB,QAASD,GAExB,KACLhI,EAAKkI,oBAAoB,QAASF,EAAY,CAC/C,GACA,IAGDzK,IAAAA,cAAC6H,EAAc,CACbgD,QACE5H,EACI3C,EAAEC,EAAAA,EAAE6C,+BACJsB,EAAeyC,iBAAiBQ,GAChCrH,EAAEC,EAAAA,EAAEiD,wBACJlD,EAAEC,EAAAA,EAAE8C,0BAEVpD,UAAW6J,IAAW,YAAa7J,IAEnCD,IAAAA,cAAC7B,GAAWgN,EAAAA,EAAAA,GAAA,CACVtJ,IAAKqJ,EACLjL,UAAW6J,IAAW,CAAE7G,WACxBV,IAAI,OACJE,KAAK,QACAQ,EAAS,CAAET,MAAO,UAAa,CAAC,IAI7C,CAQO,SAAS4I,EAAc7M,GAC5B,IAAM,KAAE4H,EAAI,UAAElG,EAAS,QAAE0H,EAAO,WAAEwC,EAAU,OAAElH,GAAW1E,EAEnDqM,GAAerL,EAAAA,EAAAA,UACnB,IACES,IAAAA,cAACgL,EAAQ,CACPrD,QAASA,EACT1E,OAAQA,EACRhD,UAAU,OACVkG,KAAMA,EACNgE,WAAYA,KAGhB,CAAChE,EAAMwB,EAASwC,EAAYlH,IAG9B,OACEjD,IAAAA,cAAC6I,EAAO,CACN5I,UAAW6J,IAAW,sBAAuB7J,GAC7C6I,OAAQ8B,EACRzE,KAAMA,GAGZ,CC7SA,SAASkF,EAAaxI,EAAuBnC,GAEL,UAAnCmC,EAA0ByI,MAC3BC,MAAMC,QAAS3I,EAA0BlE,OAQ7C,SACEA,EACA+B,GAEA,IAAK,IAAMmC,KAAQlE,EACjB0M,EAAaxI,EAAMnC,EAEvB,CAbI+K,CAAe5I,EAA0BlE,MAAO+B,GAEhDA,EAAKgL,KAAK7I,EAEd,CCHA,IAAM+E,GAAc7J,EAAAA,EAAAA,WAA2B,WASlC4N,EAAkB,IAExB,SAASC,EAAUrN,GACxB,IDUgCsN,EAI1BC,EACAC,GCfA,QAAEpE,EAAO,YAAEjJ,EAAW,WAAEyL,GAAe5L,EACvCyN,GDS0BH,ECTKtN,EAAMsN,ODarCC,EAAmB,IAAIhH,IACvBiH,EAAgB,IAAIE,IAE1BJ,SAAAA,EAAQK,SAASrJ,IAAS,IAAAsJ,EAClB7E,EAAqB,QAAjB6E,EAAGtJ,EAAKuJ,iBAAS,IAAAD,EAAAA,EAAI,UAC/BJ,EAAcM,IAAI/E,GAElB,IAAMgF,EAAQR,EAAiB7H,IAAIqD,GAE9BgF,EAGHA,EAAOZ,KAAK7I,GAFZiJ,EAAiB/F,IAAIuB,EAAM,CAACzE,GAG9B,IAGK0I,MAAMjE,KAAKyE,GAAejK,KAAKa,IAAG,CACvCyJ,UAAWzJ,EACXkJ,OAAQC,EAAkB7H,IAAItB,QC7BhC,OACE3C,IAAAA,cAAA,OAAKC,UAAU,cACZ+L,EAAWlK,KAAI,CAACe,EAAMC,IAEnB9C,IAAAA,cAAA,OAAK2C,IAAKG,GACG,IAAVA,GAAe9C,IAAAA,cAAA,OAAKC,UAAU,YACX,YAAnB4C,EAAKuJ,UACJpM,IAAAA,cAACuM,EAAY,CACX5E,QAASA,EACTjJ,YAAaA,EACbmN,OAAQhJ,EAAKgJ,OACb1B,WAAYA,IAGdnK,IAAAA,cAACwM,EAAW,CACV7E,QAASA,EACTjJ,YAAaA,EACbmN,OAAQhJ,EAAKgJ,OACb1B,WAAYA,OAQ5B,CAQO,SAASoC,EAAahO,GAC3B,IAAM,QAAEoJ,EAAO,WAAEwC,EAAU,YAAEzL,EAAW,OAAEmN,GAAWtN,EAE/CkO,EAAWzM,IAAAA,OAA6B,OACvC0M,EAAaC,IAAkB7N,EAAAA,EAAAA,YAmBtC,OAjBA0L,EAAAA,EAAAA,YAAU,KAER,IAAMoC,EAAiB,IAAIC,gBAAgBC,IACzC,IAAK,IAAMC,KAASD,EAClB,GAAIC,EAAM5E,SAAWsE,EAAS3M,QAAS,CACrC,IAAMkC,EAAQ+K,EAAMC,YAAYhL,MAEhC2K,EAAeM,KAAKC,MAAMlL,EAAQ2J,GACpC,CACF,IAKF,OAFAiB,EAAeO,QAAQV,EAAS3M,SAEzB,IAAM8M,EAAeQ,YAAY,GACvC,IAGDpN,IAAAA,cAAA,OACEC,UAAU,QACV4B,IAAK4K,EACLxK,MACGyK,GAAyBb,aAAM,EAANA,EAAQjL,QAC9B,CAAE8L,cAAaW,YAAa1B,GAC5B,CACE2B,QAAS,OACT1K,oBAAqB,oBAAFxD,OAAsBuM,EAAe,SAI/DE,EAAO/J,KAAKyL,GACXvN,IAAAA,cAAA,OAAK2C,IAAK4K,EAAM5K,IAAK1C,UAAU,cAC7BD,IAAAA,cAAA,OAAKC,UAAU,SAASsN,EAAMlO,OAC9BW,IAAAA,cAAA,OAAKC,UAAU,WACZsN,EAAM5O,MAAMmD,KAAKe,GAChB7C,IAAAA,cAACwN,EAAS,CACR7K,IAAKE,EAAKF,IACVgF,QAASA,EACTjJ,YAAaA,EACbyH,KAAMtD,EACNsH,WAAYA,UAQ5B,CAEO,SAASqC,EAAYjO,GAC1B,IAAM,QAAEoJ,EAAO,WAAEwC,EAAU,YAAEzL,EAAW,OAAEmN,GAAWtN,EAErD,OACEyB,IAAAA,cAAA,OAAKC,UAAU,gBACZ4L,EAAO/J,KAAKyL,GACXvN,IAAAA,cAAA,OAAK2C,IAAK4K,EAAM5K,KACd3C,IAAAA,cAAA,OAAKC,UAAU,SAASsN,EAAMlO,OAC9BW,IAAAA,cAAA,OACEC,UAAU,iBACVgC,MAAO,CACLqL,QAAS,OACT1K,oBAAqB,oBAAFxD,OAAsBuM,EAAe,SAGzD4B,EAAM5O,MAAMmD,KAAKe,GAChB7C,IAAAA,cAACwN,EAAS,CACR7K,IAAKE,EAAKF,IACVjE,YAAaA,EACbiJ,QAASA,EACTxB,KAAMtD,EACNsH,WAAYA,UAQ5B,CAQO,SAASqD,EAAUjP,GACxB,IAAM,KAAE4H,EAAI,QAAEwB,EAAO,WAAEwC,EAAU,YAAEzL,GAAgBH,EAEnD,OACEyB,IAAAA,cAAC4H,EAAW,CACVjF,IAAKwD,EAAKxD,IACVF,KAAM0D,EAAK1D,KACX4D,IAAKF,EAAKG,GACVyD,KAAM5D,EAAK4D,KACX5B,OAAQhC,EAAKgC,OACblI,UAAW6J,IAAW,YAAa,CACjC7G,OAAQvE,aAAW,EAAXA,EAAa0C,SAAS+E,EAAKxD,QAGrC3C,IAAAA,cAAA,QAAMC,UAAU,WAAWZ,MAAO8G,EAAKjF,MACpCiF,EAAKjF,MAERlB,IAAAA,cAAA,QAAMC,UAAU,gBACdD,IAAAA,cAACgL,EAAQ,CACP/H,OAAQyB,EAAesC,YAAYW,EAASxB,GAC5CwB,QAASA,EACTxB,KAAMA,EACNgE,WAAYA,KAKtB,CChKA,IAAMhM,GAAcJ,EAAAA,EAAAA,WAAyC,WAUvD0P,GAAe1P,EAAAA,EAAAA,WACnB,WACA,CACE2P,cAAe,WAoCZ,SAASC,EAAYpP,GAC1B,IAAM,IAAQC,EAAAA,EAAAA,gBAAeZ,EAAAA,KACvB,UAAEgQ,EAAS,YAAElP,EAAW,QAAEmP,GAAYtP,EACtCoJ,EAAUiG,EAAUjG,SAEnBmG,EAAcC,IAAmBjP,EAAAA,EAAAA,UAAkC,IACpEkP,GAAYzO,EAAAA,EAAAA,UAAQ,KAAM0O,OF/ChC5C,EE+C8CuC,EFjDxClN,EAAgC,IAI/BA,EALF,IACCA,CEiDkD,GAAE,CAACkN,KACpDM,EAAGC,IAAQrP,EAAAA,EAAAA,aACXmC,EAAQmN,IAActP,EAAAA,EAAAA,UAAkC,KACxDuP,EAAaC,IAAkBxP,EAAAA,EAAAA,aAC/BmK,EAAasF,IAAkBzP,EAAAA,EAAAA,aAC/BiK,EAAWyF,IAAgB1P,EAAAA,EAAAA,aAC3ByI,EAAWkH,IAAgB3P,EAAAA,EAAAA,YAE5B4P,EAAkBC,IACtBZ,EAAgBY,EAAY,EAGxBC,GAAetE,EAAAA,EAAAA,cAClBnK,IACC,IAAM0O,EAAI1O,EAAEM,OACZ0N,EAAKhO,EAAEM,QAEP2N,EACGS,EAEGb,EAAU/M,QAAQ4B,GAChBA,EAAK3B,KAAKC,cAAcC,SAASjB,EAAEM,OAAOU,iBAF5C6M,EAIL,GAEH,CAACA,IAGGc,GAAwBvP,EAAAA,EAAAA,UAC5B,KAAMwP,EAAAA,EAAAA,UAASH,EAAc,MAC7B,CAACA,IAOGI,GAAiBzP,EAAAA,EAAAA,UACrB,KACE0P,EAAAA,EAAAA,WAAU9O,IACRA,EAAEyJ,iBAEF,IAAMsF,EA1EP,SAAyBC,GAG9B,IAFA,IAAIC,EAAOD,EAEJC,GAAM,CACX,GAAIA,EAAK5F,WAAgC,qBAAnB4F,EAAKnP,UACzB,OAAOmP,EAGTA,EAAOA,EAAKC,aACd,CACF,CAgE4BC,CAAgBnP,EAAEgI,QAGtC,GAFAoG,EAAeW,GAGbA,GAlEH,SACLb,EACAa,GAEA,OACEb,GACAa,KAEEb,EAAY9E,QAAQjD,KAAO4I,EAAY3F,QAAQjD,IAC/C+H,EAAY9E,QAAQrI,OAASgO,EAAY3F,QAAQrI,KAGvD,CAuDUqO,CAAkBL,EAAab,GAE/B,GAA8B,qBAA1Ba,EAAYjP,UACdwO,EAAaS,EAAY3F,QAAQhC,eAC5B,CACL,IAAM,MAAEvF,EAAK,KAAEwN,GAASN,EAAYO,wBAE9BC,EAAQvP,EAAEwP,QAAUH,EAAOxN,EAAQ,EACzCyM,EAAaiB,EAAQnL,EAAeyF,MAAQzF,EAAemD,KAC7D,MAEA+G,OAAamB,EACf,KAEJ,CAACvB,IAsBH,OATA7D,EAAAA,EAAAA,YAAU,MACRlF,EAAAA,EAAAA,IAAC,YACC,GAAIuI,EAAS,CACX,IAAMnN,QAAagE,EAAeU,eAAeuC,GACjDoG,EAAgBrN,EAClB,CACF,GALA4E,EAKI,GACH,CAACqC,EAASkG,IAGX7N,IAAAA,cAAA,OAAKC,UAAU,YACbD,IAAAA,cAAA,OAAKC,UAAU,kBACbD,IAAAA,cAACyN,EAAY,CACXxN,UAAU,eACVgC,MAAO,CAAED,MAAO,QAChB0L,cAAeoB,EACfzO,YAAaC,EAAEC,EAAAA,EAAEmD,0BAEjB1D,IAAAA,cAAC7B,EAAW,CAACyD,KAAK,SAASW,IAAI,OAAOE,KAAK,cAI7CyL,GACAlO,IAAAA,cAAA,WAC2B,IAAxB8N,EAAalN,QACZZ,IAAAA,cAAA,OACEC,UAAW6J,IAAW,eAAgB,CACpC+F,QAAS/B,EAAalN,UAGxBZ,IAAAA,cAAA,QAAMC,UAAU,SAASK,EAAEC,EAAAA,EAAE4C,eAC7BnD,IAAAA,cAACyE,EAAYqL,SAAQ,CACnBxD,MAAO,CACL3E,UACAsB,cACA1B,YACAwB,YACAC,YA9ES7I,IACvBmO,EAAenO,EAAEgI,OAAsB,EA8EzBJ,WAAYiH,EACZ9F,UAjDM6G,KACpBzB,OAAesB,GACfnB,OAAamB,GACbpB,GAAa,EAAM,EA+CLtE,YA5CS8F,IACvBxB,EAAawB,EAAO,EA4CNhI,iBAAkB0G,IAGpB1O,IAAAA,cAAA,OAAKC,UAAU,eACZ6N,EAAahM,KAAKe,GACjB7C,IAAAA,cAACiK,EAAc,CACbE,WAAYuE,EACZ/G,QAASA,EACThF,IAAKE,EAAKF,IACVwD,KAAMtD,SAQlB7C,IAAAA,cAAC4L,EAAS,CACRjE,QAASA,EACTjJ,YAAaA,EACbmN,OAAQ+B,EAAUjP,MAClBwL,WAAYuE,KAKjBR,GACClO,IAAAA,cAAA,OAAKC,UAAU,gBACbD,IAAAA,cAAA,QAAMC,UAAU,SAASK,EAAEC,EAAAA,EAAEgD,4BAC5BtC,EAAOL,OACNZ,IAAAA,cAAA,OAAKC,UAAU,qBACZgB,EAAOa,KAAKe,GACX7C,IAAAA,cAACoL,EAAa,CACZzI,IAAKE,EAAKF,IACVgF,QAASA,EACTxB,KAAMtD,EACNsH,WAAYuE,EACZzL,OAAQyB,EAAesC,YAAYW,EAAS9E,QAKlD7C,IAAAA,cAAA,OAAKC,UAAU,gBAAgBK,EAAEC,EAAAA,EAAEkD,uBAM/C,gGCnOMtF,GAAcJ,EAAAA,EAAAA,WAAyC,WAEvDkS,GAAkBlS,EAAAA,EAAAA,WAA2B,WAE5C,SAASmS,EAAQrN,GACtB,MAAqB,UAAdA,EAAKyI,IACd,CAEO,SAAS6E,EACdtN,EACAuN,GAEA,OAAOtK,QACS,YAAdjD,EAAKyI,MAAuB8E,GAAgC,UAAdvN,EAAKyI,KAEvD,CAMO,IAAMvJ,EAAgBA,CAC3Bc,EACAwN,IAGErQ,IAAAA,cAACiQ,EAAe,CACdtN,IAAKE,EAAKF,IACV0D,IAAKxD,EAAKyD,GACVyD,KAAMlH,EAAKkH,KACX5B,OAAQtF,EAAKsF,OACblG,MAAOoO,GAEPrQ,IAAAA,cAAA,QAAMC,UAAU,mBAAmB4C,EAAK3B,OAKjCoP,EAAgBA,CAC3BzN,EACA0N,IAGEvQ,IAAAA,cAAA,QAAM2C,IAAKE,EAAKF,IAAK1C,UAAU,mBAC5B4C,EAAKxD,MACLkR,GAAWvQ,IAAAA,cAAC7B,EAAW,CAACoE,IAAI,KAAKE,KAAK,mFCtDzC+N,QAA0B,GAA4B,KAE1DA,EAAwB9E,KAAK,CAAChG,EAAOV,GAAI,kyIAMo+E,KAE7gF,QAAewL,EAAwBC,6ECVnCD,QAA0B,GAA4B,KAE1DA,EAAwB9E,KAAK,CAAChG,EAAOV,GAAI,qlEAGyiD,KAEllD,QAAewL,EAAwBC,6ECPnCD,QAA0B,GAA4B,KAE1DA,EAAwB9E,KAAK,CAAChG,EAAOV,GAAI,irCAAkrC,KAE3tC,QAAewL,EAAwBC,6ECJnCD,QAA0B,GAA4B,KAE1DA,EAAwB9E,KAAK,CAAChG,EAAOV,GAAI,08CAA28C,KAEp/C,QAAewL,EAAwBC,2BCPxB,SAASC,EAA2BC,EAAKC,GACtD,GAAIA,EAAkBC,IAAIF,GACxB,MAAM,IAAIG,UAAU,iEAExB,iCCJe,SAASC,EAA6BC,EAAUC,EAAYC,GACzE,IAAKD,EAAWJ,IAAIG,GAClB,MAAM,IAAIF,UAAU,gBAAkBI,EAAS,kCAEjD,OAAOD,EAAWhN,IAAI+M,EACxB,+DCHe,SAASG,EAAsBH,EAAUC,GAEtD,OCJa,SAAkCD,EAAUI,GACzD,OAAIA,EAAWnN,IACNmN,EAAWnN,IAAIoN,KAAKL,GAEtBI,EAAW9E,KACpB,CDDS,CAAwB0E,GADd,EAAAM,EAAA,GAA4BN,EAAUC,EAAY,OAErE,iDEJe,SAASM,EAA2BZ,EAAKM,EAAY3E,IAClE,OAA0BqE,EAAKM,GAC/BA,EAAWlL,IAAI4K,EAAKrE,EACtB,+CCFe,SAASkF,EAAsBR,EAAUC,EAAY3E,GAGlE,OCLa,SAAkC0E,EAAUI,EAAY9E,GACrE,GAAI8E,EAAWrL,IACbqL,EAAWrL,IAAIsL,KAAKL,EAAU1E,OACzB,CACL,IAAK8E,EAAWK,SACd,MAAM,IAAIX,UAAU,4CAEtBM,EAAW9E,MAAQA,CACrB,CACF,CDLE,CAAwB0E,GADP,EAAAM,EAAA,GAA4BN,EAAUC,EAAY,OACrB3E,GACvCA,CACT,4DEeO,SAASoF,EACdC,EACAC,EACAC,EACAC,GAKA,IAAMC,EAAyB,GACzBC,EAAuB,GAEzBC,EAAS,EA0Bb,OAzBAN,EAAUzF,SAASrJ,IAGjB,GADAA,EAAKF,IAAuB,KAAjBmP,EAAsB,GAAH1S,OAAM6S,GAAM,GAAA7S,OAAQ0S,EAAY,KAAA1S,OAAI6S,GA5B/D,SAAiBpP,GACtB,MAAqB,UAAdA,EAAKyI,IACd,CA2BQ4E,CAAQrN,IAzBT,SACLA,EACAuN,GAEA,OAAOtK,QACS,YAAdjD,EAAKyI,WAoBgB6E,EAlBzB,CAkByBA,CAAUtN,GAAO,CACpC,IAAMqP,EAAMR,EACV7O,EAAKlE,MACLiT,EACAC,EACAhP,EAAKF,KAEPoP,EAAarG,QAAQwG,EAAIH,eACrBG,EAAIH,aAAanR,QAAUiC,EAAKsP,kBAClCH,EAAWtG,KAAK7I,EAAKF,KAEvBqP,EAAWtG,QAAQwG,EAAIF,WACzB,MA8BG,SACLnP,EACA+O,EACAC,GAEA,IAAKhP,EAAKyD,GAAI,OAAO,EACrB,IAAMA,EAAwB,iBAAZzD,EAAKyD,GAAkBzD,EAAKyD,IAAK8L,EAAAA,EAAAA,WAAUvP,EAAKyD,IAG5D+L,EAAc/L,EAAGsL,SAAUU,QAAQ,4BAA6B,QAElEC,KAAUC,EAAAA,EAAAA,WAAUZ,EAAU,CAChCa,KAAMJ,EACNK,MAAO7P,EAAK6P,QAGd,IAAKH,GAAShH,MAAMC,QAAQ3I,EAAK8P,gBAC/B,IAAK,IAAMC,KAAW/P,EAAK8P,eAAgB,KAAAE,EACrCC,OAAkC,EAChCC,EAAYH,EAAQxR,SAAS,KAcnC,GAZI2R,IACFD,GAAeV,EAAAA,EAAAA,WAAUQ,KAE3BL,KAAUC,EAAAA,EAAAA,WAAUZ,EAAU,CAC5Ba,KAAMM,EAAYD,EAAclB,SAAWgB,EAC3CF,OAAO,MAGgB,QAAhBG,EAAIC,SAAY,IAAAD,GAAZA,EAAchB,SACzBU,EAAQS,EAAiBnB,EAAQiB,EAAajB,SAG5CU,EACF,KAEJ,CAGF,GAAIA,GAAShH,MAAMC,QAAQ3I,EAAKoQ,gBAC9B,IAAK,IAAMC,KAAWrQ,EAAKoQ,eAKzB,KAJAV,IAASC,EAAAA,EAAAA,WAAUZ,EAAU,CAC3Ba,KAAMS,EACNR,OAAO,KAGP,MASN,OAJIH,GAAU1P,EAAasQ,oBACzBZ,EAAQS,EAAiBnB,EAAQvL,EAAGuL,SAG/BU,CACT,EArFUa,CAAcvQ,EAAM+O,EAAUC,IAChCE,EAAarG,KAAK2H,OAAOxQ,EAAKF,MAGlCsP,GAAU,CAAC,IAETF,EAAanR,QAA2B,KAAjBkR,GACzBE,EAAWtG,KAAKoG,GAEX,CACLC,aAAcA,EACdC,WAAYA,EAEhB,CAEA,SAASgB,EACPM,EACAC,GAEA,IAAMzT,EAAU,IAAI0T,gBAAgBF,GAC9BhN,EAAK,IAAIkN,gBAAgBD,GAC/B,IAAK,IAAO5Q,EAAK2J,KAAUhG,EAAGwG,UAC5B,GAAIhN,EAAQmE,IAAItB,KAAS2J,EACvB,OAAO,EAGX,OAAO,CACT","sources":["webpack:///./src/nav-menu/ThreeLevelMenuPopoverContent.tsx","webpack:///./src/nav-menu/i18n.ts","webpack:///../../node_modules/@next-api-sdk/user-service-sdk/dist/esm/api/user_service/my_collection/listMyCollection.js","webpack:///./src/nav-menu/site-map/constants.ts","webpack:///./src/nav-menu/site-map/CollectService.ts","webpack:///../../node_modules/@next-api-sdk/user-service-sdk/dist/esm/api/user_service/my_collection/upsertMyCollection.js","webpack:///./src/nav-menu/site-map/ItemTag.tsx","webpack:///./src/nav-menu/site-map/processor.ts","webpack:///./src/nav-menu/site-map/GroupItem.tsx","webpack:///./src/nav-menu/site-map/SiteMapItem.tsx","webpack:///./src/nav-menu/utils.tsx","webpack:///./src/nav-menu/nav-menu.shadow.css","webpack:///./src/nav-menu/site-map/GroupItem.shadow.css","webpack:///./src/nav-menu/site-map/ItemTag.shadow.css","webpack:///./src/nav-menu/site-map/SiteMapItem.shadow.css","webpack:///../../node_modules/@babel/runtime/helpers/esm/checkPrivateRedeclaration.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classExtractFieldDescriptor.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldGet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classApplyDescriptorGet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldSet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classApplyDescriptorSet.js","webpack:///../../src/menu.ts"],"sourcesContent":["import React, { useMemo, useState, useRef } from \"react\";\nimport classnames from \"classnames\";\nimport { renderLinkCom } from \"./utils.js\";\nimport { uniq } from \"lodash\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuItem,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type { ReactNextElement } from \"@next-core/react-element\";\nimport type { Popover, PopoverProps } from \"@next-bricks/basic/popover\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { JsonStorage } from \"@next-shared/general/JsonStorage\";\nimport { K, NS, locales } from \"./i18n.js\";\nimport { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\n\ninitializeReactI18n(NS, locales);\nconst WrappedPopover = wrapBrick<Popover, PopoverProps>(\"eo-popover\");\ninterface SearchProps {\n value?: string;\n placeholder?: string;\n autoFocus?: boolean;\n clearable?: boolean;\n trim?: boolean;\n debounceTime?: number;\n}\n\ninterface SearchEvents {\n change: CustomEvent<string>;\n search: CustomEvent<string>;\n}\n\ninterface SearchEventsMap {\n onChange: \"change\";\n onSearch: \"search\";\n}\nconst WrappedSearch = wrapBrick<\n ReactNextElement,\n SearchProps,\n SearchEvents,\n SearchEventsMap\n>(\"eo-search\", {\n onChange: \"change\",\n onSearch: \"search\",\n});\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\ninterface ThreeLevelMenuPopoverContentProps {\n menuItem: SidebarMenuGroup;\n selectedKey: string[];\n}\nconst LOCAL_STORAGE_PREFIX = \"threeLevelCategoryMenu\";\nconst maxVisitorLength = 6;\nexport function ThreeLevelMenuPopoverContent(\n props: ThreeLevelMenuPopoverContentProps\n): React.ReactElement {\n const { t } = useTranslation(NS);\n const { menuItem, selectedKey } = props;\n const items = menuItem.items as SidebarMenuGroup[];\n const [searchResult, setSearchResult] = useState<SidebarMenuSimpleItem[]>([]);\n const [searchKey, setSearchKey] = useState(\"\");\n const triggerRef = useRef<HTMLDivElement>(null);\n const nameSpace = `${LOCAL_STORAGE_PREFIX}_${menuItem.title}`;\n const storage = useMemo(() => new JsonStorage(localStorage), []);\n const searchHistory = (storage.getItem(nameSpace) as string[]) || [];\n\n const handleSearch = (e: CustomEvent<string>) => {\n setSearchKey(e.detail);\n if (e.detail) {\n const list = uniq([e.detail, ...searchHistory]);\n if (list.length > maxVisitorLength) {\n list.pop();\n }\n storage.setItem(nameSpace, list);\n setSearchResult(\n items\n .flatMap((i) => (i.items as SidebarMenuSimpleItem[]) || [])\n .filter((i) =>\n (i.text as string)\n .toLowerCase()\n .includes((e.detail as string).trim().toLowerCase())\n )\n );\n } else {\n setSearchResult([]);\n }\n };\n\n const popoverTriggerClick = () => {\n triggerRef.current?.click();\n };\n\n return (\n <div className={\"three-level-menu-container\"}>\n <div\n className=\"three-level-menu-search-container\"\n onClick={(e) => {\n e.stopPropagation();\n }}\n >\n <WrappedSearch\n placeholder={t(K.SEARCH_BY_MENU_NAME) as string}\n onSearch={handleSearch}\n onFocus={popoverTriggerClick}\n onBlur={popoverTriggerClick}\n />\n <WrappedPopover\n trigger=\"click\"\n placement={\"bottom-start\"}\n anchorDisplay=\"block\"\n distance={0}\n >\n <div slot=\"anchor\" ref={triggerRef}></div>\n {\n <div className=\"three-level-menu-search-result\">\n {!!searchResult.length &&\n searchResult.map((i) => renderLinkCom(i, { width: \"100%\" }))}\n {searchKey && !searchResult.length && (\n <div\n style={{\n height: \"100px\",\n textAlign: \"center\",\n lineHeight: \"100px\",\n }}\n >\n {t(K.NO_DATA)}\n </div>\n )}\n </div>\n }\n </WrappedPopover>\n </div>\n {!!searchHistory.length && (\n <div className=\"three-level-menu-search-history-container\">\n <div className=\"three-level-menu-search-history-title\">\n {t(K.SEARCH_HISTORY)}\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"delete\"\n className=\"three-level-menu-search-history-icon\"\n />\n </div>\n <div>\n {searchHistory.map((h) => (\n <span key={h} className=\"three-level-menu-search-history-text\">\n {h}\n </span>\n ))}\n </div>\n </div>\n )}\n <div\n className={\"three-level-menu-item-container\"}\n style={{\n gridTemplateColumns: `repeat(${\n items.length > 4 ? 4 : items.length\n },1fr)`,\n }}\n >\n {items.map((item: SidebarMenuGroup, index: number) => (\n <div key={index}>\n <div className=\"three-level-menu-item-title-container\">\n <span className=\"three-level-menu-item-title-icon\"></span>\n <span className=\"three-level-menu-item-title\">{item.title}</span>\n </div>\n {item.items?.map((i) => (\n <span\n key={i.key}\n className={classnames({\n active: i.key ? selectedKey.includes(i.key) : false,\n })}\n >\n {renderLinkCom(i as SidebarMenuSimpleItem, { width: \"100%\" })}\n </span>\n ))}\n </div>\n ))}\n </div>\n </div>\n );\n}\n","export enum K {\n SEARCH_BY_MENU_NAME = \"SEARCH_BY_MENU_NAME\",\n SEARCH_HISTORY = \"SEARCH_HISTORY\",\n NO_DATA = \"NO_DATA\",\n QUICK_ACCESS = \"QUICK_ACCESS\",\n REMOVE_ITEM_FROM_QUICK_ACCESS = \"REMOVE_ITEM_FROM_QUICK_ACCESS\",\n ADD_ITEM_TO_QUICK_ACCESS = \"ADD_ITEM_TO_QUICK_ACCESS\",\n NO_DATA_TIPS_IN_QUICK_ACCESS = \"NO_DATA_TIPS_IN_QUICK_ACCESS\",\n SITE_MAP_SEARCH_RECOMMEND = \"SITE_MAP_SEARCH_RECOMMEND\",\n MAX_COLLECT_COUNT_TIPS = \"MAX_COLLECT_COUNT_TIPS\",\n NO_DATA_SEARCH_INFO = \"NO_DATA_SEARCH_INFO\",\n SEARCH_ITEM_PLACEHOLDER = \"SEARCH_ITEM_PLACEHOLDER\",\n}\n\nconst en: Locale = {\n SEARCH_BY_MENU_NAME: \"Search by menu name\",\n SEARCH_HISTORY: \"Search history\",\n NO_DATA: \"No data\",\n QUICK_ACCESS: \"Quick Access\",\n REMOVE_ITEM_FROM_QUICK_ACCESS: \"Remove from Quick Access\",\n ADD_ITEM_TO_QUICK_ACCESS: \"Add to Quick Access\",\n NO_DATA_TIPS_IN_QUICK_ACCESS:\n \"No quick access resources have been added yet. Please add from the list below or after searching\",\n SITE_MAP_SEARCH_RECOMMEND: \"Search recommend\",\n MAX_COLLECT_COUNT_TIPS: \"Need to delete some favorites in order to add\",\n NO_DATA_SEARCH_INFO: \"The search result is empty, please enter again\",\n SEARCH_ITEM_PLACEHOLDER: \"Please enter keywords to search\",\n};\n\nconst zh: Locale = {\n SEARCH_BY_MENU_NAME: \"通过菜单名称搜索\",\n SEARCH_HISTORY: \"历史搜索\",\n NO_DATA: \"暂无数据\",\n QUICK_ACCESS: \"快捷访问\",\n REMOVE_ITEM_FROM_QUICK_ACCESS: \"从快捷访问移除\",\n ADD_ITEM_TO_QUICK_ACCESS: \"添加至快捷访问\",\n NO_DATA_TIPS_IN_QUICK_ACCESS: \"暂未添加快捷访问资源,从下方列表或搜索后添加\",\n SITE_MAP_SEARCH_RECOMMEND: \"搜索推荐\",\n MAX_COLLECT_COUNT_TIPS: \"需删除部分收藏,才能添加\",\n NO_DATA_SEARCH_INFO: \"搜索结果为空,请重新输入\",\n SEARCH_ITEM_PLACEHOLDER: \"请输入关键词搜索\",\n};\n\nexport const NS = \"bricks/nav/nav-menu\";\n\nexport const locales = { en, zh };\n\ntype Locale = { [key in K]: string };\n","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport { http } from \"@next-core/http\";\n/**\n * @description 获取我的收藏列表\n * @endpoint GET /api/v1/user_service/my_collection/collections\n */\nexport var MyCollectionApi_listMyCollection = /*#__PURE__*/function () {\n var _ref = _asyncToGenerator(function* (params, options) {\n return (/**! @contract easyops.api.user_service.my_collection.ListMyCollection@1.0.0 */(yield http.get(\"api/gateway/user_service.my_collection.ListMyCollection/api/v1/user_service/my_collection/collections\", _objectSpread(_objectSpread({}, options), {}, {\n params\n }))).data\n );\n });\n return function MyCollectionApi_listMyCollection(_x, _x2) {\n return _ref.apply(this, arguments);\n };\n}();\n//# sourceMappingURL=listMyCollection.js.map","import React from \"react\";\n\nexport enum DRAG_DIRECTION {\n Left = \"left\",\n Right = \"right\",\n}\n\nexport interface ContextOfDragProps {\n groupId: string;\n direction?: DRAG_DIRECTION;\n overElement?: HTMLElement;\n allowDrag?: boolean;\n onAllowDrag?: (enable: boolean) => void;\n onDragStart?: (e: React.DragEvent) => void;\n onDragOver?: (e: React.DragEvent) => void;\n onDragEnd?: (e: React.DragEvent) => void;\n onFavoriteUpdate?: (list: any[]) => void;\n}\n\nexport const collectModule = \"sidebarMenuCollect\";\n\nexport const DragContext = React.createContext<ContextOfDragProps>(\n {} as ContextOfDragProps\n);\n","import { JsonStorage } from \"@next-shared/general/JsonStorage\";\nimport type { SidebarMenuSimpleItem } from \"@next-shared/general/types\";\nimport {\n MyCollectionApi_listMyCollection,\n MyCollectionApi_ListMyCollectionResponseBody,\n MyCollectionApi_upsertMyCollection,\n} from \"@next-api-sdk/user-service-sdk\";\nimport { DRAG_DIRECTION, collectModule } from \"./constants.js\";\nimport { cloneDeep, isEmpty } from \"lodash\";\nimport { handleHttpError } from \"@next-core/runtime\";\n\nexport class CollectService {\n private maxCollectLength: number;\n private collectMap: Map<string, SidebarMenuSimpleItem[]> = new Map();\n\n constructor(maxCollectLength?: number) {\n this.maxCollectLength = maxCollectLength ?? 10;\n }\n\n public getFavoritesById(id: string): SidebarMenuSimpleItem[] {\n return cloneDeep(this.collectMap.get(id)) ?? [];\n }\n\n public async fetchFavorites(id: string): Promise<SidebarMenuSimpleItem[]> {\n if (!isEmpty(this.getFavoritesById(id))) {\n return this.getFavoritesById(id);\n }\n\n const favorites = (\n await MyCollectionApi_listMyCollection({\n module: collectModule,\n collectionName: id,\n })\n ).payloads\n ?.map((item) => item.extInfo)\n .filter(Boolean) as SidebarMenuSimpleItem[];\n\n this.collectMap.set(id, favorites);\n\n return favorites;\n }\n\n public setItemAsFavorite(id: string, item: SidebarMenuSimpleItem): void {\n const list = this.getFavoritesById(id);\n\n if (list.length >= this.maxCollectLength) {\n list.pop();\n }\n\n list.unshift(item);\n this.updateFavoriteItems(id, list);\n }\n\n public updateFavoriteItems(id: string, list: SidebarMenuSimpleItem[]): void {\n try {\n this.collectMap.set(id, list);\n MyCollectionApi_upsertMyCollection({\n module: collectModule,\n collectionName: id,\n payloads: list?.map((item) => ({\n name: item.text,\n url: item.to,\n extInfo: item,\n })) as MyCollectionApi_ListMyCollectionResponseBody[\"payloads\"],\n });\n } catch (error) {\n // istanbul ignore next\n handleHttpError(error);\n }\n }\n\n private equalItem(\n prevItem: SidebarMenuSimpleItem,\n item: SidebarMenuSimpleItem\n ): boolean {\n return prevItem.text === item.text && prevItem.to === item.to;\n }\n\n public removeItemFromFavorite(id: string, item: SidebarMenuSimpleItem): void {\n const list = this.getFavoritesById(id);\n const index = list.findIndex((row) => this.equalItem(row, item));\n // istanbul ignore else\n if (index !== -1) {\n list.splice(index, 1);\n this.updateFavoriteItems(id, list);\n }\n }\n\n public isCollected(id: string, item: SidebarMenuSimpleItem): boolean {\n const list = this.getFavoritesById(id);\n return list.some((row) => this.equalItem(row, item));\n }\n\n public toggleFavorite(id: string, item: SidebarMenuSimpleItem): void {\n if (this.isCollected(id, item)) {\n this.removeItemFromFavorite(id, item);\n } else {\n if (this.checkMaxCapacity(id)) return;\n this.setItemAsFavorite(id, item);\n }\n }\n\n public moveFavoriteTo(\n id: string,\n option: {\n from: SidebarMenuSimpleItem;\n to: SidebarMenuSimpleItem;\n direction: DRAG_DIRECTION;\n }\n ): SidebarMenuSimpleItem[] {\n const { from, to, direction } = option;\n\n const list = this.getFavoritesById(id);\n if (this.equalItem(from, to)) return list;\n\n const fromIndex = list.findIndex((row) => this.equalItem(row, from));\n\n // istanbul ignore else\n if (fromIndex !== -1) {\n list.splice(fromIndex, 1);\n\n const toIndex = list.findIndex((row) => this.equalItem(row, to));\n\n // istanbul ignore else\n if (toIndex !== -1) {\n if (direction === DRAG_DIRECTION.Left) {\n list.splice(toIndex, 0, from);\n } else {\n list.splice(toIndex + 1, 0, from);\n }\n\n this.updateFavoriteItems(id, list);\n }\n }\n\n return list;\n }\n\n checkMaxCapacity(groupId: string): boolean {\n return this.getFavoritesById(groupId).length >= this.maxCollectLength;\n }\n}\n\nexport const collectService = new CollectService();\n","import { http } from \"@next-core/http\";\n/**\n * @description 更新/新增我的收藏,这个接口用于全量更新单实例\n * @endpoint POST /api/v1/user_service/my_collection/upsert_collections\n */\nexport var MyCollectionApi_upsertMyCollection = (data, options) => /**! @contract easyops.api.user_service.my_collection.UpsertMyCollection@1.0.0 */http.post(\"api/gateway/user_service.my_collection.UpsertMyCollection/api/v1/user_service/my_collection/upsert_collections\", data, options);\n//# sourceMappingURL=upsertMyCollection.js.map","import React, {\n useMemo,\n useCallback,\n forwardRef,\n useRef,\n useState,\n useEffect,\n useContext,\n DragEvent,\n} from \"react\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { Link, LinkProps } from \"@next-bricks/basic/link\";\n\nimport { EoTooltip, ToolTipProps } from \"@next-bricks/basic/tooltip\";\nimport classNames from \"classnames\";\nimport { SidebarMenuSimpleItem } from \"@next-shared/general/types\";\nimport { K, NS, locales } from \"../i18n.js\";\nimport { collectService } from \"./CollectService.js\";\nimport { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\nimport { DRAG_DIRECTION, DragContext } from \"./constants.js\";\n\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\ninitializeReactI18n(NS, locales);\nconst WrappedLink = wrapBrick<Link, LinkProps>(\"eo-link\");\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nconst WrappedTooltip = wrapBrick<EoTooltip, ToolTipProps>(\"eo-tooltip\");\n\ninterface CellItemProps {\n data: SidebarMenuSimpleItem;\n suffix?: React.ReactNode;\n className?: string;\n}\n\nexport type OnFavoriteCallback = (collectList: SidebarMenuSimpleItem[]) => void;\n\ninterface PlaceholderCompProps {\n data: SidebarMenuSimpleItem;\n direction: DRAG_DIRECTION;\n onDragOver?: (e: DragEvent) => void;\n}\nexport function PlaceholderDropComp({\n data,\n onDragOver,\n direction,\n}: PlaceholderCompProps) {\n const { groupId, onFavoriteUpdate } = useContext(DragContext);\n const handleDrop = (e: DragEvent) => {\n const formData = JSON.parse(e.dataTransfer.getData(\"application/json\"));\n\n const newDataList = collectService.moveFavoriteTo(groupId, {\n from: formData,\n to: data,\n direction,\n });\n\n onFavoriteUpdate?.(newDataList);\n };\n\n return (\n <div\n className=\"indicate-wrapper\"\n data-direction={direction}\n data-to={data.to}\n onDragEnter={(e) =>\n ((e.target as HTMLElement).style.background = \"var(--palette-blue-1)\")\n }\n onDragLeave={(e) =>\n ((e.target as HTMLElement).style.background = \"transparent\")\n }\n data-text={data.text}\n onDragOver={onDragOver}\n onDrop={handleDrop}\n />\n );\n}\n\nexport function ItemTag(props: CellItemProps): React.ReactElement {\n const { data, suffix, className } = props;\n\n const {\n allowDrag,\n onDragStart,\n overElement,\n direction,\n onDragEnd,\n onDragOver,\n } = useContext(DragContext);\n const containerRef = useRef<any>(null);\n\n const [isDragIng, setIsDragIng] = useState(false);\n\n const isActive = useMemo(\n () =>\n overElement &&\n overElement.dataset.to == data.to &&\n overElement.dataset.text === overElement.dataset.text,\n [overElement, data]\n );\n\n const handleDragStart = (e: React.DragEvent) => {\n if (!allowDrag) {\n e.preventDefault();\n } else {\n setIsDragIng(true);\n e.dataTransfer?.setData(\"application/json\", JSON.stringify(data));\n onDragStart?.(e);\n }\n };\n\n const handleDragEnd = (e: React.DragEvent) => {\n setIsDragIng(false);\n onDragEnd?.(e);\n };\n\n const handleOver = (e: React.DragEvent) => {\n e.dataTransfer.dropEffect = \"none\";\n onDragOver?.(e);\n };\n\n return (\n <>\n {isActive && direction === DRAG_DIRECTION.Left && (\n <PlaceholderDropComp\n data={data}\n onDragOver={onDragOver}\n direction={DRAG_DIRECTION.Left}\n />\n )}\n <WrappedLink\n data-to={data.to}\n data-text={data.text}\n ref={containerRef}\n draggable\n onDragStart={handleDragStart}\n onDragEnd={handleDragEnd}\n onDragOver={handleOver}\n className={classNames(\"tag-container\", className, {\n \"is-drag\": isDragIng,\n })}\n url={data.to as string}\n href={data.href}\n target={data.target as LinkProps[\"target\"]}\n >\n <span className=\"tag-text ellipsis\" title={data.text}>\n {data.text}\n </span>\n <span className=\"tag-suffix\" onClick={(e) => e.preventDefault()}>\n {suffix}\n </span>\n </WrappedLink>\n\n {isActive && direction === DRAG_DIRECTION.Right && (\n <PlaceholderDropComp\n data={data}\n onDragOver={onDragOver}\n direction={DRAG_DIRECTION.Right}\n />\n )}\n </>\n );\n}\n\ninterface QuickVisitTagProps extends CellItemProps {\n groupId: string;\n onFavorite?: OnFavoriteCallback;\n}\n\nexport function QuickVisitItem(props: QuickVisitTagProps): React.ReactElement {\n const { t } = useTranslation(NS);\n const { onAllowDrag } = useContext(DragContext);\n const { data, onFavorite, groupId } = props;\n const suffixRef = useRef<any>();\n\n const handleRemove = useCallback(() => {\n collectService.removeItemFromFavorite(groupId, data);\n onFavorite?.(collectService.getFavoritesById(groupId));\n }, [groupId, data, onFavorite]);\n\n const handleMouseDown = () => {\n onAllowDrag?.(true);\n };\n\n useEffect(() => {\n const suffix = suffixRef.current;\n const handleClick = (e: MouseEvent) => {\n e.preventDefault();\n };\n suffix.addEventListener(\"click\", handleClick);\n\n return () => {\n suffix.removeEventListener(\"click\", handleClick);\n };\n }, []);\n\n const suffixGroups = useMemo(\n () => (\n <div className=\"operation\" ref={suffixRef}>\n <WrappedTooltip\n content={t(K.REMOVE_ITEM_FROM_QUICK_ACCESS)}\n hoist\n placement=\"bottom\"\n className=\"close\"\n onClick={handleRemove}\n >\n <WrappedIcon lib=\"antd\" icon=\"close\" />\n </WrappedTooltip>\n <span className=\"drag-wrapper\" onMouseDown={handleMouseDown}>\n :::\n </span>\n </div>\n ),\n [t, handleRemove]\n );\n\n return (\n <ItemTag className=\"visit-container\" suffix={suffixGroups} data={data} />\n );\n}\n\ninterface StarIconProps {\n onFavorite?: OnFavoriteCallback;\n className?: string;\n groupId: string;\n data: SidebarMenuSimpleItem;\n active?: boolean;\n}\n\nexport function StarIcon({\n onFavorite,\n className,\n groupId,\n data,\n active,\n}: StarIconProps): React.ReactElement {\n const { t } = useTranslation(NS);\n const iconRef = useRef<any>();\n\n const handleClick = (e: React.MouseEvent) => {\n e.preventDefault();\n collectService.toggleFavorite(groupId, data);\n onFavorite?.(collectService.getFavoritesById(groupId));\n };\n\n useEffect(() => {\n // workaround for prevent Link jump when click.\n const icon = iconRef.current;\n icon.addEventListener(\"click\", handleClick);\n\n return () => {\n icon.removeEventListener(\"click\", handleClick);\n };\n }, []);\n\n return (\n <WrappedTooltip\n content={\n active\n ? t(K.REMOVE_ITEM_FROM_QUICK_ACCESS)\n : collectService.checkMaxCapacity(groupId)\n ? t(K.MAX_COLLECT_COUNT_TIPS)\n : t(K.ADD_ITEM_TO_QUICK_ACCESS)\n }\n className={classNames(\"star-icon\", className)}\n >\n <WrappedIcon\n ref={iconRef}\n className={classNames({ active })}\n lib=\"antd\"\n icon=\"star\"\n {...(active ? { theme: \"filled\" } : {})}\n />\n </WrappedTooltip>\n );\n}\n\ninterface RecommendItemProps extends CellItemProps {\n active?: boolean;\n groupId: string;\n onFavorite?: OnFavoriteCallback;\n}\n\nexport function RecommendItem(props: RecommendItemProps): React.ReactElement {\n const { data, className, groupId, onFavorite, active } = props;\n\n const suffixGroups = useMemo(\n () => (\n <StarIcon\n groupId={groupId}\n active={active}\n className=\"star\"\n data={data}\n onFavorite={onFavorite}\n />\n ),\n [data, groupId, onFavorite, active]\n );\n\n return (\n <ItemTag\n className={classNames(\"recommend-container\", className)}\n suffix={suffixGroups}\n data={data}\n />\n );\n}\n","import {\n SidebarMenuItem,\n SidebarMenuGroup,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\n\nfunction walkMenuItem(item: SidebarMenuItem, list: SidebarMenuSimpleItem[]) {\n if (\n (item as SidebarMenuGroup).type === \"group\" &&\n Array.isArray((item as SidebarMenuGroup).items)\n ) {\n walkMenuItems((item as SidebarMenuGroup).items, list);\n } else {\n list.push(item as SidebarMenuSimpleItem);\n }\n}\n\nfunction walkMenuItems(\n items: SidebarMenuItem[],\n list: SidebarMenuSimpleItem[]\n): void {\n for (const item of items) {\n walkMenuItem(item, list);\n }\n}\n\nexport function flatMenuItems(item: SidebarMenuItem): SidebarMenuSimpleItem[] {\n const list: SidebarMenuSimpleItem[] = [];\n\n walkMenuItem(item, list);\n\n return list;\n}\n\nexport function processGroupItems(groups: SidebarMenuGroup[]): Array<{\n groupFrom: string;\n groups: SidebarMenuGroup[];\n}> {\n const groupCategoryMap = new Map<string, SidebarMenuGroup[]>();\n const categoryOrder = new Set<string>();\n\n groups?.forEach((item) => {\n const from = item.groupFrom ?? \"default\";\n categoryOrder.add(from);\n\n const value = groupCategoryMap.get(from);\n\n if (!value) {\n groupCategoryMap.set(from, [item]);\n } else {\n value!.push(item);\n }\n });\n\n return Array.from(categoryOrder).map((key) => ({\n groupFrom: key,\n groups: groupCategoryMap!.get(key)!,\n }));\n}\n","import React, { useEffect, useState } from \"react\";\nimport type {\n SidebarMenuSimpleItem,\n SidebarMenuGroup,\n} from \"@next-shared/general/types\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { StarIcon, OnFavoriteCallback } from \"./ItemTag.js\";\nimport { Link, LinkProps } from \"@next-bricks/basic/link\";\nimport { collectService } from \"./CollectService.js\";\nimport { processGroupItems } from \"./processor.js\";\nimport classNames from \"classnames\";\n\nconst WrappedLink = wrapBrick<Link, LinkProps>(\"eo-link\");\n\ninterface GroupViewProps {\n groups: SidebarMenuGroup[];\n groupId: string;\n selectedKey?: string[];\n onFavorite: OnFavoriteCallback;\n}\n\nexport const itemColumnWidth = 240;\n\nexport function GroupView(props: GroupViewProps): React.ReactElement {\n const { groupId, selectedKey, onFavorite } = props;\n const groupMenus = processGroupItems(props.groups);\n\n return (\n <div className=\"group-view\">\n {groupMenus.map((item, index) => {\n return (\n <div key={index}>\n {index !== 0 && <div className=\"divider\" />}\n {item.groupFrom === \"default\" ? (\n <DefaultGroup\n groupId={groupId}\n selectedKey={selectedKey}\n groups={item.groups}\n onFavorite={onFavorite}\n />\n ) : (\n <CustomGroup\n groupId={groupId}\n selectedKey={selectedKey}\n groups={item.groups}\n onFavorite={onFavorite}\n />\n )}\n </div>\n );\n })}\n </div>\n );\n}\n\ninterface BaseGroupProps {\n groupId: string;\n selectedKey?: string[];\n onFavorite: OnFavoriteCallback;\n groups: SidebarMenuGroup[];\n}\nexport function DefaultGroup(props: BaseGroupProps): React.ReactElement {\n const { groupId, onFavorite, selectedKey, groups } = props;\n\n const groupRef = React.useRef<HTMLDivElement>(null);\n const [columnCount, setColumnCount] = useState<number>();\n\n useEffect(() => {\n // istanbul ignore next\n const resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n if (entry.target === groupRef.current) {\n const width = entry.contentRect.width;\n\n setColumnCount(Math.floor(width / itemColumnWidth));\n }\n }\n });\n\n resizeObserver.observe(groupRef.current as HTMLDivElement);\n\n return () => resizeObserver.disconnect();\n }, []);\n\n return (\n <div\n className=\"group\"\n ref={groupRef}\n style={\n (columnCount as number) < groups?.length\n ? { columnCount, columnWidth: itemColumnWidth }\n : {\n display: \"grid\",\n gridTemplateColumns: `repeat(auto-fit, ${itemColumnWidth}px)`,\n }\n }\n >\n {groups.map((group) => (\n <div key={group.key} className=\"group-item\">\n <div className=\"title\">{group.title}</div>\n <div className=\"content\">\n {group.items.map((item) => (\n <GroupItem\n key={item.key}\n groupId={groupId}\n selectedKey={selectedKey}\n data={item as SidebarMenuSimpleItem}\n onFavorite={onFavorite}\n />\n ))}\n </div>\n </div>\n ))}\n </div>\n );\n}\n\nexport function CustomGroup(props: BaseGroupProps): React.ReactElement {\n const { groupId, onFavorite, selectedKey, groups } = props;\n\n return (\n <div className=\"custom-group\">\n {groups.map((group) => (\n <div key={group.key}>\n <div className=\"title\">{group.title}</div>\n <div\n className=\"custom-content\"\n style={{\n display: \"grid\",\n gridTemplateColumns: `repeat(auto-fit, ${itemColumnWidth}px)`,\n }}\n >\n {group.items.map((item) => (\n <GroupItem\n key={item.key}\n selectedKey={selectedKey}\n groupId={groupId}\n data={item as SidebarMenuSimpleItem}\n onFavorite={onFavorite}\n />\n ))}\n </div>\n </div>\n ))}\n </div>\n );\n}\n\ninterface GroupItemProps {\n data: SidebarMenuSimpleItem;\n selectedKey?: string[];\n groupId: string;\n onFavorite: OnFavoriteCallback;\n}\nexport function GroupItem(props: GroupItemProps): React.ReactElement {\n const { data, groupId, onFavorite, selectedKey } = props;\n\n return (\n <WrappedLink\n key={data.key}\n icon={data.icon}\n url={data.to as string}\n href={data.href}\n target={data.target as LinkProps[\"target\"]}\n className={classNames(\"item-link\", {\n active: selectedKey?.includes(data.key as string),\n })}\n >\n <span className=\"ellipsis\" title={data.text}>\n {data.text}\n </span>\n <span className=\"icon-wrapper\">\n <StarIcon\n active={collectService.isCollected(groupId, data)}\n groupId={groupId}\n data={data}\n onFavorite={onFavorite}\n />\n </span>\n </WrappedLink>\n );\n}\n","import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { QuickVisitItem, RecommendItem } from \"./ItemTag.js\";\nimport { GroupView } from \"./GroupItem.js\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { K, NS } from \"../i18n.js\";\nimport { DragContext } from \"./constants.js\";\nimport { useTranslation } from \"@next-core/i18n/react\";\nimport { collectService } from \"./CollectService.js\";\nimport { flatMenuItems } from \"./processor.js\";\nimport { DRAG_DIRECTION } from \"./constants.js\";\nimport classNames from \"classnames\";\nimport { throttle, debounce } from \"lodash\";\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nexport interface InputEvents {\n change: CustomEvent<string>;\n}\n\nexport interface InputEventsMap {\n onValueChange: \"change\";\n}\n\nconst WrappedInput = wrapBrick<any, any, InputEvents, InputEventsMap>(\n \"eo-input\",\n {\n onValueChange: \"change\",\n }\n);\n\ninterface SiteMapItemProps {\n menuGroup: SidebarMenuGroup;\n selectedKey?: string[];\n visible?: boolean;\n}\n\nexport function findDropElement(element: HTMLElement): HTMLElement | undefined {\n let node = element;\n\n while (node) {\n if (node.draggable || node.className === \"indicate-wrapper\") {\n return node;\n }\n\n node = node.parentElement as HTMLElement;\n }\n}\n\nexport function isValidDragAction(\n dragElement: HTMLElement,\n dropElement: HTMLElement\n): boolean {\n return (\n dragElement &&\n dropElement &&\n !(\n dragElement.dataset.to === dropElement.dataset.to &&\n dragElement.dataset.text === dropElement.dataset.text\n )\n );\n}\n\nexport function SiteMapItem(props: SiteMapItemProps) {\n const { t } = useTranslation(NS);\n const { menuGroup, selectedKey, visible } = props;\n const groupId = menuGroup.groupId as string;\n\n const [favoriteList, setFavoriteList] = useState<SidebarMenuSimpleItem[]>([]);\n const flatItems = useMemo(() => flatMenuItems(menuGroup), [menuGroup]);\n const [q, setQ] = useState<string>();\n const [filter, setFilters] = useState<SidebarMenuSimpleItem[]>([]);\n const [dragElement, setDragElement] = useState<HTMLElement>();\n const [overElement, setOverElement] = useState<HTMLElement>();\n const [allowDrag, setAllowDrag] = useState<boolean>();\n const [direction, setDirection] = useState<DRAG_DIRECTION>();\n\n const handleFavorite = (collectList: SidebarMenuSimpleItem[]) => {\n setFavoriteList(collectList);\n };\n\n const handleSearch = useCallback(\n (e: CustomEvent<string>): void => {\n const v = e.detail;\n setQ(e.detail);\n\n setFilters(\n !v\n ? flatItems\n : flatItems.filter((item) =>\n item.text.toLowerCase().includes(e.detail.toLowerCase())\n )\n );\n },\n [flatItems]\n );\n\n const debouncedHandleSearch = useMemo(\n () => debounce(handleSearch, 200),\n [handleSearch]\n );\n\n const handleDragStart = (e: React.DragEvent): void => {\n setDragElement(e.target as HTMLElement);\n };\n\n const handleDragOver = useMemo(\n () =>\n throttle((e: React.DragEvent): void => {\n e.preventDefault();\n\n const dropElement = findDropElement(e.target as HTMLElement);\n setOverElement(dropElement);\n\n if (\n dropElement &&\n isValidDragAction(dropElement, dragElement as HTMLElement)\n ) {\n if (dropElement.className === \"indicate-wrapper\") {\n setDirection(dropElement.dataset.direction as DRAG_DIRECTION);\n } else {\n const { width, left } = dropElement.getBoundingClientRect();\n\n const right = e.clientX > left + width / 2;\n setDirection(right ? DRAG_DIRECTION.Right : DRAG_DIRECTION.Left);\n }\n } else {\n setDirection(undefined);\n }\n }),\n [dragElement]\n );\n\n const handleDragEnd = (): void => {\n setDragElement(undefined);\n setDirection(undefined);\n setAllowDrag(false);\n };\n\n const handleAllowDrag = (enable: boolean): void => {\n setAllowDrag(enable);\n };\n\n useEffect(() => {\n (async () => {\n if (visible) {\n const list = await collectService.fetchFavorites(groupId);\n setFavoriteList(list);\n }\n })();\n }, [groupId, visible]);\n\n return (\n <div className=\"site-map\">\n <div className=\"search-wrapper\">\n <WrappedInput\n className=\"search-input\"\n style={{ width: \"100%\" }}\n onValueChange={debouncedHandleSearch}\n placeholder={t(K.SEARCH_ITEM_PLACEHOLDER)}\n >\n <WrappedIcon slot=\"prefix\" lib=\"antd\" icon=\"search\" />\n </WrappedInput>\n </div>\n\n {!q && (\n <div>\n {favoriteList.length !== 0 && (\n <div\n className={classNames(\"visit-access\", {\n hasData: favoriteList.length,\n })}\n >\n <span className=\"title\">{t(K.QUICK_ACCESS)}</span>\n <DragContext.Provider\n value={{\n groupId,\n overElement,\n direction,\n allowDrag,\n onDragStart: handleDragStart,\n onDragOver: handleDragOver,\n onDragEnd: handleDragEnd,\n onAllowDrag: handleAllowDrag,\n onFavoriteUpdate: handleFavorite,\n }}\n >\n <div className=\"tag-wrapper\">\n {favoriteList.map((item) => (\n <QuickVisitItem\n onFavorite={handleFavorite}\n groupId={groupId}\n key={item.key}\n data={item}\n />\n ))}\n </div>\n </DragContext.Provider>\n </div>\n )}\n\n <GroupView\n groupId={groupId}\n selectedKey={selectedKey}\n groups={menuGroup.items as SidebarMenuGroup[]}\n onFavorite={handleFavorite}\n />\n </div>\n )}\n\n {q && (\n <div className=\"search-panel\">\n <span className=\"title\">{t(K.SITE_MAP_SEARCH_RECOMMEND)}</span>\n {filter.length ? (\n <div className=\"recommend-wrapper\">\n {filter.map((item) => (\n <RecommendItem\n key={item.key}\n groupId={groupId}\n data={item}\n onFavorite={handleFavorite}\n active={collectService.isCollected(groupId, item)}\n />\n ))}\n </div>\n ) : (\n <div className=\"no-data-tips\">{t(K.NO_DATA_SEARCH_INFO)}</div>\n )}\n </div>\n )}\n </div>\n );\n}\n","import React from \"react\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuItem,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport type { Link, LinkProps } from \"@next-bricks/basic/link\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nconst WrappedLinkItem = wrapBrick<Link, LinkProps>(\"eo-link\");\n\nexport function isGroup(item: SidebarMenuItem): item is SidebarMenuGroup {\n return item.type === \"group\";\n}\n\nexport function isSubMenu(\n item: SidebarMenuGroup,\n groupAsSubMenu?: boolean\n): item is SidebarMenuGroup {\n return Boolean(\n item.type === \"subMenu\" || (groupAsSubMenu && item.type === \"group\")\n );\n}\n\nexport function isSimple(item: SidebarMenuItem): item is SidebarMenuSimpleItem {\n return item.type === \"default\" || !item.type;\n}\n\nexport const renderLinkCom = (\n item: SidebarMenuSimpleItem,\n linkStyle?: React.CSSProperties\n): React.ReactElement => {\n return (\n <WrappedLinkItem\n key={item.key}\n url={item.to as string}\n href={item.href}\n target={item.target as LinkProps[\"target\"]}\n style={linkStyle}\n >\n <span className=\"menu-item-label\">{item.text}</span>\n </WrappedLinkItem>\n );\n};\n\nexport const renderSpanCom = (\n item: SidebarMenuGroup,\n subMenu?: boolean\n): React.ReactElement => {\n return (\n <span key={item.key} className=\"menu-item-label\">\n {item.title}\n {subMenu && <WrappedIcon lib=\"fa\" icon=\"angle-right\" />}\n </span>\n );\n};\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block;background:none;--three-level-menu-search-input-background:linear-gradient(90deg,#e8eef6 0%,rgba(233,234,243,0) 100%);--three-level-menu-hover-color:#6bb3ff;--three-level-menu-title-color:#0b5ad9;--three-level-menu-active-color:#1a7aff;--three-level-menu-search-tag-color:rgb(89,89,89);--three-level-menu-search-tag-background:rgb(245,245,245)}:host::part(menu-item),\neo-link{display:block;padding:2px 0px}:host-context(html[data-theme=\"dark-v2\"]),\n:host-context([data-override-theme=\"dark-v2\"]){--three-level-menu-search-input-background:linear-gradient(124deg,rgba(255,255,255,0.36) 0%,rgba(255,255,255,0) 100%);--three-level-menu-hover-color:rgba(54,95,175,0.85);--three-level-menu-title-color:#6597e8;--three-level-menu-active-color:#3f75dd;--three-level-menu-search-tag-color:rgb(140,140,140);--three-level-menu-search-tag-background:rgb(107,107,107)}.nav-menu-wrapper{display:flex}.nav-menu-wrapper > eo-menu-item{padding:2px 14px}.nav-menu-wrapper > eo-popover{padding:2px 6px}.popover .sub-menu-item-label{padding:2px 0px;color:var(--color-normal-text)}.popover.subprime{display:inline-block;width:100%}.sub-menu-wrapper{min-width:160px;max-height:calc(100vh - 100px);background-color:var(--antd-dropdown-menu-bg);padding:4px 0;border-radius:6px;box-shadow:0px 4px 12px 0px rgba(17,37,64,0.08);overflow-x:hidden;overflow-y:auto}.sub-menu-wrapper > eo-menu-item{display:block;width:100%}.sub-menu-wrapper > eo-menu-item .menu-item-label,\n.sub-menu-wrapper > eo-popover .menu-item-label,\n.sub-menu-wrapper > .group-wrapper > eo-popover .menu-item-label,\n.sub-menu-wrapper > .group-wrapper > eo-menu-item .menu-item-label{display:block;width:100%;padding:6px 24px;box-sizing:border-box;color:var(--color-normal-text)}.sub-menu-wrapper > eo-popover.subprime .menu-item-label,\n.sub-menu-wrapper > .group-wrapper > eo-popover.subprime .menu-item-label{display:flex;justify-content:space-between;align-items:center}.sub-menu-wrapper .menu-item-label{border-radius:0}.menu-item-label{display:inline-block;cursor:pointer;border-radius:4px;padding:5px 10px;color:var(--color-normal-text)}.menu-item-label:hover{background-color:var(--v8-top-menu-item-hover)}.group-label{padding-left:16px;font-size:12px;color:var(--palette-gray-7)}eo-menu-item[active] .menu-item-label{background:var(--v8-top-menu-item-selected-bg);color:var(--color-brand)!important;font-weight:500}.three-level-menu-container{max-width:980px;max-height:510px;overflow:auto;min-width:160px}.three-level-menu-item-container{display:grid;grid-gap:20px;gap:20px;margin-top:13px;padding:5px 10px}.three-level-menu-item-title-container{display:flex;align-items:center}.three-level-menu-item-title-icon{width:4px;height:4px;background-color:var(--three-level-menu-title-color);margin-right:4px;transform:rotate(45deg)}.three-level-menu-item-title{font-size:14px;font-family:PingFang-SC-Medium,PingFang-SC;font-weight:500;color:var(--three-level-menu-title-color)}.three-level-menu-container .menu-item-label{margin-top:4px;margin-left:4px;padding:4px;width:100%}.three-level-menu-container .active .menu-item-label{color:var(--three-level-menu-active-color)}.three-level-menu-search-result .menu-item-label{margin:0px}.three-level-menu-container .menu-item-label:hover{color:var(--three-level-menu-hover-color)}.three-level-menu-popover .sub-menu-wrapper{padding-top:0px}.three-level-menu-search-container{background:var(--three-level-menu-search-input-background);padding:5px 10px}.three-level-menu-search-result{min-width:187px;max-width:328px;max-height:324px;background-color:var(--antd-dropdown-menu-bg);box-shadow:0px 4px 12px 0px rgba(17,37,64,0.08);overflow:scroll}.three-level-menu-search-history-container{padding:5px 10px}.three-level-menu-search-history-text{background:var(--three-level-menu-search-tag-background);border-radius:2px;font-size:7px;line-height:11px;display:inline-block;height:11px;padding:4px;color:var(--three-level-menu-search-tag-color);margin-right:8px}.three-level-menu-search-history-title{color:#8c8c8c;margin:10px 0;display:flex;align-items:center}.three-level-menu-search-history-icon{margin-left:5px}.sub-menu-sit-map-wrapper{box-sizing:border-box;width:calc(100vw);padding:0 120px 24px;max-height:520px;background-color:var(--antd-dropdown-menu-bg);border-radius:6px;box-shadow:0px 4px 12px 0px rgba(17,37,64,0.08);overflow-x:hidden;overflow-y:auto}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.group .item-link, .custom-group .item-link{font-weight:400}.group .item-link:hover, .custom-group .item-link:hover{background-color:var(--color-fill-bg-base-1)}.group .item-link:hover::part(link), .custom-group .item-link:hover::part(link){color:var(--color-brand-hover)}.group .item-link:hover::part(icon), .custom-group .item-link:hover::part(icon){color:var(--color-brand-hover)}.group .item-link.active::part(link),\n .custom-group .item-link.active::part(link),\n .group .item-link.active::part(icon),\n .custom-group .item-link.active::part(icon){color:var(--palette-blue-8)}.group .item-link::part(link), .custom-group .item-link::part(link){padding:8px 12px;display:flex;gap:4px;color:var(--color-header-text)}.group .item-link::part(icon), .custom-group .item-link::part(icon){color:var(--color-normal-text)}.group .title, .custom-group .title{padding:8px 16px;font-size:16px;font-weight:500;position:relative}.group .title::before, .custom-group .title::before{content:\"\";position:absolute;width:6px;height:6px;top:17px;left:1px;transform:rotate(45deg);background:var(--color-secondary-text)}.group .content .icon-wrapper, .custom-group .content .icon-wrapper, .group .custom-content .icon-wrapper, .custom-group .custom-content .icon-wrapper{color:var(--color-secondary-text);font-size:16px;display:none;margin-left:auto}.group .content .item-link:hover .icon-wrapper, .custom-group .content .item-link:hover .icon-wrapper, .group .custom-content .item-link:hover .icon-wrapper, .custom-group .custom-content .item-link:hover .icon-wrapper{display:block}.group .content .item-link:hover .icon-wrapper:hover, .custom-group .content .item-link:hover .icon-wrapper:hover, .group .custom-content .item-link:hover .icon-wrapper:hover, .custom-group .custom-content .item-link:hover .icon-wrapper:hover{color:var(--color-brand-hover)}.group .content, .custom-group .content{display:flex;flex-direction:column}.group .group-item, .custom-group .group-item{page-break-inside:avoid;break-inside:avoid}.group-view{min-height:300px}.group-view .divider{height:2px;background:var(--color-text-divider-line);margin:16px 0}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.tag-container::part(link){display:flex;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;-moz-user-select:none;justify-content:space-between;background-color:var(--color-fill-bg-base-1);border-radius:2px;padding:1px 6px}.tag-container .tag-text{color:var(--color-normal-text);font-weight:400}.tag-container:hover .tag-text{color:var(--color-brand-hover)}.tag-container .tag-suffix{display:inline-flex;font-size:12px;gap:4px;align-items:center;color:var(--color-secondary-text)}.tag-container.is-drag{opacity:0.4}.indicate-wrapper{border:1px dashed var(--color-brand-hover);border-radius:4px;height:20px;margin:2px 0}.close{display:inline-flex;margin-top:2px;padding:0 2px}.close:hover{color:var(--color-error)}.drag-wrapper{cursor:move}.drag-wrapper:hover{color:var(--color-brand-hover)}.star-icon{display:flex;alignitems:center;color:var(--color-secondary-text)}.star-icon:hover{color:var(--color-brand-hover)}.star-icon .active{color:var(--palette-yellow-6)}.recommend-container:hover .star{display:inline-flex}.recommend-container .star{font-size:13px;display:none}.visit-container:hover .operation{display:inline-flex;align-items:center}.visit-container .operation{display:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.site-map .search-wrapper{position:-webkit-sticky;position:sticky;top:0;z-index:9999;padding-top:24px;padding-bottom:16px;background:var(--antd-dropdown-menu-bg)}.site-map .search-input::part(affix-wrapper){border:none;border-bottom:1px solid var(--antd-input-border-color);border-radius:0px}.site-map .visit-access .title, .site-map .search-panel .title{display:inline-block;padding:2px 16px;font-weight:500;line-height:24px;position:relative}.site-map .visit-access .title::before, .site-map .search-panel .title::before{content:\"\";position:absolute;width:6px;height:6px;top:10px;left:1px;border-radius:50%;background:var(--color-secondary-text)}.site-map .visit-access .no-data-tips, .site-map .search-panel .no-data-tips{display:flex;margin:16px 0 32px;align-items:center;justify-content:center;color:var(--color-secondary-text)}.site-map .visit-access{margin-bottom:8px}.site-map .visit-access.hasData{display:flex}.site-map .visit-access .tag-wrapper{flex:1;display:grid;grid-template-columns:repeat(auto-fit,200px);grid-gap:8px;gap:8px}.site-map .ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.site-map .search-panel .recommend-wrapper{margin-top:16px;display:grid;grid-template-columns:repeat(auto-fit,200px);grid-gap:8px;gap:8px}:host-context(html[data-theme=\"dark-v2\"]) .site-map .search-input::part(affix-wrapper), :host-context([data-override-theme=\"dark-v2\"]) .site-map .search-input::part(affix-wrapper){background:var(--antd-dropdown-menu-bg)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","export default function _checkPrivateRedeclaration(obj, privateCollection) {\n if (privateCollection.has(obj)) {\n throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n }\n}","export default function _classExtractFieldDescriptor(receiver, privateMap, action) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to \" + action + \" private field on non-instance\");\n }\n return privateMap.get(receiver);\n}","import classApplyDescriptorGet from \"./classApplyDescriptorGet.js\";\nimport classExtractFieldDescriptor from \"./classExtractFieldDescriptor.js\";\nexport default function _classPrivateFieldGet(receiver, privateMap) {\n var descriptor = classExtractFieldDescriptor(receiver, privateMap, \"get\");\n return classApplyDescriptorGet(receiver, descriptor);\n}","export default function _classApplyDescriptorGet(receiver, descriptor) {\n if (descriptor.get) {\n return descriptor.get.call(receiver);\n }\n return descriptor.value;\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateFieldInitSpec(obj, privateMap, value) {\n checkPrivateRedeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}","import classApplyDescriptorSet from \"./classApplyDescriptorSet.js\";\nimport classExtractFieldDescriptor from \"./classExtractFieldDescriptor.js\";\nexport default function _classPrivateFieldSet(receiver, privateMap, value) {\n var descriptor = classExtractFieldDescriptor(receiver, privateMap, \"set\");\n classApplyDescriptorSet(receiver, descriptor, value);\n return value;\n}","export default function _classApplyDescriptorSet(receiver, descriptor, value) {\n if (descriptor.set) {\n descriptor.set.call(receiver, value);\n } else {\n if (!descriptor.writable) {\n throw new TypeError(\"attempted to set read only private field\");\n }\n descriptor.value = value;\n }\n}","import { Location, parsePath } from \"history\";\nimport { matchPath } from \"@next-core/runtime\";\nimport type {\n SidebarMenuSimpleItem,\n SidebarMenuItem,\n SidebarMenuGroup,\n} from \"./types.js\";\n\nexport function isGroup(item: SidebarMenuItem): item is SidebarMenuGroup {\n return item.type === \"group\";\n}\n\nexport function isSubMenu(\n item: SidebarMenuItem,\n groupAsSubMenu?: boolean\n): item is SidebarMenuGroup {\n return Boolean(\n item.type === \"subMenu\" || (groupAsSubMenu && item.type === \"group\")\n );\n}\n\nexport function initMenuItemAndMatchCurrentPathKeys(\n menuItems: SidebarMenuItem[],\n pathname: string,\n search: string,\n parentCursor: string\n): {\n selectedKeys: string[];\n openedKeys: string[];\n} {\n const selectedKeys: string[] = [];\n const openedKeys: string[] = [];\n\n let cursor = 0;\n menuItems.forEach((item) => {\n // key的格式最终为0,1,2,0.1,0.2,0.1.1,0.1.2\n item.key = parentCursor === \"\" ? `${cursor}` : `${parentCursor}.${cursor}`;\n if (isGroup(item) || isSubMenu(item)) {\n const tmp = initMenuItemAndMatchCurrentPathKeys(\n item.items,\n pathname,\n search,\n item.key\n );\n selectedKeys.push(...tmp.selectedKeys);\n if (tmp.selectedKeys.length || item.defaultExpanded) {\n openedKeys.push(item.key);\n }\n openedKeys.push(...tmp.openedKeys);\n } else {\n if (matchMenuItem(item, pathname, search)) {\n selectedKeys.push(String(item.key));\n }\n }\n cursor += 1;\n });\n if (selectedKeys.length && parentCursor !== \"\") {\n openedKeys.push(parentCursor);\n }\n return {\n selectedKeys: selectedKeys,\n openedKeys: openedKeys,\n };\n}\n\nfunction getMatchOfSearch(\n currentSearch: string,\n toSearch: string | undefined\n): boolean {\n const current = new URLSearchParams(currentSearch);\n const to = new URLSearchParams(toSearch);\n for (const [key, value] of to.entries()) {\n if (current.get(key) !== value) {\n return false;\n }\n }\n return true;\n}\n\nexport function matchMenuItem(\n item: SidebarMenuSimpleItem,\n pathname: string,\n search: string\n): boolean {\n if (!item.to) return false;\n const to = typeof item.to === \"object\" ? item.to : parsePath(item.to);\n\n // Regex taken from: https://github.com/pillarjs/path-to-regexp/blob/master/index.js#L202\n const escapedPath = to.pathname!.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, \"\\\\$1\");\n\n let match = !!matchPath(pathname, {\n path: escapedPath,\n exact: item.exact,\n });\n\n if (!match && Array.isArray(item.activeIncludes)) {\n for (const include of item.activeIncludes) {\n let parseInclude: Location | undefined;\n const hasSearch = include.includes(\"?\");\n\n if (hasSearch) {\n parseInclude = parsePath(include);\n }\n match = !!matchPath(pathname, {\n path: hasSearch ? parseInclude!.pathname : include,\n exact: true,\n });\n\n if (match && parseInclude?.search) {\n match = getMatchOfSearch(search, parseInclude.search);\n }\n\n if (match) {\n break;\n }\n }\n }\n\n if (match && Array.isArray(item.activeExcludes)) {\n for (const include of item.activeExcludes) {\n match = !matchPath(pathname, {\n path: include,\n exact: true,\n });\n if (!match) {\n break;\n }\n }\n }\n\n if (match && (item as any).activeMatchSearch) {\n match = getMatchOfSearch(search, to.search);\n }\n\n return match;\n}\n"],"names":["initializeReactI18n","NS","locales","WrappedPopover","wrapBrick","WrappedSearch","onChange","onSearch","WrappedIcon","LOCAL_STORAGE_PREFIX","maxVisitorLength","ThreeLevelMenuPopoverContent","props","useTranslation","menuItem","selectedKey","items","searchResult","setSearchResult","useState","searchKey","setSearchKey","triggerRef","useRef","nameSpace","concat","title","storage","useMemo","JsonStorage","localStorage","searchHistory","getItem","popoverTriggerClick","_triggerRef$current","current","click","React","className","onClick","e","stopPropagation","placeholder","t","K","SEARCH_BY_MENU_NAME","detail","list","uniq","length","pop","setItem","flatMap","i","filter","text","toLowerCase","includes","trim","onFocus","onBlur","trigger","placement","anchorDisplay","distance","slot","ref","map","renderLinkCom","width","style","height","textAlign","lineHeight","NO_DATA","SEARCH_HISTORY","lib","theme","icon","h","key","gridTemplateColumns","item","index","_item$items","classnames","active","en","QUICK_ACCESS","REMOVE_ITEM_FROM_QUICK_ACCESS","ADD_ITEM_TO_QUICK_ACCESS","NO_DATA_TIPS_IN_QUICK_ACCESS","SITE_MAP_SEARCH_RECOMMEND","MAX_COLLECT_COUNT_TIPS","NO_DATA_SEARCH_INFO","SEARCH_ITEM_PLACEHOLDER","zh","MyCollectionApi_listMyCollection","_ref","params","options","http","get","_x","_x2","apply","this","arguments","DRAG_DIRECTION","collectModule","DragContext","collectService","constructor","maxCollectLength","_defineProperty","Map","getFavoritesById","id","_cloneDeep","cloneDeep","collectMap","fetchFavorites","_this","_asyncToGenerator","_yield$MyCollectionAp","isEmpty","favorites","module","collectionName","payloads","extInfo","Boolean","set","setItemAsFavorite","unshift","updateFavoriteItems","data","name","url","to","post","error","handleHttpError","equalItem","prevItem","removeItemFromFavorite","findIndex","row","splice","isCollected","some","toggleFavorite","checkMaxCapacity","moveFavoriteTo","option","from","direction","fromIndex","toIndex","Left","groupId","WrappedLink","WrappedTooltip","PlaceholderDropComp","onDragOver","onFavoriteUpdate","useContext","onDragEnter","target","background","onDragLeave","onDrop","formData","JSON","parse","dataTransfer","getData","newDataList","ItemTag","suffix","allowDrag","onDragStart","overElement","onDragEnd","containerRef","isDragIng","setIsDragIng","isActive","dataset","draggable","_e$dataTransfer","setData","stringify","preventDefault","dropEffect","classNames","href","Right","QuickVisitItem","onAllowDrag","onFavorite","suffixRef","handleRemove","useCallback","handleMouseDown","useEffect","handleClick","addEventListener","removeEventListener","suffixGroups","content","hoist","onMouseDown","StarIcon","_ref2","iconRef","_extends","RecommendItem","walkMenuItem","type","Array","isArray","walkMenuItems","push","itemColumnWidth","GroupView","groups","groupCategoryMap","categoryOrder","groupMenus","Set","forEach","_item$groupFrom","groupFrom","add","value","DefaultGroup","CustomGroup","groupRef","columnCount","setColumnCount","resizeObserver","ResizeObserver","entries","entry","contentRect","Math","floor","observe","disconnect","columnWidth","display","group","GroupItem","WrappedInput","onValueChange","SiteMapItem","menuGroup","visible","favoriteList","setFavoriteList","flatItems","flatMenuItems","q","setQ","setFilters","dragElement","setDragElement","setOverElement","setAllowDrag","setDirection","handleFavorite","collectList","handleSearch","v","debouncedHandleSearch","debounce","handleDragOver","throttle","dropElement","element","node","parentElement","findDropElement","isValidDragAction","left","getBoundingClientRect","right","clientX","undefined","hasData","Provider","handleDragEnd","enable","WrappedLinkItem","isGroup","isSubMenu","groupAsSubMenu","linkStyle","renderSpanCom","subMenu","___CSS_LOADER_EXPORT___","toString","_checkPrivateRedeclaration","obj","privateCollection","has","TypeError","_classExtractFieldDescriptor","receiver","privateMap","action","_classPrivateFieldGet","descriptor","call","classExtractFieldDescriptor","_classPrivateFieldInitSpec","_classPrivateFieldSet","writable","initMenuItemAndMatchCurrentPathKeys","menuItems","pathname","search","parentCursor","selectedKeys","openedKeys","cursor","tmp","defaultExpanded","parsePath","escapedPath","replace","match","matchPath","path","exact","activeIncludes","include","_parseInclude","parseInclude","hasSearch","getMatchOfSearch","activeExcludes","_include","activeMatchSearch","matchMenuItem","String","currentSearch","toSearch","URLSearchParams"],"sourceRoot":""}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";(self.webpackChunk_next_bricks_nav=self.webpackChunk_next_bricks_nav||[]).push([[752],{752:(e,t,l)=>{l.r(t);var n,a,r,i,o,s,c,m,u,p=l(4795),d=l(3395),h=l(381),v=l(687),y=l(8390),b=l(7896),g=l(8657),E=l.n(g),k=l(
|
|
2
|
-
//# sourceMappingURL=752.
|
|
1
|
+
"use strict";(self.webpackChunk_next_bricks_nav=self.webpackChunk_next_bricks_nav||[]).push([[752],{752:(e,t,l)=>{l.r(t);var n,a,r,i,o,s,c,m,u,p=l(4795),d=l(3395),h=l(381),v=l(687),y=l(8390),b=l(7896),g=l(8657),E=l.n(g),k=l(1218),w=l(6397),f=l(3105),T=l(9800),Z=l(6951),x=l(3874),N=(l(5254),l(2779)),K=l.n(N),C=l(4358),D=l(2763),_=l(2598),F=l(8462),I=l(8101),{defineElement:R,property:S}=(0,k.createDecorators)(),V=(0,f.wrapBrick)("eo-menu-item"),W=(0,f.wrapBrick)("eo-popover",{onVisibleChange:"visible.change",beforeVisibleChange:"before.visible.change"});function B(e){var{item:t}=e;return(0,Z.cl)(t,e.topData)?E().createElement(A,(0,b.Z)({},e,{item:t})):(0,Z.ty)(t)?E().createElement(G,(0,b.Z)({},e,{item:t})):E().createElement(L,(0,b.Z)({},e,{item:t}))}function L(e){var{item:t,showTooltip:l,selectedKey:n=[]}=e;return E().createElement(V,{key:t.key,title:l?t.text:"",active:!!t.key&&n.includes(t.key)},(0,Z.nC)(t,{width:"100%"}))}var M,z=e=>{var t,l=null!==(t=u)&&void 0!==t?t:u=window.innerWidth-document.body.clientWidth;document.body.style.paddingRight=e.detail?l+"px":"",document.body.style.overflow=e.detail?"hidden":"",document.body.style.touchAction=e.detail?"none":""};function A(e){var t,{item:l,topData:n,showTooltip:a,selectedKey:r=[]}=e;return(null===(t=l.items)||void 0===t?void 0:t.length)>0?E().createElement(W,{className:K()("popover",{subprime:!n}),trigger:"hover",placement:n?"bottom-start":"right-start",distance:0,anchorDisplay:"block"},E().createElement(V,{className:"sub-menu-item-label",key:l.key,slot:"anchor",title:a?l.title:""},(0,Z.cx)(l,!n)),E().createElement("div",{className:"sub-menu-wrapper"},l.items.map((e=>E().createElement(E().Fragment,{key:e.key},E().createElement(B,{item:e,selectedKey:r,showTooltip:a})))))):null}function G(e){var t,{item:l,showTooltip:n,selectedKey:a=[]}=e;return(null===(t=l.items)||void 0===t?void 0:t.length)>0?E().createElement(E().Fragment,null,E().createElement("div",{className:"group-label"},l.title),E().createElement("div",{className:"group-wrapper"},l.items.map((e=>E().createElement(E().Fragment,{key:e.key},E().createElement(B,{item:e,showTooltip:n,selectedKey:a})))))):null}function H(e){var t,{item:l,selectedKey:n=[],showTooltip:a}=e;return(null===(t=l.items)||void 0===t?void 0:t.length)>0?E().createElement(W,{className:K()("three-level-menu-popover","popover"),trigger:"hover",placement:"bottom-start",distance:0,key:l.key,strategy:"fixed",beforeVisibleChange:z},E().createElement(V,{className:"sub-menu-item-label",key:l.key,slot:"anchor",title:a?l.title:""},(0,Z.cx)(l)),E().createElement("div",{className:"sub-menu-wrapper"},E().createElement(C.m,{menuItem:l,selectedKey:n}))):null}function O(e){var t,{item:l,selectedKey:n=[],showTooltip:a}=e,[r,i]=(0,g.useState)();return(null===(t=l.items)||void 0===t?void 0:t.length)>0?E().createElement(W,{className:K()("popover"),trigger:"hover",placement:"bottom-start",distance:0,key:l.key,strategy:"fixed",beforeVisibleChange:e=>{i(e.detail),z(e)}},E().createElement(V,{className:"sub-menu-item-label",key:l.key,slot:"anchor",title:a?l.title:""},(0,Z.cx)(l)),E().createElement("div",{className:"sub-menu-sit-map-wrapper",onClick:e=>e.stopPropagation()},E().createElement(D.hX,{menuGroup:l,selectedKey:n,visible:r}))):null}a=R("eo-nav-menu",{styleTexts:[_.Z,F.Z,I.Z,T.Z]}),r=S({attribute:!1}),o=S({type:Boolean});var P=new WeakMap,X=new WeakMap;class j extends f.ReactNextElement{constructor(){super(...arguments),(0,d.Z)(this,P,{writable:!0,value:(c(this),i(this))}),(0,d.Z)(this,X,{writable:!0,value:s(this)})}get menu(){return(0,v.Z)(this,P)}set menu(e){(0,h.Z)(this,P,e)}get showTooltip(){return(0,v.Z)(this,X)}set showTooltip(e){(0,h.Z)(this,X,e)}render(){return E().createElement(q,{menu:this.menu,showTooltip:this.showTooltip})}}function q(e){var{menu:t,showTooltip:l}=e,n=(0,w.getHistory)(),[a,r]=(0,g.useState)(n.location),{pathname:i,search:o}=a,[s,c]=(0,g.useState)([]),m=function(){var e=(0,p.Z)((function*(){var e,{selectedKeys:l}=(0,x.OZ)(null!==(e=null==t?void 0:t.menuItems)&&void 0!==e?e:[],i,o,"");c(l)}));return function(){return e.apply(this,arguments)}}();return(0,g.useEffect)((()=>{var e=n.listen((e=>{r(e)}));return m(),e}),[]),E().createElement("div",{className:"nav-menu-wrapper"},null==t?void 0:t.menuItems.map((e=>{var t;return E().createElement(E().Fragment,{key:e.key},(0,Z.cl)(e,!0)&&"category"===e.childLayout&&null!==(t=e.items)&&void 0!==t&&t.length?E().createElement(H,{item:e,showTooltip:l,selectedKey:s}):"group"===e.type&&"siteMap"===e.childLayout?E().createElement(O,{item:e,showTooltip:l,selectedKey:s}):E().createElement(B,{item:e,showTooltip:l,selectedKey:s,topData:!0}))})))}m=j,({e:[i,s,c],c:[M,n]}=(0,y.Z)(m,[[r,1,"menu"],[o,1,"showTooltip"]],[a])),n();var J,Q,U,Y=l(3294),$=l(759),ee=l(481),te=l(2152);(0,$.initializeReactI18n)(ee.NS,ee.k);var le,{defineElement:ne}=(0,k.createDecorators)();Q=ne("eo-launchpad-button",{styleTexts:[te.Z]});class ae extends f.ReactNextElement{render(){return E().createElement(Y.L,null)}}U=ae,[le,J]=(0,y.Z)(U,[],[Q]).c,J()}}]);
|
|
2
|
+
//# sourceMappingURL=752.ca4288fe.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/752.f1bb3fce.js","mappings":"6IAkGIA,E,yNA1DE,cAAEC,EAAa,SAAEC,IAAaC,EAAAA,EAAAA,oBAE9BC,GAAkBC,EAAAA,EAAAA,WACtB,gBAEIC,GAAiBD,EAAAA,EAAAA,WAKrB,aAAc,CACdE,gBAAiB,iBACjBC,oBAAqB,0BAoBvB,SAASC,EAAkBC,GACzB,IAAM,KAAEC,GAASD,EACjB,OAAOE,EAAAA,EAAAA,IAAUD,EAA0BD,EAAMG,SAC/CC,IAAAA,cAACC,GAAcC,EAAAA,EAAAA,GAAA,GAAKN,EAAK,CAAEC,KAAMA,MAC/BM,EAAAA,EAAAA,IAAQN,GACVG,IAAAA,cAACI,GAAgBF,EAAAA,EAAAA,GAAA,GAAKN,EAAK,CAAEC,KAAMA,KAEnCG,IAAAA,cAACK,GAAiBH,EAAAA,EAAAA,GAAA,GACZN,EAAK,CACTC,KAAMA,IAGZ,CACA,SAASQ,EAAkBT,GACzB,IAAM,KAAEC,EAAI,YAAES,EAAW,YAAEC,EAAc,IAAOX,EAChD,OACEI,IAAAA,cAACV,EAAe,CACdkB,IAAKX,EAAKW,IACVC,MAAOH,EAAcT,EAAKa,KAAO,GACjCC,SAAQd,EAAKW,KAAMD,EAAYK,SAASf,EAAKW,OAE5CK,EAAAA,EAAAA,IAAchB,EAAM,CAAEiB,MAAO,SAGpC,CAIA,IA+JAC,EA/JMC,EAA4BC,IAAgC,IAAAC,EAG1DC,EACO,QADKD,EAChBhC,SAAW,IAAAgC,EAAAA,EACVhC,EAAckC,OAAOC,WAAaC,SAASC,KAAKC,YAEnDF,SAASC,KAAKE,MAAMN,aAAeF,EAAMS,OAASP,EAAe,KAAO,GACxEG,SAASC,KAAKE,MAAME,SAAWV,EAAMS,OAAS,SAAW,GACzDJ,SAASC,KAAKE,MAAMG,YAAcX,EAAMS,OAAS,OAAS,EAAE,EAG9D,SAASzB,EAAc4B,GAKD,IAAAC,GALE,KACtBjC,EAAI,QACJE,EAAO,YACPO,EAAW,YACXC,EAAc,IACIsB,EAClB,OAAiB,QAAVC,EAAAjC,EAAKkC,aAAK,IAAAD,OAAA,EAAVA,EAAYE,QAAS,EAC1BhC,IAAAA,cAACR,EAAc,CACbyC,UAAWC,IAAW,UAAW,CAAEC,UAAWpC,IAC9CqC,QAAS,QACTC,UAAWtC,EAAU,eAAiB,cACtCuC,SAAU,EACVC,cAAc,SAEdvC,IAAAA,cAACV,EAAe,CACd2C,UAAU,sBACVzB,IAAKX,EAAKW,IACVgC,KAAK,SACL/B,MAAOH,EAAcT,EAAKY,MAAQ,KAEjCgC,EAAAA,EAAAA,IAAc5C,GAAOE,IAExBC,IAAAA,cAAA,OAAKiC,UAAU,oBACZpC,EAAKkC,MAAMW,KAAKC,GACf3C,IAAAA,cAACA,IAAAA,SAAc,CAACQ,IAAKmC,EAAUnC,KAC7BR,IAAAA,cAACL,EAAiB,CAChBE,KAAM8C,EACNpC,YAAaA,EACbD,YAAaA,SAMrB,IACN,CAEA,SAASF,EAAgBwC,GAIH,IAAAC,GAJI,KACxBhD,EAAI,YACJS,EAAW,YACXC,EAAc,IACIqC,EAClB,OAAiB,QAAVC,EAAAhD,EAAKkC,aAAK,IAAAc,OAAA,EAAVA,EAAYb,QAAS,EAC1BhC,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,OAAKiC,UAAU,eAAepC,EAAKY,OACnCT,IAAAA,cAAA,OAAKiC,UAAU,iBACZpC,EAAKkC,MAAMW,KAAKC,GAEb3C,IAAAA,cAACA,IAAAA,SAAc,CAACQ,IAAKmC,EAAUnC,KAC7BR,IAAAA,cAACL,EAAiB,CAChBE,KAAM8C,EACNrC,YAAaA,EACbC,YAAaA,SAOvB,IACN,CAEA,SAASuC,EAAiBC,GAQvB,IAAAC,GARwB,KACzBnD,EAAI,YACJU,EAAc,GAAE,YAChBD,GAKDyC,EACC,OAAiB,QAAVC,EAAAnD,EAAKkC,aAAK,IAAAiB,OAAA,EAAVA,EAAYhB,QAAS,EAC1BhC,IAAAA,cAACR,EAAc,CACbyC,UAAWC,IAAW,2BAA4B,WAClDE,QAAS,QACTC,UAAW,eACXC,SAAU,EACV9B,IAAKX,EAAKW,IACVyC,SAAS,QACTvD,oBAAqBsB,GAErBhB,IAAAA,cAACV,EAAe,CACd2C,UAAU,sBACVzB,IAAKX,EAAKW,IACVgC,KAAK,SACL/B,MAAOH,EAAcT,EAAKY,MAAQ,KAEjCgC,EAAAA,EAAAA,IAAc5C,IAEjBG,IAAAA,cAAA,OAAKiC,UAAU,oBACbjC,IAAAA,cAACkD,EAAAA,EAA4B,CAC3BC,SAAUtD,EACVU,YAAaA,MAIjB,IACN,CAEA,SAAS6C,EAAYC,GAQlB,IAAAC,GARmB,KACpBzD,EAAI,YACJU,EAAc,GAAE,YAChBD,GAKD+C,GACQE,EAASC,IAAcC,EAAAA,EAAAA,YAO9B,OAAiB,QAAVH,EAAAzD,EAAKkC,aAAK,IAAAuB,OAAA,EAAVA,EAAYtB,QAAS,EAC1BhC,IAAAA,cAACR,EAAc,CACbyC,UAAWC,IAAW,WACtBE,QAAS,QACTC,UAAW,eACXC,SAAU,EACV9B,IAAKX,EAAKW,IACVyC,SAAS,QACTvD,oBAbyBuB,IAC3BuC,EAAWvC,EAAMS,QACjBV,EAAyBC,EAAM,GAa7BjB,IAAAA,cAACV,EAAe,CACd2C,UAAU,sBACVzB,IAAKX,EAAKW,IACVgC,KAAK,SACL/B,MAAOH,EAAcT,EAAKY,MAAQ,KAEjCgC,EAAAA,EAAAA,IAAc5C,IAEjBG,IAAAA,cAAA,OACEiC,UAAU,2BACVyB,QAAUC,GAAMA,EAAEC,mBAElB5D,IAAAA,cAAC6D,EAAAA,GAAW,CACVC,UAAWjE,EACXU,YAAaA,EACbgD,QAASA,MAIb,IACN,CAEAQ,EAKC5E,EAAc,cAAe,CAC5B6E,WAAY,CACVC,EAAAA,EACAC,EAAAA,EACAC,EAAAA,EACAC,EAAAA,KAEFC,EAKCjF,EAAS,CACRkF,WAAW,IACXC,EAMDnF,EAAS,CACRoF,KAAMC,UACN,IAAAC,EAAA,IAAAC,QAAAC,EAAA,IAAAD,QAtBJ,MAAAE,UAQsBC,EAAAA,iBAAiBC,cAAA,SAAAC,YACrCC,EAAAA,EAAAA,GAAA,KAAAP,EAAA,CAAAQ,UAAA,EAAAC,OAAAC,EAAA,MAAAC,EAAA,UAQAJ,EAAAA,EAAAA,GAAA,KAAAL,EAAA,CAAAM,UAAA,EAAAC,MAAAG,EAAA,QAFSC,WAAI,OAAAC,EAAAA,EAAAA,GAAA,KAAAd,EAAA,CAAJa,SAAIE,IAAAC,EAAAA,EAAAA,GAAA,KAAAhB,EAAAe,EAAA,CAQJnF,kBAAW,OAAAkF,EAAAA,EAAAA,GAAA,KAAAZ,EAAA,CAAXtE,gBAAWmF,IAAAC,EAAAA,EAAAA,GAAA,KAAAd,EAAAa,EAAA,CAEpBE,SACE,OAAO3F,IAAAA,cAAC4F,EAAgB,CAACL,KAAMM,KAAKN,KAAMjF,YAAauF,KAAKvF,aAC9D,EAGF,SAASsF,EAAiBhG,GACxB,IAAM,KAAE2F,EAAI,YAAEjF,GAAgBV,EAExBkG,GAAUC,EAAAA,EAAAA,eACTC,EAAUC,IAAexC,EAAAA,EAAAA,UAASqC,EAAQE,WAC3C,SAAEE,EAAQ,OAAEC,GAAWH,GAEtBzF,EAAa6F,IAAkB3C,EAAAA,EAAAA,UAAmB,IAEnD4C,EAAW,eAAAC,GAAAC,EAAAA,EAAAA,IAAG,YAA2B,IAAAC,GACvC,aAAEC,IAAiBC,EAAAA,EAAAA,IACR,QAD2CF,EAC1DjB,aAAI,EAAJA,EAAMoB,iBAAS,IAAAH,EAAAA,EAAI,GACnBN,EACAC,EACA,IAEFC,EAAeK,EACjB,IAAC,kBARgB,OAAAH,EAAAM,MAAA,KAAA5B,UAAA,KAkBjB,OARA6B,EAAAA,EAAAA,YAAU,KACR,IAAMC,EAA+BhB,EAAQiB,QAAQf,IACnDC,EAAYD,EAAS,IAGvB,OADAK,IACOS,CAAQ,GACd,IAGD9G,IAAAA,cAAA,OAAKiC,UAAU,oBACZsD,aAAI,EAAJA,EAAMoB,UAAUjE,KAAK7C,IAAS,IAAAmH,EAC7B,OACEhH,IAAAA,cAACA,IAAAA,SAAc,CAACQ,IAAKX,EAAKW,MACvBV,EAAAA,EAAAA,IAAUD,GAA0B,IACM,aAA1CA,EAA0BoH,aACK,QADqBD,EACpDnH,EAA0BkC,aAAK,IAAAiF,GAAhCA,EAAkChF,OAChChC,IAAAA,cAAC8C,EAAiB,CAChBjD,KAAMA,EACNS,YAAaA,EACbC,YAAaA,IAEuB,UAAnCV,EAA0B2E,MACc,YAA1C3E,EAA0BoH,YAC3BjH,IAAAA,cAACoD,EAAY,CACXvD,KAAMA,EACNS,YAAaA,EACbC,YAAaA,IAGfP,IAAAA,cAACL,EAAiB,CAChBE,KAAMA,EACNS,YAAaA,EACbC,YAAaA,EACbR,SAAS,IAGE,IAK3B,CA9DCmH,EAAArC,IAAAlB,GAAA0B,EAAAC,EAAAF,GAAA+B,GAAApG,EAAAqG,KAAAC,EAAAA,EAAAA,GAAAH,EAAA,EAAA7C,EAAA,WAAAE,EAAA,mBAAAR,KAAAqD,I,mDC3RDE,EAAAA,EAAAA,qBAAoBC,GAAAA,GAAIC,GAAAA,GAExB,IAEAC,IAFQtI,cAAaA,KAAKE,EAAAA,EAAAA,oBAE1B0E,EAIC5E,GAAc,sBAAuB,CACpC6E,WAAY,CAACI,GAAAA,KADf,MAAAsD,WAG8B5C,EAAAA,iBAC5Ba,SACE,OAAO3F,IAAAA,cAAC2H,EAAAA,EAAwB,KAClC,EACDT,EAAAQ,IAAAD,GAAAL,IAAAC,EAAAA,EAAAA,GAAAH,EAAA,IAAAnD,IAAAoD,EAAAC,G","sources":["webpack:///./src/nav-menu/index.tsx","webpack:///./src/launchpad/index.tsx"],"sourcesContent":["import React, { useEffect, useState } from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { getHistory } from \"@next-core/runtime\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport styleText from \"./nav-menu.shadow.css\";\nimport { LocationDescriptor, UnregisterCallback } from \"history\";\nimport type { SidebarMenu } from \"@next-bricks/basic/menu\";\nimport type {\n MenuItem as MenuItemComponent,\n MenuComponentProps,\n} from \"@next-bricks/basic/menu-item\";\nimport {\n isSimple,\n isSubMenu,\n isGroup,\n renderLinkCom,\n renderSpanCom,\n} from \"./utils.js\";\nimport { initMenuItemAndMatchCurrentPathKeys } from \"@next-shared/general/menu\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuItem,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport type {\n Popover,\n PopoverProps,\n PopoverEvents,\n PopoverEventsMapping,\n} from \"@next-bricks/basic/popover\";\nimport \"@next-core/theme\";\nimport classnames from \"classnames\";\nimport { ThreeLevelMenuPopoverContent } from \"./ThreeLevelMenuPopoverContent.js\";\nimport { SiteMapItem } from \"./site-map/SiteMapItem.js\";\nimport SiteMapStyleText from \"../nav-menu/site-map/SiteMapItem.shadow.css\";\nimport ItemTagStyleText from \"../nav-menu/site-map/ItemTag.shadow.css\";\nimport GroupItemStyleText from \"../nav-menu/site-map/GroupItem.shadow.css\";\nimport { debounce } from \"lodash\";\n\nconst { defineElement, property } = createDecorators();\n\nconst WrappedMenuItem = wrapBrick<MenuItemComponent, MenuComponentProps>(\n \"eo-menu-item\"\n);\nconst WrappedPopover = wrapBrick<\n Popover,\n PopoverProps,\n PopoverEvents,\n PopoverEventsMapping\n>(\"eo-popover\", {\n onVisibleChange: \"visible.change\",\n beforeVisibleChange: \"before.visible.change\",\n});\n\ninterface NavMenuProps {\n menu?: SidebarMenu;\n showTooltip?: boolean;\n}\n\ninterface MenuItemComProps {\n item: SidebarMenuItem;\n topData?: boolean;\n selectedKey?: string[];\n showTooltip?: boolean;\n}\ninterface SimpleMenuItemComProps extends MenuItemComProps {\n item: SidebarMenuSimpleItem;\n}\ninterface MenuGroupComProps extends MenuItemComProps {\n item: SidebarMenuGroup;\n}\nfunction RenderMenuItemCom(props: MenuItemComProps) {\n const { item } = props;\n return isSubMenu(item as SidebarMenuGroup, props.topData) ? (\n <SubMenuItemCom {...props} item={item as SidebarMenuGroup}></SubMenuItemCom>\n ) : isGroup(item) ? (\n <GroupMenuItemCom {...props} item={item as SidebarMenuGroup} />\n ) : (\n <SimpleMenuItemCom\n {...props}\n item={item as SidebarMenuSimpleItem}\n ></SimpleMenuItemCom>\n );\n}\nfunction SimpleMenuItemCom(props: SimpleMenuItemComProps) {\n const { item, showTooltip, selectedKey = [] } = props;\n return (\n <WrappedMenuItem\n key={item.key}\n title={showTooltip ? item.text : \"\"}\n active={item.key ? selectedKey.includes(item.key) : false}\n >\n {renderLinkCom(item, { width: \"100%\" })}\n </WrappedMenuItem>\n );\n}\n\nlet scrollWidth: number;\n// istanbul ignore next;\nconst handlePopupVisibleChange = (event: CustomEvent<boolean>) => {\n // 当用户设置滚动条一直显示时,来回切换 overflow: hidden 会导致滚动条显示或隐藏\n // 造成页面宽度变化而导致的抖动的问题\n const paddingRight =\n scrollWidth ??\n (scrollWidth = window.innerWidth - document.body.clientWidth);\n\n document.body.style.paddingRight = event.detail ? paddingRight + \"px\" : \"\";\n document.body.style.overflow = event.detail ? \"hidden\" : \"\";\n document.body.style.touchAction = event.detail ? \"none\" : \"\";\n};\n\nfunction SubMenuItemCom({\n item,\n topData,\n showTooltip,\n selectedKey = [],\n}: MenuGroupComProps) {\n return item.items?.length > 0 ? (\n <WrappedPopover\n className={classnames(\"popover\", { subprime: !topData })}\n trigger={\"hover\"}\n placement={topData ? \"bottom-start\" : \"right-start\"}\n distance={0}\n anchorDisplay=\"block\"\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item, !topData)}\n </WrappedMenuItem>\n <div className=\"sub-menu-wrapper\">\n {item.items.map((innerItem) => (\n <React.Fragment key={innerItem.key}>\n <RenderMenuItemCom\n item={innerItem}\n selectedKey={selectedKey}\n showTooltip={showTooltip}\n />\n </React.Fragment>\n ))}\n </div>\n </WrappedPopover>\n ) : null;\n}\n\nfunction GroupMenuItemCom({\n item,\n showTooltip,\n selectedKey = [],\n}: MenuGroupComProps) {\n return item.items?.length > 0 ? (\n <>\n <div className=\"group-label\">{item.title}</div>\n <div className=\"group-wrapper\">\n {item.items.map((innerItem) => {\n return (\n <React.Fragment key={innerItem.key}>\n <RenderMenuItemCom\n item={innerItem}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n />\n </React.Fragment>\n );\n })}\n </div>\n </>\n ) : null;\n}\n\nfunction ThreeLevelMenuCom({\n item,\n selectedKey = [],\n showTooltip,\n}: {\n item: SidebarMenuGroup;\n selectedKey?: string[];\n showTooltip?: boolean;\n}) {\n return item.items?.length > 0 ? (\n <WrappedPopover\n className={classnames(\"three-level-menu-popover\", \"popover\")}\n trigger={\"hover\"}\n placement={\"bottom-start\"}\n distance={0}\n key={item.key}\n strategy=\"fixed\"\n beforeVisibleChange={handlePopupVisibleChange}\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item)}\n </WrappedMenuItem>\n <div className=\"sub-menu-wrapper\">\n <ThreeLevelMenuPopoverContent\n menuItem={item}\n selectedKey={selectedKey}\n ></ThreeLevelMenuPopoverContent>\n </div>\n </WrappedPopover>\n ) : null;\n}\n\nfunction SitMapMenCom({\n item,\n selectedKey = [],\n showTooltip,\n}: {\n item: SidebarMenuGroup;\n selectedKey?: string[];\n showTooltip?: boolean;\n}) {\n const [visible, setVisible] = useState<boolean>();\n\n const handleVisibleChange = (event: CustomEvent<boolean>): void => {\n setVisible(event.detail);\n handlePopupVisibleChange(event);\n };\n\n return item.items?.length > 0 ? (\n <WrappedPopover\n className={classnames(\"popover\")}\n trigger={\"hover\"}\n placement={\"bottom-start\"}\n distance={0}\n key={item.key}\n strategy=\"fixed\"\n beforeVisibleChange={handleVisibleChange}\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item)}\n </WrappedMenuItem>\n <div\n className=\"sub-menu-sit-map-wrapper\"\n onClick={(e) => e.stopPropagation()}\n >\n <SiteMapItem\n menuGroup={item}\n selectedKey={selectedKey}\n visible={visible}\n />\n </div>\n </WrappedPopover>\n ) : null;\n}\n\n/**\n * 菜单构件\n * @author sailor\n *\n */\n@defineElement(\"eo-nav-menu\", {\n styleTexts: [\n SiteMapStyleText,\n ItemTagStyleText,\n GroupItemStyleText,\n styleText,\n ],\n})\nclass NavMenu extends ReactNextElement {\n /**\n * 菜单项\n */\n @property({\n attribute: false,\n })\n accessor menu: SidebarMenu | undefined;\n\n /**\n * 是否显示 tooltip\n */\n @property({\n type: Boolean,\n })\n accessor showTooltip: boolean | undefined;\n\n render() {\n return <NavMenuComponent menu={this.menu} showTooltip={this.showTooltip} />;\n }\n}\n\nfunction NavMenuComponent(props: NavMenuProps) {\n const { menu, showTooltip } = props;\n\n const history = getHistory();\n const [location, setLocation] = useState(history.location);\n const { pathname, search } = location;\n\n const [selectedKey, setSelectedKey] = useState<string[]>([]);\n\n const setSelected = async (): Promise<void> => {\n const { selectedKeys } = initMenuItemAndMatchCurrentPathKeys(\n menu?.menuItems ?? [],\n pathname,\n search,\n \"\"\n );\n setSelectedKey(selectedKeys);\n };\n\n useEffect(() => {\n const unListen: UnregisterCallback = history.listen((location) => {\n setLocation(location);\n });\n setSelected();\n return unListen;\n }, []);\n\n return (\n <div className=\"nav-menu-wrapper\">\n {menu?.menuItems.map((item) => {\n return (\n <React.Fragment key={item.key}>\n {isSubMenu(item as SidebarMenuGroup, true) &&\n (item as SidebarMenuGroup).childLayout === \"category\" &&\n (item as SidebarMenuGroup).items?.length ? (\n <ThreeLevelMenuCom\n item={item as SidebarMenuGroup}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n />\n ) : (item as SidebarMenuGroup).type === \"group\" &&\n (item as SidebarMenuGroup).childLayout === \"siteMap\" ? (\n <SitMapMenCom\n item={item as SidebarMenuGroup}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n />\n ) : (\n <RenderMenuItemCom\n item={item}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n topData={true}\n />\n )}\n </React.Fragment>\n );\n })}\n </div>\n );\n}\n\nexport { NavMenu };\n","import React from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport { LaunchpadButton as LaunchpadButtonComponent } from \"./LaunchpadButton/LaunchpadButton.js\";\nimport { initializeReactI18n } from \"@next-core/i18n/react\";\nimport \"@next-core/theme\";\nimport { NS, locales } from \"./i18n.js\";\nimport styleText from \"./LaunchpadButton/LaunchpadButton.shadow.css\";\n\ninitializeReactI18n(NS, locales);\n\nconst { defineElement } = createDecorators();\n\n/**\n * Launchpad 按钮构件\n * @author sailor\n */\n@defineElement(\"eo-launchpad-button\", {\n styleTexts: [styleText],\n})\nclass LaunchpadButton extends ReactNextElement {\n render() {\n return <LaunchpadButtonComponent />;\n }\n}\n\nexport { LaunchpadButton };\n"],"names":["scrollWidth","defineElement","property","createDecorators","WrappedMenuItem","wrapBrick","WrappedPopover","onVisibleChange","beforeVisibleChange","RenderMenuItemCom","props","item","isSubMenu","topData","React","SubMenuItemCom","_extends","isGroup","GroupMenuItemCom","SimpleMenuItemCom","showTooltip","selectedKey","key","title","text","active","includes","renderLinkCom","width","_NavMenu","handlePopupVisibleChange","event","_scrollWidth","paddingRight","window","innerWidth","document","body","clientWidth","style","detail","overflow","touchAction","_ref","_item$items","items","length","className","classnames","subprime","trigger","placement","distance","anchorDisplay","slot","renderSpanCom","map","innerItem","_ref2","_item$items2","ThreeLevelMenuCom","_ref3","_item$items3","strategy","ThreeLevelMenuPopoverContent","menuItem","SitMapMenCom","_ref4","_item$items4","visible","setVisible","useState","onClick","e","stopPropagation","SiteMapItem","menuGroup","_dec","styleTexts","SiteMapStyleText","ItemTagStyleText","GroupItemStyleText","styleText","_dec2","attribute","_dec3","type","Boolean","_A","WeakMap","_B","NavMenu","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","writable","value","_initProto","_init_menu","_init_showTooltip","menu","_classPrivateFieldGet","v","_classPrivateFieldSet","render","NavMenuComponent","this","history","getHistory","location","setLocation","pathname","search","setSelectedKey","setSelected","_ref5","_asyncToGenerator","_menu$menuItems","selectedKeys","initMenuItemAndMatchCurrentPathKeys","menuItems","apply","useEffect","unListen","listen","_items","childLayout","_class","c","_initClass","_applyDecs","initializeReactI18n","NS","locales","_LaunchpadButton","LaunchpadButton","LaunchpadButtonComponent"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"chunks/752.ca4288fe.js","mappings":"6IAkGIA,E,yNA1DE,cAAEC,EAAa,SAAEC,IAAaC,EAAAA,EAAAA,oBAE9BC,GAAkBC,EAAAA,EAAAA,WACtB,gBAEIC,GAAiBD,EAAAA,EAAAA,WAKrB,aAAc,CACdE,gBAAiB,iBACjBC,oBAAqB,0BAoBvB,SAASC,EAAkBC,GACzB,IAAM,KAAEC,GAASD,EACjB,OAAOE,EAAAA,EAAAA,IAAUD,EAA0BD,EAAMG,SAC/CC,IAAAA,cAACC,GAAcC,EAAAA,EAAAA,GAAA,GAAKN,EAAK,CAAEC,KAAMA,MAC/BM,EAAAA,EAAAA,IAAQN,GACVG,IAAAA,cAACI,GAAgBF,EAAAA,EAAAA,GAAA,GAAKN,EAAK,CAAEC,KAAMA,KAEnCG,IAAAA,cAACK,GAAiBH,EAAAA,EAAAA,GAAA,GACZN,EAAK,CACTC,KAAMA,IAGZ,CACA,SAASQ,EAAkBT,GACzB,IAAM,KAAEC,EAAI,YAAES,EAAW,YAAEC,EAAc,IAAOX,EAChD,OACEI,IAAAA,cAACV,EAAe,CACdkB,IAAKX,EAAKW,IACVC,MAAOH,EAAcT,EAAKa,KAAO,GACjCC,SAAQd,EAAKW,KAAMD,EAAYK,SAASf,EAAKW,OAE5CK,EAAAA,EAAAA,IAAchB,EAAM,CAAEiB,MAAO,SAGpC,CAIA,IA+JAC,EA/JMC,EAA4BC,IAAgC,IAAAC,EAG1DC,EACO,QADKD,EAChBhC,SAAW,IAAAgC,EAAAA,EACVhC,EAAckC,OAAOC,WAAaC,SAASC,KAAKC,YAEnDF,SAASC,KAAKE,MAAMN,aAAeF,EAAMS,OAASP,EAAe,KAAO,GACxEG,SAASC,KAAKE,MAAME,SAAWV,EAAMS,OAAS,SAAW,GACzDJ,SAASC,KAAKE,MAAMG,YAAcX,EAAMS,OAAS,OAAS,EAAE,EAG9D,SAASzB,EAAc4B,GAKD,IAAAC,GALE,KACtBjC,EAAI,QACJE,EAAO,YACPO,EAAW,YACXC,EAAc,IACIsB,EAClB,OAAiB,QAAVC,EAAAjC,EAAKkC,aAAK,IAAAD,OAAA,EAAVA,EAAYE,QAAS,EAC1BhC,IAAAA,cAACR,EAAc,CACbyC,UAAWC,IAAW,UAAW,CAAEC,UAAWpC,IAC9CqC,QAAS,QACTC,UAAWtC,EAAU,eAAiB,cACtCuC,SAAU,EACVC,cAAc,SAEdvC,IAAAA,cAACV,EAAe,CACd2C,UAAU,sBACVzB,IAAKX,EAAKW,IACVgC,KAAK,SACL/B,MAAOH,EAAcT,EAAKY,MAAQ,KAEjCgC,EAAAA,EAAAA,IAAc5C,GAAOE,IAExBC,IAAAA,cAAA,OAAKiC,UAAU,oBACZpC,EAAKkC,MAAMW,KAAKC,GACf3C,IAAAA,cAACA,IAAAA,SAAc,CAACQ,IAAKmC,EAAUnC,KAC7BR,IAAAA,cAACL,EAAiB,CAChBE,KAAM8C,EACNpC,YAAaA,EACbD,YAAaA,SAMrB,IACN,CAEA,SAASF,EAAgBwC,GAIH,IAAAC,GAJI,KACxBhD,EAAI,YACJS,EAAW,YACXC,EAAc,IACIqC,EAClB,OAAiB,QAAVC,EAAAhD,EAAKkC,aAAK,IAAAc,OAAA,EAAVA,EAAYb,QAAS,EAC1BhC,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,OAAKiC,UAAU,eAAepC,EAAKY,OACnCT,IAAAA,cAAA,OAAKiC,UAAU,iBACZpC,EAAKkC,MAAMW,KAAKC,GAEb3C,IAAAA,cAACA,IAAAA,SAAc,CAACQ,IAAKmC,EAAUnC,KAC7BR,IAAAA,cAACL,EAAiB,CAChBE,KAAM8C,EACNrC,YAAaA,EACbC,YAAaA,SAOvB,IACN,CAEA,SAASuC,EAAiBC,GAQvB,IAAAC,GARwB,KACzBnD,EAAI,YACJU,EAAc,GAAE,YAChBD,GAKDyC,EACC,OAAiB,QAAVC,EAAAnD,EAAKkC,aAAK,IAAAiB,OAAA,EAAVA,EAAYhB,QAAS,EAC1BhC,IAAAA,cAACR,EAAc,CACbyC,UAAWC,IAAW,2BAA4B,WAClDE,QAAS,QACTC,UAAW,eACXC,SAAU,EACV9B,IAAKX,EAAKW,IACVyC,SAAS,QACTvD,oBAAqBsB,GAErBhB,IAAAA,cAACV,EAAe,CACd2C,UAAU,sBACVzB,IAAKX,EAAKW,IACVgC,KAAK,SACL/B,MAAOH,EAAcT,EAAKY,MAAQ,KAEjCgC,EAAAA,EAAAA,IAAc5C,IAEjBG,IAAAA,cAAA,OAAKiC,UAAU,oBACbjC,IAAAA,cAACkD,EAAAA,EAA4B,CAC3BC,SAAUtD,EACVU,YAAaA,MAIjB,IACN,CAEA,SAAS6C,EAAYC,GAQlB,IAAAC,GARmB,KACpBzD,EAAI,YACJU,EAAc,GAAE,YAChBD,GAKD+C,GACQE,EAASC,IAAcC,EAAAA,EAAAA,YAO9B,OAAiB,QAAVH,EAAAzD,EAAKkC,aAAK,IAAAuB,OAAA,EAAVA,EAAYtB,QAAS,EAC1BhC,IAAAA,cAACR,EAAc,CACbyC,UAAWC,IAAW,WACtBE,QAAS,QACTC,UAAW,eACXC,SAAU,EACV9B,IAAKX,EAAKW,IACVyC,SAAS,QACTvD,oBAbyBuB,IAC3BuC,EAAWvC,EAAMS,QACjBV,EAAyBC,EAAM,GAa7BjB,IAAAA,cAACV,EAAe,CACd2C,UAAU,sBACVzB,IAAKX,EAAKW,IACVgC,KAAK,SACL/B,MAAOH,EAAcT,EAAKY,MAAQ,KAEjCgC,EAAAA,EAAAA,IAAc5C,IAEjBG,IAAAA,cAAA,OACEiC,UAAU,2BACVyB,QAAUC,GAAMA,EAAEC,mBAElB5D,IAAAA,cAAC6D,EAAAA,GAAW,CACVC,UAAWjE,EACXU,YAAaA,EACbgD,QAASA,MAIb,IACN,CAEAQ,EAKC5E,EAAc,cAAe,CAC5B6E,WAAY,CACVC,EAAAA,EACAC,EAAAA,EACAC,EAAAA,EACAC,EAAAA,KAEFC,EAKCjF,EAAS,CACRkF,WAAW,IACXC,EAMDnF,EAAS,CACRoF,KAAMC,UACN,IAAAC,EAAA,IAAAC,QAAAC,EAAA,IAAAD,QAtBJ,MAAAE,UAQsBC,EAAAA,iBAAiBC,cAAA,SAAAC,YACrCC,EAAAA,EAAAA,GAAA,KAAAP,EAAA,CAAAQ,UAAA,EAAAC,OAAAC,EAAA,MAAAC,EAAA,UAQAJ,EAAAA,EAAAA,GAAA,KAAAL,EAAA,CAAAM,UAAA,EAAAC,MAAAG,EAAA,QAFSC,WAAI,OAAAC,EAAAA,EAAAA,GAAA,KAAAd,EAAA,CAAJa,SAAIE,IAAAC,EAAAA,EAAAA,GAAA,KAAAhB,EAAAe,EAAA,CAQJnF,kBAAW,OAAAkF,EAAAA,EAAAA,GAAA,KAAAZ,EAAA,CAAXtE,gBAAWmF,IAAAC,EAAAA,EAAAA,GAAA,KAAAd,EAAAa,EAAA,CAEpBE,SACE,OAAO3F,IAAAA,cAAC4F,EAAgB,CAACL,KAAMM,KAAKN,KAAMjF,YAAauF,KAAKvF,aAC9D,EAGF,SAASsF,EAAiBhG,GACxB,IAAM,KAAE2F,EAAI,YAAEjF,GAAgBV,EAExBkG,GAAUC,EAAAA,EAAAA,eACTC,EAAUC,IAAexC,EAAAA,EAAAA,UAASqC,EAAQE,WAC3C,SAAEE,EAAQ,OAAEC,GAAWH,GAEtBzF,EAAa6F,IAAkB3C,EAAAA,EAAAA,UAAmB,IAEnD4C,EAAW,eAAAC,GAAAC,EAAAA,EAAAA,IAAG,YAA2B,IAAAC,GACvC,aAAEC,IAAiBC,EAAAA,EAAAA,IACR,QAD2CF,EAC1DjB,aAAI,EAAJA,EAAMoB,iBAAS,IAAAH,EAAAA,EAAI,GACnBN,EACAC,EACA,IAEFC,EAAeK,EACjB,IAAC,kBARgB,OAAAH,EAAAM,MAAA,KAAA5B,UAAA,KAkBjB,OARA6B,EAAAA,EAAAA,YAAU,KACR,IAAMC,EAA+BhB,EAAQiB,QAAQf,IACnDC,EAAYD,EAAS,IAGvB,OADAK,IACOS,CAAQ,GACd,IAGD9G,IAAAA,cAAA,OAAKiC,UAAU,oBACZsD,aAAI,EAAJA,EAAMoB,UAAUjE,KAAK7C,IAAS,IAAAmH,EAC7B,OACEhH,IAAAA,cAACA,IAAAA,SAAc,CAACQ,IAAKX,EAAKW,MACvBV,EAAAA,EAAAA,IAAUD,GAA0B,IACM,aAA1CA,EAA0BoH,aACK,QADqBD,EACpDnH,EAA0BkC,aAAK,IAAAiF,GAAhCA,EAAkChF,OAChChC,IAAAA,cAAC8C,EAAiB,CAChBjD,KAAMA,EACNS,YAAaA,EACbC,YAAaA,IAEuB,UAAnCV,EAA0B2E,MACc,YAA1C3E,EAA0BoH,YAC3BjH,IAAAA,cAACoD,EAAY,CACXvD,KAAMA,EACNS,YAAaA,EACbC,YAAaA,IAGfP,IAAAA,cAACL,EAAiB,CAChBE,KAAMA,EACNS,YAAaA,EACbC,YAAaA,EACbR,SAAS,IAGE,IAK3B,CA9DCmH,EAAArC,IAAAlB,GAAA0B,EAAAC,EAAAF,GAAA+B,GAAApG,EAAAqG,KAAAC,EAAAA,EAAAA,GAAAH,EAAA,EAAA7C,EAAA,WAAAE,EAAA,mBAAAR,KAAAqD,I,mDC3RDE,EAAAA,EAAAA,qBAAoBC,GAAAA,GAAIC,GAAAA,GAExB,IAEAC,IAFQtI,cAAaA,KAAKE,EAAAA,EAAAA,oBAE1B0E,EAIC5E,GAAc,sBAAuB,CACpC6E,WAAY,CAACI,GAAAA,KADf,MAAAsD,WAG8B5C,EAAAA,iBAC5Ba,SACE,OAAO3F,IAAAA,cAAC2H,EAAAA,EAAwB,KAClC,EACDT,EAAAQ,IAAAD,GAAAL,IAAAC,EAAAA,EAAAA,GAAAH,EAAA,IAAAnD,IAAAoD,EAAAC,G","sources":["webpack:///./src/nav-menu/index.tsx","webpack:///./src/launchpad/index.tsx"],"sourcesContent":["import React, { useEffect, useState } from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { getHistory } from \"@next-core/runtime\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport styleText from \"./nav-menu.shadow.css\";\nimport { LocationDescriptor, UnregisterCallback } from \"history\";\nimport type { SidebarMenu } from \"@next-bricks/basic/menu\";\nimport type {\n MenuItem as MenuItemComponent,\n MenuComponentProps,\n} from \"@next-bricks/basic/menu-item\";\nimport {\n isSimple,\n isSubMenu,\n isGroup,\n renderLinkCom,\n renderSpanCom,\n} from \"./utils.js\";\nimport { initMenuItemAndMatchCurrentPathKeys } from \"@next-shared/general/menu\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuItem,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport type {\n Popover,\n PopoverProps,\n PopoverEvents,\n PopoverEventsMapping,\n} from \"@next-bricks/basic/popover\";\nimport \"@next-core/theme\";\nimport classnames from \"classnames\";\nimport { ThreeLevelMenuPopoverContent } from \"./ThreeLevelMenuPopoverContent.js\";\nimport { SiteMapItem } from \"./site-map/SiteMapItem.js\";\nimport SiteMapStyleText from \"../nav-menu/site-map/SiteMapItem.shadow.css\";\nimport ItemTagStyleText from \"../nav-menu/site-map/ItemTag.shadow.css\";\nimport GroupItemStyleText from \"../nav-menu/site-map/GroupItem.shadow.css\";\nimport { debounce } from \"lodash\";\n\nconst { defineElement, property } = createDecorators();\n\nconst WrappedMenuItem = wrapBrick<MenuItemComponent, MenuComponentProps>(\n \"eo-menu-item\"\n);\nconst WrappedPopover = wrapBrick<\n Popover,\n PopoverProps,\n PopoverEvents,\n PopoverEventsMapping\n>(\"eo-popover\", {\n onVisibleChange: \"visible.change\",\n beforeVisibleChange: \"before.visible.change\",\n});\n\ninterface NavMenuProps {\n menu?: SidebarMenu;\n showTooltip?: boolean;\n}\n\ninterface MenuItemComProps {\n item: SidebarMenuItem;\n topData?: boolean;\n selectedKey?: string[];\n showTooltip?: boolean;\n}\ninterface SimpleMenuItemComProps extends MenuItemComProps {\n item: SidebarMenuSimpleItem;\n}\ninterface MenuGroupComProps extends MenuItemComProps {\n item: SidebarMenuGroup;\n}\nfunction RenderMenuItemCom(props: MenuItemComProps) {\n const { item } = props;\n return isSubMenu(item as SidebarMenuGroup, props.topData) ? (\n <SubMenuItemCom {...props} item={item as SidebarMenuGroup}></SubMenuItemCom>\n ) : isGroup(item) ? (\n <GroupMenuItemCom {...props} item={item as SidebarMenuGroup} />\n ) : (\n <SimpleMenuItemCom\n {...props}\n item={item as SidebarMenuSimpleItem}\n ></SimpleMenuItemCom>\n );\n}\nfunction SimpleMenuItemCom(props: SimpleMenuItemComProps) {\n const { item, showTooltip, selectedKey = [] } = props;\n return (\n <WrappedMenuItem\n key={item.key}\n title={showTooltip ? item.text : \"\"}\n active={item.key ? selectedKey.includes(item.key) : false}\n >\n {renderLinkCom(item, { width: \"100%\" })}\n </WrappedMenuItem>\n );\n}\n\nlet scrollWidth: number;\n// istanbul ignore next;\nconst handlePopupVisibleChange = (event: CustomEvent<boolean>) => {\n // 当用户设置滚动条一直显示时,来回切换 overflow: hidden 会导致滚动条显示或隐藏\n // 造成页面宽度变化而导致的抖动的问题\n const paddingRight =\n scrollWidth ??\n (scrollWidth = window.innerWidth - document.body.clientWidth);\n\n document.body.style.paddingRight = event.detail ? paddingRight + \"px\" : \"\";\n document.body.style.overflow = event.detail ? \"hidden\" : \"\";\n document.body.style.touchAction = event.detail ? \"none\" : \"\";\n};\n\nfunction SubMenuItemCom({\n item,\n topData,\n showTooltip,\n selectedKey = [],\n}: MenuGroupComProps) {\n return item.items?.length > 0 ? (\n <WrappedPopover\n className={classnames(\"popover\", { subprime: !topData })}\n trigger={\"hover\"}\n placement={topData ? \"bottom-start\" : \"right-start\"}\n distance={0}\n anchorDisplay=\"block\"\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item, !topData)}\n </WrappedMenuItem>\n <div className=\"sub-menu-wrapper\">\n {item.items.map((innerItem) => (\n <React.Fragment key={innerItem.key}>\n <RenderMenuItemCom\n item={innerItem}\n selectedKey={selectedKey}\n showTooltip={showTooltip}\n />\n </React.Fragment>\n ))}\n </div>\n </WrappedPopover>\n ) : null;\n}\n\nfunction GroupMenuItemCom({\n item,\n showTooltip,\n selectedKey = [],\n}: MenuGroupComProps) {\n return item.items?.length > 0 ? (\n <>\n <div className=\"group-label\">{item.title}</div>\n <div className=\"group-wrapper\">\n {item.items.map((innerItem) => {\n return (\n <React.Fragment key={innerItem.key}>\n <RenderMenuItemCom\n item={innerItem}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n />\n </React.Fragment>\n );\n })}\n </div>\n </>\n ) : null;\n}\n\nfunction ThreeLevelMenuCom({\n item,\n selectedKey = [],\n showTooltip,\n}: {\n item: SidebarMenuGroup;\n selectedKey?: string[];\n showTooltip?: boolean;\n}) {\n return item.items?.length > 0 ? (\n <WrappedPopover\n className={classnames(\"three-level-menu-popover\", \"popover\")}\n trigger={\"hover\"}\n placement={\"bottom-start\"}\n distance={0}\n key={item.key}\n strategy=\"fixed\"\n beforeVisibleChange={handlePopupVisibleChange}\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item)}\n </WrappedMenuItem>\n <div className=\"sub-menu-wrapper\">\n <ThreeLevelMenuPopoverContent\n menuItem={item}\n selectedKey={selectedKey}\n ></ThreeLevelMenuPopoverContent>\n </div>\n </WrappedPopover>\n ) : null;\n}\n\nfunction SitMapMenCom({\n item,\n selectedKey = [],\n showTooltip,\n}: {\n item: SidebarMenuGroup;\n selectedKey?: string[];\n showTooltip?: boolean;\n}) {\n const [visible, setVisible] = useState<boolean>();\n\n const handleVisibleChange = (event: CustomEvent<boolean>): void => {\n setVisible(event.detail);\n handlePopupVisibleChange(event);\n };\n\n return item.items?.length > 0 ? (\n <WrappedPopover\n className={classnames(\"popover\")}\n trigger={\"hover\"}\n placement={\"bottom-start\"}\n distance={0}\n key={item.key}\n strategy=\"fixed\"\n beforeVisibleChange={handleVisibleChange}\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item)}\n </WrappedMenuItem>\n <div\n className=\"sub-menu-sit-map-wrapper\"\n onClick={(e) => e.stopPropagation()}\n >\n <SiteMapItem\n menuGroup={item}\n selectedKey={selectedKey}\n visible={visible}\n />\n </div>\n </WrappedPopover>\n ) : null;\n}\n\n/**\n * 菜单构件\n * @author sailor\n *\n */\n@defineElement(\"eo-nav-menu\", {\n styleTexts: [\n SiteMapStyleText,\n ItemTagStyleText,\n GroupItemStyleText,\n styleText,\n ],\n})\nclass NavMenu extends ReactNextElement {\n /**\n * 菜单项\n */\n @property({\n attribute: false,\n })\n accessor menu: SidebarMenu | undefined;\n\n /**\n * 是否显示 tooltip\n */\n @property({\n type: Boolean,\n })\n accessor showTooltip: boolean | undefined;\n\n render() {\n return <NavMenuComponent menu={this.menu} showTooltip={this.showTooltip} />;\n }\n}\n\nfunction NavMenuComponent(props: NavMenuProps) {\n const { menu, showTooltip } = props;\n\n const history = getHistory();\n const [location, setLocation] = useState(history.location);\n const { pathname, search } = location;\n\n const [selectedKey, setSelectedKey] = useState<string[]>([]);\n\n const setSelected = async (): Promise<void> => {\n const { selectedKeys } = initMenuItemAndMatchCurrentPathKeys(\n menu?.menuItems ?? [],\n pathname,\n search,\n \"\"\n );\n setSelectedKey(selectedKeys);\n };\n\n useEffect(() => {\n const unListen: UnregisterCallback = history.listen((location) => {\n setLocation(location);\n });\n setSelected();\n return unListen;\n }, []);\n\n return (\n <div className=\"nav-menu-wrapper\">\n {menu?.menuItems.map((item) => {\n return (\n <React.Fragment key={item.key}>\n {isSubMenu(item as SidebarMenuGroup, true) &&\n (item as SidebarMenuGroup).childLayout === \"category\" &&\n (item as SidebarMenuGroup).items?.length ? (\n <ThreeLevelMenuCom\n item={item as SidebarMenuGroup}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n />\n ) : (item as SidebarMenuGroup).type === \"group\" &&\n (item as SidebarMenuGroup).childLayout === \"siteMap\" ? (\n <SitMapMenCom\n item={item as SidebarMenuGroup}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n />\n ) : (\n <RenderMenuItemCom\n item={item}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n topData={true}\n />\n )}\n </React.Fragment>\n );\n })}\n </div>\n );\n}\n\nexport { NavMenu };\n","import React from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport { LaunchpadButton as LaunchpadButtonComponent } from \"./LaunchpadButton/LaunchpadButton.js\";\nimport { initializeReactI18n } from \"@next-core/i18n/react\";\nimport \"@next-core/theme\";\nimport { NS, locales } from \"./i18n.js\";\nimport styleText from \"./LaunchpadButton/LaunchpadButton.shadow.css\";\n\ninitializeReactI18n(NS, locales);\n\nconst { defineElement } = createDecorators();\n\n/**\n * Launchpad 按钮构件\n * @author sailor\n */\n@defineElement(\"eo-launchpad-button\", {\n styleTexts: [styleText],\n})\nclass LaunchpadButton extends ReactNextElement {\n render() {\n return <LaunchpadButtonComponent />;\n }\n}\n\nexport { LaunchpadButton };\n"],"names":["scrollWidth","defineElement","property","createDecorators","WrappedMenuItem","wrapBrick","WrappedPopover","onVisibleChange","beforeVisibleChange","RenderMenuItemCom","props","item","isSubMenu","topData","React","SubMenuItemCom","_extends","isGroup","GroupMenuItemCom","SimpleMenuItemCom","showTooltip","selectedKey","key","title","text","active","includes","renderLinkCom","width","_NavMenu","handlePopupVisibleChange","event","_scrollWidth","paddingRight","window","innerWidth","document","body","clientWidth","style","detail","overflow","touchAction","_ref","_item$items","items","length","className","classnames","subprime","trigger","placement","distance","anchorDisplay","slot","renderSpanCom","map","innerItem","_ref2","_item$items2","ThreeLevelMenuCom","_ref3","_item$items3","strategy","ThreeLevelMenuPopoverContent","menuItem","SitMapMenCom","_ref4","_item$items4","visible","setVisible","useState","onClick","e","stopPropagation","SiteMapItem","menuGroup","_dec","styleTexts","SiteMapStyleText","ItemTagStyleText","GroupItemStyleText","styleText","_dec2","attribute","_dec3","type","Boolean","_A","WeakMap","_B","NavMenu","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","writable","value","_initProto","_init_menu","_init_showTooltip","menu","_classPrivateFieldGet","v","_classPrivateFieldSet","render","NavMenuComponent","this","history","getHistory","location","setLocation","pathname","search","setSelectedKey","setSelected","_ref5","_asyncToGenerator","_menu$menuItems","selectedKeys","initMenuItemAndMatchCurrentPathKeys","menuItems","apply","useEffect","unListen","listen","_items","childLayout","_class","c","_initClass","_applyDecs","initializeReactI18n","NS","locales","_LaunchpadButton","LaunchpadButton","LaunchpadButtonComponent"],"sourceRoot":""}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";(self.webpackChunk_next_bricks_nav=self.webpackChunk_next_bricks_nav||[]).push([[7746],{7029:(e,t,n)=>{var r=n(2484);t.s=r.createRoot,r.hydrateRoot},5863:(e,t,n)=>{function r(e,t){if(t.has(e))throw new TypeError("Cannot initialize the same private elements twice on an object")}n.d(t,{Z:()=>r})},175:(e,t,n)=>{function r(e,t,n){if(!t.has(e))throw new TypeError("attempted to "+n+" private field on non-instance");return t.get(e)}n.d(t,{Z:()=>r})},687:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(175);function i(e,t){return function(e,t){return t.get?t.get.call(e):t.value}(e,(0,r.Z)(e,t,"get"))}},3395:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(5863);function i(e,t,n){(0,r.Z)(e,t),t.set(e,n)}},381:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(175);function i(e,t,n){return function(e,t,n){if(t.set)t.set.call(e,n);else{if(!t.writable)throw new TypeError("attempted to set read only private field");t.value=n}}(e,(0,r.Z)(e,t,"set"),n),n}},6171:(e,t,n)=>{function r(e,t,n){if(!t.has(e))throw new TypeError("attempted to get private field on non-instance");return n}n.d(t,{Z:()=>r})},5866:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(5863);function i(e,t){(0,r.Z)(e,t),t.add(e)}},9740:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(1461);function i(e,t){if(null==e)return{};var n,i,a=(0,r.Z)(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(i=0;i<o.length;i++)n=o[i],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}},1461:(e,t,n)=>{function r(e,t){if(null==e)return{};var n,r,i={},a=Object.keys(e);for(r=0;r<a.length;r++)n=a[r],t.indexOf(n)>=0||(i[n]=e[n]);return i}n.d(t,{Z:()=>r})},1646:(e,t,n)=>{n.r(t),n.d(t,{ReactNextElement:()=>p,wrapBrick:()=>m,wrapLocalBrick:()=>b});var r=n(5866),i=n(3395),a=n(6171),o=n(381),s=n(687),l=n(8657),c=n(7029),d=n(2484),u=n(
|
|
2
|
-
//# sourceMappingURL=7746.
|
|
1
|
+
"use strict";(self.webpackChunk_next_bricks_nav=self.webpackChunk_next_bricks_nav||[]).push([[7746],{7029:(e,t,n)=>{var r=n(2484);t.s=r.createRoot,r.hydrateRoot},5863:(e,t,n)=>{function r(e,t){if(t.has(e))throw new TypeError("Cannot initialize the same private elements twice on an object")}n.d(t,{Z:()=>r})},175:(e,t,n)=>{function r(e,t,n){if(!t.has(e))throw new TypeError("attempted to "+n+" private field on non-instance");return t.get(e)}n.d(t,{Z:()=>r})},687:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(175);function i(e,t){return function(e,t){return t.get?t.get.call(e):t.value}(e,(0,r.Z)(e,t,"get"))}},3395:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(5863);function i(e,t,n){(0,r.Z)(e,t),t.set(e,n)}},381:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(175);function i(e,t,n){return function(e,t,n){if(t.set)t.set.call(e,n);else{if(!t.writable)throw new TypeError("attempted to set read only private field");t.value=n}}(e,(0,r.Z)(e,t,"set"),n),n}},6171:(e,t,n)=>{function r(e,t,n){if(!t.has(e))throw new TypeError("attempted to get private field on non-instance");return n}n.d(t,{Z:()=>r})},5866:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(5863);function i(e,t){(0,r.Z)(e,t),t.add(e)}},9740:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(1461);function i(e,t){if(null==e)return{};var n,i,a=(0,r.Z)(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(i=0;i<o.length;i++)n=o[i],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}},1461:(e,t,n)=>{function r(e,t){if(null==e)return{};var n,r,i={},a=Object.keys(e);for(r=0;r<a.length;r++)n=a[r],t.indexOf(n)>=0||(i[n]=e[n]);return i}n.d(t,{Z:()=>r})},1646:(e,t,n)=>{n.r(t),n.d(t,{ReactNextElement:()=>p,wrapBrick:()=>m,wrapLocalBrick:()=>b});var r=n(5866),i=n(3395),a=n(6171),o=n(381),s=n(687),l=n(8657),c=n(7029),d=n(2484),u=n(1218),h=new WeakMap,f=new WeakSet;class p extends u.NextElement{constructor(){super(...arguments),(0,r.Z)(this,f),(0,i.Z)(this,h,{writable:!0,value:void 0})}connectedCallback(){super._markConnectedCallbackCalled(),(0,a.Z)(this,f,v).call(this),this._render()}disconnectedCallback(){var e;null===(e=(0,s.Z)(this,h))||void 0===e||e.render(null)}_render(){var e=()=>{if(this.isConnected&&(0,s.Z)(this,h)){var e,t=this.constructor;t.shadowOptions?(0,s.Z)(this,h).render((0,u.supportsAdoptingStyleSheets)()||null===(e=t.styleTexts)||void 0===e||!e.length?this.render():l.createElement(l.Fragment,null,l.createElement("style",null,t.styleTexts.join("\n")),this.render())):(0,s.Z)(this,h).render(this.render())}};window.BRICK_NEXT_VERSIONS&&!window.DISABLE_REACT_FLUSH_SYNC?(0,d.flushSync)(e):e()}}function v(){if(!(0,s.Z)(this,h)){var e=this.constructor;if(e.shadowOptions){var t,n=this.attachShadow(e.shadowOptions);if((0,u.supportsAdoptingStyleSheets)()&&null!==(t=e.styleTexts)&&void 0!==t&&t.length){var r=new CSSStyleSheet;r.replaceSync(e.styleTexts.join("")),n.adoptedStyleSheets=[r]}(0,o.Z)(this,h,(0,c.s)(n))}else(0,o.Z)(this,h,(0,c.s)(this))}}var w=n(7896),Z=n(9740),y=["children"],S=["children"];function b(e,t){return(0,l.forwardRef)((function(n,r){var{children:i}=n,a=(0,Z.Z)(n,y),o="string"==typeof e?e:e.__tagName,s=g(a,t);return l.createElement(o,(0,w.Z)({},s,{ref:r}),i)}))}function m(e,t){return(0,l.forwardRef)((function(n,r){var{children:i}=n,a=g((0,Z.Z)(n,S),t);return l.createElement(e,(0,w.Z)({},a,{ref:r}),i)}))}function g(e,t){var n;if(t)for(var[r,i]of(n={},Object.entries(e)))Object.prototype.hasOwnProperty.call(t,r)?n["on".concat(t[r])]=i:n[r]=i;else n=e;return n}}}]);
|
|
2
|
+
//# sourceMappingURL=7746.c6b6602c.js.map
|