@companix/uikit 0.0.36 → 0.0.38

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 (167) hide show
  1. package/dist/Avatar/Avatar.scss +64 -0
  2. package/dist/Avatar/helpers.d.ts +10 -0
  3. package/dist/Avatar/index.d.ts +8 -0
  4. package/dist/Avatar/types.d.ts +2 -0
  5. package/dist/Button/Button.scss +128 -0
  6. package/dist/Button/index.d.ts +21 -0
  7. package/dist/ButtonGroup/ButtonGroup.scss +18 -0
  8. package/dist/ButtonGroup/index.d.ts +6 -0
  9. package/dist/Calendar/Calendar.d.ts +14 -0
  10. package/dist/Calendar/Calendar.scss +125 -0
  11. package/dist/Calendar/CalendarHeader.d.ts +10 -0
  12. package/dist/Checkbox/Checkbox.scss +115 -0
  13. package/dist/Checkbox/index.d.ts +10 -0
  14. package/dist/Countdown/index.d.ts +6 -0
  15. package/dist/DateInput/DateInput.scss +11 -0
  16. package/dist/DateInput/index.d.ts +13 -0
  17. package/dist/DatePicker/index.d.ts +9 -0
  18. package/dist/Dialog/Dialog.scss +25 -0
  19. package/dist/Dialog/Popup.scss +55 -0
  20. package/dist/Dialog/index.d.ts +16 -0
  21. package/dist/DialogAlert/Alert.d.ts +19 -0
  22. package/dist/DialogAlert/Alert.scss +52 -0
  23. package/dist/DialogAlert/Viewport.d.ts +8 -0
  24. package/dist/DialogAlert/index.d.ts +11 -0
  25. package/dist/Drawer/Drawer.scss +112 -0
  26. package/dist/Drawer/index.d.ts +13 -0
  27. package/dist/File/index.d.ts +10 -0
  28. package/dist/FormGroup/FormGroup.scss +32 -0
  29. package/dist/FormGroup/index.d.ts +9 -0
  30. package/dist/Icon/icon.scss +18 -0
  31. package/dist/Icon/index.d.ts +7 -0
  32. package/dist/Input/Form.scss +67 -0
  33. package/dist/Input/InlineInput.d.ts +0 -0
  34. package/dist/Input/Input.d.ts +14 -0
  35. package/dist/Input/Input.scss +47 -0
  36. package/dist/Input/InputContainer.d.ts +11 -0
  37. package/dist/Input/InputElement.d.ts +9 -0
  38. package/dist/LoadingButton/index.d.ts +5 -0
  39. package/dist/NumberInput/index.d.ts +23 -0
  40. package/dist/OptionItem/Option.scss +89 -0
  41. package/dist/OptionItem/OptionItem.d.ts +6 -0
  42. package/dist/OptionItem/OptionsList.d.ts +7 -0
  43. package/dist/Popover/Popover.scss +80 -0
  44. package/dist/Popover/index.d.ts +27 -0
  45. package/dist/Progress/Progress.scss +47 -0
  46. package/dist/Progress/index.d.ts +5 -0
  47. package/dist/Radio/Radio.scss +148 -0
  48. package/dist/Radio/index.d.ts +20 -0
  49. package/dist/Scrollable/ImitateScroll.d.ts +10 -0
  50. package/dist/Scrollable/Scrollable.scss +50 -0
  51. package/dist/Scrollable/index.d.ts +33 -0
  52. package/dist/Segments/Segments.scss +57 -0
  53. package/dist/Segments/index.d.ts +11 -0
  54. package/dist/Select/Select.scss +80 -0
  55. package/dist/Select/SelectInput.d.ts +15 -0
  56. package/dist/Select/SelectOptions.d.ts +12 -0
  57. package/dist/Select/SelectRight.d.ts +8 -0
  58. package/dist/Select/index.d.ts +24 -0
  59. package/dist/SelectTags/SelectTags.scss +67 -0
  60. package/dist/SelectTags/index.d.ts +17 -0
  61. package/dist/Spinner/Spinner.scss +14 -0
  62. package/dist/Spinner/index.d.ts +7 -0
  63. package/dist/Switch/Switch.scss +102 -0
  64. package/dist/Switch/index.d.ts +10 -0
  65. package/dist/Tabs/Tabs.scss +58 -0
  66. package/dist/Tabs/index.d.ts +13 -0
  67. package/dist/TextArea/TextArea.scss +34 -0
  68. package/dist/TextArea/index.d.ts +7 -0
  69. package/dist/ThemeProvider/helpers.d.ts +4 -0
  70. package/dist/ThemeProvider/index.d.ts +12 -0
  71. package/dist/ThemeProvider/script.d.ts +8 -0
  72. package/dist/ThemeProvider/types.d.ts +2 -0
  73. package/dist/TimePicker/index.d.ts +10 -0
  74. package/dist/Toaster/Toast.d.ts +15 -0
  75. package/dist/Toaster/Toaster.scss +155 -0
  76. package/dist/Toaster/Viewport.d.ts +13 -0
  77. package/dist/Toaster/index.d.ts +20 -0
  78. package/dist/Tooltip/Tooltip.scss +28 -0
  79. package/dist/Tooltip/index.d.ts +7 -0
  80. package/dist/__helpers/createDialogRegistry.d.ts +26 -0
  81. package/dist/__helpers/createPopoversRegistry.d.ts +19 -0
  82. package/dist/__hooks/use-frooze-closing.d.ts +5 -0
  83. package/dist/__hooks/use-input-padding.d.ts +5 -0
  84. package/dist/__hooks/use-loading.d.ts +8 -0
  85. package/dist/__hooks/use-local-storage.d.ts +1 -0
  86. package/dist/__hooks/use-popover-position.d.ts +8 -0
  87. package/dist/__hooks/use-previos.d.ts +2 -0
  88. package/dist/__hooks/use-resize.d.ts +3 -0
  89. package/dist/__hooks/use-scrollbox.d.ts +7 -0
  90. package/dist/__hooks/use-update.d.ts +1 -0
  91. package/dist/__hooks/useCalendar.d.ts +17 -0
  92. package/dist/__hooks/useCalendarOptions-copy.d.ts +22 -0
  93. package/dist/__hooks/useCalendarOptions.d.ts +31 -0
  94. package/dist/__libs/calendar.d.ts +25 -0
  95. package/dist/__utils/RemoveListener.d.ts +3 -0
  96. package/dist/__utils/utils.d.ts +39 -0
  97. package/dist/bundle.es.js +88 -0
  98. package/dist/bundle.es10.js +82 -0
  99. package/dist/bundle.es11.js +28 -0
  100. package/dist/bundle.es12.js +77 -0
  101. package/dist/bundle.es13.js +43 -0
  102. package/dist/bundle.es14.js +38 -0
  103. package/dist/bundle.es15.js +58 -0
  104. package/dist/bundle.es16.js +23 -0
  105. package/dist/bundle.es17.js +35 -0
  106. package/dist/bundle.es18.js +27 -0
  107. package/dist/bundle.es19.js +47 -0
  108. package/dist/bundle.es2.js +44 -0
  109. package/dist/bundle.es20.js +25 -0
  110. package/dist/bundle.es21.js +31 -0
  111. package/dist/bundle.es22.js +40 -0
  112. package/dist/bundle.es23.js +18 -0
  113. package/dist/bundle.es24.js +36 -0
  114. package/dist/bundle.es25.js +23 -0
  115. package/dist/bundle.es26.js +44 -0
  116. package/dist/bundle.es27.js +117 -0
  117. package/dist/bundle.es28.js +123 -0
  118. package/dist/bundle.es29.js +76 -0
  119. package/dist/bundle.es3.js +4 -0
  120. package/dist/bundle.es30.js +35 -0
  121. package/dist/bundle.es31.js +14 -0
  122. package/dist/bundle.es32.js +88 -0
  123. package/dist/bundle.es33.js +22 -0
  124. package/dist/bundle.es34.js +9 -0
  125. package/dist/bundle.es35.js +37 -0
  126. package/dist/bundle.es36.js +24 -0
  127. package/dist/bundle.es37.js +13 -0
  128. package/dist/bundle.es38.js +27 -0
  129. package/dist/bundle.es39.js +41 -0
  130. package/dist/bundle.es4.js +47 -0
  131. package/dist/bundle.es40.js +53 -0
  132. package/dist/bundle.es41.js +45 -0
  133. package/dist/bundle.es42.js +11 -0
  134. package/dist/bundle.es43.js +27 -0
  135. package/dist/bundle.es44.js +26 -0
  136. package/dist/bundle.es45.js +89 -0
  137. package/dist/bundle.es46.js +20 -0
  138. package/dist/bundle.es47.js +22 -0
  139. package/dist/bundle.es48.js +26 -0
  140. package/dist/bundle.es49.js +41 -0
  141. package/dist/bundle.es5.js +10 -0
  142. package/dist/bundle.es50.js +7 -0
  143. package/dist/bundle.es51.js +16 -0
  144. package/dist/bundle.es52.js +16 -0
  145. package/dist/bundle.es53.js +72 -0
  146. package/dist/bundle.es54.js +70 -0
  147. package/dist/bundle.es55.js +72 -0
  148. package/dist/bundle.es56.js +13 -0
  149. package/dist/bundle.es57.js +45 -0
  150. package/dist/bundle.es58.js +17 -0
  151. package/dist/bundle.es59.js +34 -0
  152. package/dist/bundle.es6.js +13 -0
  153. package/dist/bundle.es60.js +72 -0
  154. package/dist/bundle.es61.js +16 -0
  155. package/dist/bundle.es62.js +77 -0
  156. package/dist/bundle.es63.js +51 -0
  157. package/dist/bundle.es64.js +16 -0
  158. package/dist/bundle.es7.js +87 -0
  159. package/dist/bundle.es8.js +87 -0
  160. package/dist/bundle.es9.js +24 -0
  161. package/dist/css-properties.scss +120 -0
  162. package/dist/index.d.ts +77 -0
  163. package/dist/index.scss +28 -0
  164. package/dist/mixins.scss +102 -0
  165. package/dist/theme.scss +101 -0
  166. package/dist/types.d.ts +17 -0
  167. package/package.json +6 -6
