@oneplatformdev/ui 0.1.99-beta.4 → 0.1.99-beta.40

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 (98) hide show
  1. package/Accordion/Accordion.d.ts +1 -1
  2. package/Accordion/Accordion.d.ts.map +1 -1
  3. package/Accordion/Accordion.js +48 -26
  4. package/Accordion/Accordion.js.map +1 -1
  5. package/Badge/badgeVariants.d.ts +1 -1
  6. package/Button/Button.d.ts +6 -6
  7. package/Button/Button.d.ts.map +1 -1
  8. package/Button/Button.js +44 -42
  9. package/Button/Button.js.map +1 -1
  10. package/Button/Button.stories.js +45 -53
  11. package/Button/Button.stories.js.map +1 -1
  12. package/Button/Button.types.d.ts +24 -1
  13. package/Button/Button.types.d.ts.map +1 -1
  14. package/Button/ButtonCounterBadge.d.ts +7 -0
  15. package/Button/ButtonCounterBadge.d.ts.map +1 -0
  16. package/Button/ButtonCounterBadge.js +20 -0
  17. package/Button/ButtonCounterBadge.js.map +1 -0
  18. package/Button/buttonVariants.d.ts +11 -20
  19. package/Button/buttonVariants.d.ts.map +1 -1
  20. package/Button/buttonVariants.js +76 -12
  21. package/Button/buttonVariants.js.map +1 -1
  22. package/Button/index.js +6 -5
  23. package/ButtonIcon/ButtonIcon.d.ts +30 -19
  24. package/ButtonIcon/ButtonIcon.d.ts.map +1 -1
  25. package/ButtonIcon/ButtonIcon.js +70 -46
  26. package/ButtonIcon/ButtonIcon.js.map +1 -1
  27. package/ButtonIcon/ButtonIcon.stories.js +121 -78
  28. package/ButtonIcon/ButtonIcon.stories.js.map +1 -1
  29. package/ButtonIcon/ButtonIcon.types.d.ts +2 -1
  30. package/ButtonIcon/ButtonIcon.types.d.ts.map +1 -1
  31. package/ButtonIcon/buttonIconVariants.d.ts +1 -1
  32. package/ButtonIcon/buttonIconVariants.d.ts.map +1 -1
  33. package/ButtonIcon/buttonIconVariants.js +7 -6
  34. package/ButtonIcon/buttonIconVariants.js.map +1 -1
  35. package/CHANGELOG.md +466 -0
  36. package/Combobox/Combobox.d.ts.map +1 -1
  37. package/Combobox/Combobox.js +25 -26
  38. package/Combobox/Combobox.js.map +1 -1
  39. package/Combobox/Combobox.stories.js +192 -0
  40. package/Combobox/Combobox.stories.js.map +1 -0
  41. package/Combobox/ComboboxOptions.d.ts.map +1 -1
  42. package/Combobox/ComboboxOptions.js +42 -42
  43. package/Combobox/ComboboxOptions.js.map +1 -1
  44. package/Dialog/Dialog.js +13 -13
  45. package/Dialog/Dialog.js.map +1 -1
  46. package/DropdownMenu/DropdownMenu.d.ts.map +1 -1
  47. package/DropdownMenu/DropdownMenu.js +33 -20
  48. package/DropdownMenu/DropdownMenu.js.map +1 -1
  49. package/Form/Form.d.ts.map +1 -1
  50. package/Form/Form.js.map +1 -1
  51. package/Form/FormRenderControl.d.ts.map +1 -1
  52. package/Form/FormRenderControl.js +26 -13
  53. package/Form/FormRenderControl.js.map +1 -1
  54. package/Form/FormRenderControl.types.d.ts +2 -1
  55. package/Form/FormRenderControl.types.d.ts.map +1 -1
  56. package/Form/FormTooltipButton.d.ts +6 -0
  57. package/Form/FormTooltipButton.d.ts.map +1 -0
  58. package/Form/FormTooltipButton.js +34 -0
  59. package/Form/FormTooltipButton.js.map +1 -0
  60. package/FormInput/FormInput.d.ts.map +1 -1
  61. package/FormInput/FormInput.js +22 -21
  62. package/FormInput/FormInput.js.map +1 -1
  63. package/Input/Input.js +1 -1
  64. package/Input/Input.js.map +1 -1
  65. package/Input/inputVariants.d.ts.map +1 -1
  66. package/Input/inputVariants.js +5 -4
  67. package/Input/inputVariants.js.map +1 -1
  68. package/LoadedIcon/LoadedIcon.d.ts.map +1 -1
  69. package/LoadedIcon/LoadedIcon.js +3 -1
  70. package/LoadedIcon/LoadedIcon.js.map +1 -1
  71. package/Resizable/Resizable.d.ts +5 -20
  72. package/Resizable/Resizable.d.ts.map +1 -1
  73. package/Resizable/Resizable.js +48 -31
  74. package/Resizable/Resizable.js.map +1 -1
  75. package/Resizable/Resizable.stories.js +140 -0
  76. package/Resizable/Resizable.stories.js.map +1 -0
  77. package/Search/Search.js +12 -12
  78. package/Search/Search.js.map +1 -1
  79. package/Search/Search.stories.js +17 -0
  80. package/Search/Search.stories.js.map +1 -0
  81. package/Textarea/Textarea.d.ts.map +1 -1
  82. package/Textarea/Textarea.js +50 -45
  83. package/Textarea/Textarea.js.map +1 -1
  84. package/Textarea/Textarea.stories.js +12 -0
  85. package/Textarea/Textarea.stories.js.map +1 -0
  86. package/Textarea/Textarea.types.d.ts +3 -1
  87. package/Textarea/Textarea.types.d.ts.map +1 -1
  88. package/Textarea/useAutosizeTextArea.d.ts +1 -1
  89. package/Textarea/useAutosizeTextArea.d.ts.map +1 -1
  90. package/Textarea/useAutosizeTextArea.js.map +1 -1
  91. package/Tooltip/Tooltip.d.ts.map +1 -1
  92. package/Tooltip/Tooltip.js.map +1 -1
  93. package/index.js +326 -325
  94. package/package.json +7 -4
  95. package/Button/Button.s.d.ts +0 -83
  96. package/Button/Button.s.d.ts.map +0 -1
  97. package/Button/Button.s.js +0 -163
  98. package/Button/Button.s.js.map +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@oneplatformdev/ui",
