@rolder/kit 3.0.0-alpha.14 → 3.0.0-alpha.16

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 (129) hide show
  1. package/dist/TestIcon.d.ts +1 -0
  2. package/dist/TestIcon.js +4 -0
  3. package/dist/index.d.ts +1 -9
  4. package/dist/index.js +2 -0
  5. package/package.json +8 -32
  6. package/dist/ai/ui/conversation/ConversationContext.d.ts +0 -7
  7. package/dist/ai/ui/conversation/ConversationContext.js +0 -8
  8. package/dist/ai/ui/conversation/ConversationProvider.d.ts +0 -2
  9. package/dist/ai/ui/conversation/ConversationProvider.js +0 -14
  10. package/dist/ai/ui/conversation/Empty.d.ts +0 -1
  11. package/dist/ai/ui/conversation/Empty.js +0 -21
  12. package/dist/ai/ui/conversation/File.d.ts +0 -4
  13. package/dist/ai/ui/conversation/File.js +0 -42
  14. package/dist/ai/ui/conversation/FileIcon.d.ts +0 -3
  15. package/dist/ai/ui/conversation/FileIcon.js +0 -225
  16. package/dist/ai/ui/conversation/Loader.d.ts +0 -2
  17. package/dist/ai/ui/conversation/Loader.js +0 -12
  18. package/dist/ai/ui/conversation/Message.d.ts +0 -4
  19. package/dist/ai/ui/conversation/Message.js +0 -25
  20. package/dist/ai/ui/conversation/Root.d.ts +0 -2
  21. package/dist/ai/ui/conversation/Root.js +0 -26
  22. package/dist/ai/ui/conversation/index.d.ts +0 -13
  23. package/dist/ai/ui/conversation/index.js +0 -14
  24. package/dist/ai/ui/conversation/types.d.ts +0 -7
  25. package/dist/ai/ui/conversation/types.js +0 -0
  26. package/dist/ai/ui/conversation/useChatMessage.d.ts +0 -2
  27. package/dist/ai/ui/conversation/useChatMessage.js +0 -12
  28. package/dist/ai/ui/promptInput/File.d.ts +0 -2
  29. package/dist/ai/ui/promptInput/File.js +0 -117
  30. package/dist/ai/ui/promptInput/FileIcon.d.ts +0 -3
  31. package/dist/ai/ui/promptInput/FileIcon.js +0 -225
  32. package/dist/ai/ui/promptInput/Footer.d.ts +0 -2
  33. package/dist/ai/ui/promptInput/Footer.js +0 -8
  34. package/dist/ai/ui/promptInput/PromptInputContext.d.ts +0 -12
  35. package/dist/ai/ui/promptInput/PromptInputContext.js +0 -8
  36. package/dist/ai/ui/promptInput/PromptInputProvider.d.ts +0 -2
  37. package/dist/ai/ui/promptInput/PromptInputProvider.js +0 -50
  38. package/dist/ai/ui/promptInput/Root.d.ts +0 -3
  39. package/dist/ai/ui/promptInput/Root.js +0 -17
  40. package/dist/ai/ui/promptInput/Submit.d.ts +0 -2
  41. package/dist/ai/ui/promptInput/Submit.js +0 -40
  42. package/dist/ai/ui/promptInput/Textarea.d.ts +0 -2
  43. package/dist/ai/ui/promptInput/Textarea.js +0 -33
  44. package/dist/ai/ui/promptInput/index.d.ts +0 -8
  45. package/dist/ai/ui/promptInput/index.js +0 -13
  46. package/dist/ai/ui/promptInput/types.d.ts +0 -11
  47. package/dist/ai/ui/promptInput/types.js +0 -0
  48. package/dist/ai/utils/convertFileUIPartBlobToDataURL.d.ts +0 -5
  49. package/dist/ai/utils/convertFileUIPartBlobToDataURL.js +0 -21
  50. package/dist/ai/utils/parseAiMessagePart.d.ts +0 -2
  51. package/dist/ai/utils/parseAiMessagePart.js +0 -12
  52. package/dist/app/AppDefaults.d.ts +0 -3
  53. package/dist/app/AppDefaults.js +0 -27
  54. package/dist/app/DefaultApp.d.ts +0 -6
  55. package/dist/app/DefaultApp.js +0 -43
  56. package/dist/app/cookieColorSchemeManager.d.ts +0 -6
  57. package/dist/app/cookieColorSchemeManager.js +0 -46
  58. package/dist/app/defaultRequestMiddlewares.d.ts +0 -4
  59. package/dist/app/defaultRequestMiddlewares.js +0 -24
  60. package/dist/app/defaultTheme.d.ts +0 -141
  61. package/dist/app/defaultTheme.js +0 -24
  62. package/dist/functions/getCookie.d.ts +0 -3
  63. package/dist/functions/setCookie.d.ts +0 -10
  64. package/dist/functions/setCookies.d.ts +0 -14
  65. package/dist/hooks/useMutation.d.ts +0 -4
  66. package/dist/hooks/useMutationWithInvalidate.d.ts +0 -4
  67. package/dist/styles.css +0 -74
  68. package/dist/surreal/connection.d.ts +0 -9
  69. package/dist/surreal/deafaultCrud.d.ts +0 -2
  70. package/dist/surreal/deserialize.d.ts +0 -17
  71. package/dist/surreal/encryption.d.ts +0 -6
  72. package/dist/ui/AnimatedChevron.d.ts +0 -6
  73. package/dist/ui/JsonInput.d.ts +0 -2
  74. package/dist/ui/RouterLink.d.ts +0 -16
  75. package/dist/ui/editor/Content.d.ts +0 -3
  76. package/dist/ui/editor/Provider.d.ts +0 -17
  77. package/dist/ui/editor/Root.d.ts +0 -2
  78. package/dist/ui/editor/Toolbar.d.ts +0 -5
  79. package/dist/ui/editor/index.d.ts +0 -12
  80. package/dist/ui/editor/types.d.ts +0 -7
  81. package/dist/ui/error/DefaultError.d.ts +0 -2
  82. package/dist/ui/error/DefaultNotFound.d.ts +0 -1
  83. package/dist/ui/error/Forbidden.d.ts +0 -1
  84. package/dist/ui/error/defaultErrorNotification.d.ts +0 -1
  85. package/dist/ui/error/index.d.ts +0 -4
  86. package/dist/ui/form/blurOnError.d.ts +0 -4
  87. package/dist/ui/form/buttons/CancelButton.d.ts +0 -5
  88. package/dist/ui/form/buttons/SubmitButton.d.ts +0 -5
  89. package/dist/ui/form/buttons/SubscribeActionIcon.d.ts +0 -4
  90. package/dist/ui/form/buttons/SubscribeButton.d.ts +0 -5
  91. package/dist/ui/form/buttons/index.d.ts +0 -4
  92. package/dist/ui/form/context.d.ts +0 -83
  93. package/dist/ui/form/fields/JsonField.d.ts +0 -2
  94. package/dist/ui/form/fields/MultiSelectField.d.ts +0 -2
  95. package/dist/ui/form/fields/NumberField.d.ts +0 -2
  96. package/dist/ui/form/fields/PassowrdField.d.ts +0 -2
  97. package/dist/ui/form/fields/SelectField.d.ts +0 -2
  98. package/dist/ui/form/fields/SwitchField.d.ts +0 -2
  99. package/dist/ui/form/fields/TextField.d.ts +0 -2
  100. package/dist/ui/form/fields/TextPassowrdField.d.ts +0 -2
  101. package/dist/ui/form/fields/TextareaField.d.ts +0 -2
  102. package/dist/ui/form/fields/index.d.ts +0 -9
  103. package/dist/ui/form/fieldsSchema.d.ts +0 -12
  104. package/dist/ui/form/index.d.ts +0 -3
  105. package/dist/ui/hoverPaper/HoverPaper.d.ts +0 -6
  106. package/dist/ui/hoverPaper/index.d.ts +0 -2
  107. package/dist/ui/hoverPaper/usePaperHover.d.ts +0 -4
  108. package/dist/ui/saveInput/JsonInput.d.ts +0 -6
  109. package/dist/ui/saveInput/NumberInput.d.ts +0 -6
  110. package/dist/ui/saveInput/SaveInput.d.ts +0 -36
  111. package/dist/ui/saveInput/Select.d.ts +0 -6
  112. package/dist/ui/saveInput/Switch.d.ts +0 -6
  113. package/dist/ui/saveInput/TextInput.d.ts +0 -6
  114. package/dist/ui/saveInput/Textarea.d.ts +0 -6
  115. package/dist/ui/saveInput/index.d.ts +0 -1
  116. package/dist/ui/scrollArea/ScrollArea.d.ts +0 -62
  117. package/dist/ui/scrollArea/ScrollArea.js +0 -30
  118. package/dist/ui/scrollArea/ScrollAreaButton.d.ts +0 -5
  119. package/dist/ui/scrollArea/ScrollAreaButton.js +0 -51
  120. package/dist/ui/scrollArea/ScrollAreaContent.d.ts +0 -6
  121. package/dist/ui/scrollArea/ScrollAreaContent.js +0 -29
  122. package/dist/ui/scrollArea/context.d.ts +0 -28
  123. package/dist/ui/scrollArea/context.js +0 -10
  124. package/dist/ui/scrollArea/index.d.ts +0 -3
  125. package/dist/ui/scrollArea/index.js +0 -3
  126. package/dist/ui/scrollArea/types.d.ts +0 -65
  127. package/dist/ui/scrollArea/types.js +0 -0
  128. package/dist/ui/scrollArea/useScrollArea.d.ts +0 -9
  129. package/dist/ui/scrollArea/useScrollArea.js +0 -146
