@codemonster-ru/vueforge-core 1.2.0 → 1.3.1

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 (99) hide show
  1. package/README.md +18 -1
  2. package/dist/components/accordion/VfAccordion.vue.d.ts.map +1 -1
  3. package/dist/components/accordion/index.d.ts.map +1 -1
  4. package/dist/components/alert/VfAlert.vue.d.ts.map +1 -1
  5. package/dist/components/alert/index.d.ts.map +1 -1
  6. package/dist/components/badge/VfBadge.vue.d.ts.map +1 -1
  7. package/dist/components/badge/index.d.ts.map +1 -1
  8. package/dist/components/button/VfButton.vue.d.ts +1 -1
  9. package/dist/components/button/VfButton.vue.d.ts.map +1 -1
  10. package/dist/components/button/index.d.ts.map +1 -1
  11. package/dist/components/card/VfCard.vue.d.ts.map +1 -1
  12. package/dist/components/card/index.d.ts.map +1 -1
  13. package/dist/components/checkbox/VfCheckbox.vue.d.ts +1 -1
  14. package/dist/components/checkbox/VfCheckbox.vue.d.ts.map +1 -1
  15. package/dist/components/checkbox/index.d.ts.map +1 -1
  16. package/dist/components/dialog/VfDialog.vue.d.ts.map +1 -1
  17. package/dist/components/dialog/index.d.ts.map +1 -1
  18. package/dist/components/divider/VfDivider.vue.d.ts.map +1 -1
  19. package/dist/components/divider/index.d.ts.map +1 -1
  20. package/dist/components/drawer/VfDrawer.vue.d.ts.map +1 -1
  21. package/dist/components/drawer/index.d.ts.map +1 -1
  22. package/dist/components/dropdown/VfDropdown.vue.d.ts.map +1 -1
  23. package/dist/components/dropdown/index.d.ts.map +1 -1
  24. package/dist/components/icon-button/VfIconButton.vue.d.ts +1 -1
  25. package/dist/components/icon-button/VfIconButton.vue.d.ts.map +1 -1
  26. package/dist/components/icon-button/index.d.ts.map +1 -1
  27. package/dist/components/index.d.ts.map +1 -1
  28. package/dist/components/input/VfInput.vue.d.ts.map +1 -1
  29. package/dist/components/input/index.d.ts.map +1 -1
  30. package/dist/components/link/VfLink.vue.d.ts.map +1 -1
  31. package/dist/components/link/index.d.ts.map +1 -1
  32. package/dist/components/nav-menu/VfNavMenu.vue.d.ts +3 -3
  33. package/dist/components/nav-menu/VfNavMenu.vue.d.ts.map +1 -1
  34. package/dist/components/nav-menu/VfNavMenuItemNode.vue.d.ts.map +1 -1
  35. package/dist/components/nav-menu/index.d.ts.map +1 -1
  36. package/dist/components/panel/VfPanel.vue.d.ts.map +1 -1
  37. package/dist/components/panel/index.d.ts.map +1 -1
  38. package/dist/components/popover/VfPopover.vue.d.ts.map +1 -1
  39. package/dist/components/popover/index.d.ts.map +1 -1
  40. package/dist/components/radio/VfRadio.vue.d.ts +1 -1
  41. package/dist/components/radio/VfRadio.vue.d.ts.map +1 -1
  42. package/dist/components/radio/index.d.ts.map +1 -1
  43. package/dist/components/switch/VfSwitch.vue.d.ts.map +1 -1
  44. package/dist/components/switch/index.d.ts.map +1 -1
  45. package/dist/components/tabs/VfTabs.vue.d.ts.map +1 -1
  46. package/dist/components/tabs/index.d.ts.map +1 -1
  47. package/dist/components/tag/VfTag.vue.d.ts.map +1 -1
  48. package/dist/components/tag/index.d.ts.map +1 -1
  49. package/dist/components/textarea/VfTextarea.vue.d.ts.map +1 -1
  50. package/dist/components/textarea/index.d.ts.map +1 -1
  51. package/dist/components/tooltip/VfTooltip.vue.d.ts.map +1 -1
  52. package/dist/components/tooltip/index.d.ts.map +1 -1
  53. package/dist/composables/index.d.ts.map +1 -1
  54. package/dist/composables/useClickOutside.d.ts.map +1 -1
  55. package/dist/composables/useDisclosure.d.ts.map +1 -1
  56. package/dist/composables/useEscapeKey.d.ts +1 -1
  57. package/dist/composables/useEscapeKey.d.ts.map +1 -1
  58. package/dist/composables/useFloating.d.ts.map +1 -1
  59. package/dist/composables/useFocusTrap.d.ts.map +1 -1
  60. package/dist/composables/useId.d.ts.map +1 -1
  61. package/dist/composables/useTheme.d.ts +3 -3
  62. package/dist/foundation/breakpoints.d.ts.map +1 -1
  63. package/dist/foundation/index.d.ts.map +1 -1
  64. package/dist/foundation/useBreakpoint.d.ts +1 -1
  65. package/dist/foundation/useBreakpoint.d.ts.map +1 -1
  66. package/dist/foundation/useBreakpointValue.d.ts.map +1 -1
  67. package/dist/foundation/useBreakpoints.d.ts.map +1 -1
  68. package/dist/foundation/useScrollLock.d.ts.map +1 -1
  69. package/dist/foundation-api.js +1 -1
  70. package/dist/foundation.css +2 -2
  71. package/dist/index.d.ts +6 -6
  72. package/dist/index.d.ts.map +1 -1
  73. package/dist/plugin.d.ts.map +1 -1
  74. package/dist/providers/VfThemeProvider.vue.d.ts.map +1 -1
  75. package/dist/providers/themeContext.d.ts.map +1 -1
  76. package/dist/providers/vueForgeConfig.d.ts.map +1 -1
  77. package/dist/styles.css +1 -1
  78. package/dist/theme/default-preset.d.ts.map +1 -1
  79. package/dist/theme/index.d.ts +2 -1
  80. package/dist/theme/index.d.ts.map +1 -1
  81. package/dist/theme/motion.d.ts +1 -9
  82. package/dist/theme/motion.d.ts.map +1 -1
  83. package/dist/theme/public.d.ts +2 -1
  84. package/dist/theme/public.d.ts.map +1 -1
  85. package/dist/theme/utils.d.ts +2 -7
  86. package/dist/theme/utils.d.ts.map +1 -1
  87. package/dist/theme-api.js +220 -2
  88. package/dist/theme.css +80 -19
  89. package/dist/tokens.css +86 -18
  90. package/dist/types/components.d.ts +11 -11
  91. package/dist/types/components.d.ts.map +1 -1
  92. package/dist/types/theme.d.ts +2 -206
  93. package/dist/types/theme.d.ts.map +1 -1
  94. package/dist/{useScrollLock-B7pq1ybb.js → useScrollLock-FYdn9vRp.js} +8 -10
  95. package/dist/utils/theme.d.ts +1 -5
  96. package/dist/utils/theme.d.ts.map +1 -1
  97. package/dist/vueforge-core.js +429 -290
  98. package/package.json +3 -2
  99. package/dist/public-CFcLjh0P.js +0 -306
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@codemonster-ru/vueforge-core",
3
- "version": "1.2.0",
3
+ "version": "1.3.1",
4
4
  "description": "Foundation layer for the VueForge design system.",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -64,7 +64,7 @@
