@skbkontur/react-ui 4.2.2 → 4.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +17 -0
- package/cjs/components/Autocomplete/Autocomplete.d.ts +9 -17
- package/cjs/components/Autocomplete/Autocomplete.js +10 -6
- package/cjs/components/Autocomplete/Autocomplete.js.map +1 -1
- package/cjs/components/Button/Button.d.ts +4 -5
- package/cjs/components/Button/Button.js +8 -3
- package/cjs/components/Button/Button.js.map +1 -1
- package/cjs/components/Button/Button.mixins.js +1 -1
- package/cjs/components/Button/Button.mixins.js.map +1 -1
- package/cjs/components/Button/Button.styles.js +18 -18
- package/cjs/components/Button/Button.styles.js.map +1 -1
- package/cjs/components/Center/Center.d.ts +4 -3
- package/cjs/components/Center/Center.js +9 -3
- package/cjs/components/Center/Center.js.map +1 -1
- package/cjs/components/ComboBox/ComboBox.d.ts +8 -13
- package/cjs/components/ComboBox/ComboBox.js +12 -2
- package/cjs/components/ComboBox/ComboBox.js.map +1 -1
- package/cjs/components/CurrencyInput/CurrencyInput.d.ts +6 -9
- package/cjs/components/CurrencyInput/CurrencyInput.js +15 -6
- package/cjs/components/CurrencyInput/CurrencyInput.js.map +1 -1
- package/cjs/components/CurrencyLabel/CurrencyLabel.d.ts +3 -9
- package/cjs/components/CurrencyLabel/CurrencyLabel.js +15 -15
- package/cjs/components/CurrencyLabel/CurrencyLabel.js.map +1 -1
- package/cjs/components/DateInput/DateInput.d.ts +8 -11
- package/cjs/components/DateInput/DateInput.js +11 -3
- package/cjs/components/DateInput/DateInput.js.map +1 -1
- package/cjs/components/DatePicker/DatePicker.d.ts +6 -8
- package/cjs/components/DatePicker/DatePicker.js +12 -6
- package/cjs/components/DatePicker/DatePicker.js.map +1 -1
- package/cjs/components/DropdownMenu/DropdownMenu.d.ts +5 -5
- package/cjs/components/DropdownMenu/DropdownMenu.js +9 -3
- package/cjs/components/DropdownMenu/DropdownMenu.js.map +1 -1
- package/cjs/components/FxInput/FxInput.d.ts +6 -6
- package/cjs/components/FxInput/FxInput.js +13 -10
- package/cjs/components/FxInput/FxInput.js.map +1 -1
- package/cjs/components/Gapped/Gapped.d.ts +7 -8
- package/cjs/components/Gapped/Gapped.js +12 -6
- package/cjs/components/Gapped/Gapped.js.map +1 -1
- package/cjs/components/GlobalLoader/GlobalLoader.d.ts +7 -14
- package/cjs/components/GlobalLoader/GlobalLoader.js +13 -9
- package/cjs/components/GlobalLoader/GlobalLoader.js.map +1 -1
- package/cjs/components/Hint/Hint.d.ts +7 -11
- package/cjs/components/Hint/Hint.js +15 -5
- package/cjs/components/Hint/Hint.js.map +1 -1
- package/cjs/components/Input/Input.d.ts +4 -3
- package/cjs/components/Input/Input.js +7 -4
- package/cjs/components/Input/Input.js.map +1 -1
- package/cjs/components/Kebab/Kebab.d.ts +7 -11
- package/cjs/components/Kebab/Kebab.js +14 -5
- package/cjs/components/Kebab/Kebab.js.map +1 -1
- package/cjs/components/Link/Link.d.ts +4 -4
- package/cjs/components/Link/Link.js +11 -4
- package/cjs/components/Link/Link.js.map +1 -1
- package/cjs/components/Loader/Loader.d.ts +7 -4
- package/cjs/components/Loader/Loader.js +14 -4
- package/cjs/components/Loader/Loader.js.map +1 -1
- package/cjs/components/Modal/Modal.d.ts +4 -3
- package/cjs/components/Modal/Modal.js +8 -3
- package/cjs/components/Modal/Modal.js.map +1 -1
- package/cjs/components/Paging/Paging.d.ts +6 -9
- package/cjs/components/Paging/Paging.js +15 -5
- package/cjs/components/Paging/Paging.js.map +1 -1
- package/cjs/components/Paging/PagingDefaultComponent.d.ts +1 -1
- package/cjs/components/Paging/PagingDefaultComponent.js.map +1 -1
- package/cjs/components/PasswordInput/PasswordInput.d.ts +4 -3
- package/cjs/components/PasswordInput/PasswordInput.js +8 -3
- package/cjs/components/PasswordInput/PasswordInput.js.map +1 -1
- package/cjs/components/Radio/Radio.d.ts +4 -3
- package/cjs/components/Radio/Radio.js +8 -3
- package/cjs/components/Radio/Radio.js.map +1 -1
- package/cjs/components/RadioGroup/RadioGroup.d.ts +2 -4
- package/cjs/components/RadioGroup/RadioGroup.js +4 -2
- package/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
- package/cjs/components/ScrollContainer/ScrollContainer.d.ts +6 -7
- package/cjs/components/ScrollContainer/ScrollContainer.js +11 -5
- package/cjs/components/ScrollContainer/ScrollContainer.js.map +1 -1
- package/cjs/components/Select/Select.d.ts +3 -12
- package/cjs/components/Select/Select.js +6 -1
- package/cjs/components/Select/Select.js.map +1 -1
- package/cjs/components/Select/Select.styles.js +4 -4
- package/cjs/components/Select/Select.styles.js.map +1 -1
- package/cjs/components/SidePage/SidePage.d.ts +5 -6
- package/cjs/components/SidePage/SidePage.js +8 -1
- package/cjs/components/SidePage/SidePage.js.map +1 -1
- package/cjs/components/Spinner/Spinner.d.ts +4 -2
- package/cjs/components/Spinner/Spinner.js +9 -3
- package/cjs/components/Spinner/Spinner.js.map +1 -1
- package/cjs/components/Sticky/Sticky.d.ts +5 -4
- package/cjs/components/Sticky/Sticky.js +9 -2
- package/cjs/components/Sticky/Sticky.js.map +1 -1
- package/cjs/components/Tabs/Tab.d.ts +4 -4
- package/cjs/components/Tabs/Tab.js +11 -13
- package/cjs/components/Tabs/Tab.js.map +1 -1
- package/cjs/components/Tabs/Tabs.d.ts +4 -4
- package/cjs/components/Tabs/Tabs.js +12 -3
- package/cjs/components/Tabs/Tabs.js.map +1 -1
- package/cjs/components/Textarea/Textarea.d.ts +8 -10
- package/cjs/components/Textarea/Textarea.js +10 -6
- package/cjs/components/Textarea/Textarea.js.map +1 -1
- package/cjs/components/Toggle/Toggle.d.ts +5 -6
- package/cjs/components/Toggle/Toggle.js +10 -4
- package/cjs/components/Toggle/Toggle.js.map +1 -1
- package/cjs/components/TokenInput/TokenInput.d.ts +19 -16
- package/cjs/components/TokenInput/TokenInput.js +75 -57
- package/cjs/components/TokenInput/TokenInput.js.map +1 -1
- package/cjs/components/Tooltip/Tooltip.d.ts +10 -14
- package/cjs/components/Tooltip/Tooltip.js +23 -12
- package/cjs/components/Tooltip/Tooltip.js.map +1 -1
- package/cjs/components/TooltipMenu/TooltipMenu.d.ts +5 -4
- package/cjs/components/TooltipMenu/TooltipMenu.js +11 -5
- package/cjs/components/TooltipMenu/TooltipMenu.js.map +1 -1
- package/cjs/internal/BGRuler.d.ts +13 -15
- package/cjs/internal/BGRuler.js +16 -8
- package/cjs/internal/BGRuler.js.map +1 -1
- package/cjs/internal/Calendar/Calendar.d.ts +4 -13
- package/cjs/internal/Calendar/Calendar.js +10 -5
- package/cjs/internal/Calendar/Calendar.js.map +1 -1
- package/cjs/internal/Calendar/DayCellView.styles.js +1 -1
- package/cjs/internal/Calendar/DayCellView.styles.js.map +1 -1
- package/cjs/internal/Calendar/Month.js +16 -11
- package/cjs/internal/Calendar/Month.js.map +1 -1
- package/cjs/internal/ComponentCombinator.d.ts +6 -8
- package/cjs/internal/ComponentCombinator.js +6 -2
- package/cjs/internal/ComponentCombinator.js.map +1 -1
- package/cjs/internal/ComponentTable.d.ts +5 -6
- package/cjs/internal/ComponentTable.js +11 -2
- package/cjs/internal/ComponentTable.js.map +1 -1
- package/cjs/internal/CustomComboBox/ComboBoxMenu.d.ts +4 -4
- package/cjs/internal/CustomComboBox/ComboBoxMenu.js +7 -1
- package/cjs/internal/CustomComboBox/ComboBoxMenu.js.map +1 -1
- package/cjs/internal/CustomComboBox/ComboBoxView.d.ts +4 -12
- package/cjs/internal/CustomComboBox/ComboBoxView.js +18 -10
- package/cjs/internal/CustomComboBox/ComboBoxView.js.map +1 -1
- package/cjs/internal/DateSelect/DateSelect.d.ts +4 -6
- package/cjs/internal/DateSelect/DateSelect.js +15 -9
- package/cjs/internal/DateSelect/DateSelect.js.map +1 -1
- package/cjs/internal/DropdownContainer/DropdownContainer.d.ts +3 -6
- package/cjs/internal/DropdownContainer/DropdownContainer.js +8 -5
- package/cjs/internal/DropdownContainer/DropdownContainer.js.map +1 -1
- package/cjs/internal/InputLikeText/InputLikeText.d.ts +4 -3
- package/cjs/internal/InputLikeText/InputLikeText.js +7 -2
- package/cjs/internal/InputLikeText/InputLikeText.js.map +1 -1
- package/cjs/internal/InternalMenu/InternalMenu.d.ts +3 -9
- package/cjs/internal/InternalMenu/InternalMenu.js +16 -6
- package/cjs/internal/InternalMenu/InternalMenu.js.map +1 -1
- package/cjs/internal/MaskedInput/MaskedInput.d.ts +4 -2
- package/cjs/internal/MaskedInput/MaskedInput.js +7 -2
- package/cjs/internal/MaskedInput/MaskedInput.js.map +1 -1
- package/cjs/internal/Menu/Menu.d.ts +4 -7
- package/cjs/internal/Menu/Menu.js +7 -1
- package/cjs/internal/Menu/Menu.js.map +1 -1
- package/cjs/internal/Popup/Popup.d.ts +10 -16
- package/cjs/internal/Popup/Popup.js +21 -7
- package/cjs/internal/Popup/Popup.js.map +1 -1
- package/cjs/internal/PopupMenu/PopupMenu.d.ts +8 -11
- package/cjs/internal/PopupMenu/PopupMenu.js +8 -1
- package/cjs/internal/PopupMenu/PopupMenu.js.map +1 -1
- package/cjs/internal/RenderLayer/RenderLayer.d.ts +4 -3
- package/cjs/internal/RenderLayer/RenderLayer.js +8 -2
- package/cjs/internal/RenderLayer/RenderLayer.js.map +1 -1
- package/cjs/internal/ThemePlayground/VariableValue.d.ts +5 -4
- package/cjs/internal/ThemePlayground/VariableValue.js +6 -1
- package/cjs/internal/ThemePlayground/VariableValue.js.map +1 -1
- package/cjs/internal/ZIndex/ZIndex.d.ts +7 -11
- package/cjs/internal/ZIndex/ZIndex.js +10 -3
- package/cjs/internal/ZIndex/ZIndex.js.map +1 -1
- package/cjs/lib/createPropsGetter.d.ts +2 -1
- package/cjs/lib/createPropsGetter.js +2 -0
- package/cjs/lib/createPropsGetter.js.map +1 -1
- package/components/Autocomplete/Autocomplete/Autocomplete.js +22 -12
- package/components/Autocomplete/Autocomplete/Autocomplete.js.map +1 -1
- package/components/Autocomplete/Autocomplete.d.ts +9 -17
- package/components/Button/Button/Button.js +11 -5
- package/components/Button/Button/Button.js.map +1 -1
- package/components/Button/Button.d.ts +4 -5
- package/components/Button/Button.mixins/Button.mixins.js +1 -1
- package/components/Button/Button.mixins/Button.mixins.js.map +1 -1
- package/components/Button/Button.styles/Button.styles.js +18 -18
- package/components/Button/Button.styles/Button.styles.js.map +1 -1
- package/components/Center/Center/Center.js +7 -5
- package/components/Center/Center/Center.js.map +1 -1
- package/components/Center/Center.d.ts +4 -3
- package/components/ComboBox/ComboBox/ComboBox.js +3 -1
- package/components/ComboBox/ComboBox/ComboBox.js.map +1 -1
- package/components/ComboBox/ComboBox.d.ts +8 -13
- package/components/CurrencyInput/CurrencyInput/CurrencyInput.js +21 -18
- package/components/CurrencyInput/CurrencyInput/CurrencyInput.js.map +1 -1
- package/components/CurrencyInput/CurrencyInput.d.ts +6 -9
- package/components/CurrencyLabel/CurrencyLabel/CurrencyLabel.js +21 -15
- package/components/CurrencyLabel/CurrencyLabel/CurrencyLabel.js.map +1 -1
- package/components/CurrencyLabel/CurrencyLabel.d.ts +3 -9
- package/components/DateInput/DateInput/DateInput.js +17 -4
- package/components/DateInput/DateInput/DateInput.js.map +1 -1
- package/components/DateInput/DateInput.d.ts +8 -11
- package/components/DatePicker/DatePicker/DatePicker.js +12 -9
- package/components/DatePicker/DatePicker/DatePicker.js.map +1 -1
- package/components/DatePicker/DatePicker.d.ts +6 -8
- package/components/DropdownMenu/DropdownMenu/DropdownMenu.js +8 -2
- package/components/DropdownMenu/DropdownMenu/DropdownMenu.js.map +1 -1
- package/components/DropdownMenu/DropdownMenu.d.ts +5 -5
- package/components/FxInput/FxInput/FxInput.js +11 -9
- package/components/FxInput/FxInput/FxInput.js.map +1 -1
- package/components/FxInput/FxInput.d.ts +6 -6
- package/components/Gapped/Gapped/Gapped.js +17 -8
- package/components/Gapped/Gapped/Gapped.js.map +1 -1
- package/components/Gapped/Gapped.d.ts +7 -8
- package/components/GlobalLoader/GlobalLoader/GlobalLoader.js +35 -16
- package/components/GlobalLoader/GlobalLoader/GlobalLoader.js.map +1 -1
- package/components/GlobalLoader/GlobalLoader.d.ts +7 -14
- package/components/Hint/Hint/Hint.js +30 -18
- package/components/Hint/Hint/Hint.js.map +1 -1
- package/components/Hint/Hint.d.ts +7 -11
- package/components/Input/Input/Input.js +9 -7
- package/components/Input/Input/Input.js.map +1 -1
- package/components/Input/Input.d.ts +4 -3
- package/components/Kebab/Kebab/Kebab.js +19 -8
- package/components/Kebab/Kebab/Kebab.js.map +1 -1
- package/components/Kebab/Kebab.d.ts +7 -11
- package/components/Link/Link/Link.js +9 -6
- package/components/Link/Link/Link.js.map +1 -1
- package/components/Link/Link.d.ts +4 -4
- package/components/Loader/Loader/Loader.js +22 -17
- package/components/Loader/Loader/Loader.js.map +1 -1
- package/components/Loader/Loader.d.ts +7 -4
- package/components/Modal/Modal/Modal.js +3 -1
- package/components/Modal/Modal/Modal.js.map +1 -1
- package/components/Modal/Modal.d.ts +4 -3
- package/components/Paging/Paging/Paging.js +24 -14
- package/components/Paging/Paging/Paging.js.map +1 -1
- package/components/Paging/Paging.d.ts +6 -9
- package/components/Paging/PagingDefaultComponent/PagingDefaultComponent.js.map +1 -1
- package/components/Paging/PagingDefaultComponent.d.ts +1 -1
- package/components/PasswordInput/PasswordInput/PasswordInput.js +7 -5
- package/components/PasswordInput/PasswordInput/PasswordInput.js.map +1 -1
- package/components/PasswordInput/PasswordInput.d.ts +4 -3
- package/components/Radio/Radio/Radio.js +7 -5
- package/components/Radio/Radio/Radio.js.map +1 -1
- package/components/Radio/Radio.d.ts +4 -3
- package/components/RadioGroup/RadioGroup/RadioGroup.js +10 -10
- package/components/RadioGroup/RadioGroup/RadioGroup.js.map +1 -1
- package/components/RadioGroup/RadioGroup.d.ts +2 -4
- package/components/ScrollContainer/ScrollContainer/ScrollContainer.js +10 -6
- package/components/ScrollContainer/ScrollContainer/ScrollContainer.js.map +1 -1
- package/components/ScrollContainer/ScrollContainer.d.ts +6 -7
- package/components/Select/Select/Select.js +4 -3
- package/components/Select/Select/Select.js.map +1 -1
- package/components/Select/Select.d.ts +3 -12
- package/components/Select/Select.styles/Select.styles.js +4 -4
- package/components/Select/Select.styles/Select.styles.js.map +1 -1
- package/components/SidePage/SidePage/SidePage.js +14 -9
- package/components/SidePage/SidePage/SidePage.js.map +1 -1
- package/components/SidePage/SidePage.d.ts +5 -6
- package/components/Spinner/Spinner/Spinner.js +7 -5
- package/components/Spinner/Spinner/Spinner.js.map +1 -1
- package/components/Spinner/Spinner.d.ts +4 -2
- package/components/Sticky/Sticky/Sticky.js +7 -4
- package/components/Sticky/Sticky/Sticky.js.map +1 -1
- package/components/Sticky/Sticky.d.ts +5 -4
- package/components/Tabs/Tab/Tab.js +15 -7
- package/components/Tabs/Tab/Tab.js.map +1 -1
- package/components/Tabs/Tab.d.ts +4 -4
- package/components/Tabs/Tabs/Tabs.js +10 -8
- package/components/Tabs/Tabs/Tabs.js.map +1 -1
- package/components/Tabs/Tabs.d.ts +4 -4
- package/components/Textarea/Textarea/Textarea.js +19 -14
- package/components/Textarea/Textarea/Textarea.js.map +1 -1
- package/components/Textarea/Textarea.d.ts +8 -10
- package/components/Toggle/Toggle/Toggle.js +12 -7
- package/components/Toggle/Toggle/Toggle.js.map +1 -1
- package/components/Toggle/Toggle.d.ts +5 -6
- package/components/TokenInput/TokenInput/TokenInput.js +107 -77
- package/components/TokenInput/TokenInput/TokenInput.js.map +1 -1
- package/components/TokenInput/TokenInput.d.ts +19 -16
- package/components/Tooltip/Tooltip/Tooltip.js +51 -30
- package/components/Tooltip/Tooltip/Tooltip.js.map +1 -1
- package/components/Tooltip/Tooltip.d.ts +10 -14
- package/components/TooltipMenu/TooltipMenu/TooltipMenu.js +15 -13
- package/components/TooltipMenu/TooltipMenu/TooltipMenu.js.map +1 -1
- package/components/TooltipMenu/TooltipMenu.d.ts +5 -4
- package/internal/BGRuler/BGRuler.js +11 -6
- package/internal/BGRuler/BGRuler.js.map +1 -1
- package/internal/BGRuler.d.ts +13 -15
- package/internal/Calendar/Calendar/Calendar.js +11 -5
- package/internal/Calendar/Calendar/Calendar.js.map +1 -1
- package/internal/Calendar/Calendar.d.ts +4 -13
- package/internal/Calendar/DayCellView.styles/DayCellView.styles.js +1 -1
- package/internal/Calendar/DayCellView.styles/DayCellView.styles.js.map +1 -1
- package/internal/Calendar/Month/Month.js +20 -11
- package/internal/Calendar/Month/Month.js.map +1 -1
- package/internal/ComponentCombinator/ComponentCombinator.js +8 -5
- package/internal/ComponentCombinator/ComponentCombinator.js.map +1 -1
- package/internal/ComponentCombinator.d.ts +6 -8
- package/internal/ComponentTable/ComponentTable.js +16 -4
- package/internal/ComponentTable/ComponentTable.js.map +1 -1
- package/internal/ComponentTable.d.ts +5 -6
- package/internal/CustomComboBox/ComboBoxMenu/ComboBoxMenu.js +4 -2
- package/internal/CustomComboBox/ComboBoxMenu/ComboBoxMenu.js.map +1 -1
- package/internal/CustomComboBox/ComboBoxMenu.d.ts +4 -4
- package/internal/CustomComboBox/ComboBoxView/ComboBoxView.js +21 -10
- package/internal/CustomComboBox/ComboBoxView/ComboBoxView.js.map +1 -1
- package/internal/CustomComboBox/ComboBoxView.d.ts +4 -12
- package/internal/DateSelect/DateSelect/DateSelect.js +14 -11
- package/internal/DateSelect/DateSelect/DateSelect.js.map +1 -1
- package/internal/DateSelect/DateSelect.d.ts +4 -6
- package/internal/DropdownContainer/DropdownContainer/DropdownContainer.js +6 -10
- package/internal/DropdownContainer/DropdownContainer/DropdownContainer.js.map +1 -1
- package/internal/DropdownContainer/DropdownContainer.d.ts +3 -6
- package/internal/InputLikeText/InputLikeText/InputLikeText.js +4 -2
- package/internal/InputLikeText/InputLikeText/InputLikeText.js.map +1 -1
- package/internal/InputLikeText/InputLikeText.d.ts +4 -3
- package/internal/InternalMenu/InternalMenu/InternalMenu.js +21 -10
- package/internal/InternalMenu/InternalMenu/InternalMenu.js.map +1 -1
- package/internal/InternalMenu/InternalMenu.d.ts +3 -9
- package/internal/MaskedInput/MaskedInput/MaskedInput.js +3 -1
- package/internal/MaskedInput/MaskedInput/MaskedInput.js.map +1 -1
- package/internal/MaskedInput/MaskedInput.d.ts +4 -2
- package/internal/Menu/Menu/Menu.js +10 -3
- package/internal/Menu/Menu/Menu.js.map +1 -1
- package/internal/Menu/Menu.d.ts +4 -7
- package/internal/Popup/Popup/Popup.js +32 -23
- package/internal/Popup/Popup/Popup.js.map +1 -1
- package/internal/Popup/Popup.d.ts +10 -16
- package/internal/PopupMenu/PopupMenu/PopupMenu.js +12 -4
- package/internal/PopupMenu/PopupMenu/PopupMenu.js.map +1 -1
- package/internal/PopupMenu/PopupMenu.d.ts +8 -11
- package/internal/RenderLayer/RenderLayer/RenderLayer.js +8 -4
- package/internal/RenderLayer/RenderLayer/RenderLayer.js.map +1 -1
- package/internal/RenderLayer/RenderLayer.d.ts +4 -3
- package/internal/ThemePlayground/VariableValue/VariableValue.js +4 -2
- package/internal/ThemePlayground/VariableValue/VariableValue.js.map +1 -1
- package/internal/ThemePlayground/VariableValue.d.ts +5 -4
- package/internal/ZIndex/ZIndex/ZIndex.js +15 -13
- package/internal/ZIndex/ZIndex/ZIndex.js.map +1 -1
- package/internal/ZIndex/ZIndex.d.ts +7 -11
- package/lib/createPropsGetter/createPropsGetter.js.map +1 -1
- package/lib/createPropsGetter.d.ts +2 -1
- package/package.json +2 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["Toggle.tsx"],"names":["React","PropTypes","warning","keyListener","ThemeContext","CommonWrapper","cx","rootNode","styles","globalClasses","colorWarningShown","ToggleDataTids","root","Toggle","props","input","focus","isTabPressed","inputRef","element","handleChange","event","onValueChange","target","checked","isUncontrolled","setState","onChange","handleFocus","onFocus","focusByTab","handleBlur","onBlur","state","defaultChecked","componentDidMount","autoFocus","render","theme","renderMain","children","captionPosition","error","loading","color","id","disabled","containerClassNames","container","containerDisabled","containerLoading","labelClassNames","rootLeft","caption","captionClass","captionLeft","disabledCaption","setRootNode","button","buttonRight","isWarning","isError","focused","backgroundColor","boxShadow","undefined","activeBackground","background","activeBackgroundLoading","disabledBackground","handle","handleDisabled","Component","__KONTUR_REACT_UI__","propTypes","bool","func","defaultProps"],"mappings":"2JAAA,OAAOA,KAAP,MAAkB,OAAlB;AACA,OAAOC,SAAP,MAAsB,YAAtB;AACA,OAAOC,OAAP,MAAoB,SAApB;;AAEA,SAASC,WAAT,QAA4B,8BAA5B;AACA,SAASC,YAAT,QAA6B,gCAA7B;;AAEA,SAAsBC,aAAtB,QAA2C,8BAA3C;AACA,SAASC,EAAT,QAAmB,2BAAnB;AACA,SAASC,QAAT,QAAuC,oBAAvC;;AAEA,SAASC,MAAT,EAAiBC,aAAjB,QAAsC,iBAAtC;;AAEA,IAAIC,iBAAiB,GAAG,KAAxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuEA,OAAO,IAAMC,cAAc,GAAG;AAC5BC,EAAAA,IAAI,EAAE,cADsB,EAAvB;;;AAIP;AACA;AACA;;AAEA,WAAaC,MAAb,GADCN,QACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6BE,kBAAYO,KAAZ,EAAgC;AAC9B,wCAAMA,KAAN,UAD8B,MAHxBC,KAGwB,GAHS,IAGT;;;;;;;;;;;;;;;;;;AAmBzBC,IAAAA,KAnByB,GAmBjB,YAAM;AACnB,UAAI,MAAKD,KAAT,EAAgB;AACdZ,QAAAA,WAAW,CAACc,YAAZ,GAA2B,IAA3B;AACA,cAAKF,KAAL,CAAWC,KAAX;AACD;AACF,KAxB+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4HxBE,IAAAA,QA5HwB,GA4Hb,UAACC,OAAD,EAA+B;AAChD,YAAKJ,KAAL,GAAaI,OAAb;AACD,KA9H+B;;AAgIxBC,IAAAA,YAhIwB,GAgIT,UAACC,KAAD,EAAgD;AACrE,UAAI,MAAKP,KAAL,CAAWQ,aAAf,EAA8B;AAC5B,cAAKR,KAAL,CAAWQ,aAAX,CAAyBD,KAAK,CAACE,MAAN,CAAaC,OAAtC;AACD;;AAED,UAAI,MAAKC,cAAL,EAAJ,EAA2B;AACzB,cAAKC,QAAL,CAAc;AACZF,UAAAA,OAAO,EAAEH,KAAK,CAACE,MAAN,CAAaC,OADV,EAAd;;AAGD;;AAED,UAAI,MAAKV,KAAL,CAAWa,QAAf,EAAyB;AACvB,cAAKb,KAAL,CAAWa,QAAX,CAAoBN,KAApB;AACD;AACF,KA9I+B;;AAgJxBO,IAAAA,WAhJwB,GAgJV,UAACP,KAAD,EAA+C;AACnE,UAAI,MAAKP,KAAL,CAAWe,OAAf,EAAwB;AACtB,cAAKf,KAAL,CAAWe,OAAX,CAAmBR,KAAnB;AACD;;AAED,UAAIlB,WAAW,CAACc,YAAhB,EAA8B;AAC5B,cAAKS,QAAL,CAAc,EAAEI,UAAU,EAAE,IAAd,EAAd;AACD;AACF,KAxJ+B;;AA0JxBC,IAAAA,UA1JwB,GA0JX,UAACV,KAAD,EAA+C;AAClE,UAAI,MAAKP,KAAL,CAAWkB,MAAf,EAAuB;AACrB,cAAKlB,KAAL,CAAWkB,MAAX,CAAkBX,KAAlB;AACD;AACD,YAAKK,QAAL,CAAc;AACZI,QAAAA,UAAU,EAAE,KADA,EAAd;;AAGD,KAjK+B,CAG9B,MAAKG,KAAL,GAAa,EACXH,UAAU,EAAE,KADD,EAEXN,OAAO,EAAEV,KAAK,CAACoB,cAFJ,EAAb,CAH8B,aAO/B,CApCH,qCAsCSC,iBAtCT,GAsCE,6BAA2B,CACzB,IAAI,KAAKrB,KAAL,CAAWsB,SAAf,EAA0B,CACxBjC,WAAW,CAACc,YAAZ,GAA2B,IAA3B,CACA,KAAKD,KAAL,GACD,CACF,CA3CH,CA6CE;AACF;AACA,KA/CA,QAuDSqB,MAvDT,GAuDE,kBAAgB,mBACd,oBACE,oBAAC,YAAD,CAAc,QAAd,QACG,UAACC,KAAD,EAAW,CACV,MAAI,CAACA,KAAL,GAAaA,KAAb,CACA,OAAO,MAAI,CAACC,UAAL,EAAP,CACD,CAJH,CADF,CAQD,CAhEH,QAkEUA,UAlEV,GAkEE,sBAAqB,iCACnB,kBAA0E,KAAKzB,KAA/E,CAAQ0B,QAAR,eAAQA,QAAR,CAAkBC,eAAlB,eAAkBA,eAAlB,CAAmCvC,OAAnC,eAAmCA,OAAnC,CAA4CwC,KAA5C,eAA4CA,KAA5C,CAAmDC,OAAnD,eAAmDA,OAAnD,CAA4DC,KAA5D,eAA4DA,KAA5D,CAAmEC,EAAnE,eAAmEA,EAAnE,CACA,IAAMC,QAAQ,GAAG,KAAKhC,KAAL,CAAWgC,QAAX,IAAuBH,OAAxC,CACA,IAAMnB,OAAO,GAAG,KAAKC,cAAL,KAAwB,KAAKQ,KAAL,CAAWT,OAAnC,GAA6C,KAAKV,KAAL,CAAWU,OAAxE,CAEA,IAAMuB,mBAAmB,GAAGzC,EAAE,CAACE,MAAM,CAACwC,SAAP,CAAiB,KAAKV,KAAtB,CAAD,iBAC3B9B,MAAM,CAACyC,iBAAP,CAAyB,KAAKX,KAA9B,CAD2B,IACY,CAAC,CAACQ,QADd,MAE3BrC,aAAa,CAACuC,SAFa,IAED,IAFC,MAG3BvC,aAAa,CAACwC,iBAHa,IAGO,CAAC,CAACH,QAHT,MAI3BrC,aAAa,CAACyC,gBAJa,IAIMP,OAJN,OAA9B,CAOA,IAAMQ,eAAe,GAAG7C,EAAE,CAACE,MAAM,CAACI,IAAP,CAAY,KAAK0B,KAAjB,CAAD,mBACvB9B,MAAM,CAAC4C,QAAP,EADuB,IACHX,eAAe,KAAK,MADjB,OAEvBjC,MAAM,CAACsC,QAAP,EAFuB,IAEH,CAAC,CAACA,QAFC,OAGvBrC,aAAa,CAACqC,QAHS,IAGE,CAAC,CAACA,QAHJ,QAA1B,CAMA,IAAIO,OAAO,GAAG,IAAd,CACA,IAAIb,QAAJ,EAAc,UACZ,IAAMc,YAAY,GAAGhD,EAAE,CAACE,MAAM,CAAC6C,OAAP,CAAe,KAAKf,KAApB,CAAD,mBACpB9B,MAAM,CAAC+C,WAAP,CAAmB,KAAKjB,KAAxB,CADoB,IACaG,eAAe,KAAK,MADjC,OAEpBjC,MAAM,CAACgD,eAAP,CAAuB,KAAKlB,KAA5B,CAFoB,IAEiB,CAAC,CAACQ,QAFnB,QAAvB,CAIAO,OAAO,gBAAG,8BAAM,SAAS,EAAEC,YAAjB,IAAgCd,QAAhC,CAAV,CACD,CAED,oBACE,oBAAC,aAAD,aAAe,WAAW,EAAE,KAAKiB,WAAjC,IAAkD,KAAK3C,KAAvD,gBACE,+BAAO,YAAUH,cAAc,CAACC,IAAhC,EAAsC,SAAS,EAAEuC,eAAjD,iBACE,6BACE,SAAS,EAAE7C,EAAE,CAACE,MAAM,CAACkD,MAAP,CAAc,KAAKpB,KAAnB,CAAD,mBACV9B,MAAM,CAACmD,WAAP,EADU,IACalB,eAAe,KAAK,MADjC,OAEVjC,MAAM,CAACoD,SAAP,CAAiB,KAAKtB,KAAtB,CAFU,IAEqB,CAAC,CAACpC,OAFvB,OAGVM,MAAM,CAACqD,OAAP,CAAe,KAAKvB,KAApB,CAHU,IAGmB,CAAC,CAACI,KAHrB,OAIVlC,MAAM,CAACsD,OAAP,CAAe,KAAKxB,KAApB,CAJU,IAImB,CAACQ,QAAD,IAAa,CAAC,CAAC,KAAKb,KAAL,CAAWH,UAJ7C,QADf,iBAQE,+BACE,IAAI,EAAC,UADP,EAEE,OAAO,EAAEN,OAFX,EAGE,QAAQ,EAAE,KAAKJ,YAHjB,EAIE,SAAS,EAAEZ,MAAM,CAACO,KAAP,CAAa,KAAKuB,KAAlB,CAJb,EAKE,OAAO,EAAE,KAAKV,WALhB,EAME,MAAM,EAAE,KAAKG,UANf,EAOE,GAAG,EAAE,KAAKb,QAPZ,EAQE,QAAQ,EAAE4B,QARZ,EASE,EAAE,EAAED,EATN,GARF,eAmBE,6BACE,SAAS,EAAEE,mBADb,EAEE,KAAK,EACHvB,OAAO,IAAIoB,KAAX,IAAoB,CAACE,QAArB,GACI,EACEiB,eAAe,EAAEnB,KADnB,EAEEoB,SAAS,uBAAqBpB,KAFhC,EADJ,GAKIqB,SARR,iBAWE,6BACE,SAAS,EAAE3D,EAAE,CAACE,MAAM,CAAC0D,gBAAP,EAAD,EAA4BzD,aAAa,CAAC0D,UAA1C,mBACV3D,MAAM,CAAC4D,uBAAP,CAA+B,KAAK9B,KAApC,CADU,IACmCK,OADnC,OAEVnC,MAAM,CAAC6D,kBAAP,CAA0B,KAAK/B,KAA/B,CAFU,IAE8BQ,QAF9B,QADf,EAKE,KAAK,EACHtB,OAAO,IAAIoB,KAAX,IAAoB,CAACE,QAArB,GACI,EACEiB,eAAe,EAAEnB,KADnB,EAEEoB,SAAS,uBAAqBpB,KAFhC,EADJ,GAKIqB,SAXR,GAXF,CAnBF,eA6CE,6BACE,SAAS,EAAE3D,EAAE,CAACE,MAAM,CAAC8D,MAAP,CAAc,KAAKhC,KAAnB,CAAD,EAA4B7B,aAAa,CAAC6D,MAA1C,mBACV9D,MAAM,CAAC+D,cAAP,CAAsB,KAAKjC,KAA3B,CADU,IAC0BQ,QAD1B,QADf,GA7CF,CADF,EAoDGO,OApDH,CADF,CADF,CA0DD,CAvJH,QAgMU5B,cAhMV,GAgME,0BAAyB;AACvB,WAAO,KAAKX,KAAL,CAAWU,OAAX,KAAuByC,SAA9B;AACD,GAlMH,iBAA4BjE,KAAK,CAACwE,SAAlC,WACgBC,mBADhB,GACsC,QADtC,UAGgBC,SAHhB,GAG4B,EACxBlD,OAAO,EAAEvB,SAAS,CAAC0E,IADK,EAExBzC,cAAc,EAAEjC,SAAS,CAAC0E,IAFF,EAGxB7B,QAAQ,EAAE7C,SAAS,CAAC0E,IAHI,EAIxBjC,KAAK,EAAEzC,SAAS,CAAC0E,IAJO,EAKxBhC,OAAO,EAAE1C,SAAS,CAAC0E,IALK,EAMxBzE,OAAO,EAAED,SAAS,CAAC0E,IANK,EAOxBrD,aAAa,EAAErB,SAAS,CAAC2E,IAPD,EAQxBhC,KAAK,EAAE,eAAC9B,KAAD,EAAwB,CAC7B,IAAIA,KAAK,CAAC8B,KAAN,IAAe,CAAClC,iBAApB,EAAuC,CACrCR,OAAO,CAAC,KAAD,iGAAP,CACAQ,iBAAiB,GAAG,IAApB,CACD,CACF,CAbuB,EAH5B,UAmBgBmE,YAnBhB,GAmB+B,EAC3B/B,QAAQ,EAAE,KADiB,EAE3BH,OAAO,EAAE,KAFkB,EAG3BF,eAAe,EAAE,OAHU,EAnB/B","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport warning from 'warning';\n\nimport { keyListener } from '../../lib/events/keyListener';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { CommonProps, CommonWrapper } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode';\n\nimport { styles, globalClasses } from './Toggle.styles';\n\nlet colorWarningShown = false;\n\nexport interface ToggleProps extends CommonProps {\n children?: React.ReactNode;\n /**\n * Положение `children` относительно переключателя.\n * @default 'right'\n */\n captionPosition: 'left' | 'right';\n /**\n * Состояние `тогла`, если `true` - `тогл` будет включён, иначе выключен.\n * @default false\n */\n checked?: boolean;\n /**\n * Делает `тогл` включенным по умолчанию.\n */\n defaultChecked?: boolean;\n /**\n * Отключает `тогл`.\n */\n disabled?: boolean;\n /**\n * Событие вызывающееся, когда значение `тогла` меняется, передаёт текущее значение тогла в переданную функцию.\n */\n onValueChange?: (value: boolean) => void;\n /**\n * Событие вызывающееся при клике на `тогл`.\n */\n onChange?: React.ChangeEventHandler<HTMLInputElement>;\n /**\n * Состояние валидации при предупреждении.\n * @default false\n */\n warning?: boolean;\n /**\n * Состояние валидации при ошибке.\n * @default false\n */\n error?: boolean;\n /**\n * Добавляет стили для состояния `loading` и отключает `тогл`.\n */\n loading?: boolean;\n /**\n * Если true, выставляет фокус на `тогле` после загрузки страницы.\n */\n autoFocus?: boolean;\n /**\n * Событие вызывающееся, когда `тогл` получает фокус.\n */\n onFocus?: React.FocusEventHandler<HTMLInputElement>;\n /**\n * Событие вызывающееся, когда `тогл` теряет фокус.\n */\n onBlur?: React.FocusEventHandler<HTMLInputElement>;\n /**\n * @deprecated используйте переменную темы `toggleBgChecked` вместо этого пропа.\n */\n color?: React.CSSProperties['color'];\n /**\n * HTML-атрибут `id` для передачи во внутренний `<input />`.\n */\n id?: string;\n}\n\nexport interface ToggleState {\n checked?: boolean;\n focusByTab?: boolean;\n}\n\nexport const ToggleDataTids = {\n root: 'Toggle__root',\n} as const;\n\n/**\n * _Примечание:_ под тоглом понимается полный компонент т.е. надпись + переключатель, а не просто переключатель.\n */\n@rootNode\nexport class Toggle extends React.Component<ToggleProps, ToggleState> {\n public static __KONTUR_REACT_UI__ = 'Toggle';\n\n public static propTypes = {\n checked: PropTypes.bool,\n defaultChecked: PropTypes.bool,\n disabled: PropTypes.bool,\n error: PropTypes.bool,\n loading: PropTypes.bool,\n warning: PropTypes.bool,\n onValueChange: PropTypes.func,\n color: (props: ToggleProps) => {\n if (props.color && !colorWarningShown) {\n warning(false, `[Toggle]: prop 'color' is deprecated. Please, use theme variable 'toggleBgChecked' instead. `);\n colorWarningShown = true;\n }\n },\n };\n\n public static defaultProps = {\n disabled: false,\n loading: false,\n captionPosition: 'right',\n };\n\n private theme!: Theme;\n private input: HTMLInputElement | null = null;\n private setRootNode!: TSetRootNode;\n\n constructor(props: ToggleProps) {\n super(props);\n\n this.state = {\n focusByTab: false,\n checked: props.defaultChecked,\n };\n }\n\n public componentDidMount() {\n if (this.props.autoFocus) {\n keyListener.isTabPressed = true;\n this.focus();\n }\n }\n\n /**\n * @public\n */\n public focus = () => {\n if (this.input) {\n keyListener.isTabPressed = true;\n this.input.focus();\n }\n };\n\n public render() {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return this.renderMain();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const { children, captionPosition, warning, error, loading, color, id } = this.props;\n const disabled = this.props.disabled || loading;\n const checked = this.isUncontrolled() ? this.state.checked : this.props.checked;\n\n const containerClassNames = cx(styles.container(this.theme), {\n [styles.containerDisabled(this.theme)]: !!disabled,\n [globalClasses.container]: true,\n [globalClasses.containerDisabled]: !!disabled,\n [globalClasses.containerLoading]: loading,\n });\n\n const labelClassNames = cx(styles.root(this.theme), {\n [styles.rootLeft()]: captionPosition === 'left',\n [styles.disabled()]: !!disabled,\n [globalClasses.disabled]: !!disabled,\n });\n\n let caption = null;\n if (children) {\n const captionClass = cx(styles.caption(this.theme), {\n [styles.captionLeft(this.theme)]: captionPosition === 'left',\n [styles.disabledCaption(this.theme)]: !!disabled,\n });\n caption = <span className={captionClass}>{children}</span>;\n }\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <label data-tid={ToggleDataTids.root} className={labelClassNames}>\n <div\n className={cx(styles.button(this.theme), {\n [styles.buttonRight()]: captionPosition === 'left',\n [styles.isWarning(this.theme)]: !!warning,\n [styles.isError(this.theme)]: !!error,\n [styles.focused(this.theme)]: !disabled && !!this.state.focusByTab,\n })}\n >\n <input\n type=\"checkbox\"\n checked={checked}\n onChange={this.handleChange}\n className={styles.input(this.theme)}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n ref={this.inputRef}\n disabled={disabled}\n id={id}\n />\n <div\n className={containerClassNames}\n style={\n checked && color && !disabled\n ? {\n backgroundColor: color,\n boxShadow: `inset 0 0 0 1px ${color}`,\n }\n : undefined\n }\n >\n <div\n className={cx(styles.activeBackground(), globalClasses.background, {\n [styles.activeBackgroundLoading(this.theme)]: loading,\n [styles.disabledBackground(this.theme)]: disabled,\n })}\n style={\n checked && color && !disabled\n ? {\n backgroundColor: color,\n boxShadow: `inset 0 0 0 1px ${color}`,\n }\n : undefined\n }\n />\n </div>\n <div\n className={cx(styles.handle(this.theme), globalClasses.handle, {\n [styles.handleDisabled(this.theme)]: disabled,\n })}\n />\n </div>\n {caption}\n </label>\n </CommonWrapper>\n );\n }\n\n private inputRef = (element: HTMLInputElement) => {\n this.input = element;\n };\n\n private handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {\n if (this.props.onValueChange) {\n this.props.onValueChange(event.target.checked);\n }\n\n if (this.isUncontrolled()) {\n this.setState({\n checked: event.target.checked,\n });\n }\n\n if (this.props.onChange) {\n this.props.onChange(event);\n }\n };\n\n private handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n if (this.props.onFocus) {\n this.props.onFocus(event);\n }\n\n if (keyListener.isTabPressed) {\n this.setState({ focusByTab: true });\n }\n };\n\n private handleBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n if (this.props.onBlur) {\n this.props.onBlur(event);\n }\n this.setState({\n focusByTab: false,\n });\n };\n\n private isUncontrolled() {\n return this.props.checked === undefined;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["Toggle.tsx"],"names":["React","PropTypes","warning","keyListener","ThemeContext","CommonWrapper","cx","rootNode","createPropsGetter","styles","globalClasses","colorWarningShown","ToggleDataTids","root","Toggle","props","getProps","defaultProps","input","focus","isTabPressed","inputRef","element","handleChange","event","onValueChange","target","checked","isUncontrolled","setState","onChange","handleFocus","onFocus","focusByTab","handleBlur","onBlur","state","defaultChecked","componentDidMount","autoFocus","render","theme","renderMain","children","error","color","id","loading","captionPosition","disabled","containerClassNames","container","containerDisabled","containerLoading","labelClassNames","rootLeft","caption","captionClass","captionLeft","disabledCaption","setRootNode","button","buttonRight","isWarning","isError","focused","backgroundColor","boxShadow","undefined","activeBackground","background","activeBackgroundLoading","disabledBackground","handle","handleDisabled","Component","__KONTUR_REACT_UI__","propTypes","bool","func"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport warning from 'warning';\n\nimport { keyListener } from '../../lib/events/keyListener';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { CommonProps, CommonWrapper } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode';\nimport { createPropsGetter } from '../../lib/createPropsGetter';\n\nimport { styles, globalClasses } from './Toggle.styles';\n\nlet colorWarningShown = false;\n\nexport interface ToggleProps extends CommonProps {\n children?: React.ReactNode;\n /**\n * Положение `children` относительно переключателя.\n * @default 'right'\n */\n captionPosition?: 'left' | 'right';\n /**\n * Состояние `тогла`, если `true` - `тогл` будет включён, иначе выключен.\n * @default false\n */\n checked?: boolean;\n /**\n * Делает `тогл` включенным по умолчанию.\n */\n defaultChecked?: boolean;\n /**\n * Отключает `тогл`.\n */\n disabled?: boolean;\n /**\n * Событие вызывающееся, когда значение `тогла` меняется, передаёт текущее значение тогла в переданную функцию.\n */\n onValueChange?: (value: boolean) => void;\n /**\n * Событие вызывающееся при клике на `тогл`.\n */\n onChange?: React.ChangeEventHandler<HTMLInputElement>;\n /**\n * Состояние валидации при предупреждении.\n * @default false\n */\n warning?: boolean;\n /**\n * Состояние валидации при ошибке.\n * @default false\n */\n error?: boolean;\n /**\n * Добавляет стили для состояния `loading` и отключает `тогл`.\n */\n loading?: boolean;\n /**\n * Если true, выставляет фокус на `тогле` после загрузки страницы.\n */\n autoFocus?: boolean;\n /**\n * Событие вызывающееся, когда `тогл` получает фокус.\n */\n onFocus?: React.FocusEventHandler<HTMLInputElement>;\n /**\n * Событие вызывающееся, когда `тогл` теряет фокус.\n */\n onBlur?: React.FocusEventHandler<HTMLInputElement>;\n /**\n * @deprecated используйте переменную темы `toggleBgChecked` вместо этого пропа.\n */\n color?: React.CSSProperties['color'];\n /**\n * HTML-атрибут `id` для передачи во внутренний `<input />`.\n */\n id?: string;\n}\n\nexport interface ToggleState {\n checked?: boolean;\n focusByTab?: boolean;\n}\n\nexport const ToggleDataTids = {\n root: 'Toggle__root',\n} as const;\n\ntype DefaultProps = Required<Pick<ToggleProps, 'disabled' | 'loading' | 'captionPosition'>>;\n\n/**\n * _Примечание:_ под тоглом понимается полный компонент т.е. надпись + переключатель, а не просто переключатель.\n */\n@rootNode\nexport class Toggle extends React.Component<ToggleProps, ToggleState> {\n public static __KONTUR_REACT_UI__ = 'Toggle';\n\n public static propTypes = {\n checked: PropTypes.bool,\n defaultChecked: PropTypes.bool,\n disabled: PropTypes.bool,\n error: PropTypes.bool,\n loading: PropTypes.bool,\n warning: PropTypes.bool,\n onValueChange: PropTypes.func,\n color: (props: ToggleProps) => {\n if (props.color && !colorWarningShown) {\n warning(false, `[Toggle]: prop 'color' is deprecated. Please, use theme variable 'toggleBgChecked' instead. `);\n colorWarningShown = true;\n }\n },\n };\n\n public static defaultProps: DefaultProps = {\n disabled: false,\n loading: false,\n captionPosition: 'right',\n };\n\n private getProps = createPropsGetter(Toggle.defaultProps);\n\n private theme!: Theme;\n private input: HTMLInputElement | null = null;\n private setRootNode!: TSetRootNode;\n\n constructor(props: ToggleProps) {\n super(props);\n\n this.state = {\n focusByTab: false,\n checked: props.defaultChecked,\n };\n }\n\n public componentDidMount() {\n if (this.props.autoFocus) {\n keyListener.isTabPressed = true;\n this.focus();\n }\n }\n\n /**\n * @public\n */\n public focus = () => {\n if (this.input) {\n keyListener.isTabPressed = true;\n this.input.focus();\n }\n };\n\n public render() {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return this.renderMain();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const { children, warning, error, color, id } = this.props;\n const { loading, captionPosition } = this.getProps();\n const disabled = this.getProps().disabled || loading;\n const checked = this.isUncontrolled() ? this.state.checked : this.props.checked;\n\n const containerClassNames = cx(styles.container(this.theme), {\n [styles.containerDisabled(this.theme)]: !!disabled,\n [globalClasses.container]: true,\n [globalClasses.containerDisabled]: !!disabled,\n [globalClasses.containerLoading]: loading,\n });\n\n const labelClassNames = cx(styles.root(this.theme), {\n [styles.rootLeft()]: captionPosition === 'left',\n [styles.disabled()]: !!disabled,\n [globalClasses.disabled]: !!disabled,\n });\n\n let caption = null;\n if (children) {\n const captionClass = cx(styles.caption(this.theme), {\n [styles.captionLeft(this.theme)]: captionPosition === 'left',\n [styles.disabledCaption(this.theme)]: !!disabled,\n });\n caption = <span className={captionClass}>{children}</span>;\n }\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <label data-tid={ToggleDataTids.root} className={labelClassNames}>\n <div\n className={cx(styles.button(this.theme), {\n [styles.buttonRight()]: captionPosition === 'left',\n [styles.isWarning(this.theme)]: !!warning,\n [styles.isError(this.theme)]: !!error,\n [styles.focused(this.theme)]: !disabled && !!this.state.focusByTab,\n })}\n >\n <input\n type=\"checkbox\"\n checked={checked}\n onChange={this.handleChange}\n className={styles.input(this.theme)}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n ref={this.inputRef}\n disabled={disabled}\n id={id}\n />\n <div\n className={containerClassNames}\n style={\n checked && color && !disabled\n ? {\n backgroundColor: color,\n boxShadow: `inset 0 0 0 1px ${color}`,\n }\n : undefined\n }\n >\n <div\n className={cx(styles.activeBackground(), globalClasses.background, {\n [styles.activeBackgroundLoading(this.theme)]: loading,\n [styles.disabledBackground(this.theme)]: disabled,\n })}\n style={\n checked && color && !disabled\n ? {\n backgroundColor: color,\n boxShadow: `inset 0 0 0 1px ${color}`,\n }\n : undefined\n }\n />\n </div>\n <div\n className={cx(styles.handle(this.theme), globalClasses.handle, {\n [styles.handleDisabled(this.theme)]: disabled,\n })}\n />\n </div>\n {caption}\n </label>\n </CommonWrapper>\n );\n }\n\n private inputRef = (element: HTMLInputElement) => {\n this.input = element;\n };\n\n private handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {\n if (this.props.onValueChange) {\n this.props.onValueChange(event.target.checked);\n }\n\n if (this.isUncontrolled()) {\n this.setState({\n checked: event.target.checked,\n });\n }\n\n if (this.props.onChange) {\n this.props.onChange(event);\n }\n };\n\n private handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n if (this.props.onFocus) {\n this.props.onFocus(event);\n }\n\n if (keyListener.isTabPressed) {\n this.setState({ focusByTab: true });\n }\n };\n\n private handleBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n if (this.props.onBlur) {\n this.props.onBlur(event);\n }\n this.setState({\n focusByTab: false,\n });\n };\n\n private isUncontrolled() {\n return this.props.checked === undefined;\n }\n}\n"]}
|
|
@@ -7,7 +7,7 @@ export interface ToggleProps extends CommonProps {
|
|
|
7
7
|
* Положение `children` относительно переключателя.
|
|
8
8
|
* @default 'right'
|
|
9
9
|
*/
|
|
10
|
-
captionPosition
|
|
10
|
+
captionPosition?: 'left' | 'right';
|
|
11
11
|
/**
|
|
12
12
|
* Состояние `тогла`, если `true` - `тогл` будет включён, иначе выключен.
|
|
13
13
|
* @default false
|
|
@@ -71,6 +71,7 @@ export interface ToggleState {
|
|
|
71
71
|
export declare const ToggleDataTids: {
|
|
72
72
|
readonly root: "Toggle__root";
|
|
73
73
|
};
|
|
74
|
+
declare type DefaultProps = Required<Pick<ToggleProps, 'disabled' | 'loading' | 'captionPosition'>>;
|
|
74
75
|
/**
|
|
75
76
|
* _Примечание:_ под тоглом понимается полный компонент т.е. надпись + переключатель, а не просто переключатель.
|
|
76
77
|
*/
|
|
@@ -86,11 +87,8 @@ export declare class Toggle extends React.Component<ToggleProps, ToggleState> {
|
|
|
86
87
|
onValueChange: PropTypes.Requireable<(...args: any[]) => any>;
|
|
87
88
|
color: (props: ToggleProps) => void;
|
|
88
89
|
};
|
|
89
|
-
static defaultProps:
|
|
90
|
-
|
|
91
|
-
loading: boolean;
|
|
92
|
-
captionPosition: string;
|
|
93
|
-
};
|
|
90
|
+
static defaultProps: DefaultProps;
|
|
91
|
+
private getProps;
|
|
94
92
|
private theme;
|
|
95
93
|
private input;
|
|
96
94
|
private setRootNode;
|
|
@@ -108,3 +106,4 @@ export declare class Toggle extends React.Component<ToggleProps, ToggleState> {
|
|
|
108
106
|
private handleBlur;
|
|
109
107
|
private isUncontrolled;
|
|
110
108
|
}
|
|
109
|
+
export {};
|
|
@@ -59,6 +59,7 @@ import { MenuItem } from "../../MenuItem/MenuItem";
|
|
|
59
59
|
import { CommonWrapper } from "../../../internal/CommonWrapper";
|
|
60
60
|
import { cx } from "../../../lib/theming/Emotion";
|
|
61
61
|
import { getRootNode, rootNode } from "../../../lib/rootNode";
|
|
62
|
+
import { createPropsGetter } from "../../../lib/createPropsGetter";
|
|
62
63
|
import { TokenInputLocaleHelper } from "../locale";
|
|
63
64
|
import { styles } from "../TokenInput.styles";
|
|
64
65
|
import { tokenInputReducer } from "../TokenInputReducer";
|
|
@@ -124,6 +125,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
124
125
|
}
|
|
125
126
|
|
|
126
127
|
_this = _React$PureComponent.call.apply(_React$PureComponent, [this].concat(args)) || this;
|
|
128
|
+
_this.getProps = createPropsGetter(TokenInput.defaultProps);
|
|
127
129
|
_this.state = DefaultState;
|
|
128
130
|
_this.input = null;
|
|
129
131
|
_this.tokensInputMenu = null;
|
|
@@ -168,9 +170,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
168
170
|
type: 'SET_FOCUS_IN'
|
|
169
171
|
});
|
|
170
172
|
|
|
171
|
-
|
|
172
|
-
_this.props.onFocus(event);
|
|
173
|
-
}
|
|
173
|
+
_this.getProps().onFocus(event);
|
|
174
174
|
};
|
|
175
175
|
|
|
176
176
|
_this.handleInputBlur = function (event) {
|
|
@@ -202,7 +202,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
202
202
|
type: 'BLUR'
|
|
203
203
|
});
|
|
204
204
|
|
|
205
|
-
_this.
|
|
205
|
+
_this.getProps().onBlur(event);
|
|
206
206
|
}
|
|
207
207
|
};
|
|
208
208
|
|
|
@@ -210,7 +210,6 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
210
210
|
var _this$state = _this.state,
|
|
211
211
|
inputValue = _this$state.inputValue,
|
|
212
212
|
autocompleteItems = _this$state.autocompleteItems;
|
|
213
|
-
var valueToString = _this.props.valueToString;
|
|
214
213
|
|
|
215
214
|
if (inputValue === '') {
|
|
216
215
|
// если стерли содержимое токена в режиме редактирования, то удаляем токен
|
|
@@ -232,7 +231,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
232
231
|
if (autocompleteItems && autocompleteItems.length === 1) {
|
|
233
232
|
var _item = autocompleteItems[0];
|
|
234
233
|
|
|
235
|
-
if (valueToString(_item) === inputValue) {
|
|
234
|
+
if (_this.getProps().valueToString(_item) === inputValue) {
|
|
236
235
|
_this.isEditingMode ? _this.finishTokenEdit() : _this.selectItem(_item);
|
|
237
236
|
return;
|
|
238
237
|
}
|
|
@@ -288,17 +287,23 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
288
287
|
return;
|
|
289
288
|
}
|
|
290
289
|
|
|
291
|
-
event.preventDefault();
|
|
290
|
+
event.preventDefault();
|
|
291
|
+
|
|
292
|
+
var _this$getProps = _this.getProps(),
|
|
293
|
+
selectedItems = _this$getProps.selectedItems,
|
|
294
|
+
valueToString = _this$getProps.valueToString,
|
|
295
|
+
delimiters = _this$getProps.delimiters; // упорядочивание токенов по индексу
|
|
296
|
+
|
|
292
297
|
|
|
293
298
|
var tokens = _this.state.activeTokens.map(function (token) {
|
|
294
|
-
return
|
|
299
|
+
return selectedItems.indexOf(token);
|
|
295
300
|
}).sort().map(function (index) {
|
|
296
|
-
return
|
|
301
|
+
return selectedItems[index];
|
|
297
302
|
}).map(function (item) {
|
|
298
|
-
return
|
|
303
|
+
return valueToString(item);
|
|
299
304
|
});
|
|
300
305
|
|
|
301
|
-
event.clipboardData.setData('text/plain', tokens.join(
|
|
306
|
+
event.clipboardData.setData('text/plain', tokens.join(delimiters[0]));
|
|
302
307
|
};
|
|
303
308
|
|
|
304
309
|
_this.handleInputPaste = function (event) {
|
|
@@ -307,7 +312,12 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
307
312
|
}
|
|
308
313
|
|
|
309
314
|
var paste = event.clipboardData.getData('text');
|
|
310
|
-
|
|
315
|
+
|
|
316
|
+
var _this$getProps2 = _this.getProps(),
|
|
317
|
+
delimiters = _this$getProps2.delimiters,
|
|
318
|
+
selectedItems = _this$getProps2.selectedItems,
|
|
319
|
+
valueToItem = _this$getProps2.valueToItem,
|
|
320
|
+
onValueChange = _this$getProps2.onValueChange;
|
|
311
321
|
|
|
312
322
|
if (delimiters.some(function (delimiter) {
|
|
313
323
|
return paste.includes(delimiter);
|
|
@@ -323,14 +333,13 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
323
333
|
var tokens = paste.split(delimiters[0]);
|
|
324
334
|
|
|
325
335
|
var _items = tokens.map(function (token) {
|
|
326
|
-
return
|
|
336
|
+
return valueToItem(token);
|
|
327
337
|
}).filter(function (item) {
|
|
328
|
-
return !_this.hasValueInItems(
|
|
338
|
+
return !_this.hasValueInItems(selectedItems, item);
|
|
329
339
|
});
|
|
330
340
|
|
|
331
|
-
var newItems =
|
|
332
|
-
|
|
333
|
-
_this.props.onValueChange(newItems);
|
|
341
|
+
var newItems = selectedItems.concat(_items);
|
|
342
|
+
onValueChange(newItems);
|
|
334
343
|
|
|
335
344
|
_this.dispatch({
|
|
336
345
|
type: 'SET_AUTOCOMPLETE_ITEMS',
|
|
@@ -343,7 +352,8 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
343
352
|
|
|
344
353
|
_this.tryGetItems = /*#__PURE__*/function () {
|
|
345
354
|
var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(query) {
|
|
346
|
-
var autocompleteItems, isSelectedItem, isEditingItem, autocompleteItemsUnique, editingItem, selectItemIndex;
|
|
355
|
+
var autocompleteItems, _this$getProps3, selectedItems, valueToItem, valueToString, isSelectedItem, isEditingItem, autocompleteItemsUnique, editingItem, selectItemIndex;
|
|
356
|
+
|
|
347
357
|
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
348
358
|
while (1) {
|
|
349
359
|
switch (_context.prev = _context.next) {
|
|
@@ -353,7 +363,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
353
363
|
}
|
|
354
364
|
|
|
355
365
|
if (!(_this.props.getItems && (_this.state.inputValue !== '' || !_this.props.hideMenuIfEmptyInputValue))) {
|
|
356
|
-
_context.next =
|
|
366
|
+
_context.next = 15;
|
|
357
367
|
break;
|
|
358
368
|
}
|
|
359
369
|
|
|
@@ -373,12 +383,14 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
373
383
|
payload: false
|
|
374
384
|
});
|
|
375
385
|
|
|
386
|
+
_this$getProps3 = _this.getProps(), selectedItems = _this$getProps3.selectedItems, valueToItem = _this$getProps3.valueToItem, valueToString = _this$getProps3.valueToString;
|
|
387
|
+
|
|
376
388
|
isSelectedItem = function isSelectedItem(item) {
|
|
377
|
-
return _this.hasValueInItems(
|
|
389
|
+
return _this.hasValueInItems(selectedItems, item);
|
|
378
390
|
};
|
|
379
391
|
|
|
380
392
|
isEditingItem = function isEditingItem(item) {
|
|
381
|
-
var editingItem =
|
|
393
|
+
var editingItem = selectedItems[_this.state.editingTokenIndex];
|
|
382
394
|
return !!editingItem && isEqual(item, editingItem);
|
|
383
395
|
};
|
|
384
396
|
|
|
@@ -387,9 +399,9 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
387
399
|
});
|
|
388
400
|
|
|
389
401
|
if (_this.isEditingMode) {
|
|
390
|
-
editingItem =
|
|
402
|
+
editingItem = selectedItems[_this.state.editingTokenIndex];
|
|
391
403
|
|
|
392
|
-
if (isEqual(editingItem,
|
|
404
|
+
if (isEqual(editingItem, valueToItem(_this.state.inputValue)) && !_this.hasValueInItems(autocompleteItemsUnique, editingItem)) {
|
|
393
405
|
autocompleteItemsUnique.unshift(editingItem);
|
|
394
406
|
}
|
|
395
407
|
}
|
|
@@ -406,14 +418,14 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
406
418
|
}
|
|
407
419
|
|
|
408
420
|
selectItemIndex = autocompleteItemsUnique.findIndex(function (item) {
|
|
409
|
-
return
|
|
421
|
+
return valueToString(item).toLowerCase() === _this.state.inputValue.toLowerCase();
|
|
410
422
|
});
|
|
411
423
|
|
|
412
424
|
if (_this.menuRef) {
|
|
413
425
|
_this.menuRef.highlightItem(selectItemIndex < 0 ? 0 : selectItemIndex);
|
|
414
426
|
}
|
|
415
427
|
|
|
416
|
-
case
|
|
428
|
+
case 15:
|
|
417
429
|
case "end":
|
|
418
430
|
return _context.stop();
|
|
419
431
|
}
|
|
@@ -439,7 +451,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
439
451
|
|
|
440
452
|
e.stopPropagation();
|
|
441
453
|
|
|
442
|
-
if (_this.type !== TokenInputType.WithReference && _this.
|
|
454
|
+
if (_this.type !== TokenInputType.WithReference && _this.getProps().delimiters.some(function (key) {
|
|
443
455
|
return key === e.key || key === ',' && isKeyComma(e);
|
|
444
456
|
}) || isKeyEnter(e) && _this.type === TokenInputType.WithoutReference) {
|
|
445
457
|
e.preventDefault();
|
|
@@ -515,16 +527,19 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
515
527
|
_this.handleWrapperKeyDown = function (e) {
|
|
516
528
|
var _this$wrapper2;
|
|
517
529
|
|
|
530
|
+
var _this$getProps4 = _this.getProps(),
|
|
531
|
+
selectedItems = _this$getProps4.selectedItems,
|
|
532
|
+
onValueChange = _this$getProps4.onValueChange;
|
|
533
|
+
|
|
518
534
|
switch (true) {
|
|
519
535
|
case isKeyBackspace(e):
|
|
520
536
|
case isKeyDelete(e):
|
|
521
537
|
{
|
|
522
538
|
if (!_this.isEditingMode) {
|
|
523
|
-
var itemsNew =
|
|
539
|
+
var itemsNew = selectedItems.filter(function (item) {
|
|
524
540
|
return !_this.hasValueInItems(_this.state.activeTokens, item);
|
|
525
541
|
});
|
|
526
|
-
|
|
527
|
-
_this.props.onValueChange(itemsNew);
|
|
542
|
+
onValueChange(itemsNew);
|
|
528
543
|
|
|
529
544
|
_this.dispatch({
|
|
530
545
|
type: 'REMOVE_ALL_ACTIVE_TOKENS'
|
|
@@ -562,7 +577,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
562
577
|
|
|
563
578
|
_this.dispatch({
|
|
564
579
|
type: 'SET_ACTIVE_TOKENS',
|
|
565
|
-
payload:
|
|
580
|
+
payload: selectedItems
|
|
566
581
|
});
|
|
567
582
|
|
|
568
583
|
break;
|
|
@@ -571,13 +586,14 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
571
586
|
|
|
572
587
|
_this.handleWrapperArrows = function (e) {
|
|
573
588
|
e.preventDefault();
|
|
574
|
-
var activeTokens = _this.state.activeTokens;
|
|
575
589
|
|
|
576
|
-
var
|
|
590
|
+
var selectedItems = _this.getProps().selectedItems;
|
|
577
591
|
|
|
592
|
+
var activeTokens = _this.state.activeTokens;
|
|
593
|
+
var activeItemIndex = selectedItems.indexOf(activeTokens[0]);
|
|
578
594
|
var newItemIndex = activeItemIndex + (isKeyArrowLeft(e) ? -1 : +1);
|
|
579
595
|
var isLeftEdge = activeItemIndex === 0 && isKeyArrowLeft(e);
|
|
580
|
-
var isRightEdge = activeItemIndex ===
|
|
596
|
+
var isRightEdge = activeItemIndex === selectedItems.length - 1 && isKeyArrowRight(e);
|
|
581
597
|
|
|
582
598
|
if (!e.shiftKey && activeTokens.length === 1) {
|
|
583
599
|
_this.handleWrapperArrowsWithoutShift(isLeftEdge, isRightEdge, newItemIndex);
|
|
@@ -598,14 +614,15 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
598
614
|
} else if (!isLeftEdge) {
|
|
599
615
|
_this.dispatch({
|
|
600
616
|
type: 'SET_ACTIVE_TOKENS',
|
|
601
|
-
payload: [_this.
|
|
617
|
+
payload: [_this.getProps().selectedItems[newItemIndex]]
|
|
602
618
|
});
|
|
603
619
|
}
|
|
604
620
|
};
|
|
605
621
|
|
|
606
622
|
_this.handleWrapperArrowsWithShift = function (isLeftEdge, isRightEdge, newItemIndex) {
|
|
607
623
|
if (!isLeftEdge && !isRightEdge) {
|
|
608
|
-
var itemNew = _this.
|
|
624
|
+
var itemNew = _this.getProps().selectedItems[newItemIndex];
|
|
625
|
+
|
|
609
626
|
var itemsNew = [itemNew].concat(_this.state.activeTokens.filter(function (item) {
|
|
610
627
|
return !isEqual(item, itemNew);
|
|
611
628
|
}));
|
|
@@ -618,11 +635,11 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
618
635
|
};
|
|
619
636
|
|
|
620
637
|
_this.handleValueChange = function (items) {
|
|
621
|
-
_this.
|
|
638
|
+
_this.getProps().onValueChange(items);
|
|
622
639
|
};
|
|
623
640
|
|
|
624
641
|
_this.handleAddItem = function () {
|
|
625
|
-
var item = _this.
|
|
642
|
+
var item = _this.getProps().valueToItem(_this.state.inputValue);
|
|
626
643
|
|
|
627
644
|
if (item) {
|
|
628
645
|
_this.selectItem(item);
|
|
@@ -630,12 +647,14 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
630
647
|
};
|
|
631
648
|
|
|
632
649
|
_this.selectItem = function (item) {
|
|
633
|
-
var
|
|
650
|
+
var _this$getProps5 = _this.getProps(),
|
|
651
|
+
selectedItems = _this$getProps5.selectedItems,
|
|
652
|
+
valueToString = _this$getProps5.valueToString;
|
|
634
653
|
|
|
635
654
|
if (_this.isEditingMode) {
|
|
636
655
|
_this.dispatch({
|
|
637
656
|
type: 'UPDATE_QUERY',
|
|
638
|
-
payload:
|
|
657
|
+
payload: valueToString(item)
|
|
639
658
|
}, _this.finishTokenEdit);
|
|
640
659
|
} else if (!_this.hasValueInItems(selectedItems, item)) {
|
|
641
660
|
_this.handleValueChange(selectedItems.concat([item]));
|
|
@@ -649,7 +668,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
649
668
|
};
|
|
650
669
|
|
|
651
670
|
_this.handleRemoveToken = function (item) {
|
|
652
|
-
_this.props.onValueChange
|
|
671
|
+
_this.props.onValueChange == null ? void 0 : _this.props.onValueChange(_this.getProps().selectedItems.filter(function (_) {
|
|
653
672
|
return !isEqual(_, item);
|
|
654
673
|
}));
|
|
655
674
|
|
|
@@ -692,7 +711,11 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
692
711
|
};
|
|
693
712
|
|
|
694
713
|
_this.handleTokenEdit = function (itemNew) {
|
|
695
|
-
var
|
|
714
|
+
var _this$getProps6 = _this.getProps(),
|
|
715
|
+
selectedItems = _this$getProps6.selectedItems,
|
|
716
|
+
valueToString = _this$getProps6.valueToString;
|
|
717
|
+
|
|
718
|
+
var editingTokenIndex = selectedItems.findIndex(function (item) {
|
|
696
719
|
return item === itemNew;
|
|
697
720
|
});
|
|
698
721
|
|
|
@@ -712,7 +735,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
712
735
|
|
|
713
736
|
_this.dispatch({
|
|
714
737
|
type: 'UPDATE_QUERY',
|
|
715
|
-
payload:
|
|
738
|
+
payload: valueToString(itemNew)
|
|
716
739
|
}, _this.selectInputText);
|
|
717
740
|
|
|
718
741
|
_this.dispatch({
|
|
@@ -723,14 +746,15 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
723
746
|
};
|
|
724
747
|
|
|
725
748
|
_this.finishTokenEdit = function () {
|
|
749
|
+
var selectedItems = _this.getProps().selectedItems;
|
|
750
|
+
|
|
726
751
|
var _this$state2 = _this.state,
|
|
727
752
|
editingTokenIndex = _this$state2.editingTokenIndex,
|
|
728
753
|
inputValue = _this$state2.inputValue,
|
|
729
754
|
reservedInputValue = _this$state2.reservedInputValue;
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
var editedItem = valueToItem(inputValue);
|
|
755
|
+
|
|
756
|
+
var editedItem = _this.getProps().valueToItem(inputValue);
|
|
757
|
+
|
|
734
758
|
var newItems = selectedItems.concat([]);
|
|
735
759
|
|
|
736
760
|
if (!_this.hasValueInItems(selectedItems, editedItem)) {
|
|
@@ -834,22 +858,24 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
834
858
|
|
|
835
859
|
_this.renderTokensStart = function () {
|
|
836
860
|
var editingTokenIndex = _this.state.editingTokenIndex;
|
|
837
|
-
|
|
861
|
+
|
|
862
|
+
var selectedItems = _this.getProps().selectedItems;
|
|
863
|
+
|
|
838
864
|
var delimiter = editingTokenIndex >= 0 ? editingTokenIndex : selectedItems.length;
|
|
839
865
|
return selectedItems.slice(0, delimiter).map(_this.renderToken);
|
|
840
866
|
};
|
|
841
867
|
|
|
842
868
|
_this.renderTokensEnd = function () {
|
|
843
869
|
if (_this.state.editingTokenIndex >= 0) {
|
|
844
|
-
return _this.
|
|
870
|
+
return _this.getProps().selectedItems.slice(_this.state.editingTokenIndex + 1).map(_this.renderToken);
|
|
845
871
|
}
|
|
846
872
|
};
|
|
847
873
|
|
|
848
874
|
_this.renderToken = function (item) {
|
|
849
|
-
var _this$
|
|
850
|
-
_this$
|
|
851
|
-
renderToken = _this$
|
|
852
|
-
disabled = _this$
|
|
875
|
+
var _this$props = _this.props,
|
|
876
|
+
_this$props$renderTok = _this$props.renderToken,
|
|
877
|
+
renderToken = _this$props$renderTok === void 0 ? defaultRenderToken : _this$props$renderTok,
|
|
878
|
+
disabled = _this$props.disabled;
|
|
853
879
|
|
|
854
880
|
var isActive = _this.state.activeTokens.includes(item); // TODO useCallback
|
|
855
881
|
|
|
@@ -937,7 +963,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
937
963
|
});
|
|
938
964
|
}
|
|
939
965
|
|
|
940
|
-
if (prevProps.selectedItems.length !== this.
|
|
966
|
+
if (prevProps.selectedItems.length !== this.getProps().selectedItems.length) {
|
|
941
967
|
LayoutEvents.emit();
|
|
942
968
|
}
|
|
943
969
|
|
|
@@ -986,24 +1012,27 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
986
1012
|
throw Error('Missed getItems for type ' + this.type);
|
|
987
1013
|
}
|
|
988
1014
|
|
|
989
|
-
var _this$
|
|
990
|
-
|
|
991
|
-
|
|
992
|
-
|
|
993
|
-
|
|
994
|
-
|
|
995
|
-
|
|
996
|
-
|
|
997
|
-
|
|
998
|
-
|
|
999
|
-
|
|
1000
|
-
|
|
1001
|
-
|
|
1002
|
-
|
|
1003
|
-
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1015
|
+
var _this$props2 = this.props,
|
|
1016
|
+
maxMenuHeight = _this$props2.maxMenuHeight,
|
|
1017
|
+
error = _this$props2.error,
|
|
1018
|
+
warning = _this$props2.warning,
|
|
1019
|
+
disabled = _this$props2.disabled,
|
|
1020
|
+
placeholder = _this$props2.placeholder,
|
|
1021
|
+
renderNotFound = _this$props2.renderNotFound,
|
|
1022
|
+
hideMenuIfEmptyInputValue = _this$props2.hideMenuIfEmptyInputValue,
|
|
1023
|
+
inputMode = _this$props2.inputMode,
|
|
1024
|
+
renderTotalCount = _this$props2.renderTotalCount,
|
|
1025
|
+
totalCount = _this$props2.totalCount;
|
|
1026
|
+
|
|
1027
|
+
var _this$getProps7 = this.getProps(),
|
|
1028
|
+
selectedItems = _this$getProps7.selectedItems,
|
|
1029
|
+
width = _this$getProps7.width,
|
|
1030
|
+
onMouseEnter = _this$getProps7.onMouseEnter,
|
|
1031
|
+
onMouseLeave = _this$getProps7.onMouseLeave,
|
|
1032
|
+
menuWidth = _this$getProps7.menuWidth,
|
|
1033
|
+
menuAlign = _this$getProps7.menuAlign,
|
|
1034
|
+
renderItem = _this$getProps7.renderItem;
|
|
1035
|
+
|
|
1007
1036
|
var _this$state3 = this.state,
|
|
1008
1037
|
activeTokens = _this$state3.activeTokens,
|
|
1009
1038
|
inFocus = _this$state3.inFocus,
|
|
@@ -1113,7 +1142,7 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
1113
1142
|
};
|
|
1114
1143
|
|
|
1115
1144
|
_proto.moveFocusToLastToken = function moveFocusToLastToken() {
|
|
1116
|
-
var items = this.
|
|
1145
|
+
var items = this.getProps().selectedItems;
|
|
1117
1146
|
|
|
1118
1147
|
if (this.state.inputValue === '' && items && items.length > 0) {
|
|
1119
1148
|
this.dispatch({
|
|
@@ -1127,13 +1156,13 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
1127
1156
|
key: "showAddItemHint",
|
|
1128
1157
|
get: function get() {
|
|
1129
1158
|
var items = this.state.autocompleteItems;
|
|
1130
|
-
var value = this.
|
|
1159
|
+
var value = this.getProps().valueToItem(this.state.inputValue);
|
|
1131
1160
|
|
|
1132
1161
|
if (items && this.hasValueInItems(items, value)) {
|
|
1133
1162
|
return false;
|
|
1134
1163
|
}
|
|
1135
1164
|
|
|
1136
|
-
var selectedItems = this.
|
|
1165
|
+
var selectedItems = this.getProps().selectedItems;
|
|
1137
1166
|
|
|
1138
1167
|
if (selectedItems && this.hasValueInItems(selectedItems, value)) {
|
|
1139
1168
|
return false;
|
|
@@ -1184,9 +1213,10 @@ export var TokenInput = (_dec = locale('TokenInput', TokenInputLocaleHelper), ro
|
|
|
1184
1213
|
var _this$state4 = this.state,
|
|
1185
1214
|
inputValue = _this$state4.inputValue,
|
|
1186
1215
|
editingTokenIndex = _this$state4.editingTokenIndex;
|
|
1187
|
-
|
|
1188
|
-
|
|
1189
|
-
valueToString = _this$
|
|
1216
|
+
|
|
1217
|
+
var _this$getProps8 = this.getProps(),
|
|
1218
|
+
valueToString = _this$getProps8.valueToString,
|
|
1219
|
+
selectedItems = _this$getProps8.selectedItems;
|
|
1190
1220
|
|
|
1191
1221
|
if (this.isEditingMode) {
|
|
1192
1222
|
return valueToString(selectedItems[editingTokenIndex]) !== inputValue;
|