organify-ui 0.2.16 → 0.3.2

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.
@@ -1,35 +1,37 @@
1
1
  /**
2
2
  * @organify/ui — Color Tokens
3
3
  *
4
- * Organify Organic Design System — 3 Themes:
5
- * Dark (Organic-Dark) — deep void, glassmorphism, glow accents
6
- * Cream (Organic-Cream) soft whites, indigo accents, light glass
7
- * Fluid (Library) — vibrant mesh, neon glows, deep blacks
4
+ * Organify Organic Design System — Vibrant Violet
5
+ * Purple-dominant glassmorphism with violet accents.
6
+ * Inspired by the Organify landing page aesthetic.
7
+ *
8
+ * Themes: Dark (default), Cream (light), Fluid (vibrant)
8
9
  */
9
10
  declare const colors: {
10
11
  readonly primary: {
11
- readonly DEFAULT: "#241979";
12
- readonly light: "#4C35DE";
13
- readonly soft: "#3A2E9E";
14
- readonly electric: "#4F39F6";
15
- readonly 'electric-light': "#7C6AF8";
16
- readonly dark: "#0f0a38";
12
+ readonly DEFAULT: "#7C3AED";
13
+ readonly light: "#A78BFA";
14
+ readonly soft: "#6D28D9";
15
+ readonly electric: "#8B5CF6";
16
+ readonly 'electric-light': "#C4B5FD";
17
+ readonly dark: "#4C1D95";
18
+ readonly deep: "#3B0764";
17
19
  };
18
20
  readonly neutral: {
19
- readonly 900: "#191919";
20
- readonly 875: "#0b0c10";
21
- readonly 850: "#161618";
22
- readonly 800: "#1F1F21";
23
- readonly 750: "#1a1a1c";
24
- readonly 700: "#2A2A2E";
25
- readonly 600: "#3a3a3e";
26
- readonly 500: "#6B6B76";
27
- readonly 400: "#9CA3AF";
28
- readonly 300: "#d1d5db";
29
- readonly 200: "#e5e7eb";
30
- readonly 100: "#f3f4f6";
31
- readonly 50: "#F9F9F7";
32
- readonly 25: "#FEFEFD";
21
+ readonly 900: "#0D0A1A";
22
+ readonly 875: "#110E22";
23
+ readonly 850: "#16122E";
24
+ readonly 800: "#1A1530";
25
+ readonly 750: "#211B3A";
26
+ readonly 700: "#2A2245";
27
+ readonly 600: "#352D52";
28
+ readonly 500: "#7B7394";
29
+ readonly 400: "#A49BBF";
30
+ readonly 300: "#C4BDD9";
31
+ readonly 200: "#DDD8EB";
32
+ readonly 100: "#F0ECF9";
33
+ readonly 50: "#F8F6FC";
34
+ readonly 25: "#FCFBFE";
33
35
  readonly 0: "#FFFFFF";
34
36
  };
35
37
  readonly semantic: {
@@ -37,76 +39,102 @@ declare const colors: {
37
39
  readonly DEFAULT: "#10B981";
38
40
  readonly light: "#34d399";
39
41
  readonly dark: "#065f46";
40
- readonly surface: "rgba(16, 185, 129, 0.10)";
42
+ readonly surface: "rgba(16, 185, 129, 0.12)";
41
43
  readonly border: "rgba(16, 185, 129, 0.30)";
42
44
  };
43
45
  readonly warning: {
44
46
  readonly DEFAULT: "#F59E0B";
45
47
  readonly light: "#fbbf24";
46
48
  readonly dark: "#92400e";
47
- readonly surface: "rgba(245, 158, 11, 0.10)";
49
+ readonly surface: "rgba(245, 158, 11, 0.12)";
48
50
  readonly border: "rgba(245, 158, 11, 0.30)";
49
51
  };
50
52
  readonly error: {
51
- readonly DEFAULT: "#E0115F";
52
- readonly light: "#f43f5e";
53
- readonly dark: "#9f1239";
54
- readonly surface: "rgba(244, 63, 94, 0.10)";
55
- readonly border: "rgba(244, 63, 94, 0.30)";
53
+ readonly DEFAULT: "#EF4444";
54
+ readonly light: "#f87171";
55
+ readonly dark: "#991b1b";
56
+ readonly surface: "rgba(239, 68, 68, 0.12)";
57
+ readonly border: "rgba(239, 68, 68, 0.30)";
56
58
  };
57
59
  readonly info: {
58
60
  readonly DEFAULT: "#3B82F6";
59
61
  readonly light: "#60a5fa";
60
62
  readonly dark: "#1e40af";
61
- readonly surface: "rgba(59, 130, 246, 0.10)";
63
+ readonly surface: "rgba(59, 130, 246, 0.12)";
62
64
  readonly border: "rgba(59, 130, 246, 0.30)";
63
65
  };
64
66
  };
65
67
  readonly glass: {
66
- readonly bg: "rgba(31, 31, 33, 0.40)";
67
- readonly bgHeavy: "rgba(31, 31, 33, 0.80)";
68
- readonly surface: "rgba(31, 31, 33, 0.70)";
69
- readonly border: "rgba(255, 255, 255, 0.03)";
70
- readonly borderMedium: "rgba(255, 255, 255, 0.08)";
71
- readonly borderStrong: "rgba(255, 255, 255, 0.20)";
72
- readonly highlight: "rgba(255, 255, 255, 0.05)";
68
+ readonly bg: "rgba(124, 58, 237, 0.06)";
69
+ readonly bgHeavy: "rgba(124, 58, 237, 0.12)";
70
+ readonly surface: "rgba(255, 255, 255, 0.05)";
71
+ readonly border: "rgba(167, 139, 250, 0.15)";
72
+ readonly borderMedium: "rgba(167, 139, 250, 0.25)";
73
+ readonly borderStrong: "rgba(167, 139, 250, 0.40)";
74
+ readonly highlight: "rgba(255, 255, 255, 0.06)";
73
75
  readonly white5: "rgba(255, 255, 255, 0.05)";
74
76
  readonly white10: "rgba(255, 255, 255, 0.10)";
75
77
  readonly white20: "rgba(255, 255, 255, 0.20)";
76
78
  readonly white40: "rgba(255, 255, 255, 0.40)";
77
79
  };
78
80
  readonly cream: {
79
- readonly base: "#F9F9F7";
80
- readonly surface: "rgba(255, 255, 255, 0.70)";
81
- readonly surfaceStrong: "rgba(255, 255, 255, 0.90)";
82
- readonly border: "rgba(255, 255, 255, 0.60)";
83
- readonly borderMedium: "rgba(36, 25, 121, 0.06)";
84
- readonly borderStrong: "rgba(36, 25, 121, 0.15)";
85
- readonly glassBorder: "rgba(36, 25, 121, 0.03)";
86
- readonly text: "#191919";
87
- readonly textMuted: "#6B6B76";
88
- readonly textSubtle: "#9CA3AF";
81
+ readonly base: "#F8F6FC";
82
+ readonly surface: "rgba(255, 255, 255, 0.75)";
83
+ readonly surfaceStrong: "rgba(255, 255, 255, 0.92)";
84
+ readonly border: "rgba(124, 58, 237, 0.08)";
85
+ readonly borderMedium: "rgba(124, 58, 237, 0.12)";
86
+ readonly borderStrong: "rgba(124, 58, 237, 0.20)";
87
+ readonly glassBorder: "rgba(124, 58, 237, 0.04)";
88
+ readonly text: "#1A1530";
89
+ readonly textMuted: "#7B7394";
90
+ readonly textSubtle: "#A49BBF";
89
91
  };
90
92
  readonly fluid: {
91
- readonly bg: "rgba(255, 255, 255, 0.03)";
92
- readonly surface: "#161618";
93
- readonly border: "rgba(255, 255, 255, 0.05)";
94
- readonly borderMedium: "rgba(255, 255, 255, 0.08)";
95
- readonly borderStrong: "rgba(255, 255, 255, 0.10)";
96
- readonly highlight: "rgba(255, 255, 255, 0.05)";
97
- readonly primarySoft: "rgba(124, 106, 248, 0.20)";
93
+ readonly bg: "rgba(124, 58, 237, 0.05)";
94
+ readonly surface: "#1A1530";
95
+ readonly border: "rgba(167, 139, 250, 0.08)";
96
+ readonly borderMedium: "rgba(167, 139, 250, 0.12)";
97
+ readonly borderStrong: "rgba(167, 139, 250, 0.18)";
98
+ readonly highlight: "rgba(167, 139, 250, 0.06)";
99
+ readonly primarySoft: "rgba(124, 58, 237, 0.20)";
100
+ };
101
+ readonly liquid: {
102
+ readonly void: "#0D0A1A";
103
+ readonly surface: "#110E22";
104
+ readonly elevated: "#1A1530";
105
+ readonly card: "#13102A";
106
+ readonly text: "#F0ECF9";
107
+ readonly textSecondary: "#C4BDD9";
108
+ readonly textMuted: "#7B7394";
109
+ readonly border: "rgba(139, 92, 246, 0.10)";
110
+ readonly borderMedium: "rgba(139, 92, 246, 0.18)";
111
+ readonly borderStrong: "rgba(167, 139, 250, 0.28)";
112
+ readonly glassBg: "rgba(124, 58, 237, 0.06)";
113
+ readonly glassBgHeavy: "rgba(17, 14, 34, 0.85)";
114
+ readonly glassSurface: "rgba(17, 14, 34, 0.70)";
115
+ readonly glassBorder: "rgba(139, 92, 246, 0.08)";
116
+ readonly glassBorderMedium: "rgba(139, 92, 246, 0.15)";
117
+ readonly glassBorderStrong: "rgba(167, 139, 250, 0.25)";
118
+ readonly glassHighlight: "rgba(167, 139, 250, 0.06)";
119
+ readonly primaryViolet: "#7C3AED";
120
+ readonly primaryPurple: "#A855F7";
121
+ readonly primaryLavender: "#C4B5FD";
122
+ readonly primaryDeep: "#6D28D9";
123
+ readonly primarySoft: "rgba(124, 58, 237, 0.20)";
124
+ readonly accentGlow: "rgba(124, 58, 237, 0.40)";
125
+ readonly grainOpacity: "0.04";
98
126
  };
99
127
  readonly status: {
100
128
  readonly inFlow: {
101
- readonly bg: "rgba(99, 102, 241, 0.20)";
102
- readonly text: "#c7d2fe";
103
- readonly border: "rgba(99, 102, 241, 0.30)";
104
- readonly dot: "#818cf8";
129
+ readonly bg: "rgba(124, 58, 237, 0.20)";
130
+ readonly text: "#C4B5FD";
131
+ readonly border: "rgba(124, 58, 237, 0.30)";
132
+ readonly dot: "#A78BFA";
105
133
  };
106
134
  readonly deepWork: {
107
- readonly bg: "rgba(217, 70, 239, 0.10)";
135
+ readonly bg: "rgba(217, 70, 239, 0.12)";
108
136
  readonly text: "#f0abfc";
109
- readonly border: "rgba(217, 70, 239, 0.20)";
137
+ readonly border: "rgba(217, 70, 239, 0.22)";
110
138
  };
111
139
  readonly resting: {
112
140
  readonly bg: "rgba(245, 158, 11, 0.15)";
@@ -114,9 +142,9 @@ declare const colors: {
114
142
  readonly border: "rgba(245, 158, 11, 0.30)";
115
143
  };
116
144
  readonly disconnected: {
117
- readonly bg: "rgba(244, 63, 94, 0.15)";
145
+ readonly bg: "rgba(239, 68, 68, 0.15)";
118
146
  readonly text: "#fecdd3";
119
- readonly border: "rgba(244, 63, 94, 0.30)";
147
+ readonly border: "rgba(239, 68, 68, 0.30)";
120
148
  };
121
149
  };
122
150
  };
@@ -125,38 +153,39 @@ type Colors = typeof colors;
125
153
  /**
126
154
  * @organify/ui — Typography Tokens
127
155
  *
128
- * Space Grotesk font family variable weight (300–700).
129
- * Geometric precision, maximal legibility.
156
+ * Space Grotesk primary font, geometric & modern.
157
+ * Inter kept as secondary/fallback.
158
+ * Display headings use italic style for landing aesthetic.
130
159
  */
131
160
  declare const fontFamily: {
132
- readonly sans: readonly ["Space Grotesk", "system-ui", "-apple-system", "sans-serif"];
161
+ readonly sans: readonly ["Space Grotesk", "Inter", "system-ui", "-apple-system", "sans-serif"];
133
162
  readonly mono: readonly ["ui-monospace", "SFMono-Regular", "Menlo", "Monaco", "Consolas", "Liberation Mono", "Courier New", "monospace"];
134
163
  };
135
164
  declare const fontSize: {
136
165
  readonly 'display-xl': readonly ["5rem", {
137
- readonly lineHeight: "0.85";
166
+ readonly lineHeight: "0.90";
138
167
  readonly letterSpacing: "-0.04em";
139
- readonly fontWeight: "100";
168
+ readonly fontWeight: "300";
140
169
  }];
141
170
  readonly 'display-lg': readonly ["4rem", {
142
- readonly lineHeight: "0.9";
171
+ readonly lineHeight: "0.95";
143
172
  readonly letterSpacing: "-0.03em";
144
- readonly fontWeight: "100";
173
+ readonly fontWeight: "300";
145
174
  }];
146
175
  readonly 'heading-xl': readonly ["2.5rem", {
147
176
  readonly lineHeight: "1.1";
148
177
  readonly letterSpacing: "-0.02em";
149
- readonly fontWeight: "300";
178
+ readonly fontWeight: "400";
150
179
  }];
151
180
  readonly 'heading-lg': readonly ["1.5rem", {
152
181
  readonly lineHeight: "1.2";
153
182
  readonly letterSpacing: "-0.01em";
154
- readonly fontWeight: "300";
183
+ readonly fontWeight: "400";
155
184
  }];
156
185
  readonly 'heading-md': readonly ["1.25rem", {
157
186
  readonly lineHeight: "1.3";
158
187
  readonly letterSpacing: "-0.01em";
159
- readonly fontWeight: "300";
188
+ readonly fontWeight: "400";
160
189
  }];
161
190
  readonly 'heading-sm': readonly ["1rem", {
162
191
  readonly lineHeight: "1.4";
@@ -180,8 +209,8 @@ declare const fontSize: {
180
209
  }];
181
210
  readonly label: readonly ["0.625rem", {
182
211
  readonly lineHeight: "1.3";
183
- readonly letterSpacing: "0.2em";
184
- readonly fontWeight: "600";
212
+ readonly letterSpacing: "0.15em";
213
+ readonly fontWeight: "500";
185
214
  }];
186
215
  readonly 'mono-xs': readonly ["0.625rem", {
187
216
  readonly lineHeight: "1.4";
@@ -239,35 +268,45 @@ type Spacing = typeof spacing;
239
268
  /**
240
269
  * @organify/ui — Shadow Tokens
241
270
  *
242
- * Organic Design System — depth & glow layers.
271
+ * Organic Design System — violet-tinted depth & glow layers.
243
272
  */
244
273
  declare const shadows: {
245
- readonly glass: "0 20px 40px -10px rgba(0, 0, 0, 0.50), inset 0 1px 0 0 rgba(255, 255, 255, 0.05)";
246
- readonly 'glass-sm': "0 8px 32px 0 rgba(0, 0, 0, 0.30)";
247
- readonly 'glass-lg': "0 20px 60px -15px rgba(0, 0, 0, 0.50)";
248
- readonly 'glass-xl': "20px 20px 60px rgba(0, 0, 0, 0.50)";
249
- readonly 'cream-glass': "0 10px 40px -10px rgba(36, 25, 121, 0.04), inset 0 0 20px rgba(255, 255, 255, 0.50)";
250
- readonly 'cream-soft': "0 20px 60px -15px rgba(36, 25, 121, 0.05)";
251
- readonly 'cream-glow': "0 0 15px rgba(36, 25, 121, 0.10)";
252
- readonly 'cream-btn': "0 8px 20px rgba(36, 25, 121, 0.08)";
253
- readonly 'cream-btn-primary': "0 4px 12px rgba(36, 25, 121, 0.10)";
254
- readonly 'inner-light': "inset 0 2px 4px 0 rgba(255, 255, 255, 0.80)";
255
- readonly 'neon-glow': "0 0 15px rgba(124, 106, 248, 0.30), 0 0 30px rgba(124, 106, 248, 0.10)";
256
- readonly 'neon-glow-sm': "0 0 8px rgba(124, 106, 248, 0.30)";
257
- readonly 'neon-glow-lg': "0 0 30px rgba(79, 57, 246, 0.40), 0 0 60px rgba(79, 57, 246, 0.20)";
258
- readonly 'soft-glow': "0 0 20px rgba(255, 255, 255, 0.05)";
259
- readonly 'glow-primary': "0 0 25px rgba(76, 53, 222, 0.60)";
260
- readonly 'glow-soft': "0 0 60px rgba(36, 25, 121, 0.15)";
261
- readonly 'glow-indigo': "0 0 15px rgba(36, 25, 121, 0.60)";
274
+ readonly glass: "0 24px 80px -15px rgba(13, 10, 26, 0.60)";
275
+ readonly 'glass-sm': "0 8px 32px -8px rgba(13, 10, 26, 0.50)";
276
+ readonly 'glass-lg': "0 32px 100px -20px rgba(13, 10, 26, 0.70)";
277
+ readonly 'glass-xl': "0 40px 120px -20px rgba(13, 10, 26, 0.80)";
278
+ readonly 'cream-glass': "0 10px 40px -10px rgba(124, 58, 237, 0.06), inset 0 0 20px rgba(255, 255, 255, 0.50)";
279
+ readonly 'cream-soft': "0 20px 60px -15px rgba(124, 58, 237, 0.08)";
280
+ readonly 'cream-glow': "0 0 15px rgba(124, 58, 237, 0.12)";
281
+ readonly 'cream-btn': "0 8px 20px rgba(124, 58, 237, 0.10)";
282
+ readonly 'cream-btn-primary': "0 4px 12px rgba(124, 58, 237, 0.15)";
283
+ readonly 'inner-light': "inset 0 1px 0 0 rgba(167, 139, 250, 0.08)";
284
+ readonly 'neon-glow': "0 0 15px rgba(124, 58, 237, 0.35), 0 0 30px rgba(124, 58, 237, 0.15)";
285
+ readonly 'neon-glow-sm': "0 0 8px rgba(124, 58, 237, 0.30)";
286
+ readonly 'neon-glow-lg': "0 0 30px rgba(124, 58, 237, 0.45), 0 0 60px rgba(124, 58, 237, 0.20)";
287
+ readonly 'soft-glow': "0 0 20px rgba(124, 58, 237, 0.08)";
288
+ readonly 'glow-primary': "0 0 25px rgba(124, 58, 237, 0.50)";
289
+ readonly 'glow-soft': "0 0 60px rgba(124, 58, 237, 0.18)";
290
+ readonly 'glow-indigo': "0 0 15px rgba(124, 58, 237, 0.50)";
262
291
  readonly 'glow-success': "0 0 20px rgba(16, 185, 129, 0.20)";
263
292
  readonly 'glow-warning': "0 0 20px rgba(245, 158, 11, 0.20)";
264
- readonly 'glow-error': "0 0 20px rgba(244, 63, 94, 0.20)";
293
+ readonly 'glow-error': "0 0 20px rgba(239, 68, 68, 0.20)";
265
294
  readonly 'glow-info': "0 0 20px rgba(59, 130, 246, 0.20)";
266
- readonly 'asymmetric-glow': "0 0 60px -15px rgba(99, 91, 255, 0.30)";
267
- readonly sharp: "4px 4px 0px 0px rgba(36, 25, 121, 1)";
295
+ readonly 'asymmetric-glow': "0 0 60px -15px rgba(124, 58, 237, 0.35)";
296
+ readonly sharp: "4px 4px 0px 0px rgba(124, 58, 237, 1)";
268
297
  readonly 'status-online': "0 0 8px rgba(74, 222, 128, 0.80)";
269
- readonly 'status-flow': "0 0 8px rgba(129, 140, 248, 0.80)";
270
- readonly 'status-primary': "0 0 15px rgba(79, 57, 246, 0.50)";
298
+ readonly 'status-flow': "0 0 8px rgba(167, 139, 250, 0.80)";
299
+ readonly 'status-primary': "0 0 15px rgba(124, 58, 237, 0.50)";
300
+ readonly 'liquid-glass': "0 8px 32px rgba(13, 10, 26, 0.60), inset 0 1px 0 0 rgba(167, 139, 250, 0.06)";
301
+ readonly 'liquid-glass-sm': "0 4px 16px rgba(13, 10, 26, 0.40)";
302
+ readonly 'liquid-glass-lg': "0 16px 48px rgba(13, 10, 26, 0.70), inset 0 1px 0 0 rgba(167, 139, 250, 0.08)";
303
+ readonly 'liquid-glass-xl': "0 24px 64px rgba(13, 10, 26, 0.80), inset 0 1px 0 0 rgba(167, 139, 250, 0.10)";
304
+ readonly 'liquid-glow': "0 0 20px rgba(124, 58, 237, 0.30), 0 0 40px rgba(168, 85, 247, 0.15)";
305
+ readonly 'liquid-glow-sm': "0 0 12px rgba(124, 58, 237, 0.25)";
306
+ readonly 'liquid-glow-lg': "0 0 40px rgba(124, 58, 237, 0.40), 0 0 80px rgba(168, 85, 247, 0.20)";
307
+ readonly 'liquid-glow-primary': "0 0 24px rgba(124, 58, 237, 0.35), 0 4px 16px rgba(124, 58, 237, 0.20)";
308
+ readonly 'liquid-neon': "0 0 15px rgba(124, 58, 237, 0.50), 0 0 30px rgba(168, 85, 247, 0.25)";
309
+ readonly 'liquid-inner': "inset 0 1px 0 0 rgba(167, 139, 250, 0.08)";
271
310
  };
272
311
  type Shadows = typeof shadows;
273
312
 
@@ -375,6 +414,49 @@ declare const animation: {
375
414
  readonly transform: "translateY(0)";
376
415
  };
377
416
  };
417
+ readonly 'liquid-reveal': {
418
+ readonly from: {
419
+ readonly opacity: "0";
420
+ readonly transform: "translateY(8px) scale(0.98)";
421
+ readonly filter: "blur(4px)";
422
+ };
423
+ readonly to: {
424
+ readonly opacity: "1";
425
+ readonly transform: "translateY(0) scale(1)";
426
+ readonly filter: "blur(0)";
427
+ };
428
+ };
429
+ readonly 'liquid-fade': {
430
+ readonly from: {
431
+ readonly opacity: "0";
432
+ readonly backdropFilter: "blur(0px)";
433
+ };
434
+ readonly to: {
435
+ readonly opacity: "1";
436
+ readonly backdropFilter: "blur(40px)";
437
+ };
438
+ };
439
+ readonly 'liquid-glow-pulse': {
440
+ readonly '0%, 100%': {
441
+ readonly opacity: "0.3";
442
+ readonly boxShadow: "0 0 20px rgba(124, 58, 237, 0.20)";
443
+ };
444
+ readonly '50%': {
445
+ readonly opacity: "0.6";
446
+ readonly boxShadow: "0 0 40px rgba(124, 58, 237, 0.40)";
447
+ };
448
+ };
449
+ readonly 'grain-drift': {
450
+ readonly '0%': {
451
+ readonly transform: "translate(0, 0)";
452
+ };
453
+ readonly '50%': {
454
+ readonly transform: "translate(-2%, -1%)";
455
+ };
456
+ readonly '100%': {
457
+ readonly transform: "translate(0, 0)";
458
+ };
459
+ };
378
460
  };
379
461
  readonly durations: {
380
462
  readonly fast: "150ms";
@@ -1,4 +1,4 @@
1
- export { animation, borderRadius, colors, fontFamily, fontSize, fontWeight, shadows } from '../chunk-HZXKUGFH.js';
1
+ export { animation, borderRadius, colors, fontFamily, fontSize, fontWeight, shadows } from '../chunk-UGX6D3AO.js';
2
2
 
3
3
  // src/tokens/spacing.ts
4
4
  var spacing = {
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "organify-ui",
3
- "version": "0.2.16",
4
- "description": "Organify Design System — Geometric glass-morphism UI components, branded icons, i18n, and theme system for React",
3
+ "version": "0.3.2",
4
+ "description": "Organify Design System — Liquid Glass UI components with glassmorphism, branded icons, i18n, and theme system for React",
5
5
  "license": "MIT",
6
6
  "author": "Organify <dev@organify.studio>",
7
7
  "homepage": "https://github.com/organify/organify/tree/main/packages/ui#readme",