@plesk/ui-library 3.35.2 → 3.35.3

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 (267) hide show
  1. package/cjs/components/Action/Action.js +1 -2
  2. package/cjs/components/Alert/Alert.js +1 -2
  3. package/cjs/components/AutoClosable/AutoClosable.js +1 -2
  4. package/cjs/components/AuxiliaryActions/AuxiliaryActions.js +1 -2
  5. package/cjs/components/Badge/Badge.js +1 -2
  6. package/cjs/components/Breadcrumbs/Breadcrumbs.js +1 -2
  7. package/cjs/components/Button/Button.js +1 -2
  8. package/cjs/components/Button/ButtonContext.js +2 -4
  9. package/cjs/components/ButtonGroup/ButtonGroup.js +1 -2
  10. package/cjs/components/Card/Card.js +1 -2
  11. package/cjs/components/Card/CardButton.js +1 -2
  12. package/cjs/components/Card/PreviewPanel.js +1 -2
  13. package/cjs/components/CardList/CardList.js +5 -10
  14. package/cjs/components/CardList/CardListToolbar.js +1 -2
  15. package/cjs/components/Carousel/Carousel.js +1 -2
  16. package/cjs/components/Checkbox/Checkbox.js +1 -2
  17. package/cjs/components/ClosingConfirmation/locale/en-US.js +2 -3
  18. package/cjs/components/ClosingConfirmation/useClosingConfirmation.js +1 -2
  19. package/cjs/components/CodeEditor/CodeEditor.js +1 -2
  20. package/cjs/components/Columns/Column.js +1 -2
  21. package/cjs/components/Columns/Columns.js +1 -2
  22. package/cjs/components/ComboBox/ComboBox.js +1 -2
  23. package/cjs/components/ComboBox/ComboBoxOption.js +1 -2
  24. package/cjs/components/ComboBoxDropdown/ComboBoxDropdown.js +1 -2
  25. package/cjs/components/ConsoleOutput/ConsoleOutput.js +1 -2
  26. package/cjs/components/ContentLoader/ContentLoader.js +1 -2
  27. package/cjs/components/ContentLoader/IconsLoader.js +1 -2
  28. package/cjs/components/Cuttable/Cuttable.js +1 -2
  29. package/cjs/components/Dialog/Dialog.js +1 -2
  30. package/cjs/components/DistractionFreeModeContext/DistractionFreeModeContext.js +1 -2
  31. package/cjs/components/Drawer/Drawer.js +1 -2
  32. package/cjs/components/Drawer/DrawerProgress.js +1 -2
  33. package/cjs/components/Drawer/Header.js +1 -2
  34. package/cjs/components/Dropdown/Dropdown.js +1 -2
  35. package/cjs/components/Dropdown/locale/en-US.js +2 -3
  36. package/cjs/components/ExtendedStatusMessage/ExtendedStatusMessage.js +1 -2
  37. package/cjs/components/ExtendedStatusMessage/ExtendedStatusMessageActions.js +1 -2
  38. package/cjs/components/ExtendedStatusMessage/ExtendedStatusMessageDescription.js +1 -2
  39. package/cjs/components/ExtendedStatusMessage/ExtendedStatusMessageSeparator.js +1 -2
  40. package/cjs/components/ExtendedStatusMessage/ExtendedStatusMessageTitle.js +1 -2
  41. package/cjs/components/Figure/Figure.js +1 -2
  42. package/cjs/components/FocusTrap/FocusTrap.js +1 -2
  43. package/cjs/components/Form/DisabledContext.js +1 -2
  44. package/cjs/components/Form/Form.js +1 -2
  45. package/cjs/components/Form/FormContext.js +1 -2
  46. package/cjs/components/Form/ScrollableElementFormContext.js +1 -2
  47. package/cjs/components/FormField/FormField.js +4 -4
  48. package/cjs/components/FormField/index.js +9 -2
  49. package/cjs/components/FormFieldCheckbox/FormFieldCheckbox.js +1 -2
  50. package/cjs/components/FormFieldPassword/FormFieldPassword.js +1 -2
  51. package/cjs/components/FormFieldPassword/PasswordMeter.js +2 -3
  52. package/cjs/components/FormFieldPassword/estimatePassword.js +3 -5
  53. package/cjs/components/FormFieldPassword/generatePassword.js +1 -2
  54. package/cjs/components/FormFieldPassword/locale/en-US.js +2 -3
  55. package/cjs/components/FormFieldRadioButtons/FormFieldRadioButtons.js +65 -134
  56. package/cjs/components/FormFieldSelect/FormFieldSelect.js +1 -2
  57. package/cjs/components/FormFieldText/FormFieldText.js +56 -143
  58. package/cjs/components/Grid/Grid.js +1 -2
  59. package/cjs/components/GridCol/GridCol.js +1 -2
  60. package/cjs/components/Heading/Heading.js +1 -2
  61. package/cjs/components/Hint/Hint.js +1 -2
  62. package/cjs/components/Icon/Icon.js +10 -20
  63. package/cjs/components/Icon/constants.js +2 -4
  64. package/cjs/components/Icon/images/symbols.svg +39 -1
  65. package/cjs/components/Icon/oldIconNames.js +1 -2
  66. package/cjs/components/InPlaceEdit/InPlaceEdit.js +7 -29
  67. package/cjs/components/InPlaceEdit/locale/en-US.js +2 -3
  68. package/cjs/components/Input/Input.js +1 -2
  69. package/cjs/components/InputFile/InputFile.js +1 -2
  70. package/cjs/components/InputFile/locale/en-US.js +2 -3
  71. package/cjs/components/InputNumber/InputNumber.js +1 -2
  72. package/cjs/components/Item/Item.js +1 -2
  73. package/cjs/components/ItemLink/ItemLink.js +1 -2
  74. package/cjs/components/ItemList/ItemList.js +1 -2
  75. package/cjs/components/Label/Label.js +1 -2
  76. package/cjs/components/Layer/Layer.js +2 -4
  77. package/cjs/components/Layout/Layout.js +32 -123
  78. package/cjs/components/Link/Link.js +1 -2
  79. package/cjs/components/List/List.js +2 -2
  80. package/cjs/components/List/ListAction.js +1 -2
  81. package/cjs/components/List/ListActions.js +1 -2
  82. package/cjs/components/List/ListActionsDivider.js +1 -2
  83. package/cjs/components/List/ListEmptyView.js +1 -2
  84. package/cjs/components/List/ListOperation.js +2 -3
  85. package/cjs/components/List/ListOperationContext.js +1 -2
  86. package/cjs/components/LocaleProvider/LocaleProvider.js +1 -2
  87. package/cjs/components/Markdown/Markdown.js +1 -2
  88. package/cjs/components/Media/Media.js +5 -76
  89. package/cjs/components/Media/MediaSection.js +4 -26
  90. package/cjs/components/Menu/Menu.js +6 -58
  91. package/cjs/components/Menu/MenuBaseItem.js +5 -45
  92. package/cjs/components/Menu/MenuDivider.js +4 -20
  93. package/cjs/components/Menu/MenuHeader.js +4 -26
  94. package/cjs/components/Menu/MenuItem.js +7 -65
  95. package/cjs/components/Menu/MenuSelectableItem.js +5 -33
  96. package/cjs/components/OnDarkContext/OnDarkContext.js +1 -2
  97. package/cjs/components/Overlay/Overlay.js +1 -2
  98. package/cjs/components/PageHeader/PageHeader.js +1 -2
  99. package/cjs/components/Pagination/Pagination.js +2 -4
  100. package/cjs/components/Panel/Panel.js +1 -2
  101. package/cjs/components/Paragraph/Paragraph.js +1 -2
  102. package/cjs/components/Plaintext/Plaintext.js +3 -25
  103. package/cjs/components/Popover/Popover.js +22 -118
  104. package/cjs/components/Popper/Popper.js +1 -2
  105. package/cjs/components/Progress/Progress.js +1 -2
  106. package/cjs/components/ProgressBar/ProgressBar.js +1 -2
  107. package/cjs/components/ProgressBar/ProgressIndicator.js +1 -2
  108. package/cjs/components/ProgressDialog/ProgressDialog.js +1 -2
  109. package/cjs/components/ProgressDialogStep/ProgressDialogStep.js +1 -2
  110. package/cjs/components/ProgressStep/ProgressStep.js +7 -14
  111. package/cjs/components/Radio/Radio.js +1 -2
  112. package/cjs/components/Rating/Rating.js +1 -2
  113. package/cjs/components/ResponsiveContext/ResponsiveContext.js +1 -2
  114. package/cjs/components/Section/Section.js +30 -100
  115. package/cjs/components/Section/SectionItem.js +7 -46
  116. package/cjs/components/Section/index.js +16 -3
  117. package/cjs/components/SegmentedControl/SegmentedControl.js +1 -2
  118. package/cjs/components/Select/MultiValue.js +1 -2
  119. package/cjs/components/Select/Select.js +1 -2
  120. package/cjs/components/Select/SelectControl.js +1 -2
  121. package/cjs/components/Select/SelectOption.js +1 -2
  122. package/cjs/components/Select/SelectOptionGroup.js +1 -2
  123. package/cjs/components/Skeleton/Skeleton.js +1 -2
  124. package/cjs/components/Skeleton/SkeletonTabs.js +1 -2
  125. package/cjs/components/Skeleton/SkeletonText.js +1 -2
  126. package/cjs/components/Spinner/Spinner.js +1 -2
  127. package/cjs/components/SplitButton/SplitButton.js +1 -2
  128. package/cjs/components/Spot/Spot.js +1 -2
  129. package/cjs/components/Spot/SpotPopup.js +1 -2
  130. package/cjs/components/Spot/SpotPulsar.js +1 -2
  131. package/cjs/components/Squeezer/Squeezer.js +1 -2
  132. package/cjs/components/Status/Status.js +1 -2
  133. package/cjs/components/StatusMessage/StatusMessage.js +1 -2
  134. package/cjs/components/Subnav/Subnav.js +11 -58
  135. package/cjs/components/Subnav/index.js +6 -12
  136. package/cjs/components/Switch/Switch.js +1 -2
  137. package/cjs/components/SwitchesPanel/SwitchesPanel.js +1 -2
  138. package/cjs/components/SwitchesPanelItem/SwitchesPanelItem.js +1 -2
  139. package/cjs/components/Tabs/SearchBar.js +1 -2
  140. package/cjs/components/Tabs/Tab.js +1 -2
  141. package/cjs/components/Tabs/Tabs.js +1 -2
  142. package/cjs/components/Text/Text.js +1 -2
  143. package/cjs/components/TextArea/TextArea.js +1 -2
  144. package/cjs/components/Toolbar/RegistryContext.js +1 -2
  145. package/cjs/components/Toolbar/Toolbar.js +6 -21
  146. package/cjs/components/Toolbar/ToolbarExpander.js +1 -2
  147. package/cjs/components/Toolbar/ToolbarGroup.js +21 -53
  148. package/cjs/components/Toolbar/ToolbarMenu.js +2 -3
  149. package/cjs/components/Tooltip/Tooltip.js +1 -2
  150. package/cjs/components/Tour/Tour.js +1 -2
  151. package/cjs/components/Translate/Translate.js +1 -2
  152. package/cjs/components/VerticalContext/VerticalContext.js +2 -4
  153. package/cjs/components/index.js +63 -55
  154. package/cjs/components/intentIconMap.js +2 -3
  155. package/cjs/index.js +1 -2
  156. package/cjs/publicPath.js +1 -2
  157. package/cjs/utils/types/DataAttributes.js +5 -0
  158. package/dist/images/symbols.svg +39 -1
  159. package/dist/plesk-ui-library-rtl.css +1 -1
  160. package/dist/plesk-ui-library-rtl.css.map +1 -1
  161. package/dist/plesk-ui-library.css +1 -1
  162. package/dist/plesk-ui-library.css.map +1 -1
  163. package/dist/plesk-ui-library.js +759 -1786
  164. package/dist/plesk-ui-library.js.map +1 -1
  165. package/dist/plesk-ui-library.min.js +5 -5
  166. package/dist/plesk-ui-library.min.js.map +1 -1
  167. package/esm/components/FormField/FormField.js +4 -2
  168. package/esm/components/FormField/index.js +2 -1
  169. package/esm/components/FormFieldPassword/PasswordMeter.js +1 -1
  170. package/esm/components/FormFieldRadioButtons/FormFieldRadioButtons.js +64 -132
  171. package/esm/components/FormFieldText/FormFieldText.js +55 -140
  172. package/esm/components/Icon/constants.js +2 -2
  173. package/esm/components/Icon/images/symbols.svg +39 -1
  174. package/esm/components/InPlaceEdit/InPlaceEdit.js +6 -25
  175. package/esm/components/Layout/Layout.js +32 -121
  176. package/esm/components/List/List.js +1 -0
  177. package/esm/components/List/ListOperation.js +1 -1
  178. package/esm/components/Media/Media.js +4 -74
  179. package/esm/components/Media/MediaSection.js +2 -25
  180. package/esm/components/Menu/Menu.js +5 -54
  181. package/esm/components/Menu/MenuBaseItem.js +4 -45
  182. package/esm/components/Menu/MenuDivider.js +2 -19
  183. package/esm/components/Menu/MenuHeader.js +2 -25
  184. package/esm/components/Menu/MenuItem.js +5 -62
  185. package/esm/components/Menu/MenuSelectableItem.js +3 -32
  186. package/esm/components/Plaintext/Plaintext.js +2 -23
  187. package/esm/components/Popover/Popover.js +21 -114
  188. package/esm/components/Section/Section.js +28 -97
  189. package/esm/components/Section/SectionItem.js +5 -41
  190. package/esm/components/Section/index.js +2 -1
  191. package/esm/components/Subnav/Subnav.js +10 -54
  192. package/esm/components/Subnav/index.js +1 -2
  193. package/esm/components/Toolbar/Toolbar.js +7 -21
  194. package/esm/components/Toolbar/ToolbarGroup.js +17 -50
  195. package/esm/components/Toolbar/ToolbarMenu.js +1 -1
  196. package/esm/components/index.js +5 -10
  197. package/esm/index.js +1 -1
  198. package/esm/utils/types/DataAttributes.js +1 -0
  199. package/package.json +21 -21
  200. package/styleguide/build/bundle.8058bbce.js +2 -0
  201. package/styleguide/images/symbols.svg +39 -1
  202. package/styleguide/index.html +2 -2
  203. package/types/src/components/AutoClosable/AutoClosable.d.ts +23 -2
  204. package/types/src/components/Button/Button.d.ts +1 -4
  205. package/types/src/components/Columns/Column.d.ts +2 -2
  206. package/types/src/components/Columns/Columns.d.ts +2 -2
  207. package/types/src/components/Columns/index.d.ts +2 -0
  208. package/types/src/components/DistractionFreeModeContext/DistractionFreeModeContext.d.ts +1 -1
  209. package/types/src/components/DistractionFreeModeContext/index.d.ts +1 -0
  210. package/types/src/components/FormFieldPassword/PasswordMeter.d.ts +4 -3
  211. package/types/src/components/FormFieldRadioButtons/FormFieldRadioButtons.d.ts +72 -0
  212. package/types/src/components/FormFieldRadioButtons/index.d.ts +2 -0
  213. package/types/src/components/FormFieldSelect/FormFieldSelect.d.ts +1 -1
  214. package/types/src/components/FormFieldSelect/index.d.ts +1 -0
  215. package/types/src/components/FormFieldText/FormFieldText.d.ts +82 -0
  216. package/types/src/components/FormFieldText/index.d.ts +2 -0
  217. package/types/src/components/Icon/constants.d.ts +1 -1
  218. package/types/src/components/InPlaceEdit/InPlaceEdit.d.ts +50 -0
  219. package/types/src/components/InPlaceEdit/index.d.ts +2 -0
  220. package/types/src/components/Input/Input.d.ts +1 -1
  221. package/types/src/components/Input/index.d.ts +1 -0
  222. package/types/src/components/InputFile/InputFile.d.ts +3 -2
  223. package/types/src/components/InputFile/index.d.ts +1 -0
  224. package/types/src/components/InputNumber/InputNumber.d.ts +2 -2
  225. package/types/src/components/InputNumber/index.d.ts +1 -0
  226. package/types/src/components/Layout/Layout.d.ts +161 -0
  227. package/types/src/components/Layout/index.d.ts +2 -0
  228. package/types/src/components/Media/Media.d.ts +66 -0
  229. package/types/src/components/Media/MediaSection.d.ts +22 -0
  230. package/types/src/components/Media/index.d.ts +4 -0
  231. package/types/src/components/Menu/Menu.d.ts +40 -0
  232. package/types/src/components/Menu/MenuBaseItem.d.ts +41 -0
  233. package/types/src/components/Menu/MenuDivider.d.ts +16 -0
  234. package/types/src/components/Menu/MenuHeader.d.ts +22 -0
  235. package/types/src/components/Menu/MenuItem.d.ts +49 -0
  236. package/types/src/components/Menu/MenuSelectableItem.d.ts +28 -0
  237. package/types/src/components/Menu/index.d.ts +11 -0
  238. package/types/src/components/Panel/Panel.d.ts +2 -1
  239. package/types/src/components/Plaintext/Plaintext.d.ts +23 -0
  240. package/types/src/components/Plaintext/index.d.ts +2 -0
  241. package/types/src/components/Popover/Popover.d.ts +156 -0
  242. package/types/src/components/Popover/index.d.ts +2 -0
  243. package/types/src/components/Section/Section.d.ts +145 -0
  244. package/types/src/components/Section/SectionItem.d.ts +38 -0
  245. package/types/src/components/Section/index.d.ts +5 -0
  246. package/types/src/components/Spot/Spot.d.ts +3 -2
  247. package/types/src/components/Spot/SpotPulsar.d.ts +4 -2
  248. package/types/src/components/Spot/index.d.ts +1 -0
  249. package/types/src/components/Subnav/Subnav.d.ts +50 -0
  250. package/types/src/components/Subnav/index.d.ts +2 -0
  251. package/types/src/components/TextArea/TextArea.d.ts +3 -3
  252. package/types/src/components/TextArea/index.d.ts +1 -0
  253. package/types/src/components/Toolbar/RegistryContext.d.ts +2 -2
  254. package/types/src/components/Toolbar/Toolbar.d.ts +47 -0
  255. package/types/src/components/Toolbar/ToolbarGroup.d.ts +46 -0
  256. package/types/src/components/Toolbar/ToolbarMenu.d.ts +1 -1
  257. package/types/src/components/Toolbar/index.d.ts +5 -0
  258. package/types/src/components/Tour/Tour.d.ts +1 -1
  259. package/types/src/components/index.d.ts +21 -10
  260. package/types/src/utils/types/DataAttributes.d.ts +3 -0
  261. package/types/src/utils/types/index.d.ts +1 -0
  262. package/cjs/tests/index.js +0 -13
  263. package/cjs/tests/renderer.js +0 -33
  264. package/esm/tests/index.js +0 -3
  265. package/esm/tests/renderer.js +0 -25
  266. package/styleguide/build/bundle.6318f4a5.js +0 -2
  267. /package/styleguide/build/{bundle.6318f4a5.js.LICENSE.txt → bundle.8058bbce.js.LICENSE.txt} +0 -0
