@preply/ds-web-lib 0.49.0 → 0.51.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.
Files changed (27) hide show
  1. package/dist/components/AvatarWithStatus/AvatarWithStatus.js +2 -2
  2. package/dist/components/Badge/Badge.d.ts +10 -0
  3. package/dist/components/Badge/Badge.js +23 -0
  4. package/dist/components/Badge/style/index.module.less +7 -0
  5. package/dist/components/Badge/style/index.module.less.js +9 -0
  6. package/dist/components/Badge/style/mixins.less +56 -0
  7. package/dist/components/Badge/style/mixins.less.js +8 -0
  8. package/dist/components/Link/Link.d.ts +2 -1
  9. package/dist/components/Link/Link.js +7 -5
  10. package/dist/components/PasswordField/PasswordField.d.ts +9 -0
  11. package/dist/components/PasswordField/PasswordField.js +40 -0
  12. package/dist/components/PasswordField/style/index.module.less +5 -0
  13. package/dist/components/PasswordField/style/index.module.less.js +9 -0
  14. package/dist/components/PasswordField/style/mixins.less +3 -0
  15. package/dist/components/PasswordField/style/mixins.less.js +8 -0
  16. package/dist/components/PasswordField/svg/eye-hide.svg.js +21 -0
  17. package/dist/components/PasswordField/svg/eye.svg.js +21 -0
  18. package/dist/components/PasswordField/svg/lock.svg.js +21 -0
  19. package/dist/components/index.d.ts +2 -0
  20. package/dist/components/index.js +3 -1
  21. package/dist/components/private/ButtonBase/ButtonBase.d.ts +2 -1
  22. package/dist/components/private/ButtonBase/ButtonBase.js +15 -4
  23. package/dist/components/private/Input/InputPassword.d.ts +5 -3
  24. package/dist/components/private/Input/InputPassword.js +6 -5
  25. package/dist/components/private/Input/InputText.js +3 -3
  26. package/dist/index.js +3 -1
  27. package/package.json +12 -12
