@farm-junction/design-library 0.1.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.
@@ -0,0 +1 @@
1
+ @import"https://fonts.googleapis.com/css2?family=Mulish:wght@400;500;600;700&display=swap";/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-font-weight:initial;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:"Mulish", ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-slate-100:oklch(96.8% .007 247.896);--color-slate-200:oklch(92.9% .013 255.508);--color-slate-500:oklch(55.4% .046 257.417);--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-medium:500;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-brand-600:#1d4ed8;--color-brand-700:#1e40af;--color-primary:var(--color-brand-600);--color-primary-hover:var(--color-brand-700);--color-on-primary:#fff;--color-secondary:#f1f5f9;--color-on-secondary:#0f172a;--color-on-surface:#0f172a;--color-border:#e2e8f0}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.flex{display:flex}.grid{display:grid}.inline-flex{display:inline-flex}.h-16{height:calc(var(--spacing) * 16)}.h-20{height:calc(var(--spacing) * 20)}.w-20{width:calc(var(--spacing) * 20)}.w-full{width:100%}.min-w-\[8rem\]{min-width:8rem}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.border{border-style:var(--tw-border-style);border-width:1px}.border-border{border-color:var(--color-border)}.border-transparent{border-color:#0000}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.bg-transparent{background-color:#0000}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.font-sans{font-family:var(--font-sans)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.text-on-primary{color:var(--color-on-primary)}.text-on-secondary{color:var(--color-on-secondary)}.text-on-surface{color:var(--color-on-surface)}.text-slate-500{color:var(--color-slate-500)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media(hover:hover){.hover\:bg-primary-hover:hover{background-color:var(--color-primary-hover)}.hover\:bg-slate-100:hover{background-color:var(--color-slate-100)}.hover\:bg-slate-200:hover{background-color:var(--color-slate-200)}}.focus-visible\:outline-2:focus-visible{outline-style:var(--tw-outline-style);outline-width:2px}.focus-visible\:outline-offset-2:focus-visible{outline-offset:2px}.focus-visible\:outline-primary:focus-visible{outline-color:var(--color-primary)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}@media(min-width:40rem){.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:48rem){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
@@ -0,0 +1,3 @@
1
+ @import url("https://fonts.googleapis.com/css2?family=Mulish:wght@400;500;600;700&display=swap");
2
+ @import "tailwindcss";
3
+ @import "./tokens/theme.css";
@@ -0,0 +1,37 @@
1
+ @theme {
2
+ /* Brand */
3
+ --color-brand-50: #eff6ff;
4
+ --color-brand-100: #dbeafe;
5
+ --color-brand-500: #2563eb;
6
+ --color-brand-600: #1d4ed8;
7
+ --color-brand-700: #1e40af;
8
+
9
+ /* Semantic */
10
+ --color-primary: var(--color-brand-600);
11
+ --color-primary-hover: var(--color-brand-700);
12
+ --color-on-primary: #ffffff;
13
+ --color-secondary: #f1f5f9;
14
+ --color-on-secondary: #0f172a;
15
+ --color-surface: #ffffff;
16
+ --color-on-surface: #0f172a;
17
+ --color-danger: #dc2626;
18
+ --color-on-danger: #ffffff;
19
+ --color-border: #e2e8f0;
20
+
21
+ /* Typography */
22
+ --font-sans: "Mulish", ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
23
+ "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
24
+
25
+ /* Radius */
26
+ --radius-sm: 0.25rem;
27
+ --radius-md: 0.375rem;
28
+ --radius-lg: 0.5rem;
29
+
30
+ /* Spacing (used by components) */
31
+ --spacing-button-sm-x: 0.75rem;
32
+ --spacing-button-sm-y: 0.375rem;
33
+ --spacing-button-md-x: 1rem;
34
+ --spacing-button-md-y: 0.5rem;
35
+ --spacing-button-lg-x: 1.25rem;
36
+ --spacing-button-lg-y: 0.625rem;
37
+ }
package/package.json ADDED
@@ -0,0 +1,72 @@
1
+ {
2
+ "name": "@farm-junction/design-library",
3
+ "version": "0.1.0",
4
+ "description": "Farm Junction React design system — tokens, components, and Tailwind 4 preset",
5
+ "type": "module",
6
+ "files": [
7
+ "dist"
8
+ ],
9
+ "main": "./dist/index.js",
10
+ "module": "./dist/index.js",
11
+ "types": "./dist/index.d.ts",
12
+ "exports": {
13
+ ".": {
14
+ "import": "./dist/index.js",
15
+ "types": "./dist/index.d.ts"
16
+ },
17
+ "./styles.css": "./dist/styles.css",
18
+ "./tailwind-preset": "./dist/tailwind-preset.css"
19
+ },
20
+ "sideEffects": [
21
+ "**/*.css"
22
+ ],
23
+ "scripts": {
24
+ "dev": "storybook dev -p 6006",
25
+ "build": "tsc -p tsconfig.build.json --noEmit && vite build",
26
+ "build-storybook": "storybook build",
27
+ "lint": "eslint src .storybook",
28
+ "prepublishOnly": "npm run build"
29
+ },
30
+ "publishConfig": {
31
+ "access": "public"
32
+ },
33
+ "dependencies": {
34
+ "clsx": "^2.1.1",
35
+ "tailwind-merge": "^3.3.0"
36
+ },
37
+ "peerDependencies": {
38
+ "react": "^19.0.0",
39
+ "react-dom": "^19.0.0"
40
+ },
41
+ "devDependencies": {
42
+ "@eslint/js": "^9.28.0",
43
+ "@storybook/addon-essentials": "^8.6.14",
44
+ "@storybook/addon-interactions": "^8.6.14",
45
+ "@storybook/addon-links": "^8.6.14",
46
+ "@storybook/blocks": "^8.6.14",
47
+ "@storybook/react": "^8.6.14",
48
+ "@storybook/react-vite": "^8.6.14",
49
+ "@storybook/test": "^8.6.14",
50
+ "@tailwindcss/vite": "^4.1.8",
51
+ "@types/react": "^19.1.6",
52
+ "@types/react-dom": "^19.1.5",
53
+ "@vitejs/plugin-react": "^4.5.2",
54
+ "eslint": "^9.28.0",
55
+ "eslint-plugin-react-hooks": "^5.2.0",
56
+ "react": "^19.1.0",
57
+ "react-dom": "^19.1.0",
58
+ "storybook": "^8.6.14",
59
+ "tailwindcss": "^4.1.8",
60
+ "typescript": "^5.8.3",
61
+ "typescript-eslint": "^8.33.1",
62
+ "vite": "^6.3.5",
63
+ "vite-plugin-dts": "^4.5.4"
64
+ },
65
+ "keywords": [
66
+ "design-system",
67
+ "react",
68
+ "tailwindcss",
69
+ "components"
70
+ ],
71
+ "license": "UNLICENSED"
72
+ }