@rolder/kit 3.0.0-alpha.3 → 3.0.0-alpha.30

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 (114) hide show
  1. package/dist/ai/index.d.ts +2 -0
  2. package/dist/ai/index.js +2 -0
  3. package/dist/ai/ui/{conversation → chat}/Empty.js +4 -3
  4. package/dist/ai/ui/chat/File.d.ts +3 -0
  5. package/dist/ai/ui/{conversation → chat}/File.js +10 -8
  6. package/dist/ai/ui/chat/FileIcon.js +43 -0
  7. package/dist/ai/ui/{conversation → chat}/Loader.js +4 -3
  8. package/dist/ai/ui/chat/Message.d.ts +3 -0
  9. package/dist/ai/ui/chat/Message.js +24 -0
  10. package/dist/ai/ui/chat/Messages.d.ts +2 -0
  11. package/dist/ai/ui/chat/Messages.js +12 -0
  12. package/dist/ai/ui/chat/Root.d.ts +8 -0
  13. package/dist/ai/ui/chat/Root.js +22 -0
  14. package/dist/ai/ui/chat/chatInput/File.js +72 -0
  15. package/dist/ai/ui/chat/chatInput/FileIcon.js +43 -0
  16. package/dist/ai/ui/{promptInput → chat/chatInput}/Footer.js +4 -1
  17. package/dist/ai/ui/chat/chatInput/Root.d.ts +9 -0
  18. package/dist/ai/ui/chat/chatInput/Root.js +25 -0
  19. package/dist/ai/ui/chat/chatInput/Submit.js +24 -0
  20. package/dist/ai/ui/{promptInput → chat/chatInput}/Textarea.js +10 -8
  21. package/dist/ai/ui/{promptInput → chat/chatInput}/index.d.ts +2 -3
  22. package/dist/ai/ui/{promptInput → chat/chatInput}/index.js +2 -2
  23. package/dist/ai/ui/chat/chatInput/store.d.ts +13 -0
  24. package/dist/ai/ui/chat/chatInput/store.js +40 -0
  25. package/dist/ai/ui/chat/index.d.ts +13 -0
  26. package/dist/ai/ui/{conversation → chat}/index.js +5 -3
  27. package/dist/ai/ui/chat/store/index.d.ts +2 -0
  28. package/dist/ai/ui/chat/store/index.js +2 -0
  29. package/dist/ai/ui/chat/store/messages.d.ts +17 -0
  30. package/dist/ai/ui/chat/store/messages.js +78 -0
  31. package/dist/ai/ui/chat/store/states.d.ts +11 -0
  32. package/dist/ai/ui/chat/store/states.js +17 -0
  33. package/dist/ai/ui/index.d.ts +1 -0
  34. package/dist/ai/ui/index.js +1 -0
  35. package/dist/ai/utils/index.d.ts +2 -0
  36. package/dist/ai/utils/index.js +2 -0
  37. package/dist/app/defaultTheme.d.ts +1 -1
  38. package/dist/app/index.d.ts +1 -0
  39. package/dist/app/index.js +1 -0
  40. package/dist/functions/index.d.ts +3 -1
  41. package/dist/functions/index.js +4 -1
  42. package/dist/index.d.ts +1 -5
  43. package/dist/index.js +1 -6
  44. package/dist/styles.css +3 -3
  45. package/dist/ui/AnimatedChevron.d.ts +2 -2
  46. package/dist/ui/AnimatedChevron.js +7 -25
  47. package/dist/ui/editor/Toolbar.js +4 -22
  48. package/dist/ui/error/index.d.ts +4 -4
  49. package/dist/ui/error/index.js +5 -4
  50. package/dist/ui/form/buttons/CancelButton.js +4 -26
  51. package/dist/ui/form/buttons/SubmitButton.js +4 -29
  52. package/dist/ui/form/fields/TextPassowrdField.js +4 -26
  53. package/dist/ui/form/index.d.ts +2 -2
  54. package/dist/ui/form/index.js +3 -3
  55. package/dist/ui/hoverPaper/index.d.ts +2 -2
  56. package/dist/ui/hoverPaper/index.js +3 -2
  57. package/dist/ui/scrollArea/ScrollArea.d.ts +1 -1
  58. package/dist/ui/scrollArea/ScrollAreaButton.d.ts +1 -1
  59. package/dist/ui/scrollArea/ScrollAreaButton.js +7 -28
  60. package/package.json +29 -22
  61. package/dist/ai/ui/conversation/ConversationContext.d.ts +0 -7
  62. package/dist/ai/ui/conversation/ConversationContext.js +0 -8
  63. package/dist/ai/ui/conversation/ConversationProvider.d.ts +0 -2
  64. package/dist/ai/ui/conversation/ConversationProvider.js +0 -14
  65. package/dist/ai/ui/conversation/File.d.ts +0 -4
  66. package/dist/ai/ui/conversation/FileIcon.js +0 -225
  67. package/dist/ai/ui/conversation/Message.d.ts +0 -4
  68. package/dist/ai/ui/conversation/Message.js +0 -25
  69. package/dist/ai/ui/conversation/Root.d.ts +0 -2
  70. package/dist/ai/ui/conversation/Root.js +0 -26
  71. package/dist/ai/ui/conversation/index.d.ts +0 -13
  72. package/dist/ai/ui/conversation/types.d.ts +0 -7
  73. package/dist/ai/ui/conversation/types.js +0 -0
  74. package/dist/ai/ui/conversation/useChatMessage.d.ts +0 -2
  75. package/dist/ai/ui/conversation/useChatMessage.js +0 -12
  76. package/dist/ai/ui/promptInput/File.js +0 -117
  77. package/dist/ai/ui/promptInput/FileIcon.js +0 -225
  78. package/dist/ai/ui/promptInput/PromptInputContext.d.ts +0 -12
  79. package/dist/ai/ui/promptInput/PromptInputContext.js +0 -8
  80. package/dist/ai/ui/promptInput/PromptInputProvider.d.ts +0 -2
  81. package/dist/ai/ui/promptInput/PromptInputProvider.js +0 -50
  82. package/dist/ai/ui/promptInput/Root.d.ts +0 -3
  83. package/dist/ai/ui/promptInput/Root.js +0 -17
  84. package/dist/ai/ui/promptInput/Submit.js +0 -40
  85. package/dist/ai/ui/promptInput/types.d.ts +0 -11
  86. package/dist/ai/ui/promptInput/types.js +0 -0
  87. package/dist/functions/cookies/index.d.ts +0 -3
  88. package/dist/functions/cookies/index.js +0 -3
  89. package/dist/surreal/connection.d.ts +0 -9
  90. package/dist/surreal/connection.js +0 -49
  91. package/dist/surreal/deafaultCrud.d.ts +0 -2
  92. package/dist/surreal/deafaultCrud.js +0 -18
  93. package/dist/surreal/deserialize.d.ts +0 -17
  94. package/dist/surreal/deserialize.js +0 -46
  95. package/dist/surreal/encryption.d.ts +0 -6
  96. package/dist/surreal/encryption.js +0 -30
  97. package/dist/surreal/index.d.ts +0 -4
  98. package/dist/surreal/index.js +0 -5
  99. package/dist/ui/editor/styles.module.js +0 -7
  100. package/dist/ui/editor/styles_module.css +0 -16
  101. /package/dist/ai/ui/{conversation → chat}/Empty.d.ts +0 -0
  102. /package/dist/ai/ui/{conversation → chat}/FileIcon.d.ts +0 -0
  103. /package/dist/ai/ui/{conversation → chat}/Loader.d.ts +0 -0
  104. /package/dist/ai/ui/{promptInput → chat/chatInput}/File.d.ts +0 -0
  105. /package/dist/ai/ui/{promptInput → chat/chatInput}/FileIcon.d.ts +0 -0
  106. /package/dist/ai/ui/{promptInput → chat/chatInput}/Footer.d.ts +0 -0
  107. /package/dist/ai/ui/{promptInput → chat/chatInput}/Submit.d.ts +0 -0
  108. /package/dist/ai/ui/{promptInput → chat/chatInput}/Textarea.d.ts +0 -0
  109. /package/dist/functions/{cookies/getCookie.d.ts → getCookie.d.ts} +0 -0
  110. /package/dist/functions/{cookies/getCookie.js → getCookie.js} +0 -0
  111. /package/dist/functions/{cookies/setCookie.d.ts → setCookie.d.ts} +0 -0
  112. /package/dist/functions/{cookies/setCookie.js → setCookie.js} +0 -0
  113. /package/dist/functions/{cookies/setCookies.d.ts → setCookies.d.ts} +0 -0
  114. /package/dist/functions/{cookies/setCookies.js → setCookies.js} +0 -0
