azeriand-library 1.3.7 → 1.3.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -15,15 +15,39 @@ yarn add azeriand-library
15
15
  ### Basic Usage
16
16
 
17
17
  ```tsx
18
- import { Button } from 'azeriand-library';
19
- import 'azeriand-library/dist/style.css'; // Import the CSS
18
+ import { Button, Card } from 'azeriand-library';
20
19
 
21
20
  function App() {
22
21
  return (
23
22
  <div>
24
- <Button color="#ff6b6b">
25
- Click me!
26
- </Button>
23
+ <Card>
24
+ <Button color="blue">
25
+ Click me!
26
+ </Button>
27
+ </Card>
28
+ </div>
29
+ );
30
+ }
31
+ ```
32
+
33
+ **Note**: Component styles are automatically injected when you import components. No separate CSS imports are required for component functionality.
34
+
35
+ ### Optional: Global Styles
36
+
37
+ If you want to use Tailwind classes and design tokens in your own code, you can optionally import the global styles:
38
+
39
+ ```tsx
40
+ import { Button, Card } from 'azeriand-library';
41
+ import 'azeriand-library/dist/styles.css'; // Optional: for Tailwind classes and design tokens
42
+
43
+ function App() {
44
+ return (
45
+ <div className="bg-red-500"> {/* This will work with global styles imported */}
46
+ <Card>
47
+ <Button color="blue">
48
+ Click me!
49
+ </Button>
50
+ </Card>
27
51
  </div>
28
52
  );
29
53
  }
@@ -31,8 +55,23 @@ function App() {
31
55
 
32
56
  ### With Tailwind CSS
33
57
 
34
- If your project uses Tailwind CSS, make sure to include the library's source files in your Tailwind configuration:
58
+ Component styles are automatically included, but if you want to use Tailwind classes in your own application, you have two options:
59
+
60
+ **Option 1: Import global styles** (includes design tokens and Tailwind base styles)
61
+ ```tsx
62
+ import { Button } from 'azeriand-library';
63
+ import 'azeriand-library/dist/styles.css';
64
+
65
+ function App() {
66
+ return (
67
+ <div className="bg-blue-500 p-4"> {/* Tailwind classes work */}
68
+ <Button color="red">My Button</Button>
69
+ </div>
70
+ );
71
+ }
72
+ ```
35
73
 
74
+ **Option 2: Configure Tailwind to scan the library** (if you want to use your own Tailwind config)
36
75
  ```js
37
76
  // tailwind.config.js