@@ -0,0 +1,161 @@
1
+ import { Component, ReactNode } from 'react';
2
+ import { ContentRect } from 'react-measure';
3
+ import '../../helpers/base.less';
4
+ import './Layout.less';
5
+ declare type CollapsedState = 'responsive' | 'desktop';
6
+ export interface LayoutProps {
7
+ /**
8
+ * Type of the `Layout`
9
+ * @since 1.4.0
10
+ */
11
+ type?: 'fluid' | 'simplified';
12
+ /**
13
+ * Header content.
14
+ * @since 1.4.0
15
+ */
16
+ header?: ReactNode;
17
+ /**
18
+ * Define header position - always on top (fixed) or static.
19
+ * @since 1.4.0
20
+ */
21
+ headerFixed?: boolean;
22
+ /**
23
+ * Additional content at the top of the header.
24
+ * @since 3.2.0
25
+ */
26
+ headerAddon?: ReactNode;
27
+ /**
28
+ * Sidebar content.
29
+ * @since 1.4.0
30
+ */
31
+ sidebar?: ReactNode;
32
+ /**
33
+ * Sidebar type.
34
+ * @since 3.2.0
35
+ */
36
+ sidebarType?: 'collapsed' | 'folded';
37
+ /**
38
+ * Define if sidebar can collapse.
39
+ * @since 1.4.0
40
+ */
41
+ sidebarCollapsible?: boolean;
42
+ /**
43
+ * Sidebar collapsed state.
44
+ * A boolean value is used for desktop mode only, but you can set an array with collapsed states for all modes, e.g. `['responsive', 'desktop']`.
45
+ *
46
+ * @since 1.4.0
47
+ */
48
+ sidebarCollapsed?: boolean | CollapsedState[];
49
+ /**
50
+ * Additional content between header and main content.
51
+ * @since 1.4.0
52
+ */
53
+ contentAddon?: ReactNode;
54
+ /**
55
+ * Content header.
56
+ * @since 3.0.0
57
+ */
58
+ contentHeader?: ReactNode;
59
+ /**
60
+ * Footer content.
61
+ * @since 1.4.0
62
+ */
63
+ footer?: ReactNode;
64
+ /**
65
+ * Main content of the `Layout`.
66
+ * @since 1.4.0
67
+ */
68
+ children?: ReactNode;
69
+ /**
70
+ * Width of the content
71
+ * @since 3.0.0
72
+ */
73
+ width?: 'sm' | 'md' | 'lg';
74
+ /**
75
+ * Sidebar onToggle handler.
76
+ * The handler is called with two args:
77
+ *
78
+ * * Whether collapsed or not.
79
+ * * In which mode: responsive or desktop.
80
+ *
81
+ * @since 1.4.0
82
+ */
83
+ onSidebarToggle?: (sidebarClosed: boolean, state: CollapsedState) => void;
84
+ /**
85
+ * @ignore
86
+ */
87
+ className?: string;
88
+ /**
89
+ * @ignore
90
+ */
91
+ baseClassName?: string;
92
+ }
93
+ declare type LayoutState = {
94
+ isSidebarClosedDesktop?: boolean;
95
+ isSidebarClosedResponsive?: boolean;
96
+ headerHeight?: number | null;
97
+ isResponsive?: boolean;
98
+ prevSidebarCollapsed?: LayoutProps['sidebarCollapsed'];
99
+ };
100
+ /**
101
+ * @since 1.4.0
102
+ */
103
+ export default class Layout extends Component<LayoutProps, LayoutState> {
104
+ static defaultProps: {
105
+ type: string;
106
+ header: undefined;
107
+ headerFixed: boolean;
108
+ headerAddon: undefined;
109
+ sidebar: undefined;
110
+ sidebarType: string;
111
+ sidebarCollapsible: boolean;
112
+ sidebarCollapsed: boolean;
113
+ contentAddon: undefined;
114
+ contentHeader: undefined;
115
+ footer: undefined;
116
+ width: undefined;
117
+ onSidebarToggle: undefined;
118
+ children: undefined;
119
+ className: undefined;
120
+ baseClassName: string;
121
+ };
122
+ state: {
123
+ isSidebarClosedDesktop: boolean;
124
+ isSidebarClosedResponsive: boolean;
125
+ headerHeight: null;
126
+ isResponsive: boolean;
127
+ };
128
+ static getDerivedStateFromProps(props: LayoutProps, state: LayoutState): LayoutState;
129
+ componentDidMount(): void;
130
+ componentWillUnmount(): void;
131
+ private readonly headerRef;
132
+ private readonly sidebarRef;
133
+ private readonly responsiveSidebarTogglerRef;
134
+ private unsubscribeMatchMedia?;
135
+ private unsubscribeClickOutside?;
136
+ handleMatchMedia: ({ matches }: MediaQueryListEvent | MediaQueryList) => void;
137
+ handleClickOutside: () => void;
138
+ handleToggle: () => void;
139
+ handleResize: ({ bounds }: ContentRect) => void;
140
+ getSidebarClosed: () => boolean;
141
+ renderHeader({ header }: {
142
+ header: ReactNode;
143
+ }): JSX.Element | null;
144
+ renderContentAddon({ contentAddon }: {
145
+ contentAddon: ReactNode;
146
+ }): JSX.Element | null;
147
+ renderContentHeader({ contentHeader }: {
148
+ contentHeader: ReactNode;
149
+ }): JSX.Element | null;
150
+ renderSidebar({ sidebar }: {
151
+ sidebar: ReactNode;
152
+ }): JSX.Element | null;
153
+ renderMainContent({ children }: {
154
+ children: ReactNode;
155
+ }): JSX.Element;
156
+ renderFooter({ footer }: {
157
+ footer: ReactNode;
158
+ }): JSX.Element | null;
159
+ render(): JSX.Element;
160
+ }
161
+ export {};
@@ -0,0 +1,2 @@
1
+ export { default } from './Layout';
2
+ export type { LayoutProps } from './Layout';
@@ -0,0 +1,66 @@
1
+ import { ReactNode, HTMLProps } from 'react';
2
+ import './Media.less';
3
+ export interface MediaProps extends Omit<HTMLProps<HTMLDivElement>, 'title'> {
4
+ /**
5
+ * Title
6
+ * @since 0.0.45
7
+ */
8
+ title?: ReactNode;
9
+ /**
10
+ * Title addon
11
+ * @since 0.0.68
12
+ */
13
+ titleAddon?: ReactNode;
14
+ /**
15
+ * Title size
16
+ * @deprecated Pass a component as a title prop
17
+ * @since 0.0.68
18
+ */
19
+ titleSize?: 'md' | 'lg' | 'xl';
20
+ /**
21
+ * Image
22
+ * @since 0.0.45
23
+ */
24
+ image?: ReactNode;
25
+ /**
26
+ * Spacings between image and content
27
+ * @since 0.3.0
28
+ */
29
+ imageSpacing?: 'sm' | 'md' | 'lg' | 'xl' | 'xxl';
30
+ /**
31
+ * Media object and content alignment
32
+ * @since 3.19.0
33
+ */
34
+ align?: 'start' | 'center' | 'end';
35
+ /**
36
+ * Media object (image) alignment
37
+ * @since 3.19.0
38
+ */
39
+ imageAlign?: 'start' | 'center' | 'end';
40
+ /**
41
+ * Media vertical direction
42
+ * @since 3.19.0
43
+ */
44
+ vertical?: boolean;
45
+ /**
46
+ * Content of the `Media`.
47
+ * @since 0.0.45
48
+ */
49
+ children?: ReactNode;
50
+ /**
51
+ * @ignore
52
+ */
53
+ className?: string;
54
+ /**
55
+ * @ignore
56
+ */
57
+ baseClassName?: string;
58
+ }
59
+ /**
60
+ * `Media` component is a combination of icon, text title and content.
61
+ * This layout was so widely spread in our products so we have decided to create a special component for it.
62
+ * Probably we should have named the component differently (not Media), but we didn't have better idea then ;)
63
+ * @since 0.0.45
64
+ */
65
+ declare const Media: ({ className, children, title, titleAddon, titleSize, image, imageSpacing, imageAlign, align, vertical, baseClassName, ...props }: MediaProps) => JSX.Element;
66
+ export default Media;
@@ -0,0 +1,22 @@
1
+ import { ReactNode } from 'react';
2
+ export interface MediaSectionProps {
3
+ /**
4
+ * Content of the `MediaSection`.
5
+ * @since 0.0.68
6
+ */
7
+ children?: ReactNode;
8
+ /**
9
+ * @ignore
10
+ */
11
+ className?: string;
12
+ /**
13
+ * @ignore
14
+ */
15
+ baseClassName?: string;
16
+ }
17
+ /**
18
+ * `MediaSection` is a part of [Media](#!/Media) component.
19
+ * @since 0.0.68
20
+ */
21
+ declare const MediaSection: ({ className, children, baseClassName, ...props }: MediaSectionProps) => JSX.Element;
22
+ export default MediaSection;
@@ -0,0 +1,4 @@
1
+ export { default } from './Media';
2
+ export type { MediaProps } from './Media';
3
+ export { default as MediaSection } from './MediaSection';
4
+ export type { MediaSectionProps } from './MediaSection';
@@ -0,0 +1,40 @@
1
+ import { ReactNode, HTMLAttributes } from 'react';
2
+ import '../../helpers/base.less';
3
+ import './Menu.less';
4
+ export interface MenuProps extends HTMLAttributes<HTMLDivElement> {
5
+ /**
6
+ * Triggered when menu item was clicked.
7
+ * @since 0.0.56
8
+ */
9
+ onItemClick?: () => void;
10
+ /**
11
+ * Content of the `Menu`.
12
+ * @since 0.0.55
13
+ */
14
+ children?: ReactNode;
15
+ /**
16
+ * Show menu in overlay.
17
+ * @ignore
18
+ */
19
+ overlay?: boolean;
20
+ /**
21
+ * @ignore
22
+ */
23
+ className?: string;
24
+ /**
25
+ * @ignore
26
+ */
27
+ baseClassName?: string;
28
+ }
29
+ /**
30
+ * `Menu` component displays grouped controls for navigating the UI, performing actions on objects, or showing
31
+ * options for [Lists](#!/List) (for example, sorting and filtering settings). `Menu` is most typically used in a
32
+ * [Dropdown](#!/Dropdown).
33
+ *
34
+ * `Menu` consists of several [Menu Items](#!/MenuItem) (or [Selectable Menu
35
+ * Items](#!/MenuSelectableItem)) which can be grouped by [Menu Headers](#!/MenuHeader)
36
+ * or separated by [Menu Dividers](#!/MenuDivider).
37
+ * @since 0.0.55
38
+ */
39
+ declare const Menu: import("react").ForwardRefExoticComponent<MenuProps & import("react").RefAttributes<HTMLElement>>;
40
+ export default Menu;
@@ -0,0 +1,41 @@
1
+ import { ElementType, ReactNode } from 'react';
2
+ import { IconName, IconProps } from '../Icon';
3
+ import { PolymorphicComponentProps } from '../../utils/types';
4
+ declare type MenuBaseItemBaseProps = {
5
+ /**
6
+ * Icon
7
+ * @since 0.0.60
8
+ */
9
+ icon?: IconName | IconProps | ReactNode;
10
+ /**
11
+ * Right label of item.
12
+ * @since 0.0.60
13
+ */
14
+ label?: ReactNode;
15
+ /**
16
+ * Content of the `MenuBaseItem`.
17
+ * @since 0.0.60
18
+ */
19
+ children?: ReactNode;
20
+ /**
21
+ * @ignore
22
+ */
23
+ className?: string;
24
+ /**
25
+ * @ignore
26
+ */
27
+ baseClassName?: string;
28
+ };
29
+ export declare type MenuBaseItemProps<Component extends ElementType = 'div'> = {
30
+ /**
31
+ * Component to render as the root element. Useful when rendering a `MenuBaseItem` as other component or tag.
32
+ * @since 1.9.1
33
+ */
34
+ component?: Component;
35
+ } & PolymorphicComponentProps<Component, MenuBaseItemBaseProps>;
36
+ /**
37
+ * `MenuBaseItem` component.
38
+ * @since 0.0.60
39
+ */
40
+ declare const MenuBaseItem: ({ className, children, icon, label, component: Component, baseClassName, ...props }: MenuBaseItemProps) => JSX.Element;
41
+ export default MenuBaseItem;
@@ -0,0 +1,16 @@
1
+ export interface MenuDividerProps {
2
+ /**
3
+ * @ignore
4
+ */
5
+ className?: string;
6
+ /**
7
+ * @ignore
8
+ */
9
+ baseClassName?: string;
10
+ }
11
+ /**
12
+ * `MenuDivider` is a part of [Menu](#!/Menu) component.
13
+ * @since 0.0.57
14
+ */
15
+ declare const MenuDivider: ({ className, baseClassName, ...props }: MenuDividerProps) => JSX.Element;
16
+ export default MenuDivider;
@@ -0,0 +1,22 @@
1
+ import { ReactNode } from 'react';
2
+ export interface MenuHeaderProps {
3
+ /**
4
+ * Content of the `MenuHeader`.
5
+ * @since 0.0.57
6
+ */
7
+ children?: ReactNode;
8
+ /**
9
+ * @ignore
10
+ */
11
+ className?: string;
12
+ /**
13
+ * @ignore
14
+ */
15
+ baseClassName?: string;
16
+ }
17
+ /**
18
+ * `MenuHeader` is a part of [Menu](#!/Menu) component.
19
+ * @since 0.0.57
20
+ */
21
+ declare const MenuHeader: ({ className, children, baseClassName, ...props }: MenuHeaderProps) => JSX.Element;
22
+ export default MenuHeader;
@@ -0,0 +1,49 @@
1
+ import { ElementType, ReactNode } from 'react';
2
+ import { MenuBaseItemProps } from './MenuBaseItem';
3
+ import { IconName, IconProps } from '../Icon';
4
+ export declare type MenuItemProps<Component extends ElementType = 'div'> = {
5
+ /**
6
+ * Whether item is active.
7
+ * @since 0.0.55
8
+ */
9
+ active?: boolean;
10
+ /**
11
+ * Whether item is disabled.
12
+ * @since 0.0.55
13
+ */
14
+ disabled?: boolean;
15
+ /**
16
+ * Icon
17
+ * @since 0.0.55
18
+ */
19
+ icon?: IconName | IconProps | ReactNode;
20
+ /**
21
+ * Right label of item.
22
+ * @since 0.0.57
23
+ */
24
+ label?: ReactNode;
25
+ /**
26
+ * Tooltip for component.
27
+ * @since 2.6.1
28
+ */
29
+ tooltip?: ReactNode;
30
+ /**
31
+ * Content of the `MenuItem`.
32
+ * @since 0.0.55
33
+ */
34
+ children?: ReactNode;
35
+ /**
36
+ * @ignore
37
+ */
38
+ className?: string;
39
+ /**
40
+ * @ignore
41
+ */
42
+ baseClassName?: string;
43
+ } & MenuBaseItemProps<Component>;
44
+ /**
45
+ * `MenuItem` is a part of [Menu](#!/Menu) component.
46
+ * @since 0.0.55
47
+ */
48
+ declare const MenuItem: ({ className, children, onClick, icon, label, tooltip, baseClassName, disabled, active, ...props }: MenuItemProps) => JSX.Element;
49
+ export default MenuItem;
@@ -0,0 +1,28 @@
1
+ import { ElementType, ReactNode } from 'react';
2
+ import { MenuItemProps } from './MenuItem';
3
+ export declare type MenuSelectableItemProps<Component extends ElementType = 'div'> = {
4
+ /**
5
+ * Whether item is selected.
6
+ * @since 0.0.57
7
+ */
8
+ selected?: boolean;
9
+ /**
10
+ * Content of the `MenuSelectableItem`.
11
+ * @since 0.0.57
12
+ */
13
+ children?: ReactNode;
14
+ /**
15
+ * @ignore
16
+ */
17
+ className?: string;
18
+ /**
19
+ * @ignore
20
+ */
21
+ baseClassName?: string;
22
+ } & MenuItemProps<Component>;
23
+ /**
24
+ * `MenuSelectableItem` is a part of [Menu](#!/Menu) component.
25
+ * @since 0.0.57
26
+ */
27
+ declare const MenuSelectableItem: ({ className, children, selected, baseClassName, ...props }: MenuSelectableItemProps) => JSX.Element;
28
+ export default MenuSelectableItem;
@@ -0,0 +1,11 @@
1
+ export { default } from './Menu';
2
+ export type { MenuProps } from './Menu';
3
+ export { default as MenuItem } from './MenuItem';
4
+ export type { MenuItemProps } from './MenuItem';
5
+ export { default as MenuBaseItem } from './MenuBaseItem';
6
+ export { default as MenuSelectableItem } from './MenuSelectableItem';
7
+ export type { MenuSelectableItemProps } from './MenuSelectableItem';
8
+ export { default as MenuDivider } from './MenuDivider';
9
+ export type { MenuDividerProps } from './MenuDivider';
10
+ export { default as MenuHeader } from './MenuHeader';
11
+ export type { MenuHeaderProps } from './MenuHeader';
@@ -1,4 +1,5 @@
1
1
  import { Component, SyntheticEvent, ReactNode } from 'react';