3
- "version": "0.1.99-beta.4",
3
+ "version": "0.1.99-beta.40",
4
4
  "description": "UI component library for OnePlatform",
5
5
  "author": "One Platform Development Team",
6
6
  "keywords": [
@@ -105,8 +105,11 @@
105
105
  "recharts": "^3.2.0",
106
106
  "sonner": "^2.0.7",
107
107
  "vaul": "^1.1.2",
108
- "@oneplatformdev/tokens": "^0.1.99-beta.4",
109
- "@oneplatformdev/hooks": "^0.1.99-beta.4",
110
- "@oneplatformdev/utils": "^0.1.99-beta.4"
108
+ "@oneplatformdev/tokens": "^0.1.99-beta.40",
109
+ "@oneplatformdev/hooks": "^0.1.99-beta.40",
110
+ "@oneplatformdev/utils": "^0.1.99-beta.40"
111
+ },
112
+ "scripts": {
113
+ "chromatic": "chromatic"
111
114
  }
112
115
  }
@@ -1,83 +0,0 @@
1
- import { StoryObj } from '@storybook/react';
2
- import { ButtonProps } from './Button.types';
3
- declare const meta: {
4
- title: string;
5
- component: import('react').ForwardRefExoticComponent<ButtonProps & import('react').RefAttributes<HTMLButtonElement>>;
6
- render: (props: ButtonProps) => import("react/jsx-runtime").JSX.Element;
7
- args: {
8
- tooltip: undefined;
9
- asChild: false;
10
- variant: "none" | "default" | "destructive" | "outline" | "secondary" | "contained" | "outlined" | "ghost" | null | undefined;
11
- color: "secondary" | "primary" | "error" | null | undefined;
12
- size: "xs" | "sm" | "md" | "lg" | null | undefined;
13
- disabled: false;
14
- };
15
- argTypes: {
16
- tooltip: {
17
- control: false;
18
- };
19
- asChild: {
20
- control: false;
21
- };
22
- variant: {
23
- options: ("none" | "default" | "destructive" | "outline" | "secondary" | "contained" | "outlined" | "ghost" | null | undefined)[];
24
- control: {
25
- type: "inline-radio";
26
- };
27
- };
28
- color: {
29
- options: ("secondary" | "primary" | "error" | null | undefined)[];
30
- control: {
31
- type: "inline-radio";
32
- };
33
- };
34
- size: {
35
- options: ("xs" | "sm" | "md" | "lg" | null | undefined)[];
36
- control: {
37
- type: "inline-radio";
38
- };
39
- };
40
- title: {
41
- name: string;
42
- description: string;
43
- control: {
44
- type: "text";
45
- };
46
- };
47
- message: {
48
- name: string;
49
- description: string;
50
- control: {
51
- type: "object";
52
- };
53
- };
54
- slotProps: {
55
- name: string;
56
- description: string;
57
- control: {
58
- type: "object";
59
- };
60
- };
61
- };
62
- tags: string[];
63
- parameters: {
64
- docs: {
65
- description: {
66
- component: string;
67
- };
68
- };
69
- pseudo: {
70
- hover: string;
71
- focus: string;
72
- active: string;
73
- disabled: string;
74
- };
75
- };
76
- };
77
- export default meta;
78
- type Story = StoryObj<typeof meta>;
79
- export declare const Default: Story;
80
- export declare const Primary: Story;
81
- export declare const Secondary: Story;
82
- export declare const Error: Story;
83
- //# sourceMappingURL=Button.s.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Button.s.d.ts","sourceRoot":"","sources":["../../src/Button/Button.s.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAGvD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AA2DlD,QAAA,MAAM,IAAI;;;oBAvDe,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwGL,CAAC;AAChC,eAAe,IAAI,CAAC;AAEpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAQnC,eAAO,MAAM,OAAO,EAAE,KAKrB,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,KAoBrB,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,KAoBvB,CAAC;AAEF,eAAO,MAAM,KAAK,EAAE,KAoBnB,CAAC"}
@@ -1,163 +0,0 @@
1
- import { jsx as e, jsxs as n } from "react/jsx-runtime";
2
- import { Button as i } from "./Button.js";
3
- import { PlusIcon as s } from "lucide-react";
4
- const g = (o) => /* @__PURE__ */ e(i, { ...o }), a = (o) => /* @__PURE__ */ e(
5
- "div",
6
- {
7
- style: {
8
- padding: "0px 20px",
9
- display: "flex",
10
- gap: "32px",
11
- alignItems: "flex-start"
12
- },
13
- children: /* @__PURE__ */ e(
14
- "div",
15
- {
16
- style: {
17
- position: "relative",
18
- border: "2px dashed rgba(139, 92, 246, 0.7)",
19
- borderRadius: "24px",
20
- padding: "24px 32px",
21
- display: "flex",
22
- gap: "32px"
23
- },
24
- children: o.children
25
- }
26
- )
27
- }
28
- ), t = (o) => /* @__PURE__ */ e(
29
- "div",
30
- {
31
- style: {
32
- position: "relative",
33
- display: "flex",
34
- flexDirection: "column",
35
- gap: "16px"
36
- },
37
- children: ["default", "hover", "focus", "active", "disabled"].map((r) => /* @__PURE__ */ e(
38
- i,
39
- {
40
- id: r,
41
- ...o,
42
- disabled: r === "disabled" || o.disabled,
43
- children: o.children ?? r
44
- },
45
- r
46
- ))
47
- }
48
- ), d = ["none", "contained", "outlined", "ghost"], c = ["primary", "secondary", "error"], p = ["xs", "sm", "md", "lg"], m = {
49
- title: "Button",
50
- component: i,
51
- render: g,
52
- args: {
53
- tooltip: void 0,
54
- asChild: !1,
55
- //
56
- variant: d[0],
57
- color: c[0],
58
- size: p[0],
59
- disabled: !1
60
- },
61
- argTypes: {
62
- tooltip: { control: !1 },
63
- asChild: { control: !1 },
64
- variant: { options: d, control: { type: "inline-radio" } },
65
- color: { options: c, control: { type: "inline-radio" } },
66
- size: { options: p, control: { type: "inline-radio" } },
67
- title: {
68
- name: "title",
69
- description: "Button tooltip title from HTMLAttributes<HTMLButtonElement> [string only]",
70
- control: { type: "text" }
71
- },
72
- message: {
73
- name: "message",
74
- description: "Button tooltip message from ButtonProps [ReactNode]",
75
- control: { type: "object" }
76
- },
77
- slotProps: {
78
- name: "slotProps",
79
- description: "Button slotProps from ButtonProps [object]",
80
- control: { type: "object" }
81
- }
82
- },
83
- tags: ["autodocs"],
84
- parameters: {
85
- docs: {
86
- description: {
87
- component: "Universal button component with variants, icons and tooltip support."
88
- }
89
- },
90
- pseudo: {
91
- hover: "#hover",
92
- focus: "#focus",
93
- active: "#active",
94
- disabled: "#disabled"
95
- }
96
- }
97
- }, l = {
98
- ...m.args,
99
- startAdornment: /* @__PURE__ */ e(s, {}),
100
- endAdornment: /* @__PURE__ */ e(s, {}),
101
- children: "children"
102
- }, u = {
103
- args: {
104
- ...m.args,
105
- children: "__children__"
106
- }
107
- }, y = {
108
- args: {
109
- ...l,
110
- color: "primary",
111
- size: "lg",
112
- children: "Створити"
113
- },
114
- argTypes: {
115
- variant: { control: !1 },
116
- color: { control: !1 }
117
- },
118
- render: (o) => /* @__PURE__ */ e("div", { className: "flex", children: /* @__PURE__ */ n(a, { children: [
119
- /* @__PURE__ */ e(t, { ...o, variant: "contained" }),
120
- /* @__PURE__ */ e(t, { ...o, variant: "outlined" }),
121
- /* @__PURE__ */ e(t, { ...o, variant: "ghost" })
122
- ] }) })
123
- }, x = {
124
- args: {
125
- ...l,
126
- color: "secondary",
127
- size: "lg",
128
- children: "Створити"
129
- },
130
- argTypes: {
131
- variant: { control: !1 },
132
- color: { control: !1 }
133
- },
134
- render: (o) => /* @__PURE__ */ e("div", { className: "flex", children: /* @__PURE__ */ n(a, { children: [
135
- /* @__PURE__ */ e(t, { ...o, variant: "contained" }),
136
- /* @__PURE__ */ e(t, { ...o, variant: "outlined" }),
137
- /* @__PURE__ */ e(t, { ...o, variant: "ghost" })
138
- ] }) })
139
- }, b = {
140
- args: {
141
- ...l,
142
- color: "error",
143
- size: "lg",
144
- children: "Створити"
145
- },
146
- argTypes: {
147
- variant: { control: !1 },
148
- color: { control: !1 }
149
- },
150
- render: (o) => /* @__PURE__ */ e("div", { className: "flex", children: /* @__PURE__ */ n(a, { children: [
151
- /* @__PURE__ */ e(t, { ...o, variant: "contained" }),
152
- /* @__PURE__ */ e(t, { ...o, variant: "outlined" }),
153
- /* @__PURE__ */ e(t, { ...o, variant: "ghost" })
154
- ] }) })
155
- };
156
- export {
157
- u as Default,
158
- b as Error,
159
- y as Primary,
160
- x as Secondary,
161
- m as default
162
- };
163
- //# sourceMappingURL=Button.s.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Button.s.js","sources":["../../src/Button/Button.s.tsx"],"sourcesContent":["import type { Meta, StoryObj } from '@storybook/react';\n\nimport { Button } from './Button';\nimport type { ButtonProps } from './Button.types';\nimport { PropsWithChildren } from 'react';\nimport { PlusIcon } from 'lucide-react'\n\nconst Template = (props: ButtonProps) => <Button {...props}/>;\n\nconst DashedWrapper = (props: PropsWithChildren) => {\n return (\n <div\n style={{\n padding: '0px 20px',\n display: 'flex',\n gap: '32px',\n alignItems: 'flex-start',\n }}\n >\n <div\n style={{\n position: 'relative',\n border: '2px dashed rgba(139, 92, 246, 0.7)',\n borderRadius: '24px',\n padding: '24px 32px',\n display: 'flex',\n gap: '32px',\n }}\n >\n {props.children}\n </div>\n </div>\n )\n}\n\nconst States = (props: ButtonProps) => (\n <div\n style={{\n position: 'relative',\n display: 'flex',\n flexDirection: 'column',\n gap: '16px',\n }}\n >\n {[ 'default', 'hover', 'focus', 'active', 'disabled' ]\n .map((state) => (\n <Button\n key={state}\n id={state}\n {...props}\n disabled={state === 'disabled' || props.disabled}\n >\n {props.children ?? state}\n </Button>\n ))}\n </div>\n);\n\nconst variants: ButtonProps['variant'][] = [ 'none', 'contained', 'outlined', 'ghost' ]\nconst colors: ButtonProps['color'][] = [ 'primary', 'secondary', 'error' ]\nconst sizes: ButtonProps['size'][] = [ 'xs', 'sm', 'md', 'lg' ]\n\nconst meta = {\n title: 'Button',\n component: Button,\n render: Template,\n args: {\n tooltip: undefined,\n asChild: false,\n //\n variant: variants[0],\n color: colors[0],\n size: sizes[0],\n disabled: false,\n },\n argTypes: {\n tooltip: { control: false },\n asChild: { control: false },\n variant: { options: variants, control: { type: 'inline-radio' } },\n color: { options: colors, control: { type: 'inline-radio' } },\n size: { options: sizes, control: { type: 'inline-radio' } },\n title: {\n name: 'title',\n description: \"Button tooltip title from HTMLAttributes<HTMLButtonElement> [string only]\",\n control: { type: 'text' },\n },\n message: {\n name: 'message',\n description: 'Button tooltip message from ButtonProps [ReactNode]',\n control: { type: \"object\" },\n },\n slotProps: {\n name: 'slotProps',\n description: 'Button slotProps from ButtonProps [object]',\n control: { type: \"object\" },\n },\n },\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: 'Universal button component with variants, icons and tooltip support.',\n },\n },\n pseudo: {\n hover: '#hover',\n focus: '#focus',\n active: '#active',\n disabled: '#disabled',\n },\n }\n} satisfies Meta<typeof Button>;\nexport default meta;\n\ntype Story = StoryObj<typeof meta>;\nconst args: Story['args'] = {\n ...meta.args,\n startAdornment: <PlusIcon/>,\n endAdornment: <PlusIcon/>,\n children: 'children',\n}\n\nexport const Default: Story = {\n args: {\n ...meta.args,\n children: '__children__',\n }\n};\n\nexport const Primary: Story = {\n args: {\n ...args,\n color: 'primary',\n size: 'lg',\n children: 'Створити',\n },\n argTypes: {\n variant: { control: false },\n color: { control: false },\n },\n render: (props) => (\n <div className='flex'>\n <DashedWrapper>\n <States {...props} variant='contained'/>\n <States {...props} variant='outlined'/>\n <States {...props} variant='ghost'/>\n </DashedWrapper>\n </div>\n ),\n};\n\nexport const Secondary: Story = {\n args: {\n ...args,\n color: 'secondary',\n size: 'lg',\n children: 'Створити',\n },\n argTypes: {\n variant: { control: false },\n color: { control: false },\n },\n render: (props) => (\n <div className='flex'>\n <DashedWrapper>\n <States {...props} variant='contained'/>\n <States {...props} variant='outlined'/>\n <States {...props} variant='ghost'/>\n </DashedWrapper>\n </div>\n ),\n};\n\nexport const Error: Story = {\n args: {\n ...args,\n color: 'error',\n size: 'lg',\n children: 'Створити',\n },\n argTypes: {\n variant: { control: false },\n color: { control: false },\n },\n render: (props) => (\n <div className='flex'>\n <DashedWrapper>\n <States {...props} variant='contained'/>\n <States {...props} variant='outlined'/>\n <States {...props} variant='ghost'/>\n </DashedWrapper>\n </div>\n ),\n};\n\n"],"names":["Template","props","jsx","Button","DashedWrapper","States","state","variants","colors","sizes","meta","args","PlusIcon","Default","Primary","Secondary","Error"],"mappings":"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"}