38
77
  module.exports = {
@@ -44,8 +83,6 @@ module.exports = {
44
83
  }
45
84
  ```
46
85
 
47
- Then you can use the components without importing the CSS:
48
-
49
86
  ```tsx
50
87
  import { Button } from 'azeriand-library';
51
88
 
@@ -0,0 +1 @@
1
+ export declare const BUTTON_CSS = "\nbutton{\n background: none;\n\tcolor: inherit;\n\tborder: none;\n\tpadding: 0;\n\tfont: inherit;\n\tcursor: pointer;\n\toutline: inherit;\n font-weight: bold;\n}\n\nbutton:focus {\n outline: revert;\n}\n";
@@ -0,0 +1 @@
1
+ export declare const CARD_CSS = "\n.card{\n /* border-radius: 20px; */\n color: var(--card-text-color, white);\n}\n\n.card.glass{\n background-color: color-mix(in oklch, var(--glass-color), transparent 80%);\n border: 1px solid color-mix(in oklch, var(--glass-color), transparent 40%);\n -webkit-backface-visibility: hidden;\n -webkit-perspective: 1000;\n -webkit-transform: translate3d(0,0,0);\n -webkit-transform: translateZ(0);\n backface-visibility: hidden;\n perspective: 1000;\n transform: translate3d(0,0,0);\n transform: translateZ(0);\n}\n\n.card.mate{\n background-color: var(--glass-color);\n}\n\n.card.outlined{\n border: solid white 2px;\n}\n\nbutton .card.ghost:hover, button .card.outlined:hover{\n background: color-mix(in oklch, var(--glass-color), transparent 80%);\n}\n\nbutton .card.glass:hover{\n box-shadow: 0 4px 10px color-mix(in oklch, var(--glass-color), transparent 85%);\n}\n\nbutton .card.mate:hover{\n background-color: color-mix(in oklch, var(--glass-color), white 10%) \n}\n";
package/dist/index.d.ts CHANGED
@@ -1,4 +1,4 @@
1
1
  export { Avatar } from './components/avatar';
2
2
  export { Card } from './components/card/card';
3
3
  export { Button } from './components/button/button';
4
- export * from './styles/index';
4
+ export { injectCSS } from './utils/css-injection';
package/dist/index.esm.js CHANGED
@@ -13,6 +13,57 @@ function Avatar({ src, className = "", style }) {
13
13
  const DEFAULT_THEME = "dark";
14
14
  const ThemeContext = createContext({ theme: DEFAULT_THEME, setTheme: () => {
15
15
  } });
16
+ let injectedStyles = /* @__PURE__ */ new Set();
17
+ function injectCSS(css, id) {
18
+ if (typeof document === "undefined" || injectedStyles.has(id)) {
19
+ return;
20
+ }
21
+ const style = document.createElement("style");
22
+ style.setAttribute("data-component-css", id);
23
+ style.innerHTML = css;
24
+ document.head.appendChild(style);
25
+ injectedStyles.add(id);
26
+ }
27
+ const CARD_CSS = `
28
+ .card{
29
+ /* border-radius: 20px; */
30
+ color: var(--card-text-color, white);
31
+ }
32
+
33
+ .card.glass{
34
+ background-color: color-mix(in oklch, var(--glass-color), transparent 80%);
35
+ border: 1px solid color-mix(in oklch, var(--glass-color), transparent 40%);
36
+ -webkit-backface-visibility: hidden;
37
+ -webkit-perspective: 1000;
38
+ -webkit-transform: translate3d(0,0,0);
39
+ -webkit-transform: translateZ(0);
40
+ backface-visibility: hidden;
41
+ perspective: 1000;
42
+ transform: translate3d(0,0,0);
43
+ transform: translateZ(0);
44
+ }
45
+
46
+ .card.mate{
47
+ background-color: var(--glass-color);
48
+ }
49
+
50
+ .card.outlined{
51
+ border: solid white 2px;
52
+ }
53
+
54
+ button .card.ghost:hover, button .card.outlined:hover{
55
+ background: color-mix(in oklch, var(--glass-color), transparent 80%);
56
+ }
57
+
58
+ button .card.glass:hover{
59
+ box-shadow: 0 4px 10px color-mix(in oklch, var(--glass-color), transparent 85%);
60
+ }
61
+
62
+ button .card.mate:hover{
63
+ background-color: color-mix(in oklch, var(--glass-color), white 10%)
64
+ }
65
+ `;
66
+ injectCSS(CARD_CSS, "card-component");
16
67
  function Card({ children, noPadding, noBlur = false, appearance = "glass", color = "neutral", intensity, dark = true, onClick, className, style }) {
17
68
  let [classNames, setClassNames] = useState("");
18
69
  let [cardStyle, setCardStyle] = useState({});
@@ -39,6 +90,23 @@ function Card({ children, noPadding, noBlur = false, appearance = "glass", color
39
90
  }, [color, intensity, dark, appearance, noBlur, className, theme]);
40
91
  return /* @__PURE__ */ jsx("article", { className: classNames, style: cardStyle, onClick, children });
41
92
  }
93
+ const BUTTON_CSS = `
94
+ button{
95
+ background: none;
96
+ color: inherit;
97
+ border: none;
98
+ padding: 0;
99
+ font: inherit;
100
+ cursor: pointer;
101
+ outline: inherit;
102
+ font-weight: bold;
103
+ }
104
+
105
+ button:focus {
106
+ outline: revert;
107
+ }
108
+ `;
109
+ injectCSS(BUTTON_CSS, "button-component");
42
110
  function Button({ children, label, icon, position = "left", onClick, size, className, ...cardProps }) {
43
111
  let cardClassNames = "flex justify-center items-center gap-x-[0.40rem] h-[2.5rem] min-w-[2.5rem] box-border p-0";
44
112
  if (label) {
@@ -68,6 +136,7 @@ function Button({ children, label, icon, position = "left", onClick, size, class
68
136
  export {
69
137
  Avatar,
70
138
  Button,
71
- Card
139
+ Card,
140
+ injectCSS
72
141
  };
73
142
  //# sourceMappingURL=index.esm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.esm.js","sources":["../src/components/avatar.tsx","../src/components/theme-context.tsx","../src/components/card/card.tsx","../src/components/button/button.tsx"],"sourcesContent":["\r\ntype AvatarProps = {\r\n src: string;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport function Avatar({ src, className = '', style }: AvatarProps){\r\n return(\r\n <img className={`size-[3rem] rounded-2xl ${className}`} \r\n src={src} \r\n style={style}/>\r\n )\r\n}","import { useState, createContext } from 'react'\n\ntype ThemeMode = 'dark' | 'light';\nconst DEFAULT_THEME = 'dark';\n\ntype ThemeContext = {\n theme: ThemeMode,\n setTheme: (val: ThemeMode) => void\n}\n\nexport const ThemeContext = createContext<ThemeContext>({theme: DEFAULT_THEME, setTheme: () => {}}); //Creando el 'espacio compartido' al que los componentes pueden acceder??\n\nimport { ReactNode } from 'react';\n\nexport default function ThemeContextComponent({children}: {children: ReactNode}){\n\n const [theme, setTheme] = useState<ThemeMode>(DEFAULT_THEME)\n\n //Creando el componente donde todos los hijos pueden acceder al contexto (siendo children los props)\n return(\n <ThemeContext.Provider value={{theme, setTheme}}> \n {children}\n </ThemeContext.Provider>\n )\n}","import { MouseEventHandler, ReactNode, useContext, useEffect, useState } from 'react';\nimport { ThemeContext } from '../theme-context';\n\ntype CardProps = {\n children?: ReactNode;\n noPadding?: boolean;\n noBlur?: boolean;\n appearance?: string;\n color?: string;\n intensity?: number;\n dark?: boolean;\n onClick?: MouseEventHandler<HTMLElement>;\n className?: string;\n style?: React.CSSProperties;\n}\nexport function Card({children, noPadding, noBlur = false, appearance = 'glass', color = 'neutral', intensity, dark = true, onClick, className, style}: CardProps){\n \n let [classNames, setClassNames] = useState(\"\")\n let [cardStyle, setCardStyle] = useState({})\n const {theme} = useContext(ThemeContext)\n \n useEffect(() => {\n\n let intensityValue = intensity\n \n if (intensityValue === undefined){\n intensityValue = theme === 'dark' ? 600 : 300;\n }\n \n setCardStyle({\n \"--glass-color\": `var(--color-${color}-${intensityValue})`,\n \"--card-text-color\": `var(--color-${color}-${dark ? '100' : '800'})`,\n backdropFilter: appearance === 'glass' && !noBlur ? 'blur(10px)' : undefined,\n ...style\n });\n\n let rounded = 'rounded-md'\n\n if (className){\n const roundedMatch = className.match(/rounded\\-[a-z0-9]+/g)\n if (roundedMatch){\n rounded = roundedMatch[roundedMatch.length - 1]\n }\n }\n\n setClassNames(`card ${rounded} ${appearance} ${className} ${noPadding ? '' : 'p-[2rem]'}`)\n\n \n }, [color, intensity, dark, appearance, noBlur, className, theme])\n\n return(\n <article className={classNames} style={cardStyle} onClick={onClick}>\n {children}\n </article>\n )\n\n}\n","import { MouseEventHandler, ReactNode, useContext, useEffect, useState } from 'react';\nimport { Card } from '../card/card'\n\ntype ButtonProps = {\n children?: ReactNode;\n label?: string;\n icon?: ReactNode;\n position?: string\n onClick?: MouseEventHandler<HTMLElement>;\n size?: string;\n className?: string;\n noPadding?: boolean;\n noBlur?: boolean;\n appearance?: string;\n color?: string;\n intensity?: number;\n dark?: boolean;\n style?: React.CSSProperties;\n}\n\nexport function Button({children, label, icon, position='left', onClick, size, className, ...cardProps} : ButtonProps){\n\n let cardClassNames = 'flex justify-center items-center gap-x-[0.40rem] h-[2.5rem] min-w-[2.5rem] box-border p-0'\n\n if (label) {\n cardClassNames += ' px-0 py-1'\n }\n\n\n if (className){\n const roundedMatch = className.match(/rounded\\-[a-z0-9]+/g)\n if (roundedMatch){\n cardClassNames += ' ' + roundedMatch[roundedMatch.length-1]\n }\n }\n\n if (size === 'sm'){\n cardClassNames += ' h-[2rem] w-[2rem] min-w-auto'\n }\n\n const buttonClick: MouseEventHandler<HTMLButtonElement> = (ev) => {\n if (typeof onClick === 'function') { \n onClick(ev)\n }\n }\n \n return(\n <button className={className} onClick={buttonClick}>\n <Card noBlur noPadding className={cardClassNames} {...cardProps}>\n {position === 'left' && icon}\n {label}\n {children}\n {position === 'right' && icon}\n </Card>\n </button>\n )\n}"],"names":[],"mappings":";;AAOO,SAAS,OAAO,EAAE,KAAK,YAAY,IAAI,SAAqB;AAC/D,SACI;AAAA,IAAC;AAAA,IAAA;AAAA,MAAI,WAAW,2BAA2B,SAAS;AAAA,MACpD;AAAA,MACA;AAAA,IAAA;AAAA,EAAA;AAER;ACVA,MAAM,gBAAgB;AAOf,MAAM,eAAe,cAA4B,EAAC,OAAO,eAAe,UAAU,MAAM;AAAC,GAAE;ACK3F,SAAS,KAAK,EAAC,UAAU,WAAW,SAAS,OAAO,aAAa,SAAS,QAAQ,WAAW,WAAW,OAAO,MAAM,SAAS,WAAW,SAAkB;AAE9J,MAAI,CAAC,YAAY,aAAa,IAAI,SAAS,EAAE;AAC7C,MAAI,CAAC,WAAW,YAAY,IAAI,SAAS,CAAA,CAAE;AAC3C,QAAM,EAAC,MAAA,IAAS,WAAW,YAAY;AAEvC,YAAU,MAAM;AAEZ,QAAI,iBAAiB;AAErB,QAAI,mBAAmB,QAAU;AAC7B,uBAAiB,UAAU,SAAS,MAAM;AAAA,IAC9C;AAEA,iBAAa;AAAA,MACT,iBAAiB,eAAe,KAAK,IAAI,cAAc;AAAA,MACvD,qBAAqB,eAAe,KAAK,IAAI,OAAO,QAAQ,KAAK;AAAA,MACjE,gBAAgB,eAAe,WAAW,CAAC,SAAS,eAAe;AAAA,MACnE,GAAG;AAAA,IAAA,CACN;AAED,QAAI,UAAU;AAEd,QAAI,WAAU;AACV,YAAM,eAAe,UAAU,MAAM,qBAAqB;AAC1D,UAAI,cAAa;AACb,kBAAU,aAAa,aAAa,SAAS,CAAC;AAAA,MAClD;AAAA,IACJ;AAEA,kBAAc,QAAQ,OAAO,IAAI,UAAU,IAAI,SAAS,IAAI,YAAY,KAAK,UAAU,EAAE;AAAA,EAG7F,GAAG,CAAC,OAAO,WAAW,MAAM,YAAY,QAAQ,WAAW,KAAK,CAAC;AAEjE,6BACK,WAAA,EAAQ,WAAW,YAAY,OAAO,WAAW,SAC7C,UACL;AAGR;ACpCO,SAAS,OAAO,EAAC,UAAU,OAAO,MAAM,WAAS,QAAQ,SAAS,MAAM,WAAW,GAAG,UAAA,GAAyB;AAElH,MAAI,iBAAiB;AAErB,MAAI,OAAO;AACP,sBAAkB;AAAA,EACtB;AAGA,MAAI,WAAU;AACV,UAAM,eAAe,UAAU,MAAM,qBAAqB;AAC1D,QAAI,cAAa;AACb,wBAAkB,MAAM,aAAa,aAAa,SAAO,CAAC;AAAA,IAC9D;AAAA,EACJ;AAEA,MAAI,SAAS,MAAK;AACd,sBAAkB;AAAA,EACtB;AAEA,QAAM,cAAoD,CAAC,OAAO;AAC9D,QAAI,OAAO,YAAY,YAAY;AAC/B,cAAQ,EAAE;AAAA,IACd;AAAA,EACJ;AAEA,SACI,oBAAC,UAAA,EAAO,WAAsB,SAAS,aACnC,UAAA,qBAAC,MAAA,EAAK,QAAM,MAAC,WAAS,MAAC,WAAW,gBAAiB,GAAG,WACjD,UAAA;AAAA,IAAA,aAAa,UAAU;AAAA,IACvB;AAAA,IACA;AAAA,IACA,aAAa,WAAW;AAAA,EAAA,EAAA,CAC7B,EAAA,CACJ;AAER;"}
1
+ {"version":3,"file":"index.esm.js","sources":["../src/components/avatar.tsx","../src/components/theme-context.tsx","../src/utils/css-injection.ts","../src/components/card/card-styles.ts","../src/components/card/card.tsx","../src/components/button/button-styles.ts","../src/components/button/button.tsx"],"sourcesContent":["\r\ntype AvatarProps = {\r\n src: string;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport function Avatar({ src, className = '', style }: AvatarProps){\r\n return(\r\n <img className={`size-[3rem] rounded-2xl ${className}`} \r\n src={src} \r\n style={style}/>\r\n )\r\n}","import { useState, createContext } from 'react'\n\ntype ThemeMode = 'dark' | 'light';\nconst DEFAULT_THEME = 'dark';\n\ntype ThemeContext = {\n theme: ThemeMode,\n setTheme: (val: ThemeMode) => void\n}\n\nexport const ThemeContext = createContext<ThemeContext>({theme: DEFAULT_THEME, setTheme: () => {}}); //Creando el 'espacio compartido' al que los componentes pueden acceder??\n\nimport { ReactNode } from 'react';\n\nexport default function ThemeContextComponent({children}: {children: ReactNode}){\n\n const [theme, setTheme] = useState<ThemeMode>(DEFAULT_THEME)\n\n //Creando el componente donde todos los hijos pueden acceder al contexto (siendo children los props)\n return(\n <ThemeContext.Provider value={{theme, setTheme}}> \n {children}\n </ThemeContext.Provider>\n )\n}","// CSS injection utility to automatically include component styles\nlet injectedStyles = new Set<string>();\n\nexport function injectCSS(css: string, id: string): void {\n if (typeof document === 'undefined' || injectedStyles.has(id)) {\n return; // Skip in SSR or if already injected\n }\n\n const style = document.createElement('style');\n style.setAttribute('data-component-css', id);\n style.innerHTML = css;\n document.head.appendChild(style);\n injectedStyles.add(id);\n}\n","// Card component CSS as a string constant\nexport const CARD_CSS = `\n.card{\n /* border-radius: 20px; */\n color: var(--card-text-color, white);\n}\n\n.card.glass{\n background-color: color-mix(in oklch, var(--glass-color), transparent 80%);\n border: 1px solid color-mix(in oklch, var(--glass-color), transparent 40%);\n -webkit-backface-visibility: hidden;\n -webkit-perspective: 1000;\n -webkit-transform: translate3d(0,0,0);\n -webkit-transform: translateZ(0);\n backface-visibility: hidden;\n perspective: 1000;\n transform: translate3d(0,0,0);\n transform: translateZ(0);\n}\n\n.card.mate{\n background-color: var(--glass-color);\n}\n\n.card.outlined{\n border: solid white 2px;\n}\n\nbutton .card.ghost:hover, button .card.outlined:hover{\n background: color-mix(in oklch, var(--glass-color), transparent 80%);\n}\n\nbutton .card.glass:hover{\n box-shadow: 0 4px 10px color-mix(in oklch, var(--glass-color), transparent 85%);\n}\n\nbutton .card.mate:hover{\n background-color: color-mix(in oklch, var(--glass-color), white 10%) \n}\n`;\n","import { MouseEventHandler, ReactNode, useContext, useEffect, useState } from 'react';\nimport { ThemeContext } from '../theme-context';\nimport { injectCSS } from '../../utils/css-injection';\nimport { CARD_CSS } from './card-styles';\n\n// Inject Card CSS when the component is imported\ninjectCSS(CARD_CSS, 'card-component');\n\ntype CardProps = {\n children?: ReactNode;\n noPadding?: boolean;\n noBlur?: boolean;\n appearance?: string;\n color?: string;\n intensity?: number;\n dark?: boolean;\n onClick?: MouseEventHandler<HTMLElement>;\n className?: string;\n style?: React.CSSProperties;\n}\nexport function Card({children, noPadding, noBlur = false, appearance = 'glass', color = 'neutral', intensity, dark = true, onClick, className, style}: CardProps){\n \n let [classNames, setClassNames] = useState(\"\")\n let [cardStyle, setCardStyle] = useState({})\n const {theme} = useContext(ThemeContext)\n \n useEffect(() => {\n\n let intensityValue = intensity\n \n if (intensityValue === undefined){\n intensityValue = theme === 'dark' ? 600 : 300;\n }\n \n setCardStyle({\n \"--glass-color\": `var(--color-${color}-${intensityValue})`,\n \"--card-text-color\": `var(--color-${color}-${dark ? '100' : '800'})`,\n backdropFilter: appearance === 'glass' && !noBlur ? 'blur(10px)' : undefined,\n ...style\n });\n\n let rounded = 'rounded-md'\n\n if (className){\n const roundedMatch = className.match(/rounded\\-[a-z0-9]+/g)\n if (roundedMatch){\n rounded = roundedMatch[roundedMatch.length - 1]\n }\n }\n\n setClassNames(`card ${rounded} ${appearance} ${className} ${noPadding ? '' : 'p-[2rem]'}`)\n\n \n }, [color, intensity, dark, appearance, noBlur, className, theme])\n\n return(\n <article className={classNames} style={cardStyle} onClick={onClick}>\n {children}\n </article>\n )\n\n}\n","// Button component CSS as a string constant\nexport const BUTTON_CSS = `\nbutton{\n background: none;\n\tcolor: inherit;\n\tborder: none;\n\tpadding: 0;\n\tfont: inherit;\n\tcursor: pointer;\n\toutline: inherit;\n font-weight: bold;\n}\n\nbutton:focus {\n outline: revert;\n}\n`;\n","import { MouseEventHandler, ReactNode, useContext, useEffect, useState } from 'react';\nimport { Card } from '../card/card'\nimport { injectCSS } from '../../utils/css-injection';\nimport { BUTTON_CSS } from './button-styles';\n\n// Inject Button CSS when the component is imported\ninjectCSS(BUTTON_CSS, 'button-component');\n\ntype ButtonProps = {\n children?: ReactNode;\n label?: string;\n icon?: ReactNode;\n position?: string\n onClick?: MouseEventHandler<HTMLElement>;\n size?: string;\n className?: string;\n noPadding?: boolean;\n noBlur?: boolean;\n appearance?: string;\n color?: string;\n intensity?: number;\n dark?: boolean;\n style?: React.CSSProperties;\n}\n\nexport function Button({children, label, icon, position='left', onClick, size, className, ...cardProps} : ButtonProps){\n\n let cardClassNames = 'flex justify-center items-center gap-x-[0.40rem] h-[2.5rem] min-w-[2.5rem] box-border p-0'\n\n if (label) {\n cardClassNames += ' px-0 py-1'\n }\n\n\n if (className){\n const roundedMatch = className.match(/rounded\\-[a-z0-9]+/g)\n if (roundedMatch){\n cardClassNames += ' ' + roundedMatch[roundedMatch.length-1]\n }\n }\n\n if (size === 'sm'){\n cardClassNames += ' h-[2rem] w-[2rem] min-w-auto'\n }\n\n const buttonClick: MouseEventHandler<HTMLButtonElement> = (ev) => {\n if (typeof onClick === 'function') { \n onClick(ev)\n }\n }\n \n return(\n <button className={className} onClick={buttonClick}>\n <Card noBlur noPadding className={cardClassNames} {...cardProps}>\n {position === 'left' && icon}\n {label}\n {children}\n {position === 'right' && icon}\n </Card>\n </button>\n )\n}"],"names":[],"mappings":"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"}
package/dist/index.umd.js CHANGED
@@ -15,6 +15,57 @@
15
15
  const DEFAULT_THEME = "dark";
16
16
  const ThemeContext = react.createContext({ theme: DEFAULT_THEME, setTheme: () => {
17
17
  } });
18
+ let injectedStyles = /* @__PURE__ */ new Set();
19
+ function injectCSS(css, id) {
20
+ if (typeof document === "undefined" || injectedStyles.has(id)) {
21
+ return;
22
+ }
23
+ const style = document.createElement("style");
24
+ style.setAttribute("data-component-css", id);
25
+ style.innerHTML = css;
26
+ document.head.appendChild(style);
27
+ injectedStyles.add(id);
28
+ }
29
+ const CARD_CSS = `
30
+ .card{
31
+ /* border-radius: 20px; */
32
+ color: var(--card-text-color, white);
33
+ }
34
+
35
+ .card.glass{
36
+ background-color: color-mix(in oklch, var(--glass-color), transparent 80%);
37
+ border: 1px solid color-mix(in oklch, var(--glass-color), transparent 40%);
38
+ -webkit-backface-visibility: hidden;
39
+ -webkit-perspective: 1000;
40
+ -webkit-transform: translate3d(0,0,0);
41
+ -webkit-transform: translateZ(0);
42
+ backface-visibility: hidden;
43
+ perspective: 1000;
44
+ transform: translate3d(0,0,0);
45
+ transform: translateZ(0);
46
+ }
47
+
48
+ .card.mate{
49
+ background-color: var(--glass-color);
50
+ }
51
+
52
+ .card.outlined{
53
+ border: solid white 2px;
54
+ }
55
+
56
+ button .card.ghost:hover, button .card.outlined:hover{
57
+ background: color-mix(in oklch, var(--glass-color), transparent 80%);
58
+ }
59
+
60
+ button .card.glass:hover{
61
+ box-shadow: 0 4px 10px color-mix(in oklch, var(--glass-color), transparent 85%);
62
+ }
63
+
64
+ button .card.mate:hover{
65
+ background-color: color-mix(in oklch, var(--glass-color), white 10%)
66
+ }
67
+ `;
68
+ injectCSS(CARD_CSS, "card-component");
18
69
  function Card({ children, noPadding, noBlur = false, appearance = "glass", color = "neutral", intensity, dark = true, onClick, className, style }) {
19
70
  let [classNames, setClassNames] = react.useState("");
20
71
  let [cardStyle, setCardStyle] = react.useState({});
@@ -41,6 +92,23 @@
41
92
  }, [color, intensity, dark, appearance, noBlur, className, theme]);
42
93
  return /* @__PURE__ */ jsxRuntime.jsx("article", { className: classNames, style: cardStyle, onClick, children });
43
94
  }
95
+ const BUTTON_CSS = `
96
+ button{
97
+ background: none;
98
+ color: inherit;
99
+ border: none;
100
+ padding: 0;
101
+ font: inherit;
102
+ cursor: pointer;
103
+ outline: inherit;
104
+ font-weight: bold;
105
+ }
106
+
107
+ button:focus {
108
+ outline: revert;
109
+ }
110
+ `;
111
+ injectCSS(BUTTON_CSS, "button-component");
44
112
  function Button({ children, label, icon, position = "left", onClick, size, className, ...cardProps }) {
45
113
  let cardClassNames = "flex justify-center items-center gap-x-[0.40rem] h-[2.5rem] min-w-[2.5rem] box-border p-0";
46
114
  if (label) {
@@ -70,6 +138,7 @@
70
138
  exports2.Avatar = Avatar;
71
139
  exports2.Button = Button;
72
140
  exports2.Card = Card;
141
+ exports2.injectCSS = injectCSS;
73
142
  Object.defineProperty(exports2, Symbol.toStringTag, { value: "Module" });
74
143
  });
75
144
  //# sourceMappingURL=index.umd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.umd.js","sources":["../src/components/avatar.tsx","../src/components/theme-context.tsx","../src/components/card/card.tsx","../src/components/button/button.tsx"],"sourcesContent":["\r\ntype AvatarProps = {\r\n src: string;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport function Avatar({ src, className = '', style }: AvatarProps){\r\n return(\r\n <img className={`size-[3rem] rounded-2xl ${className}`} \r\n src={src} \r\n style={style}/>\r\n )\r\n}","import { useState, createContext } from 'react'\n\ntype ThemeMode = 'dark' | 'light';\nconst DEFAULT_THEME = 'dark';\n\ntype ThemeContext = {\n theme: ThemeMode,\n setTheme: (val: ThemeMode) => void\n}\n\nexport const ThemeContext = createContext<ThemeContext>({theme: DEFAULT_THEME, setTheme: () => {}}); //Creando el 'espacio compartido' al que los componentes pueden acceder??\n\nimport { ReactNode } from 'react';\n\nexport default function ThemeContextComponent({children}: {children: ReactNode}){\n\n const [theme, setTheme] = useState<ThemeMode>(DEFAULT_THEME)\n\n //Creando el componente donde todos los hijos pueden acceder al contexto (siendo children los props)\n return(\n <ThemeContext.Provider value={{theme, setTheme}}> \n {children}\n </ThemeContext.Provider>\n )\n}","import { MouseEventHandler, ReactNode, useContext, useEffect, useState } from 'react';\nimport { ThemeContext } from '../theme-context';\n\ntype CardProps = {\n children?: ReactNode;\n noPadding?: boolean;\n noBlur?: boolean;\n appearance?: string;\n color?: string;\n intensity?: number;\n dark?: boolean;\n onClick?: MouseEventHandler<HTMLElement>;\n className?: string;\n style?: React.CSSProperties;\n}\nexport function Card({children, noPadding, noBlur = false, appearance = 'glass', color = 'neutral', intensity, dark = true, onClick, className, style}: CardProps){\n \n let [classNames, setClassNames] = useState(\"\")\n let [cardStyle, setCardStyle] = useState({})\n const {theme} = useContext(ThemeContext)\n \n useEffect(() => {\n\n let intensityValue = intensity\n \n if (intensityValue === undefined){\n intensityValue = theme === 'dark' ? 600 : 300;\n }\n \n setCardStyle({\n \"--glass-color\": `var(--color-${color}-${intensityValue})`,\n \"--card-text-color\": `var(--color-${color}-${dark ? '100' : '800'})`,\n backdropFilter: appearance === 'glass' && !noBlur ? 'blur(10px)' : undefined,\n ...style\n });\n\n let rounded = 'rounded-md'\n\n if (className){\n const roundedMatch = className.match(/rounded\\-[a-z0-9]+/g)\n if (roundedMatch){\n rounded = roundedMatch[roundedMatch.length - 1]\n }\n }\n\n setClassNames(`card ${rounded} ${appearance} ${className} ${noPadding ? '' : 'p-[2rem]'}`)\n\n \n }, [color, intensity, dark, appearance, noBlur, className, theme])\n\n return(\n <article className={classNames} style={cardStyle} onClick={onClick}>\n {children}\n </article>\n )\n\n}\n","import { MouseEventHandler, ReactNode, useContext, useEffect, useState } from 'react';\nimport { Card } from '../card/card'\n\ntype ButtonProps = {\n children?: ReactNode;\n label?: string;\n icon?: ReactNode;\n position?: string\n onClick?: MouseEventHandler<HTMLElement>;\n size?: string;\n className?: string;\n noPadding?: boolean;\n noBlur?: boolean;\n appearance?: string;\n color?: string;\n intensity?: number;\n dark?: boolean;\n style?: React.CSSProperties;\n}\n\nexport function Button({children, label, icon, position='left', onClick, size, className, ...cardProps} : ButtonProps){\n\n let cardClassNames = 'flex justify-center items-center gap-x-[0.40rem] h-[2.5rem] min-w-[2.5rem] box-border p-0'\n\n if (label) {\n cardClassNames += ' px-0 py-1'\n }\n\n\n if (className){\n const roundedMatch = className.match(/rounded\\-[a-z0-9]+/g)\n if (roundedMatch){\n cardClassNames += ' ' + roundedMatch[roundedMatch.length-1]\n }\n }\n\n if (size === 'sm'){\n cardClassNames += ' h-[2rem] w-[2rem] min-w-auto'\n }\n\n const buttonClick: MouseEventHandler<HTMLButtonElement> = (ev) => {\n if (typeof onClick === 'function') { \n onClick(ev)\n }\n }\n \n return(\n <button className={className} onClick={buttonClick}>\n <Card noBlur noPadding className={cardClassNames} {...cardProps}>\n {position === 'left' && icon}\n {label}\n {children}\n {position === 'right' && icon}\n </Card>\n </button>\n )\n}"],"names":["jsx","createContext","useState","useContext","useEffect","jsxs"],"mappings":";;;;AAOO,WAAS,OAAO,EAAE,KAAK,YAAY,IAAI,SAAqB;AAC/D,WACIA,2BAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QAAI,WAAW,2BAA2B,SAAS;AAAA,QACpD;AAAA,QACA;AAAA,MAAA;AAAA,IAAA;AAAA,EAER;ACVA,QAAM,gBAAgB;AAOf,QAAM,eAAeC,MAAAA,cAA4B,EAAC,OAAO,eAAe,UAAU,MAAM;AAAA,EAAC,GAAE;ACK3F,WAAS,KAAK,EAAC,UAAU,WAAW,SAAS,OAAO,aAAa,SAAS,QAAQ,WAAW,WAAW,OAAO,MAAM,SAAS,WAAW,SAAkB;AAE9J,QAAI,CAAC,YAAY,aAAa,IAAIC,MAAAA,SAAS,EAAE;AAC7C,QAAI,CAAC,WAAW,YAAY,IAAIA,MAAAA,SAAS,CAAA,CAAE;AAC3C,UAAM,EAAC,MAAA,IAASC,MAAAA,WAAW,YAAY;AAEvCC,UAAAA,UAAU,MAAM;AAEZ,UAAI,iBAAiB;AAErB,UAAI,mBAAmB,QAAU;AAC7B,yBAAiB,UAAU,SAAS,MAAM;AAAA,MAC9C;AAEA,mBAAa;AAAA,QACT,iBAAiB,eAAe,KAAK,IAAI,cAAc;AAAA,QACvD,qBAAqB,eAAe,KAAK,IAAI,OAAO,QAAQ,KAAK;AAAA,QACjE,gBAAgB,eAAe,WAAW,CAAC,SAAS,eAAe;AAAA,QACnE,GAAG;AAAA,MAAA,CACN;AAED,UAAI,UAAU;AAEd,UAAI,WAAU;AACV,cAAM,eAAe,UAAU,MAAM,qBAAqB;AAC1D,YAAI,cAAa;AACb,oBAAU,aAAa,aAAa,SAAS,CAAC;AAAA,QAClD;AAAA,MACJ;AAEA,oBAAc,QAAQ,OAAO,IAAI,UAAU,IAAI,SAAS,IAAI,YAAY,KAAK,UAAU,EAAE;AAAA,IAG7F,GAAG,CAAC,OAAO,WAAW,MAAM,YAAY,QAAQ,WAAW,KAAK,CAAC;AAEjE,0CACK,WAAA,EAAQ,WAAW,YAAY,OAAO,WAAW,SAC7C,UACL;AAAA,EAGR;ACpCO,WAAS,OAAO,EAAC,UAAU,OAAO,MAAM,WAAS,QAAQ,SAAS,MAAM,WAAW,GAAG,UAAA,GAAyB;AAElH,QAAI,iBAAiB;AAErB,QAAI,OAAO;AACP,wBAAkB;AAAA,IACtB;AAGA,QAAI,WAAU;AACV,YAAM,eAAe,UAAU,MAAM,qBAAqB;AAC1D,UAAI,cAAa;AACb,0BAAkB,MAAM,aAAa,aAAa,SAAO,CAAC;AAAA,MAC9D;AAAA,IACJ;AAEA,QAAI,SAAS,MAAK;AACd,wBAAkB;AAAA,IACtB;AAEA,UAAM,cAAoD,CAAC,OAAO;AAC9D,UAAI,OAAO,YAAY,YAAY;AAC/B,gBAAQ,EAAE;AAAA,MACd;AAAA,IACJ;AAEA,WACIJ,2BAAAA,IAAC,UAAA,EAAO,WAAsB,SAAS,aACnC,UAAAK,gCAAC,MAAA,EAAK,QAAM,MAAC,WAAS,MAAC,WAAW,gBAAiB,GAAG,WACjD,UAAA;AAAA,MAAA,aAAa,UAAU;AAAA,MACvB;AAAA,MACA;AAAA,MACA,aAAa,WAAW;AAAA,IAAA,EAAA,CAC7B,EAAA,CACJ;AAAA,EAER;;;;;;"}
1
+ {"version":3,"file":"index.umd.js","sources":["../src/components/avatar.tsx","../src/components/theme-context.tsx","../src/utils/css-injection.ts","../src/components/card/card-styles.ts","../src/components/card/card.tsx","../src/components/button/button-styles.ts","../src/components/button/button.tsx"],"sourcesContent":["\r\ntype AvatarProps = {\r\n src: string;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport function Avatar({ src, className = '', style }: AvatarProps){\r\n return(\r\n <img className={`size-[3rem] rounded-2xl ${className}`} \r\n src={src} \r\n style={style}/>\r\n )\r\n}","import { useState, createContext } from 'react'\n\ntype ThemeMode = 'dark' | 'light';\nconst DEFAULT_THEME = 'dark';\n\ntype ThemeContext = {\n theme: ThemeMode,\n setTheme: (val: ThemeMode) => void\n}\n\nexport const ThemeContext = createContext<ThemeContext>({theme: DEFAULT_THEME, setTheme: () => {}}); //Creando el 'espacio compartido' al que los componentes pueden acceder??\n\nimport { ReactNode } from 'react';\n\nexport default function ThemeContextComponent({children}: {children: ReactNode}){\n\n const [theme, setTheme] = useState<ThemeMode>(DEFAULT_THEME)\n\n //Creando el componente donde todos los hijos pueden acceder al contexto (siendo children los props)\n return(\n <ThemeContext.Provider value={{theme, setTheme}}> \n {children}\n </ThemeContext.Provider>\n )\n}","// CSS injection utility to automatically include component styles\nlet injectedStyles = new Set<string>();\n\nexport function injectCSS(css: string, id: string): void {\n if (typeof document === 'undefined' || injectedStyles.has(id)) {\n return; // Skip in SSR or if already injected\n }\n\n const style = document.createElement('style');\n style.setAttribute('data-component-css', id);\n style.innerHTML = css;\n document.head.appendChild(style);\n injectedStyles.add(id);\n}\n","// Card component CSS as a string constant\nexport const CARD_CSS = `\n.card{\n /* border-radius: 20px; */\n color: var(--card-text-color, white);\n}\n\n.card.glass{\n background-color: color-mix(in oklch, var(--glass-color), transparent 80%);\n border: 1px solid color-mix(in oklch, var(--glass-color), transparent 40%);\n -webkit-backface-visibility: hidden;\n -webkit-perspective: 1000;\n -webkit-transform: translate3d(0,0,0);\n -webkit-transform: translateZ(0);\n backface-visibility: hidden;\n perspective: 1000;\n transform: translate3d(0,0,0);\n transform: translateZ(0);\n}\n\n.card.mate{\n background-color: var(--glass-color);\n}\n\n.card.outlined{\n border: solid white 2px;\n}\n\nbutton .card.ghost:hover, button .card.outlined:hover{\n background: color-mix(in oklch, var(--glass-color), transparent 80%);\n}\n\nbutton .card.glass:hover{\n box-shadow: 0 4px 10px color-mix(in oklch, var(--glass-color), transparent 85%);\n}\n\nbutton .card.mate:hover{\n background-color: color-mix(in oklch, var(--glass-color), white 10%) \n}\n`;\n","import { MouseEventHandler, ReactNode, useContext, useEffect, useState } from 'react';\nimport { ThemeContext } from '../theme-context';\nimport { injectCSS } from '../../utils/css-injection';\nimport { CARD_CSS } from './card-styles';\n\n// Inject Card CSS when the component is imported\ninjectCSS(CARD_CSS, 'card-component');\n\ntype CardProps = {\n children?: ReactNode;\n noPadding?: boolean;\n noBlur?: boolean;\n appearance?: string;\n color?: string;\n intensity?: number;\n dark?: boolean;\n onClick?: MouseEventHandler<HTMLElement>;\n className?: string;\n style?: React.CSSProperties;\n}\nexport function Card({children, noPadding, noBlur = false, appearance = 'glass', color = 'neutral', intensity, dark = true, onClick, className, style}: CardProps){\n \n let [classNames, setClassNames] = useState(\"\")\n let [cardStyle, setCardStyle] = useState({})\n const {theme} = useContext(ThemeContext)\n \n useEffect(() => {\n\n let intensityValue = intensity\n \n if (intensityValue === undefined){\n intensityValue = theme === 'dark' ? 600 : 300;\n }\n \n setCardStyle({\n \"--glass-color\": `var(--color-${color}-${intensityValue})`,\n \"--card-text-color\": `var(--color-${color}-${dark ? '100' : '800'})`,\n backdropFilter: appearance === 'glass' && !noBlur ? 'blur(10px)' : undefined,\n ...style\n });\n\n let rounded = 'rounded-md'\n\n if (className){\n const roundedMatch = className.match(/rounded\\-[a-z0-9]+/g)\n if (roundedMatch){\n rounded = roundedMatch[roundedMatch.length - 1]\n }\n }\n\n setClassNames(`card ${rounded} ${appearance} ${className} ${noPadding ? '' : 'p-[2rem]'}`)\n\n \n }, [color, intensity, dark, appearance, noBlur, className, theme])\n\n return(\n <article className={classNames} style={cardStyle} onClick={onClick}>\n {children}\n </article>\n )\n\n}\n","// Button component CSS as a string constant\nexport const BUTTON_CSS = `\nbutton{\n background: none;\n\tcolor: inherit;\n\tborder: none;\n\tpadding: 0;\n\tfont: inherit;\n\tcursor: pointer;\n\toutline: inherit;\n font-weight: bold;\n}\n\nbutton:focus {\n outline: revert;\n}\n`;\n","import { MouseEventHandler, ReactNode, useContext, useEffect, useState } from 'react';\nimport { Card } from '../card/card'\nimport { injectCSS } from '../../utils/css-injection';\nimport { BUTTON_CSS } from './button-styles';\n\n// Inject Button CSS when the component is imported\ninjectCSS(BUTTON_CSS, 'button-component');\n\ntype ButtonProps = {\n children?: ReactNode;\n label?: string;\n icon?: ReactNode;\n position?: string\n onClick?: MouseEventHandler<HTMLElement>;\n size?: string;\n className?: string;\n noPadding?: boolean;\n noBlur?: boolean;\n appearance?: string;\n color?: string;\n intensity?: number;\n dark?: boolean;\n style?: React.CSSProperties;\n}\n\nexport function Button({children, label, icon, position='left', onClick, size, className, ...cardProps} : ButtonProps){\n\n let cardClassNames = 'flex justify-center items-center gap-x-[0.40rem] h-[2.5rem] min-w-[2.5rem] box-border p-0'\n\n if (label) {\n cardClassNames += ' px-0 py-1'\n }\n\n\n if (className){\n const roundedMatch = className.match(/rounded\\-[a-z0-9]+/g)\n if (roundedMatch){\n cardClassNames += ' ' + roundedMatch[roundedMatch.length-1]\n }\n }\n\n if (size === 'sm'){\n cardClassNames += ' h-[2rem] w-[2rem] min-w-auto'\n }\n\n const buttonClick: MouseEventHandler<HTMLButtonElement> = (ev) => {\n if (typeof onClick === 'function') { \n onClick(ev)\n }\n }\n \n return(\n <button className={className} onClick={buttonClick}>\n <Card noBlur noPadding className={cardClassNames} {...cardProps}>\n {position === 'left' && icon}\n {label}\n {children}\n {position === 'right' && icon}\n </Card>\n </button>\n )\n}"],"names":["jsx","createContext","useState","useContext","useEffect","jsxs"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ *,:before,:after{--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: rgb(59 130 246 / .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: rgb(59 130 246 / .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: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{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,samp,pre{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,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{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}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.mb-2{margin-bottom:.5rem}.mr-\[1rem\]{margin-right:1rem}.box-border{box-sizing:border-box}.flex{display:flex}.hidden{display:none}.size-\[3rem\]{width:3rem;height:3rem}.h-\[2\.5rem\]{height:2.5rem}.h-\[2rem\]{height:2rem}.w-\[2rem\]{width:2rem}.min-w-\[2\.5rem\]{min-width:2.5rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.items-center{align-items:center}.justify-center{justify-content:center}.gap-x-\[0\.40rem\]{-moz-column-gap:.4rem;column-gap:.4rem}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-4{border-width:4px}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.p-0{padding:0}.p-\[2rem\]{padding:2rem}.px-0{padding-left:0;padding-right:0}.py-1{padding-top:.25rem;padding-bottom:.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.font-bold{font-weight:700}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-red-50: oklch(.971 .013 17.38);--color-red-100: oklch(.936 .032 17.717);--color-red-200: oklch(.885 .062 18.334);--color-red-300: oklch(.808 .114 19.571);--color-red-400: oklch(.704 .191 22.216);--color-red-500: oklch(.637 .237 25.331);--color-red-600: oklch(.577 .245 27.325);--color-red-700: oklch(.505 .213 27.518);--color-red-800: oklch(.444 .177 26.899);--color-red-900: oklch(.396 .141 25.723);--color-red-950: oklch(.258 .092 26.042);--color-orange-50: oklch(.98 .016 73.684);--color-orange-100: oklch(.954 .038 75.164);--color-orange-200: oklch(.901 .076 70.697);--color-orange-300: oklch(.837 .128 66.29);--color-orange-400: oklch(.75 .183 55.934);--color-orange-500: oklch(.705 .213 47.604);--color-orange-600: oklch(.646 .222 41.116);--color-orange-700: oklch(.553 .195 38.402);--color-orange-800: oklch(.47 .157 37.304);--color-orange-900: oklch(.408 .123 38.172);--color-orange-950: oklch(.266 .079 36.259);--color-amber-50: oklch(.987 .022 95.277);--color-amber-100: oklch(.962 .059 95.617);--color-amber-200: oklch(.924 .12 95.746);--color-amber-300: oklch(.879 .169 91.605);--color-amber-400: oklch(.828 .189 84.429);--color-amber-500: oklch(.769 .188 70.08);--color-amber-600: oklch(.666 .179 58.318);--color-amber-700: oklch(.555 .163 48.998);--color-amber-800: oklch(.473 .137 46.201);--color-amber-900: oklch(.414 .112 45.904);--color-amber-950: oklch(.279 .077 45.635);--color-yellow-50: oklch(.987 .026 102.212);--color-yellow-100: oklch(.973 .071 103.193);--color-yellow-200: oklch(.945 .129 101.54);--color-yellow-300: oklch(.905 .182 98.111);--color-yellow-400: oklch(.852 .199 91.936);--color-yellow-500: oklch(.795 .184 86.047);--color-yellow-600: oklch(.681 .162 75.834);--color-yellow-700: oklch(.554 .135 66.442);--color-yellow-800: oklch(.476 .114 61.907);--color-yellow-900: oklch(.421 .095 57.708);--color-yellow-950: oklch(.286 .066 53.813);--color-lime-50: oklch(.986 .031 120.757);--color-lime-100: oklch(.967 .067 122.328);--color-lime-200: oklch(.938 .127 124.321);--color-lime-300: oklch(.897 .196 126.665);--color-lime-400: oklch(.841 .238 128.85);--color-lime-500: oklch(.768 .233 130.85);--color-lime-600: oklch(.648 .2 131.684);--color-lime-700: oklch(.532 .157 131.589);--color-lime-800: oklch(.453 .124 130.933);--color-lime-900: oklch(.405 .101 131.063);--color-lime-950: oklch(.274 .072 132.109);--color-green-50: oklch(.982 .018 155.826);--color-green-100: oklch(.962 .044 156.743);--color-green-200: oklch(.925 .084 155.995);--color-green-300: oklch(.871 .15 154.449);--color-green-400: oklch(.792 .209 151.711);--color-green-500: oklch(.723 .219 149.579);--color-green-600: oklch(.627 .194 149.214);--color-green-700: oklch(.527 .154 150.069);--color-green-800: oklch(.448 .119 151.328);--color-green-900: oklch(.393 .095 152.535);--color-green-950: oklch(.266 .065 152.934);--color-emerald-50: oklch(.979 .021 166.113);--color-emerald-100: oklch(.95 .052 163.051);--color-emerald-200: oklch(.905 .093 164.15);--color-emerald-300: oklch(.845 .143 164.978);--color-emerald-400: oklch(.765 .177 163.223);--color-emerald-500: oklch(.696 .17 162.48);--color-emerald-600: oklch(.596 .145 163.225);--color-emerald-700: oklch(.508 .118 165.612);--color-emerald-800: oklch(.432 .095 166.913);--color-emerald-900: oklch(.378 .077 168.94);--color-emerald-950: oklch(.262 .051 172.552);--color-teal-50: oklch(.984 .014 180.72);--color-teal-100: oklch(.953 .051 180.801);--color-teal-200: oklch(.91 .096 180.426);--color-teal-300: oklch(.855 .138 181.071);--color-teal-400: oklch(.777 .152 181.912);--color-teal-500: oklch(.704 .14 182.503);--color-teal-600: oklch(.6 .118 184.704);--color-teal-700: oklch(.511 .096 186.391);--color-teal-800: oklch(.437 .078 188.216);--color-teal-900: oklch(.386 .063 188.416);--color-teal-950: oklch(.277 .046 192.524);--color-cyan-50: oklch(.984 .019 200.873);--color-cyan-100: oklch(.956 .045 203.388);--color-cyan-200: oklch(.917 .08 205.041);--color-cyan-300: oklch(.865 .127 207.078);--color-cyan-400: oklch(.789 .154 211.53);--color-cyan-500: oklch(.715 .143 215.221);--color-cyan-600: oklch(.609 .126 221.723);--color-cyan-700: oklch(.52 .105 223.128);--color-cyan-800: oklch(.45 .085 224.283);--color-cyan-900: oklch(.398 .07 227.392);--color-cyan-950: oklch(.302 .056 229.695);--color-sky-50: oklch(.977 .013 236.62);--color-sky-100: oklch(.951 .026 236.824);--color-sky-200: oklch(.901 .058 230.902);--color-sky-300: oklch(.828 .111 230.318);--color-sky-400: oklch(.746 .16 232.661);--color-sky-500: oklch(.685 .169 237.323);--color-sky-600: oklch(.588 .158 241.966);--color-sky-700: oklch(.5 .134 242.749);--color-sky-800: oklch(.443 .11 240.79);--color-sky-900: oklch(.391 .09 240.876);--color-sky-950: oklch(.293 .066 243.157);--color-blue-50: oklch(.97 .014 254.604);--color-blue-100: oklch(.932 .032 255.585);--color-blue-200: oklch(.882 .059 254.128);--color-blue-300: oklch(.809 .105 251.813);--color-blue-400: oklch(.707 .165 254.624);--color-blue-500: oklch(.623 .214 259.815);--color-blue-600: oklch(.546 .245 262.881);--color-blue-700: oklch(.488 .243 264.376);--color-blue-800: oklch(.424 .199 265.638);--color-blue-900: oklch(.379 .146 265.522);--color-blue-950: oklch(.282 .091 267.935);--color-indigo-50: oklch(.962 .018 272.314);--color-indigo-100: oklch(.93 .034 272.788);--color-indigo-200: oklch(.87 .065 274.039);--color-indigo-300: oklch(.785 .115 274.713);--color-indigo-400: oklch(.673 .182 276.935);--color-indigo-500: oklch(.585 .233 277.117);--color-indigo-600: oklch(.511 .262 276.966);--color-indigo-700: oklch(.457 .24 277.023);--color-indigo-800: oklch(.398 .195 277.366);--color-indigo-900: oklch(.359 .144 278.697);--color-indigo-950: oklch(.257 .09 281.288);--color-violet-50: oklch(.969 .016 293.756);--color-violet-100: oklch(.943 .029 294.588);--color-violet-200: oklch(.894 .057 293.283);--color-violet-300: oklch(.811 .111 293.571);--color-violet-400: oklch(.702 .183 293.541);--color-violet-500: oklch(.606 .25 292.717);--color-violet-600: oklch(.541 .281 293.009);--color-violet-700: oklch(.491 .27 292.581);--color-violet-800: oklch(.432 .232 292.759);--color-violet-900: oklch(.38 .189 293.745);--color-violet-950: oklch(.283 .141 291.089);--color-purple-50: oklch(.977 .014 308.299);--color-purple-100: oklch(.946 .033 307.174);--color-purple-200: oklch(.902 .063 306.703);--color-purple-300: oklch(.827 .119 306.383);--color-purple-400: oklch(.714 .203 305.504);--color-purple-500: oklch(.627 .265 303.9);--color-purple-600: oklch(.558 .288 302.321);--color-purple-700: oklch(.496 .265 301.924);--color-purple-800: oklch(.438 .218 303.724);--color-purple-900: oklch(.381 .176 304.987);--color-purple-950: oklch(.291 .149 302.717);--color-fuchsia-50: oklch(.977 .017 320.058);--color-fuchsia-100: oklch(.952 .037 318.852);--color-fuchsia-200: oklch(.903 .076 319.62);--color-fuchsia-300: oklch(.833 .145 321.434);--color-fuchsia-400: oklch(.74 .238 322.16);--color-fuchsia-500: oklch(.667 .295 322.15);--color-fuchsia-600: oklch(.591 .293 322.896);--color-fuchsia-700: oklch(.518 .253 323.949);--color-fuchsia-800: oklch(.452 .211 324.591);--color-fuchsia-900: oklch(.401 .17 325.612);--color-fuchsia-950: oklch(.293 .136 325.661);--color-pink-50: oklch(.971 .014 343.198);--color-pink-100: oklch(.948 .028 342.258);--color-pink-200: oklch(.899 .061 343.231);--color-pink-300: oklch(.823 .12 346.018);--color-pink-400: oklch(.718 .202 349.761);--color-pink-500: oklch(.656 .241 354.308);--color-pink-600: oklch(.592 .249 .584);--color-pink-700: oklch(.525 .223 3.958);--color-pink-800: oklch(.459 .187 3.815);--color-pink-900: oklch(.408 .153 2.432);--color-pink-950: oklch(.284 .109 3.907);--color-rose-50: oklch(.969 .015 12.422);--color-rose-100: oklch(.941 .03 12.58);--color-rose-200: oklch(.892 .058 10.001);--color-rose-300: oklch(.81 .117 11.638);--color-rose-400: oklch(.712 .194 13.428);--color-rose-500: oklch(.645 .246 16.439);--color-rose-600: oklch(.586 .253 17.585);--color-rose-700: oklch(.514 .222 16.935);--color-rose-800: oklch(.455 .188 13.697);--color-rose-900: oklch(.41 .159 10.272);--color-rose-950: oklch(.271 .105 12.094);--color-slate-50: oklch(.984 .003 247.858);--color-slate-100: oklch(.968 .007 247.896);--color-slate-200: oklch(.929 .013 255.508);--color-slate-300: oklch(.869 .022 252.894);--color-slate-400: oklch(.704 .04 256.788);--color-slate-500: oklch(.554 .046 257.417);--color-slate-600: oklch(.446 .043 257.281);--color-slate-700: oklch(.372 .044 257.287);--color-slate-800: oklch(.279 .041 260.031);--color-slate-900: oklch(.208 .042 265.755);--color-slate-950: oklch(.129 .042 264.695);--color-gray-50: oklch(.985 .002 247.839);--color-gray-100: oklch(.967 .003 264.542);--color-gray-200: oklch(.928 .006 264.531);--color-gray-300: oklch(.872 .01 258.338);--color-gray-400: oklch(.707 .022 261.325);--color-gray-500: oklch(.551 .027 264.364);--color-gray-600: oklch(.446 .03 256.802);--color-gray-700: oklch(.373 .034 259.733);--color-gray-800: oklch(.278 .033 256.848);--color-gray-900: oklch(.21 .034 264.665);--color-gray-950: oklch(.13 .028 261.692);--color-zinc-50: oklch(.985 0 0);--color-zinc-100: oklch(.967 .001 286.375);--color-zinc-200: oklch(.92 .004 286.32);--color-zinc-300: oklch(.871 .006 286.286);--color-zinc-400: oklch(.705 .015 286.067);--color-zinc-500: oklch(.552 .016 285.938);--color-zinc-600: oklch(.442 .017 285.786);--color-zinc-700: oklch(.37 .013 285.805);--color-zinc-800: oklch(.274 .006 286.033);--color-zinc-900: oklch(.21 .006 285.885);--color-zinc-950: oklch(.141 .005 285.823);--color-neutral-50: oklch(.985 0 0);--color-neutral-100: oklch(.97 0 0);--color-neutral-200: oklch(.922 0 0);--color-neutral-300: oklch(.87 0 0);--color-neutral-400: oklch(.708 0 0);--color-neutral-500: oklch(.556 0 0);--color-neutral-600: oklch(.439 0 0);--color-neutral-700: oklch(.371 0 0);--color-neutral-800: oklch(.269 0 0);--color-neutral-900: oklch(.205 0 0);--color-neutral-950: oklch(.145 0 0);--color-stone-50: oklch(.985 .001 106.423);--color-stone-100: oklch(.97 .001 106.424);--color-stone-200: oklch(.923 .003 48.717);--color-stone-300: oklch(.869 .005 56.366);--color-stone-400: oklch(.709 .01 56.259);--color-stone-500: oklch(.553 .013 58.071);--color-stone-600: oklch(.444 .011 73.639);--color-stone-700: oklch(.374 .01 67.558);--color-stone-800: oklch(.268 .007 34.298);--color-stone-900: oklch(.216 .006 56.043);--color-stone-950: oklch(.147 .004 49.25);--color-black: #000;--color-white: #fff;--glass-color: var(--color-neutral-400);--card-text-color: var(--color-neutral-100);--glass-opacity: 80%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;background-color:#1a1a1a;height:100vh;overflow:hidden}h1{font-size:3.2em;line-height:1.1}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
@@ -0,0 +1 @@
1
+ export declare function injectCSS(css: string, id: string): void;
package/package.json CHANGED
@@ -1,19 +1,18 @@
1
1
  {
2
2
  "name": "azeriand-library",
3
- "version": "1.3.7",
3
+ "version": "1.3.8",
4
4
  "description": "A React component library with Tailwind CSS",
5
- "main": "dist/index.js",
5
+ "main": "dist/index.umd.js",
6
6
  "module": "dist/index.esm.js",
7
7
  "types": "dist/index.d.ts",
8
8
  "files": [
9
- "dist",
10
- "src/styles/globals.css"
9
+ "dist"
11
10
  ],
12
11
  "scripts": {
13
- "build": "npm run build:types && npm run build:js && npm run postbuild",
14
- "postbuild": "node copy-styles.js",
12
+ "build": "npm run build:types && npm run build:js && npm run build:css",
15
13
  "build:types": "tsc --emitDeclarationOnly --outDir dist",
16
14
  "build:js": "vite build",
15
+ "build:css": "vite build --config vite.styles.config.ts && rm -f dist/styles-temp.js dist/styles-only.d.ts && rm -rf dist/styles/",
17
16
  "dev": "vite build --watch",
18
17
  "test": "echo \"Error: no test specified\" && exit 1",
19
18
  "storybook": "storybook dev -p 6006",
@@ -1,14 +0,0 @@
1
- button{
2
- background: none;
3
- color: inherit;
4
- border: none;
5
- padding: 0;
6
- font: inherit;
7
- cursor: pointer;
8
- outline: inherit;
9
- font-weight: bold;
10
- }
11
-
12
- button:focus {
13
- outline: revert;
14
- }
@@ -1,37 +0,0 @@
1
- .card{
2
- /* border-radius: 20px; */
3
- color: var(--card-text-color, white);
4
- }
5
-
6
- .card.glass{
7
- background-color: color-mix(in oklch, var(--glass-color), transparent 80%);
8
- border: 1px solid color-mix(in oklch, var(--glass-color), transparent 40%);
9
- -webkit-backface-visibility: hidden;
10
- -webkit-perspective: 1000;
11
- -webkit-transform: translate3d(0,0,0);
12
- -webkit-transform: translateZ(0);
13
- backface-visibility: hidden;
14
- perspective: 1000;
15
- transform: translate3d(0,0,0);
16
- transform: translateZ(0);
17
- }
18
-
19
- .card.mate{
20
- background-color: var(--glass-color);
21
- }
22
-
23
- .card.outlined{
24
- border: solid white 2px;
25
- }
26
-
27
- button .card.ghost:hover, button .card.outlined:hover{
28
- background: color-mix(in oklch, var(--glass-color), transparent 80%);
29
- }
30
-
31
- button .card.glass:hover{
32
- box-shadow: 0 4px 10px color-mix(in oklch, var(--glass-color), transparent 85%);
33
- }
34
-
35
- button .card.mate:hover{
36
- background-color: color-mix(in oklch, var(--glass-color), white 10%)
37
- }