2
+ import { DataAttributes } from '../../utils/types';
2
3
  import './Panel.less';
3
4
  declare type PanelProps = {
4
5
  /**
@@ -39,7 +40,7 @@ declare type PanelProps = {
39
40
  * @ignore
40
41
  */
41
42
  baseClassName?: string;
42
- };
43
+ } & DataAttributes;
43
44
  declare type PanelState = {
44
45
  collapsed: boolean;
45
46
  prevPropsCollapsed: boolean;
@@ -0,0 +1,23 @@
1
+ import { ReactNode } from 'react';
2
+ import './Plaintext.less';
3
+ export interface PlainTextProps {
4
+ /**
5
+ * Content of the Plaintext
6
+ * @since 0.0.42
7
+ */
8
+ children: ReactNode;
9
+ /**
10
+ * @ignore
11
+ */
12
+ className?: string;
13
+ /**
14
+ * @ignore
15
+ */
16
+ baseClassName?: string;
17
+ }
18
+ /**
19
+ * `Plaintext` component is used to show regular text, without any formatting options and ignoring html tags.
20
+ * @since 0.0.42
21
+ */
22
+ declare const Plaintext: ({ className, children, baseClassName, }: PlainTextProps) => JSX.Element;
23
+ export default Plaintext;
@@ -0,0 +1,2 @@
1
+ export { default } from './Plaintext';
2
+ export type { PlainTextProps } from './Plaintext';
@@ -0,0 +1,156 @@
1
+ import { ContentRect } from 'react-measure';
2
+ import { PopperState } from '../Popper';
3
+ import { Placement } from 'popper.js';
4
+ import { Component, KeyboardEventHandler, MouseEvent, MutableRefObject, ReactElement, ReactNode } from 'react';
5
+ import './Popover.less';
6
+ declare const PLACEMENT_MAP: Record<string, Placement>;
7
+ export interface PopoverProps {
8
+ /**
9
+ * The reference element used to position the popover.
10
+ * @since 0.0.65
11
+ */
12
+ target: ReactElement;
13
+ /**
14
+ * A React reference to the DOM element that needs for calculating the position of the popup.
15
+ * It is required only when visible or defaultVisible props are provided.
16
+ * @since 3.12.0
17
+ */
18
+ targetRef?: MutableRefObject<HTMLElement | null>;
19
+ /**
20
+ * Popover visibility. For controlled component only.
21
+ * @since 0.0.65
22
+ */
23
+ visible?: boolean;
24
+ /**
25
+ * Popover default (on init) visibility. For uncontrolled component only.
26
+ * @since 0.0.66
27
+ */
28
+ defaultVisible?: boolean;
29
+ /**
30
+ * Popover title. Header will only be rendered if this prop is defined.
31
+ * @since 0.0.42
32
+ */
33
+ title?: ReactNode;
34
+ /**
35
+ * Click handler for close button. If it is not defined then default behavior (hide popover) will be used.
36
+ * @since 0.0.42
37
+ */
38
+ onClose: () => void;
39
+ /**
40
+ * Popover placement
41
+ * @since 0.0.42
42
+ */
43
+ placement?: keyof typeof PLACEMENT_MAP;
44
+ /**
45
+ * Indicating if clicking outside the popover should close it.
46
+ * @since 0.0.65
47
+ */
48
+ canCloseOnOutsideClick?: boolean;
49
+ /**
50
+ * Indicating if pressing the escape key should close the popover.
51
+ * @since 0.0.65
52
+ */
53
+ canCloseOnEscapePress?: boolean;
54
+ /**
55
+ * Content of the Popover
56
+ * @since 0.0.42
57
+ */
58
+ children?: ReactNode;
59
+ /**
60
+ * Visual intent color to apply to component.
61
+ * @since 0.0.59
62
+ */
63
+ intent?: 'info' | 'success' | 'warning' | 'danger';
64
+ /**
65
+ * Undo predefined max-width.
66
+ * @since 2.4.0
67
+ */
68
+ wide?: boolean;
69
+ /**
70
+ * Define the popover width.
71
+ * @since 3.2.0
72
+ */
73
+ width?: 'xs' | 'sm' | 'md' | 'lg';
74
+ /**
75
+ * Define the popover height.
76
+ * @since 3.3.0
77
+ */
78
+ height?: number | string;
79
+ /**
80
+ * A slot for buttons or links in the header.
81
+ * @since 3.16.0
82
+ */
83
+ extra?: ReactNode;
84
+ /**
85
+ * @ignore
86
+ */
87
+ className?: string;
88
+ /**
89
+ * @ignore
90
+ */
91
+ baseClassName?: string;
92
+ /**
93
+ * Boundaries element for preventOverflow property.
94
+ * @since 1.12.4
95
+ */
96
+ boundariesElement?: 'scrollParent' | 'window' | 'viewport';
97
+ /**
98
+ * @ignore
99
+ */
100
+ autoFocus?: boolean;
101
+ }
102
+ declare type PopoverState = {
103
+ show?: boolean;
104
+ arrowInHeader: boolean;
105
+ };
106
+ /**
107
+ * `Popover` component is non-modal pop-up window used for providing additional information
108
+ * for an interface element. It also may contain Form with few fields or any other small content.
109
+ * @since 0.0.42
110
+ */
111
+ declare class Popover extends Component<PopoverProps, PopoverState> {
112
+ static contextType: import("react").Context<boolean>;
113
+ static defaultProps: {
114
+ visible: null;
115
+ defaultVisible: boolean;
116
+ title: undefined;
117
+ onClose: undefined;
118
+ placement: string;
119
+ canCloseOnOutsideClick: boolean;
120
+ canCloseOnEscapePress: boolean;
121
+ children: undefined;
122
+ intent: undefined;
123
+ wide: undefined;
124
+ width: undefined;
125
+ height: undefined;
126
+ extra: undefined;
127
+ className: undefined;
128
+ baseClassName: string;
129
+ boundariesElement: undefined;
130
+ autoFocus: boolean;
131
+ targetRef: undefined;
132
+ };
133
+ state: {
134
+ show: boolean | undefined;
135
+ arrowInHeader: boolean;
136
+ };
137
+ static getDerivedStateFromProps(props: PopoverProps, state: PopoverState): {
138
+ show: boolean | undefined;
139
+ };
140
+ componentDidUpdate(_: PopoverProps, prevState: PopoverState): void;
141
+ private contentRef;
142
+ private targetRef;
143
+ private prevFocusElement;
144
+ private popperData;
145
+ private headerBounds;
146
+ focus(): void;
147
+ checkArrowPosition: () => void;
148
+ hotkeyHandler: KeyboardEventHandler<HTMLDivElement>;
149
+ handleTargetClick: (e: MouseEvent<HTMLDivElement>) => void;
150
+ handleClose: () => void;
151
+ handleHeaderResize: (contentRect: ContentRect) => void;
152
+ handlePopperUpdate: (popperData: PopperState) => void;
153
+ getIgnoreNodes: () => (Element | Text | null)[] | (MutableRefObject<HTMLElement | null> | undefined)[];
154
+ render(): JSX.Element;
155
+ }
156
+ export default Popover;
@@ -0,0 +1,2 @@
1
+ export { default } from './Popover';
2
+ export type { PopoverProps } from './Popover';