tntd 2.5.8 → 2.5.9

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.
Files changed (257) hide show
  1. package/es/ellipsis/Svg/CopySVG.js +7 -7
  2. package/es/ellipsis/Svg/CopySVG.js.map +1 -1
  3. package/es/ellipsis/Svg/TickSVG.js +7 -7
  4. package/es/ellipsis/Svg/TickSVG.js.map +1 -1
  5. package/es/ellipsis/index.js +1 -1
  6. package/es/ellipsis/index.js.map +1 -1
  7. package/es/ellipsis/index.less +9 -0
  8. package/es/index.js +2 -2
  9. package/es/index.js.map +1 -1
  10. package/es/input/index.js +3 -2
  11. package/es/input/index.js.map +1 -1
  12. package/es/input/input.js +97 -0
  13. package/es/input/input.js.map +1 -0
  14. package/es/input/input.less +39 -0
  15. package/es/label/index.js +140 -0
  16. package/es/label/index.js.map +1 -0
  17. package/es/label/label.less +60 -0
  18. package/es/query-form/index.js.map +1 -1
  19. package/es/query-list-scene/List.js +3 -1
  20. package/es/query-list-scene/List.js.map +1 -1
  21. package/es/select/index.js +2 -1
  22. package/es/select/index.js.map +1 -1
  23. package/es/select/select.js +31 -0
  24. package/es/select/select.js.map +1 -0
  25. package/es/select/select.less +11 -0
  26. package/es/table/table.js +8 -4
  27. package/es/table/table.js.map +1 -1
  28. package/es/table/table.less +24 -5
  29. package/es/tag/index.js +1 -139
  30. package/es/tag/index.js.map +1 -1
  31. package/es/tntd-form/TntdForm/components/ItemComp.js +2 -2
  32. package/es/tntd-form/TntdForm/components/ItemComp.js.map +1 -1
  33. package/lib/affix/index.js.map +1 -1
  34. package/lib/alert/index.js.map +1 -1
  35. package/lib/anchor/index.js.map +1 -1
  36. package/lib/array-input/index.js.map +1 -1
  37. package/lib/auto-complete/index.js.map +1 -1
  38. package/lib/avatar/index.js.map +1 -1
  39. package/lib/back-top/index.js.map +1 -1
  40. package/lib/badge/index.js.map +1 -1
  41. package/lib/breadcrumb/index.js.map +1 -1
  42. package/lib/button/index.js.map +1 -1
  43. package/lib/calendar/index.js.map +1 -1
  44. package/lib/card/index.js.map +1 -1
  45. package/lib/carousel/index.js.map +1 -1
  46. package/lib/cascader/index.js.map +1 -1
  47. package/lib/checkbox/index.js.map +1 -1
  48. package/lib/col/index.js.map +1 -1
  49. package/lib/collapse/index.js.map +1 -1
  50. package/lib/color-picker/ColorPicker.js.map +1 -1
  51. package/lib/comment/index.js.map +1 -1
  52. package/lib/config-provider/index.js.map +1 -1
  53. package/lib/date-picker/index.js.map +1 -1
  54. package/lib/descriptions/descriptions.js.map +1 -1
  55. package/lib/descriptions/index.js.map +1 -1
  56. package/lib/development-login/LoginModal.js.map +1 -1
  57. package/lib/development-login/index.js.map +1 -1
  58. package/lib/divider/index.js.map +1 -1
  59. package/lib/drawer/index.js.map +1 -1
  60. package/lib/dropdown/index.js.map +1 -1
  61. package/lib/ellipsis/Svg/CopySVG.js +7 -7
  62. package/lib/ellipsis/Svg/CopySVG.js.map +1 -1
  63. package/lib/ellipsis/Svg/TickSVG.js +7 -7
  64. package/lib/ellipsis/Svg/TickSVG.js.map +1 -1
  65. package/lib/ellipsis/index.js +1 -1
  66. package/lib/ellipsis/index.js.map +1 -1
  67. package/lib/ellipsis/index.less +9 -0
  68. package/lib/empty/empty.js.map +1 -1
  69. package/lib/empty/index.js.map +1 -1
  70. package/lib/exception/index.js.map +1 -1
  71. package/lib/form/index.js.map +1 -1
  72. package/lib/handle/index.js.map +1 -1
  73. package/lib/icon/index.js.map +1 -1
  74. package/lib/img/index.js.map +1 -1
  75. package/lib/index.d.ts +1 -1
  76. package/lib/index.d.ts.map +1 -1
  77. package/lib/index.js +7 -7
  78. package/lib/index.js.map +1 -1
  79. package/lib/input/index.d.ts +3 -2
  80. package/lib/input/index.d.ts.map +1 -1
  81. package/lib/input/index.js +7 -9
  82. package/lib/input/index.js.map +1 -1
  83. package/lib/input/input.d.ts +25 -0
  84. package/lib/input/input.d.ts.map +1 -0
  85. package/lib/input/input.js +86 -0
  86. package/lib/input/input.js.map +1 -0
  87. package/lib/input/input.less +39 -0
  88. package/lib/input-number/index.js.map +1 -1
  89. package/lib/label/index.d.ts +52 -0
  90. package/lib/label/index.d.ts.map +1 -0
  91. package/lib/label/index.js +150 -0
  92. package/lib/label/index.js.map +1 -0
  93. package/lib/label/label.less +60 -0
  94. package/lib/layout/index.js.map +1 -1
  95. package/lib/list/index.js.map +1 -1
  96. package/lib/loading-button/index.js.map +1 -1
  97. package/lib/locale/index.js.map +1 -1
  98. package/lib/locale-provider/index.js.map +1 -1
  99. package/lib/mentions/index.js.map +1 -1
  100. package/lib/menu/index.js.map +1 -1
  101. package/lib/message/index.js.map +1 -1
  102. package/lib/modal/index.js.map +1 -1
  103. package/lib/modal/modal.js.map +1 -1
  104. package/lib/notification/index.js.map +1 -1
  105. package/lib/page-header/index.js.map +1 -1
  106. package/lib/pagination/index.js.map +1 -1
  107. package/lib/popconfirm/index.js.map +1 -1
  108. package/lib/popover/index.js.map +1 -1
  109. package/lib/progress/index.js.map +1 -1
  110. package/lib/query-form/Field/Select.js.map +1 -1
  111. package/lib/query-form/Field/SelectInput.js.map +1 -1
  112. package/lib/query-form/Field/fieldsMap.d.ts +1 -1
  113. package/lib/query-form/Field/index.d.ts +0 -6
  114. package/lib/query-form/Field/index.d.ts.map +1 -1
  115. package/lib/query-form/Field/index.js.map +1 -1
  116. package/lib/query-form/index.d.ts +0 -9
  117. package/lib/query-form/index.d.ts.map +1 -1
  118. package/lib/query-form/index.js.map +1 -1
  119. package/lib/query-list-scene/List.d.ts +0 -13
  120. package/lib/query-list-scene/List.d.ts.map +1 -1
  121. package/lib/query-list-scene/List.js +3 -1
  122. package/lib/query-list-scene/List.js.map +1 -1
  123. package/lib/query-list-scene/QueryForm.d.ts +0 -3
  124. package/lib/query-list-scene/QueryForm.d.ts.map +1 -1
  125. package/lib/query-list-scene/QueryListScene.d.ts +0 -1
  126. package/lib/query-list-scene/QueryListScene.d.ts.map +1 -1
  127. package/lib/radio/index.js.map +1 -1
  128. package/lib/rate/index.js.map +1 -1
  129. package/lib/result/index.js.map +1 -1
  130. package/lib/row/index.js.map +1 -1
  131. package/lib/select/index.d.ts +2 -1
  132. package/lib/select/index.d.ts.map +1 -1
  133. package/lib/select/index.js +8 -9
  134. package/lib/select/index.js.map +1 -1
  135. package/lib/select/select.d.ts +12 -0
  136. package/lib/select/select.d.ts.map +1 -0
  137. package/lib/select/select.js +40 -0
  138. package/lib/select/select.js.map +1 -0
  139. package/lib/select/select.less +11 -0
  140. package/lib/skeleton/index.js.map +1 -1
  141. package/lib/slider/index.js.map +1 -1
  142. package/lib/spin/index.js.map +1 -1
  143. package/lib/statistic/index.js.map +1 -1
  144. package/lib/steps/index.js.map +1 -1
  145. package/lib/steps/steps.js.map +1 -1
  146. package/lib/svg-components/illustration-403.d.ts +1 -1
  147. package/lib/svg-components/illustration-403.js.map +1 -1
  148. package/lib/svg-components/illustration-404.d.ts +1 -1
  149. package/lib/svg-components/illustration-404.js.map +1 -1
  150. package/lib/svg-components/illustration-500.d.ts +1 -1
  151. package/lib/svg-components/illustration-500.js.map +1 -1
  152. package/lib/svg-components/illustration-empty.d.ts +1 -1
  153. package/lib/svg-components/illustration-empty.js.map +1 -1
  154. package/lib/svg-components/illustration-failure.d.ts +1 -1
  155. package/lib/svg-components/illustration-failure.js.map +1 -1
  156. package/lib/svg-components/illustration-no-access.d.ts +1 -1
  157. package/lib/svg-components/illustration-no-access.js.map +1 -1
  158. package/lib/svg-components/illustration-no-chart.d.ts +1 -1
  159. package/lib/svg-components/illustration-no-chart.js.map +1 -1
  160. package/lib/svg-components/illustration-no-result.d.ts +1 -1
  161. package/lib/svg-components/illustration-no-result.js.map +1 -1
  162. package/lib/svg-components/illustration-offline.d.ts +1 -1
  163. package/lib/svg-components/illustration-offline.js.map +1 -1
  164. package/lib/svg-components/illustration-success.d.ts +1 -1
  165. package/lib/svg-components/illustration-success.js.map +1 -1
  166. package/lib/switch/index.js.map +1 -1
  167. package/lib/table/assets/image-loading-background.d.ts +1 -1
  168. package/lib/table/assets/image-loading-background.js.map +1 -1
  169. package/lib/table/assets/image-loading.d.ts +1 -1
  170. package/lib/table/assets/image-loading.js.map +1 -1
  171. package/lib/table/hooks/index.js.map +1 -1
  172. package/lib/table/index.js.map +1 -1
  173. package/lib/table/table.d.ts +3 -1
  174. package/lib/table/table.d.ts.map +1 -1
  175. package/lib/table/table.js +7 -3
  176. package/lib/table/table.js.map +1 -1
  177. package/lib/table/table.less +24 -5
  178. package/lib/tabs/index.js.map +1 -1
  179. package/lib/tag/index.d.ts +1 -50
  180. package/lib/tag/index.d.ts.map +1 -1
  181. package/lib/tag/index.js +4 -145
  182. package/lib/tag/index.js.map +1 -1
  183. package/lib/time-picker/index.js.map +1 -1
  184. package/lib/timeline/index.js.map +1 -1
  185. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js.map +1 -1
  186. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js.map +1 -1
  187. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js.map +1 -1
  188. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  189. package/lib/tntd-cascader/AntdCascader/component/getIcons.js.map +1 -1
  190. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js.map +1 -1
  191. package/lib/tntd-cascader/AntdCascader/config/warning.js.map +1 -1
  192. package/lib/tntd-cascader/AntdCascader/index.js.map +1 -1
  193. package/lib/tntd-cascader/rc-cascader/Cascader.js.map +1 -1
  194. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js.map +1 -1
  195. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js.map +1 -1
  196. package/lib/tntd-cascader/rc-cascader/OptionList/index.js.map +1 -1
  197. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js.map +1 -1
  198. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js.map +1 -1
  199. package/lib/tntd-cascader/rc-cascader/context.js.map +1 -1
  200. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js.map +1 -1
  201. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js.map +1 -1
  202. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js.map +1 -1
  203. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js.map +1 -1
  204. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js.map +1 -1
  205. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js.map +1 -1
  206. package/lib/tntd-form/TntdForm/components/Item.js.map +1 -1
  207. package/lib/tntd-form/TntdForm/components/ItemComp.js +2 -2
  208. package/lib/tntd-form/TntdForm/components/ItemComp.js.map +1 -1
  209. package/lib/tntd-form/TntdForm/components/List.js.map +1 -1
  210. package/lib/tntd-form/TntdForm/index.js.map +1 -1
  211. package/lib/tntd-layout/AppList.js.map +1 -1
  212. package/lib/tntd-layout/Application.js.map +1 -1
  213. package/lib/tntd-layout/Avatar.js.map +1 -1
  214. package/lib/tntd-layout/CompatibleLanguage.js.map +1 -1
  215. package/lib/tntd-layout/EnterpriseLayout/Avatar.js.map +1 -1
  216. package/lib/tntd-layout/EnterpriseLayout/Language.js.map +1 -1
  217. package/lib/tntd-layout/EnterpriseLayout/Theme.js.map +1 -1
  218. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js.map +1 -1
  219. package/lib/tntd-layout/GlobalNavigation/index.js.map +1 -1
  220. package/lib/tntd-layout/Header.js.map +1 -1
  221. package/lib/tntd-layout/HeaderActions.js.map +1 -1
  222. package/lib/tntd-layout/HeaderNavs.js.map +1 -1
  223. package/lib/tntd-layout/HeaderTabs.js.map +1 -1
  224. package/lib/tntd-layout/Language.js.map +1 -1
  225. package/lib/tntd-layout/Layout.js.map +1 -1
  226. package/lib/tntd-layout/Logo.js.map +1 -1
  227. package/lib/tntd-layout/OrgAppList.js.map +1 -1
  228. package/lib/tntd-layout/SideMenu.js.map +1 -1
  229. package/lib/tntd-layout/Theme.js.map +1 -1
  230. package/lib/tntd-layout/index.js.map +1 -1
  231. package/lib/tntd-layout/paaslayout/CompactSideMenu.js.map +1 -1
  232. package/lib/tntd-layout/paaslayout/Header.js.map +1 -1
  233. package/lib/tntd-layout/paaslayout/SideMenu.js.map +1 -1
  234. package/lib/tntd-layout/paaslayout/index.js.map +1 -1
  235. package/lib/tntd-modal/index.js.map +1 -1
  236. package/lib/tntd-select/DropDownWrap.d.ts +0 -10
  237. package/lib/tntd-select/DropDownWrap.d.ts.map +1 -1
  238. package/lib/tntd-select/DropDownWrap.js.map +1 -1
  239. package/lib/tntd-select/index.d.ts +1 -13
  240. package/lib/tntd-select/index.d.ts.map +1 -1
  241. package/lib/tntd-select/index.js.map +1 -1
  242. package/lib/tooltip/index.js.map +1 -1
  243. package/lib/transfer/index.js.map +1 -1
  244. package/lib/tree/index.js.map +1 -1
  245. package/lib/tree-select/index.js.map +1 -1
  246. package/lib/typography/index.js.map +1 -1
  247. package/lib/upload/index.js.map +1 -1
  248. package/lib/utils/index.js.map +1 -1
  249. package/lib/version/index.js.map +1 -1
  250. package/package.json +7 -10
  251. package/themes/default/variables.less +2 -2
  252. package/codemod/__testfixtures__/v1-to-v2-react.input.js +0 -24
  253. package/codemod/__testfixtures__/v1-to-v2-react.output.js +0 -23
  254. package/codemod/__testfixtures__/v1-to-v2.input.js +0 -2
  255. package/codemod/__testfixtures__/v1-to-v2.output.js +0 -2
  256. package/codemod/__tests__/v1-to-v2-test.js +0 -4
  257. package/codemod/v1-to-v2.js +0 -96
