@shohojdhara/atomix 0.5.1 → 0.5.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/atomix.config.ts +45 -33
- package/build-tools/webpack-loader.js +5 -4
- package/dist/atomix.css +138 -17
- package/dist/atomix.css.map +1 -1
- package/dist/atomix.min.css +1 -1
- package/dist/atomix.min.css.map +1 -1
- package/dist/build-tools/webpack-loader.js +5 -4
- package/dist/charts.d.ts +23 -23
- package/dist/charts.js +40 -37
- package/dist/charts.js.map +1 -1
- package/dist/config.d.ts +699 -0
- package/dist/config.js +17 -0
- package/dist/config.js.map +1 -0
- package/dist/core.d.ts +2 -2
- package/dist/core.js +111 -50
- package/dist/core.js.map +1 -1
- package/dist/forms.d.ts +3 -6
- package/dist/forms.js +2 -2
- package/dist/forms.js.map +1 -1
- package/dist/heavy.d.ts +1 -1
- package/dist/heavy.js +173 -111
- package/dist/heavy.js.map +1 -1
- package/dist/index.d.ts +1881 -790
- package/dist/index.esm.js +2713 -816
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +2693 -780
- package/dist/index.js.map +1 -1
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/dist/layout.js +59 -60
- package/dist/layout.js.map +1 -1
- package/dist/theme.d.ts +1390 -276
- package/dist/theme.js +2133 -625
- package/dist/theme.js.map +1 -1
- package/package.json +14 -9
- package/scripts/atomix-cli.js +15 -1
- package/scripts/cli/__tests__/complexity-utils.test.js +24 -0
- package/scripts/cli/__tests__/detector.test.js +50 -0
- package/scripts/cli/__tests__/template-engine.test.js +23 -0
- package/scripts/cli/__tests__/test-setup.js +3 -0
- package/scripts/cli/commands/doctor.js +15 -3
- package/scripts/cli/commands/generate.js +113 -51
- package/scripts/cli/internal/ai-engine.js +30 -10
- package/scripts/cli/internal/complexity-utils.js +60 -0
- package/scripts/cli/internal/component-validator.js +49 -16
- package/scripts/cli/internal/config-loader.js +30 -20
- package/scripts/cli/internal/generator.js +89 -36
- package/scripts/cli/internal/hook-generator.js +5 -2
- package/scripts/cli/internal/itcss-generator.js +16 -12
- package/scripts/cli/templates/next-templates.js +81 -30
- package/scripts/cli/templates/storybook-templates.js +12 -2
- package/scripts/cli/utils/detector.js +45 -7
- package/scripts/cli/utils/diagnostics.js +78 -0
- package/scripts/cli/utils/telemetry.js +13 -0
- package/src/components/Accordion/Accordion.stories.tsx +4 -0
- package/src/components/AtomixGlass/AtomixGlassContainer.tsx +1 -1
- package/src/components/AtomixGlass/__snapshots__/AtomixGlass.test.tsx.snap +219 -0
- package/src/components/AtomixGlass/glass-utils.ts +1 -1
- package/src/components/Button/Button.tsx +114 -57
- package/src/components/Callout/Callout.tsx +4 -4
- package/src/components/Chart/ChartRenderer.tsx +1 -1
- package/src/components/Chart/DonutChart.tsx +11 -8
- package/src/components/EdgePanel/EdgePanel.tsx +119 -115
- package/src/components/Form/Select.tsx +4 -4
- package/src/components/List/List.tsx +4 -4
- package/src/components/Navigation/SideMenu/SideMenu.tsx +6 -6
- package/src/components/PhotoViewer/PhotoViewerImage.tsx +1 -1
- package/src/components/ProductReview/ProductReview.tsx +4 -2
- package/src/components/Rating/Rating.tsx +4 -2
- package/src/components/SectionIntro/SectionIntro.tsx +4 -2
- package/src/components/Steps/Steps.tsx +1 -1
- package/src/components/Tabs/Tabs.tsx +5 -5
- package/src/components/Testimonial/Testimonial.tsx +4 -2
- package/src/components/VideoPlayer/VideoPlayer.tsx +4 -2
- package/src/layouts/CssGrid/CssGrid.stories.tsx +464 -0
- package/src/layouts/CssGrid/CssGrid.tsx +215 -0
- package/src/layouts/CssGrid/index.ts +8 -0
- package/src/layouts/CssGrid/scripts/CssGrid.js +284 -0
- package/src/layouts/CssGrid/scripts/index.js +43 -0
- package/src/layouts/Grid/scripts/Container.js +139 -0
- package/src/layouts/Grid/scripts/Grid.js +184 -0
- package/src/layouts/Grid/scripts/GridCol.js +273 -0
- package/src/layouts/Grid/scripts/Row.js +154 -0
- package/src/layouts/Grid/scripts/index.js +48 -0
- package/src/layouts/MasonryGrid/MasonryGrid.tsx +71 -59
- package/src/lib/composables/atomix-glass/useGlassSize.ts +1 -1
- package/src/lib/composables/useAccordion.ts +5 -5
- package/src/lib/composables/useAtomixGlass.ts +3 -3
- package/src/lib/composables/useBarChart.ts +2 -2
- package/src/lib/composables/useChart.ts +3 -2
- package/src/lib/composables/useChartToolbar.ts +48 -66
- package/src/lib/composables/useDataTable.ts +1 -1
- package/src/lib/composables/useDatePicker.ts +2 -2
- package/src/lib/composables/useEdgePanel.ts +45 -54
- package/src/lib/composables/useHeroBackgroundSlider.ts +5 -5
- package/src/lib/composables/usePhotoViewer.ts +2 -3
- package/src/lib/composables/usePieChart.ts +1 -1
- package/src/lib/composables/usePopover.ts +151 -139
- package/src/lib/composables/useSideMenu.ts +28 -41
- package/src/lib/composables/useSlider.ts +2 -6
- package/src/lib/composables/useTooltip.ts +2 -2
- package/src/lib/config/index.ts +38 -323
- package/src/lib/config/loader.ts +419 -0
- package/src/lib/config/public-api.ts +43 -0
- package/src/lib/config/types.ts +389 -0
- package/src/lib/config/validator.ts +305 -0
- package/src/lib/theme/adapters/index.ts +1 -1
- package/src/lib/theme/adapters/themeAdapter.ts +358 -229
- package/src/lib/theme/components/ThemeToggle.tsx +276 -0
- package/src/lib/theme/config/configLoader.ts +351 -0
- package/src/lib/theme/config/loader.ts +221 -0
- package/src/lib/theme/core/createTheme.ts +126 -50
- package/src/lib/theme/core/createThemeObject.ts +7 -4
- package/src/lib/theme/devtools/Comparator.tsx +1 -1
- package/src/lib/theme/devtools/Inspector.tsx +1 -1
- package/src/lib/theme/devtools/LiveEditor.tsx +1 -1
- package/src/lib/theme/hooks/useThemeSwitcher.ts +164 -0
- package/src/lib/theme/index.ts +322 -38
- package/src/lib/theme/runtime/ThemeProvider.tsx +45 -11
- package/src/lib/theme/runtime/__tests__/ThemeProvider.test.tsx +44 -393
- package/src/lib/theme/runtime/useTheme.ts +1 -0
- package/src/lib/theme/tokens/tokens.ts +101 -1
- package/src/lib/theme/types.ts +91 -0
- package/src/lib/theme/utils/performanceMonitor.ts +315 -0
- package/src/lib/theme/utils/responsive.ts +280 -0
- package/src/lib/theme/utils/themeUtils.ts +531 -117
- package/src/styles/01-settings/_index.scss +1 -0
- package/src/styles/01-settings/_settings.atomix-glass.scss +174 -0
- package/src/styles/01-settings/_settings.masonry-grid.scss +42 -6
- package/src/styles/02-tools/_tools.glass.scss +6 -0
- package/src/styles/05-objects/_objects.masonry-grid.scss +162 -24
- package/src/styles/06-components/_components.atomix-glass.scss +4 -4
- package/src/lib/composables/useBreadcrumb.ts +0 -81
- package/src/lib/composables/useChartInteractions.ts +0 -123
- package/src/lib/composables/useChartPerformance.ts +0 -347
- package/src/lib/composables/useDropdown.ts +0 -338
- package/src/lib/composables/useModal.ts +0 -110
- package/src/lib/hooks/usePerformanceMonitor.ts +0 -148
- package/src/lib/utils/displacement-generator.ts +0 -92
- package/src/lib/utils/memoryMonitor.ts +0 -191
- package/src/styles/01-settings/_settings.testtypecheck.scss +0 -53
- package/src/styles/01-settings/_settings.typedbutton.scss +0 -53
- package/src/styles/06-components/_components.testbutton.scss +0 -212
- package/src/styles/06-components/_components.testtypecheck.scss +0 -212
- package/src/styles/06-components/_components.typedbutton.scss +0 -212
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
// TestTypeCheck Component Styles
|
|
2
|
-
// Generated by Atomix CLI
|
|
3
|
-
// ITCSS Layer: Components
|
|
4
|
-
// =============================================================================
|
|
5
|
-
|
|
6
|
-
@use 'sass:map';
|
|
7
|
-
@use '../../01-settings/settings.testtypecheck' as *;
|
|
8
|
-
@use '../../02-tools/mixins' as *;
|
|
9
|
-
@use '../../02-tools/functions' as *;
|
|
10
|
-
|
|
11
|
-
// Base Component Class
|
|
12
|
-
// =============================================================================
|
|
13
|
-
|
|
14
|
-
.c-testtypecheck {
|
|
15
|
-
// Layout
|
|
16
|
-
display: inline-flex;
|
|
17
|
-
align-items: center;
|
|
18
|
-
justify-content: center;
|
|
19
|
-
gap: var(--testtypecheck-gap);
|
|
20
|
-
|
|
21
|
-
// Spacing
|
|
22
|
-
padding: var(--testtypecheck-padding-y) var(--testtypecheck-padding-x);
|
|
23
|
-
|
|
24
|
-
// Typography
|
|
25
|
-
font-size: var(--testtypecheck-font-size);
|
|
26
|
-
font-weight: var(--testtypecheck-font-weight);
|
|
27
|
-
line-height: var(--testtypecheck-line-height);
|
|
28
|
-
|
|
29
|
-
// Appearance
|
|
30
|
-
border-radius: var(--testtypecheck-radius);
|
|
31
|
-
border: none;
|
|
32
|
-
cursor: pointer;
|
|
33
|
-
|
|
34
|
-
// Transition
|
|
35
|
-
transition: all var(--atomix-duration-fast) var(--atomix-easing-smooth);
|
|
36
|
-
|
|
37
|
-
// Focus
|
|
38
|
-
&:focus-visible {
|
|
39
|
-
outline: none;
|
|
40
|
-
box-shadow: var(--testtypecheck-focus-ring);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
// Disabled state
|
|
44
|
-
&:disabled {
|
|
45
|
-
opacity: var(--testtypecheck-disabled-opacity);
|
|
46
|
-
cursor: not-allowed;
|
|
47
|
-
pointer-events: none;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
// Variants
|
|
52
|
-
// =============================================================================
|
|
53
|
-
|
|
54
|
-
@if true {
|
|
55
|
-
.c-testtypecheck--variant-primary {
|
|
56
|
-
background-color: var(--testtypecheck-primary);
|
|
57
|
-
color: var(--atomix-color-white);
|
|
58
|
-
|
|
59
|
-
&:hover:not(:disabled) {
|
|
60
|
-
background-color: var(--testtypecheck-primary-hover);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
&:active:not(:disabled) {
|
|
64
|
-
background-color: var(--testtypecheck-primary-active);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
.c-testtypecheck--variant-secondary {
|
|
69
|
-
background-color: var(--atomix-color-neutral-100);
|
|
70
|
-
color: var(--atomix-color-neutral-900);
|
|
71
|
-
|
|
72
|
-
&:hover:not(:disabled) {
|
|
73
|
-
background-color: var(--atomix-color-neutral-200);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
.c-testtypecheck--variant-outline {
|
|
78
|
-
background-color: transparent;
|
|
79
|
-
border: 1px solid var(--atomix-color-neutral-300);
|
|
80
|
-
color: var(--atomix-color-neutral-700);
|
|
81
|
-
|
|
82
|
-
&:hover:not(:disabled) {
|
|
83
|
-
border-color: var(--atomix-color-neutral-400);
|
|
84
|
-
background-color: var(--atomix-color-neutral-50);
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
// Glassmorphism Variant
|
|
90
|
-
// =============================================================================
|
|
91
|
-
|
|
92
|
-
.c-testtypecheck--glass {
|
|
93
|
-
background: rgba(255, 255, 255, 0.1);
|
|
94
|
-
backdrop-filter: blur(10px) saturate(200%);
|
|
95
|
-
border: 1px solid rgba(255, 255, 255, 0.2);
|
|
96
|
-
|
|
97
|
-
@media (prefers-reduced-transparency: reduce) {
|
|
98
|
-
background: rgba(255, 255, 255, 0.8);
|
|
99
|
-
backdrop-filter: none;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
&:hover:not(:disabled) {
|
|
103
|
-
background: rgba(255, 255, 255, 0.15);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// Animation Variants
|
|
108
|
-
// =============================================================================
|
|
109
|
-
|
|
110
|
-
@if true {
|
|
111
|
-
// Fade In Animation
|
|
112
|
-
.c-testtypecheck--animate-fade-in {
|
|
113
|
-
animation: atomix-fade-in var(--atomix-duration-base) var(--atomix-easing-smooth);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
// Slide In Up Animation
|
|
117
|
-
.c-testtypecheck--animate-slide-in-up {
|
|
118
|
-
animation: atomix-slide-in-up var(--atomix-duration-slow) var(--atomix-easing-smooth);
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// Scale In Animation
|
|
122
|
-
.c-testtypecheck--animate-scale-in {
|
|
123
|
-
animation: atomix-scale-in var(--atomix-duration-base) var(--atomix-easing-smooth);
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
// Pulse Animation (for loading states)
|
|
127
|
-
.c-testtypecheck--animate-pulse {
|
|
128
|
-
animation: atomix-pulse 2s var(--atomix-easing-smooth) infinite;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
// Shimmer Animation (for skeleton loaders)
|
|
132
|
-
.c-testtypecheck--animate-shimmer {
|
|
133
|
-
animation: atomix-shimmer 2s linear infinite;
|
|
134
|
-
background: linear-gradient(
|
|
135
|
-
90deg,
|
|
136
|
-
var(--atomix-color-neutral-100) 0%,
|
|
137
|
-
var(--atomix-color-neutral-200) 50%,
|
|
138
|
-
var(--atomix-color-neutral-100) 100%
|
|
139
|
-
);
|
|
140
|
-
background-size: 200% 100%;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
// Motion Preferences
|
|
145
|
-
// =============================================================================
|
|
146
|
-
|
|
147
|
-
@media (prefers-reduced-motion: reduce) {
|
|
148
|
-
.c-testtypecheck,
|
|
149
|
-
.c-testtypecheck * {
|
|
150
|
-
animation-duration: 0.01ms !important;
|
|
151
|
-
animation-iteration-count: 1 !important;
|
|
152
|
-
transition-duration: 0.01ms !important;
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
// Sizes
|
|
157
|
-
// =============================================================================
|
|
158
|
-
|
|
159
|
-
@if true {
|
|
160
|
-
.c-testtypecheck--size-sm {
|
|
161
|
-
padding: calc(var(--testtypecheck-padding-y) * 0.75) calc(var(--testtypecheck-padding-x) * 0.75);
|
|
162
|
-
font-size: var(--atomix-font-size-sm);
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
.c-testtypecheck--size-md {
|
|
166
|
-
// Default size - no overrides needed
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
.c-testtypecheck--size-lg {
|
|
170
|
-
padding: calc(var(--testtypecheck-padding-y) * 1.25) calc(var(--testtypecheck-padding-x) * 1.25);
|
|
171
|
-
font-size: var(--atomix-font-size-lg);
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
// States
|
|
176
|
-
// =============================================================================
|
|
177
|
-
|
|
178
|
-
@if true {
|
|
179
|
-
.c-testtypecheck--state-loading {
|
|
180
|
-
position: relative;
|
|
181
|
-
pointer-events: none;
|
|
182
|
-
|
|
183
|
-
&::after {
|
|
184
|
-
content: '';
|
|
185
|
-
position: absolute;
|
|
186
|
-
inset: 0;
|
|
187
|
-
background: rgba(255, 255, 255, 0.3);
|
|
188
|
-
backdrop-filter: blur(2px);
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
.c-testtypecheck--state-glass {
|
|
193
|
-
background-color: rgba(255, 255, 255, 0.1);
|
|
194
|
-
backdrop-filter: blur(10px);
|
|
195
|
-
border: 1px solid rgba(255, 255, 255, 0.2);
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
// Responsive Overrides
|
|
200
|
-
// =============================================================================
|
|
201
|
-
|
|
202
|
-
@include atomix-media-breakpoint-up(md) {
|
|
203
|
-
.c-testtypecheck {
|
|
204
|
-
// Tablet-specific adjustments if needed
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
@include atomix-media-breakpoint-up(lg) {
|
|
209
|
-
.c-testtypecheck {
|
|
210
|
-
// Desktop-specific adjustments if needed
|
|
211
|
-
}
|
|
212
|
-
}
|
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
// TypedButton Component Styles
|
|
2
|
-
// Generated by Atomix CLI
|
|
3
|
-
// ITCSS Layer: Components
|
|
4
|
-
// =============================================================================
|
|
5
|
-
|
|
6
|
-
@use 'sass:map';
|
|
7
|
-
@use '../../01-settings/settings.typedbutton' as *;
|
|
8
|
-
@use '../../02-tools/mixins' as *;
|
|
9
|
-
@use '../../02-tools/functions' as *;
|
|
10
|
-
|
|
11
|
-
// Base Component Class
|
|
12
|
-
// =============================================================================
|
|
13
|
-
|
|
14
|
-
.c-typedbutton {
|
|
15
|
-
// Layout
|
|
16
|
-
display: inline-flex;
|
|
17
|
-
align-items: center;
|
|
18
|
-
justify-content: center;
|
|
19
|
-
gap: var(--typedbutton-gap);
|
|
20
|
-
|
|
21
|
-
// Spacing
|
|
22
|
-
padding: var(--typedbutton-padding-y) var(--typedbutton-padding-x);
|
|
23
|
-
|
|
24
|
-
// Typography
|
|
25
|
-
font-size: var(--typedbutton-font-size);
|
|
26
|
-
font-weight: var(--typedbutton-font-weight);
|
|
27
|
-
line-height: var(--typedbutton-line-height);
|
|
28
|
-
|
|
29
|
-
// Appearance
|
|
30
|
-
border-radius: var(--typedbutton-radius);
|
|
31
|
-
border: none;
|
|
32
|
-
cursor: pointer;
|
|
33
|
-
|
|
34
|
-
// Transition
|
|
35
|
-
transition: all var(--atomix-duration-fast) var(--atomix-easing-smooth);
|
|
36
|
-
|
|
37
|
-
// Focus
|
|
38
|
-
&:focus-visible {
|
|
39
|
-
outline: none;
|
|
40
|
-
box-shadow: var(--typedbutton-focus-ring);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
// Disabled state
|
|
44
|
-
&:disabled {
|
|
45
|
-
opacity: var(--typedbutton-disabled-opacity);
|
|
46
|
-
cursor: not-allowed;
|
|
47
|
-
pointer-events: none;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
// Variants
|
|
52
|
-
// =============================================================================
|
|
53
|
-
|
|
54
|
-
@if true {
|
|
55
|
-
.c-typedbutton--variant-primary {
|
|
56
|
-
background-color: var(--typedbutton-primary);
|
|
57
|
-
color: var(--atomix-color-white);
|
|
58
|
-
|
|
59
|
-
&:hover:not(:disabled) {
|
|
60
|
-
background-color: var(--typedbutton-primary-hover);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
&:active:not(:disabled) {
|
|
64
|
-
background-color: var(--typedbutton-primary-active);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
.c-typedbutton--variant-secondary {
|
|
69
|
-
background-color: var(--atomix-color-neutral-100);
|
|
70
|
-
color: var(--atomix-color-neutral-900);
|
|
71
|
-
|
|
72
|
-
&:hover:not(:disabled) {
|
|
73
|
-
background-color: var(--atomix-color-neutral-200);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
.c-typedbutton--variant-outline {
|
|
78
|
-
background-color: transparent;
|
|
79
|
-
border: 1px solid var(--atomix-color-neutral-300);
|
|
80
|
-
color: var(--atomix-color-neutral-700);
|
|
81
|
-
|
|
82
|
-
&:hover:not(:disabled) {
|
|
83
|
-
border-color: var(--atomix-color-neutral-400);
|
|
84
|
-
background-color: var(--atomix-color-neutral-50);
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
// Glassmorphism Variant
|
|
90
|
-
// =============================================================================
|
|
91
|
-
|
|
92
|
-
.c-typedbutton--glass {
|
|
93
|
-
background: rgba(255, 255, 255, 0.1);
|
|
94
|
-
backdrop-filter: blur(10px) saturate(200%);
|
|
95
|
-
border: 1px solid rgba(255, 255, 255, 0.2);
|
|
96
|
-
|
|
97
|
-
@media (prefers-reduced-transparency: reduce) {
|
|
98
|
-
background: rgba(255, 255, 255, 0.8);
|
|
99
|
-
backdrop-filter: none;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
&:hover:not(:disabled) {
|
|
103
|
-
background: rgba(255, 255, 255, 0.15);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// Animation Variants
|
|
108
|
-
// =============================================================================
|
|
109
|
-
|
|
110
|
-
@if true {
|
|
111
|
-
// Fade In Animation
|
|
112
|
-
.c-typedbutton--animate-fade-in {
|
|
113
|
-
animation: atomix-fade-in var(--atomix-duration-base) var(--atomix-easing-smooth);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
// Slide In Up Animation
|
|
117
|
-
.c-typedbutton--animate-slide-in-up {
|
|
118
|
-
animation: atomix-slide-in-up var(--atomix-duration-slow) var(--atomix-easing-smooth);
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// Scale In Animation
|
|
122
|
-
.c-typedbutton--animate-scale-in {
|
|
123
|
-
animation: atomix-scale-in var(--atomix-duration-base) var(--atomix-easing-smooth);
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
// Pulse Animation (for loading states)
|
|
127
|
-
.c-typedbutton--animate-pulse {
|
|
128
|
-
animation: atomix-pulse 2s var(--atomix-easing-smooth) infinite;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
// Shimmer Animation (for skeleton loaders)
|
|
132
|
-
.c-typedbutton--animate-shimmer {
|
|
133
|
-
animation: atomix-shimmer 2s linear infinite;
|
|
134
|
-
background: linear-gradient(
|
|
135
|
-
90deg,
|
|
136
|
-
var(--atomix-color-neutral-100) 0%,
|
|
137
|
-
var(--atomix-color-neutral-200) 50%,
|
|
138
|
-
var(--atomix-color-neutral-100) 100%
|
|
139
|
-
);
|
|
140
|
-
background-size: 200% 100%;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
// Motion Preferences
|
|
145
|
-
// =============================================================================
|
|
146
|
-
|
|
147
|
-
@media (prefers-reduced-motion: reduce) {
|
|
148
|
-
.c-typedbutton,
|
|
149
|
-
.c-typedbutton * {
|
|
150
|
-
animation-duration: 0.01ms !important;
|
|
151
|
-
animation-iteration-count: 1 !important;
|
|
152
|
-
transition-duration: 0.01ms !important;
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
// Sizes
|
|
157
|
-
// =============================================================================
|
|
158
|
-
|
|
159
|
-
@if true {
|
|
160
|
-
.c-typedbutton--size-sm {
|
|
161
|
-
padding: calc(var(--typedbutton-padding-y) * 0.75) calc(var(--typedbutton-padding-x) * 0.75);
|
|
162
|
-
font-size: var(--atomix-font-size-sm);
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
.c-typedbutton--size-md {
|
|
166
|
-
// Default size - no overrides needed
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
.c-typedbutton--size-lg {
|
|
170
|
-
padding: calc(var(--typedbutton-padding-y) * 1.25) calc(var(--typedbutton-padding-x) * 1.25);
|
|
171
|
-
font-size: var(--atomix-font-size-lg);
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
// States
|
|
176
|
-
// =============================================================================
|
|
177
|
-
|
|
178
|
-
@if true {
|
|
179
|
-
.c-typedbutton--state-loading {
|
|
180
|
-
position: relative;
|
|
181
|
-
pointer-events: none;
|
|
182
|
-
|
|
183
|
-
&::after {
|
|
184
|
-
content: '';
|
|
185
|
-
position: absolute;
|
|
186
|
-
inset: 0;
|
|
187
|
-
background: rgba(255, 255, 255, 0.3);
|
|
188
|
-
backdrop-filter: blur(2px);
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
.c-typedbutton--state-glass {
|
|
193
|
-
background-color: rgba(255, 255, 255, 0.1);
|
|
194
|
-
backdrop-filter: blur(10px);
|
|
195
|
-
border: 1px solid rgba(255, 255, 255, 0.2);
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
// Responsive Overrides
|
|
200
|
-
// =============================================================================
|
|
201
|
-
|
|
202
|
-
@include atomix-media-breakpoint-up(md) {
|
|
203
|
-
.c-typedbutton {
|
|
204
|
-
// Tablet-specific adjustments if needed
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
@include atomix-media-breakpoint-up(lg) {
|
|
209
|
-
.c-typedbutton {
|
|
210
|
-
// Desktop-specific adjustments if needed
|
|
211
|
-
}
|
|
212
|
-
}
|