lecom-ui 2.0.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 (43) hide show
  1. package/README.md +1 -0
  2. package/dist/components/Button/Button.js +140 -0
  3. package/dist/index.d.ts +163 -0
  4. package/dist/index.js +3 -0
  5. package/dist/lib/utils.js +8 -0
  6. package/dist/plugin/extend.ts +51 -0
  7. package/dist/plugin/fontFaces.ts +172 -0
  8. package/dist/plugin/general.ts +12 -0
  9. package/dist/plugin/plugin.cjs +5 -0
  10. package/dist/plugin/pluginDev.cjs +5 -0
  11. package/dist/plugin/template.ts +31 -0
  12. package/dist/plugin/typographies.ts +106 -0
  13. package/dist/plugin/varsTheme.ts +57 -0
  14. package/dist/public/fonts/Ibm/bold-700-italic.woff2 +0 -0
  15. package/dist/public/fonts/Ibm/bold-700.woff2 +0 -0
  16. package/dist/public/fonts/Ibm/light-300-italic.woff2 +0 -0
  17. package/dist/public/fonts/Ibm/light-300.woff2 +0 -0
  18. package/dist/public/fonts/Ibm/medium-500-italic.woff2 +0 -0
  19. package/dist/public/fonts/Ibm/medium-500.woff2 +0 -0
  20. package/dist/public/fonts/Ibm/regular-400-italic.woff2 +0 -0
  21. package/dist/public/fonts/Ibm/regular-400.woff2 +0 -0
  22. package/dist/public/fonts/Ibm/thin-100-italic.woff2 +0 -0
  23. package/dist/public/fonts/Ibm/thin-100.woff2 +0 -0
  24. package/dist/public/fonts/Montserrat/italic.woff2 +0 -0
  25. package/dist/public/fonts/Montserrat/normal.woff2 +0 -0
  26. package/dist/public/fonts/Roboto/black-900-italic.woff2 +0 -0
  27. package/dist/public/fonts/Roboto/black-900.woff2 +0 -0
  28. package/dist/public/fonts/Roboto/bold-700-italic.woff2 +0 -0
  29. package/dist/public/fonts/Roboto/bold-700.woff2 +0 -0
  30. package/dist/public/fonts/Roboto/light-300-italic.woff2 +0 -0
  31. package/dist/public/fonts/Roboto/light-300.woff2 +0 -0
  32. package/dist/public/fonts/Roboto/medium-500-italic.woff2 +0 -0
  33. package/dist/public/fonts/Roboto/medium-500.woff2 +0 -0
  34. package/dist/public/fonts/Roboto/regular-400-italic.woff2 +0 -0
  35. package/dist/public/fonts/Roboto/regular-400.woff2 +0 -0
  36. package/dist/public/fonts/Roboto/thin-100-italic.woff2 +0 -0
  37. package/dist/public/fonts/Roboto/thin-100.woff2 +0 -0
  38. package/dist/public/img/logo-lecom-ui.png +0 -0
  39. package/dist/public/img/logo-lecom.png +0 -0
  40. package/dist/style.min.css +1 -0
  41. package/dist/tokens/colors.js +125 -0
  42. package/dist/tokens/fonts.js +7 -0
  43. package/package.json +87 -0