@@ -1 +1 @@
1
- {"version":3,"file":"Avatar.js","sourceRoot":"","sources":["../../../src/tntd-layout/EnterpriseLayout/Avatar.js"],"names":[],"mappings":"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","sourcesContent":["import { get } from 'lodash'\nimport React, { useContext } from 'react'\nimport styled, { createGlobalStyle } from 'styled-components'\nimport images from '../images'\nimport ActionsContext from '../ActionsContext'\nimport Language from './Language'\nimport Theme from './Theme'\nimport { getLanguageStore, clearLoginCookie } from '../storage'\nimport Divider from '../../divider'\nimport Popover from '../../popover'\nimport Row from '../../row'\n\nconst Avatar = styled.li`\n margin-right: 0;\n font-size: 0;\n img {\n width: 26px;\n height: 26px;\n border-radius: 50%;\n cursor: pointer;\n .large-size & {\n width: 32px;\n height: 32px;\n }\n }\n`\n\nconst GlobalStyle = createGlobalStyle`\n .tnt-layout-personal-popover {\n .ant-popover-inner-content {\n padding: 0;\n }\n }\n`\n\nconst UserInfoWrapper = styled.div`\n width: 330px;\n z-index: 1;\n background-color: #fff;\n border-radius: 4px;\n box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.1);\n .isInIframe & {\n display: none;\n }\n\n .user-info-body {\n padding: 20px 15px;\n line-height: 16px;\n list-style: none;\n margin: 0;\n .user-info-body-username {\n margin-top: 0px;\n font-family: PingFangSC-Regular;\n font-weight: normal;\n font-size: 14px;\n color: ${(props) => `${props.theme.primaryTextColor}`};\n line-height: 14px;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .user-info-body-account {\n margin-top: 0px;\n font-family: PingFangSC-Regular;\n font-size: 12px;\n color: #8b919e;\n margin-bottom: 14px;\n line-height: 14px;\n margin-left: 10px;\n }\n }\n .user-info-footer {\n border-top: ${(props) => `1px solid ${props.theme.dividerColor}`};\n background-color: #fff;\n height: 36px;\n line-height: 36px;\n padding: 0 15px;\n font-size: 12px;\n color: ${(props) => `${props.theme.primaryColor}`};\n a {\n flex: 1;\n text-align: center;\n color: ${(props) => `${props.theme.primaryColor}`};\n }\n }\n`\n\nconst UserInfoContent = (props) => {\n const {\n userInfo,\n config = {},\n onLogout,\n onChangePassword = () => true,\n onPersonalSetting = () => true,\n onLanguageChange,\n onThemeChange,\n } = props\n const { getText } = useContext(ActionsContext)\n const { language = true } = config || {}\n return (\n <UserInfoWrapper className=\"user-info-setting-wrap\">\n <ul className=\"user-info-body\">\n <li className=\"user-info-body-username\">\n {userInfo.userName || getText('nameNull')}\n <span className=\"user-info-body-account\">{userInfo.account}</span>\n </li>\n {language && <Language language={userInfo.lang} onChange={onLanguageChange} />}\n <Theme theme={userInfo.theme} onChange={onThemeChange} />\n </ul>\n <Row className=\"user-info-footer\" type=\"flex\" justify=\"space-between\" align=\"middle\">\n <a onClick={onPersonalSetting} href=\"/bridge/userCenter?currentTab=1\">\n {getText('personalSettings')}\n </a>\n <Divider type=\"vertical\" />\n <a\n onClick={onChangePassword}\n href=\"/bridge/userCenter?currentTab=2\"\n style={getLanguageStore() === 'en' ? { flex: 2 } : {}}\n >\n {getText('changePwd')}\n </a>\n <Divider type=\"vertical\" />\n <a\n className=\"user-info-footer-signout\"\n onClick={() => {\n if (onLogout) {\n onLogout()\n clearLoginCookie()\n } else {\n clearLoginCookie()\n window.location.href = `/user/login?callbackUrl=${window.encodeURI(location.href)}`\n }\n }}\n >\n {getText('signOut')}\n </a>\n </Row>\n </UserInfoWrapper>\n )\n}\n\nexport default (props) => {\n const { userInfo = {} } = props\n const { avatar } = userInfo\n\n return (\n <Avatar>\n <Popover\n popupClassName=\"tnt-layout-personal-popover\"\n placement=\"bottomRight\"\n title={null}\n content={<UserInfoContent {...props} />}\n trigger=\"click\"\n >\n {avatar ? (\n <img\n src={\n avatar.indexOf('base64') > 0 ? avatar : get(images[avatar], 'default', images[avatar])\n }\n onError={(e) => {\n e.target.onerror = null\n e.target.src = images.empty?.default || images.empty\n }}\n />\n ) : (\n <img src={images.empty?.default || images.empty} />\n )}\n </Popover>\n <GlobalStyle />\n </Avatar>\n )\n}\n"]}
1
+ {"version":3,"file":"Avatar.js","sourceRoot":"","sources":["../../../src/tntd-layout/EnterpriseLayout/Avatar.js"],"names":[],"mappings":"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","sourcesContent":["import { get } from 'lodash'\nimport React, { useContext } from 'react'\nimport styled, { createGlobalStyle } from 'styled-components'\nimport images from '../images'\nimport ActionsContext from '../ActionsContext'\nimport Language from './Language'\nimport Theme from './Theme'\nimport { getLanguageStore, clearLoginCookie } from '../storage'\nimport Divider from '../../divider'\nimport Popover from '../../popover'\nimport Row from '../../row'\n\nconst Avatar = styled.li`\n margin-right: 0;\n font-size: 0;\n img {\n width: 26px;\n height: 26px;\n border-radius: 50%;\n cursor: pointer;\n .large-size & {\n width: 32px;\n height: 32px;\n }\n }\n`\n\nconst GlobalStyle = createGlobalStyle`\n .tnt-layout-personal-popover {\n .ant-popover-inner-content {\n padding: 0;\n }\n }\n`\n\nconst UserInfoWrapper = styled.div`\n width: 330px;\n z-index: 1;\n background-color: #fff;\n border-radius: 4px;\n box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.1);\n .isInIframe & {\n display: none;\n }\n\n .user-info-body {\n padding: 20px 15px;\n line-height: 16px;\n list-style: none;\n margin: 0;\n .user-info-body-username {\n margin-top: 0px;\n font-family: PingFangSC-Regular;\n font-weight: normal;\n font-size: 14px;\n color: ${(props) => `${props.theme.primaryTextColor}`};\n line-height: 14px;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .user-info-body-account {\n margin-top: 0px;\n font-family: PingFangSC-Regular;\n font-size: 12px;\n color: #8b919e;\n margin-bottom: 14px;\n line-height: 14px;\n margin-left: 10px;\n }\n }\n .user-info-footer {\n border-top: ${(props) => `1px solid ${props.theme.dividerColor}`};\n background-color: #fff;\n height: 36px;\n line-height: 36px;\n padding: 0 15px;\n font-size: 12px;\n color: ${(props) => `${props.theme.primaryColor}`};\n a {\n flex: 1;\n text-align: center;\n color: ${(props) => `${props.theme.primaryColor}`};\n }\n }\n`\n\nconst UserInfoContent = (props) => {\n const {\n userInfo,\n config = {},\n onLogout,\n onChangePassword = () => true,\n onPersonalSetting = () => true,\n onLanguageChange,\n onThemeChange,\n } = props\n const { getText } = useContext(ActionsContext)\n const { language = true } = config || {}\n return (\n <UserInfoWrapper className=\"user-info-setting-wrap\">\n <ul className=\"user-info-body\">\n <li className=\"user-info-body-username\">\n {userInfo.userName || getText('nameNull')}\n <span className=\"user-info-body-account\">{userInfo.account}</span>\n </li>\n {language && <Language language={userInfo.lang} onChange={onLanguageChange} />}\n <Theme theme={userInfo.theme} onChange={onThemeChange} />\n </ul>\n <Row className=\"user-info-footer\" type=\"flex\" justify=\"space-between\" align=\"middle\">\n <a onClick={onPersonalSetting} href=\"/bridge/userCenter?currentTab=1\">\n {getText('personalSettings')}\n </a>\n <Divider type=\"vertical\" />\n <a\n onClick={onChangePassword}\n href=\"/bridge/userCenter?currentTab=2\"\n style={getLanguageStore() === 'en' ? { flex: 2 } : {}}\n >\n {getText('changePwd')}\n </a>\n <Divider type=\"vertical\" />\n <a\n className=\"user-info-footer-signout\"\n onClick={() => {\n if (onLogout) {\n onLogout()\n clearLoginCookie()\n } else {\n clearLoginCookie()\n window.location.href = `/user/login?callbackUrl=${window.encodeURI(location.href)}`\n }\n }}\n >\n {getText('signOut')}\n </a>\n </Row>\n </UserInfoWrapper>\n )\n}\n\nexport default (props) => {\n const { userInfo = {} } = props\n const { avatar } = userInfo\n\n return (\n <Avatar>\n <Popover\n popupClassName=\"tnt-layout-personal-popover\"\n placement=\"bottomRight\"\n title={null}\n content={<UserInfoContent {...props} />}\n trigger=\"click\"\n >\n {avatar ? (\n <img\n src={\n avatar.indexOf('base64') > 0 ? avatar : get(images[avatar], 'default', images[avatar])\n }\n onError={(e) => {\n e.target.onerror = null\n e.target.src = images.empty?.default || images.empty\n }}\n />\n ) : (\n <img src={images.empty?.default || images.empty} />\n )}\n </Popover>\n <GlobalStyle />\n </Avatar>\n )\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Language.js","sourceRoot":"","sources":["../../../src/tntd-layout/EnterpriseLayout/Language.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAgD;AAChD,uEAAqD;AACrD,mCAA4B;AAC5B,2DAAkC;AAClC,wCAA+D;AAE/D,MAAM,SAAS,GAAG;IAChB,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE;IAC3B,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE;CAC7B,CAAA;AACD,MAAM,YAAY,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;IACjD,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,CAAA;IACpB,OAAO,GAAG,CAAA;AACZ,CAAC,EAAE,EAAE,CAAC,CAAA;AAEN,MAAM,QAAQ,GAAG,2BAAM,CAAC,EAAE,CAAA;;;;;;;;;;;eAWX,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;iBAK3D,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;;iBAM7D,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;WACnE,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;;;CAOvE,CAAA;AAED,kBAAe,IAAA,6BAAS,EAAC,CAAC,KAAK,EAAE,EAAE;IACjC,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAA;IAC1B,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,IAAI,IAAI,GAAG,IAAA,0BAAgB,GAAE,IAAI,KAAK,CAAC,QAAQ,CAAA;QAE/C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;YACvB,IAAI,GAAG,IAAA,YAAG,EAAC,SAAS,EAAE,SAAS,CAAC,CAAA;SACjC;QAED,OAAO,IAAI,CAAA;IACb,CAAC,CAAA;IACD,MAAM,CAAC,QAAQ,GAAG,IAAI,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,WAAW,EAAE,CAAC,CAAA;IAC9D,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,MAAM,IAAI,GAAG,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;QAE5C,WAAW,CAAC,IAAI,CAAC,CAAA;QACjB,IAAA,0BAAgB,EAAC,IAAI,CAAC,CAAA;QACtB,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAA;IAC5B,CAAC,CAAA;IAEH,MAAM,aAAa,GAAG,IAAA,eAAO,EAAC,GAAE,EAAE,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;IAE7E,OAAO,CACL,8BAAC,QAAQ,IAAC,OAAO,EAAE,cAAc;QAC/B,8BAAC,kBAAQ,IAAC,IAAI,EAAE,QAAQ,aAAa,EAAE,GAAI;QAC3C,4CAAO,IAAA,YAAG,EAAC,YAAY,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC,CAAQ,CAC9C,CACZ,CAAA;AACH,CAAC,CAAC,CAAA","sourcesContent":["import React, { useState, useMemo } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport { get } from 'lodash'\nimport Iconfont from '../Iconfont'\nimport { setLanguageStore, getLanguageStore } from '../storage'\n\nconst languages = [\n { value: 'cn', name: '中文' },\n { value: 'en', name: 'EN ' },\n]\nconst languagesMap = languages.reduce((acc, cur) => {\n acc[cur.value] = cur\n return acc\n}, {})\n\nconst Language = styled.li`\n display: inline-block;\n padding: 0 10px;\n height: 32px;\n line-height: 32px;\n text-align: center;\n background: #ffffff;\n border: 1px solid #e1e6ee;\n border-radius: 2px;\n font-family: PingFangSC-Regular;\n color: #17233d;\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n cursor: pointer;\n margin-top: 8px;\n\n .tnt-icon {\n font-size: ${({ theme: { size } }) => (size === 'large' ? '24px' : '20px')};\n margin-right: 4px;\n }\n\n span {\n position: relative;\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n top: ${({ theme: { size } }) => (size === 'large' ? '-3px' : '-2px')};\n font-family: auto;\n }\n\n .isInIframe & {\n display: none;\n }\n`\n\nexport default withTheme((props) => {\n const { onChange } = props\n const getLanguage = () => {\n let lang = getLanguageStore() || props.language\n\n if (!languagesMap[lang]) {\n lang = get(languages, '0.value')\n }\n\n return lang\n }\n const [language = 'cn', setLanguage] = useState(getLanguage())\n const switchLanguage = () => {\n const lang = language !== 'en' ? 'en' : 'cn'\n\n setLanguage(lang)\n setLanguageStore(lang)\n onChange && onChange(lang)\n }\n\nconst otherLanguage = useMemo(()=> language === 'cn' ? 'en' : 'cn',[language]);\n\n return (\n <Language onClick={switchLanguage}>\n <Iconfont type={`flag-${otherLanguage}`} />\n <span>{get(languagesMap[otherLanguage], 'name')}</span>\n </Language>\n )\n})\n"]}
1
+ {"version":3,"file":"Language.js","sourceRoot":"","sources":["../../../src/tntd-layout/EnterpriseLayout/Language.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAgD;AAChD,uEAAqD;AACrD,mCAA4B;AAC5B,2DAAkC;AAClC,wCAA+D;AAE/D,MAAM,SAAS,GAAG;IAChB,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE;IAC3B,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE;CAC7B,CAAA;AACD,MAAM,YAAY,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;IACjD,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,CAAA;IACpB,OAAO,GAAG,CAAA;AACZ,CAAC,EAAE,EAAE,CAAC,CAAA;AAEN,MAAM,QAAQ,GAAG,2BAAM,CAAC,EAAE,CAAA;;;;;;;;;;;eAWX,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;iBAK3D,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;;iBAM7D,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;WACnE,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;;;CAOvE,CAAA;AAED,kBAAe,IAAA,6BAAS,EAAC,CAAC,KAAK,EAAE,EAAE;IACjC,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAA;IAC1B,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,IAAI,IAAI,GAAG,IAAA,0BAAgB,GAAE,IAAI,KAAK,CAAC,QAAQ,CAAA;QAE/C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;YACvB,IAAI,GAAG,IAAA,YAAG,EAAC,SAAS,EAAE,SAAS,CAAC,CAAA;SACjC;QAED,OAAO,IAAI,CAAA;IACb,CAAC,CAAA;IACD,MAAM,CAAC,QAAQ,GAAG,IAAI,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,WAAW,EAAE,CAAC,CAAA;IAC9D,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,MAAM,IAAI,GAAG,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;QAE5C,WAAW,CAAC,IAAI,CAAC,CAAA;QACjB,IAAA,0BAAgB,EAAC,IAAI,CAAC,CAAA;QACtB,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAA;IAC5B,CAAC,CAAA;IAEH,MAAM,aAAa,GAAG,IAAA,eAAO,EAAC,GAAE,EAAE,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;IAE7E,OAAO,CACL,8BAAC,QAAQ,IAAC,OAAO,EAAE,cAAc;QAC/B,8BAAC,kBAAQ,IAAC,IAAI,EAAE,QAAQ,aAAa,EAAE,GAAI;QAC3C,4CAAO,IAAA,YAAG,EAAC,YAAY,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC,CAAQ,CAC9C,CACZ,CAAA;AACH,CAAC,CAAC,CAAA","sourcesContent":["import React, { useState, useMemo } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport { get } from 'lodash'\nimport Iconfont from '../Iconfont'\nimport { setLanguageStore, getLanguageStore } from '../storage'\n\nconst languages = [\n { value: 'cn', name: '中文' },\n { value: 'en', name: 'EN ' },\n]\nconst languagesMap = languages.reduce((acc, cur) => {\n acc[cur.value] = cur\n return acc\n}, {})\n\nconst Language = styled.li`\n display: inline-block;\n padding: 0 10px;\n height: 32px;\n line-height: 32px;\n text-align: center;\n background: #ffffff;\n border: 1px solid #e1e6ee;\n border-radius: 2px;\n font-family: PingFangSC-Regular;\n color: #17233d;\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n cursor: pointer;\n margin-top: 8px;\n\n .tnt-icon {\n font-size: ${({ theme: { size } }) => (size === 'large' ? '24px' : '20px')};\n margin-right: 4px;\n }\n\n span {\n position: relative;\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n top: ${({ theme: { size } }) => (size === 'large' ? '-3px' : '-2px')};\n font-family: auto;\n }\n\n .isInIframe & {\n display: none;\n }\n`\n\nexport default withTheme((props) => {\n const { onChange } = props\n const getLanguage = () => {\n let lang = getLanguageStore() || props.language\n\n if (!languagesMap[lang]) {\n lang = get(languages, '0.value')\n }\n\n return lang\n }\n const [language = 'cn', setLanguage] = useState(getLanguage())\n const switchLanguage = () => {\n const lang = language !== 'en' ? 'en' : 'cn'\n\n setLanguage(lang)\n setLanguageStore(lang)\n onChange && onChange(lang)\n }\n\nconst otherLanguage = useMemo(()=> language === 'cn' ? 'en' : 'cn',[language]);\n\n return (\n <Language onClick={switchLanguage}>\n <Iconfont type={`flag-${otherLanguage}`} />\n <span>{get(languagesMap[otherLanguage], 'name')}</span>\n </Language>\n )\n})\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Theme.js","sourceRoot":"","sources":["../../../src/tntd-layout/EnterpriseLayout/Theme.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAuC;AACvC,0EAAsC;AACtC,wCAA2E;AAC3E,oDAA2B;AAC3B,2BAAsC;AAEtC,MAAM,KAAK,GAAG,2BAAM,CAAC,EAAE,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiDtB,CAAA;AAED,MAAM,MAAM,GAAG;IACb,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE;IACnD,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE;IACpD,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE;CACrD,CAAA;AAED,kBAAe,CAAC,KAAK,EAAE,EAAE;IACvB,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAA;IAE1B,MAAM,QAAQ,GAAG,GAAG,EAAE;QACpB,IAAI,KAAK,GAAG,IAAA,uBAAa,GAAE,IAAI,KAAK,CAAC,KAAK,IAAI,SAAS,CAAA;QACvD,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAA;IACxE,CAAC,CAAA;IAED,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAC,QAAQ,EAAE,CAAC,CAAA;IAC9C,MAAM,WAAW,GAAG,CAAC,KAAK,EAAE,EAAE;QAC5B,QAAQ,CAAC,KAAK,CAAC,CAAA;QACf,IAAA,uBAAa,EAAC,KAAK,CAAC,CAAA;QACpB,QAAQ,CAAC,KAAK,CAAC,CAAA;IACjB,CAAC,CAAA;IAED,OAAO,CACL,8BAAC,KAAK;QACJ,8BAAC,aAAG,IAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,eAAe,EAAC,SAAS,EAAC,0BAA0B,IAC1E,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CACzC,uCAAK,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC;YAC1D,IAAA,0BAAgB,GAAE,KAAK,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK;YAC7C,KAAK,KAAK,KAAK,IAAI,wCAAM,SAAS,EAAC,mBAAmB,GAAQ,CAC3D,CACP,CAAC,CACE,CACA,CACT,CAAA;AACH,CAAC,CAAA","sourcesContent":["import React, { useState } from 'react'\nimport styled from 'styled-components'\nimport { getThemeStore, setThemeStore, getLanguageStore } from '../storage'\nimport Row from '../../row'\nimport Iconfont from '../../tntd-icon'\n\nconst Theme = styled.li`\n margin-top: 20px;\n .user-info-body-theme-row {\n > div {\n width: 90px;\n height: 36px;\n line-height: 36px;\n font-family: PingFangSC-Regular;\n font-size: 12px;\n border-radius: 2px;\n text-align: center;\n cursor: pointer;\n position: relative;\n &.themeS3 {\n background-image: linear-gradient(180deg, #213f83 0%, #0f75d6 100%);\n color: #ffffff;\n }\n &.themeS2 {\n background: #17233d;\n color: #ffffff;\n }\n &.themeS1 {\n background: #ffffff;\n box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.1);\n color: #17233d;\n }\n .icon-checked-wrap {\n width: 14px;\n height: 14px;\n border-radius: 100%;\n background: #126bfb;\n position: absolute;\n top: -5px;\n right: -5px;\n &:after {\n content: '';\n width: 4px;\n height: 6px;\n border-color: #ffffff;\n border-width: 0 1px 1px 0;\n border-style: solid;\n transform: rotate(45deg);\n position: absolute;\n top: 3px;\n left: 5px;\n }\n }\n }\n }\n`\n\nconst themes = [\n { value: 'themeS3', label: '科技蓝', enLabel: 'Blue' },\n { value: 'themeS2', label: '暗夜黑', enLabel: 'Black' },\n { value: 'themeS1', label: '极致白', enLabel: 'White' },\n]\n\nexport default (props) => {\n const { onChange } = props\n\n const getTheme = () => {\n let theme = getThemeStore() || props.theme || 'themeS3'\n return themes.some(({ value }) => value === theme) ? theme : 'themeS3'\n }\n\n const [theme, setTheme] = useState(getTheme())\n const changeTheme = (theme) => {\n setTheme(theme)\n setThemeStore(theme)\n onChange(theme)\n }\n\n return (\n <Theme>\n <Row type=\"flex\" justify=\"space-between\" className=\"user-info-body-theme-row\">\n {themes.map(({ value, label, enLabel }) => (\n <div className={value} onClick={changeTheme.bind(this, value)}>\n {getLanguageStore() === 'en' ? enLabel : label}\n {theme === value && <span className=\"icon-checked-wrap\"></span>}\n </div>\n ))}\n </Row>\n </Theme>\n )\n}\n"]}
1
+ {"version":3,"file":"Theme.js","sourceRoot":"","sources":["../../../src/tntd-layout/EnterpriseLayout/Theme.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAuC;AACvC,0EAAsC;AACtC,wCAA2E;AAC3E,oDAA2B;AAC3B,2BAAsC;AAEtC,MAAM,KAAK,GAAG,2BAAM,CAAC,EAAE,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiDtB,CAAA;AAED,MAAM,MAAM,GAAG;IACb,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE;IACnD,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE;IACpD,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE;CACrD,CAAA;AAED,kBAAe,CAAC,KAAK,EAAE,EAAE;IACvB,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAA;IAE1B,MAAM,QAAQ,GAAG,GAAG,EAAE;QACpB,IAAI,KAAK,GAAG,IAAA,uBAAa,GAAE,IAAI,KAAK,CAAC,KAAK,IAAI,SAAS,CAAA;QACvD,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAA;IACxE,CAAC,CAAA;IAED,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAC,QAAQ,EAAE,CAAC,CAAA;IAC9C,MAAM,WAAW,GAAG,CAAC,KAAK,EAAE,EAAE;QAC5B,QAAQ,CAAC,KAAK,CAAC,CAAA;QACf,IAAA,uBAAa,EAAC,KAAK,CAAC,CAAA;QACpB,QAAQ,CAAC,KAAK,CAAC,CAAA;IACjB,CAAC,CAAA;IAED,OAAO,CACL,8BAAC,KAAK;QACJ,8BAAC,aAAG,IAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,eAAe,EAAC,SAAS,EAAC,0BAA0B,IAC1E,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CACzC,uCAAK,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC;YAC1D,IAAA,0BAAgB,GAAE,KAAK,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK;YAC7C,KAAK,KAAK,KAAK,IAAI,wCAAM,SAAS,EAAC,mBAAmB,GAAQ,CAC3D,CACP,CAAC,CACE,CACA,CACT,CAAA;AACH,CAAC,CAAA","sourcesContent":["import React, { useState } from 'react'\nimport styled from 'styled-components'\nimport { getThemeStore, setThemeStore, getLanguageStore } from '../storage'\nimport Row from '../../row'\nimport Iconfont from '../../tntd-icon'\n\nconst Theme = styled.li`\n margin-top: 20px;\n .user-info-body-theme-row {\n > div {\n width: 90px;\n height: 36px;\n line-height: 36px;\n font-family: PingFangSC-Regular;\n font-size: 12px;\n border-radius: 2px;\n text-align: center;\n cursor: pointer;\n position: relative;\n &.themeS3 {\n background-image: linear-gradient(180deg, #213f83 0%, #0f75d6 100%);\n color: #ffffff;\n }\n &.themeS2 {\n background: #17233d;\n color: #ffffff;\n }\n &.themeS1 {\n background: #ffffff;\n box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.1);\n color: #17233d;\n }\n .icon-checked-wrap {\n width: 14px;\n height: 14px;\n border-radius: 100%;\n background: #126bfb;\n position: absolute;\n top: -5px;\n right: -5px;\n &:after {\n content: '';\n width: 4px;\n height: 6px;\n border-color: #ffffff;\n border-width: 0 1px 1px 0;\n border-style: solid;\n transform: rotate(45deg);\n position: absolute;\n top: 3px;\n left: 5px;\n }\n }\n }\n }\n`\n\nconst themes = [\n { value: 'themeS3', label: '科技蓝', enLabel: 'Blue' },\n { value: 'themeS2', label: '暗夜黑', enLabel: 'Black' },\n { value: 'themeS1', label: '极致白', enLabel: 'White' },\n]\n\nexport default (props) => {\n const { onChange } = props\n\n const getTheme = () => {\n let theme = getThemeStore() || props.theme || 'themeS3'\n return themes.some(({ value }) => value === theme) ? theme : 'themeS3'\n }\n\n const [theme, setTheme] = useState(getTheme())\n const changeTheme = (theme) => {\n setTheme(theme)\n setThemeStore(theme)\n onChange(theme)\n }\n\n return (\n <Theme>\n <Row type=\"flex\" justify=\"space-between\" className=\"user-info-body-theme-row\">\n {themes.map(({ value, label, enLabel }) => (\n <div className={value} onClick={changeTheme.bind(this, value)}>\n {getLanguageStore() === 'en' ? enLabel : label}\n {theme === value && <span className=\"icon-checked-wrap\"></span>}\n </div>\n ))}\n </Row>\n </Theme>\n )\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"NavigationPopup.js","sourceRoot":"","sources":["../../../src/tntd-layout/GlobalNavigation/NavigationPopup.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport cn from 'classnames'\nimport styled from 'styled-components'\nimport { debounce } from 'lodash'\nimport { traverseTree, hasLevel3 } from '../../utils'\nimport Icon from '../Iconfont'\nimport { getText } from '../../locale'\n\nconst SearchArea = styled.div`\n position: relative;\n font-size: 14px;\n margin-bottom: 20px;\n color: ${(props) => props.theme.secondaryTextColor};\n &.active {\n color: ${(props) => props.theme.primaryColor};\n input {\n border-color: ${(props) => props.theme.primaryColor};\n }\n }\n .tnt-icon {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n line-height: 1em;\n &[type='close'] {\n right: 0;\n top: 0;\n font-size: 18px;\n cursor: pointer;\n }\n }\n input {\n border-width: 0 0 1px;\n border-style: solid;\n border-color: ${(props) => props.theme.borderColor};\n width: 100%;\n padding: 4px 20px;\n line-height: 20px;\n background-color: transparent;\n outline: none;\n }\n`\n\nconst ApplicationTabs = styled.ul`\n border: 1px solid ${(props) => props.theme.borderColor};\n color: ${(props) => props.theme.primaryTextColor};\n line-height: 32px;\n margin: 0 0 16px;\n padding: 0;\n display: inline-block;\n\n & > li {\n padding: 0 20px;\n display: inline-block;\n cursor: pointer;\n &:not(:last-child) {\n border-right: 1px solid ${(props) => props.theme.borderColor};\n }\n &.active {\n background-color: ${(props) => props.theme.primaryColor};\n color: #fff;\n }\n }\n`\n\nconst GroupMenus = styled.div`\n height: ${(props) => (props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)')};\n overflow: auto;\n & > div {\n width: 200px;\n margin-right: 10px;\n display: inline-block;\n vertical-align: top;\n }\n`\n\nconst GroupMenuItem = styled.div`\n margin-bottom: 20px;\n & > h5 {\n line-height: 20px;\n margin: 0;\n margin-bottom: 6px;\n }\n`\n\nconst MenuList = styled.ul`\n list-style: none;\n padding: 0;\n margin: 0;\n`\n\nconst MenuItem = styled.li`\n display: block;\n line-height: 30px;\n font-size: 12px;\n cursor: pointer;\n a {\n color: ${(props) => props.theme.secondaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor} !important;\n }\n }\n &.active a {\n color: ${(props) => props.theme.primaryColor};\n }\n`\n\nconst ListBox = styled.ul`\n background: #fff;\n max-height: 320px;\n overflow-y: auto;\n margin: 0;\n padding: 6px 0;\n list-style: none;\n font-size: 13px;\n position: absolute;\n top: 29px;\n width: 100%;\n box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12), 0 6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n li {\n cursor: pointer;\n line-height: 32px;\n padding: 0 10px;\n color: ${(props) => props.theme.primaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor};\n background-color: ${(props) => props.theme.lightBgColor};\n }\n }\n`\n\nconst SearchList = ({ items, onSelectMenu, theme }) => (\n <ListBox theme={theme}>\n {items?.map((item) => (\n <li onClick={() => onSelectMenu(item)}>{item?.menuName}</li>\n ))}\n </ListBox>\n)\n\nexport default ({ theme, menus = [], close, actions, popupRef, containerRef }) => {\n const [active, setActive] = useState(false)\n const [searchValue, setSearchValue] = useState()\n const language = actions?.getLanguage()\n const isLevel3 = hasLevel3(menus)\n const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus?.[0] : null)\n const selectedMenuKey = actions.getSelectedMenuKey()\n const calcGroupMenus = (menus) => {\n menus = menus?.reduce((acc, cur) => {\n // 分组\n if (cur?.children?.length) {\n acc.push(cur)\n } else {\n const defaultGroup = acc.find(({ isDefaultGroup }) => isDefaultGroup)\n if (!defaultGroup) {\n acc.unshift({\n isDefaultGroup: true,\n children: [cur],\n })\n } else {\n defaultGroup.children.push(cur)\n }\n }\n return acc\n }, [])\n\n return menus?.reduce((acc, cur) => {\n const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210))\n\n if (!acc.length) {\n acc.push([cur])\n } else {\n const calcGroupHeight = (group) => 46 + (group?.children?.length || 0) * 30\n const calcColumnHeight = (columnGroups) =>\n columnGroups?.reduce((acc, cur) => {\n acc += calcGroupHeight(cur)\n return acc\n }, 0)\n const currentColumnHeight = calcColumnHeight(acc[acc.length - 1])\n const nextGroupHeight = calcGroupHeight(cur)\n const findMinHeightGroup = (groups) => {\n let minHeight = Infinity\n let index = 0\n\n for (let i = 0; i < groups.length; i++) {\n const height = calcColumnHeight(groups[i])\n if (height < minHeight) {\n index = i\n minHeight = height\n }\n }\n\n return groups[index]\n }\n\n if (acc.length >= column) {\n const minHeightGroup = findMinHeightGroup(acc)\n minHeightGroup?.push(cur)\n } else {\n if (currentColumnHeight + nextGroupHeight > 440) {\n acc.push([cur])\n } else {\n acc[acc?.length - 1]?.push(cur)\n }\n }\n }\n\n return acc\n }, [])\n }\n const groupMenus = calcGroupMenus(activeTopMenu?.children || menus)\n const [searchedMenus, setSearchedMenus] = useState([])\n\n const onMenuClick = (menu) => {\n actions.emit('menuSelect', { key: menu.code, data: menu })\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n const debounceSearch = debounce((evt) => {\n const value = evt.target.value?.trim()\n const matchedMenus = []\n\n if (value) {\n traverseTree(menus, (node) => {\n if (node.path && node?.menuName?.includes(value)) {\n matchedMenus.push(node)\n }\n })\n }\n\n setSearchedMenus(matchedMenus)\n }, 100)\n\n const onSearchChange = (evt) => {\n evt.persist()\n setSearchValue(evt.target.value)\n debounceSearch(evt)\n }\n\n const onSelectAppTab = (menu) => {\n setActiveTopMenu(menu)\n }\n\n useEffect(() => {\n const clickOutside = (evt) => {\n const { clientX, clientY, pageX, pageY } = evt\n const isOutside = (evt, popup) => {\n if (popup?.contains) {\n return !popup?.contains(evt.target)\n }\n\n let { x, y, height, width } = popup.getBoundingClientRect()\n x += window.scrollX\n y += window.scrollY\n\n return pageX < x || pageX > x + width || pageY < y || pageY > y + height\n }\n\n if (isOutside(evt, popupRef.current)) {\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n }\n\n document.addEventListener('click', clickOutside)\n return () => document.removeEventListener('click', clickOutside)\n }, [])\n\n return (\n <>\n <SearchArea theme={theme} className={cn({ active })}>\n <Icon type=\"search\" />\n <input\n placeholder={actions?.getText('menuSearch')}\n value={searchValue}\n onChange={onSearchChange}\n onFocus={() => setActive(true)}\n onBlur={() => setActive(false)}\n />\n <Icon type=\"close\" onClick={close} />\n {searchedMenus?.length > 0 && (\n <SearchList items={searchedMenus} theme={theme} onSelectMenu={onMenuClick} />\n )}\n </SearchArea>\n {isLevel3 && (\n <ApplicationTabs theme={theme}>\n {menus?.map((menu) => (\n <li\n className={cn({ active: menu.code === activeTopMenu?.code })}\n onClick={() => onSelectAppTab(menu)}\n >\n {menu?.[language === 'cn' ? 'groupName' : 'enName']}\n </li>\n ))}\n </ApplicationTabs>\n )}\n <GroupMenus theme={theme} isLevel3={isLevel3}>\n {groupMenus?.map((groups) => (\n <div>\n {groups?.map((group) => (\n <GroupMenuItem theme={theme}>\n <h5>{group?.[language === 'cn' ? 'groupName' : 'enName']}</h5>\n <MenuList>\n {(group.children || []).map((menu) => (\n <MenuItem\n key={menu.code}\n className={cn({ active: selectedMenuKey === menu.code })}\n theme={theme}\n onClick={() => onMenuClick(menu)}\n >\n <a href={menu.path} onClick={(evt) => evt.preventDefault()}>\n {menu?.[language === 'cn' ? 'menuName' : 'enName']}\n </a>\n </MenuItem>\n ))}\n </MenuList>\n </GroupMenuItem>\n ))}\n </div>\n ))}\n </GroupMenus>\n </>\n )\n}\n"]}
1
+ {"version":3,"file":"NavigationPopup.js","sourceRoot":"","sources":["../../../src/tntd-layout/GlobalNavigation/NavigationPopup.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport cn from 'classnames'\nimport styled from 'styled-components'\nimport { debounce } from 'lodash'\nimport { traverseTree, hasLevel3 } from '../../utils'\nimport Icon from '../Iconfont'\nimport { getText } from '../../locale'\n\nconst SearchArea = styled.div`\n position: relative;\n font-size: 14px;\n margin-bottom: 20px;\n color: ${(props) => props.theme.secondaryTextColor};\n &.active {\n color: ${(props) => props.theme.primaryColor};\n input {\n border-color: ${(props) => props.theme.primaryColor};\n }\n }\n .tnt-icon {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n line-height: 1em;\n &[type='close'] {\n right: 0;\n top: 0;\n font-size: 18px;\n cursor: pointer;\n }\n }\n input {\n border-width: 0 0 1px;\n border-style: solid;\n border-color: ${(props) => props.theme.borderColor};\n width: 100%;\n padding: 4px 20px;\n line-height: 20px;\n background-color: transparent;\n outline: none;\n }\n`\n\nconst ApplicationTabs = styled.ul`\n border: 1px solid ${(props) => props.theme.borderColor};\n color: ${(props) => props.theme.primaryTextColor};\n line-height: 32px;\n margin: 0 0 16px;\n padding: 0;\n display: inline-block;\n\n & > li {\n padding: 0 20px;\n display: inline-block;\n cursor: pointer;\n &:not(:last-child) {\n border-right: 1px solid ${(props) => props.theme.borderColor};\n }\n &.active {\n background-color: ${(props) => props.theme.primaryColor};\n color: #fff;\n }\n }\n`\n\nconst GroupMenus = styled.div`\n height: ${(props) => (props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)')};\n overflow: auto;\n & > div {\n width: 200px;\n margin-right: 10px;\n display: inline-block;\n vertical-align: top;\n }\n`\n\nconst GroupMenuItem = styled.div`\n margin-bottom: 20px;\n & > h5 {\n line-height: 20px;\n margin: 0;\n margin-bottom: 6px;\n }\n`\n\nconst MenuList = styled.ul`\n list-style: none;\n padding: 0;\n margin: 0;\n`\n\nconst MenuItem = styled.li`\n display: block;\n line-height: 30px;\n font-size: 12px;\n cursor: pointer;\n a {\n color: ${(props) => props.theme.secondaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor} !important;\n }\n }\n &.active a {\n color: ${(props) => props.theme.primaryColor};\n }\n`\n\nconst ListBox = styled.ul`\n background: #fff;\n max-height: 320px;\n overflow-y: auto;\n margin: 0;\n padding: 6px 0;\n list-style: none;\n font-size: 13px;\n position: absolute;\n top: 29px;\n width: 100%;\n box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12), 0 6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n li {\n cursor: pointer;\n line-height: 32px;\n padding: 0 10px;\n color: ${(props) => props.theme.primaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor};\n background-color: ${(props) => props.theme.lightBgColor};\n }\n }\n`\n\nconst SearchList = ({ items, onSelectMenu, theme }) => (\n <ListBox theme={theme}>\n {items?.map((item) => (\n <li onClick={() => onSelectMenu(item)}>{item?.menuName}</li>\n ))}\n </ListBox>\n)\n\nexport default ({ theme, menus = [], close, actions, popupRef, containerRef }) => {\n const [active, setActive] = useState(false)\n const [searchValue, setSearchValue] = useState()\n const language = actions?.getLanguage()\n const isLevel3 = hasLevel3(menus)\n const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus?.[0] : null)\n const selectedMenuKey = actions.getSelectedMenuKey()\n const calcGroupMenus = (menus) => {\n menus = menus?.reduce((acc, cur) => {\n // 分组\n if (cur?.children?.length) {\n acc.push(cur)\n } else {\n const defaultGroup = acc.find(({ isDefaultGroup }) => isDefaultGroup)\n if (!defaultGroup) {\n acc.unshift({\n isDefaultGroup: true,\n children: [cur],\n })\n } else {\n defaultGroup.children.push(cur)\n }\n }\n return acc\n }, [])\n\n return menus?.reduce((acc, cur) => {\n const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210))\n\n if (!acc.length) {\n acc.push([cur])\n } else {\n const calcGroupHeight = (group) => 46 + (group?.children?.length || 0) * 30\n const calcColumnHeight = (columnGroups) =>\n columnGroups?.reduce((acc, cur) => {\n acc += calcGroupHeight(cur)\n return acc\n }, 0)\n const currentColumnHeight = calcColumnHeight(acc[acc.length - 1])\n const nextGroupHeight = calcGroupHeight(cur)\n const findMinHeightGroup = (groups) => {\n let minHeight = Infinity\n let index = 0\n\n for (let i = 0; i < groups.length; i++) {\n const height = calcColumnHeight(groups[i])\n if (height < minHeight) {\n index = i\n minHeight = height\n }\n }\n\n return groups[index]\n }\n\n if (acc.length >= column) {\n const minHeightGroup = findMinHeightGroup(acc)\n minHeightGroup?.push(cur)\n } else {\n if (currentColumnHeight + nextGroupHeight > 440) {\n acc.push([cur])\n } else {\n acc[acc?.length - 1]?.push(cur)\n }\n }\n }\n\n return acc\n }, [])\n }\n const groupMenus = calcGroupMenus(activeTopMenu?.children || menus)\n const [searchedMenus, setSearchedMenus] = useState([])\n\n const onMenuClick = (menu) => {\n actions.emit('menuSelect', { key: menu.code, data: menu })\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n const debounceSearch = debounce((evt) => {\n const value = evt.target.value?.trim()\n const matchedMenus = []\n\n if (value) {\n traverseTree(menus, (node) => {\n if (node.path && node?.menuName?.includes(value)) {\n matchedMenus.push(node)\n }\n })\n }\n\n setSearchedMenus(matchedMenus)\n }, 100)\n\n const onSearchChange = (evt) => {\n evt.persist()\n setSearchValue(evt.target.value)\n debounceSearch(evt)\n }\n\n const onSelectAppTab = (menu) => {\n setActiveTopMenu(menu)\n }\n\n useEffect(() => {\n const clickOutside = (evt) => {\n const { clientX, clientY, pageX, pageY } = evt\n const isOutside = (evt, popup) => {\n if (popup?.contains) {\n return !popup?.contains(evt.target)\n }\n\n let { x, y, height, width } = popup.getBoundingClientRect()\n x += window.scrollX\n y += window.scrollY\n\n return pageX < x || pageX > x + width || pageY < y || pageY > y + height\n }\n\n if (isOutside(evt, popupRef.current)) {\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n }\n\n document.addEventListener('click', clickOutside)\n return () => document.removeEventListener('click', clickOutside)\n }, [])\n\n return (\n <>\n <SearchArea theme={theme} className={cn({ active })}>\n <Icon type=\"search\" />\n <input\n placeholder={actions?.getText('menuSearch')}\n value={searchValue}\n onChange={onSearchChange}\n onFocus={() => setActive(true)}\n onBlur={() => setActive(false)}\n />\n <Icon type=\"close\" onClick={close} />\n {searchedMenus?.length > 0 && (\n <SearchList items={searchedMenus} theme={theme} onSelectMenu={onMenuClick} />\n )}\n </SearchArea>\n {isLevel3 && (\n <ApplicationTabs theme={theme}>\n {menus?.map((menu) => (\n <li\n className={cn({ active: menu.code === activeTopMenu?.code })}\n onClick={() => onSelectAppTab(menu)}\n >\n {menu?.[language === 'cn' ? 'groupName' : 'enName']}\n </li>\n ))}\n </ApplicationTabs>\n )}\n <GroupMenus theme={theme} isLevel3={isLevel3}>\n {groupMenus?.map((groups) => (\n <div>\n {groups?.map((group) => (\n <GroupMenuItem theme={theme}>\n <h5>{group?.[language === 'cn' ? 'groupName' : 'enName']}</h5>\n <MenuList>\n {(group.children || []).map((menu) => (\n <MenuItem\n key={menu.code}\n className={cn({ active: selectedMenuKey === menu.code })}\n theme={theme}\n onClick={() => onMenuClick(menu)}\n >\n <a href={menu.path} onClick={(evt) => evt.preventDefault()}>\n {menu?.[language === 'cn' ? 'menuName' : 'enName']}\n </a>\n </MenuItem>\n ))}\n </MenuList>\n </GroupMenuItem>\n ))}\n </div>\n ))}\n </GroupMenus>\n </>\n )\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tntd-layout/GlobalNavigation/index.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect, useRef, useContext } from 'react'\nimport ReactDOM from 'react-dom'\nimport cn from 'classnames'\nimport styled, { createGlobalStyle, withTheme } from 'styled-components'\nimport { uniq } from 'lodash'\nimport ActionsContext from '../ActionsContext'\nimport { hasLevel3 } from '../../utils'\nimport Icon from '../Iconfont'\nimport NavigationPopup from './NavigationPopup'\n\nconst Navigation = styled.li`\n &.active {\n color: ${({ theme }) => theme.primaryColor} !important;\n }\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n .tnt-icon {\n font-size: ${({ theme: { size } }) => (size === 'large' ? '22px' : '18px')};\n margin-right: 4px;\n }\n span {\n position: relative;\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n top: ${({ theme: { size } }) => (size === 'large' ? '-3px' : '-2px')};\n font-family: auto;\n .tnt-themeS1 & {\n /* color: rgba(255,255,255,.85); */\n }\n }\n .isInIframe & {\n display: none;\n }\n`\n\nconst createPopupContainer = () => {\n const div = document.createElement('div')\n\n div.setAttribute('class', 'tnt-navigation-popup')\n\n return div\n}\n\nconst GlobalStyle = createGlobalStyle`\n .tnt-navigation-popup {\n position: absolute;\n left: 0;\n top: ${(props) => (props.theme.size === 'large' ? '60px' : '50px')};\n width: 100%;\n height: ${(props) => (props.hasLevel3 ? '560px' : '530px')};\n background: #FFF;\n box-shadow: 0 10px 10px -8px rgba(0,0,0,.1) inset,\n 0 10px 10px -8px rgba(0,0,0,.1);\n transition: all .15s ease-in-out;\n overflow: hidden;\n padding: 20px 16px;\n box-sizing: border-box;\n &.hide {\n height: 0;\n padding: 0;\n }\n }\n`\n\nexport default withTheme((props) => {\n const actions = useContext(ActionsContext)\n const { getText } = actions\n const { headerRef, menus } = props\n const [visible, setVisible] = useState(false)\n const popupRef = useRef()\n\n useEffect(() => {\n popupRef.current = createPopupContainer()\n headerRef?.current?.appendChild(popupRef.current)\n\n return () => {\n headerRef?.current?.removeChild(popupRef.current)\n }\n }, [])\n\n useEffect(() => {\n const classNames = popupRef.current.getAttribute('class').split(' ')\n\n if (visible) {\n ReactDOM.render(\n <NavigationPopup\n actions={actions}\n theme={props.theme}\n menus={menus}\n containerRef={headerRef}\n popupRef={popupRef}\n close={() => setVisible(false)}\n />,\n popupRef.current\n )\n popupRef.current.setAttribute('class', classNames.filter((item) => item !== 'hide').join(' '))\n } else {\n popupRef.current.setAttribute('class', uniq([...classNames, 'hide']).join(' '))\n }\n }, [visible])\n\n return (\n <Navigation\n onClick={(evt) => {\n evt.stopPropagation()\n evt.nativeEvent?.stopImmediatePropagation()\n evt.nativeEvent?.stopPropagation()\n setVisible(!visible)\n }}\n className={cn({ active: visible })}\n >\n <Icon type=\"unordered-list\" />\n <span>{getText('globalNavigation')}</span>\n <GlobalStyle hasLevel3={hasLevel3(menus)} />\n </Navigation>\n )\n})\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tntd-layout/GlobalNavigation/index.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect, useRef, useContext } from 'react'\nimport ReactDOM from 'react-dom'\nimport cn from 'classnames'\nimport styled, { createGlobalStyle, withTheme } from 'styled-components'\nimport { uniq } from 'lodash'\nimport ActionsContext from '../ActionsContext'\nimport { hasLevel3 } from '../../utils'\nimport Icon from '../Iconfont'\nimport NavigationPopup from './NavigationPopup'\n\nconst Navigation = styled.li`\n &.active {\n color: ${({ theme }) => theme.primaryColor} !important;\n }\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n .tnt-icon {\n font-size: ${({ theme: { size } }) => (size === 'large' ? '22px' : '18px')};\n margin-right: 4px;\n }\n span {\n position: relative;\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n top: ${({ theme: { size } }) => (size === 'large' ? '-3px' : '-2px')};\n font-family: auto;\n .tnt-themeS1 & {\n /* color: rgba(255,255,255,.85); */\n }\n }\n .isInIframe & {\n display: none;\n }\n`\n\nconst createPopupContainer = () => {\n const div = document.createElement('div')\n\n div.setAttribute('class', 'tnt-navigation-popup')\n\n return div\n}\n\nconst GlobalStyle = createGlobalStyle`\n .tnt-navigation-popup {\n position: absolute;\n left: 0;\n top: ${(props) => (props.theme.size === 'large' ? '60px' : '50px')};\n width: 100%;\n height: ${(props) => (props.hasLevel3 ? '560px' : '530px')};\n background: #FFF;\n box-shadow: 0 10px 10px -8px rgba(0,0,0,.1) inset,\n 0 10px 10px -8px rgba(0,0,0,.1);\n transition: all .15s ease-in-out;\n overflow: hidden;\n padding: 20px 16px;\n box-sizing: border-box;\n &.hide {\n height: 0;\n padding: 0;\n }\n }\n`\n\nexport default withTheme((props) => {\n const actions = useContext(ActionsContext)\n const { getText } = actions\n const { headerRef, menus } = props\n const [visible, setVisible] = useState(false)\n const popupRef = useRef()\n\n useEffect(() => {\n popupRef.current = createPopupContainer()\n headerRef?.current?.appendChild(popupRef.current)\n\n return () => {\n headerRef?.current?.removeChild(popupRef.current)\n }\n }, [])\n\n useEffect(() => {\n const classNames = popupRef.current.getAttribute('class').split(' ')\n\n if (visible) {\n ReactDOM.render(\n <NavigationPopup\n actions={actions}\n theme={props.theme}\n menus={menus}\n containerRef={headerRef}\n popupRef={popupRef}\n close={() => setVisible(false)}\n />,\n popupRef.current\n )\n popupRef.current.setAttribute('class', classNames.filter((item) => item !== 'hide').join(' '))\n } else {\n popupRef.current.setAttribute('class', uniq([...classNames, 'hide']).join(' '))\n }\n }, [visible])\n\n return (\n <Navigation\n onClick={(evt) => {\n evt.stopPropagation()\n evt.nativeEvent?.stopImmediatePropagation()\n evt.nativeEvent?.stopPropagation()\n setVisible(!visible)\n }}\n className={cn({ active: visible })}\n >\n <Icon type=\"unordered-list\" />\n <span>{getText('globalNavigation')}</span>\n <GlobalStyle hasLevel3={hasLevel3(menus)} />\n </Navigation>\n )\n})\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Header.js","sourceRoot":"","sources":["../../src/tntd-layout/Header.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;GAGG;AACH,+CAAqC;AACrC,uEAAqD;AACrD,6DAA+B;AAC/B,oEAAqC;AACrC,wDAA+B;AAC/B,8DAAqC;AAErC,MAAM,MAAM,GAAG,2BAAM,CAAC,GAAG,CAAA;;;YAGb,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;;;;;;;;;;;;;;uBAc/B,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,WAAW,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;aAyB5D,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;mBACpC,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;cAC/C,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;;aAE3C,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,gBAAgB,EAAE;;;;;;;;;;;;;;;;;;;;;;eAsB1C,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,gBAAgB,EAAE;;;;;;;;;CAS1D,CAAA;AAED,MAAM,OAAO,GAAG,2BAAM,CAAC,GAAG,CAAA;;;;;CAKzB,CAAA;AAED,kBAAe,IAAA,6BAAS,EAAC,CAAC,KAAK,EAAE,EAAE;IACjC,MAAM,EACJ,SAAS,EACT,qBAAqB,GAAG,OAAO,EAC/B,cAAc,EACd,OAAO,EAAE,aAAa;IACtB,UAAU,EAAE,SAAS;IACrB,UAAU,EAAE,aAAa;IACzB,aAAa,EAAE,SAAS;IACxB,cAAc,EACd,OAAO,EACP,UAAU,EACV,WAAW,EACX,WAAW,EACX,gBAAgB,EAChB,YAAY,GACb,GAAG,KAAK,CAAA;IACT,MAAM,SAAS,GAAG,IAAA,cAAM,GAAE,CAAA;IAC1B,OAAO,CACL,8BAAC,MAAM,IAAC,SAAS,EAAC,mBAAmB,EAAC,GAAG,EAAE,SAAS;QACjD,qBAAqB,KAAK,OAAO,IAAI,CACpC,uCAAK,SAAS,EAAC,8BAA8B,EAAC,OAAO,EAAE,gBAAgB;YACrE,8BAAC,mBAAI,IAAC,IAAI,EAAE,QAAQ,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,GAAI,CACnD,CACP;QACA,UAAU;QAGV,OAAO,IAAI,CACV,8BAAC,oBAAU,IACT,UAAU,EAAE,UAAU,EACtB,cAAc,EAAE,cAAc,EAC9B,OAAO,EAAE,OAAO,EAChB,cAAc,EAAE,cAAc,EAC9B,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,aAAa,EAC5B,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,UAAU,GACtB,CACH;QAGA,OAAO,IAAI,CAAC,OAAO,IAAI,CACtB,8BAAC,iBAAO,IAAC,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,WAAW,GAAI,CAChF;QACD,8BAAC,OAAO,IAAC,SAAS,EAAC,2BAA2B,IAAE,KAAK,CAAC,QAAQ,CAAW;QACzE,8BAAC,uBAAO,oBAAK,KAAK,IAAE,SAAS,EAAE,SAAS,KACrC,YAAY,CACL,CACH,CACV,CAAA;AACH,CAAC,CAAC,CAAA","sourcesContent":["/**\n * @file Layout header\n * @author zhangyou\n */\nimport React, { useRef } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport Icon from '../tntd-icon'\nimport Actions from './HeaderActions'\nimport AppList from './AppList'\nimport OrgAppList from './OrgAppList'\n\nconst Header = styled.div`\n position: relative;\n z-index: 201;\n height: ${(props) => `${props.theme.headerHeight}px`};\n display: flex;\n color: rgba(255, 255, 255, 0.85);\n background: #fff;\n .hasHeaderTabs & {\n // background: #191D29;\n background: #fff !important;\n box-shadow: 0px 1px 6px 0px rgba(0, 0, 0, 0.18);\n .tnt-layout-header-content {\n display: none;\n }\n }\n\n // .tnt-themeS3.hasHeaderTabs &{\n // background: ${(props) => `${props.theme.blueBgColor} !important`}; //#1D4295 !important;\n // }\n\n .isInIframe.noAppList &,\n .isEmptyLayout & {\n display: none;\n }\n .tnt-themeS1 & {\n background: #ffffff;\n box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.15);\n }\n .tnt-themeS1.compatible & {\n /* background: #323b4a; */\n }\n padding-right: 20px;\n background: #ffffff;\n box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1);\n .compatible & {\n box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1);\n }\n transition: box-shadow 0.2s cubic-bezier(0.4, 0, 0.2, 1),\n -webkit-box-shadow 0.2s cubic-bezier(0.4, 0, 0.2, 1);\n\n .sidebar-collapsed-controller {\n text-align: center;\n width: ${(props) => `${props.theme.headerHeight}px`};\n line-height: ${(props) => `${props.theme.headerHeight}px`};\n height: ${(props) => `${props.theme.headerHeight}px`};\n cursor: pointer;\n color: ${(props) => `${props.theme.primaryTextColor}`};\n margin-right: 10px;\n\n & > .tnt-icon {\n font-size: 16px;\n .large-size & {\n font-size: 20px;\n }\n }\n\n i {\n position: relative;\n top: -1px;\n vertical-align: sub;\n }\n\n &:hover {\n background-color: rgba(0, 0, 0, 0.06);\n }\n\n .tnt-themeS1 & {\n /* color: rgba(255,255,255,.85); */\n color: ${(props) => `${props.theme.primaryTextColor}`};\n }\n .large-size & {\n font-size: 18px;\n }\n .isInIframe & {\n display: none;\n }\n }\n`\n\nconst Content = styled.div`\n flex: 1;\n .isInIframe & {\n display: none;\n }\n`\n\nexport default withTheme((props) => {\n const {\n collapsed,\n collapseIconPlacement = 'right',\n selectedAppKey,\n appList, // 当前机构下的应用列表\n orgAppShow, // 是否展示应用\n orgAppList, // 指定机构下的应用列表\n orgTreeConfig, // 机构tree\n selectedOrgKey,\n orgList,\n headerTabs,\n onAppChange,\n onOrgChange,\n onCollapseChange,\n extraActions,\n } = props\n const headerRef = useRef()\n return (\n <Header className=\"tnt-layout-header\" ref={headerRef}>\n {collapseIconPlacement === 'right' && (\n <div className=\"sidebar-collapsed-controller\" onClick={onCollapseChange}>\n <Icon type={`menu-${collapsed ? 'unfold' : 'fold'}`} />\n </div>\n )}\n {headerTabs}\n\n {/* 展示机构+应用 */}\n {orgList && (\n <OrgAppList\n orgAppShow={orgAppShow}\n selectedOrgKey={selectedOrgKey}\n orgList={orgList}\n selectedAppKey={selectedAppKey}\n onOrgChange={onOrgChange}\n orgTreeConfig={orgTreeConfig}\n orgAppList={orgAppList}\n onAppChange={onAppChange}\n headerTabs={headerTabs}\n />\n )}\n\n {/* 只展示应用 走老逻辑 */}\n {appList && !orgList && (\n <AppList items={appList} selectedKey={selectedAppKey} onChange={onAppChange} />\n )}\n <Content className=\"tnt-layout-header-content\">{props.children}</Content>\n <Actions {...props} headerRef={headerRef}>\n {extraActions}\n </Actions>\n </Header>\n )\n})\n"]}
1
+ {"version":3,"file":"Header.js","sourceRoot":"","sources":["../../src/tntd-layout/Header.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;GAGG;AACH,+CAAqC;AACrC,uEAAqD;AACrD,6DAA+B;AAC/B,oEAAqC;AACrC,wDAA+B;AAC/B,8DAAqC;AAErC,MAAM,MAAM,GAAG,2BAAM,CAAC,GAAG,CAAA;;;YAGb,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;;;;;;;;;;;;;;uBAc/B,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,WAAW,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;aAyB5D,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;mBACpC,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;cAC/C,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;;aAE3C,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,gBAAgB,EAAE;;;;;;;;;;;;;;;;;;;;;;eAsB1C,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,gBAAgB,EAAE;;;;;;;;;CAS1D,CAAA;AAED,MAAM,OAAO,GAAG,2BAAM,CAAC,GAAG,CAAA;;;;;CAKzB,CAAA;AAED,kBAAe,IAAA,6BAAS,EAAC,CAAC,KAAK,EAAE,EAAE;IACjC,MAAM,EACJ,SAAS,EACT,qBAAqB,GAAG,OAAO,EAC/B,cAAc,EACd,OAAO,EAAE,aAAa;IACtB,UAAU,EAAE,SAAS;IACrB,UAAU,EAAE,aAAa;IACzB,aAAa,EAAE,SAAS;IACxB,cAAc,EACd,OAAO,EACP,UAAU,EACV,WAAW,EACX,WAAW,EACX,gBAAgB,EAChB,YAAY,GACb,GAAG,KAAK,CAAA;IACT,MAAM,SAAS,GAAG,IAAA,cAAM,GAAE,CAAA;IAC1B,OAAO,CACL,8BAAC,MAAM,IAAC,SAAS,EAAC,mBAAmB,EAAC,GAAG,EAAE,SAAS;QACjD,qBAAqB,KAAK,OAAO,IAAI,CACpC,uCAAK,SAAS,EAAC,8BAA8B,EAAC,OAAO,EAAE,gBAAgB;YACrE,8BAAC,mBAAI,IAAC,IAAI,EAAE,QAAQ,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,GAAI,CACnD,CACP;QACA,UAAU;QAGV,OAAO,IAAI,CACV,8BAAC,oBAAU,IACT,UAAU,EAAE,UAAU,EACtB,cAAc,EAAE,cAAc,EAC9B,OAAO,EAAE,OAAO,EAChB,cAAc,EAAE,cAAc,EAC9B,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,aAAa,EAC5B,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,UAAU,GACtB,CACH;QAGA,OAAO,IAAI,CAAC,OAAO,IAAI,CACtB,8BAAC,iBAAO,IAAC,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,WAAW,GAAI,CAChF;QACD,8BAAC,OAAO,IAAC,SAAS,EAAC,2BAA2B,IAAE,KAAK,CAAC,QAAQ,CAAW;QACzE,8BAAC,uBAAO,oBAAK,KAAK,IAAE,SAAS,EAAE,SAAS,KACrC,YAAY,CACL,CACH,CACV,CAAA;AACH,CAAC,CAAC,CAAA","sourcesContent":["/**\n * @file Layout header\n * @author zhangyou\n */\nimport React, { useRef } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport Icon from '../tntd-icon'\nimport Actions from './HeaderActions'\nimport AppList from './AppList'\nimport OrgAppList from './OrgAppList'\n\nconst Header = styled.div`\n position: relative;\n z-index: 201;\n height: ${(props) => `${props.theme.headerHeight}px`};\n display: flex;\n color: rgba(255, 255, 255, 0.85);\n background: #fff;\n .hasHeaderTabs & {\n // background: #191D29;\n background: #fff !important;\n box-shadow: 0px 1px 6px 0px rgba(0, 0, 0, 0.18);\n .tnt-layout-header-content {\n display: none;\n }\n }\n\n // .tnt-themeS3.hasHeaderTabs &{\n // background: ${(props) => `${props.theme.blueBgColor} !important`}; //#1D4295 !important;\n // }\n\n .isInIframe.noAppList &,\n .isEmptyLayout & {\n display: none;\n }\n .tnt-themeS1 & {\n background: #ffffff;\n box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.15);\n }\n .tnt-themeS1.compatible & {\n /* background: #323b4a; */\n }\n padding-right: 20px;\n background: #ffffff;\n box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1);\n .compatible & {\n box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1);\n }\n transition: box-shadow 0.2s cubic-bezier(0.4, 0, 0.2, 1),\n -webkit-box-shadow 0.2s cubic-bezier(0.4, 0, 0.2, 1);\n\n .sidebar-collapsed-controller {\n text-align: center;\n width: ${(props) => `${props.theme.headerHeight}px`};\n line-height: ${(props) => `${props.theme.headerHeight}px`};\n height: ${(props) => `${props.theme.headerHeight}px`};\n cursor: pointer;\n color: ${(props) => `${props.theme.primaryTextColor}`};\n margin-right: 10px;\n\n & > .tnt-icon {\n font-size: 16px;\n .large-size & {\n font-size: 20px;\n }\n }\n\n i {\n position: relative;\n top: -1px;\n vertical-align: sub;\n }\n\n &:hover {\n background-color: rgba(0, 0, 0, 0.06);\n }\n\n .tnt-themeS1 & {\n /* color: rgba(255,255,255,.85); */\n color: ${(props) => `${props.theme.primaryTextColor}`};\n }\n .large-size & {\n font-size: 18px;\n }\n .isInIframe & {\n display: none;\n }\n }\n`\n\nconst Content = styled.div`\n flex: 1;\n .isInIframe & {\n display: none;\n }\n`\n\nexport default withTheme((props) => {\n const {\n collapsed,\n collapseIconPlacement = 'right',\n selectedAppKey,\n appList, // 当前机构下的应用列表\n orgAppShow, // 是否展示应用\n orgAppList, // 指定机构下的应用列表\n orgTreeConfig, // 机构tree\n selectedOrgKey,\n orgList,\n headerTabs,\n onAppChange,\n onOrgChange,\n onCollapseChange,\n extraActions,\n } = props\n const headerRef = useRef()\n return (\n <Header className=\"tnt-layout-header\" ref={headerRef}>\n {collapseIconPlacement === 'right' && (\n <div className=\"sidebar-collapsed-controller\" onClick={onCollapseChange}>\n <Icon type={`menu-${collapsed ? 'unfold' : 'fold'}`} />\n </div>\n )}\n {headerTabs}\n\n {/* 展示机构+应用 */}\n {orgList && (\n <OrgAppList\n orgAppShow={orgAppShow}\n selectedOrgKey={selectedOrgKey}\n orgList={orgList}\n selectedAppKey={selectedAppKey}\n onOrgChange={onOrgChange}\n orgTreeConfig={orgTreeConfig}\n orgAppList={orgAppList}\n onAppChange={onAppChange}\n headerTabs={headerTabs}\n />\n )}\n\n {/* 只展示应用 走老逻辑 */}\n {appList && !orgList && (\n <AppList items={appList} selectedKey={selectedAppKey} onChange={onAppChange} />\n )}\n <Content className=\"tnt-layout-header-content\">{props.children}</Content>\n <Actions {...props} headerRef={headerRef}>\n {extraActions}\n </Actions>\n </Header>\n )\n})\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"HeaderActions.js","sourceRoot":"","sources":["../../src/tntd-layout/HeaderActions.js"],"names":[],"mappings":"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","sourcesContent":["import React from 'react'\nimport styled, { withTheme } from 'styled-components'\n\nimport Divider from '../divider'\nimport Application from './Application'\nimport Avatar from './Avatar'\nimport LanguageTheme from './CompatibleLanguage'\nimport GlobalNavigation from './GlobalNavigation'\nimport Language from './Language'\nimport Theme from './Theme'\n\nconst Actions = styled.ul`\n list-style: none;\n display: inline-block;\n line-height: ${(props) => `${props.theme.headerHeight}px`};\n margin: 0 0 0 20px;\n .hasHeaderTabs & {\n margin: 0;\n }\n padding: 0;\n white-space: nowrap;\n\n .isInIframe & {\n display: none;\n }\n\n & > li {\n height: 100%;\n display: inline-block;\n vertical-align: top;\n cursor: pointer;\n font-size: 20px;\n margin: 0 7.5px;\n color: ${(props) => `${props.theme.headerActionsColor}`};\n .large-size & {\n margin: 0 10px;\n }\n .tnt-themeS1 & {\n /* color: rgba(255,255,255,.85); */\n }\n &:last-of-type {\n margin-right: 0;\n }\n .hasHeaderTabs & {\n color: #455064;\n }\n // 删除色系区分 统一色调\n // .hasHeaderTabs:not(.tnt-themeS1) & {\n // color: rgba(255,255,255,.8);\n // }\n .hasHeaderTabs:not(.tnt-themeS1) & {\n color: #455064 !important;\n }\n }\n`\n\nexport default withTheme((props) => {\n const {\n type,\n config: {\n theme = true,\n avatar = true,\n language = true,\n application = false,\n globalNavigation = false,\n } = {},\n theme: { compatible },\n userInfo = {},\n menus,\n apps,\n extraActions,\n headerRef,\n onLanguageChange,\n onThemeChange,\n onApplicationChange,\n onAppChange,\n onCollapseChange,\n onPersonalSetting,\n onChangePassword,\n onLogout,\n onLogoClick,\n AvatarCustom,\n ...rest\n } = props\n\n return (\n <Actions {...rest}>\n {extraActions}\n {globalNavigation && <GlobalNavigation headerRef={headerRef} menus={menus} />}\n {type !== 'enterprise' &&\n (!compatible ? (\n <>\n {language && <Language language={userInfo.lang} onChange={onLanguageChange} />}\n {theme && <Theme theme={userInfo.theme} onChange={onThemeChange} />}\n </>\n ) : (\n <LanguageTheme\n config={props.config}\n language={userInfo.lang}\n theme={userInfo.theme}\n onLanguageChange={onLanguageChange}\n onThemeChange={onThemeChange}\n />\n ))}\n {application && (\n <Application language={userInfo.lang} apps={apps} onChange={onApplicationChange} />\n )}\n {avatar && (\n <>\n <Divider type=\"vertical\" />\n {AvatarCustom ? (\n <AvatarCustom\n userInfo={userInfo}\n onPersonalSetting={onPersonalSetting}\n onChangePassword={onChangePassword}\n onLogout={onLogout}\n onThemeChange={onThemeChange}\n config={{\n theme,\n language,\n }}\n />\n ) : (\n <Avatar\n userInfo={userInfo}\n onPersonalSetting={onPersonalSetting}\n onChangePassword={onChangePassword}\n onLogout={onLogout}\n onThemeChange={onThemeChange}\n config={{\n theme,\n language,\n }}\n />\n )}\n </>\n )}\n </Actions>\n )\n})\n"]}
1
+ {"version":3,"file":"HeaderActions.js","sourceRoot":"","sources":["../../src/tntd-layout/HeaderActions.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kDAAyB;AACzB,uEAAqD;AAErD,yDAAgC;AAChC,gEAAuC;AACvC,sDAA6B;AAC7B,8EAAgD;AAChD,0EAAiD;AACjD,0DAAiC;AACjC,oDAA2B;AAE3B,MAAM,OAAO,GAAG,2BAAM,CAAC,EAAE,CAAA;;;iBAGR,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI;;;;;;;;;;;;;;;;;;;aAmB9C,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,kBAAkB,EAAE;;;;;;;;;;;;;;;;;;;;;CAqB1D,CAAA;AAED,kBAAe,IAAA,6BAAS,EAAC,CAAC,KAAK,EAAE,EAAE;IACjC,MAAM,EACJ,IAAI,EACJ,MAAM,EAAE,EACN,KAAK,GAAG,IAAI,EACZ,MAAM,GAAG,IAAI,EACb,QAAQ,GAAG,IAAI,EACf,WAAW,GAAG,KAAK,EACnB,gBAAgB,GAAG,KAAK,GACzB,GAAG,EAAE,EACN,KAAK,EAAE,EAAE,UAAU,EAAE,EACrB,QAAQ,GAAG,EAAE,EACb,KAAK,EACL,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,gBAAgB,EAChB,aAAa,EACb,mBAAmB,EACnB,WAAW,EACX,gBAAgB,EAChB,iBAAiB,EACjB,gBAAgB,EAChB,QAAQ,EACR,WAAW,EACX,YAAY,KAEV,KAAK,EADJ,IAAI,UACL,KAAK,EA1BH,wQA0BL,CAAQ,CAAA;IAET,OAAO,CACL,8BAAC,OAAO,oBAAK,IAAI;QACd,YAAY;QACZ,gBAAgB,IAAI,8BAAC,0BAAgB,IAAC,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,GAAI;QAC5E,IAAI,KAAK,YAAY;YACpB,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CACb;gBACG,QAAQ,IAAI,8BAAC,kBAAQ,IAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE,gBAAgB,GAAI;gBAC7E,KAAK,IAAI,8BAAC,eAAK,IAAC,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,aAAa,GAAI,CAClE,CACJ,CAAC,CAAC,CAAC,CACF,8BAAC,4BAAa,IACZ,MAAM,EAAE,KAAK,CAAC,MAAM,EACpB,QAAQ,EAAE,QAAQ,CAAC,IAAI,EACvB,KAAK,EAAE,QAAQ,CAAC,KAAK,EACrB,gBAAgB,EAAE,gBAAgB,EAClC,aAAa,EAAE,aAAa,GAC5B,CACH,CAAC;QACH,WAAW,IAAI,CACd,8BAAC,qBAAW,IAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,mBAAmB,GAAI,CACpF;QACA,MAAM,IAAI,CACT;YACE,8BAAC,iBAAO,IAAC,IAAI,EAAC,UAAU,GAAG;YAC1B,YAAY,CAAC,CAAC,CAAC,CACd,8BAAC,YAAY,IACX,QAAQ,EAAE,QAAQ,EAClB,iBAAiB,EAAE,iBAAiB,EACpC,gBAAgB,EAAE,gBAAgB,EAClC,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,aAAa,EAC5B,MAAM,EAAE;oBACN,KAAK;oBACL,QAAQ;iBACT,GACD,CACH,CAAC,CAAC,CAAC,CACF,8BAAC,gBAAM,IACL,QAAQ,EAAE,QAAQ,EAClB,iBAAiB,EAAE,iBAAiB,EACpC,gBAAgB,EAAE,gBAAgB,EAClC,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,aAAa,EAC5B,MAAM,EAAE;oBACN,KAAK;oBACL,QAAQ;iBACT,GACD,CACH,CACA,CACJ,CACO,CACX,CAAA;AACH,CAAC,CAAC,CAAA","sourcesContent":["import React from 'react'\nimport styled, { withTheme } from 'styled-components'\n\nimport Divider from '../divider'\nimport Application from './Application'\nimport Avatar from './Avatar'\nimport LanguageTheme from './CompatibleLanguage'\nimport GlobalNavigation from './GlobalNavigation'\nimport Language from './Language'\nimport Theme from './Theme'\n\nconst Actions = styled.ul`\n list-style: none;\n display: inline-block;\n line-height: ${(props) => `${props.theme.headerHeight}px`};\n margin: 0 0 0 20px;\n .hasHeaderTabs & {\n margin: 0;\n }\n padding: 0;\n white-space: nowrap;\n\n .isInIframe & {\n display: none;\n }\n\n & > li {\n height: 100%;\n display: inline-block;\n vertical-align: top;\n cursor: pointer;\n font-size: 20px;\n margin: 0 7.5px;\n color: ${(props) => `${props.theme.headerActionsColor}`};\n .large-size & {\n margin: 0 10px;\n }\n .tnt-themeS1 & {\n /* color: rgba(255,255,255,.85); */\n }\n &:last-of-type {\n margin-right: 0;\n }\n .hasHeaderTabs & {\n color: #455064;\n }\n // 删除色系区分 统一色调\n // .hasHeaderTabs:not(.tnt-themeS1) & {\n // color: rgba(255,255,255,.8);\n // }\n .hasHeaderTabs:not(.tnt-themeS1) & {\n color: #455064 !important;\n }\n }\n`\n\nexport default withTheme((props) => {\n const {\n type,\n config: {\n theme = true,\n avatar = true,\n language = true,\n application = false,\n globalNavigation = false,\n } = {},\n theme: { compatible },\n userInfo = {},\n menus,\n apps,\n extraActions,\n headerRef,\n onLanguageChange,\n onThemeChange,\n onApplicationChange,\n onAppChange,\n onCollapseChange,\n onPersonalSetting,\n onChangePassword,\n onLogout,\n onLogoClick,\n AvatarCustom,\n ...rest\n } = props\n\n return (\n <Actions {...rest}>\n {extraActions}\n {globalNavigation && <GlobalNavigation headerRef={headerRef} menus={menus} />}\n {type !== 'enterprise' &&\n (!compatible ? (\n <>\n {language && <Language language={userInfo.lang} onChange={onLanguageChange} />}\n {theme && <Theme theme={userInfo.theme} onChange={onThemeChange} />}\n </>\n ) : (\n <LanguageTheme\n config={props.config}\n language={userInfo.lang}\n theme={userInfo.theme}\n onLanguageChange={onLanguageChange}\n onThemeChange={onThemeChange}\n />\n ))}\n {application && (\n <Application language={userInfo.lang} apps={apps} onChange={onApplicationChange} />\n )}\n {avatar && (\n <>\n <Divider type=\"vertical\" />\n {AvatarCustom ? (\n <AvatarCustom\n userInfo={userInfo}\n onPersonalSetting={onPersonalSetting}\n onChangePassword={onChangePassword}\n onLogout={onLogout}\n onThemeChange={onThemeChange}\n config={{\n theme,\n language,\n }}\n />\n ) : (\n <Avatar\n userInfo={userInfo}\n onPersonalSetting={onPersonalSetting}\n onChangePassword={onChangePassword}\n onLogout={onLogout}\n onThemeChange={onThemeChange}\n config={{\n theme,\n language,\n }}\n />\n )}\n </>\n )}\n </Actions>\n )\n})\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"HeaderNavs.js","sourceRoot":"","sources":["../../src/tntd-layout/HeaderNavs.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAkD;AAClD,uEAAqD;AACrD,4DAA2B;AAC3B,mCAA4B;AAE5B,MAAM,IAAI,GAAG,2BAAM,CAAC,EAAE,CAAA;;;;;CAKrB,CAAA;AACD,MAAM,OAAO,GAAG,2BAAM,CAAC,EAAE,CAAA;;;;;;iBAMR,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;aAK/D,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,kBAAkB;;;;;;;;;;;;eAYvC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;;;;;;;;;;;oBAa9B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;;;;;;CAQtD,CAAA;AAEY,QAAA,UAAU,GAAG,IAAA,6BAAS,EAAC,CAAC,EAAkD,EAAE,EAAE;QAAtD,EAAE,KAAK,EAAE,IAAI,GAAG,EAAE,EAAE,QAAQ,EAAE,QAAQ,OAAY,EAAP,KAAK,cAAhD,yCAAkD,CAAF;IACnF,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,WAAW,IAAI,IAAA,YAAG,EAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAA;IACvF,MAAM,UAAU,GAAG,CAAC,GAAG,EAAE,EAAE;QACzB,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QACvB,QAAQ,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAA;QAEzB,IAAI,WAAW,KAAK,GAAG,CAAC,GAAG,EAAE;YAC3B,QAAQ,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAA;YACzB,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;SACxB;IACH,CAAC,CAAA;IAED,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,cAAc,CAAC,KAAK,CAAC,WAAW,IAAI,IAAA,YAAG,EAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAA;IACzD,CAAC,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,CAAA;IAE7B,OAAO,CACL,8BAAC,IAAI,oBAAK,KAAK,GACZ,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CACjB,8BAAC,OAAO,IACN,GAAG,EAAE,GAAG,CAAC,GAAG,EACZ,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,IAAA,oBAAE,EAAC,EAAE,MAAM,EAAE,WAAW,KAAK,GAAG,CAAC,GAAG,EAAE,CAAC,EAClD,OAAO,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC;QAE9B,qCAAG,IAAI,EAAE,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,cAAc,EAAE,IACrD,GAAG,CAAC,IAAI,CACP,CACI,CACX,CAAC,CACG,CACR,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,kBAAe,kBAAU,CAAA","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport cn from 'classnames'\nimport { get } from 'lodash'\n\nconst Navs = styled.ul`\n margin: 0;\n padding: 0;\n list-style: none;\n text-align: right;\n`\nconst NavItem = styled.li`\n position: relative;\n margin: 0;\n padding: 0 20px;\n cursor: pointer;\n display: inline-block;\n line-height: ${(props) => (props.theme.size === 'large' ? '60px' : '50px')};\n transition: background-color 0.5;\n\n a {\n font-size: 14px;\n color: ${(props) => props.theme.secondaryTextColor};\n text-rendering: optimizeLegibility;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n .tnt-themeS1 & {\n color: rgba(255, 255, 255, 0.8);\n }\n }\n\n &:hover,\n &.active {\n a {\n color: ${(props) => props.theme.primaryColor};\n .tnt-themeS1 & {\n color: #418aff;\n }\n }\n }\n &.active {\n &:after {\n position: absolute;\n left: 0;\n bottom: 0;\n width: 100%;\n height: 3px;\n background: ${(props) => props.theme.primaryColor};\n display: inline-block;\n content: '';\n .tnt-themeS1 & {\n background: #418aff;\n }\n }\n }\n`\n\nexport const HeaderNavs = withTheme(({ theme, navs = [], onChange, onSelect, ...props }) => {\n const [selectedKey, setSelectedKey] = useState(props.selectedKey || get(navs, '0.key'))\n const onClickNav = (nav) => {\n setSelectedKey(nav.key)\n onSelect && onSelect(nav)\n\n if (selectedKey !== nav.key) {\n onChange && onChange(nav)\n setSelectedKey(nav.key)\n }\n }\n\n useEffect(() => {\n setSelectedKey(props.selectedKey || get(navs, '0.key'))\n }, [navs, props.selectedKey])\n\n return (\n <Navs {...props}>\n {navs.map((nav) => (\n <NavItem\n key={nav.key}\n theme={theme}\n className={cn({ active: selectedKey === nav.key })}\n onClick={() => onClickNav(nav)}\n >\n <a href={nav.key} onClick={(evt) => evt.preventDefault()}>\n {nav.name}\n </a>\n </NavItem>\n ))}\n </Navs>\n )\n})\n\nexport default HeaderNavs\n"]}
1
+ {"version":3,"file":"HeaderNavs.js","sourceRoot":"","sources":["../../src/tntd-layout/HeaderNavs.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAkD;AAClD,uEAAqD;AACrD,4DAA2B;AAC3B,mCAA4B;AAE5B,MAAM,IAAI,GAAG,2BAAM,CAAC,EAAE,CAAA;;;;;CAKrB,CAAA;AACD,MAAM,OAAO,GAAG,2BAAM,CAAC,EAAE,CAAA;;;;;;iBAMR,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;aAK/D,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,kBAAkB;;;;;;;;;;;;eAYvC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;;;;;;;;;;;oBAa9B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;;;;;;CAQtD,CAAA;AAEY,QAAA,UAAU,GAAG,IAAA,6BAAS,EAAC,CAAC,EAAkD,EAAE,EAAE;QAAtD,EAAE,KAAK,EAAE,IAAI,GAAG,EAAE,EAAE,QAAQ,EAAE,QAAQ,OAAY,EAAP,KAAK,cAAhD,yCAAkD,CAAF;IACnF,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,WAAW,IAAI,IAAA,YAAG,EAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAA;IACvF,MAAM,UAAU,GAAG,CAAC,GAAG,EAAE,EAAE;QACzB,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QACvB,QAAQ,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAA;QAEzB,IAAI,WAAW,KAAK,GAAG,CAAC,GAAG,EAAE;YAC3B,QAAQ,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAA;YACzB,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;SACxB;IACH,CAAC,CAAA;IAED,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,cAAc,CAAC,KAAK,CAAC,WAAW,IAAI,IAAA,YAAG,EAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAA;IACzD,CAAC,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,CAAA;IAE7B,OAAO,CACL,8BAAC,IAAI,oBAAK,KAAK,GACZ,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CACjB,8BAAC,OAAO,IACN,GAAG,EAAE,GAAG,CAAC,GAAG,EACZ,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,IAAA,oBAAE,EAAC,EAAE,MAAM,EAAE,WAAW,KAAK,GAAG,CAAC,GAAG,EAAE,CAAC,EAClD,OAAO,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC;QAE9B,qCAAG,IAAI,EAAE,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,cAAc,EAAE,IACrD,GAAG,CAAC,IAAI,CACP,CACI,CACX,CAAC,CACG,CACR,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,kBAAe,kBAAU,CAAA","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport cn from 'classnames'\nimport { get } from 'lodash'\n\nconst Navs = styled.ul`\n margin: 0;\n padding: 0;\n list-style: none;\n text-align: right;\n`\nconst NavItem = styled.li`\n position: relative;\n margin: 0;\n padding: 0 20px;\n cursor: pointer;\n display: inline-block;\n line-height: ${(props) => (props.theme.size === 'large' ? '60px' : '50px')};\n transition: background-color 0.5;\n\n a {\n font-size: 14px;\n color: ${(props) => props.theme.secondaryTextColor};\n text-rendering: optimizeLegibility;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n .tnt-themeS1 & {\n color: rgba(255, 255, 255, 0.8);\n }\n }\n\n &:hover,\n &.active {\n a {\n color: ${(props) => props.theme.primaryColor};\n .tnt-themeS1 & {\n color: #418aff;\n }\n }\n }\n &.active {\n &:after {\n position: absolute;\n left: 0;\n bottom: 0;\n width: 100%;\n height: 3px;\n background: ${(props) => props.theme.primaryColor};\n display: inline-block;\n content: '';\n .tnt-themeS1 & {\n background: #418aff;\n }\n }\n }\n`\n\nexport const HeaderNavs = withTheme(({ theme, navs = [], onChange, onSelect, ...props }) => {\n const [selectedKey, setSelectedKey] = useState(props.selectedKey || get(navs, '0.key'))\n const onClickNav = (nav) => {\n setSelectedKey(nav.key)\n onSelect && onSelect(nav)\n\n if (selectedKey !== nav.key) {\n onChange && onChange(nav)\n setSelectedKey(nav.key)\n }\n }\n\n useEffect(() => {\n setSelectedKey(props.selectedKey || get(navs, '0.key'))\n }, [navs, props.selectedKey])\n\n return (\n <Navs {...props}>\n {navs.map((nav) => (\n <NavItem\n key={nav.key}\n theme={theme}\n className={cn({ active: selectedKey === nav.key })}\n onClick={() => onClickNav(nav)}\n >\n <a href={nav.key} onClick={(evt) => evt.preventDefault()}>\n {nav.name}\n </a>\n </NavItem>\n ))}\n </Navs>\n )\n})\n\nexport default HeaderNavs\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"HeaderTabs.js","sourceRoot":"","sources":["../../src/tntd-layout/HeaderTabs.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect, useRef } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport cn from 'classnames'\nimport { get } from 'lodash'\nimport Icon from '../tntd-icon'\n\nconst TabsContainer = styled.div`\n display: flex;\n flex: 1;\n overflow: hidden;\n position: relative;\n margin-right: 12px;\n margin-left: 4px;\n\n .tnt-layout-header-tabs-arrows {\n position: absolute;\n right: 0;\n bottom: 0;\n font-size: 16px;\n line-height: 36px;\n height: 36px;\n background: #fff !important;\n color: rgba(255, 255, 255, 0.8) !important;\n .tnt-icon {\n cursor: pointer;\n color: rgba(139, 145, 158, 1);\n &[disabled] {\n color: rgba(139, 145, 158, 0.5);\n pointer-events: none;\n cursor: not-allowed;\n }\n }\n // background: #191D29;\n // .tnt-icon {\n // cursor: pointer;\n // &[disabled] {\n // color: rgba(139, 145, 158, .5);\n // pointer-events: none;\n // cursor: not-allowed;\n // }\n // }\n // .tnt-themeS1 & {\n // background: #fff;\n // .tnt-icon {\n // color: rgba(139,145,158,1);\n // }\n // }\n // 多签页的箭头样式\n // .tnt-themeS3 & {\n // background: ${(props) => `${props.theme.blueBgColor}`}; //#1D4295;\n // .tnt-icon {\n // color: rgba(255, 255, 255, .5);\n // &[disabled] {\n // color: rgba(139, 145, 158, .5);\n // pointer-events: none;\n // cursor: not-allowed;\n // }\n // }\n // }\n }\n`\nconst Tabs = styled.ul`\n margin: 14px 0 0;\n padding: 0;\n list-style: none;\n text-align: left;\n height: 36px;\n line-height: 36px;\n flex: 1;\n white-space: nowrap;\n padding-right: 40px;\n transition: transform 0.25s linear;\n position: absolute;\n`\nconst TabItem = styled.li`\n position: relative;\n margin: 0;\n padding: 0 20px 0 10px;\n cursor: pointer;\n display: inline-block;\n line-height: ${(props) => (props.theme.size === 'large' ? '46px' : '36px')};\n /* transition: background-color .5; */\n width: 130px;\n color: rgba(255, 255, 255, 0.6);\n\n .tnt-icon[type='close'] {\n display: none;\n position: absolute;\n right: 0;\n top: 0;\n font-size: 10px;\n padding: 0 10px;\n cursor: pointer;\n z-index: 1;\n }\n\n &:not(:last-child):after {\n position: absolute;\n content: '';\n right: 0;\n top: 6px;\n height: 24px;\n width: 1px;\n // opacity: .5;\n // background: #fff;\n background: #e1e6ee;\n opacity: 0.5;\n // .tnt-themeS1 & {\n // background: #E1E6EE;\n // opacity: 1;\n // }\n }\n\n &.active,\n &.activeTabPreSibling {\n &:after {\n display: none;\n }\n }\n\n a {\n font-size: 14px;\n color: ${(props) => props.theme.headerActionsColor}; //rgba(255,255,255,.6);\n text-rendering: optimizeLegibility;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n transition: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n display: inline-block;\n line-height: 36px;\n width: 100%;\n // &:hover {\n // color: rgba(255,255,255,.8);\n // }\n // .tnt-themeS1 & {\n // color: ${(props) => props.theme.headerActionsColor};\n // }\n }\n\n &:hover,\n &.active {\n .tnt-icon[type='close'] {\n display: unset;\n color: #455064;\n // .tnt-themeS1 & {\n // color: #455064;\n // }\n }\n }\n\n &.active {\n background: #f1f2f5;\n border-radius: 2px 2px 0 0;\n color: ${(props) => props.theme.primaryTextColor};\n font-weight: 600;\n\n a {\n color: ${(props) => props.theme.primaryTextColor};\n }\n }\n`\n\nexport const HeaderTabs = withTheme(\n ({\n theme,\n className,\n tabs = [],\n onTabChange,\n onTabSelect,\n onTabClose,\n appListVisible,\n orgListVisible,\n orgAppListVisible,\n language,\n ...props\n }) => {\n const [selectedKey, setSelectedKey] = useState(props.selectedKey || get(tabs, '0.key'))\n const [tabItems, setTabItems] = useState(tabs || [])\n const [arrowVisible, setArrowVisible] = useState(false)\n const [tabsPositionFlags, setTabsPositionFlags] = useState({ start: true, end: true })\n const tabsRef = useRef()\n\n const getTabsDom = () => tabsRef.current\n\n const onTabClick = (tab, index) => {\n setSelectedKey(tab.key)\n onTabSelect?.(tab)\n\n if (selectedKey !== tab.key) {\n onTabChange?.(tab)\n }\n }\n const closeTabHandle = (tab, index, evt) => {\n evt.stopPropagation()\n const newTabItems = tabItems.filter(({ key }) => key !== tab.key)\n let newSelectedKey = selectedKey\n\n setTabItems(newTabItems)\n if (tab.key === selectedKey) {\n newSelectedKey = index === 0 ? newTabItems[0]?.key : newTabItems[index - 1]?.key\n setSelectedKey(newSelectedKey)\n }\n onTabClose?.(\n tab,\n newTabItems,\n newTabItems.find(({ key }) => key === newSelectedKey)\n )\n }\n const onMoveToLeft = () => {\n const tabsDom = getTabsDom()\n const parentBBox = tabsDom.parentNode.getBoundingClientRect()\n const parentWidth = parentBBox.width - 32\n let x = Math.abs(+tabsDom.style.transform.replace(/[^\\d.-]/g, ''))\n const index = Math.ceil(x / 130)\n const trueX = index * 130\n let newX = Math.min(0, -(trueX - parentWidth))\n tabsDom.style.transform = `translateX(${newX}px)`\n\n const width = tabItems.length * 130\n setTabsPositionFlags({\n start: newX < 0,\n end: Math.abs(newX) < width - parentWidth,\n })\n }\n const onMoveToRight = () => {\n const tabsDom = getTabsDom()\n const parentBBox = tabsDom.parentNode.getBoundingClientRect()\n const parentWidth = parentBBox.width - 32\n const width = tabItems.length * 130\n\n let x = Math.abs(+tabsDom.style.transform.replace(/[^\\d.-]/g, ''))\n const index = Math.floor(x / 130)\n const trueX = index * 130\n let newX = Math.max(-(width - parentWidth), -(trueX + parentWidth))\n tabsDom.style.transform = `translateX(${newX}px)`\n\n setTabsPositionFlags({\n start: newX < 0,\n end: Math.abs(newX) < width - parentWidth,\n })\n }\n\n const translateTabsDom = (tabs, selectedKey) => {\n if (!selectedKey) return\n const index = tabs.indexOf(tabs.find(({ key }) => key === selectedKey))\n if (index === -1) return\n const tabsDom = getTabsDom()\n let x = -+tabsDom.style.transform.replace(/[^\\d.-]/g, '')\n const bbox = {\n left: index * 130,\n right: (index + 1) * 130,\n }\n const parentBBox = tabsDom.parentNode.getBoundingClientRect()\n const parentWidth = parentBBox.width - 36\n const width = tabItems.length * 130\n\n let tailX = x + parentWidth //当前滑动窗口尾部坐标\n let newX = -x\n if (bbox.left < x) {\n newX = -bbox.left\n } else if (bbox.right >= tailX) {\n newX = parentWidth - bbox.right\n }\n if (newX + width < parentWidth) {\n newX = -(width - parentWidth)\n }\n newX = Math.min(0, newX)\n tabsDom.style.transform = `translateX(${newX}px)`\n\n setTabsPositionFlags({\n start: newX < 0,\n end: Math.abs(newX) < width - parentWidth,\n })\n }\n\n useEffect(() => {\n setSelectedKey(props.selectedKey || get(tabs, '0.key'))\n // const t = [{'code':'tagdata','enName':'tagdata','icon':'layer-color','menuName':'打标数据管理打标数据管理打标数据管理','path':'/orion/tag/datalist','key':'tagdata','name':'打标数据管理打标数据管理打标数据管理'},{'code':'taglist','enName':'taglist','icon':'home','menuName':'标签管理','path':'http://baidu.com/orion/tag/list','key':'taglist','name':'标签管理'},{'code':'relation1','enName':'dadicasesearch1','icon':'home','menuName':'案件检索1','path':'/orion/case/relation1','key':'relation1','name':'案件检索1'},{'code':'dadicasesearch-0','enName':'dadicasesearch','icon':'home','menuName':'案件检索-0','path':'/orion/case/relation0','key':'dadicasesearch-0','name':'案件检索-0'},{'code':'dadicasesearch-1','enName':'dadicasesearch','icon':'home','menuName':'案件检索-1','path':'/orion/case/relation1','key':'dadicasesearch-1','name':'案件检索-1'},{'code':'dadicasesearch-2','enName':'dadicasesearch','icon':'home','menuName':'案件检索-2','path':'/orion/case/relation2','key':'dadicasesearch-2','name':'案件检索-2'},{'code':'dadicasesearch-3','enName':'dadicasesearch','icon':'home','menuName':'案件检索-3','path':'/orion/case/relation3','key':'dadicasesearch-3','name':'案件检索-3'},{'code':'dadicasesearch-4','enName':'dadicasesearch','icon':'home','menuName':'案件检索-4','path':'/orion/case/relation4','key':'dadicasesearch-4','name':'案件检索-4'},{'code':'dadicasesearch-5','enName':'dadicasesearch','icon':'home','menuName':'案件检索-5','path':'/orion/case/relation5','key':'dadicasesearch-5','name':'案件检索-5'},{'code':'dadicasesearch-6','enName':'dadicasesearch','icon':'home','menuName':'案件检索-6','path':'/orion/case/relation6','key':'dadicasesearch-6','name':'案件检索-6'},{'code':'dadicasesearch-7','enName':'dadicasesearch','icon':'home','menuName':'案件检索-7','path':'/orion/case/relation7','key':'dadicasesearch-7','name':'案件检索-7'},{'code':'dadicasesearch-8','enName':'dadicasesearch','icon':'home','menuName':'案件检索-8','path':'/orion/case/relation8','key':'dadicasesearch-8','name':'案件检索-8'}] ;\n setTabItems(tabs)\n }, [tabs, props.selectedKey])\n\n useEffect(() => {}, [props.orgAppListVisible])\n\n useEffect(() => {\n const tabsDom = getTabsDom()\n\n setArrowVisible(tabsDom.offsetWidth - tabsDom.parentNode.offsetWidth > 0)\n }, [tabItems])\n\n useEffect(() => {\n translateTabsDom(tabItems, selectedKey)\n }, [tabItems, selectedKey, appListVisible, orgListVisible, orgAppListVisible])\n\n return (\n <TabsContainer\n {...props}\n className={cn('tnt-layout-header-tabs', { [className]: className })}\n >\n <Tabs className=\"tnt-layout-header-tabs-content\" ref={tabsRef}>\n {tabItems.map((tab, index) => (\n <TabItem\n key={tab.key}\n theme={theme}\n className={cn({\n active: selectedKey === tab.key,\n activeTabPreSibling: tabItems[index + 1]?.key === selectedKey,\n })}\n onClick={() => onTabClick(tab, index)}\n >\n <a href={tab.key} onClick={(evt) => evt.preventDefault()}>\n {\n {\n cn: tab.name,\n en: tab.enName || tab.name,\n }[language || 'cn']\n }\n </a>\n {tab.closable !== false && tabItems.length > 1 && (\n <Icon type=\"close\" onClick={closeTabHandle.bind(null, tab, index)} />\n )}\n </TabItem>\n ))}\n </Tabs>\n {arrowVisible && (\n <div className=\"tnt-layout-header-tabs-arrows\">\n <Icon type=\"left\" onClick={onMoveToLeft} disabled={!tabsPositionFlags.start} />\n <Icon type=\"right\" onClick={onMoveToRight} disabled={!tabsPositionFlags.end} />\n </div>\n )}\n </TabsContainer>\n )\n }\n)\n\nexport default HeaderTabs\n"]}
1
+ {"version":3,"file":"HeaderTabs.js","sourceRoot":"","sources":["../../src/tntd-layout/HeaderTabs.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect, useRef } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport cn from 'classnames'\nimport { get } from 'lodash'\nimport Icon from '../tntd-icon'\n\nconst TabsContainer = styled.div`\n display: flex;\n flex: 1;\n overflow: hidden;\n position: relative;\n margin-right: 12px;\n margin-left: 4px;\n\n .tnt-layout-header-tabs-arrows {\n position: absolute;\n right: 0;\n bottom: 0;\n font-size: 16px;\n line-height: 36px;\n height: 36px;\n background: #fff !important;\n color: rgba(255, 255, 255, 0.8) !important;\n .tnt-icon {\n cursor: pointer;\n color: rgba(139, 145, 158, 1);\n &[disabled] {\n color: rgba(139, 145, 158, 0.5);\n pointer-events: none;\n cursor: not-allowed;\n }\n }\n // background: #191D29;\n // .tnt-icon {\n // cursor: pointer;\n // &[disabled] {\n // color: rgba(139, 145, 158, .5);\n // pointer-events: none;\n // cursor: not-allowed;\n // }\n // }\n // .tnt-themeS1 & {\n // background: #fff;\n // .tnt-icon {\n // color: rgba(139,145,158,1);\n // }\n // }\n // 多签页的箭头样式\n // .tnt-themeS3 & {\n // background: ${(props) => `${props.theme.blueBgColor}`}; //#1D4295;\n // .tnt-icon {\n // color: rgba(255, 255, 255, .5);\n // &[disabled] {\n // color: rgba(139, 145, 158, .5);\n // pointer-events: none;\n // cursor: not-allowed;\n // }\n // }\n // }\n }\n`\nconst Tabs = styled.ul`\n margin: 14px 0 0;\n padding: 0;\n list-style: none;\n text-align: left;\n height: 36px;\n line-height: 36px;\n flex: 1;\n white-space: nowrap;\n padding-right: 40px;\n transition: transform 0.25s linear;\n position: absolute;\n`\nconst TabItem = styled.li`\n position: relative;\n margin: 0;\n padding: 0 20px 0 10px;\n cursor: pointer;\n display: inline-block;\n line-height: ${(props) => (props.theme.size === 'large' ? '46px' : '36px')};\n /* transition: background-color .5; */\n width: 130px;\n color: rgba(255, 255, 255, 0.6);\n\n .tnt-icon[type='close'] {\n display: none;\n position: absolute;\n right: 0;\n top: 0;\n font-size: 10px;\n padding: 0 10px;\n cursor: pointer;\n z-index: 1;\n }\n\n &:not(:last-child):after {\n position: absolute;\n content: '';\n right: 0;\n top: 6px;\n height: 24px;\n width: 1px;\n // opacity: .5;\n // background: #fff;\n background: #e1e6ee;\n opacity: 0.5;\n // .tnt-themeS1 & {\n // background: #E1E6EE;\n // opacity: 1;\n // }\n }\n\n &.active,\n &.activeTabPreSibling {\n &:after {\n display: none;\n }\n }\n\n a {\n font-size: 14px;\n color: ${(props) => props.theme.headerActionsColor}; //rgba(255,255,255,.6);\n text-rendering: optimizeLegibility;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n transition: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n display: inline-block;\n line-height: 36px;\n width: 100%;\n // &:hover {\n // color: rgba(255,255,255,.8);\n // }\n // .tnt-themeS1 & {\n // color: ${(props) => props.theme.headerActionsColor};\n // }\n }\n\n &:hover,\n &.active {\n .tnt-icon[type='close'] {\n display: unset;\n color: #455064;\n // .tnt-themeS1 & {\n // color: #455064;\n // }\n }\n }\n\n &.active {\n background: #f1f2f5;\n border-radius: 2px 2px 0 0;\n color: ${(props) => props.theme.primaryTextColor};\n font-weight: 600;\n\n a {\n color: ${(props) => props.theme.primaryTextColor};\n }\n }\n`\n\nexport const HeaderTabs = withTheme(\n ({\n theme,\n className,\n tabs = [],\n onTabChange,\n onTabSelect,\n onTabClose,\n appListVisible,\n orgListVisible,\n orgAppListVisible,\n language,\n ...props\n }) => {\n const [selectedKey, setSelectedKey] = useState(props.selectedKey || get(tabs, '0.key'))\n const [tabItems, setTabItems] = useState(tabs || [])\n const [arrowVisible, setArrowVisible] = useState(false)\n const [tabsPositionFlags, setTabsPositionFlags] = useState({ start: true, end: true })\n const tabsRef = useRef()\n\n const getTabsDom = () => tabsRef.current\n\n const onTabClick = (tab, index) => {\n setSelectedKey(tab.key)\n onTabSelect?.(tab)\n\n if (selectedKey !== tab.key) {\n onTabChange?.(tab)\n }\n }\n const closeTabHandle = (tab, index, evt) => {\n evt.stopPropagation()\n const newTabItems = tabItems.filter(({ key }) => key !== tab.key)\n let newSelectedKey = selectedKey\n\n setTabItems(newTabItems)\n if (tab.key === selectedKey) {\n newSelectedKey = index === 0 ? newTabItems[0]?.key : newTabItems[index - 1]?.key\n setSelectedKey(newSelectedKey)\n }\n onTabClose?.(\n tab,\n newTabItems,\n newTabItems.find(({ key }) => key === newSelectedKey)\n )\n }\n const onMoveToLeft = () => {\n const tabsDom = getTabsDom()\n const parentBBox = tabsDom.parentNode.getBoundingClientRect()\n const parentWidth = parentBBox.width - 32\n let x = Math.abs(+tabsDom.style.transform.replace(/[^\\d.-]/g, ''))\n const index = Math.ceil(x / 130)\n const trueX = index * 130\n let newX = Math.min(0, -(trueX - parentWidth))\n tabsDom.style.transform = `translateX(${newX}px)`\n\n const width = tabItems.length * 130\n setTabsPositionFlags({\n start: newX < 0,\n end: Math.abs(newX) < width - parentWidth,\n })\n }\n const onMoveToRight = () => {\n const tabsDom = getTabsDom()\n const parentBBox = tabsDom.parentNode.getBoundingClientRect()\n const parentWidth = parentBBox.width - 32\n const width = tabItems.length * 130\n\n let x = Math.abs(+tabsDom.style.transform.replace(/[^\\d.-]/g, ''))\n const index = Math.floor(x / 130)\n const trueX = index * 130\n let newX = Math.max(-(width - parentWidth), -(trueX + parentWidth))\n tabsDom.style.transform = `translateX(${newX}px)`\n\n setTabsPositionFlags({\n start: newX < 0,\n end: Math.abs(newX) < width - parentWidth,\n })\n }\n\n const translateTabsDom = (tabs, selectedKey) => {\n if (!selectedKey) return\n const index = tabs.indexOf(tabs.find(({ key }) => key === selectedKey))\n if (index === -1) return\n const tabsDom = getTabsDom()\n let x = -+tabsDom.style.transform.replace(/[^\\d.-]/g, '')\n const bbox = {\n left: index * 130,\n right: (index + 1) * 130,\n }\n const parentBBox = tabsDom.parentNode.getBoundingClientRect()\n const parentWidth = parentBBox.width - 36\n const width = tabItems.length * 130\n\n let tailX = x + parentWidth //当前滑动窗口尾部坐标\n let newX = -x\n if (bbox.left < x) {\n newX = -bbox.left\n } else if (bbox.right >= tailX) {\n newX = parentWidth - bbox.right\n }\n if (newX + width < parentWidth) {\n newX = -(width - parentWidth)\n }\n newX = Math.min(0, newX)\n tabsDom.style.transform = `translateX(${newX}px)`\n\n setTabsPositionFlags({\n start: newX < 0,\n end: Math.abs(newX) < width - parentWidth,\n })\n }\n\n useEffect(() => {\n setSelectedKey(props.selectedKey || get(tabs, '0.key'))\n // const t = [{'code':'tagdata','enName':'tagdata','icon':'layer-color','menuName':'打标数据管理打标数据管理打标数据管理','path':'/orion/tag/datalist','key':'tagdata','name':'打标数据管理打标数据管理打标数据管理'},{'code':'taglist','enName':'taglist','icon':'home','menuName':'标签管理','path':'http://baidu.com/orion/tag/list','key':'taglist','name':'标签管理'},{'code':'relation1','enName':'dadicasesearch1','icon':'home','menuName':'案件检索1','path':'/orion/case/relation1','key':'relation1','name':'案件检索1'},{'code':'dadicasesearch-0','enName':'dadicasesearch','icon':'home','menuName':'案件检索-0','path':'/orion/case/relation0','key':'dadicasesearch-0','name':'案件检索-0'},{'code':'dadicasesearch-1','enName':'dadicasesearch','icon':'home','menuName':'案件检索-1','path':'/orion/case/relation1','key':'dadicasesearch-1','name':'案件检索-1'},{'code':'dadicasesearch-2','enName':'dadicasesearch','icon':'home','menuName':'案件检索-2','path':'/orion/case/relation2','key':'dadicasesearch-2','name':'案件检索-2'},{'code':'dadicasesearch-3','enName':'dadicasesearch','icon':'home','menuName':'案件检索-3','path':'/orion/case/relation3','key':'dadicasesearch-3','name':'案件检索-3'},{'code':'dadicasesearch-4','enName':'dadicasesearch','icon':'home','menuName':'案件检索-4','path':'/orion/case/relation4','key':'dadicasesearch-4','name':'案件检索-4'},{'code':'dadicasesearch-5','enName':'dadicasesearch','icon':'home','menuName':'案件检索-5','path':'/orion/case/relation5','key':'dadicasesearch-5','name':'案件检索-5'},{'code':'dadicasesearch-6','enName':'dadicasesearch','icon':'home','menuName':'案件检索-6','path':'/orion/case/relation6','key':'dadicasesearch-6','name':'案件检索-6'},{'code':'dadicasesearch-7','enName':'dadicasesearch','icon':'home','menuName':'案件检索-7','path':'/orion/case/relation7','key':'dadicasesearch-7','name':'案件检索-7'},{'code':'dadicasesearch-8','enName':'dadicasesearch','icon':'home','menuName':'案件检索-8','path':'/orion/case/relation8','key':'dadicasesearch-8','name':'案件检索-8'}] ;\n setTabItems(tabs)\n }, [tabs, props.selectedKey])\n\n useEffect(() => {}, [props.orgAppListVisible])\n\n useEffect(() => {\n const tabsDom = getTabsDom()\n\n setArrowVisible(tabsDom.offsetWidth - tabsDom.parentNode.offsetWidth > 0)\n }, [tabItems])\n\n useEffect(() => {\n translateTabsDom(tabItems, selectedKey)\n }, [tabItems, selectedKey, appListVisible, orgListVisible, orgAppListVisible])\n\n return (\n <TabsContainer\n {...props}\n className={cn('tnt-layout-header-tabs', { [className]: className })}\n >\n <Tabs className=\"tnt-layout-header-tabs-content\" ref={tabsRef}>\n {tabItems.map((tab, index) => (\n <TabItem\n key={tab.key}\n theme={theme}\n className={cn({\n active: selectedKey === tab.key,\n activeTabPreSibling: tabItems[index + 1]?.key === selectedKey,\n })}\n onClick={() => onTabClick(tab, index)}\n >\n <a href={tab.key} onClick={(evt) => evt.preventDefault()}>\n {\n {\n cn: tab.name,\n en: tab.enName || tab.name,\n }[language || 'cn']\n }\n </a>\n {tab.closable !== false && tabItems.length > 1 && (\n <Icon type=\"close\" onClick={closeTabHandle.bind(null, tab, index)} />\n )}\n </TabItem>\n ))}\n </Tabs>\n {arrowVisible && (\n <div className=\"tnt-layout-header-tabs-arrows\">\n <Icon type=\"left\" onClick={onMoveToLeft} disabled={!tabsPositionFlags.start} />\n <Icon type=\"right\" onClick={onMoveToRight} disabled={!tabsPositionFlags.end} />\n </div>\n )}\n </TabsContainer>\n )\n }\n)\n\nexport default HeaderTabs\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Language.js","sourceRoot":"","sources":["../../src/tntd-layout/Language.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAuC;AACvC,uEAAqD;AACrD,mCAA4B;AAC5B,0DAAiC;AACjC,uCAA8D;AAE9D,MAAM,SAAS,GAAG;IAChB,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE;IAC3B,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE;CAC9B,CAAA;AACD,MAAM,YAAY,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;IACjD,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,CAAA;IACpB,OAAO,GAAG,CAAA;AACZ,CAAC,EAAE,EAAE,CAAC,CAAA;AAEN,MAAM,QAAQ,GAAG,2BAAM,CAAC,EAAE,CAAA;eACX,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;iBAE3D,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;iBAK7D,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;WACnE,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;;;;;CASvE,CAAA;AAED,kBAAe,IAAA,6BAAS,EAAC,CAAC,KAAK,EAAE,EAAE;IACjC,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAA;IAC1B,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,IAAI,IAAI,GAAG,IAAA,0BAAgB,GAAE,IAAI,KAAK,CAAC,QAAQ,CAAA;QAE/C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;YACvB,IAAI,GAAG,IAAA,YAAG,EAAC,SAAS,EAAE,SAAS,CAAC,CAAA;SACjC;QAED,OAAO,IAAI,CAAA;IACb,CAAC,CAAA;IACD,MAAM,CAAC,QAAQ,GAAG,IAAI,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,WAAW,EAAE,CAAC,CAAA;IAC9D,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,MAAM,IAAI,GAAG,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;QAE5C,WAAW,CAAC,IAAI,CAAC,CAAA;QACjB,IAAA,0BAAgB,EAAC,IAAI,CAAC,CAAA;QACtB,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAA;IAC5B,CAAC,CAAA;IAED,OAAO,CACL,8BAAC,QAAQ,IAAC,OAAO,EAAE,cAAc;QAC/B,8BAAC,kBAAQ,IAAC,IAAI,EAAE,QAAQ,QAAQ,EAAE,GAAI;QACtC,4CAAO,IAAA,YAAG,EAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAQ,CACzC,CACZ,CAAA;AACH,CAAC,CAAC,CAAA","sourcesContent":["import React, { useState } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport { get } from 'lodash'\nimport Iconfont from './Iconfont'\nimport { setLanguageStore, getLanguageStore } from './storage'\n\nconst languages = [\n { value: 'cn', name: '中文' },\n { value: 'en', name: ' EN ' },\n]\nconst languagesMap = languages.reduce((acc, cur) => {\n acc[cur.value] = cur\n return acc\n}, {})\n\nconst Language = styled.li`\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n .tnt-icon {\n font-size: ${({ theme: { size } }) => (size === 'large' ? '24px' : '20px')};\n margin-right: 4px;\n }\n span {\n position: relative;\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n top: ${({ theme: { size } }) => (size === 'large' ? '-3px' : '-2px')};\n font-family: auto;\n .tnt-themeS1 & {\n /* color: rgba(255,255,255,.85); */\n }\n }\n .isInIframe & {\n display: none;\n }\n`\n\nexport default withTheme((props) => {\n const { onChange } = props\n const getLanguage = () => {\n let lang = getLanguageStore() || props.language\n\n if (!languagesMap[lang]) {\n lang = get(languages, '0.value')\n }\n\n return lang\n }\n const [language = 'cn', setLanguage] = useState(getLanguage())\n const switchLanguage = () => {\n const lang = language === 'cn' ? 'en' : 'cn'\n\n setLanguage(lang)\n setLanguageStore(lang)\n onChange && onChange(lang)\n }\n\n return (\n <Language onClick={switchLanguage}>\n <Iconfont type={`flag-${language}`} />\n <span>{get(languagesMap[language], 'name')}</span>\n </Language>\n )\n})\n"]}
1
+ {"version":3,"file":"Language.js","sourceRoot":"","sources":["../../src/tntd-layout/Language.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAuC;AACvC,uEAAqD;AACrD,mCAA4B;AAC5B,0DAAiC;AACjC,uCAA8D;AAE9D,MAAM,SAAS,GAAG;IAChB,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE;IAC3B,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE;CAC9B,CAAA;AACD,MAAM,YAAY,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;IACjD,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,CAAA;IACpB,OAAO,GAAG,CAAA;AACZ,CAAC,EAAE,EAAE,CAAC,CAAA;AAEN,MAAM,QAAQ,GAAG,2BAAM,CAAC,EAAE,CAAA;eACX,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;iBAE3D,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;iBAK7D,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;WACnE,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;;;;;;CASvE,CAAA;AAED,kBAAe,IAAA,6BAAS,EAAC,CAAC,KAAK,EAAE,EAAE;IACjC,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAA;IAC1B,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,IAAI,IAAI,GAAG,IAAA,0BAAgB,GAAE,IAAI,KAAK,CAAC,QAAQ,CAAA;QAE/C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;YACvB,IAAI,GAAG,IAAA,YAAG,EAAC,SAAS,EAAE,SAAS,CAAC,CAAA;SACjC;QAED,OAAO,IAAI,CAAA;IACb,CAAC,CAAA;IACD,MAAM,CAAC,QAAQ,GAAG,IAAI,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,WAAW,EAAE,CAAC,CAAA;IAC9D,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,MAAM,IAAI,GAAG,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;QAE5C,WAAW,CAAC,IAAI,CAAC,CAAA;QACjB,IAAA,0BAAgB,EAAC,IAAI,CAAC,CAAA;QACtB,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAA;IAC5B,CAAC,CAAA;IAED,OAAO,CACL,8BAAC,QAAQ,IAAC,OAAO,EAAE,cAAc;QAC/B,8BAAC,kBAAQ,IAAC,IAAI,EAAE,QAAQ,QAAQ,EAAE,GAAI;QACtC,4CAAO,IAAA,YAAG,EAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAQ,CACzC,CACZ,CAAA;AACH,CAAC,CAAC,CAAA","sourcesContent":["import React, { useState } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport { get } from 'lodash'\nimport Iconfont from './Iconfont'\nimport { setLanguageStore, getLanguageStore } from './storage'\n\nconst languages = [\n { value: 'cn', name: '中文' },\n { value: 'en', name: ' EN ' },\n]\nconst languagesMap = languages.reduce((acc, cur) => {\n acc[cur.value] = cur\n return acc\n}, {})\n\nconst Language = styled.li`\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n .tnt-icon {\n font-size: ${({ theme: { size } }) => (size === 'large' ? '24px' : '20px')};\n margin-right: 4px;\n }\n span {\n position: relative;\n font-size: ${({ theme: { size } }) => (size === 'large' ? '14px' : '12px')};\n top: ${({ theme: { size } }) => (size === 'large' ? '-3px' : '-2px')};\n font-family: auto;\n .tnt-themeS1 & {\n /* color: rgba(255,255,255,.85); */\n }\n }\n .isInIframe & {\n display: none;\n }\n`\n\nexport default withTheme((props) => {\n const { onChange } = props\n const getLanguage = () => {\n let lang = getLanguageStore() || props.language\n\n if (!languagesMap[lang]) {\n lang = get(languages, '0.value')\n }\n\n return lang\n }\n const [language = 'cn', setLanguage] = useState(getLanguage())\n const switchLanguage = () => {\n const lang = language === 'cn' ? 'en' : 'cn'\n\n setLanguage(lang)\n setLanguageStore(lang)\n onChange && onChange(lang)\n }\n\n return (\n <Language onClick={switchLanguage}>\n <Iconfont type={`flag-${language}`} />\n <span>{get(languagesMap[language], 'name')}</span>\n </Language>\n )\n})\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Layout.js","sourceRoot":"","sources":["../../src/tntd-layout/Layout.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport cn from 'classnames'\nimport { isUndefined } from 'lodash'\nimport Layout from '../layout'\nimport Icon from '../tntd-icon'\nimport Header from './Header'\nimport Logo from './Logo'\nimport SideMenu from './SideMenu'\nimport { getSideMenuStore, setSideMenuStore, getLanguageStore, getThemeStore } from './storage'\n\nconst { Content, Sider } = Layout\nconst TNTLayout = styled(Layout)`\n position: relative;\n .tnt-layout-sider {\n overflow-x: hidden;\n background: #191d29;\n }\n .tnt-layout-menu-collapse {\n position: absolute;\n bottom: 0;\n left: 0;\n line-height: 36px;\n background: #191d29;\n box-shadow: 0 0 6px 0 rgb(0 0 0 / 10%);\n color: #fff;\n width: 100%;\n padding-left: 24px;\n font-size: 14px;\n cursor: pointer;\n }\n &.isInIframe,\n &.isEmptyLayout {\n .tnt-layout-sider {\n display: none;\n }\n }\n &.compatible .tnt-layout-sider {\n background: linear-gradient(#213f83, #0f75d6) !important;\n }\n &.tnt-themeS1 {\n .tnt-layout-sider {\n background: #fff !important;\n overflow-x: unset;\n }\n .tnt-layout-menu-collapse {\n z-index: 3;\n background: #fff;\n color: ${(props) => props.theme.primaryTextColor};\n }\n }\n // 蓝色系列\n &.tnt-themeS3 {\n .tnt-layout-sider {\n background-image: linear-gradient(180deg, #213f83 0%, #0f75d6 100%) !important;\n overflow-x: unset;\n }\n .tnt-layout-menu-collapse {\n background: #207ad4;\n color: #fff;\n }\n }\n & > .ant-layout-content {\n background-color: ${(props) => props.theme.lightBgColor};\n & > div:nth-child(2) {\n height: calc(100vh - 50px);\n overflow: auto;\n }\n }\n &.large-size > .ant-layout-content {\n & > div:nth-child(2) {\n height: calc(100vh - 60px);\n }\n }\n`\n\nexport default withTheme((props) => {\n const {\n type,\n logo,\n name,\n enName,\n selectedOrgKey,\n orgAppShow,\n orgList,\n orgAppList,\n onOrgChange,\n selectedAppKey,\n appList,\n selectedMenuKey,\n menuAlignMode = 'side',\n collapseIconPlacement = 'right',\n menus = [],\n formatMenuPath,\n changeRouter,\n headerTabs,\n orgTreeConfig,\n headerNavs,\n extraHeaderActions,\n isInIframe,\n isEmptyLayout,\n onLogoClick = () => null,\n onCollapseChange,\n onThemeChange,\n onLanguageChange,\n onBeforeMenuChange,\n onMenuChange,\n onMenuSelect,\n onAppChange,\n onPersonalSetting,\n onChangePassword,\n onLogout,\n config,\n extendMap = {},\n AvatarCustom, // 右上角用户信息自定义\n } = props\n let { collapsed: storeCollapsed, openKeys = [] } = getSideMenuStore()\n const [collapsed, setCollapsed] = useState(\n isUndefined(storeCollapsed) ? props.collapsed : storeCollapsed\n )\n const [openMenuKeys, setOpenMenuKeys] = useState(\n (() => {\n openKeys = collapsed ? [] : openKeys\n openKeys = openKeys instanceof Array ? openKeys : []\n return openKeys\n })(openKeys)\n )\n const [userInfo, setUserInfo] = useState(props.userInfo || {})\n let theme = getThemeStore() || extendMap?.defaultTheme || userInfo.theme || 'themeS2'\n const language = getLanguageStore() || userInfo.lang || 'cn'\n theme = theme === 'default' ? 'themeS2' : theme\n\n const collapseChangeHandle = () => {\n const { beforeOpenKeys = [] } = getSideMenuStore()\n const newCollapsed = !collapsed\n\n // 菜单收起:记住当前展开子菜单到store,并收起子菜单\n if (newCollapsed) {\n setSideMenuStore({\n collapsed: newCollapsed,\n beforeOpenKeys: openMenuKeys,\n })\n setOpenMenuKeys([])\n } else {\n // 菜单展开:恢复子菜单展开项,并更新到store\n setSideMenuStore({\n collapsed: newCollapsed,\n openKeys: beforeOpenKeys,\n })\n setOpenMenuKeys(beforeOpenKeys)\n }\n\n setCollapsed(newCollapsed)\n onCollapseChange && onCollapseChange(newCollapsed)\n }\n\n useEffect(() => {\n setUserInfo(props.userInfo)\n }, [props.userInfo])\n\n return (\n <TNTLayout\n className={cn(`tnt-layout tnt-${theme} ${props.className || ''}`, {\n 'large-size': props.theme.size === 'large',\n compatible: props.theme.compatible,\n isInIframe,\n isEmptyLayout,\n noAppList: !appList,\n hasHeaderTabs: !!headerTabs,\n layoutMenusCollapsed: collapsed,\n collapseIconPlacementBottom: collapseIconPlacement === 'bottom',\n })}\n >\n <Sider\n collapsible\n breakpoint=\"md\"\n className=\"tnt-layout-sider\"\n collapsed={collapsed}\n width={220}\n trigger={null}\n >\n <Logo\n language={language}\n logo={logo}\n name={name}\n enName={enName}\n collapsed={collapsed}\n onClick={onLogoClick}\n />\n <SideMenu\n language={language}\n selectedKey={selectedMenuKey}\n menuAlignMode={menuAlignMode}\n menus={menus}\n collapsed={collapsed}\n openKeys={openMenuKeys}\n onOpenChange={(keys) => {\n if (!collapsed) {\n setSideMenuStore({\n openKeys: keys,\n beforeOpenKeys: keys,\n })\n }\n\n setOpenMenuKeys(keys)\n }}\n formatMenuPath={formatMenuPath}\n changeRouter={changeRouter}\n onBeforeChange={onBeforeMenuChange}\n onChange={onMenuChange}\n onSelect={onMenuSelect}\n />\n {collapseIconPlacement === 'bottom' && (\n <div className=\"tnt-layout-menu-collapse\" onClick={collapseChangeHandle}>\n <Icon type={`menu-${collapsed ? 'unfold' : 'fold'}`} />\n </div>\n )}\n </Sider>\n <Content>\n <Header\n type={type}\n userInfo={userInfo}\n config={config}\n collapsed={collapsed}\n collapseIconPlacement={collapseIconPlacement}\n orgAppShow={orgAppShow}\n orgList={orgList}\n orgTreeConfig={orgTreeConfig}\n orgAppList={orgAppList}\n onOrgChange={onOrgChange}\n selectedOrgKey={selectedOrgKey}\n selectedAppKey={selectedAppKey}\n appList={appList}\n menus={menus}\n headerTabs={headerTabs}\n extraActions={extraHeaderActions}\n onAppChange={onAppChange}\n onCollapseChange={collapseChangeHandle}\n AvatarCustom={AvatarCustom}\n onThemeChange={(theme) => {\n setUserInfo({\n ...userInfo,\n theme,\n })\n onThemeChange && onThemeChange(theme)\n }}\n onLanguageChange={(lang) => {\n setUserInfo({\n ...userInfo,\n lang,\n })\n onLanguageChange && onLanguageChange(lang)\n }}\n onPersonalSetting={onPersonalSetting}\n onChangePassword={onChangePassword}\n onLogout={onLogout}\n >\n {headerNavs}\n </Header>\n {props.children}\n </Content>\n </TNTLayout>\n )\n})\n"]}
1
+ {"version":3,"file":"Layout.js","sourceRoot":"","sources":["../../src/tntd-layout/Layout.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport cn from 'classnames'\nimport { isUndefined } from 'lodash'\nimport Layout from '../layout'\nimport Icon from '../tntd-icon'\nimport Header from './Header'\nimport Logo from './Logo'\nimport SideMenu from './SideMenu'\nimport { getSideMenuStore, setSideMenuStore, getLanguageStore, getThemeStore } from './storage'\n\nconst { Content, Sider } = Layout\nconst TNTLayout = styled(Layout)`\n position: relative;\n .tnt-layout-sider {\n overflow-x: hidden;\n background: #191d29;\n }\n .tnt-layout-menu-collapse {\n position: absolute;\n bottom: 0;\n left: 0;\n line-height: 36px;\n background: #191d29;\n box-shadow: 0 0 6px 0 rgb(0 0 0 / 10%);\n color: #fff;\n width: 100%;\n padding-left: 24px;\n font-size: 14px;\n cursor: pointer;\n }\n &.isInIframe,\n &.isEmptyLayout {\n .tnt-layout-sider {\n display: none;\n }\n }\n &.compatible .tnt-layout-sider {\n background: linear-gradient(#213f83, #0f75d6) !important;\n }\n &.tnt-themeS1 {\n .tnt-layout-sider {\n background: #fff !important;\n overflow-x: unset;\n }\n .tnt-layout-menu-collapse {\n z-index: 3;\n background: #fff;\n color: ${(props) => props.theme.primaryTextColor};\n }\n }\n // 蓝色系列\n &.tnt-themeS3 {\n .tnt-layout-sider {\n background-image: linear-gradient(180deg, #213f83 0%, #0f75d6 100%) !important;\n overflow-x: unset;\n }\n .tnt-layout-menu-collapse {\n background: #207ad4;\n color: #fff;\n }\n }\n & > .ant-layout-content {\n background-color: ${(props) => props.theme.lightBgColor};\n & > div:nth-child(2) {\n height: calc(100vh - 50px);\n overflow: auto;\n }\n }\n &.large-size > .ant-layout-content {\n & > div:nth-child(2) {\n height: calc(100vh - 60px);\n }\n }\n`\n\nexport default withTheme((props) => {\n const {\n type,\n logo,\n name,\n enName,\n selectedOrgKey,\n orgAppShow,\n orgList,\n orgAppList,\n onOrgChange,\n selectedAppKey,\n appList,\n selectedMenuKey,\n menuAlignMode = 'side',\n collapseIconPlacement = 'right',\n menus = [],\n formatMenuPath,\n changeRouter,\n headerTabs,\n orgTreeConfig,\n headerNavs,\n extraHeaderActions,\n isInIframe,\n isEmptyLayout,\n onLogoClick = () => null,\n onCollapseChange,\n onThemeChange,\n onLanguageChange,\n onBeforeMenuChange,\n onMenuChange,\n onMenuSelect,\n onAppChange,\n onPersonalSetting,\n onChangePassword,\n onLogout,\n config,\n extendMap = {},\n AvatarCustom, // 右上角用户信息自定义\n } = props\n let { collapsed: storeCollapsed, openKeys = [] } = getSideMenuStore()\n const [collapsed, setCollapsed] = useState(\n isUndefined(storeCollapsed) ? props.collapsed : storeCollapsed\n )\n const [openMenuKeys, setOpenMenuKeys] = useState(\n (() => {\n openKeys = collapsed ? [] : openKeys\n openKeys = openKeys instanceof Array ? openKeys : []\n return openKeys\n })(openKeys)\n )\n const [userInfo, setUserInfo] = useState(props.userInfo || {})\n let theme = getThemeStore() || extendMap?.defaultTheme || userInfo.theme || 'themeS2'\n const language = getLanguageStore() || userInfo.lang || 'cn'\n theme = theme === 'default' ? 'themeS2' : theme\n\n const collapseChangeHandle = () => {\n const { beforeOpenKeys = [] } = getSideMenuStore()\n const newCollapsed = !collapsed\n\n // 菜单收起:记住当前展开子菜单到store,并收起子菜单\n if (newCollapsed) {\n setSideMenuStore({\n collapsed: newCollapsed,\n beforeOpenKeys: openMenuKeys,\n })\n setOpenMenuKeys([])\n } else {\n // 菜单展开:恢复子菜单展开项,并更新到store\n setSideMenuStore({\n collapsed: newCollapsed,\n openKeys: beforeOpenKeys,\n })\n setOpenMenuKeys(beforeOpenKeys)\n }\n\n setCollapsed(newCollapsed)\n onCollapseChange && onCollapseChange(newCollapsed)\n }\n\n useEffect(() => {\n setUserInfo(props.userInfo)\n }, [props.userInfo])\n\n return (\n <TNTLayout\n className={cn(`tnt-layout tnt-${theme} ${props.className || ''}`, {\n 'large-size': props.theme.size === 'large',\n compatible: props.theme.compatible,\n isInIframe,\n isEmptyLayout,\n noAppList: !appList,\n hasHeaderTabs: !!headerTabs,\n layoutMenusCollapsed: collapsed,\n collapseIconPlacementBottom: collapseIconPlacement === 'bottom',\n })}\n >\n <Sider\n collapsible\n breakpoint=\"md\"\n className=\"tnt-layout-sider\"\n collapsed={collapsed}\n width={220}\n trigger={null}\n >\n <Logo\n language={language}\n logo={logo}\n name={name}\n enName={enName}\n collapsed={collapsed}\n onClick={onLogoClick}\n />\n <SideMenu\n language={language}\n selectedKey={selectedMenuKey}\n menuAlignMode={menuAlignMode}\n menus={menus}\n collapsed={collapsed}\n openKeys={openMenuKeys}\n onOpenChange={(keys) => {\n if (!collapsed) {\n setSideMenuStore({\n openKeys: keys,\n beforeOpenKeys: keys,\n })\n }\n\n setOpenMenuKeys(keys)\n }}\n formatMenuPath={formatMenuPath}\n changeRouter={changeRouter}\n onBeforeChange={onBeforeMenuChange}\n onChange={onMenuChange}\n onSelect={onMenuSelect}\n />\n {collapseIconPlacement === 'bottom' && (\n <div className=\"tnt-layout-menu-collapse\" onClick={collapseChangeHandle}>\n <Icon type={`menu-${collapsed ? 'unfold' : 'fold'}`} />\n </div>\n )}\n </Sider>\n <Content>\n <Header\n type={type}\n userInfo={userInfo}\n config={config}\n collapsed={collapsed}\n collapseIconPlacement={collapseIconPlacement}\n orgAppShow={orgAppShow}\n orgList={orgList}\n orgTreeConfig={orgTreeConfig}\n orgAppList={orgAppList}\n onOrgChange={onOrgChange}\n selectedOrgKey={selectedOrgKey}\n selectedAppKey={selectedAppKey}\n appList={appList}\n menus={menus}\n headerTabs={headerTabs}\n extraActions={extraHeaderActions}\n onAppChange={onAppChange}\n onCollapseChange={collapseChangeHandle}\n AvatarCustom={AvatarCustom}\n onThemeChange={(theme) => {\n setUserInfo({\n ...userInfo,\n theme,\n })\n onThemeChange && onThemeChange(theme)\n }}\n onLanguageChange={(lang) => {\n setUserInfo({\n ...userInfo,\n lang,\n })\n onLanguageChange && onLanguageChange(lang)\n }}\n onPersonalSetting={onPersonalSetting}\n onChangePassword={onChangePassword}\n onLogout={onLogout}\n >\n {headerNavs}\n </Header>\n {props.children}\n </Content>\n </TNTLayout>\n )\n})\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Logo.js","sourceRoot":"","sources":["../../src/tntd-layout/Logo.js"],"names":[],"mappings":"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","sourcesContent":["/**\n * @file Logo\n * @author zhangyou\n */\nimport React from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport { logoImgMap } from './images'\n\nconst Logo = styled.div`\n height: ${(props) => `${props.theme.headerHeight}px`};\n line-height: ${(props) => `${props.theme.headerHeight}px`};\n padding-left: 15px;\n width: 220px;\n background: #191d29;\n font-size: ${(props) => `${props.fontSize}px`};\n color: rgba(226, 237, 255, 0.9);\n letter-spacing: 0;\n position: relative;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n &:after {\n position: absolute;\n bottom: -12px;\n left: 0;\n background-image: linear-gradient(0deg, #191d29 23%, #151924 93%);\n content: '';\n width: 100%;\n height: 12px;\n }\n\n .ant-layout-sider-collapsed & {\n padding-left: 26px;\n }\n\n .compatible & {\n background: #213f83;\n color: #a1d7ff;\n box-shadow: 0 1px 8px 0 rgba(0, 0, 0, 0.3);\n &:after {\n display: none;\n }\n }\n cursor: pointer;\n font-weight: 400;\n text-rendering: optimizeLegibility;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n\n .tnt-themeS1 & {\n background: #ffffff !important;\n box-shadow: 2px 3px 8px -1px rgba(0, 0, 0, 0.15);\n color: #17233d;\n &:after {\n display: none;\n }\n }\n\n .tnt-themeS1.compatible & {\n background: #323b4a;\n }\n\n // 蓝色主题\n .tnt-themeS3 & {\n background: ${(props) => `${props.theme.blueBgColor} !important`}; //#1D4295 !important;\n box-shadow: 2px 3px 8px -1px rgba(0, 0, 0, 0.15);\n color: #ffffff;\n &:after {\n display: none;\n }\n }\n\n img {\n position: relative;\n top: -1px;\n width: 23px;\n height: 23px;\n margin-right: 12px;\n .large-size & {\n width: 28px;\n height: 28px;\n }\n }\n`\n\n// JS判断字符串长度(英文占1个字符,中文汉字占2个字符)\nconst getStrLen = (str = '') => {\n let len = 0\n\n for (let i = 0; i < str.length; i++) {\n let c = str.charCodeAt(i)\n let chartLength = 2\n\n //单字节加1\n if ((c >= 0x0001 && c <= 0x007e) || (0xff60 <= c && c <= 0xff9f)) {\n chartLength = 1\n }\n\n len += chartLength\n }\n\n return len\n}\n\nexport default withTheme((props) => {\n const {\n logo,\n name,\n enName,\n language,\n collapsed,\n theme: { size },\n } = props\n const productNameLen = getStrLen(language === 'cn' ? name : enName)\n const fontSize =\n {\n 12: 19,\n 13: 18,\n 14: 17,\n 15: 16,\n 16: 15,\n }[Math.max(12, Math.min(productNameLen, 16))] + (size === 'large' ? 1 : 0)\n const LogoImg = (props) => (\n <img\n onError={(e) => {\n e.target.onerror = null\n e.target.src = logoImgMap.default\n }}\n {...props}\n />\n )\n\n return (\n <Logo {...props} fontSize={fontSize}>\n {typeof logo === 'string' ? (\n <LogoImg src={logoImgMap[logo] || logoImgMap.default} />\n ) : logo && logo.type === 'img' ? (\n <LogoImg {...logo.props} src={logo.props?.src || logoImgMap.default} />\n ) : (\n logo\n )}\n {collapsed\n ? ''\n : {\n cn: name,\n en: enName,\n }[language]}\n </Logo>\n )\n})\n"]}
1
+ {"version":3,"file":"Logo.js","sourceRoot":"","sources":["../../src/tntd-layout/Logo.js"],"names":[],"mappings":"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","sourcesContent":["/**\n * @file Logo\n * @author zhangyou\n */\nimport React from 'react'\nimport styled, { withTheme } from 'styled-components'\nimport { logoImgMap } from './images'\n\nconst Logo = styled.div`\n height: ${(props) => `${props.theme.headerHeight}px`};\n line-height: ${(props) => `${props.theme.headerHeight}px`};\n padding-left: 15px;\n width: 220px;\n background: #191d29;\n font-size: ${(props) => `${props.fontSize}px`};\n color: rgba(226, 237, 255, 0.9);\n letter-spacing: 0;\n position: relative;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n &:after {\n position: absolute;\n bottom: -12px;\n left: 0;\n background-image: linear-gradient(0deg, #191d29 23%, #151924 93%);\n content: '';\n width: 100%;\n height: 12px;\n }\n\n .ant-layout-sider-collapsed & {\n padding-left: 26px;\n }\n\n .compatible & {\n background: #213f83;\n color: #a1d7ff;\n box-shadow: 0 1px 8px 0 rgba(0, 0, 0, 0.3);\n &:after {\n display: none;\n }\n }\n cursor: pointer;\n font-weight: 400;\n text-rendering: optimizeLegibility;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n\n .tnt-themeS1 & {\n background: #ffffff !important;\n box-shadow: 2px 3px 8px -1px rgba(0, 0, 0, 0.15);\n color: #17233d;\n &:after {\n display: none;\n }\n }\n\n .tnt-themeS1.compatible & {\n background: #323b4a;\n }\n\n // 蓝色主题\n .tnt-themeS3 & {\n background: ${(props) => `${props.theme.blueBgColor} !important`}; //#1D4295 !important;\n box-shadow: 2px 3px 8px -1px rgba(0, 0, 0, 0.15);\n color: #ffffff;\n &:after {\n display: none;\n }\n }\n\n img {\n position: relative;\n top: -1px;\n width: 23px;\n height: 23px;\n margin-right: 12px;\n .large-size & {\n width: 28px;\n height: 28px;\n }\n }\n`\n\n// JS判断字符串长度(英文占1个字符,中文汉字占2个字符)\nconst getStrLen = (str = '') => {\n let len = 0\n\n for (let i = 0; i < str.length; i++) {\n let c = str.charCodeAt(i)\n let chartLength = 2\n\n //单字节加1\n if ((c >= 0x0001 && c <= 0x007e) || (0xff60 <= c && c <= 0xff9f)) {\n chartLength = 1\n }\n\n len += chartLength\n }\n\n return len\n}\n\nexport default withTheme((props) => {\n const {\n logo,\n name,\n enName,\n language,\n collapsed,\n theme: { size },\n } = props\n const productNameLen = getStrLen(language === 'cn' ? name : enName)\n const fontSize =\n {\n 12: 19,\n 13: 18,\n 14: 17,\n 15: 16,\n 16: 15,\n }[Math.max(12, Math.min(productNameLen, 16))] + (size === 'large' ? 1 : 0)\n const LogoImg = (props) => (\n <img\n onError={(e) => {\n e.target.onerror = null\n e.target.src = logoImgMap.default\n }}\n {...props}\n />\n )\n\n return (\n <Logo {...props} fontSize={fontSize}>\n {typeof logo === 'string' ? (\n <LogoImg src={logoImgMap[logo] || logoImgMap.default} />\n ) : logo && logo.type === 'img' ? (\n <LogoImg {...logo.props} src={logo.props?.src || logoImgMap.default} />\n ) : (\n logo\n )}\n {collapsed\n ? ''\n : {\n cn: name,\n en: enName,\n }[language]}\n </Logo>\n )\n})\n"]}