@strapi/content-type-builder 5.25.0 → 5.27.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.
Files changed (332) hide show
  1. package/dist/admin/components/AIChat/Chat.js +435 -0
  2. package/dist/admin/components/AIChat/Chat.js.map +1 -0
  3. package/dist/admin/components/AIChat/Chat.mjs +433 -0
  4. package/dist/admin/components/AIChat/Chat.mjs.map +1 -0
  5. package/dist/admin/components/AIChat/FeedbackModal.js +237 -0
  6. package/dist/admin/components/AIChat/FeedbackModal.js.map +1 -0
  7. package/dist/admin/components/AIChat/FeedbackModal.mjs +233 -0
  8. package/dist/admin/components/AIChat/FeedbackModal.mjs.map +1 -0
  9. package/dist/admin/components/AIChat/UploadCodeModal.js +427 -0
  10. package/dist/admin/components/AIChat/UploadCodeModal.js.map +1 -0
  11. package/dist/admin/components/AIChat/UploadCodeModal.mjs +423 -0
  12. package/dist/admin/components/AIChat/UploadCodeModal.mjs.map +1 -0
  13. package/dist/admin/components/AIChat/UploadFigmaModal.js +377 -0
  14. package/dist/admin/components/AIChat/UploadFigmaModal.js.map +1 -0
  15. package/dist/admin/components/AIChat/UploadFigmaModal.mjs +373 -0
  16. package/dist/admin/components/AIChat/UploadFigmaModal.mjs.map +1 -0
  17. package/dist/admin/components/AIChat/components/Alert.js +46 -0
  18. package/dist/admin/components/AIChat/components/Alert.js.map +1 -0
  19. package/dist/admin/components/AIChat/components/Alert.mjs +44 -0
  20. package/dist/admin/components/AIChat/components/Alert.mjs.map +1 -0
  21. package/dist/admin/components/AIChat/components/AnimatedBox.js +34 -0
  22. package/dist/admin/components/AIChat/components/AnimatedBox.js.map +1 -0
  23. package/dist/admin/components/AIChat/components/AnimatedBox.mjs +32 -0
  24. package/dist/admin/components/AIChat/components/AnimatedBox.mjs.map +1 -0
  25. package/dist/admin/components/AIChat/components/Attachments/AttachmentPreview.js +92 -0
  26. package/dist/admin/components/AIChat/components/Attachments/AttachmentPreview.js.map +1 -0
  27. package/dist/admin/components/AIChat/components/Attachments/AttachmentPreview.mjs +90 -0
  28. package/dist/admin/components/AIChat/components/Attachments/AttachmentPreview.mjs.map +1 -0
  29. package/dist/admin/components/AIChat/components/Attachments/components/Attachment.js +100 -0
  30. package/dist/admin/components/AIChat/components/Attachments/components/Attachment.js.map +1 -0
  31. package/dist/admin/components/AIChat/components/Attachments/components/Attachment.mjs +97 -0
  32. package/dist/admin/components/AIChat/components/Attachments/components/Attachment.mjs.map +1 -0
  33. package/dist/admin/components/AIChat/components/Base64Image.js +127 -0
  34. package/dist/admin/components/AIChat/components/Base64Image.js.map +1 -0
  35. package/dist/admin/components/AIChat/components/Base64Image.mjs +125 -0
  36. package/dist/admin/components/AIChat/components/Base64Image.mjs.map +1 -0
  37. package/dist/admin/components/AIChat/components/Collapsible.js +71 -0
  38. package/dist/admin/components/AIChat/components/Collapsible.js.map +1 -0
  39. package/dist/admin/components/AIChat/components/Collapsible.mjs +66 -0
  40. package/dist/admin/components/AIChat/components/Collapsible.mjs.map +1 -0
  41. package/dist/admin/components/AIChat/components/Dropzone.js +172 -0
  42. package/dist/admin/components/AIChat/components/Dropzone.js.map +1 -0
  43. package/dist/admin/components/AIChat/components/Dropzone.mjs +167 -0
  44. package/dist/admin/components/AIChat/components/Dropzone.mjs.map +1 -0
  45. package/dist/admin/components/AIChat/components/FloatingPanel.js +166 -0
  46. package/dist/admin/components/AIChat/components/FloatingPanel.js.map +1 -0
  47. package/dist/admin/components/AIChat/components/FloatingPanel.mjs +163 -0
  48. package/dist/admin/components/AIChat/components/FloatingPanel.mjs.map +1 -0
  49. package/dist/admin/components/AIChat/components/FullScreenImage.js +190 -0
  50. package/dist/admin/components/AIChat/components/FullScreenImage.js.map +1 -0
  51. package/dist/admin/components/AIChat/components/FullScreenImage.mjs +187 -0
  52. package/dist/admin/components/AIChat/components/FullScreenImage.mjs.map +1 -0
  53. package/dist/admin/components/AIChat/components/ImagePreview.js +87 -0
  54. package/dist/admin/components/AIChat/components/ImagePreview.js.map +1 -0
  55. package/dist/admin/components/AIChat/components/ImagePreview.mjs +85 -0
  56. package/dist/admin/components/AIChat/components/ImagePreview.mjs.map +1 -0
  57. package/dist/admin/components/AIChat/components/Input.js +126 -0
  58. package/dist/admin/components/AIChat/components/Input.js.map +1 -0
  59. package/dist/admin/components/AIChat/components/Input.mjs +121 -0
  60. package/dist/admin/components/AIChat/components/Input.mjs.map +1 -0
  61. package/dist/admin/components/AIChat/components/Messages/Marker.js +138 -0
  62. package/dist/admin/components/AIChat/components/Messages/Marker.js.map +1 -0
  63. package/dist/admin/components/AIChat/components/Messages/Marker.mjs +136 -0
  64. package/dist/admin/components/AIChat/components/Messages/Marker.mjs.map +1 -0
  65. package/dist/admin/components/AIChat/components/Messages/Message.js +214 -0
  66. package/dist/admin/components/AIChat/components/Messages/Message.js.map +1 -0
  67. package/dist/admin/components/AIChat/components/Messages/Message.mjs +212 -0
  68. package/dist/admin/components/AIChat/components/Messages/Message.mjs.map +1 -0
  69. package/dist/admin/components/AIChat/components/ResizableTextArea.js +78 -0
  70. package/dist/admin/components/AIChat/components/ResizableTextArea.js.map +1 -0
  71. package/dist/admin/components/AIChat/components/ResizableTextArea.mjs +76 -0
  72. package/dist/admin/components/AIChat/components/ResizableTextArea.mjs.map +1 -0
  73. package/dist/admin/components/AIChat/components/SimpleMenu.js +60 -0
  74. package/dist/admin/components/AIChat/components/SimpleMenu.js.map +1 -0
  75. package/dist/admin/components/AIChat/components/SimpleMenu.mjs +35 -0
  76. package/dist/admin/components/AIChat/components/SimpleMenu.mjs.map +1 -0
  77. package/dist/admin/components/AIChat/components/StepModal.js +175 -0
  78. package/dist/admin/components/AIChat/components/StepModal.js.map +1 -0
  79. package/dist/admin/components/AIChat/components/StepModal.mjs +171 -0
  80. package/dist/admin/components/AIChat/components/StepModal.mjs.map +1 -0
  81. package/dist/admin/components/AIChat/components/animations.js +67 -0
  82. package/dist/admin/components/AIChat/components/animations.js.map +1 -0
  83. package/dist/admin/components/AIChat/components/animations.mjs +65 -0
  84. package/dist/admin/components/AIChat/components/animations.mjs.map +1 -0
  85. package/dist/admin/components/AIChat/components/icons/FigmaIcon.js +50 -0
  86. package/dist/admin/components/AIChat/components/icons/FigmaIcon.js.map +1 -0
  87. package/dist/admin/components/AIChat/components/icons/FigmaIcon.mjs +48 -0
  88. package/dist/admin/components/AIChat/components/icons/FigmaIcon.mjs.map +1 -0
  89. package/dist/admin/components/AIChat/components/icons/StopIcon.js +25 -0
  90. package/dist/admin/components/AIChat/components/icons/StopIcon.js.map +1 -0
  91. package/dist/admin/components/AIChat/components/icons/StopIcon.mjs +23 -0
  92. package/dist/admin/components/AIChat/components/icons/StopIcon.mjs.map +1 -0
  93. package/dist/admin/components/AIChat/hooks/useAIFetch.js +107 -0
  94. package/dist/admin/components/AIChat/hooks/useAIFetch.js.map +1 -0
  95. package/dist/admin/components/AIChat/hooks/useAIFetch.mjs +96 -0
  96. package/dist/admin/components/AIChat/hooks/useAIFetch.mjs.map +1 -0
  97. package/dist/admin/components/AIChat/hooks/useAttachments.js +152 -0
  98. package/dist/admin/components/AIChat/hooks/useAttachments.js.map +1 -0
  99. package/dist/admin/components/AIChat/hooks/useAttachments.mjs +150 -0
  100. package/dist/admin/components/AIChat/hooks/useAttachments.mjs.map +1 -0
  101. package/dist/admin/components/AIChat/hooks/useChatTitle.js +47 -0
  102. package/dist/admin/components/AIChat/hooks/useChatTitle.js.map +1 -0
  103. package/dist/admin/components/AIChat/hooks/useChatTitle.mjs +45 -0
  104. package/dist/admin/components/AIChat/hooks/useChatTitle.mjs.map +1 -0
  105. package/dist/admin/components/AIChat/hooks/useCodeUpload.js +212 -0
  106. package/dist/admin/components/AIChat/hooks/useCodeUpload.js.map +1 -0
  107. package/dist/admin/components/AIChat/hooks/useCodeUpload.mjs +207 -0
  108. package/dist/admin/components/AIChat/hooks/useCodeUpload.mjs.map +1 -0
  109. package/dist/admin/components/AIChat/hooks/useFeedback.js +76 -0
  110. package/dist/admin/components/AIChat/hooks/useFeedback.js.map +1 -0
  111. package/dist/admin/components/AIChat/hooks/useFeedback.mjs +74 -0
  112. package/dist/admin/components/AIChat/hooks/useFeedback.mjs.map +1 -0
  113. package/dist/admin/components/AIChat/hooks/useFigmaUpload.js +206 -0
  114. package/dist/admin/components/AIChat/hooks/useFigmaUpload.js.map +1 -0
  115. package/dist/admin/components/AIChat/hooks/useFigmaUpload.mjs +200 -0
  116. package/dist/admin/components/AIChat/hooks/useFigmaUpload.mjs.map +1 -0
  117. package/dist/admin/components/AIChat/hooks/useLastSeenSchemas.js +115 -0
  118. package/dist/admin/components/AIChat/hooks/useLastSeenSchemas.js.map +1 -0
  119. package/dist/admin/components/AIChat/hooks/useLastSeenSchemas.mjs +113 -0
  120. package/dist/admin/components/AIChat/hooks/useLastSeenSchemas.mjs.map +1 -0
  121. package/dist/admin/components/AIChat/hooks/useTranslations.js +19 -0
  122. package/dist/admin/components/AIChat/hooks/useTranslations.js.map +1 -0
  123. package/dist/admin/components/AIChat/hooks/useTranslations.mjs +17 -0
  124. package/dist/admin/components/AIChat/hooks/useTranslations.mjs.map +1 -0
  125. package/dist/admin/components/AIChat/lib/aiClient.js +168 -0
  126. package/dist/admin/components/AIChat/lib/aiClient.js.map +1 -0
  127. package/dist/admin/components/AIChat/lib/aiClient.mjs +161 -0
  128. package/dist/admin/components/AIChat/lib/aiClient.mjs.map +1 -0
  129. package/dist/admin/components/AIChat/lib/constants.js +16 -0
  130. package/dist/admin/components/AIChat/lib/constants.js.map +1 -0
  131. package/dist/admin/components/AIChat/lib/constants.mjs +10 -0
  132. package/dist/admin/components/AIChat/lib/constants.mjs.map +1 -0
  133. package/dist/admin/components/AIChat/lib/misc.js +8 -0
  134. package/dist/admin/components/AIChat/lib/misc.js.map +1 -0
  135. package/dist/admin/components/AIChat/lib/misc.mjs +6 -0
  136. package/dist/admin/components/AIChat/lib/misc.mjs.map +1 -0
  137. package/dist/admin/components/AIChat/lib/transforms/schemas/fromCTB.js +46 -0
  138. package/dist/admin/components/AIChat/lib/transforms/schemas/fromCTB.js.map +1 -0
  139. package/dist/admin/components/AIChat/lib/transforms/schemas/fromCTB.mjs +44 -0
  140. package/dist/admin/components/AIChat/lib/transforms/schemas/fromCTB.mjs.map +1 -0
  141. package/dist/admin/components/AIChat/lib/transforms/schemas/toCTB.js +151 -0
  142. package/dist/admin/components/AIChat/lib/transforms/schemas/toCTB.js.map +1 -0
  143. package/dist/admin/components/AIChat/lib/transforms/schemas/toCTB.mjs +148 -0
  144. package/dist/admin/components/AIChat/lib/transforms/schemas/toCTB.mjs.map +1 -0
  145. package/dist/admin/components/AIChat/providers/ChatProvider.js +191 -0
  146. package/dist/admin/components/AIChat/providers/ChatProvider.js.map +1 -0
  147. package/dist/admin/components/AIChat/providers/ChatProvider.mjs +187 -0
  148. package/dist/admin/components/AIChat/providers/ChatProvider.mjs.map +1 -0
  149. package/dist/admin/components/AIChat/providers/SchemaProvider.js +90 -0
  150. package/dist/admin/components/AIChat/providers/SchemaProvider.js.map +1 -0
  151. package/dist/admin/components/AIChat/providers/SchemaProvider.mjs +88 -0
  152. package/dist/admin/components/AIChat/providers/SchemaProvider.mjs.map +1 -0
  153. package/dist/admin/components/ComponentList.js +1 -0
  154. package/dist/admin/components/ComponentList.js.map +1 -1
  155. package/dist/admin/components/ComponentList.mjs +1 -0
  156. package/dist/admin/components/ComponentList.mjs.map +1 -1
  157. package/dist/admin/components/ContentTypeBuilderNav/ContentTypeBuilderNav.js +165 -161
  158. package/dist/admin/components/ContentTypeBuilderNav/ContentTypeBuilderNav.js.map +1 -1
  159. package/dist/admin/components/ContentTypeBuilderNav/ContentTypeBuilderNav.mjs +165 -161
  160. package/dist/admin/components/ContentTypeBuilderNav/ContentTypeBuilderNav.mjs.map +1 -1
  161. package/dist/admin/components/DataManager/DataManagerContext.js.map +1 -1
  162. package/dist/admin/components/DataManager/DataManagerContext.mjs.map +1 -1
  163. package/dist/admin/components/DataManager/reducer.js +48 -6
  164. package/dist/admin/components/DataManager/reducer.js.map +1 -1
  165. package/dist/admin/components/DataManager/reducer.mjs +48 -6
  166. package/dist/admin/components/DataManager/reducer.mjs.map +1 -1
  167. package/dist/admin/components/FormModal/utils/canEditContentType.js.map +1 -1
  168. package/dist/admin/components/FormModal/utils/canEditContentType.mjs.map +1 -1
  169. package/dist/admin/pages/App/index.js +60 -29
  170. package/dist/admin/pages/App/index.js.map +1 -1
  171. package/dist/admin/pages/App/index.mjs +62 -31
  172. package/dist/admin/pages/App/index.mjs.map +1 -1
  173. package/dist/admin/pages/ListView/EmptyState.js +75 -9
  174. package/dist/admin/pages/ListView/EmptyState.js.map +1 -1
  175. package/dist/admin/pages/ListView/EmptyState.mjs +77 -11
  176. package/dist/admin/pages/ListView/EmptyState.mjs.map +1 -1
  177. package/dist/admin/src/components/AIChat/Chat.d.ts +2 -0
  178. package/dist/admin/src/components/AIChat/FeedbackModal.d.ts +13 -0
  179. package/dist/admin/src/components/AIChat/UploadCodeModal.d.ts +12 -0
  180. package/dist/admin/src/components/AIChat/UploadFigmaModal.d.ts +12 -0
  181. package/dist/admin/src/components/AIChat/components/Alert.d.ts +6 -0
  182. package/dist/admin/src/components/AIChat/components/AnimatedBox.d.ts +13 -0
  183. package/dist/admin/src/components/AIChat/components/Attachments/AttachmentPreview.d.ts +9 -0
  184. package/dist/admin/src/components/AIChat/components/Attachments/components/Attachment.d.ts +27 -0
  185. package/dist/admin/src/components/AIChat/components/Base64Image.d.ts +9 -0
  186. package/dist/admin/src/components/AIChat/components/Collapsible.d.ts +18 -0
  187. package/dist/admin/src/components/AIChat/components/Dropzone.d.ts +35 -0
  188. package/dist/admin/src/components/AIChat/components/FloatingPanel.d.ts +34 -0
  189. package/dist/admin/src/components/AIChat/components/FullScreenImage.d.ts +20 -0
  190. package/dist/admin/src/components/AIChat/components/ImagePreview.d.ts +8 -0
  191. package/dist/admin/src/components/AIChat/components/ImagePreviewGroup.d.ts +7 -0
  192. package/dist/admin/src/components/AIChat/components/Input.d.ts +43 -0
  193. package/dist/admin/src/components/AIChat/components/Messages/Marker.d.ts +2 -0
  194. package/dist/admin/src/components/AIChat/components/Messages/Message.d.ts +5 -0
  195. package/dist/admin/src/components/AIChat/components/ResizableTextArea.d.ts +9 -0
  196. package/dist/admin/src/components/AIChat/components/SimpleMenu.d.ts +32 -0
  197. package/dist/admin/src/components/AIChat/components/StepModal.d.ts +37 -0
  198. package/dist/admin/src/components/AIChat/components/animations.d.ts +8 -0
  199. package/dist/admin/src/components/AIChat/components/icons/FigmaIcon.d.ts +5 -0
  200. package/dist/admin/src/components/AIChat/components/icons/StopIcon.d.ts +5 -0
  201. package/dist/admin/src/components/AIChat/hooks/useAIFetch.d.ts +147 -0
  202. package/dist/admin/src/components/AIChat/hooks/useAttachments.d.ts +8 -0
  203. package/dist/admin/src/components/AIChat/hooks/useChatTitle.d.ts +13 -0
  204. package/dist/admin/src/components/AIChat/hooks/useCodeUpload.d.ts +31 -0
  205. package/dist/admin/src/components/AIChat/hooks/useFeedback.d.ts +7 -0
  206. package/dist/admin/src/components/AIChat/hooks/useFigmaUpload.d.ts +61 -0
  207. package/dist/admin/src/components/AIChat/hooks/useLastSeenSchemas.d.ts +10 -0
  208. package/dist/admin/src/components/AIChat/hooks/useTranslations.d.ts +3 -0
  209. package/dist/admin/src/components/AIChat/lib/aiClient.d.ts +32 -0
  210. package/dist/admin/src/components/AIChat/lib/constants.d.ts +12 -0
  211. package/dist/admin/src/components/AIChat/lib/fileToAttachment.d.ts +2 -0
  212. package/dist/admin/src/components/AIChat/lib/misc.d.ts +1 -0
  213. package/dist/admin/src/components/AIChat/lib/transforms/schemas/fromCTB.d.ts +3 -0
  214. package/dist/admin/src/components/AIChat/lib/transforms/schemas/toCTB.d.ts +16 -0
  215. package/dist/admin/src/components/AIChat/lib/types/annotations.d.ts +19 -0
  216. package/dist/admin/src/components/AIChat/lib/types/attachments.d.ts +15 -0
  217. package/dist/admin/src/components/AIChat/lib/types/feedback.d.ts +1 -0
  218. package/dist/admin/src/components/AIChat/lib/types/messages.d.ts +26 -0
  219. package/dist/admin/src/components/AIChat/lib/types/schema.d.ts +20 -0
  220. package/dist/admin/src/components/AIChat/providers/ChatProvider.d.ts +30 -0
  221. package/dist/admin/src/components/AIChat/providers/SchemaProvider.d.ts +10 -0
  222. package/dist/admin/src/components/ComponentList.d.ts +1 -1
  223. package/dist/admin/src/components/DataManager/DataManagerContext.d.ts +1 -1
  224. package/dist/admin/translations/ar.json.js +187 -2
  225. package/dist/admin/translations/ar.json.js.map +1 -1
  226. package/dist/admin/translations/ar.json.mjs +187 -3
  227. package/dist/admin/translations/ar.json.mjs.map +1 -1
  228. package/dist/admin/translations/de.json.js +42 -7
  229. package/dist/admin/translations/de.json.js.map +1 -1
  230. package/dist/admin/translations/de.json.mjs +42 -7
  231. package/dist/admin/translations/de.json.mjs.map +1 -1
  232. package/dist/admin/translations/en.json.js +53 -2
  233. package/dist/admin/translations/en.json.js.map +1 -1
  234. package/dist/admin/translations/en.json.mjs +53 -2
  235. package/dist/admin/translations/en.json.mjs.map +1 -1
  236. package/dist/admin/translations/es.json.js +37 -15
  237. package/dist/admin/translations/es.json.js.map +1 -1
  238. package/dist/admin/translations/es.json.mjs +37 -15
  239. package/dist/admin/translations/es.json.mjs.map +1 -1
  240. package/dist/admin/translations/fr.json.js +165 -3
  241. package/dist/admin/translations/fr.json.js.map +1 -1
  242. package/dist/admin/translations/fr.json.mjs +165 -4
  243. package/dist/admin/translations/fr.json.mjs.map +1 -1
  244. package/dist/admin/translations/id.json.js +93 -23
  245. package/dist/admin/translations/id.json.js.map +1 -1
  246. package/dist/admin/translations/id.json.mjs +93 -23
  247. package/dist/admin/translations/id.json.mjs.map +1 -1
  248. package/dist/admin/translations/it.json.js +75 -6
  249. package/dist/admin/translations/it.json.js.map +1 -1
  250. package/dist/admin/translations/it.json.mjs +75 -6
  251. package/dist/admin/translations/it.json.mjs.map +1 -1
  252. package/dist/admin/translations/ja.json.js +191 -5
  253. package/dist/admin/translations/ja.json.js.map +1 -1
  254. package/dist/admin/translations/ja.json.mjs +191 -6
  255. package/dist/admin/translations/ja.json.mjs.map +1 -1
  256. package/dist/admin/translations/ko.json.js +70 -16
  257. package/dist/admin/translations/ko.json.js.map +1 -1
  258. package/dist/admin/translations/ko.json.mjs +70 -16
  259. package/dist/admin/translations/ko.json.mjs.map +1 -1
  260. package/dist/admin/translations/ms.json.js +104 -31
  261. package/dist/admin/translations/ms.json.js.map +1 -1
  262. package/dist/admin/translations/ms.json.mjs +104 -31
  263. package/dist/admin/translations/ms.json.mjs.map +1 -1
  264. package/dist/admin/translations/nl.json.js +95 -15
  265. package/dist/admin/translations/nl.json.js.map +1 -1
  266. package/dist/admin/translations/nl.json.mjs +95 -15
  267. package/dist/admin/translations/nl.json.mjs.map +1 -1
  268. package/dist/admin/translations/pl.json.js +55 -11
  269. package/dist/admin/translations/pl.json.js.map +1 -1
  270. package/dist/admin/translations/pl.json.mjs +55 -11
  271. package/dist/admin/translations/pl.json.mjs.map +1 -1
  272. package/dist/admin/translations/pt-BR.json.js +54 -10
  273. package/dist/admin/translations/pt-BR.json.js.map +1 -1
  274. package/dist/admin/translations/pt-BR.json.mjs +54 -10
  275. package/dist/admin/translations/pt-BR.json.mjs.map +1 -1
  276. package/dist/admin/translations/pt.json.js +187 -2
  277. package/dist/admin/translations/pt.json.js.map +1 -1
  278. package/dist/admin/translations/pt.json.mjs +187 -3
  279. package/dist/admin/translations/pt.json.mjs.map +1 -1
  280. package/dist/admin/translations/ru.json.js +26 -1
  281. package/dist/admin/translations/ru.json.js.map +1 -1
  282. package/dist/admin/translations/ru.json.mjs +26 -1
  283. package/dist/admin/translations/ru.json.mjs.map +1 -1
  284. package/dist/admin/translations/sk.json.js +21 -1
  285. package/dist/admin/translations/sk.json.js.map +1 -1
  286. package/dist/admin/translations/sk.json.mjs +21 -1
  287. package/dist/admin/translations/sk.json.mjs.map +1 -1
  288. package/dist/admin/translations/sv.json.js +21 -1
  289. package/dist/admin/translations/sv.json.js.map +1 -1
  290. package/dist/admin/translations/sv.json.mjs +21 -1
  291. package/dist/admin/translations/sv.json.mjs.map +1 -1
  292. package/dist/admin/translations/th.json.js +21 -1
  293. package/dist/admin/translations/th.json.js.map +1 -1
  294. package/dist/admin/translations/th.json.mjs +21 -1
  295. package/dist/admin/translations/th.json.mjs.map +1 -1
  296. package/dist/admin/translations/tr.json.js +21 -1
  297. package/dist/admin/translations/tr.json.js.map +1 -1
  298. package/dist/admin/translations/tr.json.mjs +21 -1
  299. package/dist/admin/translations/tr.json.mjs.map +1 -1
  300. package/dist/admin/translations/uk.json.js +21 -2
  301. package/dist/admin/translations/uk.json.js.map +1 -1
  302. package/dist/admin/translations/uk.json.mjs +21 -2
  303. package/dist/admin/translations/uk.json.mjs.map +1 -1
  304. package/dist/admin/translations/zh-Hans.json.js +222 -133
  305. package/dist/admin/translations/zh-Hans.json.js.map +1 -1
  306. package/dist/admin/translations/zh-Hans.json.mjs +222 -133
  307. package/dist/admin/translations/zh-Hans.json.mjs.map +1 -1
  308. package/dist/admin/translations/zh.json.js +21 -1
  309. package/dist/admin/translations/zh.json.js.map +1 -1
  310. package/dist/admin/translations/zh.json.mjs +21 -1
  311. package/dist/admin/translations/zh.json.mjs.map +1 -1
  312. package/dist/server/index.js +2 -0
  313. package/dist/server/index.js.map +1 -1
  314. package/dist/server/index.mjs +2 -0
  315. package/dist/server/index.mjs.map +1 -1
  316. package/dist/server/register.js +98 -0
  317. package/dist/server/register.js.map +1 -0
  318. package/dist/server/register.mjs +96 -0
  319. package/dist/server/register.mjs.map +1 -0
  320. package/dist/server/src/controllers/ai/auth.d.ts +1 -0
  321. package/dist/server/src/controllers/ai/auth.d.ts.map +1 -0
  322. package/dist/server/src/controllers/ai/index.d.ts +1 -0
  323. package/dist/server/src/controllers/ai/index.d.ts.map +1 -0
  324. package/dist/server/src/index.d.ts +1 -0
  325. package/dist/server/src/index.d.ts.map +1 -1
  326. package/dist/server/src/register.d.ts +11 -0
  327. package/dist/server/src/register.d.ts.map +1 -0
  328. package/package.json +12 -5
  329. package/dist/admin/components/DataManager/utils/formatSchemas.js +0 -21
  330. package/dist/admin/components/DataManager/utils/formatSchemas.js.map +0 -1
  331. package/dist/admin/components/DataManager/utils/formatSchemas.mjs +0 -18
  332. package/dist/admin/components/DataManager/utils/formatSchemas.mjs.map +0 -1