@@ -1,7 +0,0 @@
1
- export interface ConversationContext {
2
- loading: boolean;
3
- streaming: boolean;
4
- empty: boolean;
5
- }
6
- export declare const ConversationContext: import("react").Context<ConversationContext | null>;
7
- export declare const useConversation: () => ConversationContext;
@@ -1,8 +0,0 @@
1
- import { createContext, useContext } from "react";
2
- const ConversationContext = createContext(null);
3
- const useConversation = ()=>{
4
- const context = useContext(ConversationContext);
5
- if (!context) throw new Error('useConversation must be used within a ConversationProvider');
6
- return context;
7
- };
8
- export { ConversationContext, useConversation };
@@ -1,2 +0,0 @@
1
- import type { ConversationProps } from './types';
2
- export declare const Provider: ({ children, loading, streaming, empty, }: ConversationProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,14 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { ConversationContext } from "./ConversationContext.js";
3
- const Provider = ({ children, loading, streaming, empty })=>{
4
- const value = {
5
- loading,
6
- streaming,
7
- empty
8
- };
9
- return /*#__PURE__*/ jsx(ConversationContext.Provider, {
10
- value: value,
11
- children: children
12
- });
13
- };
14
- export { Provider };
@@ -1,4 +0,0 @@
1
- import type { UIMessage } from 'ai';
2
- export declare const File: <T extends UIMessage>({ message }: {
3
- message: T;
4
- }) => import("react/jsx-runtime").JSX.Element | null;
@@ -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: "36",
8
- height: "36",
9
- viewBox: "0 0 36 36",
10
- fill: "none",
11
- stroke: "var(--mantine-color-text)",
12
- "stroke-width": "1.5",
13
- "stroke-linecap": "round",
14
- "stroke-linejoin": "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: "36",
41
- height: "36",
42
- viewBox: "0 0 36 36",
43
- fill: "none",
44
- stroke: "var(--mantine-color-text)",
45
- "stroke-width": "1.5",
46
- "stroke-linecap": "round",
47
- "stroke-linejoin": "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 'word' === mimeType:
77
- return /*#__PURE__*/ jsxs("svg", {
78
- xmlns: "http://www.w3.org/2000/svg",
79
- width: "36",
80
- height: "36",
81
- viewBox: "0 0 36 36",
82
- fill: "none",
83
- stroke: "var(--mantine-color-text)",
84
- "stroke-width": "1.5",
85
- "stroke-linecap": "round",
86
- "stroke-linejoin": "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 'excel' === mimeType:
113
- return /*#__PURE__*/ jsxs("svg", {
114
- xmlns: "http://www.w3.org/2000/svg",
115
- width: "36",
116
- height: "36",
117
- viewBox: "0 0 36 36",
118
- fill: "none",
119
- stroke: "var(--mantine-color-text)",
120
- "stroke-width": "1.5",
121
- "stroke-linecap": "round",
122
- "stroke-linejoin": "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 'powerpoint' === mimeType:
152
- return /*#__PURE__*/ jsxs("svg", {
153
- xmlns: "http://www.w3.org/2000/svg",
154
- width: "36",
155
- height: "36",
156
- viewBox: "0 0 36 36",
157
- fill: "none",
158
- stroke: "var(--mantine-color-text)",
159
- "stroke-width": "1.5",
160
- "stroke-linecap": "round",
161
- "stroke-linejoin": "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: "36",
197
- height: "36",
198
- viewBox: "0 0 36 36",
199
- fill: "none",
200
- stroke: "var(--mantine-color-text)",
201
- "stroke-width": "1.5",
202
- "stroke-linecap": "round",
203
- "stroke-linejoin": "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,4 +0,0 @@
1
- import type { UIMessage } from 'ai';
2
- export declare const Message: <T extends UIMessage>({ message }: {
3
- message: T;
4
- }) => import("react/jsx-runtime").JSX.Element | null;
@@ -1,25 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { Paper } from "@mantine/core";
3
- import { Streamdown } from "streamdown";
4
- import { useConversation } from "./ConversationContext.js";
5
- import { useChatMessage } from "./useChatMessage.js";
6
- const Message = ({ message })=>{
7
- const textParts = message?.parts?.filter((i)=>'text' === i.type);
8
- const lastTextPart = textParts?.[textParts.length - 1];
9
- const chatMessage = useChatMessage(lastTextPart);
10
- const { streaming } = useConversation();
11
- return chatMessage && 'system' !== message.role ? /*#__PURE__*/ jsx(Paper, {
12
- radius: "md",
13
- px: "md",
14
- py: "sm",
15
- maw: "80%",
16
- ml: 'user' === message.role ? 'auto' : void 0,
17
- bg: 'user' === message.role ? 'var(--mantine-color-default-hover)' : 'var(--mantine-primary-color-light)',
18
- fz: "sm",
19
- children: /*#__PURE__*/ jsx(Streamdown, {
20
- isAnimating: streaming && 'assistant' === message.role,
21
- children: chatMessage
22
- })
23
- }) : null;
24
- };
25
- export { Message };
@@ -1,2 +0,0 @@
1
- import type { ConversationProps } from './types';
2
- export declare const Root: ({ children, loading, streaming, empty, ...props }: ConversationProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,26 +0,0 @@
1
- import { jsx, jsxs } from "react/jsx-runtime";
2
- import { Paper, Stack } from "@mantine/core";
3
- import { ScrollArea } from "../../../ui/index.js";
4
- import { Provider } from "./ConversationProvider.js";
5
- const Root = ({ children, loading, streaming, empty, ...props })=>/*#__PURE__*/ jsx(Provider, {
6
- loading: loading,
7
- streaming: streaming,
8
- empty: empty,
9
- children: /*#__PURE__*/ jsx(Paper, {
10
- withBorder: true,
11
- radius: "md",
12
- ...props,
13
- children: /*#__PURE__*/ jsxs(ScrollArea, {
14
- autoScroll: true,
15
- scrollToBottomOnInit: true,
16
- p: "md",
17
- children: [
18
- /*#__PURE__*/ jsx(Stack, {
19
- children: children
20
- }),
21
- /*#__PURE__*/ jsx(ScrollArea.ScrollButton, {})
22
- ]
23
- })
24
- })
25
- });
26
- export { Root };
@@ -1,13 +0,0 @@
1
- export type { ConversationProps } from './types';
2
- export { useChatMessage } from './useChatMessage';
3
- export declare const Conversation: {
4
- Root: ({ children, loading, streaming, empty, ...props }: import("./types").ConversationProps) => import("react/jsx-runtime").JSX.Element;
5
- Message: <T extends import("ai").UIMessage>({ message }: {
6
- message: T;
7
- }) => import("react/jsx-runtime").JSX.Element | null;
8
- File: <T extends import("ai").UIMessage>({ message }: {
9
- message: T;
10
- }) => import("react/jsx-runtime").JSX.Element | null;
11
- Loader: (props: import("@mantine/core").LoaderProps) => import("react/jsx-runtime").JSX.Element | null;
12
- Empty: () => import("react/jsx-runtime").JSX.Element | null;
13
- };
@@ -1,7 +0,0 @@
1
- import type { PaperProps } from '@mantine/core';
2
- export interface ConversationProps extends PaperProps {
3
- children?: React.ReactNode;
4
- loading: boolean;
5
- streaming: boolean;
6
- empty: boolean;
7
- }
File without changes
@@ -1,2 +0,0 @@
1
- import type { TextUIPart } from 'ai';
2
- export declare const useChatMessage: (part: TextUIPart) => string;
@@ -1,12 +0,0 @@
1
- import { useEffect, useState } from "react";
2
- import { parseAiMessagePart } from "../../utils/parseAiMessagePart.js";
3
- const useChatMessage = (part)=>{
4
- const [parsedText, setParsedText] = useState('');
5
- useEffect(()=>{
6
- parseAiMessagePart(part).then((i)=>setParsedText(i.text));
7
- }, [
8
- part
9
- ]);
10
- return parsedText;
11
- };
12
- export { useChatMessage };
@@ -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
- "stroke-width": "1.5",
36
- "stroke-linecap": "round",
37
- "stroke-linejoin": "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
- "stroke-width": "1.5",
83
- "stroke-linecap": "round",
84
- "stroke-linejoin": "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 };