@@ -8,7 +8,7 @@ const AVATAR_WITH_STATUS = 'AvatarWithStatus';
8
8
  const AvatarWithStatus = ({ online = false, size = AVATAR_SIZE_DEFAULT, dataset, ...avatarProps }) => {
9
9
  useStyleExtract(styles);
10
10
  const classNames = moduleClassNames(styles, AVATAR_WITH_STATUS, [
11
- booleanClassNames('online', undefined, online),
11
+ booleanClassNames('online', 'normal', online),
12
12
  stringClassNames('size', size),
13
13
  ]);
14
14
  const indicatorClassName = [...moduleLocals(styles, AVATAR_WITH_STATUS, ['indicator'])];
@@ -21,4 +21,4 @@ const AvatarWithStatus = ({ online = false, size = AVATAR_SIZE_DEFAULT, dataset,
21
21
  };
22
22
 
23
23
  export { AvatarWithStatus };
24
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXZhdGFyV2l0aFN0YXR1cy5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQXZhdGFyV2l0aFN0YXR1cy9BdmF0YXJXaXRoU3RhdHVzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBVkFUQVJfU0laRV9ERUZBVUxUIH0gZnJvbSAnQHByZXBseS9kcy1jb3JlJztcbmltcG9ydCB7XG4gICAgYm9vbGVhbkNsYXNzTmFtZXMsXG4gICAgZ2V0RGF0YXNldFByb3BzLFxuICAgIG1vZHVsZUNsYXNzTmFtZXMsXG4gICAgbW9kdWxlTG9jYWxzLFxuICAgIHN0cmluZ0NsYXNzTmFtZXMsXG4gICAgdXNlU3R5bGVFeHRyYWN0LFxufSBmcm9tICdAcHJlcGx5L2RzLXdlYi1jb3JlJztcbmltcG9ydCBSZWFjdCwgeyBGQyB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgQXZhdGFyLCBQcm9wcyB9IGZyb20gJy4uL0F2YXRhci9BdmF0YXInO1xuXG5pbXBvcnQgc3R5bGVzIGZyb20gJy4vc3R5bGUvaW5kZXgubW9kdWxlLmxlc3MnO1xuXG5jb25zdCBBVkFUQVJfV0lUSF9TVEFUVVMgPSAnQXZhdGFyV2l0aFN0YXR1cyc7XG5cbnR5cGUgQXZhdGFyUHJvcHMgPSBPbWl0PFByb3BzLCAncm91bmQnIHwgJ3NpemUnPjtcblxudHlwZSBBdmF0YXJXaXRoU3RhdHVzU2l6ZXMgPSAnMnhzJyB8ICd4cycgfCAnbScgfCAneGwnO1xuXG5leHBvcnQgdHlwZSBBdmF0YXJXaXRoU3RhdHVzUHJvcHMgPSBBdmF0YXJQcm9wcyAmIHtcbiAgICBvbmxpbmU6IGJvb2xlYW47XG4gICAgc2l6ZT86IEF2YXRhcldpdGhTdGF0dXNTaXplcztcbn07XG5cbmV4cG9ydCBjb25zdCBBdmF0YXJXaXRoU3RhdHVzOiBGQzxBdmF0YXJXaXRoU3RhdHVzUHJvcHM+ID0gKHtcbiAgICBvbmxpbmUgPSBmYWxzZSxcbiAgICBzaXplID0gQVZBVEFSX1NJWkVfREVGQVVMVCxcbiAgICBkYXRhc2V0LFxuICAgIC4uLmF2YXRhclByb3BzXG59KSA9PiB7XG4gICAgdXNlU3R5bGVFeHRyYWN0KHN0eWxlcyk7XG5cbiAgICBjb25zdCBjbGFzc05hbWVzID0gbW9kdWxlQ2xhc3NOYW1lcyhzdHlsZXMsIEFWQVRBUl9XSVRIX1NUQVRVUywgW1xuICAgICAgICBib29sZWFuQ2xhc3NOYW1lcygnb25saW5lJywgdW5kZWZpbmVkLCBvbmxpbmUpLFxuICAgICAgICBzdHJpbmdDbGFzc05hbWVzKCdzaXplJywgc2l6ZSksXG4gICAgXSk7XG5cbiAgICBjb25zdCBpbmRpY2F0b3JDbGFzc05hbWUgPSBbLi4ubW9kdWxlTG9jYWxzKHN0eWxlcywgQVZBVEFSX1dJVEhfU1RBVFVTLCBbJ2luZGljYXRvciddKV07XG5cbiAgICBjb25zdCBjbGlwQ2xhc3NOYW1lID0gWy4uLm1vZHVsZUxvY2FscyhzdHlsZXMsIEFWQVRBUl9XSVRIX1NUQVRVUywgWydjbGlwJ10pXTtcblxuICAgIGNvbnN0IHByb3BzID0geyBjbGFzc05hbWU6IGNsYXNzTmFtZXMuam9pbignICcpLCAuLi5nZXREYXRhc2V0UHJvcHMoZGF0YXNldCkgfTtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxkaXYgey4uLnByb3BzfT5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT17aW5kaWNhdG9yQ2xhc3NOYW1lLmpvaW4oJyAnKX0gLz5cbiAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPXtjbGlwQ2xhc3NOYW1lLmpvaW4oJyAnKX0+XG4gICAgICAgICAgICAgICAgPEF2YXRhciB7Li4uYXZhdGFyUHJvcHN9IHNpemU9e3NpemV9IC8+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgKTtcbn07XG4iXSwibmFtZXMiOlsiUmVhY3QiXSwibWFwcGluZ3MiOiI7Ozs7OztBQWVBLE1BQU0sa0JBQWtCLEdBQUcsa0JBQWtCLENBQUM7TUFXakMsZ0JBQWdCLEdBQThCLENBQUMsRUFDeEQsTUFBTSxHQUFHLEtBQUssRUFDZCxJQUFJLEdBQUcsbUJBQW1CLEVBQzFCLE9BQU8sRUFDUCxHQUFHLFdBQVcsRUFDakI7SUFDRyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFeEIsTUFBTSxVQUFVLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLGtCQUFrQixFQUFFO1FBQzVELGlCQUFpQixDQUFDLFFBQVEsRUFBRSxTQUFTLEVBQUUsTUFBTSxDQUFDO1FBQzlDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUM7S0FDakMsQ0FBQyxDQUFDO0lBRUgsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLEdBQUcsWUFBWSxDQUFDLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUV4RixNQUFNLGFBQWEsR0FBRyxDQUFDLEdBQUcsWUFBWSxDQUFDLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUU5RSxNQUFNLEtBQUssR0FBRyxFQUFFLFNBQVMsRUFBRSxVQUFVLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEdBQUcsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7SUFFL0UsUUFDSUEsc0RBQVMsS0FBSztRQUNWQSx1Q0FBTSxTQUFTLEVBQUUsa0JBQWtCLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFJO1FBQ2pEQSxzQ0FBSyxTQUFTLEVBQUUsYUFBYSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7WUFDbkNBLDZCQUFDLE1BQU0sb0JBQUssV0FBVyxJQUFFLElBQUksRUFBRSxJQUFJLElBQUksQ0FDckMsQ0FDSixFQUNSO0FBQ047Ozs7In0=
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXZhdGFyV2l0aFN0YXR1cy5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQXZhdGFyV2l0aFN0YXR1cy9BdmF0YXJXaXRoU3RhdHVzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBVkFUQVJfU0laRV9ERUZBVUxUIH0gZnJvbSAnQHByZXBseS9kcy1jb3JlJztcbmltcG9ydCB7XG4gICAgYm9vbGVhbkNsYXNzTmFtZXMsXG4gICAgZ2V0RGF0YXNldFByb3BzLFxuICAgIG1vZHVsZUNsYXNzTmFtZXMsXG4gICAgbW9kdWxlTG9jYWxzLFxuICAgIHN0cmluZ0NsYXNzTmFtZXMsXG4gICAgdXNlU3R5bGVFeHRyYWN0LFxufSBmcm9tICdAcHJlcGx5L2RzLXdlYi1jb3JlJztcbmltcG9ydCBSZWFjdCwgeyBGQyB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgQXZhdGFyLCBQcm9wcyB9IGZyb20gJy4uL0F2YXRhci9BdmF0YXInO1xuXG5pbXBvcnQgc3R5bGVzIGZyb20gJy4vc3R5bGUvaW5kZXgubW9kdWxlLmxlc3MnO1xuXG5jb25zdCBBVkFUQVJfV0lUSF9TVEFUVVMgPSAnQXZhdGFyV2l0aFN0YXR1cyc7XG5cbnR5cGUgQXZhdGFyUHJvcHMgPSBPbWl0PFByb3BzLCAncm91bmQnIHwgJ3NpemUnPjtcblxudHlwZSBBdmF0YXJXaXRoU3RhdHVzU2l6ZXMgPSAnMnhzJyB8ICd4cycgfCAnbScgfCAneGwnO1xuXG5leHBvcnQgdHlwZSBBdmF0YXJXaXRoU3RhdHVzUHJvcHMgPSBBdmF0YXJQcm9wcyAmIHtcbiAgICBvbmxpbmU6IGJvb2xlYW47XG4gICAgc2l6ZT86IEF2YXRhcldpdGhTdGF0dXNTaXplcztcbn07XG5cbmV4cG9ydCBjb25zdCBBdmF0YXJXaXRoU3RhdHVzOiBGQzxBdmF0YXJXaXRoU3RhdHVzUHJvcHM+ID0gKHtcbiAgICBvbmxpbmUgPSBmYWxzZSxcbiAgICBzaXplID0gQVZBVEFSX1NJWkVfREVGQVVMVCxcbiAgICBkYXRhc2V0LFxuICAgIC4uLmF2YXRhclByb3BzXG59KSA9PiB7XG4gICAgdXNlU3R5bGVFeHRyYWN0KHN0eWxlcyk7XG5cbiAgICBjb25zdCBjbGFzc05hbWVzID0gbW9kdWxlQ2xhc3NOYW1lcyhzdHlsZXMsIEFWQVRBUl9XSVRIX1NUQVRVUywgW1xuICAgICAgICBib29sZWFuQ2xhc3NOYW1lcygnb25saW5lJywgJ25vcm1hbCcsIG9ubGluZSksXG4gICAgICAgIHN0cmluZ0NsYXNzTmFtZXMoJ3NpemUnLCBzaXplKSxcbiAgICBdKTtcblxuICAgIGNvbnN0IGluZGljYXRvckNsYXNzTmFtZSA9IFsuLi5tb2R1bGVMb2NhbHMoc3R5bGVzLCBBVkFUQVJfV0lUSF9TVEFUVVMsIFsnaW5kaWNhdG9yJ10pXTtcblxuICAgIGNvbnN0IGNsaXBDbGFzc05hbWUgPSBbLi4ubW9kdWxlTG9jYWxzKHN0eWxlcywgQVZBVEFSX1dJVEhfU1RBVFVTLCBbJ2NsaXAnXSldO1xuXG4gICAgY29uc3QgcHJvcHMgPSB7IGNsYXNzTmFtZTogY2xhc3NOYW1lcy5qb2luKCcgJyksIC4uLmdldERhdGFzZXRQcm9wcyhkYXRhc2V0KSB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgICAgPGRpdiB7Li4ucHJvcHN9PlxuICAgICAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtpbmRpY2F0b3JDbGFzc05hbWUuam9pbignICcpfSAvPlxuICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9e2NsaXBDbGFzc05hbWUuam9pbignICcpfT5cbiAgICAgICAgICAgICAgICA8QXZhdGFyIHsuLi5hdmF0YXJQcm9wc30gc2l6ZT17c2l6ZX0gLz5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICApO1xufTtcbiJdLCJuYW1lcyI6WyJSZWFjdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBZUEsTUFBTSxrQkFBa0IsR0FBRyxrQkFBa0IsQ0FBQztNQVdqQyxnQkFBZ0IsR0FBOEIsQ0FBQyxFQUN4RCxNQUFNLEdBQUcsS0FBSyxFQUNkLElBQUksR0FBRyxtQkFBbUIsRUFDMUIsT0FBTyxFQUNQLEdBQUcsV0FBVyxFQUNqQjtJQUNHLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUV4QixNQUFNLFVBQVUsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsa0JBQWtCLEVBQUU7UUFDNUQsaUJBQWlCLENBQUMsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLENBQUM7UUFDN0MsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQztLQUNqQyxDQUFDLENBQUM7SUFFSCxNQUFNLGtCQUFrQixHQUFHLENBQUMsR0FBRyxZQUFZLENBQUMsTUFBTSxFQUFFLGtCQUFrQixFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRXhGLE1BQU0sYUFBYSxHQUFHLENBQUMsR0FBRyxZQUFZLENBQUMsTUFBTSxFQUFFLGtCQUFrQixFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRTlFLE1BQU0sS0FBSyxHQUFHLEVBQUUsU0FBUyxFQUFFLFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsR0FBRyxlQUFlLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztJQUUvRSxRQUNJQSxzREFBUyxLQUFLO1FBQ1ZBLHVDQUFNLFNBQVMsRUFBRSxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUk7UUFDakRBLHNDQUFLLFNBQVMsRUFBRSxhQUFhLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQztZQUNuQ0EsNkJBQUMsTUFBTSxvQkFBSyxXQUFXLElBQUUsSUFBSSxFQUFFLElBQUksSUFBSSxDQUNyQyxDQUNKLEVBQ1I7QUFDTjs7OzsifQ==
@@ -0,0 +1,10 @@
1
+ import type { BadgeColor, BadgeSize, Dataset } from '@preply/ds-core';
2
+ import { FC } from 'react';
3
+ export interface Props {
4
+ color?: BadgeColor;
5
+ inverted?: boolean;
6
+ size?: BadgeSize;
7
+ assistiveText?: string;
8
+ dataset?: Dataset;
9
+ }
10
+ export declare const Badge: FC<Props>;
@@ -0,0 +1,23 @@
1
+ import { BADGE_COLOR_DEFAULT, BADGE_SIZE_DEFAULT } from '@preply/ds-core';
2
+ import { useStyleExtract, moduleClassNames, stringClassNames, booleanClassNames, getDatasetProps } from '@preply/ds-web-core';
3
+ import React__default from 'react';
4
+ import styles from './style/index.module.less.js';
5
+
6
+ const BADGE = 'Badge';
7
+ const Badge = ({ color = BADGE_COLOR_DEFAULT, inverted = false, size = BADGE_SIZE_DEFAULT, assistiveText, dataset, children, }) => {
8
+ useStyleExtract(styles);
9
+ const classNames = moduleClassNames(styles, BADGE, [
10
+ stringClassNames('color', color),
11
+ booleanClassNames('inverted', 'normal', inverted),
12
+ stringClassNames('size', size),
13
+ ]);
14
+ const props = {
15
+ 'aria-label': assistiveText,
16
+ className: classNames.join(' '),
17
+ ...getDatasetProps(dataset),
18
+ };
19
+ return React__default.createElement("span", Object.assign({}, props), children);
20
+ };
21
+
22
+ export { Badge };
23
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmFkZ2UuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0JhZGdlL0JhZGdlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEJhZGdlQ29sb3IsIEJhZGdlU2l6ZSwgRGF0YXNldCB9IGZyb20gJ0BwcmVwbHkvZHMtY29yZSc7XG5pbXBvcnQgeyBCQURHRV9DT0xPUl9ERUZBVUxULCBCQURHRV9TSVpFX0RFRkFVTFQgfSBmcm9tICdAcHJlcGx5L2RzLWNvcmUnO1xuaW1wb3J0IHtcbiAgICBib29sZWFuQ2xhc3NOYW1lcyxcbiAgICBnZXREYXRhc2V0UHJvcHMsXG4gICAgbW9kdWxlQ2xhc3NOYW1lcyxcbiAgICBzdHJpbmdDbGFzc05hbWVzLFxuICAgIHVzZVN0eWxlRXh0cmFjdCxcbn0gZnJvbSAnQHByZXBseS9kcy13ZWItY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgRkMgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZXMgZnJvbSAnLi9zdHlsZS9pbmRleC5tb2R1bGUubGVzcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvcHMge1xuICAgIGNvbG9yPzogQmFkZ2VDb2xvcjtcbiAgICBpbnZlcnRlZD86IGJvb2xlYW47XG4gICAgc2l6ZT86IEJhZGdlU2l6ZTtcbiAgICBhc3Npc3RpdmVUZXh0Pzogc3RyaW5nO1xuICAgIGRhdGFzZXQ/OiBEYXRhc2V0O1xufVxuXG5jb25zdCBCQURHRSA9ICdCYWRnZSc7XG5cbmV4cG9ydCBjb25zdCBCYWRnZTogRkM8UHJvcHM+ID0gKHtcbiAgICBjb2xvciA9IEJBREdFX0NPTE9SX0RFRkFVTFQsXG4gICAgaW52ZXJ0ZWQgPSBmYWxzZSxcbiAgICBzaXplID0gQkFER0VfU0laRV9ERUZBVUxULFxuICAgIGFzc2lzdGl2ZVRleHQsXG4gICAgZGF0YXNldCxcbiAgICBjaGlsZHJlbixcbn0pID0+IHtcbiAgICB1c2VTdHlsZUV4dHJhY3Qoc3R5bGVzKTtcblxuICAgIGNvbnN0IGNsYXNzTmFtZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgQkFER0UsIFtcbiAgICAgICAgc3RyaW5nQ2xhc3NOYW1lcygnY29sb3InLCBjb2xvciksXG4gICAgICAgIGJvb2xlYW5DbGFzc05hbWVzKCdpbnZlcnRlZCcsICdub3JtYWwnLCBpbnZlcnRlZCksXG4gICAgICAgIHN0cmluZ0NsYXNzTmFtZXMoJ3NpemUnLCBzaXplKSxcbiAgICBdKTtcblxuICAgIGNvbnN0IHByb3BzID0ge1xuICAgICAgICAnYXJpYS1sYWJlbCc6IGFzc2lzdGl2ZVRleHQsXG4gICAgICAgIGNsYXNzTmFtZTogY2xhc3NOYW1lcy5qb2luKCcgJyksXG4gICAgICAgIC4uLmdldERhdGFzZXRQcm9wcyhkYXRhc2V0KSxcbiAgICB9O1xuXG4gICAgcmV0dXJuIDxzcGFuIHsuLi5wcm9wc30+e2NoaWxkcmVufTwvc3Bhbj47XG59O1xuIl0sIm5hbWVzIjpbIlJlYWN0Il0sIm1hcHBpbmdzIjoiOzs7OztBQXFCQSxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUM7TUFFVCxLQUFLLEdBQWMsQ0FBQyxFQUM3QixLQUFLLEdBQUcsbUJBQW1CLEVBQzNCLFFBQVEsR0FBRyxLQUFLLEVBQ2hCLElBQUksR0FBRyxrQkFBa0IsRUFDekIsYUFBYSxFQUNiLE9BQU8sRUFDUCxRQUFRLEdBQ1g7SUFDRyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFeEIsTUFBTSxVQUFVLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRTtRQUMvQyxnQkFBZ0IsQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDO1FBQ2hDLGlCQUFpQixDQUFDLFVBQVUsRUFBRSxRQUFRLEVBQUUsUUFBUSxDQUFDO1FBQ2pELGdCQUFnQixDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUM7S0FDakMsQ0FBQyxDQUFDO0lBRUgsTUFBTSxLQUFLLEdBQUc7UUFDVixZQUFZLEVBQUUsYUFBYTtRQUMzQixTQUFTLEVBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7UUFDL0IsR0FBRyxlQUFlLENBQUMsT0FBTyxDQUFDO0tBQzlCLENBQUM7SUFFRixPQUFPQSx1REFBVSxLQUFLLEdBQUcsUUFBUSxDQUFRLENBQUM7QUFDOUM7Ozs7In0=
@@ -0,0 +1,7 @@
1
+ @import './mixins.less';
2
+
3
+ .Badge {
4
+ .badge-base();
5
+ .badge-color-and-inverted();
6
+ .badge-size();
7
+ }
@@ -0,0 +1,9 @@
1
+ import styleInject from '../../../external/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = "._3h-Wzd{border-radius:var(--93d4a2);display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex}._2eKUAk._1zS55d{background-color:var(--8f1238);color:var(--c9575b)}._2eKUAk._3bUZbF{background-color:var(--7c8c3c);color:var(--55407f)}._3gyNLf._1zS55d{background-color:var(--54ed1d);color:var(--de8a40)}._3gyNLf._3bUZbF{background-color:var(--de8a40);color:var(--54ed1d)}.rwgQdv._1zS55d{background-color:var(--1383a7);color:var(--bbfa9f)}.rwgQdv._3bUZbF{background-color:var(--bbfa9f);color:var(--1383a7)}.zb2wOT._1zS55d{background-color:var(--21906f);color:var(--e1c27c)}.zb2wOT._3bUZbF{background-color:var(--e1c27c);color:var(--21906f)}._1N-1FK._1zS55d{background-color:var(--c7d8be);color:var(--2242ed)}._1N-1FK._3bUZbF{background-color:var(--2242ed);color:var(--c7d8be)}._3a1P6I._1zS55d{background-color:var(--ecb5d5);color:var(--4e47fe)}._3a1P6I._3bUZbF{background-color:var(--4e47fe);color:var(--ecb5d5)}._3LKZfd._1zS55d{background-color:var(--1a9963);color:var(--6cbd80)}._3LKZfd._3bUZbF{background-color:var(--6cbd80);color:var(--1a9963)}._3Qg4_n{font-size:var(--547b8f);font-style:var(--abe371);font-variation-settings:var(--f65ebc);font-weight:var(--86a200);letter-spacing:var(--d7a1ad);line-height:var(--e7e648);padding:var(--8feee9) var(--62f094)}._1IiJgJ{font-size:var(--28e99e);font-style:var(--e1d91f);font-variation-settings:var(--d7e46a);font-weight:var(--ca04c0);letter-spacing:var(--015e8c);line-height:var(--af784d);padding:var(--25e959) var(--796ab1)}.xlRCTE{font-size:var(--a5b1e0);font-style:var(--b079f7);font-variation-settings:var(--6fc943);font-weight:var(--749dcd);letter-spacing:var(--2a3820);line-height:var(--76f1ec);padding:var(--0d8aa3) var(--3d1d33)}";
4
+ var styles = {__id:"/home/jenkins/workspace/design-system_main/packages/web-lib/src/components/Badge/style/index.module.less",__css:css_248z,"Badge":"_3h-Wzd","Badge--color-gray":"_2eKUAk","Badge--normal":"_1zS55d","Badge--inverted":"_3bUZbF","Badge--color-teal":"_3gyNLf","Badge--color-green":"rwgQdv","Badge--color-blue":"zb2wOT","Badge--color-yellow":"_1N-1FK","Badge--color-red":"_3a1P6I","Badge--color-magenta":"_3LKZfd","Badge--size-xs":"_3Qg4_n","Badge--size-s":"_1IiJgJ","Badge--size-m":"xlRCTE"};
5
+ var stylesheet=css_248z;
6
+ styleInject(css_248z);
7
+
8
+ export { styles as default, stylesheet };
9
+
@@ -0,0 +1,56 @@
1
+ @import '@preply/ds-web-core/dist/generated/tokens.less';
2
+ @import '@preply/ds-web-core/dist/generated/options.less';
3
+ @import '@preply/ds-web-core/dist/theme/style/declarations.mixins.less';
4
+ @import '@preply/ds-web-core/dist/typography/style/mixins.less';
5
+
6
+ @namespace: 'badge';
7
+
8
+ .badge-base() {
9
+ display: inline-flex;
10
+ .border-radius(@namespace, 'base');
11
+ }
12
+
13
+ // IMPORTANT: These functions should not be taken as an example or inspiration.
14
+ // Usually, it is preferred to generate specific tokens for each component prop option.
15
+ ._badge-color(@value) when (@value = 'gray') {
16
+ color: @root-palette-gray-500;
17
+ background-color: @root-palette-gray-200;
18
+ }
19
+
20
+ ._badge-color(@value) when not(@value = 'gray') {
21
+ @_color-token-name: 'root-palette-@{value}-400';
22
+ color: @@_color-token-name;
23
+ @_bg-token-name: 'root-palette-@{value}-100';
24
+ background-color: @@_bg-token-name;
25
+ }
26
+
27
+ ._badge-color(@value, @inverted) when (@inverted = true) {
28
+ @_color-token-name: 'root-palette-@{value}-100';
29
+ color: @@_color-token-name;
30
+ @_bg-token-name: 'root-palette-@{value}-400';
31
+ background-color: @@_bg-token-name;
32
+ }
33
+
34
+ .badge-color-and-inverted() {
35
+ each(@BADGE_COLOR_OPTIONS, {
36
+ &--color-@{value}&--normal {
37
+ ._badge-color('@{value}');
38
+ }
39
+
40
+ &--color-@{value}&--inverted {
41
+ ._badge-color('@{value}', true);
42
+ }
43
+ });
44
+ }
45
+
46
+ .badge-size() {
47
+ each(@BADGE_SIZE_OPTIONS, {
48
+ &--size-@{value} {
49
+ @token: 'size-@{value}';
50
+ .horizontalPadding(@namespace, @token);
51
+ .verticalPadding(@namespace, @token);
52
+ @variant: '@{value}-medium';
53
+ .text-variant(@variant);
54
+ }
55
+ });
56
+ }
@@ -0,0 +1,8 @@
1
+ import styleInject from '../../../external/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = "";
4
+ var stylesheet="";
5
+ styleInject(css_248z);
6
+
7
+ export { css_248z as default, stylesheet };
8
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjpudWxsLCJzb3VyY2VzIjpbbnVsbF0sInNvdXJjZXNDb250ZW50IjpbbnVsbF0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdCQUF3Qix3REFBNEQ7QUFDcEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOyJ9
@@ -1,5 +1,5 @@
1
1
  import type { Dataset } from '@preply/ds-core';
2
- import { FC, MouseEventHandler, ReactNode } from 'react';
2
+ import { FC, MouseEventHandler, ReactElement, ReactNode } from 'react';
3
3
  export interface Props {
4
4
  href?: string;
5
5
  url?: string;
@@ -7,6 +7,7 @@ export interface Props {
7
7
  nofollow?: boolean;
8
8
  assistiveText?: string;
9
9
  onClick?: MouseEventHandler;
10
+ as?: ReactElement;
10
11
  dataset?: Dataset;
11
12
  children?: ReactNode;
12
13
  }
@@ -1,9 +1,9 @@
1
1
  import { useInstrument, useStyleExtract, useHostname, moduleClassNames, getExternalUrlProps, getDatasetProps } from '@preply/ds-web-core';
2
- import React__default from 'react';
2
+ import React__default, { cloneElement } from 'react';
3
3
  import styles from './style/index.module.less.js';
4
4
 
5
5
  const LINK = 'Link';
6
- const Link = ({ href, url, opensInNewTab, nofollow, assistiveText, onClick, dataset, children, }) => {
6
+ const Link = ({ href, url, opensInNewTab, nofollow, assistiveText, onClick, as, dataset, children, }) => {
7
7
  useInstrument('render', {
8
8
  component: LINK,
9
9
  props: { url },
@@ -26,10 +26,12 @@ const Link = ({ href, url, opensInNewTab, nofollow, assistiveText, onClick, data
26
26
  onClick: handleClick,
27
27
  className: classNames.join(' '),
28
28
  ...getDatasetProps(dataset),
29
- ...externalUrlProps,
30
29
  };
31
- return React__default.createElement("a", Object.assign({}, props), children);
30
+ if (as) {
31
+ return cloneElement(as, { ...props }, children);
32
+ }
33
+ return (React__default.createElement("a", Object.assign({}, props, externalUrlProps), children));
32
34
  };
33
35
 
34
36
  export { Link };
35
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTGluay5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvTGluay9MaW5rLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IERhdGFzZXQgfSBmcm9tICdAcHJlcGx5L2RzLWNvcmUnO1xuaW1wb3J0IHtcbiAgICBnZXREYXRhc2V0UHJvcHMsXG4gICAgZ2V0RXh0ZXJuYWxVcmxQcm9wcyxcbiAgICBtb2R1bGVDbGFzc05hbWVzLFxuICAgIHVzZUhvc3RuYW1lLFxuICAgIHVzZUluc3RydW1lbnQsXG4gICAgdXNlU3R5bGVFeHRyYWN0LFxufSBmcm9tICdAcHJlcGx5L2RzLXdlYi1jb3JlJztcbmltcG9ydCBSZWFjdCwgeyBGQywgTW91c2VFdmVudCwgTW91c2VFdmVudEhhbmRsZXIsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHN0eWxlcyBmcm9tICcuL3N0eWxlL2luZGV4Lm1vZHVsZS5sZXNzJztcblxuZXhwb3J0IGludGVyZmFjZSBQcm9wcyB7XG4gICAgaHJlZj86IHN0cmluZztcbiAgICB1cmw/OiBzdHJpbmc7XG4gICAgb3BlbnNJbk5ld1RhYj86IGJvb2xlYW47XG4gICAgbm9mb2xsb3c/OiBib29sZWFuO1xuICAgIGFzc2lzdGl2ZVRleHQ/OiBzdHJpbmc7XG4gICAgb25DbGljaz86IE1vdXNlRXZlbnRIYW5kbGVyO1xuICAgIGRhdGFzZXQ/OiBEYXRhc2V0O1xuICAgIGNoaWxkcmVuPzogUmVhY3ROb2RlO1xufVxuXG5jb25zdCBMSU5LID0gJ0xpbmsnO1xuXG5leHBvcnQgY29uc3QgTGluazogRkM8UHJvcHM+ID0gKHtcbiAgICBocmVmLFxuICAgIHVybCxcbiAgICBvcGVuc0luTmV3VGFiLFxuICAgIG5vZm9sbG93LFxuICAgIGFzc2lzdGl2ZVRleHQsXG4gICAgb25DbGljayxcbiAgICBkYXRhc2V0LFxuICAgIGNoaWxkcmVuLFxufSkgPT4ge1xuICAgIHVzZUluc3RydW1lbnQoJ3JlbmRlcicsIHtcbiAgICAgICAgY29tcG9uZW50OiBMSU5LLFxuICAgICAgICBwcm9wczogeyB1cmwgfSxcbiAgICB9KTtcblxuICAgIHVzZVN0eWxlRXh0cmFjdChzdHlsZXMpO1xuXG4gICAgY29uc3QgaG9zdG5hbWUgPSB1c2VIb3N0bmFtZSgpO1xuXG4gICAgY29uc3QgaGFuZGxlQ2xpY2sgPSAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKG9uQ2xpY2spIHtcbiAgICAgICAgICAgIG9uQ2xpY2soZXZlbnQpO1xuICAgICAgICB9XG4gICAgfTtcblxuICAgIGNvbnN0IGNsYXNzTmFtZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgTElOSywgW10pO1xuXG4gICAgY29uc3QgYWN0dWFsSHJlZiA9IGhyZWYgfHwgdXJsO1xuXG4gICAgY29uc3QgZXh0ZXJuYWxVcmxQcm9wcyA9IGFjdHVhbEhyZWZcbiAgICAgICAgPyBnZXRFeHRlcm5hbFVybFByb3BzKGhvc3RuYW1lLCBhY3R1YWxIcmVmLCBvcGVuc0luTmV3VGFiLCBub2ZvbGxvdylcbiAgICAgICAgOiB7fTtcblxuICAgIGNvbnN0IHByb3BzID0ge1xuICAgICAgICBocmVmOiBhY3R1YWxIcmVmLFxuICAgICAgICAnYXJpYS1sYWJlbCc6IGFzc2lzdGl2ZVRleHQsXG4gICAgICAgIG9uQ2xpY2s6IGhhbmRsZUNsaWNrLFxuICAgICAgICBjbGFzc05hbWU6IGNsYXNzTmFtZXMuam9pbignICcpLFxuICAgICAgICAuLi5nZXREYXRhc2V0UHJvcHMoZGF0YXNldCksXG4gICAgICAgIC4uLmV4dGVybmFsVXJsUHJvcHMsXG4gICAgfTtcblxuICAgIHJldHVybiA8YSB7Li4ucHJvcHN9PntjaGlsZHJlbn08L2E+O1xufTtcbiJdLCJuYW1lcyI6WyJSZWFjdCJdLCJtYXBwaW5ncyI6Ijs7OztBQXdCQSxNQUFNLElBQUksR0FBRyxNQUFNLENBQUM7TUFFUCxJQUFJLEdBQWMsQ0FBQyxFQUM1QixJQUFJLEVBQ0osR0FBRyxFQUNILGFBQWEsRUFDYixRQUFRLEVBQ1IsYUFBYSxFQUNiLE9BQU8sRUFDUCxPQUFPLEVBQ1AsUUFBUSxHQUNYO0lBQ0csYUFBYSxDQUFDLFFBQVEsRUFBRTtRQUNwQixTQUFTLEVBQUUsSUFBSTtRQUNmLEtBQUssRUFBRSxFQUFFLEdBQUcsRUFBRTtLQUNqQixDQUFDLENBQUM7SUFFSCxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFeEIsTUFBTSxRQUFRLEdBQUcsV0FBVyxFQUFFLENBQUM7SUFFL0IsTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFpQjtRQUNsQyxJQUFJLE9BQU8sRUFBRTtZQUNULE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUNsQjtLQUNKLENBQUM7SUFFRixNQUFNLFVBQVUsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBRXRELE1BQU0sVUFBVSxHQUFHLElBQUksSUFBSSxHQUFHLENBQUM7SUFFL0IsTUFBTSxnQkFBZ0IsR0FBRyxVQUFVO1VBQzdCLG1CQUFtQixDQUFDLFFBQVEsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLFFBQVEsQ0FBQztVQUNsRSxFQUFFLENBQUM7SUFFVCxNQUFNLEtBQUssR0FBRztRQUNWLElBQUksRUFBRSxVQUFVO1FBQ2hCLFlBQVksRUFBRSxhQUFhO1FBQzNCLE9BQU8sRUFBRSxXQUFXO1FBQ3BCLFNBQVMsRUFBRSxVQUFVLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQztRQUMvQixHQUFHLGVBQWUsQ0FBQyxPQUFPLENBQUM7UUFDM0IsR0FBRyxnQkFBZ0I7S0FDdEIsQ0FBQztJQUVGLE9BQU9BLG9EQUFPLEtBQUssR0FBRyxRQUFRLENBQUssQ0FBQztBQUN4Qzs7OzsifQ==
37
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTGluay5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvTGluay9MaW5rLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IERhdGFzZXQgfSBmcm9tICdAcHJlcGx5L2RzLWNvcmUnO1xuaW1wb3J0IHtcbiAgICBnZXREYXRhc2V0UHJvcHMsXG4gICAgZ2V0RXh0ZXJuYWxVcmxQcm9wcyxcbiAgICBtb2R1bGVDbGFzc05hbWVzLFxuICAgIHVzZUhvc3RuYW1lLFxuICAgIHVzZUluc3RydW1lbnQsXG4gICAgdXNlU3R5bGVFeHRyYWN0LFxufSBmcm9tICdAcHJlcGx5L2RzLXdlYi1jb3JlJztcbmltcG9ydCBSZWFjdCwge1xuICAgIEZDLFxuICAgIE1vdXNlRXZlbnQsXG4gICAgTW91c2VFdmVudEhhbmRsZXIsXG4gICAgUmVhY3RFbGVtZW50LFxuICAgIFJlYWN0Tm9kZSxcbiAgICBjbG9uZUVsZW1lbnQsXG59IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHN0eWxlcyBmcm9tICcuL3N0eWxlL2luZGV4Lm1vZHVsZS5sZXNzJztcblxuZXhwb3J0IGludGVyZmFjZSBQcm9wcyB7XG4gICAgaHJlZj86IHN0cmluZztcbiAgICB1cmw/OiBzdHJpbmc7XG4gICAgb3BlbnNJbk5ld1RhYj86IGJvb2xlYW47XG4gICAgbm9mb2xsb3c/OiBib29sZWFuO1xuICAgIGFzc2lzdGl2ZVRleHQ/OiBzdHJpbmc7XG4gICAgb25DbGljaz86IE1vdXNlRXZlbnRIYW5kbGVyO1xuICAgIGFzPzogUmVhY3RFbGVtZW50O1xuICAgIGRhdGFzZXQ/OiBEYXRhc2V0O1xuICAgIGNoaWxkcmVuPzogUmVhY3ROb2RlO1xufVxuXG5jb25zdCBMSU5LID0gJ0xpbmsnO1xuXG5leHBvcnQgY29uc3QgTGluazogRkM8UHJvcHM+ID0gKHtcbiAgICBocmVmLFxuICAgIHVybCxcbiAgICBvcGVuc0luTmV3VGFiLFxuICAgIG5vZm9sbG93LFxuICAgIGFzc2lzdGl2ZVRleHQsXG4gICAgb25DbGljayxcbiAgICBhcyxcbiAgICBkYXRhc2V0LFxuICAgIGNoaWxkcmVuLFxufSkgPT4ge1xuICAgIHVzZUluc3RydW1lbnQoJ3JlbmRlcicsIHtcbiAgICAgICAgY29tcG9uZW50OiBMSU5LLFxuICAgICAgICBwcm9wczogeyB1cmwgfSxcbiAgICB9KTtcblxuICAgIHVzZVN0eWxlRXh0cmFjdChzdHlsZXMpO1xuXG4gICAgY29uc3QgaG9zdG5hbWUgPSB1c2VIb3N0bmFtZSgpO1xuXG4gICAgY29uc3QgaGFuZGxlQ2xpY2sgPSAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKG9uQ2xpY2spIHtcbiAgICAgICAgICAgIG9uQ2xpY2soZXZlbnQpO1xuICAgICAgICB9XG4gICAgfTtcblxuICAgIGNvbnN0IGNsYXNzTmFtZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgTElOSywgW10pO1xuXG4gICAgY29uc3QgYWN0dWFsSHJlZiA9IGhyZWYgfHwgdXJsO1xuXG4gICAgY29uc3QgZXh0ZXJuYWxVcmxQcm9wcyA9IGFjdHVhbEhyZWZcbiAgICAgICAgPyBnZXRFeHRlcm5hbFVybFByb3BzKGhvc3RuYW1lLCBhY3R1YWxIcmVmLCBvcGVuc0luTmV3VGFiLCBub2ZvbGxvdylcbiAgICAgICAgOiB7fTtcblxuICAgIGNvbnN0IHByb3BzID0ge1xuICAgICAgICBocmVmOiBhY3R1YWxIcmVmLFxuICAgICAgICAnYXJpYS1sYWJlbCc6IGFzc2lzdGl2ZVRleHQsXG4gICAgICAgIG9uQ2xpY2s6IGhhbmRsZUNsaWNrLFxuICAgICAgICBjbGFzc05hbWU6IGNsYXNzTmFtZXMuam9pbignICcpLFxuICAgICAgICAuLi5nZXREYXRhc2V0UHJvcHMoZGF0YXNldCksXG4gICAgfTtcblxuICAgIGlmIChhcykge1xuICAgICAgICByZXR1cm4gY2xvbmVFbGVtZW50KGFzIGFzIFJlYWN0RWxlbWVudCwgeyAuLi5wcm9wcyB9LCBjaGlsZHJlbik7XG4gICAgfVxuXG4gICAgcmV0dXJuIChcbiAgICAgICAgPGEgey4uLnByb3BzfSB7Li4uZXh0ZXJuYWxVcmxQcm9wc30+XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDwvYT5cbiAgICApO1xufTtcbiJdLCJuYW1lcyI6WyJSZWFjdCJdLCJtYXBwaW5ncyI6Ijs7OztBQWdDQSxNQUFNLElBQUksR0FBRyxNQUFNLENBQUM7TUFFUCxJQUFJLEdBQWMsQ0FBQyxFQUM1QixJQUFJLEVBQ0osR0FBRyxFQUNILGFBQWEsRUFDYixRQUFRLEVBQ1IsYUFBYSxFQUNiLE9BQU8sRUFDUCxFQUFFLEVBQ0YsT0FBTyxFQUNQLFFBQVEsR0FDWDtJQUNHLGFBQWEsQ0FBQyxRQUFRLEVBQUU7UUFDcEIsU0FBUyxFQUFFLElBQUk7UUFDZixLQUFLLEVBQUUsRUFBRSxHQUFHLEVBQUU7S0FDakIsQ0FBQyxDQUFDO0lBRUgsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBRXhCLE1BQU0sUUFBUSxHQUFHLFdBQVcsRUFBRSxDQUFDO0lBRS9CLE1BQU0sV0FBVyxHQUFHLENBQUMsS0FBaUI7UUFDbEMsSUFBSSxPQUFPLEVBQUU7WUFDVCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDbEI7S0FDSixDQUFDO0lBRUYsTUFBTSxVQUFVLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztJQUV0RCxNQUFNLFVBQVUsR0FBRyxJQUFJLElBQUksR0FBRyxDQUFDO0lBRS9CLE1BQU0sZ0JBQWdCLEdBQUcsVUFBVTtVQUM3QixtQkFBbUIsQ0FBQyxRQUFRLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxRQUFRLENBQUM7VUFDbEUsRUFBRSxDQUFDO0lBRVQsTUFBTSxLQUFLLEdBQUc7UUFDVixJQUFJLEVBQUUsVUFBVTtRQUNoQixZQUFZLEVBQUUsYUFBYTtRQUMzQixPQUFPLEVBQUUsV0FBVztRQUNwQixTQUFTLEVBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7UUFDL0IsR0FBRyxlQUFlLENBQUMsT0FBTyxDQUFDO0tBQzlCLENBQUM7SUFFRixJQUFJLEVBQUUsRUFBRTtRQUNKLE9BQU8sWUFBWSxDQUFDLEVBQWtCLEVBQUUsRUFBRSxHQUFHLEtBQUssRUFBRSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0tBQ25FO0lBRUQsUUFDSUEsb0RBQU8sS0FBSyxFQUFNLGdCQUFnQixHQUM3QixRQUFRLENBQ1QsRUFDTjtBQUNOOzs7OyJ9
@@ -0,0 +1,9 @@
1
+ import type { InputImperativeHandle } from '@preply/ds-web-core';
2
+ import React from 'react';
3
+ export declare const PasswordField: React.ForwardRefExoticComponent<import("@preply/ds-web-core").FieldCommonProps & Pick<import("@preply/ds-web-core").InputPasswordProps, "autoComplete" | "placeholder" | "maxLength" | "name" | "value" | "defaultValue" | "onChange" | "onFocus" | "onBlur" | "onClick" | "onKeyDown" | "onKeyUp" | "required" | "disabled" | "hasError" | "dataset" | "onValueChange"> & {
4
+ id?: string | undefined;
5
+ } & {
6
+ autoComplete?: "off" | "new-password" | "current-password" | undefined;
7
+ showIcon?: boolean | undefined;
8
+ revealValue?: boolean | undefined;
9
+ } & React.RefAttributes<InputImperativeHandle>>;
@@ -0,0 +1,40 @@
1
+ import { useStyleExtract, usePasswordField, moduleClassNames } from '@preply/ds-web-core';
2
+ import React__default, { forwardRef, useRef, useImperativeHandle, useState } from 'react';
3
+ import { FieldButton } from '../FieldButton/FieldButton.js';
4
+ import { FieldLayout } from '../FieldLayout/FieldLayout.js';
5
+ import { Icon } from '../Icon/Icon.js';
6
+ import { InputPassword } from '../private/Input/InputPassword.js';
7
+ import { InputText } from '../private/Input/InputText.js';
8
+ import styles from './style/index.module.less.js';
9
+ import SvgEyeHide from './svg/eye-hide.svg.js';
10
+ import SvgEye from './svg/eye.svg.js';
11
+ import SvgLock from './svg/lock.svg.js';
12
+
13
+ const PASSWORD_FIELD = 'PasswordField';
14
+ const PasswordFieldLocal = ({ showIcon, revealValue, id: optionalId, ...props }, ref) => {
15
+ useStyleExtract(styles);
16
+ const layoutRef = useRef(null);
17
+ const inputRef = useRef(null);
18
+ useImperativeHandle(ref, () => ({
19
+ setFocus: () => { var _a; return (_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.setFocus(); },
20
+ }));
21
+ const passwordField = usePasswordField({
22
+ id: optionalId,
23
+ ...props,
24
+ });
25
+ const { layoutProps, inputProps } = passwordField;
26
+ const [shouldRevealValue, setShouldRevealValue] = useState(false);
27
+ const handleButtonClick = () => setShouldRevealValue(!shouldRevealValue);
28
+ const icon = showIcon ? React__default.createElement(Icon, { svg: SvgLock }) : undefined;
29
+ const actualRevealValue = shouldRevealValue || revealValue;
30
+ const input = actualRevealValue ? (React__default.createElement(InputText, Object.assign({}, inputProps, { type: "text", ref: inputRef }))) : (React__default.createElement(InputPassword, Object.assign({}, inputProps, { ref: inputRef })));
31
+ const buttonSvg = shouldRevealValue ? SvgEyeHide : SvgEye;
32
+ const buttonText = shouldRevealValue ? 'Conceal password' : 'Reveal password';
33
+ const button = revealValue ? undefined : (React__default.createElement(FieldButton, { onClick: handleButtonClick, svg: buttonSvg, assistiveText: buttonText }));
34
+ const classNames = moduleClassNames(styles, PASSWORD_FIELD);
35
+ return (React__default.createElement(FieldLayout, Object.assign({}, layoutProps, { icon: icon, button: button, className: classNames.join(' '), input: input, inputHandle: inputRef.current, ref: layoutRef })));
36
+ };
37
+ const PasswordField = forwardRef(PasswordFieldLocal);
38
+
39
+ export { PasswordField };
40
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUGFzc3dvcmRGaWVsZC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvUGFzc3dvcmRGaWVsZC9QYXNzd29yZEZpZWxkLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IElucHV0SW1wZXJhdGl2ZUhhbmRsZSwgUGFzc3dvcmRGaWVsZFByb3BzIH0gZnJvbSAnQHByZXBseS9kcy13ZWItY29yZSc7XG5pbXBvcnQgeyBtb2R1bGVDbGFzc05hbWVzLCB1c2VQYXNzd29yZEZpZWxkLCB1c2VTdHlsZUV4dHJhY3QgfSBmcm9tICdAcHJlcGx5L2RzLXdlYi1jb3JlJztcbmltcG9ydCBSZWFjdCwgeyBGQywgZm9yd2FyZFJlZiwgdXNlSW1wZXJhdGl2ZUhhbmRsZSwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgRmllbGRCdXR0b24gfSBmcm9tICcuLi9GaWVsZEJ1dHRvbi9GaWVsZEJ1dHRvbic7XG5pbXBvcnQgeyBGaWVsZExheW91dCB9IGZyb20gJy4uL0ZpZWxkTGF5b3V0L0ZpZWxkTGF5b3V0JztcbmltcG9ydCB7IEljb24gfSBmcm9tICcuLi9JY29uL0ljb24nO1xuaW1wb3J0IHsgSW5wdXRQYXNzd29yZCB9IGZyb20gJy4uL3ByaXZhdGUvSW5wdXQvSW5wdXRQYXNzd29yZCc7XG5pbXBvcnQgeyBJbnB1dFRleHQgfSBmcm9tICcuLi9wcml2YXRlL0lucHV0L0lucHV0VGV4dCc7XG5cbmltcG9ydCBzdHlsZXMgZnJvbSAnLi9zdHlsZS9pbmRleC5tb2R1bGUubGVzcyc7XG5pbXBvcnQgRXllSGlkZVN2ZyBmcm9tICcuL3N2Zy9leWUtaGlkZS5zdmcnO1xuaW1wb3J0IEV5ZVN2ZyBmcm9tICcuL3N2Zy9leWUuc3ZnJztcbmltcG9ydCBMb2NrU3ZnIGZyb20gJy4vc3ZnL2xvY2suc3ZnJztcblxuY29uc3QgUEFTU1dPUkRfRklFTEQgPSAnUGFzc3dvcmRGaWVsZCc7XG5cbmNvbnN0IFBhc3N3b3JkRmllbGRMb2NhbDogRkM8UGFzc3dvcmRGaWVsZFByb3BzPiA9IChcbiAgICB7IHNob3dJY29uLCByZXZlYWxWYWx1ZSwgaWQ6IG9wdGlvbmFsSWQsIC4uLnByb3BzIH0sXG4gICAgcmVmLFxuKSA9PiB7XG4gICAgdXNlU3R5bGVFeHRyYWN0KHN0eWxlcyk7XG5cbiAgICBjb25zdCBsYXlvdXRSZWYgPSB1c2VSZWY8SW5wdXRJbXBlcmF0aXZlSGFuZGxlPihudWxsKTtcbiAgICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxJbnB1dEltcGVyYXRpdmVIYW5kbGU+KG51bGwpO1xuXG4gICAgdXNlSW1wZXJhdGl2ZUhhbmRsZShyZWYsICgpID0+ICh7XG4gICAgICAgIHNldEZvY3VzOiAoKSA9PiBpbnB1dFJlZj8uY3VycmVudD8uc2V0Rm9jdXMoKSxcbiAgICB9KSk7XG5cbiAgICBjb25zdCBwYXNzd29yZEZpZWxkID0gdXNlUGFzc3dvcmRGaWVsZCh7XG4gICAgICAgIGlkOiBvcHRpb25hbElkLFxuICAgICAgICAuLi5wcm9wcyxcbiAgICB9KTtcbiAgICBjb25zdCB7IGxheW91dFByb3BzLCBpbnB1dFByb3BzIH0gPSBwYXNzd29yZEZpZWxkO1xuXG4gICAgY29uc3QgW3Nob3VsZFJldmVhbFZhbHVlLCBzZXRTaG91bGRSZXZlYWxWYWx1ZV0gPSB1c2VTdGF0ZTxib29sZWFuPihmYWxzZSk7XG5cbiAgICBjb25zdCBoYW5kbGVCdXR0b25DbGljayA9ICgpID0+IHNldFNob3VsZFJldmVhbFZhbHVlKCFzaG91bGRSZXZlYWxWYWx1ZSk7XG5cbiAgICBjb25zdCBpY29uID0gc2hvd0ljb24gPyA8SWNvbiBzdmc9e0xvY2tTdmd9IC8+IDogdW5kZWZpbmVkO1xuXG4gICAgY29uc3QgYWN0dWFsUmV2ZWFsVmFsdWUgPSBzaG91bGRSZXZlYWxWYWx1ZSB8fCByZXZlYWxWYWx1ZTtcbiAgICBjb25zdCBpbnB1dCA9IGFjdHVhbFJldmVhbFZhbHVlID8gKFxuICAgICAgICA8SW5wdXRUZXh0IHsuLi5pbnB1dFByb3BzfSB0eXBlPVwidGV4dFwiIHJlZj17aW5wdXRSZWZ9IC8+XG4gICAgKSA6IChcbiAgICAgICAgPElucHV0UGFzc3dvcmQgey4uLmlucHV0UHJvcHN9IHJlZj17aW5wdXRSZWZ9IC8+XG4gICAgKTtcblxuICAgIGNvbnN0IGJ1dHRvblN2ZyA9IHNob3VsZFJldmVhbFZhbHVlID8gRXllSGlkZVN2ZyA6IEV5ZVN2ZztcbiAgICBjb25zdCBidXR0b25UZXh0ID0gc2hvdWxkUmV2ZWFsVmFsdWUgPyAnQ29uY2VhbCBwYXNzd29yZCcgOiAnUmV2ZWFsIHBhc3N3b3JkJztcbiAgICBjb25zdCBidXR0b24gPSByZXZlYWxWYWx1ZSA/IHVuZGVmaW5lZCA6IChcbiAgICAgICAgPEZpZWxkQnV0dG9uIG9uQ2xpY2s9e2hhbmRsZUJ1dHRvbkNsaWNrfSBzdmc9e2J1dHRvblN2Z30gYXNzaXN0aXZlVGV4dD17YnV0dG9uVGV4dH0gLz5cbiAgICApO1xuXG4gICAgY29uc3QgY2xhc3NOYW1lcyA9IG1vZHVsZUNsYXNzTmFtZXMoc3R5bGVzLCBQQVNTV09SRF9GSUVMRCk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgICA8RmllbGRMYXlvdXRcbiAgICAgICAgICAgIHsuLi5sYXlvdXRQcm9wc31cbiAgICAgICAgICAgIGljb249e2ljb259XG4gICAgICAgICAgICBidXR0b249e2J1dHRvbn1cbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lcy5qb2luKCcgJyl9XG4gICAgICAgICAgICBpbnB1dD17aW5wdXR9XG4gICAgICAgICAgICBpbnB1dEhhbmRsZT17aW5wdXRSZWYuY3VycmVudH1cbiAgICAgICAgICAgIHJlZj17bGF5b3V0UmVmfVxuICAgICAgICAvPlxuICAgICk7XG59O1xuXG5leHBvcnQgY29uc3QgUGFzc3dvcmRGaWVsZCA9IGZvcndhcmRSZWY8SW5wdXRJbXBlcmF0aXZlSGFuZGxlLCBQYXNzd29yZEZpZWxkUHJvcHM+KFxuICAgIFBhc3N3b3JkRmllbGRMb2NhbCxcbik7XG4i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
@@ -0,0 +1,5 @@
1
+ @import './mixins.less';
2
+
3
+ .PasswordField {
4
+ .password-field-base();
5
+ }
@@ -0,0 +1,9 @@
1
+ import styleInject from '../../../external/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = "._1cLd_W{display:-webkit-box;display:-ms-flexbox;display:flex}";
4
+ var styles = {__id:"/home/jenkins/workspace/design-system_main/packages/web-lib/src/components/PasswordField/style/index.module.less",__css:css_248z,"PasswordField":"_1cLd_W"};
5
+ var stylesheet=css_248z;
6
+ styleInject(css_248z);
7
+
8
+ export { styles as default, stylesheet };
9
+
@@ -0,0 +1,3 @@
1
+ .password-field-base() {
2
+ display: flex;
3
+ }
@@ -0,0 +1,8 @@
1
+ import styleInject from '../../../external/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = "";
4
+ var stylesheet="";
5
+ styleInject(css_248z);
6
+
7
+ export { css_248z as default, stylesheet };
8
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjpudWxsLCJzb3VyY2VzIjpbbnVsbF0sInNvdXJjZXNDb250ZW50IjpbbnVsbF0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdCQUF3Qix3REFBNEQ7QUFDcEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOyJ9
@@ -0,0 +1,21 @@
1
+ import * as React from 'react';
2
+
3
+ var _path;
4
+
5
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
6
+
7
+ function SvgEyeHide(props) {
8
+ return /*#__PURE__*/React.createElement("svg", _extends({
9
+ viewBox: "0 0 24 24",
10
+ fill: "none",
11
+ xmlns: "http://www.w3.org/2000/svg"
12
+ }, props), _path || (_path = /*#__PURE__*/React.createElement("path", {
13
+ fillRule: "evenodd",
14
+ clipRule: "evenodd",
15
+ d: "M7.649 7.234l1.737 1.738a4 4 0 015.642 5.642l1.829 1.828c1.282-.873 2.288-1.976 3.007-2.931a14.882 14.882 0 001-1.511 14.984 14.984 0 00-2.1-2.81C17.195 7.548 14.94 6 12 6c-1.674 0-3.122.5-4.351 1.234zm8.56 11.39l1.084 1.083a1 1 0 001.414-1.414l-.415-.415c1.37-.994 2.425-2.175 3.17-3.165a16.87 16.87 0 001.066-1.594 12.902 12.902 0 00.344-.627l.02-.04.006-.012.002-.004v-.002h.001L22 12l.901.433a1 1 0 000-.866L22 12c.901-.433.901-.434.9-.434v-.003l-.004-.007-.01-.02a10.08 10.08 0 00-.167-.317 16.98 16.98 0 00-2.508-3.409C18.439 5.952 15.695 4 12 4c-2.303 0-4.242.761-5.802 1.784l-.49-.491a1 1 0 00-1.415 1.414l11.491 11.491a.996.996 0 00.425.425zm-2.603-5.432a2 2 0 00-2.798-2.798l2.798 2.798zM4.121 8.878a1 1 0 01.174 1.404A15.022 15.022 0 003.135 12a14.987 14.987 0 002.1 2.81C6.806 16.453 9.062 18 12 18a1 1 0 110 2c-3.695 0-6.439-1.953-8.211-3.81a16.98 16.98 0 01-2.508-3.408 10.023 10.023 0 01-.167-.318l-.01-.02-.003-.007-.001-.002c-.001-.001-.001-.002.9-.435l-.901-.434.001-.002.002-.005.007-.013.022-.044.08-.155c.07-.131.172-.317.307-.543.268-.452.668-1.07 1.2-1.752a1 1 0 011.403-.174zM2 12l-.901.433a1 1 0 010-.866L2 12z",
16
+ fill: "currentColor"
17
+ })));
18
+ }
19
+
20
+ export { SvgEyeHide as default };
21
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXllLWhpZGUuc3ZnLmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyJ9
@@ -0,0 +1,21 @@
1
+ import * as React from 'react';
2
+
3
+ var _path;
4
+
5
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
6
+
7
+ function SvgEye(props) {
8
+ return /*#__PURE__*/React.createElement("svg", _extends({
9
+ viewBox: "0 0 24 24",
10
+ fill: "none",
11
+ xmlns: "http://www.w3.org/2000/svg"
12
+ }, props), _path || (_path = /*#__PURE__*/React.createElement("path", {
13
+ fillRule: "evenodd",
14
+ clipRule: "evenodd",
15
+ d: "M3.472 12.555A13.599 13.599 0 013.135 12a14.985 14.985 0 012.1-2.81C6.806 7.548 9.062 6 12 6c2.94 0 5.195 1.547 6.764 3.19a14.984 14.984 0 012.1 2.81 14.986 14.986 0 01-2.1 2.81C17.195 16.453 14.94 18 12 18c-2.94 0-5.195-1.547-6.764-3.19a14.987 14.987 0 01-1.764-2.255zm19.429-.99c0 .001 0 .002-.901.435.901.433.901.434.9.434v.003l-.004.007-.01.02-.035.07a15.023 15.023 0 01-.637 1.097 16.976 16.976 0 01-2.003 2.56C18.439 18.047 15.695 20 12 20c-3.695 0-6.439-1.953-8.211-3.81a16.98 16.98 0 01-2.508-3.408 10.023 10.023 0 01-.167-.318l-.01-.02-.003-.007-.001-.002c-.001-.001-.001-.002.9-.435-.901-.433-.901-.434-.9-.434v-.003l.004-.007.01-.02.035-.07a14.966 14.966 0 01.637-1.097 16.984 16.984 0 012.003-2.56C5.561 5.953 8.305 4 12 4c3.695 0 6.439 1.953 8.211 3.81a16.98 16.98 0 012.508 3.408 10.08 10.08 0 01.167.318l.01.02.003.007.001.002zM22 12l.901-.433a1 1 0 010 .866L22 12zm-20.901-.433L2 12l-.901.433a1 1 0 010-.866zM10 12a2 2 0 114 0 2 2 0 01-4 0zm2-4a4 4 0 100 8 4 4 0 000-8z",
16
+ fill: "currentColor"
17
+ })));
18
+ }
19
+
20
+ export { SvgEye as default };
21
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXllLnN2Zy5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==
@@ -0,0 +1,21 @@
1
+ import * as React from 'react';
2
+
3
+ var _path;
4
+
5
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
6
+
7
+ function SvgLock(props) {
8
+ return /*#__PURE__*/React.createElement("svg", _extends({
9
+ viewBox: "0 0 24 24",
10
+ fill: "none",
11
+ xmlns: "http://www.w3.org/2000/svg"
12
+ }, props), _path || (_path = /*#__PURE__*/React.createElement("path", {
13
+ fillRule: "evenodd",
14
+ clipRule: "evenodd",
15
+ d: "M8 5a4 4 0 118 0v4.1c2.282.463 4 2.481 4 4.9v4a5 5 0 01-5 5H9a5 5 0 01-5-5v-4a5.002 5.002 0 014-4.9V5zm6 0v4h-4V5a2 2 0 114 0zm4 9a3 3 0 00-3-3H9a3 3 0 00-3 3v4a3 3 0 003 3h6a3 3 0 003-3v-4zm-6 4a2 2 0 100-4 2 2 0 000 4z",
16
+ fill: "currentColor"
17
+ })));
18
+ }
19
+
20
+ export { SvgLock as default };
21
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jay5zdmcuanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7In0=
@@ -2,6 +2,7 @@ export { Avatar } from './Avatar/Avatar';
2
2
  export { AvatarWithStatus } from './AvatarWithStatus/AvatarWithStatus';
3
3
  export { Box } from './Box/Box';
4
4
  export { Button } from './Button/Button';
5
+ export { Badge } from './Badge/Badge';
5
6
  export { FieldAdditionalText } from './FieldAdditionalText/FieldAdditionalText';
6
7
  export { FieldButton } from './FieldButton/FieldButton';
7
8
  export { FieldLayout } from './FieldLayout/FieldLayout';
@@ -21,5 +22,6 @@ export { PanelFooter } from './Panel/private/PanelFooter';
21
22
  export { PreplyLogo } from './PreplyLogo/PreplyLogo';
22
23
  export { Text } from './Text/Text';
23
24
  export { TextField } from './TextField/TextField';
25
+ export { PasswordField } from './PasswordField/PasswordField';
24
26
  export { TextHighlighted } from './TextHighlighted/TextHighlighted';
25
27
  export { TextInline } from './TextInline/TextInline';
@@ -2,6 +2,7 @@ export { Avatar } from './Avatar/Avatar.js';
2
2
  export { AvatarWithStatus } from './AvatarWithStatus/AvatarWithStatus.js';
3
3
  export { Box } from './Box/Box.js';
4
4
  export { Button } from './Button/Button.js';
5
+ export { Badge } from './Badge/Badge.js';
5
6
  export { FieldAdditionalText } from './FieldAdditionalText/FieldAdditionalText.js';
6
7
  export { FieldButton } from './FieldButton/FieldButton.js';
7
8
  export { FieldLayout } from './FieldLayout/FieldLayout.js';
@@ -21,6 +22,7 @@ export { PanelFooter } from './Panel/private/PanelFooter.js';
21
22
  export { PreplyLogo } from './PreplyLogo/PreplyLogo.js';
22
23
  export { Text } from './Text/Text.js';
23
24
  export { TextField } from './TextField/TextField.js';
25
+ export { PasswordField } from './PasswordField/PasswordField.js';
24
26
  export { TextHighlighted } from './TextHighlighted/TextHighlighted.js';
25
27
  export { TextInline } from './TextInline/TextInline.js';
26
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7In0=
28
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==
@@ -1,5 +1,5 @@
1
1
  import type { ButtonSize, ButtonVariant, Dataset, Responsive } from '@preply/ds-core';
2
- import { FC, MouseEventHandler, ReactNode } from 'react';
2
+ import { FC, MouseEventHandler, ReactElement, ReactNode } from 'react';
3
3
  export interface ButtonBaseProps {
4
4
  variant?: ButtonVariant;
5
5
  size?: Responsive<ButtonSize>;
@@ -16,6 +16,7 @@ export interface ButtonBaseProps {
16
16
  disabled?: boolean;
17
17
  busy?: boolean;
18
18
  isIconButton: boolean;
19
+ as?: ReactElement;
19
20
  dataset?: Dataset;
20
21
  children?: ReactNode;
21
22
  }
@@ -1,6 +1,6 @@
1
1
  import { BUTTON_VARIANT_DEFAULT, BUTTON_SIZE_DEFAULT } from '@preply/ds-core';
2
2
  import { useStyleExtract, useHostname, moduleClassNames, stringClassNames, booleanClassNames, getDatasetProps, getExternalUrlProps, moduleLocals, mapEdgeKeyToStandard } from '@preply/ds-web-core';
3
- import React__default, { useRef } from 'react';
3
+ import React__default, { useRef, cloneElement } from 'react';
4
4
  import { Spinner } from '../../Spinner/Spinner.js';
5
5
  import styles from './style/index.module.less.js';
6
6
 
@@ -13,7 +13,7 @@ const renderContent = ({ children, busy }) => {
13
13
  busy && (React__default.createElement("span", { className: busyClassNames.join(' ') },
14
14
  React__default.createElement(Spinner, null)))));
15
15
  };
16
- const ButtonBase = ({ children, variant = BUTTON_VARIANT_DEFAULT, size = BUTTON_SIZE_DEFAULT, fullWidth = false, wrap = false, href, url, opensInNewTab, nofollow, submitsForm, a11yLabel, assistiveText, onClick, disabled, busy, isIconButton, dataset, }) => {
16
+ const ButtonBase = ({ variant = BUTTON_VARIANT_DEFAULT, size = BUTTON_SIZE_DEFAULT, fullWidth = false, wrap = false, href, url, opensInNewTab, nofollow, submitsForm, a11yLabel, assistiveText, onClick, disabled, busy, isIconButton, as, dataset, children, }) => {
17
17
  useStyleExtract(styles);
18
18
  const hostname = useHostname();
19
19
  const ref = useRef(null);
@@ -54,11 +54,22 @@ const ButtonBase = ({ children, variant = BUTTON_VARIANT_DEFAULT, size = BUTTON_
54
54
  'aria-disabled': disabled || busy ? true : undefined,
55
55
  };
56
56
  const actualHref = href || url;
57
+ const linkProps = {
58
+ ...props,
59
+ ref,
60
+ role: 'button',
61
+ tabIndex: disabled ? -1 : 0,
62
+ href: actualHref,
63
+ onKeyDown: handleKeyPress,
64
+ };
57
65
  if (actualHref) {
58
- return (React__default.createElement("a", Object.assign({}, props, getExternalUrlProps(hostname, actualHref, opensInNewTab, nofollow), { ref: ref, role: "button", tabIndex: disabled ? -1 : 0, href: actualHref, onKeyDown: handleKeyPress }), renderContent({ children, busy })));
66
+ return (React__default.createElement("a", Object.assign({}, linkProps, getExternalUrlProps(hostname, actualHref, opensInNewTab, nofollow)), renderContent({ children, busy })));
67
+ }
68
+ if (as) {
69
+ return cloneElement(as, { ...linkProps }, renderContent({ children, busy }));
59
70
  }
60
71
  return (React__default.createElement("button", Object.assign({}, props, { type: submitsForm ? 'submit' : 'button' }), renderContent({ children, busy })));
61
72
  };
62
73
 
63
74
  export { ButtonBase };
64
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ButtonBase.js","sources":["../../../../src/components/private/ButtonBase/ButtonBase.tsx"],"sourcesContent":["import type { ButtonSize, ButtonVariant, Dataset, Responsive } from '@preply/ds-core';\nimport { BUTTON_SIZE_DEFAULT, BUTTON_VARIANT_DEFAULT } from '@preply/ds-core';\nimport {\n    booleanClassNames,\n    getDatasetProps,\n    getExternalUrlProps,\n    mapEdgeKeyToStandard,\n    moduleClassNames,\n    moduleLocals,\n    stringClassNames,\n    useHostname,\n    useStyleExtract,\n} from '@preply/ds-web-core';\nimport React, { FC, KeyboardEvent, MouseEvent, MouseEventHandler, ReactNode, useRef } from 'react';\n\nimport { Spinner } from '../../Spinner/Spinner';\n\nimport styles from './style/index.module.less';\n\nexport interface ButtonBaseProps {\n    variant?: ButtonVariant;\n    size?: Responsive<ButtonSize>;\n    fullWidth?: Responsive<boolean>;\n    wrap?: boolean;\n    href?: string;\n    url?: string;\n    opensInNewTab?: boolean;\n    nofollow?: boolean;\n    submitsForm?: boolean;\n    a11yLabel?: string;\n    assistiveText?: string;\n    onClick?: MouseEventHandler;\n    disabled?: boolean;\n    busy?: boolean;\n    isIconButton: boolean;\n    dataset?: Dataset;\n    children?: ReactNode;\n}\n\nconst BUTTON_BASE = 'ButtonBase';\n\nconst renderContent: FC<{ busy?: boolean }> = ({ children, busy }) => {\n    const contentClassNames = [...moduleLocals(styles, BUTTON_BASE, ['content'])];\n    const busyClassNames = [...moduleLocals(styles, BUTTON_BASE, ['busy'])];\n    return (\n        <>\n            <span className={contentClassNames.join(' ')}>{children}</span>\n            {busy && (\n                <span className={busyClassNames.join(' ')}>\n                    <Spinner />\n                </span>\n            )}\n        </>\n    );\n};\n\nexport const ButtonBase: FC<ButtonBaseProps> = ({\n    children,\n    variant = BUTTON_VARIANT_DEFAULT,\n    size = BUTTON_SIZE_DEFAULT,\n    fullWidth = false,\n    wrap = false,\n    href,\n    url,\n    opensInNewTab,\n    nofollow,\n    submitsForm,\n    a11yLabel,\n    assistiveText,\n    onClick,\n    disabled,\n    busy,\n    isIconButton,\n    dataset,\n}) => {\n    useStyleExtract(styles);\n\n    const hostname = useHostname();\n    const ref = useRef<HTMLAnchorElement>(null);\n\n    const handleClick = (event: MouseEvent) => {\n        if (disabled || busy) {\n            event.preventDefault();\n        }\n        if (onClick) {\n            onClick(event);\n        }\n    };\n\n    const handleKeyPress = (event: KeyboardEvent) => {\n        const key = mapEdgeKeyToStandard(event.key);\n        if (key === ' ' || key === 'Enter') {\n            event.preventDefault();\n            ref.current?.click();\n        }\n    };\n\n    const classNames = moduleClassNames(styles, BUTTON_BASE, [\n        stringClassNames('variant', variant),\n        stringClassNames('size', size),\n        isIconButton ? stringClassNames('is-icon-button-size', size) : [],\n        booleanClassNames(undefined, 'no-wrap', wrap),\n        booleanClassNames('width-full', 'width-auto', fullWidth),\n        booleanClassNames('is-busy', undefined, busy),\n        booleanClassNames('is-icon-button', undefined, isIconButton),\n    ]);\n\n    const title = isIconButton ? assistiveText || a11yLabel : undefined;\n    const ariaLabel = !isIconButton ? assistiveText || a11yLabel : undefined;\n\n    const props = {\n        ...getDatasetProps(dataset),\n        className: classNames.join(' '),\n        title,\n        'aria-label': ariaLabel,\n        onClick: handleClick,\n        disabled,\n        'aria-disabled': disabled || busy ? true : undefined,\n    };\n\n    const actualHref = href || url;\n    if (actualHref) {\n        return (\n            <a\n                {...props}\n                {...getExternalUrlProps(hostname, actualHref, opensInNewTab, nofollow)}\n                ref={ref}\n                role=\"button\"\n                tabIndex={disabled ? -1 : 0}\n                href={actualHref}\n                onKeyDown={handleKeyPress}\n            >\n                {renderContent({ children, busy })}\n            </a>\n        );\n    }\n\n    return (\n        <button {...props} type={submitsForm ? 'submit' : 'button'}>\n            {renderContent({ children, busy })}\n        </button>\n    );\n};\n"],"names":["React"],"mappings":";;;;;;AAuCA,MAAM,WAAW,GAAG,YAAY,CAAC;AAEjC,MAAM,aAAa,GAA2B,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;IAC7D,MAAM,iBAAiB,GAAG,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAC9E,MAAM,cAAc,GAAG,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,WAAW,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IACxE,QACIA;QACIA,uCAAM,SAAS,EAAE,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAG,QAAQ,CAAQ;QAC9D,IAAI,KACDA,uCAAM,SAAS,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC;YACrCA,6BAAC,OAAO,OAAG,CACR,CACV,CACF,EACL;AACN,CAAC,CAAC;MAEW,UAAU,GAAwB,CAAC,EAC5C,QAAQ,EACR,OAAO,GAAG,sBAAsB,EAChC,IAAI,GAAG,mBAAmB,EAC1B,SAAS,GAAG,KAAK,EACjB,IAAI,GAAG,KAAK,EACZ,IAAI,EACJ,GAAG,EACH,aAAa,EACb,QAAQ,EACR,WAAW,EACX,SAAS,EACT,aAAa,EACb,OAAO,EACP,QAAQ,EACR,IAAI,EACJ,YAAY,EACZ,OAAO,GACV;IACG,eAAe,CAAC,MAAM,CAAC,CAAC;IAExB,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IAC/B,MAAM,GAAG,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAC;IAE5C,MAAM,WAAW,GAAG,CAAC,KAAiB;QAClC,IAAI,QAAQ,IAAI,IAAI,EAAE;YAClB,KAAK,CAAC,cAAc,EAAE,CAAC;SAC1B;QACD,IAAI,OAAO,EAAE;YACT,OAAO,CAAC,KAAK,CAAC,CAAC;SAClB;KACJ,CAAC;IAEF,MAAM,cAAc,GAAG,CAAC,KAAoB;;QACxC,MAAM,GAAG,GAAG,oBAAoB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAI,GAAG,KAAK,GAAG,IAAI,GAAG,KAAK,OAAO,EAAE;YAChC,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,MAAA,GAAG,CAAC,OAAO,0CAAE,KAAK,GAAG;SACxB;KACJ,CAAC;IAEF,MAAM,UAAU,GAAG,gBAAgB,CAAC,MAAM,EAAE,WAAW,EAAE;QACrD,gBAAgB,CAAC,SAAS,EAAE,OAAO,CAAC;QACpC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC;QAC9B,YAAY,GAAG,gBAAgB,CAAC,qBAAqB,EAAE,IAAI,CAAC,GAAG,EAAE;QACjE,iBAAiB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC;QAC7C,iBAAiB,CAAC,YAAY,EAAE,YAAY,EAAE,SAAS,CAAC;QACxD,iBAAiB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC;QAC7C,iBAAiB,CAAC,gBAAgB,EAAE,SAAS,EAAE,YAAY,CAAC;KAC/D,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,YAAY,GAAG,aAAa,IAAI,SAAS,GAAG,SAAS,CAAC;IACpE,MAAM,SAAS,GAAG,CAAC,YAAY,GAAG,aAAa,IAAI,SAAS,GAAG,SAAS,CAAC;IAEzE,MAAM,KAAK,GAAG;QACV,GAAG,eAAe,CAAC,OAAO,CAAC;QAC3B,SAAS,EAAE,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC;QAC/B,KAAK;QACL,YAAY,EAAE,SAAS;QACvB,OAAO,EAAE,WAAW;QACpB,QAAQ;QACR,eAAe,EAAE,QAAQ,IAAI,IAAI,GAAG,IAAI,GAAG,SAAS;KACvD,CAAC;IAEF,MAAM,UAAU,GAAG,IAAI,IAAI,GAAG,CAAC;IAC/B,IAAI,UAAU,EAAE;QACZ,QACIA,oDACQ,KAAK,EACL,mBAAmB,CAAC,QAAQ,EAAE,UAAU,EAAE,aAAa,EAAE,QAAQ,CAAC,IACtE,GAAG,EAAE,GAAG,EACR,IAAI,EAAC,QAAQ,EACb,QAAQ,EAAE,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,EAC3B,IAAI,EAAE,UAAU,EAChB,SAAS,EAAE,cAAc,KAExB,aAAa,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAClC,EACN;KACL;IAED,QACIA,yDAAY,KAAK,IAAE,IAAI,EAAE,WAAW,GAAG,QAAQ,GAAG,QAAQ,KACrD,aAAa,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC7B,EACX;AACN;;;;"}
75
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ButtonBase.js","sources":["../../../../src/components/private/ButtonBase/ButtonBase.tsx"],"sourcesContent":["import type { ButtonSize, ButtonVariant, Dataset, Responsive } from '@preply/ds-core';\nimport { BUTTON_SIZE_DEFAULT, BUTTON_VARIANT_DEFAULT } from '@preply/ds-core';\nimport {\n    booleanClassNames,\n    getDatasetProps,\n    getExternalUrlProps,\n    mapEdgeKeyToStandard,\n    moduleClassNames,\n    moduleLocals,\n    stringClassNames,\n    useHostname,\n    useStyleExtract,\n} from '@preply/ds-web-core';\nimport React, {\n    FC,\n    KeyboardEvent,\n    MouseEvent,\n    MouseEventHandler,\n    ReactElement,\n    ReactNode,\n    cloneElement,\n    useRef,\n} from 'react';\n\nimport { Spinner } from '../../Spinner/Spinner';\n\nimport styles from './style/index.module.less';\n\nexport interface ButtonBaseProps {\n    variant?: ButtonVariant;\n    size?: Responsive<ButtonSize>;\n    fullWidth?: Responsive<boolean>;\n    wrap?: boolean;\n    href?: string;\n    url?: string;\n    opensInNewTab?: boolean;\n    nofollow?: boolean;\n    submitsForm?: boolean;\n    a11yLabel?: string;\n    assistiveText?: string;\n    onClick?: MouseEventHandler;\n    disabled?: boolean;\n    busy?: boolean;\n    isIconButton: boolean;\n    as?: ReactElement;\n    dataset?: Dataset;\n    children?: ReactNode;\n}\n\nconst BUTTON_BASE = 'ButtonBase';\n\nconst renderContent: FC<{ busy?: boolean }> = ({ children, busy }) => {\n    const contentClassNames = [...moduleLocals(styles, BUTTON_BASE, ['content'])];\n    const busyClassNames = [...moduleLocals(styles, BUTTON_BASE, ['busy'])];\n    return (\n        <>\n            <span className={contentClassNames.join(' ')}>{children}</span>\n            {busy && (\n                <span className={busyClassNames.join(' ')}>\n                    <Spinner />\n                </span>\n            )}\n        </>\n    );\n};\n\nexport const ButtonBase: FC<ButtonBaseProps> = ({\n    variant = BUTTON_VARIANT_DEFAULT,\n    size = BUTTON_SIZE_DEFAULT,\n    fullWidth = false,\n    wrap = false,\n    href,\n    url,\n    opensInNewTab,\n    nofollow,\n    submitsForm,\n    a11yLabel,\n    assistiveText,\n    onClick,\n    disabled,\n    busy,\n    isIconButton,\n    as,\n    dataset,\n    children,\n}) => {\n    useStyleExtract(styles);\n\n    const hostname = useHostname();\n    const ref = useRef<HTMLAnchorElement>(null);\n\n    const handleClick = (event: MouseEvent) => {\n        if (disabled || busy) {\n            event.preventDefault();\n        }\n        if (onClick) {\n            onClick(event);\n        }\n    };\n\n    const handleKeyPress = (event: KeyboardEvent) => {\n        const key = mapEdgeKeyToStandard(event.key);\n        if (key === ' ' || key === 'Enter') {\n            event.preventDefault();\n            ref.current?.click();\n        }\n    };\n\n    const classNames = moduleClassNames(styles, BUTTON_BASE, [\n        stringClassNames('variant', variant),\n        stringClassNames('size', size),\n        isIconButton ? stringClassNames('is-icon-button-size', size) : [],\n        booleanClassNames(undefined, 'no-wrap', wrap),\n        booleanClassNames('width-full', 'width-auto', fullWidth),\n        booleanClassNames('is-busy', undefined, busy),\n        booleanClassNames('is-icon-button', undefined, isIconButton),\n    ]);\n\n    const title = isIconButton ? assistiveText || a11yLabel : undefined;\n    const ariaLabel = !isIconButton ? assistiveText || a11yLabel : undefined;\n\n    const props = {\n        ...getDatasetProps(dataset),\n        className: classNames.join(' '),\n        title,\n        'aria-label': ariaLabel,\n        onClick: handleClick,\n        disabled,\n        'aria-disabled': disabled || busy ? true : undefined,\n    };\n\n    const actualHref = href || url;\n\n    const linkProps = {\n        ...props,\n        ref,\n        role: 'button',\n        tabIndex: disabled ? -1 : 0,\n        href: actualHref,\n        onKeyDown: handleKeyPress,\n    };\n\n    if (actualHref) {\n        return (\n            <a\n                {...linkProps}\n                {...getExternalUrlProps(hostname, actualHref, opensInNewTab, nofollow)}\n            >\n                {renderContent({ children, busy })}\n            </a>\n        );\n    }\n\n    if (as) {\n        return cloneElement(\n            as as ReactElement,\n            { ...linkProps },\n            renderContent({ children, busy }),\n        );\n    }\n\n    return (\n        <button {...props} type={submitsForm ? 'submit' : 'button'}>\n            {renderContent({ children, busy })}\n        </button>\n    );\n};\n"],"names":["React"],"mappings":";;;;;;AAiDA,MAAM,WAAW,GAAG,YAAY,CAAC;AAEjC,MAAM,aAAa,GAA2B,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;IAC7D,MAAM,iBAAiB,GAAG,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAC9E,MAAM,cAAc,GAAG,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,WAAW,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IACxE,QACIA;QACIA,uCAAM,SAAS,EAAE,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAG,QAAQ,CAAQ;QAC9D,IAAI,KACDA,uCAAM,SAAS,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC;YACrCA,6BAAC,OAAO,OAAG,CACR,CACV,CACF,EACL;AACN,CAAC,CAAC;MAEW,UAAU,GAAwB,CAAC,EAC5C,OAAO,GAAG,sBAAsB,EAChC,IAAI,GAAG,mBAAmB,EAC1B,SAAS,GAAG,KAAK,EACjB,IAAI,GAAG,KAAK,EACZ,IAAI,EACJ,GAAG,EACH,aAAa,EACb,QAAQ,EACR,WAAW,EACX,SAAS,EACT,aAAa,EACb,OAAO,EACP,QAAQ,EACR,IAAI,EACJ,YAAY,EACZ,EAAE,EACF,OAAO,EACP,QAAQ,GACX;IACG,eAAe,CAAC,MAAM,CAAC,CAAC;IAExB,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IAC/B,MAAM,GAAG,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAC;IAE5C,MAAM,WAAW,GAAG,CAAC,KAAiB;QAClC,IAAI,QAAQ,IAAI,IAAI,EAAE;YAClB,KAAK,CAAC,cAAc,EAAE,CAAC;SAC1B;QACD,IAAI,OAAO,EAAE;YACT,OAAO,CAAC,KAAK,CAAC,CAAC;SAClB;KACJ,CAAC;IAEF,MAAM,cAAc,GAAG,CAAC,KAAoB;;QACxC,MAAM,GAAG,GAAG,oBAAoB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAI,GAAG,KAAK,GAAG,IAAI,GAAG,KAAK,OAAO,EAAE;YAChC,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,MAAA,GAAG,CAAC,OAAO,0CAAE,KAAK,GAAG;SACxB;KACJ,CAAC;IAEF,MAAM,UAAU,GAAG,gBAAgB,CAAC,MAAM,EAAE,WAAW,EAAE;QACrD,gBAAgB,CAAC,SAAS,EAAE,OAAO,CAAC;QACpC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC;QAC9B,YAAY,GAAG,gBAAgB,CAAC,qBAAqB,EAAE,IAAI,CAAC,GAAG,EAAE;QACjE,iBAAiB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC;QAC7C,iBAAiB,CAAC,YAAY,EAAE,YAAY,EAAE,SAAS,CAAC;QACxD,iBAAiB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC;QAC7C,iBAAiB,CAAC,gBAAgB,EAAE,SAAS,EAAE,YAAY,CAAC;KAC/D,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,YAAY,GAAG,aAAa,IAAI,SAAS,GAAG,SAAS,CAAC;IACpE,MAAM,SAAS,GAAG,CAAC,YAAY,GAAG,aAAa,IAAI,SAAS,GAAG,SAAS,CAAC;IAEzE,MAAM,KAAK,GAAG;QACV,GAAG,eAAe,CAAC,OAAO,CAAC;QAC3B,SAAS,EAAE,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC;QAC/B,KAAK;QACL,YAAY,EAAE,SAAS;QACvB,OAAO,EAAE,WAAW;QACpB,QAAQ;QACR,eAAe,EAAE,QAAQ,IAAI,IAAI,GAAG,IAAI,GAAG,SAAS;KACvD,CAAC;IAEF,MAAM,UAAU,GAAG,IAAI,IAAI,GAAG,CAAC;IAE/B,MAAM,SAAS,GAAG;QACd,GAAG,KAAK;QACR,GAAG;QACH,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC;QAC3B,IAAI,EAAE,UAAU;QAChB,SAAS,EAAE,cAAc;KAC5B,CAAC;IAEF,IAAI,UAAU,EAAE;QACZ,QACIA,oDACQ,SAAS,EACT,mBAAmB,CAAC,QAAQ,EAAE,UAAU,EAAE,aAAa,EAAE,QAAQ,CAAC,GAErE,aAAa,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAClC,EACN;KACL;IAED,IAAI,EAAE,EAAE;QACJ,OAAO,YAAY,CACf,EAAkB,EAClB,EAAE,GAAG,SAAS,EAAE,EAChB,aAAa,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CACpC,CAAC;KACL;IAED,QACIA,yDAAY,KAAK,IAAE,IAAI,EAAE,WAAW,GAAG,QAAQ,GAAG,QAAQ,KACrD,aAAa,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC7B,EACX;AACN;;;;"}
@@ -1,3 +1,5 @@
1
- import { InputPasswordProps } from '@preply/ds-web-core';
2
- import { FC } from 'react';
3
- export declare const InputPassword: FC<InputPasswordProps>;
1
+ import type { InputImperativeHandle } from '@preply/ds-web-core';
2
+ import React from 'react';
3
+ export declare const InputPassword: React.ForwardRefExoticComponent<Pick<import("@preply/ds-web-core/dist/input/private/types").InputTypePasswordProps, "aria-describedby" | "aria-disabled" | "aria-invalid" | "aria-required" | "autoComplete" | "placeholder" | "maxLength" | "id" | "name" | "value" | "defaultValue" | "onChange" | "onFocus" | "onBlur" | "onClick" | "onKeyDown" | "onKeyUp" | "required" | "disabled" | "hasError" | "dataset"> & {
4
+ onValueChange?: import("@preply/ds-web-core").ValueChangeEventHandler<string> | undefined;
5
+ } & React.RefAttributes<InputImperativeHandle>>;
@@ -1,16 +1,17 @@
1
1
  import { useStyleExtract, moduleClassNames } from '@preply/ds-web-core';
2
- import React__default from 'react';
2
+ import React__default, { forwardRef } from 'react';
3
3
  import { InputBase } from './InputBase.js';
4
4
  import { useChangeHandler } from './hooks/useChangeHandler.js';
5
5
  import styles from './style/index.module.less.js';
6
6
 
7
7
  const INPUT_PASSWORD = 'InputPassword';
8
- const InputPassword = ({ onChange, onValueChange, ...props }) => {
8
+ const InputPasswordBase = ({ onChange, onValueChange, ...props }, ref) => {
9
9
  useStyleExtract(styles);
10
10
  const localClasses = moduleClassNames(styles, INPUT_PASSWORD);
11
11
  const onChangeHandler = useChangeHandler(ev => ev.target.value, onChange, onValueChange);
12
- return (React__default.createElement(InputBase, Object.assign({}, props, { type: "password", className: localClasses.join(' '), onChange: onChangeHandler })));
13
- };
12
+ return (React__default.createElement(InputBase, Object.assign({}, props, { ref: ref, type: "password", className: localClasses.join(' '), onChange: onChangeHandler })));
13
+ };
14
+ const InputPassword = forwardRef(InputPasswordBase);
14
15
 
15
16
  export { InputPassword };
16
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5wdXRQYXNzd29yZC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvcHJpdmF0ZS9JbnB1dC9JbnB1dFBhc3N3b3JkLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnB1dFBhc3N3b3JkUHJvcHMsIG1vZHVsZUNsYXNzTmFtZXMsIHVzZVN0eWxlRXh0cmFjdCB9IGZyb20gJ0BwcmVwbHkvZHMtd2ViLWNvcmUnO1xuaW1wb3J0IFJlYWN0LCB7IEZDIH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBJbnB1dEJhc2UgfSBmcm9tICcuL0lucHV0QmFzZSc7XG5pbXBvcnQgeyB1c2VDaGFuZ2VIYW5kbGVyIH0gZnJvbSAnLi9ob29rcy91c2VDaGFuZ2VIYW5kbGVyJztcbmltcG9ydCBzdHlsZXMgZnJvbSAnLi9zdHlsZS9pbmRleC5tb2R1bGUubGVzcyc7XG5cbmNvbnN0IElOUFVUX1BBU1NXT1JEID0gJ0lucHV0UGFzc3dvcmQnO1xuXG5leHBvcnQgY29uc3QgSW5wdXRQYXNzd29yZDogRkM8SW5wdXRQYXNzd29yZFByb3BzPiA9ICh7IG9uQ2hhbmdlLCBvblZhbHVlQ2hhbmdlLCAuLi5wcm9wcyB9KSA9PiB7XG4gICAgdXNlU3R5bGVFeHRyYWN0KHN0eWxlcyk7XG5cbiAgICBjb25zdCBsb2NhbENsYXNzZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgSU5QVVRfUEFTU1dPUkQpO1xuXG4gICAgY29uc3Qgb25DaGFuZ2VIYW5kbGVyID0gdXNlQ2hhbmdlSGFuZGxlcihldiA9PiBldi50YXJnZXQudmFsdWUsIG9uQ2hhbmdlLCBvblZhbHVlQ2hhbmdlKTtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxJbnB1dEJhc2VcbiAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAgIHR5cGU9XCJwYXNzd29yZFwiXG4gICAgICAgICAgICBjbGFzc05hbWU9e2xvY2FsQ2xhc3Nlcy5qb2luKCcgJyl9XG4gICAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2VIYW5kbGVyfVxuICAgICAgICAvPlxuICAgICk7XG59O1xuIl0sIm5hbWVzIjpbIlJlYWN0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFPQSxNQUFNLGNBQWMsR0FBRyxlQUFlLENBQUM7TUFFMUIsYUFBYSxHQUEyQixDQUFDLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxHQUFHLEtBQUssRUFBRTtJQUN2RixlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFeEIsTUFBTSxZQUFZLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBRTlELE1BQU0sZUFBZSxHQUFHLGdCQUFnQixDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxRQUFRLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFFekYsUUFDSUEsNkJBQUMsU0FBUyxvQkFDRixLQUFLLElBQ1QsSUFBSSxFQUFDLFVBQVUsRUFDZixTQUFTLEVBQUUsWUFBWSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFDakMsUUFBUSxFQUFFLGVBQWUsSUFDM0IsRUFDSjtBQUNOOzs7OyJ9
17
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5wdXRQYXNzd29yZC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvcHJpdmF0ZS9JbnB1dC9JbnB1dFBhc3N3b3JkLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IElucHV0SW1wZXJhdGl2ZUhhbmRsZSwgSW5wdXRQYXNzd29yZFByb3BzIH0gZnJvbSAnQHByZXBseS9kcy13ZWItY29yZSc7XG5pbXBvcnQgeyBtb2R1bGVDbGFzc05hbWVzLCB1c2VTdHlsZUV4dHJhY3QgfSBmcm9tICdAcHJlcGx5L2RzLXdlYi1jb3JlJztcbmltcG9ydCBSZWFjdCwgeyBGQywgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgSW5wdXRCYXNlIH0gZnJvbSAnLi9JbnB1dEJhc2UnO1xuaW1wb3J0IHsgdXNlQ2hhbmdlSGFuZGxlciB9IGZyb20gJy4vaG9va3MvdXNlQ2hhbmdlSGFuZGxlcic7XG5pbXBvcnQgc3R5bGVzIGZyb20gJy4vc3R5bGUvaW5kZXgubW9kdWxlLmxlc3MnO1xuXG5jb25zdCBJTlBVVF9QQVNTV09SRCA9ICdJbnB1dFBhc3N3b3JkJztcblxuY29uc3QgSW5wdXRQYXNzd29yZEJhc2U6IEZDPElucHV0UGFzc3dvcmRQcm9wcz4gPSAoeyBvbkNoYW5nZSwgb25WYWx1ZUNoYW5nZSwgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gICAgdXNlU3R5bGVFeHRyYWN0KHN0eWxlcyk7XG5cbiAgICBjb25zdCBsb2NhbENsYXNzZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgSU5QVVRfUEFTU1dPUkQpO1xuXG4gICAgY29uc3Qgb25DaGFuZ2VIYW5kbGVyID0gdXNlQ2hhbmdlSGFuZGxlcihldiA9PiBldi50YXJnZXQudmFsdWUsIG9uQ2hhbmdlLCBvblZhbHVlQ2hhbmdlKTtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxJbnB1dEJhc2VcbiAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgdHlwZT1cInBhc3N3b3JkXCJcbiAgICAgICAgICAgIGNsYXNzTmFtZT17bG9jYWxDbGFzc2VzLmpvaW4oJyAnKX1cbiAgICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZUhhbmRsZXJ9XG4gICAgICAgIC8+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dFBhc3N3b3JkID0gZm9yd2FyZFJlZjxJbnB1dEltcGVyYXRpdmVIYW5kbGUsIElucHV0UGFzc3dvcmRQcm9wcz4oXG4gICAgSW5wdXRQYXNzd29yZEJhc2UsXG4pO1xuIl0sIm5hbWVzIjpbIlJlYWN0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFRQSxNQUFNLGNBQWMsR0FBRyxlQUFlLENBQUM7QUFFdkMsTUFBTSxpQkFBaUIsR0FBMkIsQ0FBQyxFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUUsR0FBRyxLQUFLLEVBQUUsRUFBRSxHQUFHO0lBQ3pGLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUV4QixNQUFNLFlBQVksR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDLENBQUM7SUFFOUQsTUFBTSxlQUFlLEdBQUcsZ0JBQWdCLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLFFBQVEsRUFBRSxhQUFhLENBQUMsQ0FBQztJQUV6RixRQUNJQSw2QkFBQyxTQUFTLG9CQUNGLEtBQUssSUFDVCxHQUFHLEVBQUUsR0FBRyxFQUNSLElBQUksRUFBQyxVQUFVLEVBQ2YsU0FBUyxFQUFFLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQ2pDLFFBQVEsRUFBRSxlQUFlLElBQzNCLEVBQ0o7QUFDTixDQUFDLENBQUM7TUFFVyxhQUFhLEdBQUcsVUFBVSxDQUNuQyxpQkFBaUI7Ozs7In0=
@@ -5,13 +5,13 @@ import { useChangeHandler } from './hooks/useChangeHandler.js';
5
5
  import styles from './style/index.module.less.js';
6
6
 
7
7
  const INPUT_TEXT = 'InputText';
8
- const InputTextBase = ({ onChange, onValueChange, ...props }, ref) => {
8
+ const InputTextLocal = ({ onChange, onValueChange, ...props }, ref) => {
9
9
  useStyleExtract(styles);
10
10
  const localClasses = moduleClassNames(styles, INPUT_TEXT);
11
11
  const onChangeHandler = useChangeHandler(ev => ev.target.value, onChange, onValueChange);
12
12
  return (React__default.createElement(InputBase, Object.assign({}, props, { ref: ref, className: localClasses.join(' '), onChange: onChangeHandler })));
13
13
  };
14
- const InputText = forwardRef(InputTextBase);
14
+ const InputText = forwardRef(InputTextLocal);
15
15
 
16
16
  export { InputText };
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5wdXRUZXh0LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9wcml2YXRlL0lucHV0L0lucHV0VGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBJbnB1dEJhc2VQcm9wcywgSW5wdXRJbXBlcmF0aXZlSGFuZGxlLCBJbnB1dFRleHRQcm9wcyB9IGZyb20gJ0BwcmVwbHkvZHMtd2ViLWNvcmUnO1xuaW1wb3J0IHsgbW9kdWxlQ2xhc3NOYW1lcywgdXNlU3R5bGVFeHRyYWN0IH0gZnJvbSAnQHByZXBseS9kcy13ZWItY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgRkMsIGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB7IElucHV0QmFzZSB9IGZyb20gJy4vSW5wdXRCYXNlJztcbmltcG9ydCB7IHVzZUNoYW5nZUhhbmRsZXIgfSBmcm9tICcuL2hvb2tzL3VzZUNoYW5nZUhhbmRsZXInO1xuaW1wb3J0IHN0eWxlcyBmcm9tICcuL3N0eWxlL2luZGV4Lm1vZHVsZS5sZXNzJztcblxuY29uc3QgSU5QVVRfVEVYVCA9ICdJbnB1dFRleHQnO1xuXG5jb25zdCBJbnB1dFRleHRCYXNlOiBGQzxJbnB1dFRleHRQcm9wcz4gPSAoeyBvbkNoYW5nZSwgb25WYWx1ZUNoYW5nZSwgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gICAgdXNlU3R5bGVFeHRyYWN0KHN0eWxlcyk7XG5cbiAgICBjb25zdCBsb2NhbENsYXNzZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgSU5QVVRfVEVYVCk7XG5cbiAgICBjb25zdCBvbkNoYW5nZUhhbmRsZXIgPSB1c2VDaGFuZ2VIYW5kbGVyKGV2ID0+IGV2LnRhcmdldC52YWx1ZSwgb25DaGFuZ2UsIG9uVmFsdWVDaGFuZ2UpO1xuXG4gICAgcmV0dXJuIChcbiAgICAgICAgPElucHV0QmFzZVxuICAgICAgICAgICAgey4uLihwcm9wcyBhcyBJbnB1dEJhc2VQcm9wcyl9XG4gICAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICAgIGNsYXNzTmFtZT17bG9jYWxDbGFzc2VzLmpvaW4oJyAnKX1cbiAgICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZUhhbmRsZXJ9XG4gICAgICAgIC8+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dFRleHQgPSBmb3J3YXJkUmVmPElucHV0SW1wZXJhdGl2ZUhhbmRsZSwgSW5wdXRUZXh0UHJvcHM+KElucHV0VGV4dEJhc2UpO1xuIl0sIm5hbWVzIjpbIlJlYWN0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFRQSxNQUFNLFVBQVUsR0FBRyxXQUFXLENBQUM7QUFFL0IsTUFBTSxhQUFhLEdBQXVCLENBQUMsRUFBRSxRQUFRLEVBQUUsYUFBYSxFQUFFLEdBQUcsS0FBSyxFQUFFLEVBQUUsR0FBRztJQUNqRixlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFeEIsTUFBTSxZQUFZLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBRTFELE1BQU0sZUFBZSxHQUFHLGdCQUFnQixDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxRQUFRLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFFekYsUUFDSUEsNkJBQUMsU0FBUyxvQkFDRCxLQUF3QixJQUM3QixHQUFHLEVBQUUsR0FBRyxFQUNSLFNBQVMsRUFBRSxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUNqQyxRQUFRLEVBQUUsZUFBZSxJQUMzQixFQUNKO0FBQ04sQ0FBQyxDQUFDO01BRVcsU0FBUyxHQUFHLFVBQVUsQ0FBd0MsYUFBYTs7OzsifQ==
17
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5wdXRUZXh0LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9wcml2YXRlL0lucHV0L0lucHV0VGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBJbnB1dEJhc2VQcm9wcywgSW5wdXRJbXBlcmF0aXZlSGFuZGxlLCBJbnB1dFRleHRQcm9wcyB9IGZyb20gJ0BwcmVwbHkvZHMtd2ViLWNvcmUnO1xuaW1wb3J0IHsgbW9kdWxlQ2xhc3NOYW1lcywgdXNlU3R5bGVFeHRyYWN0IH0gZnJvbSAnQHByZXBseS9kcy13ZWItY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgRkMsIGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB7IElucHV0QmFzZSB9IGZyb20gJy4vSW5wdXRCYXNlJztcbmltcG9ydCB7IHVzZUNoYW5nZUhhbmRsZXIgfSBmcm9tICcuL2hvb2tzL3VzZUNoYW5nZUhhbmRsZXInO1xuaW1wb3J0IHN0eWxlcyBmcm9tICcuL3N0eWxlL2luZGV4Lm1vZHVsZS5sZXNzJztcblxuY29uc3QgSU5QVVRfVEVYVCA9ICdJbnB1dFRleHQnO1xuXG5jb25zdCBJbnB1dFRleHRMb2NhbDogRkM8SW5wdXRUZXh0UHJvcHM+ID0gKHsgb25DaGFuZ2UsIG9uVmFsdWVDaGFuZ2UsIC4uLnByb3BzIH0sIHJlZikgPT4ge1xuICAgIHVzZVN0eWxlRXh0cmFjdChzdHlsZXMpO1xuXG4gICAgY29uc3QgbG9jYWxDbGFzc2VzID0gbW9kdWxlQ2xhc3NOYW1lcyhzdHlsZXMsIElOUFVUX1RFWFQpO1xuXG4gICAgY29uc3Qgb25DaGFuZ2VIYW5kbGVyID0gdXNlQ2hhbmdlSGFuZGxlcihldiA9PiBldi50YXJnZXQudmFsdWUsIG9uQ2hhbmdlLCBvblZhbHVlQ2hhbmdlKTtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxJbnB1dEJhc2VcbiAgICAgICAgICAgIHsuLi4ocHJvcHMgYXMgSW5wdXRCYXNlUHJvcHMpfVxuICAgICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgICBjbGFzc05hbWU9e2xvY2FsQ2xhc3Nlcy5qb2luKCcgJyl9XG4gICAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2VIYW5kbGVyfVxuICAgICAgICAvPlxuICAgICk7XG59O1xuXG5leHBvcnQgY29uc3QgSW5wdXRUZXh0ID0gZm9yd2FyZFJlZjxJbnB1dEltcGVyYXRpdmVIYW5kbGUsIElucHV0VGV4dFByb3BzPihJbnB1dFRleHRMb2NhbCk7XG4iXSwibmFtZXMiOlsiUmVhY3QiXSwibWFwcGluZ3MiOiI7Ozs7OztBQVFBLE1BQU0sVUFBVSxHQUFHLFdBQVcsQ0FBQztBQUUvQixNQUFNLGNBQWMsR0FBdUIsQ0FBQyxFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUUsR0FBRyxLQUFLLEVBQUUsRUFBRSxHQUFHO0lBQ2xGLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUV4QixNQUFNLFlBQVksR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFFMUQsTUFBTSxlQUFlLEdBQUcsZ0JBQWdCLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLFFBQVEsRUFBRSxhQUFhLENBQUMsQ0FBQztJQUV6RixRQUNJQSw2QkFBQyxTQUFTLG9CQUNELEtBQXdCLElBQzdCLEdBQUcsRUFBRSxHQUFHLEVBQ1IsU0FBUyxFQUFFLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQ2pDLFFBQVEsRUFBRSxlQUFlLElBQzNCLEVBQ0o7QUFDTixDQUFDLENBQUM7TUFFVyxTQUFTLEdBQUcsVUFBVSxDQUF3QyxjQUFjOzs7OyJ9
package/dist/index.js CHANGED
@@ -2,6 +2,7 @@ export { Avatar } from './components/Avatar/Avatar.js';
2
2
  export { AvatarWithStatus } from './components/AvatarWithStatus/AvatarWithStatus.js';
3
3
  export { Box } from './components/Box/Box.js';
4
4
  export { Button } from './components/Button/Button.js';
5
+ export { Badge } from './components/Badge/Badge.js';
5
6
  export { FieldAdditionalText } from './components/FieldAdditionalText/FieldAdditionalText.js';
6
7
  export { FieldButton } from './components/FieldButton/FieldButton.js';
7
8
  export { FieldLayout } from './components/FieldLayout/FieldLayout.js';
@@ -21,6 +22,7 @@ export { PanelFooter } from './components/Panel/private/PanelFooter.js';
21
22
  export { PreplyLogo } from './components/PreplyLogo/PreplyLogo.js';
22
23
  export { Text } from './components/Text/Text.js';
23
24
  export { TextField } from './components/TextField/TextField.js';
25
+ export { PasswordField } from './components/PasswordField/PasswordField.js';
24
26
  export { TextHighlighted } from './components/TextHighlighted/TextHighlighted.js';
25
27
  export { TextInline } from './components/TextInline/TextInline.js';
26
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7In0=
28
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@preply/ds-web-lib",
3
- "version": "0.49.0",
3
+ "version": "0.51.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -19,25 +19,25 @@
19
19
  "dev": "run build:rollup -w"
20
20
  },
21
21
  "dependencies": {
22
- "@preply/ds-core": "0.49.0",
23
- "@preply/ds-media-icons": "0.49.0",
24
- "@preply/ds-web-core": "0.49.0",
25
- "@preply/ds-web-root": "0.49.0"
22
+ "@preply/ds-core": "0.51.0",
23
+ "@preply/ds-media-icons": "0.51.0",
24
+ "@preply/ds-web-core": "0.51.0",
25
+ "@preply/ds-web-root": "0.51.0"
26
26
  },
27
27
  "peerDependencies": {
28
- "@preply/ds-core": "0.49.0",
29
- "@preply/ds-media-icons": "0.49.0",
30
- "@preply/ds-web-core": "0.49.0",
31
- "@preply/ds-web-root": "0.49.0",
28
+ "@preply/ds-core": "0.51.0",
29
+ "@preply/ds-media-icons": "0.51.0",
30
+ "@preply/ds-web-core": "0.51.0",
31
+ "@preply/ds-web-root": "0.51.0",
32
32
  "react": "^16.8.3",
33
33
  "react-dom": "^16.8.3"
34
34
  },
35
35
  "devDependencies": {
36
- "@preply/ds-docs-toolkit": "0.49.0",
37
- "@preply/ds-theme-base-ui": "0.49.0",
36
+ "@preply/ds-docs-toolkit": "0.51.0",
37
+ "@preply/ds-theme-base-ui": "0.51.0",
38
38
  "@storybook/addon-docs": "6.4.18",
39
39
  "@storybook/react": "6.4.18",
40
40
  "@testing-library/react": "11.2.7"
41
41
  },
42
- "gitHead": "3e8afea186374a22e2491bf687edd78b6ff99e60"
42
+ "gitHead": "04130ea22ee97e884b24d014e1c9d7650744c415"
43
43
  }