@@ -1,117 +0,0 @@
1
- import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
- import { ActionIcon, FileButton, Tooltip } from "@mantine/core";
3
- import { useRef } from "react";
4
- import { FileIcon } from "./FileIcon.js";
5
- import { usePromptInput } from "./PromptInputContext.js";
6
- const File = (props)=>{
7
- const resetRef = useRef(null);
8
- const { file, setFile, accept, submiting, uploading } = usePromptInput();
9
- return /*#__PURE__*/ jsx(FileButton, {
10
- resetRef: resetRef,
11
- onChange: async (file)=>{
12
- if (file) setFile(file);
13
- },
14
- accept: accept,
15
- disabled: submiting || uploading,
16
- ...props,
17
- children: (props)=>/*#__PURE__*/ jsxs(ActionIcon.Group, {
18
- children: [
19
- /*#__PURE__*/ jsx(ActionIcon, {
20
- size: "lg",
21
- variant: "default",
22
- disabled: submiting,
23
- loading: uploading,
24
- classNames: {
25
- root: 'rolder-prompt-input-file-action-action'
26
- },
27
- ...props,
28
- children: /*#__PURE__*/ jsxs("svg", {
29
- xmlns: "http://www.w3.org/2000/svg",
30
- width: "24",
31
- height: "24",
32
- viewBox: "0 0 24 24",
33
- fill: "none",
34
- stroke: "currentColor",
35
- strokeWidth: "1.5",
36
- strokeLinecap: "round",
37
- strokeLinejoin: "round",
38
- role: "img",
39
- "aria-label": "Paperclip",
40
- children: [
41
- /*#__PURE__*/ jsx("path", {
42
- stroke: "none",
43
- d: "M0 0h24v24H0z",
44
- fill: "none"
45
- }),
46
- /*#__PURE__*/ jsx("path", {
47
- d: "M15 7l-6.5 6.5a1.5 1.5 0 0 0 3 3l6.5 -6.5a3 3 0 0 0 -6 -6l-6.5 6.5a4.5 4.5 0 0 0 9 9l6.5 -6.5"
48
- })
49
- ]
50
- })
51
- }),
52
- file && /*#__PURE__*/ jsxs(Fragment, {
53
- children: [
54
- /*#__PURE__*/ jsx(Tooltip, {
55
- label: file.name,
56
- openDelay: 500,
57
- children: /*#__PURE__*/ jsx(ActionIcon.GroupSection, {
58
- variant: "default",
59
- size: "lg",
60
- children: /*#__PURE__*/ jsx(FileIcon, {
61
- mimeType: file.type
62
- })
63
- })
64
- }),
65
- /*#__PURE__*/ jsx(ActionIcon, {
66
- size: "lg",
67
- variant: "default",
68
- classNames: {
69
- root: 'rolder-prompt-input-file-action-action'
70
- },
71
- onClick: ()=>{
72
- resetRef.current?.();
73
- setFile(void 0);
74
- },
75
- children: /*#__PURE__*/ jsxs("svg", {
76
- xmlns: "http://www.w3.org/2000/svg",
77
- width: "24",
78
- height: "24",
79
- viewBox: "0 0 24 24",
80
- fill: "none",
81
- stroke: "currentColor",
82
- strokeWidth: "1.5",
83
- strokeLinecap: "round",
84
- strokeLinejoin: "round",
85
- role: "img",
86
- "aria-label": "Trash",
87
- children: [
88
- /*#__PURE__*/ jsx("path", {
89
- stroke: "none",
90
- d: "M0 0h24v24H0z",
91
- fill: "none"
92
- }),
93
- /*#__PURE__*/ jsx("path", {
94
- d: "M4 7l16 0"
95
- }),
96
- /*#__PURE__*/ jsx("path", {
97
- d: "M10 11l0 6"
98
- }),
99
- /*#__PURE__*/ jsx("path", {
100
- d: "M14 11l0 6"
101
- }),
102
- /*#__PURE__*/ jsx("path", {
103
- d: "M5 7l1 12a2 2 0 0 0 2 2h8a2 2 0 0 0 2 -2l1 -12"
104
- }),
105
- /*#__PURE__*/ jsx("path", {
106
- d: "M9 7v-3a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v3"
107
- })
108
- ]
109
- })
110
- })
111
- ]
112
- })
113
- ]
114
- })
115
- });
116
- };
117
- export { File };
@@ -1,3 +0,0 @@
1
- export declare const FileIcon: ({ mimeType }: {
2
- mimeType: string;
3
- }) => import("react/jsx-runtime").JSX.Element;
@@ -1,225 +0,0 @@
1
- import { jsx, jsxs } from "react/jsx-runtime";
2
- const FileIcon = ({ mimeType })=>{
3
- switch(true){
4
- case mimeType.includes('image/'):
5
- return /*#__PURE__*/ jsxs("svg", {
6
- xmlns: "http://www.w3.org/2000/svg",
7
- width: "24",
8
- height: "24",
9
- viewBox: "0 0 24 24",
10
- fill: "none",
11
- stroke: "var(--mantine-color-dimmed)",
12
- strokeWidth: "1.5",
13
- strokeLinecap: "round",
14
- strokeLinejoin: "round",
15
- role: "img",
16
- "aria-label": "Image",
17
- children: [
18
- /*#__PURE__*/ jsx("path", {
19
- stroke: "none",
20
- d: "M0 0h24v24H0z",
21
- fill: "none"
22
- }),
23
- /*#__PURE__*/ jsx("path", {
24
- d: "M15 8h.01"
25
- }),
26
- /*#__PURE__*/ jsx("path", {
27
- d: "M3 6a3 3 0 0 1 3 -3h12a3 3 0 0 1 3 3v12a3 3 0 0 1 -3 3h-12a3 3 0 0 1 -3 -3v-12"
28
- }),
29
- /*#__PURE__*/ jsx("path", {
30
- d: "M3 16l5 -5c.928 -.893 2.072 -.893 3 0l5 5"
31
- }),
32
- /*#__PURE__*/ jsx("path", {
33
- d: "M14 14l1 -1c.928 -.893 2.072 -.893 3 0l3 3"
34
- })
35
- ]
36
- });
37
- case mimeType.includes('application/pdf'):
38
- return /*#__PURE__*/ jsxs("svg", {
39
- xmlns: "http://www.w3.org/2000/svg",
40
- width: "24",
41
- height: "24",
42
- viewBox: "0 0 24 24",
43
- fill: "none",
44
- stroke: "var(--mantine-color-dimmed)",
45
- strokeWidth: "1.5",
46
- strokeLinecap: "round",
47
- strokeLinejoin: "round",
48
- role: "img",
49
- "aria-label": "FilePdf",
50
- children: [
51
- /*#__PURE__*/ jsx("path", {
52
- stroke: "none",
53
- d: "M0 0h24v24H0z",
54
- fill: "none"
55
- }),
56
- /*#__PURE__*/ jsx("path", {
57
- d: "M14 3v4a1 1 0 0 0 1 1h4"
58
- }),
59
- /*#__PURE__*/ jsx("path", {
60
- d: "M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4"
61
- }),
62
- /*#__PURE__*/ jsx("path", {
63
- d: "M5 18h1.5a1.5 1.5 0 0 0 0 -3h-1.5v6"
64
- }),
65
- /*#__PURE__*/ jsx("path", {
66
- d: "M17 18h2"
67
- }),
68
- /*#__PURE__*/ jsx("path", {
69
- d: "M20 15h-3v6"
70
- }),
71
- /*#__PURE__*/ jsx("path", {
72
- d: "M11 15v6h1a2 2 0 0 0 2 -2v-2a2 2 0 0 0 -2 -2h-1"
73
- })
74
- ]
75
- });
76
- case mimeType.includes('application/vnd.openxmlformats-officedocument.wordprocessingml.document'):
77
- return /*#__PURE__*/ jsxs("svg", {
78
- xmlns: "http://www.w3.org/2000/svg",
79
- width: "24",
80
- height: "24",
81
- viewBox: "0 0 24 24",
82
- fill: "none",
83
- stroke: "var(--mantine-color-dimmed)",
84
- strokeWidth: "1.5",
85
- strokeLinecap: "round",
86
- strokeLinejoin: "round",
87
- role: "img",
88
- "aria-label": "FileDoc",
89
- children: [
90
- /*#__PURE__*/ jsx("path", {
91
- stroke: "none",
92
- d: "M0 0h24v24H0z",
93
- fill: "none"
94
- }),
95
- /*#__PURE__*/ jsx("path", {
96
- d: "M14 3v4a1 1 0 0 0 1 1h4"
97
- }),
98
- /*#__PURE__*/ jsx("path", {
99
- d: "M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4"
100
- }),
101
- /*#__PURE__*/ jsx("path", {
102
- d: "M5 15v6h1a2 2 0 0 0 2 -2v-2a2 2 0 0 0 -2 -2h-1"
103
- }),
104
- /*#__PURE__*/ jsx("path", {
105
- d: "M20 16.5a1.5 1.5 0 0 0 -3 0v3a1.5 1.5 0 0 0 3 0"
106
- }),
107
- /*#__PURE__*/ jsx("path", {
108
- d: "M12.5 15a1.5 1.5 0 0 1 1.5 1.5v3a1.5 1.5 0 0 1 -3 0v-3a1.5 1.5 0 0 1 1.5 -1.5"
109
- })
110
- ]
111
- });
112
- case mimeType.includes('application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'):
113
- return /*#__PURE__*/ jsxs("svg", {
114
- xmlns: "http://www.w3.org/2000/svg",
115
- width: "24",
116
- height: "24",
117
- viewBox: "0 0 24 24",
118
- fill: "none",
119
- stroke: "var(--mantine-color-dimmed)",
120
- strokeWidth: "1.5",
121
- strokeLinecap: "round",
122
- strokeLinejoin: "round",
123
- role: "img",
124
- "aria-label": "FileXls",
125
- children: [
126
- /*#__PURE__*/ jsx("path", {
127
- stroke: "none",
128
- d: "M0 0h24v24H0z",
129
- fill: "none"
130
- }),
131
- /*#__PURE__*/ jsx("path", {
132
- d: "M14 3v4a1 1 0 0 0 1 1h4"
133
- }),
134
- /*#__PURE__*/ jsx("path", {
135
- d: "M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4"
136
- }),
137
- /*#__PURE__*/ jsx("path", {
138
- d: "M4 15l4 6"
139
- }),
140
- /*#__PURE__*/ jsx("path", {
141
- d: "M4 21l4 -6"
142
- }),
143
- /*#__PURE__*/ jsx("path", {
144
- d: "M17 20.25c0 .414 .336 .75 .75 .75h1.25a1 1 0 0 0 1 -1v-1a1 1 0 0 0 -1 -1h-1a1 1 0 0 1 -1 -1v-1a1 1 0 0 1 1 -1h1.25a.75 .75 0 0 1 .75 .75"
145
- }),
146
- /*#__PURE__*/ jsx("path", {
147
- d: "M11 15v6h3"
148
- })
149
- ]
150
- });
151
- case mimeType.includes('application/vnd.openxmlformats-officedocument.presentationml.presentation'):
152
- return /*#__PURE__*/ jsxs("svg", {
153
- xmlns: "http://www.w3.org/2000/svg",
154
- width: "24",
155
- height: "24",
156
- viewBox: "0 0 24 24",
157
- fill: "none",
158
- stroke: "var(--mantine-color-dimmed)",
159
- strokeWidth: "1.5",
160
- strokeLinecap: "round",
161
- strokeLinejoin: "round",
162
- role: "img",
163
- "aria-label": "FilePpt",
164
- children: [
165
- /*#__PURE__*/ jsx("path", {
166
- stroke: "none",
167
- d: "M0 0h24v24H0z",
168
- fill: "none"
169
- }),
170
- /*#__PURE__*/ jsx("path", {
171
- d: "M14 3v4a1 1 0 0 0 1 1h4"
172
- }),
173
- /*#__PURE__*/ jsx("path", {
174
- d: "M14 3v4a1 1 0 0 0 1 1h4"
175
- }),
176
- /*#__PURE__*/ jsx("path", {
177
- d: "M5 18h1.5a1.5 1.5 0 0 0 0 -3h-1.5v6"
178
- }),
179
- /*#__PURE__*/ jsx("path", {
180
- d: "M11 18h1.5a1.5 1.5 0 0 0 0 -3h-1.5v6"
181
- }),
182
- /*#__PURE__*/ jsx("path", {
183
- d: "M16.5 15h3"
184
- }),
185
- /*#__PURE__*/ jsx("path", {
186
- d: "M18 15v6"
187
- }),
188
- /*#__PURE__*/ jsx("path", {
189
- d: "M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4"
190
- })
191
- ]
192
- });
193
- default:
194
- return /*#__PURE__*/ jsxs("svg", {
195
- xmlns: "http://www.w3.org/2000/svg",
196
- width: "24",
197
- height: "24",
198
- viewBox: "0 0 24 24",
199
- fill: "none",
200
- stroke: "var(--mantine-color-dimmed)",
201
- strokeWidth: "1.5",
202
- strokeLinecap: "round",
203
- strokeLinejoin: "round",
204
- role: "img",
205
- "aria-label": "File",
206
- children: [
207
- /*#__PURE__*/ jsx("path", {
208
- stroke: "none",
209
- d: "M0 0h24v24H0z",
210
- fill: "none"
211
- }),
212
- /*#__PURE__*/ jsx("path", {
213
- d: "M15 3v4a1 1 0 0 0 1 1h4"
214
- }),
215
- /*#__PURE__*/ jsx("path", {
216
- d: "M18 17h-7a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h4l5 5v7a2 2 0 0 1 -2 2"
217
- }),
218
- /*#__PURE__*/ jsx("path", {
219
- d: "M16 17v2a2 2 0 0 1 -2 2h-7a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2"
220
- })
221
- ]
222
- });
223
- }
224
- };
225
- export { FileIcon };
@@ -1,2 +0,0 @@
1
- import { type GroupProps } from '@mantine/core';
2
- export declare const Footer: (props: GroupProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,8 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { Group } from "@mantine/core";
3
- const Footer = (props)=>/*#__PURE__*/ jsx(Group, {
4
- justify: "space-between",
5
- p: "xs",
6
- ...props
7
- });
8
- export { Footer };
@@ -1,12 +0,0 @@
1
- export interface PromptInputContext {
2
- text: string;
3
- setText: (text: string) => void;
4
- file?: File;
5
- setFile: (file?: File) => void;
6
- onSubmit: () => void;
7
- submiting: boolean;
8
- uploading: boolean;
9
- accept?: string;
10
- }
11
- export declare const PromptInputContext: import("react").Context<PromptInputContext | null>;
12
- export declare const usePromptInput: () => PromptInputContext;
@@ -1,8 +0,0 @@
1
- import { createContext, useContext } from "react";
2
- const PromptInputContext = createContext(null);
3
- const usePromptInput = ()=>{
4
- const context = useContext(PromptInputContext);
5
- if (!context) throw new Error('usePromptInput must be used within a PromptInputProvider');
6
- return context;
7
- };
8
- export { PromptInputContext, usePromptInput };
@@ -1,2 +0,0 @@
1
- import type { PromptInputProps } from './types';
2
- export declare const Provider: ({ children, onSubmit, submiting, uploading, accept, }: PromptInputProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,50 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { useState } from "react";
3
- import { PromptInputContext } from "./PromptInputContext.js";
4
- const Provider = ({ children, onSubmit, submiting, uploading, accept = [
5
- 'text',
6
- 'image',
7
- 'pdf'
8
- ] })=>{
9
- const [text, setText] = useState('');
10
- const [file, setFile] = useState();
11
- const value = {
12
- text,
13
- setText,
14
- file,
15
- setFile,
16
- onSubmit: ()=>{
17
- if (text.trim()) {
18
- onSubmit({
19
- text: text.trim(),
20
- file
21
- });
22
- setText('');
23
- setFile(void 0);
24
- }
25
- },
26
- submiting,
27
- uploading,
28
- accept: accept.map((type)=>{
29
- switch(type){
30
- case 'text':
31
- return 'text/plain';
32
- case 'image':
33
- return 'image/*';
34
- case 'pdf':
35
- return 'application/pdf';
36
- case 'excel':
37
- return 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
38
- case 'word':
39
- return 'application/vnd.openxmlformats-officedocument.wordprocessingml.document';
40
- default:
41
- return type;
42
- }
43
- }).join(',')
44
- };
45
- return /*#__PURE__*/ jsx(PromptInputContext.Provider, {
46
- value: value,
47
- children: children
48
- });
49
- };
50
- export { Provider };
@@ -1,3 +0,0 @@
1
- import { type PaperProps } from '@mantine/core';
2
- import type { PromptInputProps } from './types';
3
- export declare const Root: ({ className, onSubmit, submiting, uploading, accept, ...props }: PaperProps & PromptInputProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,17 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { Paper } from "@mantine/core";
3
- import clsx from "clsx";
4
- import { Provider } from "./PromptInputProvider.js";
5
- const Root = ({ className, onSubmit, submiting, uploading, accept, ...props })=>/*#__PURE__*/ jsx(Provider, {
6
- onSubmit: onSubmit,
7
- submiting: submiting,
8
- uploading: uploading,
9
- accept: accept,
10
- children: /*#__PURE__*/ jsx(Paper, {
11
- radius: "md",
12
- withBorder: true,
13
- className: clsx('rolder-prompt-input-root', className),
14
- ...props
15
- })
16
- });
17
- export { Root };
@@ -1,2 +0,0 @@
1
- import { type ActionIconProps } from '@mantine/core';
2
- export declare const Submit: ({ children, ...props }: ActionIconProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,40 +0,0 @@
1
- import { jsx, jsxs } from "react/jsx-runtime";
2
- import { ActionIcon } from "@mantine/core";
3
- import { usePromptInput } from "./PromptInputContext.js";
4
- const Submit = ({ children, ...props })=>{
5
- const Icon = /*#__PURE__*/ jsxs("svg", {
6
- xmlns: "http://www.w3.org/2000/svg",
7
- width: "24",
8
- height: "24",
9
- viewBox: "0 0 24 24",
10
- fill: "none",
11
- stroke: "currentColor",
12
- strokeWidth: "1.5",
13
- strokeLinecap: "round",
14
- strokeLinejoin: "round",
15
- role: "img",
16
- "aria-label": "Submit",
17
- children: [
18
- /*#__PURE__*/ jsx("path", {
19
- stroke: "none",
20
- d: "M0 0h24v24H0z",
21
- fill: "none"
22
- }),
23
- /*#__PURE__*/ jsx("path", {
24
- d: "M9 20v-8h-3.586a1 1 0 0 1 -.707 -1.707l6.586 -6.586a1 1 0 0 1 1.414 0l6.586 6.586a1 1 0 0 1 -.707 1.707h-3.586v8a1 1 0 0 1 -1 1h-4a1 1 0 0 1 -1 -1"
25
- })
26
- ]
27
- });
28
- const { onSubmit, submiting, uploading } = usePromptInput();
29
- return /*#__PURE__*/ jsx(ActionIcon, {
30
- "aria-label": "Submit",
31
- variant: "light",
32
- size: "lg",
33
- onClick: onSubmit,
34
- disabled: uploading,
35
- loading: submiting,
36
- ...props,
37
- children: children ?? Icon
38
- });
39
- };
40
- export { Submit };
@@ -1,2 +0,0 @@
1
- import { type TextareaProps } from '@mantine/core';
2
- export declare const Textarea: (props: TextareaProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,33 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { Textarea } from "@mantine/core";
3
- import { useState } from "react";
4
- import { usePromptInput } from "./PromptInputContext.js";
5
- const Textarea_Textarea = (props)=>{
6
- const { text, setText, onSubmit, submiting, uploading } = usePromptInput();
7
- const [isComposing, setIsComposing] = useState(false);
8
- const handleKeyDown = (e)=>{
9
- if ('Enter' === e.key) {
10
- if (isComposing || e.nativeEvent.isComposing) return;
11
- if (e.shiftKey) return;
12
- e.preventDefault();
13
- onSubmit();
14
- }
15
- };
16
- return /*#__PURE__*/ jsx(Textarea, {
17
- w: "100%",
18
- size: "md",
19
- rows: 3,
20
- classNames: {
21
- input: 'rolder-prompt-input-textarea'
22
- },
23
- placeholder: "Напишите сообщение",
24
- onCompositionEnd: ()=>setIsComposing(false),
25
- onCompositionStart: ()=>setIsComposing(true),
26
- onKeyDown: handleKeyDown,
27
- value: text,
28
- onChange: (e)=>setText(e.target.value),
29
- disabled: submiting || uploading,
30
- ...props
31
- });
32
- };
33
- export { Textarea_Textarea as Textarea };
@@ -1,8 +0,0 @@
1
- export type { Accept, PromptInputProps } from './types';
2
- export declare const PromptInput: {
3
- Root: ({ className, onSubmit, submiting, uploading, accept, ...props }: import("@mantine/core").PaperProps & import("./types").PromptInputProps) => import("react/jsx-runtime").JSX.Element;
4
- Textarea: (props: import("@mantine/core").TextareaProps) => import("react/jsx-runtime").JSX.Element;
5
- Footer: (props: import("@mantine/core").GroupProps) => import("react/jsx-runtime").JSX.Element;
6
- Submit: ({ children, ...props }: import("@mantine/core").ActionIconProps) => import("react/jsx-runtime").JSX.Element;
7
- File: (props: Omit<import("@mantine/core").FileButtonProps, "onChange" | "children">) => import("react/jsx-runtime").JSX.Element;
8
- };
@@ -1,13 +0,0 @@
1
- import { File } from "./File.js";
2
- import { Footer } from "./Footer.js";
3
- import { Root } from "./Root.js";
4
- import { Submit } from "./Submit.js";
5
- import { Textarea } from "./Textarea.js";
6
- const PromptInput = {
7
- Root: Root,
8
- Textarea: Textarea,
9
- Footer: Footer,
10
- Submit: Submit,
11
- File: File
12
- };
13
- export { PromptInput };
@@ -1,11 +0,0 @@
1
- export type Accept = 'text' | 'image' | 'pdf' | 'excel' | 'word';
2
- export interface PromptInputProps {
3
- children: React.ReactNode;
4
- onSubmit: ({ text, file }: {
5
- text: string;
6
- file?: File;
7
- }) => void;
8
- submiting: boolean;
9
- uploading: boolean;
10
- accept?: Accept[];
11
- }
File without changes
@@ -1,5 +0,0 @@
1
- import type { FileUIPart } from 'ai';
2
- /**
3
- * Converts FileUIPart array with blob URLs to data URLs
4
- */
5
- export declare function convertFileUIPartBlobToDataURL(file: FileUIPart): Promise<FileUIPart>;
@@ -1,21 +0,0 @@
1
- async function blobToDataURL(blobUrl) {
2
- const response = await fetch(blobUrl);
3
- const blob = await response.blob();
4
- return new Promise((resolve, reject)=>{
5
- const reader = new FileReader();
6
- reader.onload = ()=>resolve(reader.result);
7
- reader.onerror = reject;
8
- reader.readAsDataURL(blob);
9
- });
10
- }
11
- async function convertFileUIPartBlobToDataURL(file) {
12
- if (file.url.startsWith('blob:')) {
13
- const dataUrl = await blobToDataURL(file.url);
14
- return {
15
- ...file,
16
- url: dataUrl
17
- };
18
- }
19
- return file;
20
- }
21
- export { convertFileUIPartBlobToDataURL };
@@ -1,2 +0,0 @@
1
- import { type TextUIPart } from 'ai';
2
- export declare const parseAiMessagePart: <T extends TextUIPart>(part: T) => Promise<T>;
@@ -1,12 +0,0 @@
1
- import { parsePartialJson } from "ai";
2
- const parseAiMessagePart = async (part)=>{
3
- if (!part.text.startsWith('{')) return part;
4
- try {
5
- const result = await parsePartialJson(part.text);
6
- return result?.value || part;
7
- } catch (error) {
8
- console.error('Error parsing partial JSON:', error);
9
- return part;
10
- }
11
- };
12
- export { parseAiMessagePart };
@@ -1,3 +0,0 @@
1
- export declare const AppDefaults: ({ saveColorScheme, }: {
2
- saveColorScheme: boolean;
3
- }) => null;