64
64
  "scripts": {
65
65
  "build": "vue-tsc --noEmit && vite build",
66
66
  "check": "npm run lint && npm run test && npm run build",
67
- "dev": "vite",
67
+ "dev": "vite --force",
68
68
  "format": "prettier --write .",
69
69
  "lint": "eslint .",
70
70
  "prepack": "npm run build",
@@ -97,6 +97,7 @@
97
97
  },
98
98
  "dependencies": {
99
99
  "@codemonster-ru/floater.js": "^1.0.8",
100
+ "@codemonster-ru/vueforge-theme": "^1.1.0",
100
101
  "@codemonster-ru/vueiconify": "^1.0.1"
101
102
  }
102
103
  }
@@ -1,306 +0,0 @@
1
- import { b as t } from "./breakpoints-hxAiWC8U.js";
2
- const n = {
3
- durationFast: "220ms",
4
- durationNormal: "320ms",
5
- easeStandard: "cubic-bezier(0.16, 1, 0.3, 1)"
6
- };
7
- function i(r) {
8
- return Number.parseInt(r, 10);
9
- }
10
- const C = {
11
- fast: i(n.durationFast),
12
- normal: i(n.durationNormal)
13
- }, d = {
14
- breakpointXs: `${t.xs}px`,
15
- breakpointSm: `${t.sm}px`,
16
- breakpointMd: `${t.md}px`,
17
- breakpointLg: `${t.lg}px`,
18
- breakpointXl: `${t.xl}px`,
19
- breakpoint2xl: `${t["2xl"]}px`
20
- }, v = {
21
- name: "vueforge-default",
22
- tokens: {
23
- colorBg: "#fcfcfd",
24
- colorSurface: "#ffffff",
25
- colorSurfaceMuted: "#f5f7fb",
26
- colorText: "#172033",
27
- colorMuted: "#69738a",
28
- colorBorder: "#d8e0ef",
29
- colorPrimary: "#0b63f6",
30
- colorPrimaryContrast: "#ffffff",
31
- colorPrimarySoft: "color-mix(in srgb, var(--vf-color-primary) 12%, var(--vf-color-surface))",
32
- colorPrimaryBorderSoft: "color-mix(in srgb, var(--vf-color-primary) 22%, var(--vf-color-border))",
33
- colorFocusRing: "color-mix(in srgb, var(--vf-color-primary) 32%, var(--vf-color-surface))",
34
- colorSuccess: "#16a34a",
35
- colorSuccessContrast: "#ffffff",
36
- colorInfo: "#0ea5e9",
37
- colorInfoContrast: "#ffffff",
38
- colorWarn: "#f59e0b",
39
- colorWarnContrast: "#1f1300",
40
- colorHelp: "#8b5cf6",
41
- colorHelpContrast: "#ffffff",
42
- colorDanger: "#dc2626",
43
- colorDangerContrast: "#ffffff",
44
- colorContrast: "#111827",
45
- colorContrastContrast: "#ffffff",
46
- colorSuccessSoft: "color-mix(in srgb, var(--vf-color-success) 12%, var(--vf-color-surface))",
47
- colorInfoSoft: "color-mix(in srgb, var(--vf-color-info) 12%, var(--vf-color-surface))",
48
- colorWarnSoft: "color-mix(in srgb, var(--vf-color-warn) 12%, var(--vf-color-surface))",
49
- colorHelpSoft: "color-mix(in srgb, var(--vf-color-help) 12%, var(--vf-color-surface))",
50
- colorDangerSoft: "color-mix(in srgb, var(--vf-color-danger) 12%, var(--vf-color-surface))",
51
- colorContrastSoft: "color-mix(in srgb, var(--vf-color-contrast) 10%, var(--vf-color-surface))",
52
- colorSuccessBorderSoft: "color-mix(in srgb, var(--vf-color-success) 24%, var(--vf-color-border))",
53
- colorInfoBorderSoft: "color-mix(in srgb, var(--vf-color-info) 24%, var(--vf-color-border))",
54
- colorWarnBorderSoft: "color-mix(in srgb, var(--vf-color-warn) 24%, var(--vf-color-border))",
55
- colorHelpBorderSoft: "color-mix(in srgb, var(--vf-color-help) 24%, var(--vf-color-border))",
56
- colorDangerBorderSoft: "color-mix(in srgb, var(--vf-color-danger) 24%, var(--vf-color-border))",
57
- colorContrastBorderSoft: "color-mix(in srgb, var(--vf-color-contrast) 24%, var(--vf-color-border))",
58
- focusRingWidth: "3px",
59
- radius: "0.75rem",
60
- radiusControl: "calc(var(--vf-radius) - 0.125rem)",
61
- radiusControlTight: "calc(var(--vf-radius) - 0.25rem)",
62
- radiusSurface: "var(--vf-radius)",
63
- radiusOverlay: "calc(var(--vf-radius) + 0.125rem)",
64
- ...d,
65
- controlHeightSm: "1.75rem",
66
- controlHeightMd: "2.25rem",
67
- controlHeightLg: "2.5rem",
68
- controlFontSizeSm: "0.875rem",
69
- controlFontSizeMd: "0.9375rem",
70
- controlFontSizeLg: "1rem",
71
- buttonPaddingSm: "0.25rem 0.55rem",
72
- buttonPaddingMd: "0.375rem 0.75rem",
73
- buttonPaddingLg: "0.5rem 0.875rem",
74
- buttonGap: "0.5rem",
75
- fieldPaddingSm: "0.25rem 0.55rem",
76
- fieldPaddingMd: "0.375rem 0.65rem",
77
- fieldPaddingLg: "0.5rem 0.75rem",
78
- checkboxSizeSm: "1rem",
79
- checkboxSizeMd: "1.125rem",
80
- checkboxSizeLg: "1.25rem",
81
- selectionGap: "0.65rem",
82
- checkboxMarkWidth: "0.3rem",
83
- checkboxMarkHeight: "0.55rem",
84
- checkboxMarkStrokeWidth: "2px",
85
- checkboxMarkOffsetY: "-0.05rem",
86
- radioDotSize: "0.5rem",
87
- switchWidthSm: "2rem",
88
- switchWidthMd: "2.25rem",
89
- switchWidthLg: "2.5rem",
90
- switchHeightSm: "1.125rem",
91
- switchHeightMd: "1.25rem",
92
- switchHeightLg: "1.375rem",
93
- switchThumbSizeSm: "0.75rem",
94
- switchThumbSizeMd: "0.875rem",
95
- switchThumbSizeLg: "1rem",
96
- switchThumbInset: "0.1875rem",
97
- textareaMinHeightSm: "4.5rem",
98
- textareaMinHeightMd: "6rem",
99
- textareaMinHeightLg: "7rem",
100
- overlayPadding: "0.875rem",
101
- overlayGap: "0.75rem",
102
- overlayViewportPadding: "1rem",
103
- menuPadding: "0.4rem",
104
- menuGap: "0.2rem",
105
- menuMinWidth: "12rem",
106
- surfacePadding: "0.95rem",
107
- surfaceGap: "0.625rem",
108
- surfacePaddingCompact: "0.7rem",
109
- surfaceGapCompact: "0.5rem",
110
- sectionPadding: "0.75rem 0.9rem",
111
- sectionGap: "0.75rem",
112
- tabsGap: "0.875rem",
113
- tabsListGap: "0.375rem",
114
- tabsListPadding: "0.25rem",
115
- tabsTabPaddingInline: "0.8rem",
116
- tabsPanelPaddingTop: "0.75rem",
117
- navMenuListGap: "0.2rem",
118
- navMenuNestedGap: "0.15rem",
119
- navMenuCollapseOffsetTop: "0.1rem",
120
- navMenuCollapseInsetLevel0Margin: "1.275rem",
121
- navMenuCollapseInsetLevel0Padding: "0.7rem",
122
- navMenuCollapseInsetSimpleLevel0Margin: "0.75rem",
123
- navMenuCollapseInsetSimpleLevel0Padding: "0.45rem",
124
- navMenuCollapseInsetDeepMargin: "0.35rem",
125
- navMenuCollapseInsetDeepPadding: "0.35rem",
126
- navMenuCollapseInsetSimpleDeepMargin: "0.2rem",
127
- navMenuCollapseInsetSimpleDeepPadding: "0.2rem",
128
- navMenuNodeGroupSpacing: "0.1rem",
129
- navMenuGroupPadding: "0.35rem 0.65rem",
130
- navMenuGroupFontSize: "0.875rem",
131
- navMenuItemPadding: "0.35rem 0.65rem",
132
- navMenuItemGap: "0.55rem",
133
- navMenuLeadingIconSize: "1rem",
134
- navMenuLeadingIconColumnSize: "1.25rem",
135
- badgeHeight: "1.625rem",
136
- badgePadding: "0.2rem 0.55rem",
137
- badgeGap: "0.375rem",
138
- badgeRadius: "999px",
139
- badgeFontSize: "0.8125rem",
140
- badgeLineHeight: "1.2",
141
- tagHeight: "1.75rem",
142
- tagPadding: "0.25rem 0.6rem",
143
- tagFontSize: "0.8125rem",
144
- tagLineHeight: "1.2",
145
- tooltipPadding: "0.45rem 0.65rem",
146
- tooltipMaxWidth: "16rem",
147
- tooltipFontSize: "0.8125rem",
148
- tooltipLineHeight: "1.4",
149
- dialogWidthSm: "28rem",
150
- dialogWidthMd: "36rem",
151
- dialogWidthLg: "48rem",
152
- dialogMaxHeight: "min(85vh, 48rem)",
153
- drawerSizeSm: "20rem",
154
- drawerSizeMd: "26rem",
155
- drawerSizeLg: "32rem",
156
- drawerOffsetTop: "0px",
157
- drawerBodyPadding: "var(--vf-overlay-padding)",
158
- dialogTitleFontSize: "1.125rem",
159
- dialogHeaderGap: "0.75rem",
160
- dialogActionsGap: "0.5rem",
161
- popoverWidth: "min(100vw - 2rem, 22rem)",
162
- floatingArrowSize: "0.625rem",
163
- overlayBackdrop: "rgba(15, 23, 42, 0.56)",
164
- alertPrimarySoft: "color-mix(in srgb, var(--vf-color-primary) 8%, var(--vf-color-surface))",
165
- alertPrimaryBorderSoft: "color-mix(in srgb, var(--vf-color-primary) 22%, var(--vf-color-border))",
166
- alertContentGap: "0.25rem",
167
- alertTitleFontSize: "0.9375rem",
168
- cardTitleFontSize: "1rem",
169
- panelTitleFontSize: "0.9375rem",
170
- textLineHeight: "1.5",
171
- headingLineHeight: "1.3",
172
- tabsLineHeight: "1.2",
173
- motionDurationFast: n.durationFast,
174
- motionDurationNormal: n.durationNormal,
175
- motionEaseStandard: n.easeStandard,
176
- zOverlay: "1000",
177
- zDrawer: "1000",
178
- zDropdown: "900",
179
- zPopover: "925",
180
- zTooltip: "950",
181
- spacing: "1rem",
182
- shadow: "none"
183
- },
184
- dark: {
185
- colorBg: "#0f172a",
186
- colorSurface: "#162033",
187
- colorSurfaceMuted: "#1b2840",
188
- colorText: "#eff4ff",
189
- colorMuted: "#9fb0cf",
190
- colorBorder: "#2d405f",
191
- colorPrimary: "#6ea8fe",
192
- colorPrimaryContrast: "#081120",
193
- colorPrimarySoft: "color-mix(in srgb, var(--vf-color-primary) 12%, var(--vf-color-surface))",
194
- colorPrimaryBorderSoft: "color-mix(in srgb, var(--vf-color-primary) 22%, var(--vf-color-border))",
195
- colorFocusRing: "color-mix(in srgb, var(--vf-color-primary) 32%, var(--vf-color-surface))",
196
- colorSuccess: "#4ade80",
197
- colorSuccessContrast: "#081120",
198
- colorInfo: "#38bdf8",
199
- colorInfoContrast: "#081120",
200
- colorWarn: "#fbbf24",
201
- colorWarnContrast: "#1f1300",
202
- colorHelp: "#a78bfa",
203
- colorHelpContrast: "#081120",
204
- colorDanger: "#f87171",
205
- colorDangerContrast: "#081120",
206
- colorContrast: "#f3f4f6",
207
- colorContrastContrast: "#111827",
208
- colorSuccessSoft: "color-mix(in srgb, var(--vf-color-success) 12%, var(--vf-color-surface))",
209
- colorInfoSoft: "color-mix(in srgb, var(--vf-color-info) 12%, var(--vf-color-surface))",
210
- colorWarnSoft: "color-mix(in srgb, var(--vf-color-warn) 12%, var(--vf-color-surface))",
211
- colorHelpSoft: "color-mix(in srgb, var(--vf-color-help) 12%, var(--vf-color-surface))",
212
- colorDangerSoft: "color-mix(in srgb, var(--vf-color-danger) 12%, var(--vf-color-surface))",
213
- colorContrastSoft: "color-mix(in srgb, var(--vf-color-contrast) 10%, var(--vf-color-surface))",
214
- colorSuccessBorderSoft: "color-mix(in srgb, var(--vf-color-success) 24%, var(--vf-color-border))",
215
- colorInfoBorderSoft: "color-mix(in srgb, var(--vf-color-info) 24%, var(--vf-color-border))",
216
- colorWarnBorderSoft: "color-mix(in srgb, var(--vf-color-warn) 24%, var(--vf-color-border))",
217
- colorHelpBorderSoft: "color-mix(in srgb, var(--vf-color-help) 24%, var(--vf-color-border))",
218
- colorDangerBorderSoft: "color-mix(in srgb, var(--vf-color-danger) 24%, var(--vf-color-border))",
219
- colorContrastBorderSoft: "color-mix(in srgb, var(--vf-color-contrast) 24%, var(--vf-color-border))",
220
- focusRingWidth: "3px",
221
- zOverlay: "1000",
222
- zDrawer: "1000",
223
- zDropdown: "900",
224
- zPopover: "925",
225
- zTooltip: "950",
226
- shadow: "none"
227
- }
228
- }, g = "vf-theme", u = "data-vf-theme";
229
- function P(r) {
230
- return r === "light" || r === "dark" || r === "system";
231
- }
232
- function k(r, o) {
233
- return r === "system" ? o : r;
234
- }
235
- const m = "vf", p = "vf-theme-preset", b = ":root";
236
- function S(r) {
237
- return r.replace(/[A-Z]/g, (o) => `-${o.toLowerCase()}`);
238
- }
239
- function l(...r) {
240
- return Object.assign({}, ...r);
241
- }
242
- function y(r) {
243
- return r;
244
- }
245
- function h(r = {}) {
246
- const o = r.prefix ?? m, e = r.rootSelector ?? b, a = r.attribute ?? u;
247
- return {
248
- prefix: o,
249
- rootSelector: e,
250
- darkModeSelector: r.darkModeSelector ?? `${e}[${a}='dark']`,
251
- attribute: a,
252
- storageKey: r.storageKey ?? g,
253
- styleId: r.styleId ?? p
254
- };
255
- }
256
- function x(r = {}) {
257
- const o = r.preset ?? v, e = r.extend, a = l(o.tokens, e, r.light), c = l(o.tokens, o.dark, e, r.dark);
258
- return {
259
- name: o.name,
260
- light: a,
261
- dark: c
262
- };
263
- }
264
- function z(r = {}) {
265
- return {
266
- preset: x(r),
267
- options: h(r.options)
268
- };
269
- }
270
- function s(r, o = m) {
271
- return Object.fromEntries(
272
- Object.entries(r).map(([e, a]) => [`--${o}-${S(e)}`, a])
273
- );
274
- }
275
- function f(r) {
276
- return Object.entries(r).map(([o, e]) => ` ${o}: ${e};`).join(`
277
- `);
278
- }
279
- function M(r) {
280
- const { preset: o, options: e } = r, a = f(s(o.light, e.prefix)), c = f(s(o.dark, e.prefix));
281
- return [
282
- `${e.rootSelector} {
283
- ${a}
284
- }`,
285
- `${e.darkModeSelector} {
286
- ${c}
287
- }`
288
- ].join(`
289
-
290
- `);
291
- }
292
- function L(r, o = document) {
293
- const e = r.options.styleId, a = o.getElementById(e) ?? Object.assign(o.createElement("style"), { id: e });
294
- return a.textContent = M(r), a.parentNode || o.head.appendChild(a), a;
295
- }
296
- export {
297
- g as D,
298
- L as a,
299
- k as b,
300
- u as c,
301
- y as d,
302
- v as e,
303
- P as i,
304
- z as r,
305
- C as v
306
- };