draft-components 2.1.0 → 2.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.
@@ -1528,8 +1528,8 @@
1528
1528
  background: var(--dc-password-input-toggle-bg);
1529
1529
  }
1530
1530
 
1531
- .dc-password-input__toggle-button:focus,
1532
- .dc-password-input__toggle-button:hover {
1531
+ .dc-password-input__toggle-button:not(:disabled):focus,
1532
+ .dc-password-input__toggle-button:not(:disabled):hover {
1533
1533
  color: var(--dc-password-input-toggle-color-hover);
1534
1534
  cursor: pointer;
1535
1535
  outline: none;
@@ -1,9 +1,11 @@
1
- import { ReactNode } from 'react';
1
+ import { MouseEventHandler, ReactNode } from 'react';
2
2
  import { TextInputProps } from '../text-input/index.js';
3
3
  export type PasswordInputBaseProps = Omit<TextInputProps, 'type' | 'slotRight'>;
4
4
  export type PasswordInputProps = {
5
+ loading?: boolean;
5
6
  defaultVisible?: boolean;
6
7
  getTooltipText?: (visible: boolean) => ReactNode;
7
8
  renderToggleButtonIcon?: (visible: boolean) => ReactNode;
9
+ onClickToggleButton?: MouseEventHandler<HTMLButtonElement>;
8
10
  } & PasswordInputBaseProps;
9
11
  export declare const PasswordInput: import("react").ForwardRefExoticComponent<Omit<PasswordInputProps, "ref"> & import("react").RefAttributes<HTMLInputElement>>;
@@ -5,13 +5,22 @@ import { TextInput } from '../text-input/index.js';
5
5
  import { Tooltip } from '../tooltip/index.js';
6
6
  import { EyeIcon } from '../hero-icons/24/outline/eye-icon.js';
7
7
  import { EyeSlashIcon } from '../hero-icons/24/outline/eye-slash-icon.js';
8
+ import { Spinner } from '../spinner/index.js';
8
9
  const getDefaultTooltipText = (visible) => (visible
9
10
  ? 'Hide password'
10
11
  : 'Show password');
11
12
  const renderToggleButtonDefaultIcon = (visible) => (visible
12
13
  ? _jsx(EyeIcon, { width: "1.25em", height: "1.25em" })
13
14
  : _jsx(EyeSlashIcon, { width: "1.25em", height: "1.25em" }));
14
- export const PasswordInput = forwardRef(function PasswordInput({ className, defaultVisible = false, getTooltipText = getDefaultTooltipText, renderToggleButtonIcon = renderToggleButtonDefaultIcon, ...props }, ref) {
15
+ export const PasswordInput = forwardRef(function PasswordInput({ className, loading = false, defaultVisible = false, getTooltipText = getDefaultTooltipText, renderToggleButtonIcon = renderToggleButtonDefaultIcon, onClickToggleButton, ...props }, ref) {
15
16
  const [visible, setVisible] = useState(defaultVisible);
16
- return (_jsx(TextInput, { ...props, ref: ref, className: classNames('dc-password-input', className), type: visible ? 'text' : 'password', slotRight: () => (_jsx(Tooltip, { content: getTooltipText(visible), children: _jsx("button", { className: "dc-password-input__toggle-button", type: "button", onClick: () => setVisible(!visible), children: renderToggleButtonIcon(visible) }) })) }));
17
+ const handleClickToggleButton = (event) => {
18
+ setVisible(!visible);
19
+ if (typeof onClickToggleButton === 'function') {
20
+ onClickToggleButton(event);
21
+ }
22
+ };
23
+ return (_jsx(TextInput, { ...props, ref: ref, className: classNames('dc-password-input', className), type: visible ? 'text' : 'password', readOnly: loading ?? props.readOnly, slotRight: () => (_jsx(Tooltip, { content: getTooltipText(visible), children: _jsx("button", { className: "dc-password-input__toggle-button", type: "button", disabled: loading, onClick: handleClickToggleButton, children: loading
24
+ ? _jsx(Spinner, { width: "1.15em" })
25
+ : renderToggleButtonIcon(visible) }) })) }));
17
26
  });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "draft-components",
3
- "version": "2.1.0",
3
+ "version": "2.3.0",
4
4
  "description": "The React based UI components library.",
5
5
  "type": "module",
6
6
  "exports": {