package/README.md ADDED
@@ -0,0 +1 @@
1
+ lecom-ui
@@ -0,0 +1,140 @@
1
+ import * as React from 'react';
2
+ import { cn } from '../../lib/utils.js';
3
+ import { cva } from 'class-variance-authority';
4
+
5
+ const buttonVariants = cva(
6
+ "flex items-center justify-center gap-2 rounded-full font-roboto font-medium shadow-sm outline-none transition-all duration-300",
7
+ {
8
+ variants: {
9
+ variant: {
10
+ filled: "",
11
+ outlined: "",
12
+ tonal: "",
13
+ ghost: ""
14
+ },
15
+ size: {
16
+ small: "h-8 px-3 py-2 text-sm leading-none [&>svg]:w-5 [&>svg]:h-5",
17
+ medium: "h-10 px-4 py-3 text-sm leading-none [&>svg]:w-5 [&>svg]:h-5",
18
+ large: "h-12 px-5 py-4 text-base leading-none [&>svg]:w-5 [&>svg]:h-5",
19
+ extraLarge: "h-14 px-6 py-5 text-base leading-none [&>svg]:w-6 [&>svg]:h-6"
20
+ },
21
+ color: {
22
+ blue: "",
23
+ grey: "",
24
+ destructive: ""
25
+ },
26
+ iconButton: {
27
+ false: "",
28
+ true: ""
29
+ }
30
+ },
31
+ compoundVariants: [
32
+ {
33
+ variant: "filled",
34
+ color: "blue",
35
+ class: "bg-blue-600 text-white hover:bg-blue-700 focus:ring-4 focus:ring-blue-200 active:bg-blue-800 disabled:bg-blue-100 disabled:text-blue-400 disabled:cursor-not-allowed"
36
+ },
37
+ {
38
+ variant: "outlined",
39
+ color: "blue",
40
+ class: "bg-white text-blue-600 border border-blue-600 hover:bg-blue-100 focus:ring-4 focus:ring-blue-200 active:bg-blue-300 disabled:bg-white disabled:border-blue-200 disabled:text-blue-200 disabled:cursor-not-allowed"
41
+ },
42
+ {
43
+ variant: "tonal",
44
+ color: "blue",
45
+ class: "bg-blue-50 text-blue-600 shadow-none hover:bg-blue-100 focus:ring-4 focus:ring-blue-200 active:bg-blue-300 disabled:bg-blue-50 disabled:text-blue-200 disabled:cursor-not-allowed"
46
+ },
47
+ {
48
+ variant: "ghost",
49
+ color: "blue",
50
+ class: "bg-transparent text-blue-600 shadow-none hover:bg-blue-100 active:bg-blue-300 disabled:bg-transparent disabled:text-blue-200 disabled:cursor-not-allowed"
51
+ },
52
+ {
53
+ variant: "filled",
54
+ color: "grey",
55
+ class: "bg-grey-600 text-white hover:bg-grey-800 focus:ring-4 focus:ring-grey-200 focus:ring-opacity-30 active:bg-grey-900 disabled:bg-grey-200 disabled:text-grey-800 disabled:cursor-not-allowed"
56
+ },
57
+ {
58
+ variant: "outlined",
59
+ color: "grey",
60
+ class: "bg-white text-grey-800 border border-grey-600 hover:bg-grey-50 focus:ring-4 focus:ring-grey-200 focus:ring-opacity-30 active:bg-grey-200 disabled:bg-white disabled:border-grey-300 disabled:text-grey-300 disabled:cursor-not-allowed"
61
+ },
62
+ {
63
+ variant: "tonal",
64
+ color: "grey",
65
+ class: "bg-grey-50 text-grey-800 shadow-none hover:bg-grey-200 focus:ring-4 focus:ring-grey-200 focus:ring-opacity-30 active:bg-grey-400 disabled:bg-grey-50 disabled:text-grey-300 disabled:cursor-not-allowed"
66
+ },
67
+ {
68
+ variant: "ghost",
69
+ color: "grey",
70
+ class: "bg-transparent text-grey-800 shadow-none hover:bg-grey-200 active:bg-grey-400 disabled:bg-transparent disabled:text-grey-300 disabled:cursor-not-allowed"
71
+ },
72
+ {
73
+ variant: "filled",
74
+ color: "destructive",
75
+ class: "bg-red-600 text-white hover:bg-red-700 focus:ring-4 focus:ring-red-200 active:bg-red-800 disabled:bg-red-100 disabled:cursor-not-allowed"
76
+ },
77
+ {
78
+ variant: "outlined",
79
+ color: "destructive",
80
+ class: "bg-white text-red-600 border border-red-600 hover:bg-red-100 focus:ring-4 focus:ring-red-200 active:bg-red-300 disabled:bg-white disabled:border-red-200 disabled:text-red-100 disabled:cursor-not-allowed"
81
+ },
82
+ {
83
+ variant: "tonal",
84
+ color: "destructive",
85
+ class: "bg-red-50 text-red-600 shadow-none hover:bg-red-100 focus:ring-4 focus:ring-red-200 active:bg-red-300 disabled:bg-red-50 disabled:text-red-200 disabled:cursor-not-allowed"
86
+ },
87
+ {
88
+ variant: "ghost",
89
+ color: "destructive",
90
+ class: "bg-transparent text-red-600 shadow-none hover:bg-red-100 active:bg-red-300 disabled:bg-transparent disabled:text-red-200 disabled:cursor-not-allowed"
91
+ },
92
+ {
93
+ iconButton: true,
94
+ size: "small",
95
+ class: "rounded-full w-8 h-8 p-0"
96
+ },
97
+ {
98
+ iconButton: true,
99
+ size: "medium",
100
+ class: "rounded-full w-10 h-10 p-0"
101
+ },
102
+ {
103
+ iconButton: true,
104
+ size: "large",
105
+ class: "rounded-full w-12 h-12 p-0"
106
+ },
107
+ {
108
+ iconButton: true,
109
+ size: "extraLarge",
110
+ class: "rounded-full w-14 h-14 p-0"
111
+ }
112
+ ],
113
+ defaultVariants: {
114
+ variant: "filled",
115
+ size: "medium",
116
+ color: "blue",
117
+ iconButton: false
118
+ }
119
+ }
120
+ );
121
+ const Button = React.forwardRef(
122
+ ({ className, variant, size, color, iconButton, children, ...props }, ref) => {
123
+ const Comp = "button";
124
+ return /* @__PURE__ */ React.createElement(
125
+ Comp,
126
+ {
127
+ className: cn(
128
+ buttonVariants({ variant, size, color, iconButton, className }),
129
+ ""
130
+ ),
131
+ ref,
132
+ ...props
133
+ },
134
+ children
135
+ );
136
+ }
137
+ );
138
+ Button.displayName = "Button";
139
+
140
+ export { Button, buttonVariants };
@@ -0,0 +1,163 @@
1
+ import * as class_variance_authority_types from 'class-variance-authority/types';
2
+ import * as React from 'react';
3
+ import { VariantProps } from 'class-variance-authority';
4
+
5
+ type Transparent = 'transparent';
6
+ type Black = 'black';
7
+ type White = 'white';
8
+ type Blue = 'blue-50' | 'blue-100' | 'blue-200' | 'blue-300' | 'blue-400' | 'blue-500' | 'blue-600' | 'blue-700' | 'blue-800' | 'blue-900' | 'blue-950';
9
+ type Grey = 'grey-50' | 'grey-100' | 'grey-200' | 'grey-300' | 'grey-400' | 'grey-500' | 'grey-600' | 'grey-700' | 'grey-800' | 'grey-900' | 'grey-950';
10
+ type Red = 'red-50' | 'red-100' | 'red-200' | 'red-300' | 'red-400' | 'red-500' | 'red-600' | 'red-700' | 'red-800' | 'red-900' | 'red-950';
11
+ type Yellow = 'yellow-50' | 'yellow-100' | 'yellow-200' | 'yellow-300' | 'yellow-400' | 'yellow-500' | 'yellow-600' | 'yellow-700' | 'yellow-800' | 'yellow-900' | 'yellow-950';
12
+ type Orange = 'orange-50' | 'orange-100' | 'orange-200' | 'orange-300' | 'orange-400' | 'orange-500' | 'orange-600' | 'orange-700' | 'orange-800' | 'orange-900' | 'orange-950';
13
+ type Purple = 'purple-50' | 'purple-100' | 'purple-200' | 'purple-300' | 'purple-400' | 'purple-500' | 'purple-600' | 'purple-700' | 'purple-800' | 'purple-900' | 'purple-950';
14
+ type Green = 'green-50' | 'green-100' | 'green-200' | 'green-300' | 'green-400' | 'green-500' | 'green-600' | 'green-700' | 'green-800' | 'green-900' | 'green-950';
15
+ type Pink = 'pink-50' | 'pink-100' | 'pink-200' | 'pink-300' | 'pink-400' | 'pink-500' | 'pink-600' | 'pink-700' | 'pink-800' | 'pink-900' | 'pink-950';
16
+ type Turquoise = 'turquoise-50' | 'turquoise-100' | 'turquoise-200' | 'turquoise-300' | 'turquoise-400' | 'turquoise-500' | 'turquoise-600' | 'turquoise-700' | 'turquoise-800' | 'turquoise-900' | 'turquoise-950';
17
+ type ColorToken = Transparent | Black | White | Blue | Grey | Red | Yellow | Orange | Purple | Green | Pink | Turquoise;
18
+ type TextColor = `text-${ColorToken}`;
19
+ type BgColor = `bg-${ColorToken}`;
20
+ type FillColor = `fill-${ColorToken}`;
21
+ type Color = 'transparent' | 'black' | 'white' | 'blue' | 'grey' | 'red' | 'yellow' | 'orange' | 'purple' | 'green' | 'pink' | 'turquoise';
22
+ declare const colors: {
23
+ transparent: string;
24
+ current: string;
25
+ black: string;
26
+ white: string;
27
+ blue: {
28
+ 50: string;
29
+ 100: string;
30
+ 200: string;
31
+ 300: string;
32
+ 400: string;
33
+ 500: string;
34
+ 600: string;
35
+ 700: string;
36
+ 800: string;
37
+ 900: string;
38
+ 950: string;
39
+ };
40
+ grey: {
41
+ 50: string;
42
+ 100: string;
43
+ 200: string;
44
+ 300: string;
45
+ 400: string;
46
+ 500: string;
47
+ 600: string;
48
+ 700: string;
49
+ 800: string;
50
+ 900: string;
51
+ 950: string;
52
+ };
53
+ red: {
54
+ 50: string;
55
+ 100: string;
56
+ 200: string;
57
+ 300: string;
58
+ 400: string;
59
+ 500: string;
60
+ 600: string;
61
+ 700: string;
62
+ 800: string;
63
+ 900: string;
64
+ 950: string;
65
+ };
66
+ yellow: {
67
+ 50: string;
68
+ 100: string;
69
+ 200: string;
70
+ 300: string;
71
+ 400: string;
72
+ 500: string;
73
+ 600: string;
74
+ 700: string;
75
+ 800: string;
76
+ 900: string;
77
+ 950: string;
78
+ };
79
+ orange: {
80
+ 50: string;
81
+ 100: string;
82
+ 200: string;
83
+ 300: string;
84
+ 400: string;
85
+ 500: string;
86
+ 600: string;
87
+ 700: string;
88
+ 800: string;
89
+ 900: string;
90
+ 950: string;
91
+ };
92
+ purple: {
93
+ 50: string;
94
+ 100: string;
95
+ 200: string;
96
+ 300: string;
97
+ 400: string;
98
+ 500: string;
99
+ 600: string;
100
+ 700: string;
101
+ 800: string;
102
+ 900: string;
103
+ 950: string;
104
+ };
105
+ green: {
106
+ 50: string;
107
+ 100: string;
108
+ 200: string;
109
+ 300: string;
110
+ 400: string;
111
+ 500: string;
112
+ 600: string;
113
+ 700: string;
114
+ 800: string;
115
+ 900: string;
116
+ 950: string;
117
+ };
118
+ pink: {
119
+ 50: string;
120
+ 100: string;
121
+ 200: string;
122
+ 300: string;
123
+ 400: string;
124
+ 500: string;
125
+ 600: string;
126
+ 700: string;
127
+ 800: string;
128
+ 900: string;
129
+ 950: string;
130
+ };
131
+ turquoise: {
132
+ 50: string;
133
+ 100: string;
134
+ 200: string;
135
+ 300: string;
136
+ 400: string;
137
+ 500: string;
138
+ 600: string;
139
+ 700: string;
140
+ 800: string;
141
+ 900: string;
142
+ 950: string;
143
+ };
144
+ };
145
+
146
+ type Fonts = 'roboto' | 'montserrat' | 'ibm';
147
+ declare const fonts: {
148
+ roboto: string[];
149
+ montserrat: string[];
150
+ ibm: string[];
151
+ };
152
+
153
+ declare const buttonVariants: (props?: ({
154
+ variant?: "filled" | "outlined" | "tonal" | "ghost" | null | undefined;
155
+ size?: "small" | "medium" | "large" | "extraLarge" | null | undefined;
156
+ color?: "blue" | "grey" | "destructive" | null | undefined;
157
+ iconButton?: boolean | null | undefined;
158
+ } & class_variance_authority_types.ClassProp) | undefined) => string;
159
+ interface ButtonProps extends Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'color'>, VariantProps<typeof buttonVariants> {
160
+ }
161
+ declare const Button: React.ForwardRefExoticComponent<ButtonProps & React.RefAttributes<HTMLButtonElement>>;
162
+
163
+ export { type BgColor, Button, type ButtonProps, type Color, type ColorToken, type FillColor, type Fonts, type TextColor, buttonVariants, colors, fonts };
package/dist/index.js ADDED
@@ -0,0 +1,3 @@
1
+ export { colors } from './tokens/colors.js';
2
+ export { fonts } from './tokens/fonts.js';
3
+ export { Button, buttonVariants } from './components/Button/Button.js';
@@ -0,0 +1,8 @@
1
+ import { clsx } from 'clsx';
2
+ import { twMerge } from 'tailwind-merge';
3
+
4
+ function cn(...inputs) {
5
+ return twMerge(clsx(inputs));
6
+ }
7
+
8
+ export { cn };
@@ -0,0 +1,51 @@
1
+ const extend = {
2
+ colors: {
3
+ background: 'hsl(var(--background))',
4
+ foreground: 'hsl(var(--foreground))',
5
+ card: {
6
+ DEFAULT: 'hsl(var(--card))',
7
+ foreground: 'hsl(var(--card-foreground))',
8
+ },
9
+ popover: {
10
+ DEFAULT: 'hsl(var(--popover))',
11
+ foreground: 'hsl(var(--popover-foreground))',
12
+ },
13
+ primary: {
14
+ DEFAULT: 'hsl(var(--primary))',
15
+ foreground: 'hsl(var(--primary-foreground))',
16
+ },
17
+ secondary: {
18
+ DEFAULT: 'hsl(var(--secondary))',
19
+ foreground: 'hsl(var(--secondary-foreground))',
20
+ },
21
+ muted: {
22
+ DEFAULT: 'hsl(var(--muted))',
23
+ foreground: 'hsl(var(--muted-foreground))',
24
+ },
25
+ accent: {
26
+ DEFAULT: 'hsl(var(--accent))',
27
+ foreground: 'hsl(var(--accent-foreground))',
28
+ },
29
+ destructive: {
30
+ DEFAULT: 'hsl(var(--destructive))',
31
+ foreground: 'hsl(var(--destructive-foreground))',
32
+ },
33
+ border: 'hsl(var(--border))',
34
+ input: 'hsl(var(--input))',
35
+ ring: 'hsl(var(--ring))',
36
+ chart: {
37
+ 1: 'hsl(var(--chart-1))',
38
+ 2: 'hsl(var(--chart-2))',
39
+ 3: 'hsl(var(--chart-3))',
40
+ 4: 'hsl(var(--chart-4))',
41
+ 5: 'hsl(var(--chart-5))',
42
+ },
43
+ },
44
+ borderRadius: {
45
+ lg: 'var(--radius)',
46
+ md: 'calc(var(--radius) - 2px)',
47
+ sm: 'calc(var(--radius) - 4px)',
48
+ },
49
+ };
50
+
51
+ export { extend };
@@ -0,0 +1,172 @@
1
+ const fontFaces = (publicPath: string) => [
2
+ {
3
+ fontFamily: 'Roboto',
4
+ fontStyle: 'italic',
5
+ fontWeight: '100',
6
+ fontDisplay: 'swap',
7
+ src: `url('${publicPath}/fonts/Roboto/thin-100-italic.woff2')`,
8
+ },
9
+ {
10
+ fontFamily: 'Roboto',
11
+ fontStyle: 'italic',
12
+ fontWeight: '300',
13
+ fontDisplay: 'swap',
14
+ src: `url('${publicPath}/fonts/Roboto/light-300-italic.woff2')`,
15
+ },
16
+ {
17
+ fontFamily: 'Roboto',
18
+ fontStyle: 'italic',
19
+ fontWeight: '400',
20
+ fontDisplay: 'swap',
21
+ src: `url('${publicPath}/fonts/Roboto/regular-400-italic.woff2')`,
22
+ },
23
+ {
24
+ fontFamily: 'Roboto',
25
+ fontStyle: 'italic',
26
+ fontWeight: '500',
27
+ fontDisplay: 'swap',
28
+ src: `url('${publicPath}/fonts/Roboto/medium-500-italic.woff2')`,
29
+ },
30
+ {
31
+ fontFamily: 'Roboto',
32
+ fontStyle: 'italic',
33
+ fontWeight: '700',
34
+ fontDisplay: 'swap',
35
+ src: `url('${publicPath}/fonts/Roboto/bold-700-italic.woff2')`,
36
+ },
37
+ {
38
+ fontFamily: 'Roboto',
39
+ fontStyle: 'italic',
40
+ fontWeight: '900',
41
+ fontDisplay: 'swap',
42
+ src: `url('${publicPath}/fonts/Roboto/black-900-italic.woff2')`,
43
+ },
44
+ {
45
+ fontFamily: 'Roboto',
46
+ fontStyle: 'normal',
47
+ fontWeight: '100',
48
+ fontDisplay: 'swap',
49
+ src: `url('${publicPath}/fonts/Roboto/thin-100.woff2')`,
50
+ },
51
+ {
52
+ fontFamily: 'Roboto',
53
+ fontStyle: 'normal',
54
+ fontWeight: '300',
55
+ fontDisplay: 'swap',
56
+ src: `url('${publicPath}/fonts/Roboto/light-300.woff2')`,
57
+ },
58
+ {
59
+ fontFamily: 'Roboto',
60
+ fontStyle: 'normal',
61
+ fontWeight: '400',
62
+ fontDisplay: 'swap',
63
+ src: `url('${publicPath}/fonts/Roboto/regular-400.woff2')`,
64
+ },
65
+ {
66
+ fontFamily: 'Roboto',
67
+ fontStyle: 'normal',
68
+ fontWeight: '500',
69
+ fontDisplay: 'swap',
70
+ src: `url('${publicPath}/fonts/Roboto/medium-500.woff2')`,
71
+ },
72
+ {
73
+ fontFamily: 'Roboto',
74
+ fontStyle: 'normal',
75
+ fontWeight: '700',
76
+ fontDisplay: 'swap',
77
+ src: `url('${publicPath}/fonts/Roboto/bold-700.woff2')`,
78
+ },
79
+ {
80
+ fontFamily: 'Roboto',
81
+ fontStyle: 'normal',
82
+ fontWeight: '900',
83
+ fontDisplay: 'swap',
84
+ src: `url('${publicPath}/fonts/Roboto/black-900.woff2')`,
85
+ },
86
+ {
87
+ fontFamily: 'Montserrat',
88
+ fontStyle: 'italic',
89
+ fontWeight: '100 900',
90
+ fontDisplay: 'swap',
91
+ src: `url('${publicPath}/fonts/Montserrat/italic.woff2')`,
92
+ },
93
+ {
94
+ fontFamily: 'Montserrat',
95
+ fontStyle: 'normal',
96
+ fontWeight: '100 900',
97
+ fontDisplay: 'swap',
98
+ src: `url('${publicPath}/fonts/Montserrat/normal.woff2')`,
99
+ },
100
+ {
101
+ fontFamily: 'IBM Plex Mono',
102
+ fontStyle: 'italic',
103
+ fontWeight: '100',
104
+ fontDisplay: 'swap',
105
+ src: `url('${publicPath}/fonts/Ibm/thin-100-italic.woff2')`,
106
+ },
107
+ {
108
+ fontFamily: 'IBM Plex Mono',
109
+ fontStyle: 'italic',
110
+ fontWeight: '300',
111
+ fontDisplay: 'swap',
112
+ src: `url('${publicPath}/fonts/Ibm/light-300-italic.woff2')`,
113
+ },
114
+ {
115
+ fontFamily: 'IBM Plex Mono',
116
+ fontStyle: 'italic',
117
+ fontWeight: '400',
118
+ fontDisplay: 'swap',
119
+ src: `url('${publicPath}/fonts/Ibm/regular-400-italic.woff2')`,
120
+ },
121
+ {
122
+ fontFamily: 'IBM Plex Mono',
123
+ fontStyle: 'italic',
124
+ fontWeight: '500',
125
+ fontDisplay: 'swap',
126
+ src: `url('${publicPath}/fonts/Ibm/medium-500-italic.woff2')`,
127
+ },
128
+ {
129
+ fontFamily: 'IBM Plex Mono',
130
+ fontStyle: 'italic',
131
+ fontWeight: '700',
132
+ fontDisplay: 'swap',
133
+ src: `url('${publicPath}/fonts/Ibm/bold-700-italic.woff2')`,
134
+ },
135
+ {
136
+ fontFamily: 'IBM Plex Mono',
137
+ fontStyle: 'normal',
138
+ fontWeight: '100',
139
+ fontDisplay: 'swap',
140
+ src: `url('${publicPath}/fonts/Ibm/thin-100.woff2')`,
141
+ },
142
+ {
143
+ fontFamily: 'IBM Plex Mono',
144
+ fontStyle: 'normal',
145
+ fontWeight: '300',
146
+ fontDisplay: 'swap',
147
+ src: `url('${publicPath}/fonts/Ibm/light-300.woff2')`,
148
+ },
149
+ {
150
+ fontFamily: 'IBM Plex Mono',
151
+ fontStyle: 'normal',
152
+ fontWeight: '400',
153
+ fontDisplay: 'swap',
154
+ src: `url('${publicPath}/fonts/Ibm/regular-400.woff2')`,
155
+ },
156
+ {
157
+ fontFamily: 'IBM Plex Mono',
158
+ fontStyle: 'normal',
159
+ fontWeight: '500',
160
+ fontDisplay: 'swap',
161
+ src: `url('${publicPath}/fonts/Ibm/medium-500.woff2')`,
162
+ },
163
+ {
164
+ fontFamily: 'IBM Plex Mono',
165
+ fontStyle: 'normal',
166
+ fontWeight: '700',
167
+ fontDisplay: 'swap',
168
+ src: `url('${publicPath}/fonts/Ibm/bold-700.woff2')`,
169
+ },
170
+ ];
171
+
172
+ export { fontFaces };
@@ -0,0 +1,12 @@
1
+ const general = {
2
+ '*': {
3
+ borderColor: 'hsl(var(--border))',
4
+ },
5
+ body: {
6
+ backgroundColor: 'hsl(var(--background))',
7
+ fontFamily: 'Roboto, sans-serif',
8
+ color: 'hsl(var(--foreground))',
9
+ },
10
+ };
11
+
12
+ export { general };
@@ -0,0 +1,5 @@
1
+ /* eslint-disable @typescript-eslint/no-require-imports */
2
+
3
+ const buildPlugin = require('./template').buildPlugin;
4
+
5
+ module.exports = buildPlugin('~/node_modules/lecom-ui/dist/public');
@@ -0,0 +1,5 @@
1
+ /* eslint-disable @typescript-eslint/no-require-imports */
2
+
3
+ const buildPlugin = require('./template').buildPlugin;
4
+
5
+ module.exports = buildPlugin('../public');
@@ -0,0 +1,31 @@
1
+ import Plugin from 'tailwindcss/plugin';
2
+
3
+ import { colors } from '../tokens/colors';
4
+ import { fonts } from '../tokens/fonts';
5
+
6
+ import { extend } from './extend';
7
+ import { fontFaces } from './fontFaces';
8
+ import { general } from './general';
9
+ import { typographies } from './typographies';
10
+ import { varsTheme } from './varsTheme';
11
+
12
+ const buildPlugin = (publicPath: string) =>
13
+ Plugin(
14
+ ({ addBase, addComponents }) => {
15
+ addBase(varsTheme);
16
+ fontFaces(publicPath).map((fontFace) =>
17
+ addBase({ '@font-face': fontFace })
18
+ );
19
+ addBase(general);
20
+ addComponents(typographies);
21
+ },
22
+ {
23
+ theme: {
24
+ fontFamily: fonts,
25
+ colors,
26
+ extend,
27
+ },
28
+ }
29
+ );
30
+
31
+ export { buildPlugin };
@@ -0,0 +1,106 @@
1
+ const typographies = {
2
+ '.heading-xxlarge-500': {
3
+ fontFamily: 'Montserrat, sans-serif',
4
+ fontSize: '3rem',
5
+ fontWeight: '500',
6
+ lineHeight: '3.25rem',
7
+ },
8
+ '.heading-xlarge-500': {
9
+ fontFamily: 'Montserrat, sans-serif',
10
+ fontSize: '2.5rem',
11
+ fontWeight: '500',
12
+ lineHeight: '2.75rem',
13
+ },
14
+ '.heading-large-500': {
15
+ fontFamily: 'Montserrat, sans-serif',
16
+ fontSize: '2rem',
17
+ fontWeight: '500',
18
+ lineHeight: '2.25rem',
19
+ },
20
+ '.heading-medium-500': {
21
+ fontFamily: 'Montserrat, sans-serif',
22
+ fontSize: '1.5rem',
23
+ fontWeight: '500',
24
+ lineHeight: '1.75rem',
25
+ },
26
+ '.heading-small-500': {
27
+ fontFamily: 'Montserrat, sans-serif',
28
+ fontSize: '1.25rem',
29
+ fontWeight: '500',
30
+ lineHeight: '1.5rem',
31
+ },
32
+ '.heading-xsmall-500': {
33
+ fontFamily: 'Montserrat, sans-serif',
34
+ fontSize: '1rem',
35
+ fontWeight: '500',
36
+ lineHeight: '1.25rem',
37
+ },
38
+ '.heading-xxsmall-500': {
39
+ fontFamily: 'Montserrat, sans-serif',
40
+ fontSize: '0.875rem',
41
+ lineHeight: '1.25rem',
42
+ fontWeight: '500',
43
+ },
44
+ '.body-large-700': {
45
+ fontFamily: 'Roboto, sans-serif',
46
+ fontSize: '1rem',
47
+ lineHeight: '1.5rem',
48
+ fontWeight: '700',
49
+ },
50
+ '.body-large-500': {
51
+ fontFamily: 'Roboto, sans-serif',
52
+ fontSize: '1rem',
53
+ lineHeight: '1.5rem',
54
+ fontWeight: '500',
55
+ },
56
+ '.body-large-400': {
57
+ fontFamily: 'Roboto, sans-serif',
58
+ fontSize: '1rem',
59
+ lineHeight: '1.5rem',
60
+ fontWeight: '400',
61
+ },
62
+ '.body-medium-700': {
63
+ fontFamily: 'Roboto, sans-serif',
64
+ fontSize: '0.875rem',
65
+ lineHeight: '1.25rem',
66
+ fontWeight: '700',
67
+ },
68
+ '.body-medium-500': {
69
+ fontFamily: 'Roboto, sans-serif',
70
+ fontSize: '0.875rem',
71
+ lineHeight: '1.25rem',
72
+ fontWeight: '500',
73
+ },
74
+ '.body-medium-400': {
75
+ fontFamily: 'Roboto, sans-serif',
76
+ fontSize: '0.875rem',
77
+ lineHeight: '1.25rem',
78
+ fontWeight: '400',
79
+ },
80
+ '.body-small-700': {
81
+ fontFamily: 'Roboto, sans-serif',
82
+ fontSize: '0.75rem',
83
+ lineHeight: '1rem',
84
+ fontWeight: '700',
85
+ },
86
+ '.body-small-500': {
87
+ fontFamily: 'Roboto, sans-serif',
88
+ fontSize: '0.75rem',
89
+ lineHeight: '1rem',
90
+ fontWeight: '500',
91
+ },
92
+ '.body-small-400': {
93
+ fontFamily: 'Roboto, sans-serif',
94
+ fontSize: '0.75rem',
95
+ lineHeight: '1rem',
96
+ fontWeight: '400',
97
+ },
98
+ '.code-medium-400': {
99
+ fontFamily: 'IBM Plex Mono, sans-serif',
100
+ fontSize: '0.875rem',
101
+ lineHeight: '1.25rem',
102
+ fontWeight: '400',
103
+ },
104
+ };
105
+
106
+ export { typographies };
@@ -0,0 +1,57 @@
1
+ const varsTheme = {
2
+ ':root': {
3
+ '--background': '0 0% 100%',
4
+ '--foreground': '0 0% 14.9%',
5
+ '--card': '0 0% 100%',
6
+ '--card-foreground': '0 0% 3.9%',
7
+ '--popover': '0 0% 100%',
8
+ '--popover-foreground': '0 0% 14.9%',
9
+ '--primary': '0 0% 9%',
10
+ '--primary-foreground': '0 0% 98%',
11
+ '--secondary': '0 0% 96.1%',
12
+ '--secondary-foreground': '0 0% 9%',
13
+ '--muted': '0 0% 96.1%',
14
+ '--muted-foreground': '0 0% 45.1%',
15
+ '--accent': '0 0% 96.1%',
16
+ '--accent-foreground': '0 0% 9%',
17
+ '--destructive': '0 84.2% 60.2%',
18
+ '--destructive-foreground': '0 0% 98%',
19
+ '--border': '0 0% 89.8%',
20
+ '--input': '0 0% 89.8%',
21
+ '--ring': '0 0% 3.9%',
22
+ '--chart-1': '12 76% 61%',
23
+ '--chart-2': '173 58% 39%',
24
+ '--chart-3': '197 37% 24%',
25
+ '--chart-4': '43 74% 66%',
26
+ '--chart-5': '27 87% 67%',
27
+ '--radius': '0.5rem',
28
+ },
29
+ '.dark': {
30
+ '--background': '0 0% 3.9%',
31
+ '--foreground': '0 0% 98%',
32
+ '--card': '0 0% 3.9%',
33
+ '--card-foreground': '0 0% 98%',
34
+ '--popover': '0 0% 3.9%',
35
+ '--popover-foreground': '0 0% 98%',
36
+ '--primary': '0 0% 98%',
37
+ '--primary-foreground': '0 0% 9%',
38
+ '--secondary': '0 0% 14.9%',
39
+ '--secondary-foreground': '0 0% 98%',
40
+ '--muted': '0 0% 14.9%',
41
+ '--muted-foreground': '0 0% 63.9%',
42
+ '--accent': '0 0% 14.9%',
43
+ '--accent-foreground': '0 0% 98%',
44
+ '--destructive': '0 62.8% 30.6%',
45
+ '--destructive-foreground': '0 0% 98%',
46
+ '--border': '0 0% 14.9%',
47
+ '--input': '0 0% 14.9%',
48
+ '--ring': '0 0% 83.1%',
49
+ '--chart-1': '220 70% 50%',
50
+ '--chart-2': '160 60% 45%',
51
+ '--chart-3': '30 80% 55%',
52
+ '--chart-4': '280 65% 60%',
53
+ '--chart-5': '340 75% 55%',
54
+ },
55
+ };
56
+
57
+ export { varsTheme };
Binary file
@@ -0,0 +1 @@
1
+ *,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(89,123,216,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(89,123,216,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*! tailwindcss v3.4.16 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background:0 0% 100%;--foreground:0 0% 14.9%;--card:0 0% 100%;--card-foreground:0 0% 3.9%;--popover:0 0% 100%;--popover-foreground:0 0% 14.9%;--primary:0 0% 9%;--primary-foreground:0 0% 98%;--secondary:0 0% 96.1%;--secondary-foreground:0 0% 9%;--muted:0 0% 96.1%;--muted-foreground:0 0% 45.1%;--accent:0 0% 96.1%;--accent-foreground:0 0% 9%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:0 0% 89.8%;--input:0 0% 89.8%;--ring:0 0% 3.9%;--chart-1:12 76% 61%;--chart-2:173 58% 39%;--chart-3:197 37% 24%;--chart-4:43 74% 66%;--chart-5:27 87% 67%;--radius:0.5rem}@font-face{font-family:Roboto;font-style:italic;font-weight:100;font-display:swap;src:url(../public/fonts/Roboto/thin-100-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:300;font-display:swap;src:url(../public/fonts/Roboto/light-300-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:400;font-display:swap;src:url(../public/fonts/Roboto/regular-400-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:500;font-display:swap;src:url(../public/fonts/Roboto/medium-500-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:700;font-display:swap;src:url(../public/fonts/Roboto/bold-700-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:900;font-display:swap;src:url(../public/fonts/Roboto/black-900-italic.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:100;font-display:swap;src:url(../public/fonts/Roboto/thin-100.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:300;font-display:swap;src:url(../public/fonts/Roboto/light-300.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:400;font-display:swap;src:url(../public/fonts/Roboto/regular-400.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:500;font-display:swap;src:url(../public/fonts/Roboto/medium-500.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:700;font-display:swap;src:url(../public/fonts/Roboto/bold-700.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:900;font-display:swap;src:url(../public/fonts/Roboto/black-900.woff2)}@font-face{font-family:Montserrat;font-style:italic;font-weight:100 900;font-display:swap;src:url(../public/fonts/Montserrat/italic.woff2)}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(../public/fonts/Montserrat/normal.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:100;font-display:swap;src:url(../public/fonts/Ibm/thin-100-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:300;font-display:swap;src:url(../public/fonts/Ibm/light-300-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:400;font-display:swap;src:url(../public/fonts/Ibm/regular-400-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:500;font-display:swap;src:url(../public/fonts/Ibm/medium-500-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:700;font-display:swap;src:url(../public/fonts/Ibm/bold-700-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:100;font-display:swap;src:url(../public/fonts/Ibm/thin-100.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:300;font-display:swap;src:url(../public/fonts/Ibm/light-300.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../public/fonts/Ibm/regular-400.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../public/fonts/Ibm/medium-500.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../public/fonts/Ibm/bold-700.woff2)}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));font-family:Roboto,sans-serif;color:hsl(var(--foreground))}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.heading-xxlarge-500{font-size:3rem;line-height:3.25rem}.heading-xlarge-500,.heading-xxlarge-500{font-family:Montserrat,sans-serif;font-weight:500}.heading-xlarge-500{font-size:2.5rem;line-height:2.75rem}.heading-large-500{font-size:2rem;line-height:2.25rem}.heading-large-500,.heading-medium-500{font-family:Montserrat,sans-serif;font-weight:500}.heading-medium-500{font-size:1.5rem;line-height:1.75rem}.heading-small-500{font-family:Montserrat,sans-serif;font-size:1.25rem;font-weight:500;line-height:1.5rem}.heading-xsmall-500{font-size:1rem}.heading-xsmall-500,.heading-xxsmall-500{font-family:Montserrat,sans-serif;font-weight:500;line-height:1.25rem}.heading-xxsmall-500{font-size:.875rem}.body-large-700{font-weight:700}.body-large-500,.body-large-700{font-family:Roboto,sans-serif;font-size:1rem;line-height:1.5rem}.body-large-500{font-weight:500}.body-large-400{font-family:Roboto,sans-serif;font-size:1rem;line-height:1.5rem;font-weight:400}.body-medium-700{font-weight:700}.body-medium-500,.body-medium-700{font-family:Roboto,sans-serif;font-size:.875rem;line-height:1.25rem}.body-medium-500{font-weight:500}.body-medium-400{font-family:Roboto,sans-serif;font-size:.875rem;line-height:1.25rem;font-weight:400}.body-small-700{font-weight:700}.body-small-500,.body-small-700{font-family:Roboto,sans-serif;font-size:.75rem;line-height:1rem}.body-small-500{font-weight:500}.body-small-400{font-family:Roboto,sans-serif;font-size:.75rem;line-height:1rem;font-weight:400}.code-medium-400{font-family:IBM Plex Mono,sans-serif;font-size:.875rem;line-height:1.25rem;font-weight:400}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.left-2{left:.5rem}.left-3{left:.75rem}.left-\[50\%\]{left:50%}.right-3{right:.75rem}.right-4{right:1rem}.top-4{top:1rem}.top-\[50\%\]{top:50%}.z-50{z-index:50}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.aspect-square{aspect-ratio:1/1}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-72{height:18rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[20px\]{height:20px}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.max-h-96{max-height:24rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-4{width:1rem}.w-40{width:10rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[100px\]{width:100px}.w-\[180px\]{width:180px}.w-\[200px\]{width:200px}.w-\[200x\]{width:200x}.w-\[250px\]{width:250px}.w-\[274px\]{width:274px}.w-\[800px\]{width:800px}.w-full{width:100%}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-80{max-width:20rem}.max-w-lg{max-width:32rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.translate-x-\[-50\%\]{--tw-translate-x:-50%}.translate-x-\[-50\%\],.translate-y-\[-50\%\]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y:-50%}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-12{gap:3rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem*var(--tw-space-x-reverse));margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem*var(--tw-space-x-reverse));margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem*var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-3xl{border-radius:1.5rem}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-l-md{border-top-left-radius:calc(var(--radius) - 2px);border-bottom-left-radius:calc(var(--radius) - 2px)}.rounded-l-none{border-top-left-radius:0;border-bottom-left-radius:0}.rounded-r-md{border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.rounded-r-none{border-top-right-radius:0;border-bottom-right-radius:0}.border{border-width:1px}.border-2{border-width:2px}.border-l{border-left-width:1px}.border-l-0{border-left-width:0}.border-l-2{border-left-width:2px}.border-r-0{border-right-width:0}.border-t{border-top-width:1px}.border-none{border-style:none}.border-blue-600{--tw-border-opacity:1;border-color:rgb(60 89 201/var(--tw-border-opacity,1))}.border-grey-100{--tw-border-opacity:1;border-color:rgb(245 245 245/var(--tw-border-opacity,1))}.border-grey-400{--tw-border-opacity:1;border-color:rgb(201 201 201/var(--tw-border-opacity,1))}.border-grey-600{--tw-border-opacity:1;border-color:rgb(122 122 122/var(--tw-border-opacity,1))}.border-input{border-color:hsl(var(--input))}.border-red-600{--tw-border-opacity:1;border-color:rgb(236 22 22/var(--tw-border-opacity,1))}.border-white{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-l-transparent{border-left-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-background{background-color:hsl(var(--background))}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-black\/80{background-color:rgba(0,0,0,.8)}.bg-blue-100{--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.bg-blue-200{--tw-bg-opacity:1;background-color:rgb(201 215 244/var(--tw-bg-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(242 245 252/var(--tw-bg-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(60 89 201/var(--tw-bg-opacity,1))}.bg-blue-800{--tw-bg-opacity:1;background-color:rgb(53 65 152/var(--tw-bg-opacity,1))}.bg-border{background-color:hsl(var(--border))}.bg-green-100{--tw-bg-opacity:1;background-color:rgb(212 247 231/var(--tw-bg-opacity,1))}.bg-grey-100{--tw-bg-opacity:1;background-color:rgb(245 245 245/var(--tw-bg-opacity,1))}.bg-grey-200{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.bg-grey-400\/30{background-color:hsla(0,0%,79%,.3)}.bg-grey-50{--tw-bg-opacity:1;background-color:rgb(250 250 250/var(--tw-bg-opacity,1))}.bg-grey-600{--tw-bg-opacity:1;background-color:rgb(122 122 122/var(--tw-bg-opacity,1))}.bg-muted{background-color:hsl(var(--muted))}.bg-orange-100{--tw-bg-opacity:1;background-color:rgb(254 240 214/var(--tw-bg-opacity,1))}.bg-pink-100{--tw-bg-opacity:1;background-color:rgb(251 232 243/var(--tw-bg-opacity,1))}.bg-pink-500{--tw-bg-opacity:1;background-color:rgb(227 92 156/var(--tw-bg-opacity,1))}.bg-popover{background-color:hsl(var(--popover))}.bg-purple-100{--tw-bg-opacity:1;background-color:rgb(238 235 252/var(--tw-bg-opacity,1))}.bg-red-100{--tw-bg-opacity:1;background-color:rgb(255 224 224/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(255 241 241/var(--tw-bg-opacity,1))}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(236 22 22/var(--tw-bg-opacity,1))}.bg-transparent{background-color:transparent}.bg-turquoise-100{--tw-bg-opacity:1;background-color:rgb(211 247 250/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-yellow-100{--tw-bg-opacity:1;background-color:rgb(254 253 195/var(--tw-bg-opacity,1))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-purple-400{--tw-gradient-from:#aa94f1 var(--tw-gradient-from-position);--tw-gradient-to:rgba(170,148,241,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-yellow-400{--tw-gradient-from:#f9dc16 var(--tw-gradient-from-position);--tw-gradient-to:rgba(249,220,22,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-green-500{--tw-gradient-to:rgba(28,173,134,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1cad86 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-pink-500{--tw-gradient-to:rgba(227,92,156,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#e35c9c var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-blue-500{--tw-gradient-to:#597bd8 var(--tw-gradient-to-position)}.to-red-500{--tw-gradient-to:#ff4646 var(--tw-gradient-to-position)}.fill-blue-500{fill:#597bd8}.fill-current{fill:currentColor}.fill-grey-950{fill:#262626}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-\[1px\]{padding:1px}.p-\[2px\]{padding:2px}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0{padding-top:0;padding-bottom:0}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.pl-10{padding-left:2.5rem}.pl-2{padding-left:.5rem}.pl-8{padding-left:2rem}.pr-10{padding-right:2.5rem}.pr-2{padding-right:.5rem}.pt-20{padding-top:5rem}.text-center{text-align:center}.font-roboto{font-family:Roboto,sans-serif}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-blue-600{--tw-text-opacity:1;color:rgb(60 89 201/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:rgb(59 78 186/var(--tw-text-opacity,1))}.text-current{color:currentColor}.text-green-600{--tw-text-opacity:1;color:rgb(15 140 109/var(--tw-text-opacity,1))}.text-grey-600{--tw-text-opacity:1;color:rgb(122 122 122/var(--tw-text-opacity,1))}.text-grey-700{--tw-text-opacity:1;color:rgb(93 93 93/var(--tw-text-opacity,1))}.text-grey-800{--tw-text-opacity:1;color:rgb(74 74 74/var(--tw-text-opacity,1))}.text-grey-950{--tw-text-opacity:1;color:rgb(38 38 38/var(--tw-text-opacity,1))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-orange-600{--tw-text-opacity:1;color:rgb(229 105 16/var(--tw-text-opacity,1))}.text-pink-600{--tw-text-opacity:1;color:rgb(207 51 117/var(--tw-text-opacity,1))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-purple-600{--tw-text-opacity:1;color:rgb(130 80 223/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(236 22 22/var(--tw-text-opacity,1))}.text-turquoise-600{--tw-text-opacity:1;color:rgb(21 136 165/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-yellow-600{--tw-text-opacity:1;color:rgb(201 152 5/var(--tw-text-opacity,1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-md{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-none{--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}.shadow-none,.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.outline-none{outline:2px solid transparent;outline-offset:2px}.ring-offset-background{--tw-ring-offset-color:hsl(var(--background))}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0) scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}.animate-in{animation-name:enter;animation-duration:.15s;--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial}.fade-in-0{--tw-enter-opacity:0}.zoom-in-95{--tw-enter-scale:.95}.duration-200{animation-duration:.2s}.duration-300{animation-duration:.3s}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:cursor-not-allowed:hover{cursor:not-allowed}.hover\:cursor-pointer:hover{cursor:pointer}.hover\:border-blue-600:hover{--tw-border-opacity:1;border-color:rgb(60 89 201/var(--tw-border-opacity,1))}.hover\:border-grey-200:hover{--tw-border-opacity:1;border-color:rgb(231 231 231/var(--tw-border-opacity,1))}.hover\:border-grey-500:hover{--tw-border-opacity:1;border-color:rgb(136 136 136/var(--tw-border-opacity,1))}.hover\:bg-blue-100:hover{--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.hover\:bg-blue-200:hover{--tw-bg-opacity:1;background-color:rgb(201 215 244/var(--tw-bg-opacity,1))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(59 78 186/var(--tw-bg-opacity,1))}.hover\:bg-green-200:hover{--tw-bg-opacity:1;background-color:rgb(172 238 212/var(--tw-bg-opacity,1))}.hover\:bg-grey-200:hover{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.hover\:bg-grey-200\/70:hover{background-color:hsla(0,0%,91%,.7)}.hover\:bg-grey-300:hover{--tw-bg-opacity:1;background-color:rgb(224 225 225/var(--tw-bg-opacity,1))}.hover\:bg-grey-50:hover{--tw-bg-opacity:1;background-color:rgb(250 250 250/var(--tw-bg-opacity,1))}.hover\:bg-grey-800:hover{--tw-bg-opacity:1;background-color:rgb(74 74 74/var(--tw-bg-opacity,1))}.hover\:bg-orange-200:hover{--tw-bg-opacity:1;background-color:rgb(252 221 172/var(--tw-bg-opacity,1))}.hover\:bg-pink-200:hover{--tw-bg-opacity:1;background-color:rgb(248 210 231/var(--tw-bg-opacity,1))}.hover\:bg-purple-200:hover{--tw-bg-opacity:1;background-color:rgb(222 217 251/var(--tw-bg-opacity,1))}.hover\:bg-red-100:hover{--tw-bg-opacity:1;background-color:rgb(255 224 224/var(--tw-bg-opacity,1))}.hover\:bg-red-200:hover{--tw-bg-opacity:1;background-color:rgb(255 197 197/var(--tw-bg-opacity,1))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(199 14 14/var(--tw-bg-opacity,1))}.hover\:bg-turquoise-200:hover{--tw-bg-opacity:1;background-color:rgb(172 238 245/var(--tw-bg-opacity,1))}.hover\:bg-yellow-200:hover{--tw-bg-opacity:1;background-color:rgb(254 248 138/var(--tw-bg-opacity,1))}.hover\:opacity-100:hover{opacity:1}.hover\:opacity-70:hover{opacity:.7}.focus\:border-blue-600:focus{--tw-border-opacity:1;border-color:rgb(60 89 201/var(--tw-border-opacity,1))}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:bg-background:focus{background-color:hsl(var(--background))}.focus\:bg-blue-100:focus{--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.focus\:bg-green-100:focus{--tw-bg-opacity:1;background-color:rgb(212 247 231/var(--tw-bg-opacity,1))}.focus\:bg-grey-200:focus{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.focus\:bg-orange-100:focus{--tw-bg-opacity:1;background-color:rgb(254 240 214/var(--tw-bg-opacity,1))}.focus\:bg-pink-100:focus{--tw-bg-opacity:1;background-color:rgb(251 232 243/var(--tw-bg-opacity,1))}.focus\:bg-purple-100:focus{--tw-bg-opacity:1;background-color:rgb(238 235 252/var(--tw-bg-opacity,1))}.focus\:bg-red-100:focus{--tw-bg-opacity:1;background-color:rgb(255 224 224/var(--tw-bg-opacity,1))}.focus\:bg-transparent:focus{background-color:transparent}.focus\:bg-turquoise-100:focus{--tw-bg-opacity:1;background-color:rgb(211 247 250/var(--tw-bg-opacity,1))}.focus\:bg-yellow-100:focus{--tw-bg-opacity:1;background-color:rgb(254 253 195/var(--tw-bg-opacity,1))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-0:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-0:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-4:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-blue-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(201 215 244/var(--tw-ring-opacity,1))}.focus\:ring-blue-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(242 245 252/var(--tw-ring-opacity,1))}.focus\:ring-blue-600:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(60 89 201/var(--tw-ring-opacity,1))}.focus\:ring-green-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(237 252 246/var(--tw-ring-opacity,1))}.focus\:ring-grey-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(231 231 231/var(--tw-ring-opacity,1))}.focus\:ring-grey-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(250 250 250/var(--tw-ring-opacity,1))}.focus\:ring-orange-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(255 248 237/var(--tw-ring-opacity,1))}.focus\:ring-pink-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(252 243 248/var(--tw-ring-opacity,1))}.focus\:ring-purple-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(246 244 254/var(--tw-ring-opacity,1))}.focus\:ring-red-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(255 197 197/var(--tw-ring-opacity,1))}.focus\:ring-red-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(255 241 241/var(--tw-ring-opacity,1))}.focus\:ring-ring:focus{--tw-ring-color:hsl(var(--ring))}.focus\:ring-turquoise-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(237 253 254/var(--tw-ring-opacity,1))}.focus\:ring-yellow-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(254 254 232/var(--tw-ring-opacity,1))}.focus\:ring-opacity-20:focus{--tw-ring-opacity:0.2}.focus\:ring-opacity-30:focus{--tw-ring-opacity:0.3}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:before\:absolute:focus-visible:before{content:var(--tw-content);position:absolute}.focus-visible\:before\:left-1\/2:focus-visible:before{content:var(--tw-content);left:50%}.focus-visible\:before\:top-1\/2:focus-visible:before{content:var(--tw-content);top:50%}.focus-visible\:before\:-z-10:focus-visible:before{content:var(--tw-content);z-index:-10}.focus-visible\:before\:h-10:focus-visible:before{content:var(--tw-content);height:2.5rem}.focus-visible\:before\:w-10:focus-visible:before{content:var(--tw-content);width:2.5rem}.focus-visible\:before\:-translate-x-1\/2:focus-visible:before{content:var(--tw-content);--tw-translate-x:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.focus-visible\:before\:-translate-y-1\/2:focus-visible:before{content:var(--tw-content);--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.focus-visible\:before\:transform:focus-visible:before{content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.focus-visible\:before\:rounded-full:focus-visible:before{content:var(--tw-content);border-radius:9999px}.focus-visible\:before\:bg-blue-100:focus-visible:before{content:var(--tw-content);--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.active\:border-grey-700:active{--tw-border-opacity:1;border-color:rgb(93 93 93/var(--tw-border-opacity,1))}.active\:bg-blue-300:active{--tw-bg-opacity:1;background-color:rgb(164 190 236/var(--tw-bg-opacity,1))}.active\:bg-blue-800:active{--tw-bg-opacity:1;background-color:rgb(53 65 152/var(--tw-bg-opacity,1))}.active\:bg-green-300:active{--tw-bg-opacity:1;background-color:rgb(95 217 176/var(--tw-bg-opacity,1))}.active\:bg-grey-200:active{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.active\:bg-grey-400:active{--tw-bg-opacity:1;background-color:rgb(201 201 201/var(--tw-bg-opacity,1))}.active\:bg-grey-900:active{--tw-bg-opacity:1;background-color:rgb(61 61 61/var(--tw-bg-opacity,1))}.active\:bg-orange-300:active{--tw-bg-opacity:1;background-color:rgb(250 196 119/var(--tw-bg-opacity,1))}.active\:bg-pink-300:active{--tw-bg-opacity:1;background-color:rgb(244 173 211/var(--tw-bg-opacity,1))}.active\:bg-purple-300:active{--tw-bg-opacity:1;background-color:rgb(199 187 247/var(--tw-bg-opacity,1))}.active\:bg-red-300:active{--tw-bg-opacity:1;background-color:rgb(255 157 157/var(--tw-bg-opacity,1))}.active\:bg-red-800:active{--tw-bg-opacity:1;background-color:rgb(164 16 16/var(--tw-bg-opacity,1))}.active\:bg-turquoise-300:active{--tw-bg-opacity:1;background-color:rgb(107 221 237/var(--tw-bg-opacity,1))}.active\:bg-yellow-300:active{--tw-bg-opacity:1;background-color:rgb(252 237 72/var(--tw-bg-opacity,1))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:border-blue-200:disabled{--tw-border-opacity:1;border-color:rgb(201 215 244/var(--tw-border-opacity,1))}.disabled\:border-grey-200:disabled{--tw-border-opacity:1;border-color:rgb(231 231 231/var(--tw-border-opacity,1))}.disabled\:border-grey-300:disabled{--tw-border-opacity:1;border-color:rgb(224 225 225/var(--tw-border-opacity,1))}.disabled\:border-input:disabled{border-color:hsl(var(--input))}.disabled\:border-red-200:disabled{--tw-border-opacity:1;border-color:rgb(255 197 197/var(--tw-border-opacity,1))}.disabled\:bg-blue-100:disabled{--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.disabled\:bg-blue-50:disabled{--tw-bg-opacity:1;background-color:rgb(242 245 252/var(--tw-bg-opacity,1))}.disabled\:bg-grey-200:disabled{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.disabled\:bg-grey-50:disabled{--tw-bg-opacity:1;background-color:rgb(250 250 250/var(--tw-bg-opacity,1))}.disabled\:bg-red-100:disabled{--tw-bg-opacity:1;background-color:rgb(255 224 224/var(--tw-bg-opacity,1))}.disabled\:bg-red-50:disabled{--tw-bg-opacity:1;background-color:rgb(255 241 241/var(--tw-bg-opacity,1))}.disabled\:bg-transparent:disabled{background-color:transparent}.disabled\:bg-white:disabled{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.disabled\:text-blue-200:disabled{--tw-text-opacity:1;color:rgb(201 215 244/var(--tw-text-opacity,1))}.disabled\:text-blue-400:disabled{--tw-text-opacity:1;color:rgb(121 157 225/var(--tw-text-opacity,1))}.disabled\:text-grey-300:disabled{--tw-text-opacity:1;color:rgb(224 225 225/var(--tw-text-opacity,1))}.disabled\:text-grey-800:disabled{--tw-text-opacity:1;color:rgb(74 74 74/var(--tw-text-opacity,1))}.disabled\:text-red-100:disabled{--tw-text-opacity:1;color:rgb(255 224 224/var(--tw-text-opacity,1))}.disabled\:text-red-200:disabled{--tw-text-opacity:1;color:rgb(255 197 197/var(--tw-text-opacity,1))}.disabled\:opacity-50:disabled{opacity:.5}.group:focus .group-focus\:ring-8{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(8px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.group:focus .group-focus\:ring-blue-200{--tw-ring-opacity:1;--tw-ring-color:rgb(201 215 244/var(--tw-ring-opacity,1))}.group:focus .group-focus\:ring-opacity-50{--tw-ring-opacity:0.5}.group:active:enabled .group-active\:group-enabled\:h-5{height:1.25rem}.group:active:enabled .group-active\:group-enabled\:w-5{width:1.25rem}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-50{opacity:.5}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:0.25rem}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom],.data-\[side\=left\]\:-translate-x-1[data-side=left]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:-0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right],.data-\[side\=top\]\:-translate-y-1[data-side=top]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:-0.25rem}.data-\[state\=checked\]\:translate-x-6[data-state=checked]{--tw-translate-x:1.5rem}.data-\[state\=checked\]\:translate-x-6[data-state=checked],.data-\[state\=unchecked\]\:translate-x-1[data-state=unchecked]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-1[data-state=unchecked]{--tw-translate-x:0.25rem}.data-\[state\=unchecked\]\:border-2[data-state=unchecked]{border-width:2px}.data-\[state\=checked\]\:border-blue-600[data-state=checked]{--tw-border-opacity:1;border-color:rgb(60 89 201/var(--tw-border-opacity,1))}.data-\[state\=unchecked\]\:border-grey-400[data-state=unchecked]{--tw-border-opacity:1;border-color:rgb(201 201 201/var(--tw-border-opacity,1))}.data-\[state\=checked\]\:bg-blue-600[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(60 89 201/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:bg-white[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[state\=unchecked\]\:bg-grey-400[data-state=unchecked]{--tw-bg-opacity:1;background-color:rgb(201 201 201/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:text-blue-600[data-state=checked]{--tw-text-opacity:1;color:rgb(60 89 201/var(--tw-text-opacity,1))}.data-\[state\=checked\]\:text-white[data-state=checked]{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:hsl(var(--muted-foreground))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:animate-in[data-state=open]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:-0.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:0.5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:-0.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:0.5rem}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x:-50%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x:-50%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y:-48%}.data-\[state\=checked\]\:hover\:border-blue-700:hover[data-state=checked]{--tw-border-opacity:1;border-color:rgb(59 78 186/var(--tw-border-opacity,1))}.data-\[state\=unchecked\]\:hover\:border-grey-500:hover[data-state=unchecked]{--tw-border-opacity:1;border-color:rgb(136 136 136/var(--tw-border-opacity,1))}.data-\[state\=checked\]\:hover\:bg-blue-700:hover[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(59 78 186/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:hover\:text-blue-700:hover[data-state=checked]{--tw-text-opacity:1;color:rgb(59 78 186/var(--tw-text-opacity,1))}.data-\[state\=checked\]\:active\:border-blue-800:active[data-state=checked]{--tw-border-opacity:1;border-color:rgb(53 65 152/var(--tw-border-opacity,1))}.data-\[state\=unchecked\]\:active\:border-grey-700:active[data-state=unchecked]{--tw-border-opacity:1;border-color:rgb(93 93 93/var(--tw-border-opacity,1))}.data-\[state\=checked\]\:active\:bg-blue-800:active[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(53 65 152/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:active\:text-blue-800:active[data-state=checked]{--tw-text-opacity:1;color:rgb(53 65 152/var(--tw-text-opacity,1))}.data-\[state\=checked\]\:disabled\:border-blue-400:disabled[data-state=checked]{--tw-border-opacity:1;border-color:rgb(121 157 225/var(--tw-border-opacity,1))}.data-\[state\=unchecked\]\:disabled\:border-grey-300:disabled[data-state=unchecked]{--tw-border-opacity:1;border-color:rgb(224 225 225/var(--tw-border-opacity,1))}.data-\[state\=checked\]\:disabled\:bg-blue-200:disabled[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(201 215 244/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:disabled\:bg-blue-400:disabled[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(121 157 225/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:disabled\:text-blue-400:disabled[data-state=checked]{--tw-text-opacity:1;color:rgb(121 157 225/var(--tw-text-opacity,1))}.group:hover .group-hover\:data-\[state\=unchecked\]\:bg-grey-500[data-state=unchecked]{--tw-bg-opacity:1;background-color:rgb(136 136 136/var(--tw-bg-opacity,1))}.group:active .group-active\:data-\[state\=unchecked\]\:bg-grey-700[data-state=unchecked]{--tw-bg-opacity:1;background-color:rgb(93 93 93/var(--tw-bg-opacity,1))}.group:active:enabled .group-active\:group-enabled\:data-\[state\=unchecked\]\:translate-x-\[-2px\][data-state=unchecked]{--tw-translate-x:-2px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:disabled .group-disabled\:data-\[state\=unchecked\]\:bg-grey-300[data-state=unchecked]{--tw-bg-opacity:1;background-color:rgb(224 225 225/var(--tw-bg-opacity,1))}.group:disabled .group-disabled\:data-\[state\=unchecked\]\:bg-opacity-65[data-state=unchecked]{--tw-bg-opacity:0.65}@media (min-width:640px){.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem*var(--tw-space-x-reverse));margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)))}.sm\:rounded-lg{border-radius:var(--radius)}.sm\:text-left{text-align:left}}.\[\&\>\.custom-icon\]\:fill-white>.custom-icon{fill:#fff}.\[\&\>\.lucide\]\:text-white>.lucide{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>svg\]\:\!h-5>svg{height:1.25rem!important}.\[\&\>svg\]\:\!h-6>svg{height:1.5rem!important}.\[\&\>svg\]\:\!h-8>svg{height:2rem!important}.\[\&\>svg\]\:h-5>svg{height:1.25rem}.\[\&\>svg\]\:h-6>svg{height:1.5rem}.\[\&\>svg\]\:\!w-5>svg{width:1.25rem!important}.\[\&\>svg\]\:\!w-6>svg{width:1.5rem!important}.\[\&\>svg\]\:\!w-8>svg{width:2rem!important}.\[\&\>svg\]\:w-5>svg{width:1.25rem}.\[\&\>svg\]\:w-6>svg{width:1.5rem}.\[\&_\.tooltip-arrow\]\:fill-black .tooltip-arrow{fill:#000}.\[\&_\.tooltip-arrow\]\:fill-white .tooltip-arrow{fill:#fff}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}
@@ -0,0 +1,125 @@
1
+ const colors = {
2
+ transparent: "transparent",
3
+ current: "currentColor",
4
+ black: "#000000",
5
+ white: "#ffffff",
6
+ blue: {
7
+ 50: "#f2f5fc",
8
+ 100: "#e1e9f8",
9
+ 200: "#c9d7f4",
10
+ 300: "#a4beec",
11
+ 400: "#799de1",
12
+ 500: "#597bd8",
13
+ 600: "#3c59c9",
14
+ 700: "#3b4eba",
15
+ 800: "#354198",
16
+ 900: "#2f3a79",
17
+ 950: "#21264a"
18
+ },
19
+ grey: {
20
+ 50: "#FAFAFA",
21
+ 100: "#F5F5F5",
22
+ 200: "#E7E7E7",
23
+ 300: "#E0E1E1",
24
+ 400: "#C9C9C9",
25
+ 500: "#888888",
26
+ 600: "#7A7A7A",
27
+ 700: "#5D5D5D",
28
+ 800: "#4A4A4A",
29
+ 900: "#3D3D3D",
30
+ 950: "#262626"
31
+ },
32
+ red: {
33
+ 50: "#fff1f1",
34
+ 100: "#ffe0e0",
35
+ 200: "#ffc5c5",
36
+ 300: "#ff9d9d",
37
+ 400: "#FF6565",
38
+ 500: "#FF4646",
39
+ 600: "#EC1616",
40
+ 700: "#C70E0E",
41
+ 800: "#A41010",
42
+ 900: "#881414",
43
+ 950: "#4A0505"
44
+ },
45
+ yellow: {
46
+ 50: "#FEFEE8",
47
+ 100: "#FEFDC3",
48
+ 200: "#FEF88A",
49
+ 300: "#FCED48",
50
+ 400: "#F9DC16",
51
+ 500: "#EFC709",
52
+ 600: "#C99805",
53
+ 700: "#A06D08",
54
+ 800: "#85550E",
55
+ 900: "#714612",
56
+ 950: "#422406"
57
+ },
58
+ orange: {
59
+ 50: "#FFF8ED",
60
+ 100: "#FEF0D6",
61
+ 200: "#FCDDAC",
62
+ 300: "#FAC477",
63
+ 400: "#F8A03F",
64
+ 500: "#F5851A",
65
+ 600: "#E56910",
66
+ 700: "#BF4F0F",
67
+ 800: "#983F14",
68
+ 900: "#7A3614",
69
+ 950: "#421908"
70
+ },
71
+ purple: {
72
+ 50: "#F6F4FE",
73
+ 100: "#EEEBFC",
74
+ 200: "#DED9FB",
75
+ 300: "#C7BBF7",
76
+ 400: "#AA94F1",
77
+ 500: "#8E69E9",
78
+ 600: "#8250DF",
79
+ 700: "#6D37CA",
80
+ 800: "#5C2EA9",
81
+ 900: "#4C278B",
82
+ 950: "#2F175E"
83
+ },
84
+ green: {
85
+ 50: "#EDFCF6",
86
+ 100: "#D4F7E7",
87
+ 200: "#ACEED4",
88
+ 300: "#5FD9B0",
89
+ 400: "#3FC89E",
90
+ 500: "#1CAD86",
91
+ 600: "#0F8C6D",
92
+ 700: "#0C705A",
93
+ 800: "#0C5948",
94
+ 900: "#0B493D",
95
+ 950: "#052922"
96
+ },
97
+ pink: {
98
+ 50: "#FCF3F8",
99
+ 100: "#FBE8F3",
100
+ 200: "#F8D2E7",
101
+ 300: "#F4ADD3",
102
+ 400: "#EC7AB4",
103
+ 500: "#E35C9C",
104
+ 600: "#CF3375",
105
+ 700: "#B3235C",
106
+ 800: "#94204D",
107
+ 900: "#7C1F42",
108
+ 950: "#4B0C24"
109
+ },
110
+ turquoise: {
111
+ 50: "#EDFDFE",
112
+ 100: "#D3F7FA",
113
+ 200: "#ACEEF5",
114
+ 300: "#6BDDED",
115
+ 400: "#32C7DE",
116
+ 500: "#16AAC4",
117
+ 600: "#1588A5",
118
+ 700: "#186D86",
119
+ 800: "#1C596E",
120
+ 900: "#1C4B5D",
121
+ 950: "#0D313F"
122
+ }
123
+ };
124
+
125
+ export { colors };
@@ -0,0 +1,7 @@
1
+ const fonts = {
2
+ roboto: ["Roboto", "sans-serif"],
3
+ montserrat: ["Montserrat", "sans-serif"],
4
+ ibm: ["IBM Plex Mono", "sans-serif"]
5
+ };
6
+
7
+ export { fonts };
package/package.json ADDED
@@ -0,0 +1,87 @@
1
+ {
2
+ "name": "lecom-ui",
3
+ "version": "2.0.0",
4
+ "license": "MIT",
5
+ "type": "module",
6
+ "module": "dist/index.js",
7
+ "style": "dist/style.min.css",
8
+ "typings": "dist/index.d.ts",
9
+ "files": [
10
+ "dist"
11
+ ],
12
+ "scripts": {
13
+ "dev": "next dev",
14
+ "build": "next build",
15
+ "start": "next start",
16
+ "lint": "next lint",
17
+ "storybook": "storybook dev -p 6006",
18
+ "build-storybook": "storybook build",
19
+ "build:tailwind": "npx tailwindcss -i ./src/globals.css -o ./dist/style.min.css --minify",
20
+ "build:rollup": "rollup -c && yarn build:tailwind",
21
+ "test": "jest",
22
+ "test:watch": "jest --watch",
23
+ "test:coverage": "jest --coverage"
24
+ },
25
+ "dependencies": {
26
+ "@radix-ui/react-checkbox": "^1.1.3",
27
+ "@radix-ui/react-dialog": "^1.1.4",
28
+ "@radix-ui/react-dropdown-menu": "^2.1.4",
29
+ "@radix-ui/react-popover": "^1.1.4",
30
+ "@radix-ui/react-radio-group": "^1.2.2",
31
+ "@radix-ui/react-scroll-area": "^1.2.2",
32
+ "@radix-ui/react-select": "^2.1.4",
33
+ "@radix-ui/react-slot": "^1.1.1",
34
+ "@radix-ui/react-switch": "^1.1.2",
35
+ "@radix-ui/react-tooltip": "^1.1.6",
36
+ "class-variance-authority": "^0.7.1",
37
+ "clsx": "^2.1.1",
38
+ "lucide-react": "^0.468.0",
39
+ "next": "15.1.0",
40
+ "react": "^19.0.0",
41
+ "react-dom": "^19.0.0",
42
+ "tailwind-merge": "^2.5.5",
43
+ "tailwindcss-animate": "^1.0.7"
44
+ },
45
+ "devDependencies": {
46
+ "@chromatic-com/storybook": "3.2.2",
47
+ "@eslint/eslintrc": "^3",
48
+ "@rollup/plugin-alias": "^5.1.1",
49
+ "@storybook/addon-essentials": "8.4.7",
50
+ "@storybook/addon-interactions": "8.4.7",
51
+ "@storybook/addon-onboarding": "8.4.7",
52
+ "@storybook/blocks": "8.4.7",
53
+ "@storybook/nextjs": "8.4.7",
54
+ "@storybook/react": "8.4.7",
55
+ "@storybook/test": "8.4.7",
56
+ "@testing-library/dom": "^10.4.0",
57
+ "@testing-library/jest-dom": "^6.6.3",
58
+ "@testing-library/react": "^16.1.0",
59
+ "@types/node": "^20",
60
+ "@types/react": "^19",
61
+ "@types/react-dom": "^19",
62
+ "eslint": "^9",
63
+ "eslint-config-next": "15.1.0",
64
+ "eslint-plugin-import-helpers": "^2.0.1",
65
+ "eslint-plugin-storybook": "^0.11.1",
66
+ "jest": "^29.7.0",
67
+ "jest-environment-jsdom": "^29.7.0",
68
+ "postcss": "^8",
69
+ "rollup": "^4.28.1",
70
+ "rollup-plugin-copy": "^3.5.0",
71
+ "rollup-plugin-dts": "^6.1.1",
72
+ "rollup-plugin-esbuild": "^6.1.1",
73
+ "storybook": "8.4.7",
74
+ "tailwindcss": "^3.4.1",
75
+ "ts-node": "^10.9.2",
76
+ "typescript": "^5"
77
+ },
78
+ "peerDependencies": {
79
+ "react": "^19.0.0",
80
+ "react-dom": "^19.0.0"
81
+ },
82
+ "eslintConfig": {
83
+ "extends": [
84
+ "plugin:storybook/recommended"
85
+ ]
86
+ }
87
+ }