@@ -0,0 +1,207 @@
1
+ import { useState } from 'react';
2
+ import JSZip from 'jszip';
3
+ import micromatch from 'micromatch';
4
+ import { generateId } from '../lib/misc.mjs';
5
+ import { useStrapiChat } from '../providers/ChatProvider.mjs';
6
+ import { useFetchUploadProject } from './useAIFetch.mjs';
7
+
8
+ const ALLOWED_EXTENSIONS = [
9
+ '.ts',
10
+ '.tsx',
11
+ '.js',
12
+ '.jsx',
13
+ '.md',
14
+ '.json'
15
+ ];
16
+ const MAX_LINES_PER_FILE = 5000; // Maximum number of lines per file
17
+ // Common patterns to ignore
18
+ const DEFAULT_IGNORE_PATTERNS = [
19
+ '**/node_modules/**',
20
+ '**/.git/**',
21
+ '**/.next/**',
22
+ '**/dist/**',
23
+ '**/build/**',
24
+ '**/.cache/**',
25
+ '**/coverage/**',
26
+ '**/test/**',
27
+ '**/__tests__/**',
28
+ '**/*.test.*',
29
+ '**/*.spec.*'
30
+ ];
31
+ const isAllowedFile = (filename, ignorePatterns = [])=>{
32
+ // Check if file matches any ignore pattern
33
+ if (micromatch.isMatch(filename, [
34
+ ...DEFAULT_IGNORE_PATTERNS,
35
+ ...ignorePatterns
36
+ ])) {
37
+ return false;
38
+ }
39
+ // Check if file has allowed extension
40
+ return ALLOWED_EXTENSIONS.some((ext)=>filename.toLowerCase().endsWith(ext));
41
+ };
42
+ /**
43
+ * Prunes file content if it exceeds MAX_LINES
44
+ */ const pruneFileContent = (content)=>{
45
+ const lines = content.split('\n');
46
+ if (lines.length <= MAX_LINES_PER_FILE) {
47
+ return content;
48
+ }
49
+ const truncated = lines.slice(0, MAX_LINES_PER_FILE).join('\n');
50
+ return `${truncated}\n\n// ... [${lines.length - MAX_LINES_PER_FILE} lines truncated, file too long] ...\n\n`;
51
+ };
52
+ /* -------------------------------------------------------------------------------------------------
53
+ * Zip file processing
54
+ * -----------------------------------------------------------------------------------------------*/ async function openZipFile(file, options = {}) {
55
+ const zip = new JSZip();
56
+ const contents = await zip.loadAsync(file);
57
+ const processedFiles = [];
58
+ // Process all files in parallel
59
+ await Promise.all(Object.keys(contents.files).map(async (filename)=>{
60
+ const zipEntry = contents.files[filename];
61
+ // Skip directories and non-allowed files
62
+ if (zipEntry.dir || !isAllowedFile(filename, options.ignorePatterns)) {
63
+ return;
64
+ }
65
+ try {
66
+ const content = await zipEntry.async('string');
67
+ processedFiles.push({
68
+ path: filename,
69
+ content: pruneFileContent(content)
70
+ });
71
+ } catch (err) {
72
+ console.warn(`Failed to read file ${filename}:`, err);
73
+ }
74
+ }));
75
+ // Sort files by path for consistency
76
+ return processedFiles.sort((a, b)=>a.path.localeCompare(b.path));
77
+ }
78
+ /* -------------------------------------------------------------------------------------------------
79
+ * Folder processing
80
+ * -----------------------------------------------------------------------------------------------*/ async function processFolder(files, options = {}) {
81
+ const processedFiles = [];
82
+ let folderName = 'Project';
83
+ // Extract folder name from the first file's path
84
+ if (files.length > 0) {
85
+ const firstFile = files[0];
86
+ const folderPath = firstFile.webkitRelativePath || '';
87
+ const pathParts = folderPath.split('/');
88
+ if (pathParts.length > 0 && pathParts[0]) {
89
+ folderName = pathParts[0];
90
+ }
91
+ }
92
+ // Process all files in parallel
93
+ await Promise.all(Array.from(files).map(async (file)=>{
94
+ const filePath = file.webkitRelativePath || file.name;
95
+ // Skip non-allowed files
96
+ if (!isAllowedFile(filePath, options.ignorePatterns)) {
97
+ return;
98
+ }
99
+ try {
100
+ const content = await file.text();
101
+ processedFiles.push({
102
+ // Remove the root folder name from the path
103
+ path: filePath.includes('/') ? filePath.substring(filePath.indexOf('/') + 1) : filePath,
104
+ content: pruneFileContent(content)
105
+ });
106
+ } catch (err) {
107
+ console.warn(`Failed to read file ${filePath}:`, err);
108
+ }
109
+ }));
110
+ // Sort files by path for consistency
111
+ return {
112
+ files: processedFiles.sort((a, b)=>a.path.localeCompare(b.path)),
113
+ projectName: folderName
114
+ };
115
+ }
116
+ /* -------------------------------------------------------------------------------------------------
117
+ * Zip file processing
118
+ * -----------------------------------------------------------------------------------------------*/ async function processZipFile(file, options = {}) {
119
+ const projectName = file.name.replace('.zip', '');
120
+ const files = await openZipFile(file, options);
121
+ return {
122
+ files,
123
+ projectName
124
+ };
125
+ }
126
+ function useCodeUpload({ onSuccess, onError } = {}) {
127
+ const [error, setError] = useState(null);
128
+ const [isProcessing, setIsProcessing] = useState(false);
129
+ const { fetch: fetchUploadProject, isPending: isFetching, error: fetchError } = useFetchUploadProject();
130
+ const { id: chatId } = useStrapiChat();
131
+ /**
132
+ * Upload processed files to the server
133
+ */ const processFiles = async (projectName, processedFiles)=>{
134
+ // Upload to server
135
+ const result = await fetchUploadProject({
136
+ body: {
137
+ chatId,
138
+ name: projectName,
139
+ type: 'code',
140
+ files: processedFiles
141
+ }
142
+ });
143
+ if (!result?.data) {
144
+ throw new Error('Failed to upload project');
145
+ }
146
+ return result.data;
147
+ };
148
+ const handleZipFile = async (file)=>{
149
+ try {
150
+ setError(null);
151
+ setIsProcessing(true);
152
+ const { files: processedFiles, projectName } = await processZipFile(file, {
153
+ ignorePatterns: [
154
+ '**/node_modules/**'
155
+ ]
156
+ });
157
+ const projectAttachment = await processFiles(projectName, processedFiles);
158
+ onSuccess?.({
159
+ ...projectAttachment,
160
+ id: generateId(),
161
+ status: 'ready'
162
+ }, projectName);
163
+ return projectAttachment;
164
+ } catch (err) {
165
+ setError('Failed to process zip file');
166
+ onError?.('Failed to process zip file');
167
+ console.error('Error processing zip:', err);
168
+ throw err;
169
+ } finally{
170
+ setIsProcessing(false);
171
+ }
172
+ };
173
+ const handleFolder = async (files)=>{
174
+ try {
175
+ setError(null);
176
+ setIsProcessing(true);
177
+ const { files: processedFiles, projectName } = await processFolder(files, {
178
+ ignorePatterns: [
179
+ '**/node_modules/**'
180
+ ]
181
+ });
182
+ const projectAttachment = await processFiles(projectName, processedFiles);
183
+ onSuccess?.({
184
+ ...projectAttachment,
185
+ id: generateId(),
186
+ status: 'ready'
187
+ }, projectName);
188
+ return projectAttachment;
189
+ } catch (err) {
190
+ setError('Failed to process folder');
191
+ onError?.('Failed to process folder');
192
+ console.error('Error processing folder:', err);
193
+ throw err;
194
+ } finally{
195
+ setIsProcessing(false);
196
+ }
197
+ };
198
+ return {
199
+ processZipFile: handleZipFile,
200
+ processFolder: handleFolder,
201
+ isLoading: isProcessing || isFetching,
202
+ error: fetchError || error
203
+ };
204
+ }
205
+
206
+ export { openZipFile, processFolder, processZipFile, useCodeUpload };
207
+ //# sourceMappingURL=useCodeUpload.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCodeUpload.mjs","sources":["../../../../../admin/src/components/AIChat/hooks/useCodeUpload.ts"],"sourcesContent":["import { useState } from 'react';\n\nimport JSZip from 'jszip';\nimport micromatch from 'micromatch';\n\nimport { generateId } from '../lib/misc';\nimport { Attachment } from '../lib/types/attachments';\nimport { useStrapiChat } from '../providers/ChatProvider';\n\nimport { useFetchUploadProject } from './useAIFetch';\n\nexport interface ProjectFile {\n path: string;\n content: string;\n}\n\nconst ALLOWED_EXTENSIONS = ['.ts', '.tsx', '.js', '.jsx', '.md', '.json'];\nconst MAX_LINES_PER_FILE = 5000; // Maximum number of lines per file\n\n// Common patterns to ignore\nconst DEFAULT_IGNORE_PATTERNS = [\n '**/node_modules/**',\n '**/.git/**',\n '**/.next/**',\n '**/dist/**',\n '**/build/**',\n '**/.cache/**',\n '**/coverage/**',\n '**/test/**',\n '**/__tests__/**',\n '**/*.test.*',\n '**/*.spec.*',\n];\n\nconst isAllowedFile = (filename: string, ignorePatterns: string[] = []) => {\n // Check if file matches any ignore pattern\n if (micromatch.isMatch(filename, [...DEFAULT_IGNORE_PATTERNS, ...ignorePatterns])) {\n return false;\n }\n\n // Check if file has allowed extension\n return ALLOWED_EXTENSIONS.some((ext) => filename.toLowerCase().endsWith(ext));\n};\n\n/**\n * Prunes file content if it exceeds MAX_LINES\n */\nconst pruneFileContent = (content: string): string => {\n const lines = content.split('\\n');\n\n if (lines.length <= MAX_LINES_PER_FILE) {\n return content;\n }\n\n const truncated = lines.slice(0, MAX_LINES_PER_FILE).join('\\n');\n\n return `${truncated}\\n\\n// ... [${lines.length - MAX_LINES_PER_FILE} lines truncated, file too long] ...\\n\\n`;\n};\n\n/* -------------------------------------------------------------------------------------------------\n * File processing options\n * -----------------------------------------------------------------------------------------------*/\nexport interface ProcessOptions {\n /**\n * Additional glob patterns to ignore\n */\n ignorePatterns?: string[];\n}\n\n/* -------------------------------------------------------------------------------------------------\n * Zip file processing\n * -----------------------------------------------------------------------------------------------*/\nexport async function openZipFile(\n file: File,\n options: ProcessOptions = {}\n): Promise<ProjectFile[]> {\n const zip = new JSZip();\n const contents = await zip.loadAsync(file);\n const processedFiles: ProjectFile[] = [];\n\n // Process all files in parallel\n await Promise.all(\n Object.keys(contents.files).map(async (filename) => {\n const zipEntry = contents.files[filename];\n\n // Skip directories and non-allowed files\n if (zipEntry.dir || !isAllowedFile(filename, options.ignorePatterns)) {\n return;\n }\n\n try {\n const content = await zipEntry.async('string');\n processedFiles.push({\n path: filename,\n content: pruneFileContent(content),\n });\n } catch (err) {\n console.warn(`Failed to read file ${filename}:`, err);\n }\n })\n );\n\n // Sort files by path for consistency\n return processedFiles.sort((a, b) => a.path.localeCompare(b.path));\n}\n\n/* -------------------------------------------------------------------------------------------------\n * Folder processing\n * -----------------------------------------------------------------------------------------------*/\nexport async function processFolder(\n files: FileList | File[],\n options: ProcessOptions = {}\n): Promise<{ files: ProjectFile[]; projectName: string }> {\n const processedFiles: ProjectFile[] = [];\n let folderName = 'Project';\n\n // Extract folder name from the first file's path\n if (files.length > 0) {\n const firstFile = files[0];\n const folderPath = firstFile.webkitRelativePath || '';\n const pathParts = folderPath.split('/');\n if (pathParts.length > 0 && pathParts[0]) {\n folderName = pathParts[0];\n }\n }\n\n // Process all files in parallel\n await Promise.all(\n Array.from(files).map(async (file) => {\n const filePath = file.webkitRelativePath || file.name;\n\n // Skip non-allowed files\n if (!isAllowedFile(filePath, options.ignorePatterns)) {\n return;\n }\n\n try {\n const content = await file.text();\n processedFiles.push({\n // Remove the root folder name from the path\n path: filePath.includes('/') ? filePath.substring(filePath.indexOf('/') + 1) : filePath,\n content: pruneFileContent(content),\n });\n } catch (err) {\n console.warn(`Failed to read file ${filePath}:`, err);\n }\n })\n );\n\n // Sort files by path for consistency\n return {\n files: processedFiles.sort((a, b) => a.path.localeCompare(b.path)),\n projectName: folderName,\n };\n}\n\n/* -------------------------------------------------------------------------------------------------\n * Zip file processing\n * -----------------------------------------------------------------------------------------------*/\nexport async function processZipFile(\n file: File,\n options: ProcessOptions = {}\n): Promise<{ files: ProjectFile[]; projectName: string }> {\n const projectName = file.name.replace('.zip', '');\n const files = await openZipFile(file, options);\n\n return {\n files,\n projectName,\n };\n}\n\n/* -------------------------------------------------------------------------------------------------\n * Upload files\n * -----------------------------------------------------------------------------------------------*/\n\ninterface UseCodeUploadOptions {\n onSuccess?: (attachment: Attachment, projectName: string) => void;\n onError?: (error: string) => void;\n}\n\nexport function useCodeUpload({ onSuccess, onError }: UseCodeUploadOptions = {}) {\n const [error, setError] = useState<string | null>(null);\n const [isProcessing, setIsProcessing] = useState(false);\n const {\n fetch: fetchUploadProject,\n isPending: isFetching,\n error: fetchError,\n } = useFetchUploadProject();\n const { id: chatId } = useStrapiChat();\n\n /**\n * Upload processed files to the server\n */\n const processFiles = async (projectName: string, processedFiles: ProjectFile[]) => {\n // Upload to server\n const result = await fetchUploadProject({\n body: {\n chatId,\n name: projectName,\n type: 'code',\n files: processedFiles,\n },\n });\n\n if (!result?.data) {\n throw new Error('Failed to upload project');\n }\n\n return result.data;\n };\n\n const handleZipFile = async (file: File) => {\n try {\n setError(null);\n setIsProcessing(true);\n\n const { files: processedFiles, projectName } = await processZipFile(file, {\n ignorePatterns: ['**/node_modules/**'],\n });\n\n const projectAttachment = await processFiles(projectName, processedFiles);\n\n onSuccess?.({ ...projectAttachment, id: generateId(), status: 'ready' }, projectName);\n return projectAttachment;\n } catch (err) {\n setError('Failed to process zip file');\n onError?.('Failed to process zip file');\n console.error('Error processing zip:', err);\n throw err;\n } finally {\n setIsProcessing(false);\n }\n };\n\n const handleFolder = async (files: FileList | File[]) => {\n try {\n setError(null);\n setIsProcessing(true);\n\n const { files: processedFiles, projectName } = await processFolder(files, {\n ignorePatterns: ['**/node_modules/**'],\n });\n\n const projectAttachment = await processFiles(projectName, processedFiles);\n\n onSuccess?.({ ...projectAttachment, id: generateId(), status: 'ready' }, projectName);\n return projectAttachment;\n } catch (err) {\n setError('Failed to process folder');\n onError?.('Failed to process folder');\n console.error('Error processing folder:', err);\n throw err;\n } finally {\n setIsProcessing(false);\n }\n };\n\n return {\n processZipFile: handleZipFile,\n processFolder: handleFolder,\n isLoading: isProcessing || isFetching,\n error: fetchError || error,\n };\n}\n"],"names":["ALLOWED_EXTENSIONS","MAX_LINES_PER_FILE","DEFAULT_IGNORE_PATTERNS","isAllowedFile","filename","ignorePatterns","micromatch","isMatch","some","ext","toLowerCase","endsWith","pruneFileContent","content","lines","split","length","truncated","slice","join","openZipFile","file","options","zip","JSZip","contents","loadAsync","processedFiles","Promise","all","Object","keys","files","map","zipEntry","dir","async","push","path","err","console","warn","sort","a","b","localeCompare","processFolder","folderName","firstFile","folderPath","webkitRelativePath","pathParts","Array","from","filePath","name","text","includes","substring","indexOf","projectName","processZipFile","replace","useCodeUpload","onSuccess","onError","error","setError","useState","isProcessing","setIsProcessing","fetch","fetchUploadProject","isPending","isFetching","fetchError","useFetchUploadProject","id","chatId","useStrapiChat","processFiles","result","body","type","data","Error","handleZipFile","projectAttachment","generateId","status","handleFolder","isLoading"],"mappings":"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"}
@@ -0,0 +1,76 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+ var strapiAdmin = require('@strapi/admin/strapi-admin');
5
+ var ChatProvider = require('../providers/ChatProvider.js');
6
+ var useAIFetch = require('./useAIFetch.js');
7
+ var useTranslations = require('./useTranslations.js');
8
+
9
+ const useFeedback = ()=>{
10
+ const { fetch: sendFeedback, isPending, error } = useAIFetch.useFetchSendFeedback();
11
+ const { id, messages, schemas } = ChatProvider.useStrapiChat();
12
+ const { toggleNotification } = strapiAdmin.useNotification();
13
+ const { trackUsage } = strapiAdmin.useTracking();
14
+ const { t } = useTranslations.useTranslations();
15
+ // Keep track of messages that have received feedback
16
+ const [votedMessages, setVotedMessages] = React.useState({});
17
+ const hasVoted = (messageId)=>{
18
+ return !!votedMessages[messageId];
19
+ };
20
+ const upvoteMessage = (messageId)=>{
21
+ // Prevent spamming upvote
22
+ if (hasVoted(messageId)) {
23
+ return Promise.resolve();
24
+ }
25
+ trackUsage('didVoteAnswer', {
26
+ value: 'positive'
27
+ });
28
+ toggleNotification({
29
+ type: 'success',
30
+ message: t('chat.feedback.submitted', 'Thank you for your feedback! ')
31
+ });
32
+ // Record this message as upvoted
33
+ setVotedMessages((prev)=>({
34
+ ...prev,
35
+ [messageId]: 'upvote'
36
+ }));
37
+ return sendFeedback({
38
+ body: {
39
+ type: 'upvote',
40
+ chatId: id,
41
+ messageId,
42
+ messages,
43
+ schemas
44
+ }
45
+ });
46
+ };
47
+ const downvoteMessage = (messageId, feedback, reasons)=>{
48
+ trackUsage('didVoteAnswer', {
49
+ value: 'negative'
50
+ });
51
+ toggleNotification({
52
+ type: 'success',
53
+ message: t('chat.feedback.submitted', 'Thank you for your feedback! ')
54
+ });
55
+ return sendFeedback({
56
+ body: {
57
+ type: 'downvote',
58
+ chatId: id,
59
+ messageId,
60
+ messages,
61
+ feedback,
62
+ reasons,
63
+ schemas
64
+ }
65
+ });
66
+ };
67
+ return {
68
+ upvoteMessage,
69
+ downvoteMessage,
70
+ isPending,
71
+ error
72
+ };
73
+ };
74
+
75
+ exports.useFeedback = useFeedback;
76
+ //# sourceMappingURL=useFeedback.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFeedback.js","sources":["../../../../../admin/src/components/AIChat/hooks/useFeedback.ts"],"sourcesContent":["import { useState } from 'react';\n\nimport { useNotification, useTracking } from '@strapi/admin/strapi-admin';\n\nimport { useStrapiChat } from '../providers/ChatProvider';\n\nimport { FeedbackReasonIds, useFetchSendFeedback } from './useAIFetch';\nimport { useTranslations } from './useTranslations';\n\nexport const useFeedback = () => {\n const { fetch: sendFeedback, isPending, error } = useFetchSendFeedback();\n const { id, messages, schemas } = useStrapiChat();\n const { toggleNotification } = useNotification();\n const { trackUsage } = useTracking();\n const { t } = useTranslations();\n\n // Keep track of messages that have received feedback\n const [votedMessages, setVotedMessages] = useState<Record<string, 'upvote' | 'downvote'>>({});\n\n const hasVoted = (messageId: string) => {\n return !!votedMessages[messageId];\n };\n\n const upvoteMessage = (messageId: string) => {\n // Prevent spamming upvote\n if (hasVoted(messageId)) {\n return Promise.resolve();\n }\n\n trackUsage('didVoteAnswer', {\n value: 'positive',\n });\n\n toggleNotification({\n type: 'success',\n message: t('chat.feedback.submitted', 'Thank you for your feedback! '),\n });\n\n // Record this message as upvoted\n setVotedMessages((prev) => ({ ...prev, [messageId]: 'upvote' }));\n\n return sendFeedback({\n body: {\n type: 'upvote',\n chatId: id,\n messageId,\n messages,\n schemas,\n },\n });\n };\n\n const downvoteMessage = (messageId: string, feedback: string, reasons: FeedbackReasonIds[]) => {\n trackUsage('didVoteAnswer', {\n value: 'negative',\n });\n\n toggleNotification({\n type: 'success',\n message: t('chat.feedback.submitted', 'Thank you for your feedback! '),\n });\n\n return sendFeedback({\n body: {\n type: 'downvote',\n chatId: id,\n messageId,\n messages,\n feedback,\n reasons,\n schemas,\n },\n });\n };\n\n return { upvoteMessage, downvoteMessage, isPending, error };\n};\n"],"names":["useFeedback","fetch","sendFeedback","isPending","error","useFetchSendFeedback","id","messages","schemas","useStrapiChat","toggleNotification","useNotification","trackUsage","useTracking","t","useTranslations","votedMessages","setVotedMessages","useState","hasVoted","messageId","upvoteMessage","Promise","resolve","value","type","message","prev","body","chatId","downvoteMessage","feedback","reasons"],"mappings":";;;;;;;;MASaA,WAAc,GAAA,IAAA;IACzB,MAAM,EAAEC,OAAOC,YAAY,EAAEC,SAAS,EAAEC,KAAK,EAAE,GAAGC,+BAAAA,EAAAA;AAClD,IAAA,MAAM,EAAEC,EAAE,EAAEC,QAAQ,EAAEC,OAAO,EAAE,GAAGC,0BAAAA,EAAAA;IAClC,MAAM,EAAEC,kBAAkB,EAAE,GAAGC,2BAAAA,EAAAA;IAC/B,MAAM,EAAEC,UAAU,EAAE,GAAGC,uBAAAA,EAAAA;IACvB,MAAM,EAAEC,CAAC,EAAE,GAAGC,+BAAAA,EAAAA;;AAGd,IAAA,MAAM,CAACC,aAAAA,EAAeC,gBAAiB,CAAA,GAAGC,eAAgD,EAAC,CAAA;AAE3F,IAAA,MAAMC,WAAW,CAACC,SAAAA,GAAAA;AAChB,QAAA,OAAO,CAAC,CAACJ,aAAa,CAACI,SAAU,CAAA;AACnC,KAAA;AAEA,IAAA,MAAMC,gBAAgB,CAACD,SAAAA,GAAAA;;AAErB,QAAA,IAAID,SAASC,SAAY,CAAA,EAAA;AACvB,YAAA,OAAOE,QAAQC,OAAO,EAAA;AACxB;AAEAX,QAAAA,UAAAA,CAAW,eAAiB,EAAA;YAC1BY,KAAO,EAAA;AACT,SAAA,CAAA;QAEAd,kBAAmB,CAAA;YACjBe,IAAM,EAAA,SAAA;AACNC,YAAAA,OAAAA,EAASZ,EAAE,yBAA2B,EAAA,+BAAA;AACxC,SAAA,CAAA;;QAGAG,gBAAiB,CAAA,CAACU,QAAU;AAAE,gBAAA,GAAGA,IAAI;AAAE,gBAAA,CAACP,YAAY;aAAS,CAAA,CAAA;AAE7D,QAAA,OAAOlB,YAAa,CAAA;YAClB0B,IAAM,EAAA;gBACJH,IAAM,EAAA,QAAA;gBACNI,MAAQvB,EAAAA,EAAAA;AACRc,gBAAAA,SAAAA;AACAb,gBAAAA,QAAAA;AACAC,gBAAAA;AACF;AACF,SAAA,CAAA;AACF,KAAA;IAEA,MAAMsB,eAAAA,GAAkB,CAACV,SAAAA,EAAmBW,QAAkBC,EAAAA,OAAAA,GAAAA;AAC5DpB,QAAAA,UAAAA,CAAW,eAAiB,EAAA;YAC1BY,KAAO,EAAA;AACT,SAAA,CAAA;QAEAd,kBAAmB,CAAA;YACjBe,IAAM,EAAA,SAAA;AACNC,YAAAA,OAAAA,EAASZ,EAAE,yBAA2B,EAAA,+BAAA;AACxC,SAAA,CAAA;AAEA,QAAA,OAAOZ,YAAa,CAAA;YAClB0B,IAAM,EAAA;gBACJH,IAAM,EAAA,UAAA;gBACNI,MAAQvB,EAAAA,EAAAA;AACRc,gBAAAA,SAAAA;AACAb,gBAAAA,QAAAA;AACAwB,gBAAAA,QAAAA;AACAC,gBAAAA,OAAAA;AACAxB,gBAAAA;AACF;AACF,SAAA,CAAA;AACF,KAAA;IAEA,OAAO;AAAEa,QAAAA,aAAAA;AAAeS,QAAAA,eAAAA;AAAiB3B,QAAAA,SAAAA;AAAWC,QAAAA;AAAM,KAAA;AAC5D;;;;"}
@@ -0,0 +1,74 @@
1
+ import { useState } from 'react';
2
+ import { useNotification, useTracking } from '@strapi/admin/strapi-admin';
3
+ import { useStrapiChat } from '../providers/ChatProvider.mjs';
4
+ import { useFetchSendFeedback } from './useAIFetch.mjs';
5
+ import { useTranslations } from './useTranslations.mjs';
6
+
7
+ const useFeedback = ()=>{
8
+ const { fetch: sendFeedback, isPending, error } = useFetchSendFeedback();
9
+ const { id, messages, schemas } = useStrapiChat();
10
+ const { toggleNotification } = useNotification();
11
+ const { trackUsage } = useTracking();
12
+ const { t } = useTranslations();
13
+ // Keep track of messages that have received feedback
14
+ const [votedMessages, setVotedMessages] = useState({});
15
+ const hasVoted = (messageId)=>{
16
+ return !!votedMessages[messageId];
17
+ };
18
+ const upvoteMessage = (messageId)=>{
19
+ // Prevent spamming upvote
20
+ if (hasVoted(messageId)) {
21
+ return Promise.resolve();
22
+ }
23
+ trackUsage('didVoteAnswer', {
24
+ value: 'positive'
25
+ });
26
+ toggleNotification({
27
+ type: 'success',
28
+ message: t('chat.feedback.submitted', 'Thank you for your feedback! ')
29
+ });
30
+ // Record this message as upvoted
31
+ setVotedMessages((prev)=>({
32
+ ...prev,
33
+ [messageId]: 'upvote'
34
+ }));
35
+ return sendFeedback({
36
+ body: {
37
+ type: 'upvote',
38
+ chatId: id,
39
+ messageId,
40
+ messages,
41
+ schemas
42
+ }
43
+ });
44
+ };
45
+ const downvoteMessage = (messageId, feedback, reasons)=>{
46
+ trackUsage('didVoteAnswer', {
47
+ value: 'negative'
48
+ });
49
+ toggleNotification({
50
+ type: 'success',
51
+ message: t('chat.feedback.submitted', 'Thank you for your feedback! ')
52
+ });
53
+ return sendFeedback({
54
+ body: {
55
+ type: 'downvote',
56
+ chatId: id,
57
+ messageId,
58
+ messages,
59
+ feedback,
60
+ reasons,
61
+ schemas
62
+ }
63
+ });
64
+ };
65
+ return {
66
+ upvoteMessage,
67
+ downvoteMessage,
68
+ isPending,
69
+ error
70
+ };
71
+ };
72
+
73
+ export { useFeedback };
74
+ //# sourceMappingURL=useFeedback.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFeedback.mjs","sources":["../../../../../admin/src/components/AIChat/hooks/useFeedback.ts"],"sourcesContent":["import { useState } from 'react';\n\nimport { useNotification, useTracking } from '@strapi/admin/strapi-admin';\n\nimport { useStrapiChat } from '../providers/ChatProvider';\n\nimport { FeedbackReasonIds, useFetchSendFeedback } from './useAIFetch';\nimport { useTranslations } from './useTranslations';\n\nexport const useFeedback = () => {\n const { fetch: sendFeedback, isPending, error } = useFetchSendFeedback();\n const { id, messages, schemas } = useStrapiChat();\n const { toggleNotification } = useNotification();\n const { trackUsage } = useTracking();\n const { t } = useTranslations();\n\n // Keep track of messages that have received feedback\n const [votedMessages, setVotedMessages] = useState<Record<string, 'upvote' | 'downvote'>>({});\n\n const hasVoted = (messageId: string) => {\n return !!votedMessages[messageId];\n };\n\n const upvoteMessage = (messageId: string) => {\n // Prevent spamming upvote\n if (hasVoted(messageId)) {\n return Promise.resolve();\n }\n\n trackUsage('didVoteAnswer', {\n value: 'positive',\n });\n\n toggleNotification({\n type: 'success',\n message: t('chat.feedback.submitted', 'Thank you for your feedback! '),\n });\n\n // Record this message as upvoted\n setVotedMessages((prev) => ({ ...prev, [messageId]: 'upvote' }));\n\n return sendFeedback({\n body: {\n type: 'upvote',\n chatId: id,\n messageId,\n messages,\n schemas,\n },\n });\n };\n\n const downvoteMessage = (messageId: string, feedback: string, reasons: FeedbackReasonIds[]) => {\n trackUsage('didVoteAnswer', {\n value: 'negative',\n });\n\n toggleNotification({\n type: 'success',\n message: t('chat.feedback.submitted', 'Thank you for your feedback! '),\n });\n\n return sendFeedback({\n body: {\n type: 'downvote',\n chatId: id,\n messageId,\n messages,\n feedback,\n reasons,\n schemas,\n },\n });\n };\n\n return { upvoteMessage, downvoteMessage, isPending, error };\n};\n"],"names":["useFeedback","fetch","sendFeedback","isPending","error","useFetchSendFeedback","id","messages","schemas","useStrapiChat","toggleNotification","useNotification","trackUsage","useTracking","t","useTranslations","votedMessages","setVotedMessages","useState","hasVoted","messageId","upvoteMessage","Promise","resolve","value","type","message","prev","body","chatId","downvoteMessage","feedback","reasons"],"mappings":";;;;;;MASaA,WAAc,GAAA,IAAA;IACzB,MAAM,EAAEC,OAAOC,YAAY,EAAEC,SAAS,EAAEC,KAAK,EAAE,GAAGC,oBAAAA,EAAAA;AAClD,IAAA,MAAM,EAAEC,EAAE,EAAEC,QAAQ,EAAEC,OAAO,EAAE,GAAGC,aAAAA,EAAAA;IAClC,MAAM,EAAEC,kBAAkB,EAAE,GAAGC,eAAAA,EAAAA;IAC/B,MAAM,EAAEC,UAAU,EAAE,GAAGC,WAAAA,EAAAA;IACvB,MAAM,EAAEC,CAAC,EAAE,GAAGC,eAAAA,EAAAA;;AAGd,IAAA,MAAM,CAACC,aAAAA,EAAeC,gBAAiB,CAAA,GAAGC,SAAgD,EAAC,CAAA;AAE3F,IAAA,MAAMC,WAAW,CAACC,SAAAA,GAAAA;AAChB,QAAA,OAAO,CAAC,CAACJ,aAAa,CAACI,SAAU,CAAA;AACnC,KAAA;AAEA,IAAA,MAAMC,gBAAgB,CAACD,SAAAA,GAAAA;;AAErB,QAAA,IAAID,SAASC,SAAY,CAAA,EAAA;AACvB,YAAA,OAAOE,QAAQC,OAAO,EAAA;AACxB;AAEAX,QAAAA,UAAAA,CAAW,eAAiB,EAAA;YAC1BY,KAAO,EAAA;AACT,SAAA,CAAA;QAEAd,kBAAmB,CAAA;YACjBe,IAAM,EAAA,SAAA;AACNC,YAAAA,OAAAA,EAASZ,EAAE,yBAA2B,EAAA,+BAAA;AACxC,SAAA,CAAA;;QAGAG,gBAAiB,CAAA,CAACU,QAAU;AAAE,gBAAA,GAAGA,IAAI;AAAE,gBAAA,CAACP,YAAY;aAAS,CAAA,CAAA;AAE7D,QAAA,OAAOlB,YAAa,CAAA;YAClB0B,IAAM,EAAA;gBACJH,IAAM,EAAA,QAAA;gBACNI,MAAQvB,EAAAA,EAAAA;AACRc,gBAAAA,SAAAA;AACAb,gBAAAA,QAAAA;AACAC,gBAAAA;AACF;AACF,SAAA,CAAA;AACF,KAAA;IAEA,MAAMsB,eAAAA,GAAkB,CAACV,SAAAA,EAAmBW,QAAkBC,EAAAA,OAAAA,GAAAA;AAC5DpB,QAAAA,UAAAA,CAAW,eAAiB,EAAA;YAC1BY,KAAO,EAAA;AACT,SAAA,CAAA;QAEAd,kBAAmB,CAAA;YACjBe,IAAM,EAAA,SAAA;AACNC,YAAAA,OAAAA,EAASZ,EAAE,yBAA2B,EAAA,+BAAA;AACxC,SAAA,CAAA;AAEA,QAAA,OAAOZ,YAAa,CAAA;YAClB0B,IAAM,EAAA;gBACJH,IAAM,EAAA,UAAA;gBACNI,MAAQvB,EAAAA,EAAAA;AACRc,gBAAAA,SAAAA;AACAb,gBAAAA,QAAAA;AACAwB,gBAAAA,QAAAA;AACAC,gBAAAA,OAAAA;AACAxB,gBAAAA;AACF;AACF,SAAA,CAAA;AACF,KAAA;IAEA,OAAO;AAAEa,QAAAA,aAAAA;AAAeS,QAAAA,eAAAA;AAAiB3B,QAAAA,SAAAA;AAAWC,QAAAA;AAAM,KAAA;AAC5D;;;;"}
@@ -0,0 +1,206 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+
5
+ /**================================================================================
6
+ * Constants
7
+ *================================================================================*/ const FIGMA_TOKEN_STORAGE_KEY = 'strapi-ai-figma-token';
8
+ /**================================================================================
9
+ * Token Storage Utils
10
+ *================================================================================*/ /**
11
+ * Get Figma token from localStorage
12
+ */ const getFigmaToken = ()=>{
13
+ try {
14
+ return localStorage.getItem(FIGMA_TOKEN_STORAGE_KEY) || '';
15
+ } catch (error) {
16
+ console.error('Error accessing localStorage:', error);
17
+ return '';
18
+ }
19
+ };
20
+ /**
21
+ * Save Figma token to localStorage
22
+ */ const saveFigmaToken = (token)=>{
23
+ try {
24
+ localStorage.setItem(FIGMA_TOKEN_STORAGE_KEY, token);
25
+ } catch (error) {
26
+ console.error('Error saving to localStorage:', error);
27
+ }
28
+ };
29
+ /**
30
+ * Check if Figma token exists in localStorage
31
+ */ const hasFigmaToken = ()=>{
32
+ return !!getFigmaToken();
33
+ };
34
+ /**================================================================================
35
+ * Utils
36
+ *================================================================================*/ /**
37
+ * Extract file key and node ID from Figma URL
38
+ * @param figmaUrl - Figma URL (e.g., https://www.figma.com/file/KEY/Title)
39
+ */ const extractNodeFromFigmaUrl = (figmaUrl)=>{
40
+ const figmaUrlPattern = /figma\.com\/(?:file|design)\/([a-zA-Z0-9]+)\/.*[?&]node-id=([^&]+)/;
41
+ const match = figmaUrl.match(figmaUrlPattern);
42
+ if (!match) {
43
+ throw new Error('Invalid Figma URL');
44
+ }
45
+ const fileKey = match[1];
46
+ const nodeId = decodeURIComponent(match[2]).replace(/-/g, ':');
47
+ return {
48
+ fileKey,
49
+ nodeId
50
+ };
51
+ };
52
+ /**
53
+ * Get token and validate it's available
54
+ * @throws Error if token is not available
55
+ */ const getValidToken = ()=>{
56
+ const token = getFigmaToken();
57
+ if (!token) {
58
+ throw new Error('Figma API token is required');
59
+ }
60
+ return token;
61
+ };
62
+ /**
63
+ * Fetch Figma file data using the API
64
+ * @param fileKey - Figma file key
65
+ * @param nodeId - Figma node ID
66
+ */ const fetchFigmaNode = async (fileKey, nodeId)=>{
67
+ const token = getValidToken();
68
+ try {
69
+ const apiUrl = `https://api.figma.com/v1/files/${fileKey}/nodes?ids=${nodeId}`;
70
+ const response = await fetch(apiUrl, {
71
+ headers: {
72
+ 'X-Figma-Token': token
73
+ }
74
+ });
75
+ if (!response.ok) {
76
+ throw new Error(`Figma API error: ${response.status} ${response.statusText}`);
77
+ }
78
+ const nodes = await response.json();
79
+ return nodes.nodes[nodeId];
80
+ } catch (err) {
81
+ const errorMessage = err instanceof Error ? err.message : 'Failed to fetch Figma data';
82
+ throw new Error(errorMessage);
83
+ }
84
+ };
85
+ const findFramesInNode = (node)=>{
86
+ const frames = [];
87
+ if (node.type === 'FRAME') {
88
+ frames.push({
89
+ id: node.id,
90
+ name: node.name
91
+ });
92
+ return frames;
93
+ }
94
+ if (node.children && node.children.length > 0) {
95
+ for (const child of node.children){
96
+ // Continue searching in children if the current node is not a FRAME
97
+ frames.push(...findFramesInNode(child));
98
+ }
99
+ }
100
+ return frames;
101
+ };
102
+ /**
103
+ * Fetch images for specific nodes from the Figma API
104
+ * @param fileKey - Figma file key
105
+ * @param nodeIds - Array of node IDs to render
106
+ */ const fetchFigmaNodeImages = async (fileKey, nodeIds)=>{
107
+ const token = getValidToken();
108
+ if (nodeIds.length === 0) {
109
+ return {
110
+ images: {}
111
+ };
112
+ }
113
+ try {
114
+ // Max 50 node IDs per request according to Figma API docs
115
+ // We might need to chunk requests if nodeIds is very large
116
+ const idsQueryParam = nodeIds.slice(0, 50).join(',');
117
+ const apiUrl = `https://api.figma.com/v1/images/${fileKey}?ids=${idsQueryParam}&format=png&scale=0.4`;
118
+ const response = await fetch(apiUrl, {
119
+ headers: {
120
+ 'X-Figma-Token': token
121
+ }
122
+ });
123
+ if (!response.ok) {
124
+ const errorData = await response.text();
125
+ throw new Error(`Figma API image error: ${response.status} ${response.statusText} - ${errorData}`);
126
+ }
127
+ const result = await response.json();
128
+ if (result.err) {
129
+ throw new Error(`Figma API image error: ${result.err}`);
130
+ }
131
+ return result;
132
+ } catch (err) {
133
+ const errorMessage = err instanceof Error ? err.message : 'Failed to fetch Figma node images';
134
+ throw new Error(errorMessage);
135
+ }
136
+ };
137
+ /**================================================================================
138
+ * Hooks
139
+ *================================================================================*/ function useFigmaUpload({ onSuccess, onError } = {}) {
140
+ const [isLoading, setIsLoading] = React.useState(false);
141
+ const [error, setError] = React.useState(null);
142
+ /**
143
+ * Main method to process a Figma URL
144
+ * @param figmaUrl - Figma URL to process
145
+ */ const processFigmaUrl = async (figmaUrl)=>{
146
+ try {
147
+ // Check if token exists before proceeding
148
+ if (!hasFigmaToken()) {
149
+ const errorMessage = 'Figma API token is required';
150
+ setError(errorMessage);
151
+ onError?.(errorMessage);
152
+ throw new Error(errorMessage);
153
+ }
154
+ setIsLoading(true);
155
+ setError(null);
156
+ // 1. Extract file key from URL
157
+ const { fileKey, nodeId: selectedNode } = extractNodeFromFigmaUrl(figmaUrl);
158
+ // 2. Fetch base data from Figma API to get structure
159
+ const figmaData = await fetchFigmaNode(fileKey, selectedNode);
160
+ if (!figmaData.document) return;
161
+ // 3. Find frame nodes with their names
162
+ const frames = findFramesInNode(figmaData.document);
163
+ // Create a map of ID to name for later use
164
+ const frameNameMap = new Map(frames.map((frame)=>[
165
+ frame.id,
166
+ frame.name
167
+ ]));
168
+ // Get just the IDs for the API call
169
+ const frameIds = frames.map((frame)=>frame.id);
170
+ // 4. Fetch images for the identified nodes
171
+ const imageResponse = await fetchFigmaNodeImages(fileKey, frameIds);
172
+ const images = imageResponse.images;
173
+ // Use the name from our map instead of just the ID
174
+ const figmaImages = Object.entries(images).map(([id, url])=>({
175
+ id,
176
+ type: 'file',
177
+ filename: frameNameMap.get(id),
178
+ mediaType: 'image/png',
179
+ url,
180
+ status: 'ready'
181
+ }));
182
+ onSuccess?.(figmaImages);
183
+ return figmaImages;
184
+ } catch (err) {
185
+ const errorMessage = err instanceof Error ? err.message : 'Unknown error processing Figma URL';
186
+ setError(errorMessage);
187
+ onError?.(errorMessage);
188
+ console.error('Error processing Figma URL:', err);
189
+ throw err;
190
+ } finally{
191
+ setIsLoading(false);
192
+ }
193
+ };
194
+ return {
195
+ processFigmaUrl,
196
+ isLoading: isLoading,
197
+ error: error
198
+ };
199
+ }
200
+
201
+ exports.FIGMA_TOKEN_STORAGE_KEY = FIGMA_TOKEN_STORAGE_KEY;
202
+ exports.getFigmaToken = getFigmaToken;
203
+ exports.hasFigmaToken = hasFigmaToken;
204
+ exports.saveFigmaToken = saveFigmaToken;
205
+ exports.useFigmaUpload = useFigmaUpload;
206
+ //# sourceMappingURL=useFigmaUpload.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFigmaUpload.js","sources":["../../../../../admin/src/components/AIChat/hooks/useFigmaUpload.ts"],"sourcesContent":["import { useState } from 'react';\n\nimport type { Attachment } from '../lib/types/attachments';\n\n/**================================================================================\n * Constants\n *================================================================================*/\nexport const FIGMA_TOKEN_STORAGE_KEY = 'strapi-ai-figma-token';\n\n/**================================================================================\n * Types\n *================================================================================*/\nexport interface FigmaNodeData {\n id: string;\n name: string;\n type: string;\n children?: FigmaNodeData[];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any; // For other properties that Figma nodes may have\n}\n\nexport interface FigmaFileData {\n document: FigmaNodeData;\n schemaVersion: number;\n name: string;\n lastModified: string;\n thumbnailUrl: string;\n version: string;\n role: string;\n}\n\nexport interface FigmaImage extends Attachment {}\n\ninterface UseFigmaUploadOptions {\n onSuccess?: (attachments: FigmaImage[]) => void;\n onError?: (error: string) => void;\n}\n\n/**================================================================================\n * Token Storage Utils\n *================================================================================*/\n\n/**\n * Get Figma token from localStorage\n */\nexport const getFigmaToken = (): string => {\n try {\n return localStorage.getItem(FIGMA_TOKEN_STORAGE_KEY) || '';\n } catch (error) {\n console.error('Error accessing localStorage:', error);\n return '';\n }\n};\n\n/**\n * Save Figma token to localStorage\n */\nexport const saveFigmaToken = (token: string): void => {\n try {\n localStorage.setItem(FIGMA_TOKEN_STORAGE_KEY, token);\n } catch (error) {\n console.error('Error saving to localStorage:', error);\n }\n};\n\n/**\n * Check if Figma token exists in localStorage\n */\nexport const hasFigmaToken = (): boolean => {\n return !!getFigmaToken();\n};\n\n/**================================================================================\n * Utils\n *================================================================================*/\n\n/**\n * Extract file key and node ID from Figma URL\n * @param figmaUrl - Figma URL (e.g., https://www.figma.com/file/KEY/Title)\n */\nconst extractNodeFromFigmaUrl = (figmaUrl: string) => {\n const figmaUrlPattern = /figma\\.com\\/(?:file|design)\\/([a-zA-Z0-9]+)\\/.*[?&]node-id=([^&]+)/;\n const match = figmaUrl.match(figmaUrlPattern);\n\n if (!match) {\n throw new Error('Invalid Figma URL');\n }\n\n const fileKey = match[1];\n const nodeId = decodeURIComponent(match[2]).replace(/-/g, ':');\n\n return { fileKey, nodeId };\n};\n\n/**\n * Get token and validate it's available\n * @throws Error if token is not available\n */\nconst getValidToken = (): string => {\n const token = getFigmaToken();\n if (!token) {\n throw new Error('Figma API token is required');\n }\n return token;\n};\n\n/**\n * Fetch Figma file data using the API\n * @param fileKey - Figma file key\n * @param nodeId - Figma node ID\n */\nconst fetchFigmaNode = async (fileKey: string, nodeId: string): Promise<FigmaFileData> => {\n const token = getValidToken();\n\n try {\n const apiUrl = `https://api.figma.com/v1/files/${fileKey}/nodes?ids=${nodeId}`;\n\n const response = await fetch(apiUrl, {\n headers: {\n 'X-Figma-Token': token,\n },\n });\n\n if (!response.ok) {\n throw new Error(`Figma API error: ${response.status} ${response.statusText}`);\n }\n\n const nodes = await response.json();\n\n return nodes.nodes[nodeId];\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : 'Failed to fetch Figma data';\n throw new Error(errorMessage);\n }\n};\n\n/**\n * Recursively searches the node tree for FRAME nodes.\n * It stops searching within a branch once a FRAME is found.\n * @param node - The current FigmaNodeData to inspect.\n */\ninterface FrameInfo {\n id: string;\n name: string;\n}\n\nconst findFramesInNode = (node: FigmaNodeData): FrameInfo[] => {\n const frames: FrameInfo[] = [];\n if (node.type === 'FRAME') {\n frames.push({\n id: node.id,\n name: node.name,\n });\n return frames;\n }\n\n if (node.children && node.children.length > 0) {\n for (const child of node.children) {\n // Continue searching in children if the current node is not a FRAME\n frames.push(...findFramesInNode(child));\n }\n }\n\n return frames;\n};\n\n/**\n * Fetch images for specific nodes from the Figma API\n * @param fileKey - Figma file key\n * @param nodeIds - Array of node IDs to render\n */\nconst fetchFigmaNodeImages = async (\n fileKey: string,\n nodeIds: string[]\n): Promise<{ images: Record<string, string> }> => {\n const token = getValidToken();\n\n if (nodeIds.length === 0) {\n return { images: {} };\n }\n try {\n // Max 50 node IDs per request according to Figma API docs\n // We might need to chunk requests if nodeIds is very large\n const idsQueryParam = nodeIds.slice(0, 50).join(',');\n const apiUrl = `https://api.figma.com/v1/images/${fileKey}?ids=${idsQueryParam}&format=png&scale=0.4`;\n\n const response = await fetch(apiUrl, {\n headers: { 'X-Figma-Token': token },\n });\n\n if (!response.ok) {\n const errorData = await response.text();\n throw new Error(\n `Figma API image error: ${response.status} ${response.statusText} - ${errorData}`\n );\n }\n\n const result = await response.json();\n if (result.err) {\n throw new Error(`Figma API image error: ${result.err}`);\n }\n\n return result as { images: Record<string, string> };\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : 'Failed to fetch Figma node images';\n throw new Error(errorMessage);\n }\n};\n\n/**================================================================================\n * Hooks\n *================================================================================*/\nexport function useFigmaUpload({ onSuccess, onError }: UseFigmaUploadOptions = {}) {\n const [isLoading, setIsLoading] = useState(false);\n const [error, setError] = useState<string | null>(null);\n\n /**\n * Main method to process a Figma URL\n * @param figmaUrl - Figma URL to process\n */\n const processFigmaUrl = async (figmaUrl: string) => {\n try {\n // Check if token exists before proceeding\n if (!hasFigmaToken()) {\n const errorMessage = 'Figma API token is required';\n setError(errorMessage);\n onError?.(errorMessage);\n throw new Error(errorMessage);\n }\n\n setIsLoading(true);\n setError(null);\n\n // 1. Extract file key from URL\n const { fileKey, nodeId: selectedNode } = extractNodeFromFigmaUrl(figmaUrl);\n\n // 2. Fetch base data from Figma API to get structure\n const figmaData = await fetchFigmaNode(fileKey, selectedNode);\n if (!figmaData.document) return;\n\n // 3. Find frame nodes with their names\n const frames = findFramesInNode(figmaData.document);\n // Create a map of ID to name for later use\n const frameNameMap = new Map(frames.map((frame) => [frame.id, frame.name]));\n // Get just the IDs for the API call\n const frameIds = frames.map((frame) => frame.id);\n\n // 4. Fetch images for the identified nodes\n const imageResponse = await fetchFigmaNodeImages(fileKey, frameIds);\n const images = imageResponse.images;\n\n // Use the name from our map instead of just the ID\n const figmaImages = Object.entries(images).map(\n ([id, url]) =>\n ({\n id,\n type: 'file',\n filename: frameNameMap.get(id),\n mediaType: 'image/png',\n url,\n status: 'ready',\n }) satisfies FigmaImage\n );\n\n onSuccess?.(figmaImages);\n return figmaImages;\n } catch (err) {\n const errorMessage =\n err instanceof Error ? err.message : 'Unknown error processing Figma URL';\n setError(errorMessage);\n onError?.(errorMessage);\n console.error('Error processing Figma URL:', err);\n throw err;\n } finally {\n setIsLoading(false);\n }\n };\n\n return {\n processFigmaUrl,\n isLoading: isLoading,\n error: error,\n };\n}\n"],"names":["FIGMA_TOKEN_STORAGE_KEY","getFigmaToken","localStorage","getItem","error","console","saveFigmaToken","token","setItem","hasFigmaToken","extractNodeFromFigmaUrl","figmaUrl","figmaUrlPattern","match","Error","fileKey","nodeId","decodeURIComponent","replace","getValidToken","fetchFigmaNode","apiUrl","response","fetch","headers","ok","status","statusText","nodes","json","err","errorMessage","message","findFramesInNode","node","frames","type","push","id","name","children","length","child","fetchFigmaNodeImages","nodeIds","images","idsQueryParam","slice","join","errorData","text","result","useFigmaUpload","onSuccess","onError","isLoading","setIsLoading","useState","setError","processFigmaUrl","selectedNode","figmaData","document","frameNameMap","Map","map","frame","frameIds","imageResponse","figmaImages","Object","entries","url","filename","get","mediaType"],"mappings":"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"}