@@ -0,0 +1,64 @@
1
+ @use '../mixins.scss';
2
+
3
+ .avatar {
4
+ position: relative;
5
+ box-sizing: border-box;
6
+ display: flex;
7
+ flex-shrink: 0;
8
+ align-items: center;
9
+ justify-content: center;
10
+ background-size: cover;
11
+ isolation: isolate;
12
+
13
+ @include mixins.use-styles(avatar);
14
+
15
+ &-image {
16
+ object-fit: cover;
17
+ display: block;
18
+ width: 100%;
19
+ height: 100%;
20
+ color: transparent;
21
+ text-indent: 10000px;
22
+ border: 0;
23
+ border-radius: inherit;
24
+ }
25
+
26
+ &-icon {
27
+ position: absolute;
28
+ top: auto;
29
+ left: auto;
30
+ }
31
+
32
+ &-initials {
33
+ line-height: 1;
34
+ text-align: center;
35
+ text-transform: uppercase;
36
+
37
+ @include mixins.use-styles(avatar, initials);
38
+ }
39
+
40
+ &-border {
41
+ box-sizing: border-box;
42
+ pointer-events: none;
43
+ border-radius: inherit;
44
+ transform-origin: left top;
45
+
46
+ @include mixins.use-styles(avatar, border);
47
+ }
48
+
49
+ &-content {
50
+ display: inherit;
51
+ align-items: inherit;
52
+ justify-content: inherit;
53
+ border-radius: inherit;
54
+ }
55
+
56
+ &-border,
57
+ &-content {
58
+ position: absolute;
59
+ top: 0;
60
+ left: 0;
61
+ width: 100%;
62
+ height: 100%;
63
+ }
64
+ }
@@ -0,0 +1,10 @@
1
+ export type GetInitialsFontSizeType = (avatarSize: number) => number;
2
+ export declare const getInitialsFontSize: GetInitialsFontSizeType;
3
+ export declare function getFallbackIconSizeByImageBaseSize(imageSize: number): 12 | 16 | 20 | 24 | 28 | 36;
4
+ export declare namespace getFallbackIconSizeByImageBaseSize {
5
+ let MAX_SIZE: 36;
6
+ }
7
+ export declare function getBadgeIconSizeByImageBaseSize(imageSize: number): 12 | 16 | 20 | 24;
8
+ export declare namespace getBadgeIconSizeByImageBaseSize {
9
+ let MAX_SIZE: 24;
10
+ }
@@ -0,0 +1,8 @@
1
+ import { AvatarSize } from './types';
2
+ export interface AvatarProps extends React.ImgHTMLAttributes<HTMLElement> {
3
+ size?: AvatarSize;
4
+ noBorder?: boolean;
5
+ fallbackIcon?: React.ReactElement;
6
+ initials?: string;
7
+ }
8
+ export declare const Avatar: ({ alt, crossOrigin, decoding, loading, referrerPolicy, sizes, size, src, srcSet, useMap, initials, noBorder, fallbackIcon: fallbackIconProp, children }: AvatarProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,2 @@
1
+ export declare const avatarSizes: readonly [16, 20, 24, 28, 32, 36, 40, 44, 48, 56, 64, 72, 80, 88, 96];
2
+ export type AvatarSize = (typeof avatarSizes)[number];
@@ -0,0 +1,128 @@
1
+ @use '../mixins.scss';
2
+
3
+ // scheme: bth-[appearance]-[mode]-[property]--[state]
4
+ //
5
+ // appearance: primary, neutral, positive, negative
6
+ // mode: default, outline, minimal
7
+ // state: enabled, hovered, pressed, disabled, loading
8
+ // property: text, background, shadow, border
9
+
10
+ @mixin use-mode($appearance, $mode) {
11
+ @include mixins.use-styles(button, $appearance, $mode, enabled);
12
+
13
+ &:hover {
14
+ @include mixins.use-styles(button, $appearance, $mode, hovered);
15
+ }
16
+
17
+ &[data-active],
18
+ &:active {
19
+ @include mixins.use-styles(button, $appearance, $mode, pressed);
20
+ }
21
+
22
+ &[data-loading] {
23
+ @include mixins.use-styles(button, $appearance, $mode, loading);
24
+ }
25
+
26
+ &[disabled] {
27
+ cursor: not-allowed;
28
+ @include mixins.use-styles(button, $appearance, $mode, disabled);
29
+ }
30
+ }
31
+
32
+ @mixin use-appearance($appearance) {
33
+ &[data-appearance='#{$appearance}'] {
34
+ &[data-mode='default'] {
35
+ @include use-mode($appearance, default);
36
+ }
37
+
38
+ &[data-mode='outline'] {
39
+ @include use-mode($appearance, outline);
40
+ }
41
+
42
+ &[data-mode='minimal'] {
43
+ @include use-mode($appearance, minimal);
44
+ }
45
+ }
46
+ }
47
+
48
+ .button {
49
+ overflow: visible;
50
+ box-sizing: border-box;
51
+ -moz-user-focus: ignore;
52
+ -webkit-user-select: none;
53
+ -moz-user-select: none;
54
+ -ms-user-select: none;
55
+ user-select: none;
56
+ text-decoration: none;
57
+ outline: none;
58
+ -webkit-tap-highlight-color: transparent;
59
+ -ms-touch-action: manipulation;
60
+ touch-action: manipulation;
61
+ cursor: pointer;
62
+ display: flex;
63
+ align-items: center;
64
+
65
+ @include mixins.use-styles(button);
66
+ @include mixins.items-spacing(8px);
67
+
68
+ // fill
69
+
70
+ &[data-fill] {
71
+ width: 100%;
72
+ }
73
+
74
+ // align
75
+
76
+ &[data-align='center'] {
77
+ justify-content: center;
78
+
79
+ & > .button-text {
80
+ text-align: center;
81
+ }
82
+ }
83
+
84
+ &[data-align='left'] {
85
+ justify-content: left;
86
+
87
+ & > .button-text {
88
+ flex: 1 1 auto;
89
+ text-align: left;
90
+ }
91
+ }
92
+
93
+ &[data-align='right'] {
94
+ justify-content: right;
95
+
96
+ & > .button-text {
97
+ flex: 1 1 auto;
98
+ text-align: right;
99
+ }
100
+ }
101
+
102
+ // sizes
103
+
104
+ &[data-size='sm'] {
105
+ @include mixins.use-styles(button, size, sm);
106
+ }
107
+
108
+ &[data-size='md'] {
109
+ @include mixins.use-styles(button, size, md);
110
+ }
111
+
112
+ &[data-size='lg'] {
113
+ @include mixins.use-styles(button, size, lg);
114
+ }
115
+
116
+ // text
117
+
118
+ &-text {
119
+ @include mixins.truncate-text();
120
+ }
121
+
122
+ // appearance
123
+
124
+ @include use-appearance(primary);
125
+ @include use-appearance(neutral);
126
+ @include use-appearance(negative);
127
+ @include use-appearance(positive);
128
+ }
@@ -0,0 +1,21 @@
1
+ export type Appearance = 'primary' | 'neutral' | 'positive' | 'negative';
2
+ export type Mode = 'default' | 'outline' | 'minimal';
3
+ export type Size = 'sm' | 'md' | 'lg';
4
+ export interface InternButtonProps {
5
+ icon?: React.ReactNode;
6
+ iconRight?: React.ReactNode;
7
+ appearance?: Appearance;
8
+ mode?: Mode;
9
+ size?: Size;
10
+ fill?: boolean;
11
+ align?: 'left' | 'center' | 'right';
12
+ loading?: boolean;
13
+ active?: boolean;
14
+ text?: React.ReactNode;
15
+ children?: React.ReactNode;
16
+ className?: string;
17
+ Component?: React.ElementType;
18
+ }
19
+ export interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement>, InternButtonProps {
20
+ }
21
+ export declare const Button: import('react').ForwardRefExoticComponent<ButtonProps & import('react').RefAttributes<HTMLButtonElement>>;
@@ -0,0 +1,18 @@
1
+ .button-group {
2
+ display: flex;
3
+
4
+ &[data-fill] {
5
+ width: 100%;
6
+ }
7
+
8
+ & > .button:not(:first-child) {
9
+ border-bottom-left-radius: 0;
10
+ border-top-left-radius: 0;
11
+ }
12
+
13
+ & > .button:not(:last-child) {
14
+ border-bottom-right-radius: 0;
15
+ border-top-right-radius: 0;
16
+ margin-right: -1px;
17
+ }
18
+ }
@@ -0,0 +1,6 @@
1
+ export interface ButtonGroupProps {
2
+ children: React.ReactNode;
3
+ className?: string;
4
+ fill?: boolean;
5
+ }
6
+ export declare const ButtonGroup: import('react').ForwardRefExoticComponent<ButtonGroupProps & import('react').RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,14 @@
1
+ export interface CalendarProps {
2
+ value?: Date | null;
3
+ disablePast?: boolean;
4
+ disableFuture?: boolean;
5
+ enableTime?: boolean;
6
+ disablePickers?: boolean;
7
+ showNeighboringMonth?: boolean;
8
+ onChange?: (value: Date) => void;
9
+ shouldDisableDate?: (value: Date) => boolean;
10
+ viewDate?: Date;
11
+ minDateTime?: Date;
12
+ maxDateTime?: Date;
13
+ }
14
+ export declare const Calendar: ({ disablePickers, value, onChange, ...props }: CalendarProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,125 @@
1
+ @use '../mixins.scss';
2
+
3
+ .calendar {
4
+ @include mixins.use-styles(calendar);
5
+
6
+ &-header {
7
+ position: relative;
8
+ display: flex;
9
+ align-items: center;
10
+ justify-content: center;
11
+
12
+ @include mixins.use-styles(calendar, header);
13
+ }
14
+
15
+ &-navigation {
16
+ display: flex;
17
+ align-items: center;
18
+ justify-content: center;
19
+ position: absolute;
20
+ outline: none;
21
+ cursor: pointer;
22
+
23
+ @include mixins.use-styles(calendar, navigation);
24
+ @include mixins.use-size(calendar, navigation, size);
25
+
26
+ &[data-side='left'] {
27
+ left: 0;
28
+ }
29
+
30
+ &[data-side='right'] {
31
+ right: 0;
32
+ }
33
+
34
+ &:hover {
35
+ @include mixins.use-styles(calendar, navigation, hover);
36
+ }
37
+
38
+ &:active {
39
+ @include mixins.use-styles(calendar, navigation, active);
40
+ }
41
+
42
+ svg {
43
+ @include mixins.use-size(calendar, navigation, icon, size);
44
+ }
45
+ }
46
+
47
+ &-pickers {
48
+ display: flex;
49
+ align-items: center;
50
+ gap: 4px;
51
+ }
52
+
53
+ &-names {
54
+ display: flex;
55
+ }
56
+
57
+ &-name {
58
+ display: flex;
59
+ align-items: center;
60
+ justify-content: center;
61
+
62
+ @include mixins.use-styles(calendar, name);
63
+ }
64
+
65
+ &-days {
66
+ display: grid;
67
+ grid-template-columns: repeat(7, 1fr);
68
+ }
69
+
70
+ &-day {
71
+ display: flex;
72
+ align-items: center;
73
+ justify-content: center;
74
+ position: relative;
75
+
76
+ @include mixins.use-styles(calendar, day);
77
+
78
+ &:not([data-disabled]) {
79
+ cursor: pointer;
80
+
81
+ &:hover {
82
+ @include mixins.use-styles(calendar, day, hover);
83
+ }
84
+
85
+ &[data-active] {
86
+ @include mixins.use-styles(calendar, day, active);
87
+ }
88
+
89
+ &[data-selected] {
90
+ @include mixins.use-styles(calendar, day, selected);
91
+
92
+ .calendar-day-number::after {
93
+ background-color: #ffffff;
94
+ }
95
+ }
96
+
97
+ &[data-void] {
98
+ background-color: unset;
99
+ cursor: default;
100
+ }
101
+ }
102
+
103
+ &[data-disabled] {
104
+ @include mixins.use-styles(calendar, day, disabled);
105
+ }
106
+
107
+ &[data-today] {
108
+ .calendar-day-number {
109
+ position: relative;
110
+
111
+ &::after {
112
+ position: absolute;
113
+ height: 2px;
114
+ border-radius: 10px;
115
+ content: '';
116
+ display: block;
117
+ width: 100%;
118
+ bottom: 0px;
119
+ right: 0;
120
+ background-color: #529ef4;
121
+ }
122
+ }
123
+ }
124
+ }
125
+ }
@@ -0,0 +1,10 @@
1
+ export interface CalendarHeaderProps {
2
+ viewDate: Date;
3
+ disablePickers?: boolean;
4
+ isMonthDisabled?: (monthNumber: number, year?: number) => boolean;
5
+ isYearDisabled?: (yearNumber: number) => boolean;
6
+ onChange: (viewDate: Date) => void;
7
+ onNextMonth?: () => void;
8
+ onPrevMonth?: () => void;
9
+ }
10
+ export declare const CalendarHeader: ({ viewDate, onChange, isMonthDisabled, isYearDisabled, onNextMonth, onPrevMonth }: CalendarHeaderProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,115 @@
1
+ @use '../mixins.scss';
2
+
3
+ .checkbox {
4
+ display: inline-table;
5
+ user-select: none;
6
+ touch-action: manipulation;
7
+ max-width: max-content;
8
+
9
+ @include mixins.use-styles(checkbox);
10
+
11
+ &:not([data-disabled]):not([data-required]):hover {
12
+ .checkbox-box[data-state='unchecked'] {
13
+ @include mixins.use-styles(checkbox, box, hover);
14
+ }
15
+ }
16
+
17
+ &:not([data-disabled]):not([data-required]):active {
18
+ .checkbox-box[data-state='unchecked'] {
19
+ @include mixins.use-styles(checkbox, box, active);
20
+ }
21
+ }
22
+
23
+ &:not([data-disabled]) {
24
+ .checkbox-box[data-state='checked'] {
25
+ @include mixins.use-styles(checkbox, box, checked);
26
+ }
27
+ }
28
+
29
+ &[data-disabled] {
30
+ @include mixins.use-styles(checkbox, disabled);
31
+ }
32
+
33
+ &[data-required] {
34
+ @include mixins.use-styles(checkbox, required);
35
+
36
+ .checkbox-box::before {
37
+ content: '';
38
+ position: absolute;
39
+ width: 100%;
40
+ height: 100%;
41
+ left: 0;
42
+
43
+ @include mixins.use-styles(checkbox, required, box);
44
+
45
+ border-radius: mixins.get-var-name(checkbox, box, border-radius);
46
+ }
47
+ }
48
+
49
+ &[data-size='sm'] {
50
+ @include mixins.use-styles(checkbox, size, sm);
51
+
52
+ .checkbox-box {
53
+ @include mixins.use-size(checkbox, size, sm, box);
54
+ }
55
+ }
56
+
57
+ &[data-size='md'] {
58
+ @include mixins.use-styles(checkbox, size, md);
59
+
60
+ .checkbox-box {
61
+ @include mixins.use-size(checkbox, size, md, box);
62
+ }
63
+ }
64
+
65
+ &-box {
66
+ cursor: pointer;
67
+ outline: none;
68
+ transition: background-color 0.1s linear;
69
+ display: inline-block;
70
+ position: relative;
71
+ z-index: 0;
72
+
73
+ @include mixins.use-styles(checkbox, box);
74
+
75
+ &[data-disabled] {
76
+ cursor: default;
77
+ }
78
+
79
+ &:after {
80
+ visibility: hidden;
81
+ content: '\00A0';
82
+ }
83
+ }
84
+
85
+ &-label {
86
+ cursor: pointer;
87
+ display: table-cell;
88
+ word-break: break-word;
89
+
90
+ &[data-disabled] {
91
+ cursor: default;
92
+ }
93
+
94
+ @include mixins.use-styles(checkbox, label);
95
+ }
96
+
97
+ &-icon {
98
+ display: flex;
99
+ align-items: center;
100
+ justify-content: center;
101
+ z-index: 3;
102
+ position: absolute;
103
+ width: 100%;
104
+ height: 100%;
105
+ top: 0;
106
+
107
+ &[data-state='checked'] {
108
+ @include mixins.use-styles(checkbox, icon, in);
109
+ }
110
+
111
+ &[data-state='unchecked'] {
112
+ @include mixins.use-styles(checkbox, icon, out);
113
+ }
114
+ }
115
+ }
@@ -0,0 +1,10 @@
1
+ export interface CheckboxProps {
2
+ checked: boolean;
3
+ onCheckedChange: (checked: boolean) => void;
4
+ size?: 'sm' | 'md';
5
+ label?: React.ReactNode;
6
+ disabled?: boolean;
7
+ required?: boolean;
8
+ }
9
+ declare const Checkbox: ({ checked, required, disabled, onCheckedChange, size, label }: CheckboxProps) => import("react/jsx-runtime").JSX.Element;
10
+ export { Checkbox };
@@ -0,0 +1,6 @@
1
+ export interface CountDownProps {
2
+ expiration: number;
3
+ separator?: string;
4
+ onExpired?: VoidFunction;
5
+ }
6
+ export declare const Countdown: ({ expiration, separator, onExpired }: CountDownProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,11 @@
1
+ .data-input {
2
+ display: flex;
3
+ gap: 8px;
4
+ width: 100%;
5
+
6
+ .form {
7
+ input {
8
+ width: 100%;
9
+ }
10
+ }
11
+ }
@@ -0,0 +1,13 @@
1
+ import { DateFormat } from '..';
2
+ export interface DateInputProps {
3
+ min?: DateFormat;
4
+ max?: DateFormat;
5
+ noDaySelect?: boolean;
6
+ noYearSelect?: boolean;
7
+ disabled?: boolean;
8
+ required?: boolean;
9
+ size?: 'sm' | 'md' | 'lg';
10
+ value: DateFormat;
11
+ onChange: (e: DateFormat) => void;
12
+ }
13
+ export declare const DateInput: ({ min, max, disabled, value, noDaySelect, noYearSelect, onChange, required, size }: DateInputProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,9 @@
1
+ import { InputProps } from '../Input/Input';
2
+ import { CalendarProps } from '../Calendar/Calendar';
3
+ export interface DatePickerProps extends Omit<CalendarProps, 'onChange'>, Omit<InputProps, 'value' | 'onChange' | 'rightElement'> {
4
+ onChange?: (value: Date | null) => void;
5
+ clearButton?: boolean;
6
+ clearButtonIcon?: boolean;
7
+ children?: React.ReactNode;
8
+ }
9
+ export declare const DatePicker: (props: DatePickerProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,25 @@
1
+ @use '../mixins.scss';
2
+
3
+ .dialog {
4
+ &-container {
5
+ @include mixins.use-styles(dialog, container);
6
+ }
7
+
8
+ &-overlay {
9
+ @include mixins.use-styles(dialog, overlay);
10
+ }
11
+
12
+ @include mixins.use-styles(dialog);
13
+ }
14
+
15
+ .dialog-container {
16
+ @each $size, $v in (xxs, xs, s, m, l, xl, xxl, full) {
17
+ &[data-size='#{$size}'] {
18
+ @include mixins.use-styles(dialog, size, $size, container);
19
+
20
+ .dialog {
21
+ @include mixins.use-styles(dialog, size, $size);
22
+ }
23
+ }
24
+ }
25
+ }
@@ -0,0 +1,55 @@
1
+ @use '../mixins.scss';
2
+
3
+ .popup {
4
+ display: flex;
5
+ flex-direction: column;
6
+ max-height: 100%;
7
+ z-index: 1000;
8
+ outline: none;
9
+ pointer-events: auto;
10
+ position: relative;
11
+ width: 100%;
12
+
13
+ @include mixins.use-styles(popup);
14
+
15
+ &-overlay {
16
+ inset: 0;
17
+ overflow: auto;
18
+ position: fixed;
19
+ -webkit-user-select: none;
20
+ -moz-user-select: none;
21
+ -ms-user-select: none;
22
+ user-select: none;
23
+ outline: none;
24
+ z-index: 9999;
25
+
26
+ @include mixins.use-styles(popup, overlay);
27
+
28
+ &[data-state='open'] {
29
+ @include mixins.use-styles(popup, overlay, in);
30
+ }
31
+
32
+ &[data-state='closed'] {
33
+ @include mixins.use-styles(popup, overlay, out);
34
+ }
35
+ }
36
+
37
+ &-container {
38
+ position: fixed;
39
+ inset: 0;
40
+ z-index: 9999;
41
+ display: flex;
42
+ align-items: center;
43
+ justify-content: center;
44
+ pointer-events: none !important;
45
+ outline: none;
46
+
47
+ &[data-state='open'] {
48
+ @include mixins.use-styles(popup, in);
49
+ }
50
+
51
+ &[data-state='closed'] {
52
+ @include mixins.use-styles(popup, out);
53
+ }
54
+ }
55
+ }
@@ -0,0 +1,16 @@
1
+ import * as DialogPrimitive from '@radix-ui/react-dialog';
2
+ export type DialogSize = 'xxs' | 'xs' | 's' | 'm' | 'l' | 'xl' | 'xxl' | 'full';
3
+ export interface DialogProps {
4
+ open: boolean;
5
+ onOpenChange: (value: boolean) => void;
6
+ defaultOpen?: boolean;
7
+ children: React.ReactNode;
8
+ size?: DialogSize;
9
+ className?: string;
10
+ disableEsc?: boolean;
11
+ onClosed?: () => void;
12
+ }
13
+ export declare const Dialog: {
14
+ (props: DialogProps): import("react/jsx-runtime").JSX.Element;
15
+ Close: import('react').ForwardRefExoticComponent<DialogPrimitive.DialogCloseProps & import('react').RefAttributes<HTMLButtonElement>>;
16
+ };