@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.
- package/dist/admin/components/AIChat/Chat.js +435 -0
- package/dist/admin/components/AIChat/Chat.js.map +1 -0
- package/dist/admin/components/AIChat/Chat.mjs +433 -0
- package/dist/admin/components/AIChat/Chat.mjs.map +1 -0
- package/dist/admin/components/AIChat/FeedbackModal.js +237 -0
- package/dist/admin/components/AIChat/FeedbackModal.js.map +1 -0
- package/dist/admin/components/AIChat/FeedbackModal.mjs +233 -0
- package/dist/admin/components/AIChat/FeedbackModal.mjs.map +1 -0
- package/dist/admin/components/AIChat/UploadCodeModal.js +427 -0
- package/dist/admin/components/AIChat/UploadCodeModal.js.map +1 -0
- package/dist/admin/components/AIChat/UploadCodeModal.mjs +423 -0
- package/dist/admin/components/AIChat/UploadCodeModal.mjs.map +1 -0
- package/dist/admin/components/AIChat/UploadFigmaModal.js +377 -0
- package/dist/admin/components/AIChat/UploadFigmaModal.js.map +1 -0
- package/dist/admin/components/AIChat/UploadFigmaModal.mjs +373 -0
- package/dist/admin/components/AIChat/UploadFigmaModal.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Alert.js +46 -0
- package/dist/admin/components/AIChat/components/Alert.js.map +1 -0
- package/dist/admin/components/AIChat/components/Alert.mjs +44 -0
- package/dist/admin/components/AIChat/components/Alert.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/AnimatedBox.js +34 -0
- package/dist/admin/components/AIChat/components/AnimatedBox.js.map +1 -0
- package/dist/admin/components/AIChat/components/AnimatedBox.mjs +32 -0
- package/dist/admin/components/AIChat/components/AnimatedBox.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Attachments/AttachmentPreview.js +92 -0
- package/dist/admin/components/AIChat/components/Attachments/AttachmentPreview.js.map +1 -0
- package/dist/admin/components/AIChat/components/Attachments/AttachmentPreview.mjs +90 -0
- package/dist/admin/components/AIChat/components/Attachments/AttachmentPreview.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Attachments/components/Attachment.js +100 -0
- package/dist/admin/components/AIChat/components/Attachments/components/Attachment.js.map +1 -0
- package/dist/admin/components/AIChat/components/Attachments/components/Attachment.mjs +97 -0
- package/dist/admin/components/AIChat/components/Attachments/components/Attachment.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Base64Image.js +127 -0
- package/dist/admin/components/AIChat/components/Base64Image.js.map +1 -0
- package/dist/admin/components/AIChat/components/Base64Image.mjs +125 -0
- package/dist/admin/components/AIChat/components/Base64Image.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Collapsible.js +71 -0
- package/dist/admin/components/AIChat/components/Collapsible.js.map +1 -0
- package/dist/admin/components/AIChat/components/Collapsible.mjs +66 -0
- package/dist/admin/components/AIChat/components/Collapsible.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Dropzone.js +172 -0
- package/dist/admin/components/AIChat/components/Dropzone.js.map +1 -0
- package/dist/admin/components/AIChat/components/Dropzone.mjs +167 -0
- package/dist/admin/components/AIChat/components/Dropzone.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/FloatingPanel.js +166 -0
- package/dist/admin/components/AIChat/components/FloatingPanel.js.map +1 -0
- package/dist/admin/components/AIChat/components/FloatingPanel.mjs +163 -0
- package/dist/admin/components/AIChat/components/FloatingPanel.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/FullScreenImage.js +190 -0
- package/dist/admin/components/AIChat/components/FullScreenImage.js.map +1 -0
- package/dist/admin/components/AIChat/components/FullScreenImage.mjs +187 -0
- package/dist/admin/components/AIChat/components/FullScreenImage.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/ImagePreview.js +87 -0
- package/dist/admin/components/AIChat/components/ImagePreview.js.map +1 -0
- package/dist/admin/components/AIChat/components/ImagePreview.mjs +85 -0
- package/dist/admin/components/AIChat/components/ImagePreview.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Input.js +126 -0
- package/dist/admin/components/AIChat/components/Input.js.map +1 -0
- package/dist/admin/components/AIChat/components/Input.mjs +121 -0
- package/dist/admin/components/AIChat/components/Input.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Messages/Marker.js +138 -0
- package/dist/admin/components/AIChat/components/Messages/Marker.js.map +1 -0
- package/dist/admin/components/AIChat/components/Messages/Marker.mjs +136 -0
- package/dist/admin/components/AIChat/components/Messages/Marker.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/Messages/Message.js +214 -0
- package/dist/admin/components/AIChat/components/Messages/Message.js.map +1 -0
- package/dist/admin/components/AIChat/components/Messages/Message.mjs +212 -0
- package/dist/admin/components/AIChat/components/Messages/Message.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/ResizableTextArea.js +78 -0
- package/dist/admin/components/AIChat/components/ResizableTextArea.js.map +1 -0
- package/dist/admin/components/AIChat/components/ResizableTextArea.mjs +76 -0
- package/dist/admin/components/AIChat/components/ResizableTextArea.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/SimpleMenu.js +60 -0
- package/dist/admin/components/AIChat/components/SimpleMenu.js.map +1 -0
- package/dist/admin/components/AIChat/components/SimpleMenu.mjs +35 -0
- package/dist/admin/components/AIChat/components/SimpleMenu.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/StepModal.js +175 -0
- package/dist/admin/components/AIChat/components/StepModal.js.map +1 -0
- package/dist/admin/components/AIChat/components/StepModal.mjs +171 -0
- package/dist/admin/components/AIChat/components/StepModal.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/animations.js +67 -0
- package/dist/admin/components/AIChat/components/animations.js.map +1 -0
- package/dist/admin/components/AIChat/components/animations.mjs +65 -0
- package/dist/admin/components/AIChat/components/animations.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/icons/FigmaIcon.js +50 -0
- package/dist/admin/components/AIChat/components/icons/FigmaIcon.js.map +1 -0
- package/dist/admin/components/AIChat/components/icons/FigmaIcon.mjs +48 -0
- package/dist/admin/components/AIChat/components/icons/FigmaIcon.mjs.map +1 -0
- package/dist/admin/components/AIChat/components/icons/StopIcon.js +25 -0
- package/dist/admin/components/AIChat/components/icons/StopIcon.js.map +1 -0
- package/dist/admin/components/AIChat/components/icons/StopIcon.mjs +23 -0
- package/dist/admin/components/AIChat/components/icons/StopIcon.mjs.map +1 -0
- package/dist/admin/components/AIChat/hooks/useAIFetch.js +107 -0
- package/dist/admin/components/AIChat/hooks/useAIFetch.js.map +1 -0
- package/dist/admin/components/AIChat/hooks/useAIFetch.mjs +96 -0
- package/dist/admin/components/AIChat/hooks/useAIFetch.mjs.map +1 -0
- package/dist/admin/components/AIChat/hooks/useAttachments.js +152 -0
- package/dist/admin/components/AIChat/hooks/useAttachments.js.map +1 -0
- package/dist/admin/components/AIChat/hooks/useAttachments.mjs +150 -0
- package/dist/admin/components/AIChat/hooks/useAttachments.mjs.map +1 -0
- package/dist/admin/components/AIChat/hooks/useChatTitle.js +47 -0
- package/dist/admin/components/AIChat/hooks/useChatTitle.js.map +1 -0
- package/dist/admin/components/AIChat/hooks/useChatTitle.mjs +45 -0
- package/dist/admin/components/AIChat/hooks/useChatTitle.mjs.map +1 -0
- package/dist/admin/components/AIChat/hooks/useCodeUpload.js +212 -0
- package/dist/admin/components/AIChat/hooks/useCodeUpload.js.map +1 -0
- package/dist/admin/components/AIChat/hooks/useCodeUpload.mjs +207 -0
- package/dist/admin/components/AIChat/hooks/useCodeUpload.mjs.map +1 -0
- package/dist/admin/components/AIChat/hooks/useFeedback.js +76 -0
- package/dist/admin/components/AIChat/hooks/useFeedback.js.map +1 -0
- package/dist/admin/components/AIChat/hooks/useFeedback.mjs +74 -0
- package/dist/admin/components/AIChat/hooks/useFeedback.mjs.map +1 -0
- package/dist/admin/components/AIChat/hooks/useFigmaUpload.js +206 -0
- package/dist/admin/components/AIChat/hooks/useFigmaUpload.js.map +1 -0
- package/dist/admin/components/AIChat/hooks/useFigmaUpload.mjs +200 -0
- package/dist/admin/components/AIChat/hooks/useFigmaUpload.mjs.map +1 -0
- package/dist/admin/components/AIChat/hooks/useLastSeenSchemas.js +115 -0
- package/dist/admin/components/AIChat/hooks/useLastSeenSchemas.js.map +1 -0
- package/dist/admin/components/AIChat/hooks/useLastSeenSchemas.mjs +113 -0
- package/dist/admin/components/AIChat/hooks/useLastSeenSchemas.mjs.map +1 -0
- package/dist/admin/components/AIChat/hooks/useTranslations.js +19 -0
- package/dist/admin/components/AIChat/hooks/useTranslations.js.map +1 -0
- package/dist/admin/components/AIChat/hooks/useTranslations.mjs +17 -0
- package/dist/admin/components/AIChat/hooks/useTranslations.mjs.map +1 -0
- package/dist/admin/components/AIChat/lib/aiClient.js +168 -0
- package/dist/admin/components/AIChat/lib/aiClient.js.map +1 -0
- package/dist/admin/components/AIChat/lib/aiClient.mjs +161 -0
- package/dist/admin/components/AIChat/lib/aiClient.mjs.map +1 -0
- package/dist/admin/components/AIChat/lib/constants.js +16 -0
- package/dist/admin/components/AIChat/lib/constants.js.map +1 -0
- package/dist/admin/components/AIChat/lib/constants.mjs +10 -0
- package/dist/admin/components/AIChat/lib/constants.mjs.map +1 -0
- package/dist/admin/components/AIChat/lib/misc.js +8 -0
- package/dist/admin/components/AIChat/lib/misc.js.map +1 -0
- package/dist/admin/components/AIChat/lib/misc.mjs +6 -0
- package/dist/admin/components/AIChat/lib/misc.mjs.map +1 -0
- package/dist/admin/components/AIChat/lib/transforms/schemas/fromCTB.js +46 -0
- package/dist/admin/components/AIChat/lib/transforms/schemas/fromCTB.js.map +1 -0
- package/dist/admin/components/AIChat/lib/transforms/schemas/fromCTB.mjs +44 -0
- package/dist/admin/components/AIChat/lib/transforms/schemas/fromCTB.mjs.map +1 -0
- package/dist/admin/components/AIChat/lib/transforms/schemas/toCTB.js +151 -0
- package/dist/admin/components/AIChat/lib/transforms/schemas/toCTB.js.map +1 -0
- package/dist/admin/components/AIChat/lib/transforms/schemas/toCTB.mjs +148 -0
- package/dist/admin/components/AIChat/lib/transforms/schemas/toCTB.mjs.map +1 -0
- package/dist/admin/components/AIChat/providers/ChatProvider.js +191 -0
- package/dist/admin/components/AIChat/providers/ChatProvider.js.map +1 -0
- package/dist/admin/components/AIChat/providers/ChatProvider.mjs +187 -0
- package/dist/admin/components/AIChat/providers/ChatProvider.mjs.map +1 -0
- package/dist/admin/components/AIChat/providers/SchemaProvider.js +90 -0
- package/dist/admin/components/AIChat/providers/SchemaProvider.js.map +1 -0
- package/dist/admin/components/AIChat/providers/SchemaProvider.mjs +88 -0
- package/dist/admin/components/AIChat/providers/SchemaProvider.mjs.map +1 -0
- package/dist/admin/components/ComponentList.js +1 -0
- package/dist/admin/components/ComponentList.js.map +1 -1
- package/dist/admin/components/ComponentList.mjs +1 -0
- package/dist/admin/components/ComponentList.mjs.map +1 -1
- package/dist/admin/components/ContentTypeBuilderNav/ContentTypeBuilderNav.js +165 -161
- package/dist/admin/components/ContentTypeBuilderNav/ContentTypeBuilderNav.js.map +1 -1
- package/dist/admin/components/ContentTypeBuilderNav/ContentTypeBuilderNav.mjs +165 -161
- package/dist/admin/components/ContentTypeBuilderNav/ContentTypeBuilderNav.mjs.map +1 -1
- package/dist/admin/components/DataManager/DataManagerContext.js.map +1 -1
- package/dist/admin/components/DataManager/DataManagerContext.mjs.map +1 -1
- package/dist/admin/components/DataManager/reducer.js +48 -6
- package/dist/admin/components/DataManager/reducer.js.map +1 -1
- package/dist/admin/components/DataManager/reducer.mjs +48 -6
- package/dist/admin/components/DataManager/reducer.mjs.map +1 -1
- package/dist/admin/components/FormModal/utils/canEditContentType.js.map +1 -1
- package/dist/admin/components/FormModal/utils/canEditContentType.mjs.map +1 -1
- package/dist/admin/pages/App/index.js +60 -29
- package/dist/admin/pages/App/index.js.map +1 -1
- package/dist/admin/pages/App/index.mjs +62 -31
- package/dist/admin/pages/App/index.mjs.map +1 -1
- package/dist/admin/pages/ListView/EmptyState.js +75 -9
- package/dist/admin/pages/ListView/EmptyState.js.map +1 -1
- package/dist/admin/pages/ListView/EmptyState.mjs +77 -11
- package/dist/admin/pages/ListView/EmptyState.mjs.map +1 -1
- package/dist/admin/src/components/AIChat/Chat.d.ts +2 -0
- package/dist/admin/src/components/AIChat/FeedbackModal.d.ts +13 -0
- package/dist/admin/src/components/AIChat/UploadCodeModal.d.ts +12 -0
- package/dist/admin/src/components/AIChat/UploadFigmaModal.d.ts +12 -0
- package/dist/admin/src/components/AIChat/components/Alert.d.ts +6 -0
- package/dist/admin/src/components/AIChat/components/AnimatedBox.d.ts +13 -0
- package/dist/admin/src/components/AIChat/components/Attachments/AttachmentPreview.d.ts +9 -0
- package/dist/admin/src/components/AIChat/components/Attachments/components/Attachment.d.ts +27 -0
- package/dist/admin/src/components/AIChat/components/Base64Image.d.ts +9 -0
- package/dist/admin/src/components/AIChat/components/Collapsible.d.ts +18 -0
- package/dist/admin/src/components/AIChat/components/Dropzone.d.ts +35 -0
- package/dist/admin/src/components/AIChat/components/FloatingPanel.d.ts +34 -0
- package/dist/admin/src/components/AIChat/components/FullScreenImage.d.ts +20 -0
- package/dist/admin/src/components/AIChat/components/ImagePreview.d.ts +8 -0
- package/dist/admin/src/components/AIChat/components/ImagePreviewGroup.d.ts +7 -0
- package/dist/admin/src/components/AIChat/components/Input.d.ts +43 -0
- package/dist/admin/src/components/AIChat/components/Messages/Marker.d.ts +2 -0
- package/dist/admin/src/components/AIChat/components/Messages/Message.d.ts +5 -0
- package/dist/admin/src/components/AIChat/components/ResizableTextArea.d.ts +9 -0
- package/dist/admin/src/components/AIChat/components/SimpleMenu.d.ts +32 -0
- package/dist/admin/src/components/AIChat/components/StepModal.d.ts +37 -0
- package/dist/admin/src/components/AIChat/components/animations.d.ts +8 -0
- package/dist/admin/src/components/AIChat/components/icons/FigmaIcon.d.ts +5 -0
- package/dist/admin/src/components/AIChat/components/icons/StopIcon.d.ts +5 -0
- package/dist/admin/src/components/AIChat/hooks/useAIFetch.d.ts +147 -0
- package/dist/admin/src/components/AIChat/hooks/useAttachments.d.ts +8 -0
- package/dist/admin/src/components/AIChat/hooks/useChatTitle.d.ts +13 -0
- package/dist/admin/src/components/AIChat/hooks/useCodeUpload.d.ts +31 -0
- package/dist/admin/src/components/AIChat/hooks/useFeedback.d.ts +7 -0
- package/dist/admin/src/components/AIChat/hooks/useFigmaUpload.d.ts +61 -0
- package/dist/admin/src/components/AIChat/hooks/useLastSeenSchemas.d.ts +10 -0
- package/dist/admin/src/components/AIChat/hooks/useTranslations.d.ts +3 -0
- package/dist/admin/src/components/AIChat/lib/aiClient.d.ts +32 -0
- package/dist/admin/src/components/AIChat/lib/constants.d.ts +12 -0
- package/dist/admin/src/components/AIChat/lib/fileToAttachment.d.ts +2 -0
- package/dist/admin/src/components/AIChat/lib/misc.d.ts +1 -0
- package/dist/admin/src/components/AIChat/lib/transforms/schemas/fromCTB.d.ts +3 -0
- package/dist/admin/src/components/AIChat/lib/transforms/schemas/toCTB.d.ts +16 -0
- package/dist/admin/src/components/AIChat/lib/types/annotations.d.ts +19 -0
- package/dist/admin/src/components/AIChat/lib/types/attachments.d.ts +15 -0
- package/dist/admin/src/components/AIChat/lib/types/feedback.d.ts +1 -0
- package/dist/admin/src/components/AIChat/lib/types/messages.d.ts +26 -0
- package/dist/admin/src/components/AIChat/lib/types/schema.d.ts +20 -0
- package/dist/admin/src/components/AIChat/providers/ChatProvider.d.ts +30 -0
- package/dist/admin/src/components/AIChat/providers/SchemaProvider.d.ts +10 -0
- package/dist/admin/src/components/ComponentList.d.ts +1 -1
- package/dist/admin/src/components/DataManager/DataManagerContext.d.ts +1 -1
- package/dist/admin/translations/ar.json.js +187 -2
- package/dist/admin/translations/ar.json.js.map +1 -1
- package/dist/admin/translations/ar.json.mjs +187 -3
- package/dist/admin/translations/ar.json.mjs.map +1 -1
- package/dist/admin/translations/de.json.js +42 -7
- package/dist/admin/translations/de.json.js.map +1 -1
- package/dist/admin/translations/de.json.mjs +42 -7
- package/dist/admin/translations/de.json.mjs.map +1 -1
- package/dist/admin/translations/en.json.js +53 -2
- package/dist/admin/translations/en.json.js.map +1 -1
- package/dist/admin/translations/en.json.mjs +53 -2
- package/dist/admin/translations/en.json.mjs.map +1 -1
- package/dist/admin/translations/es.json.js +37 -15
- package/dist/admin/translations/es.json.js.map +1 -1
- package/dist/admin/translations/es.json.mjs +37 -15
- package/dist/admin/translations/es.json.mjs.map +1 -1
- package/dist/admin/translations/fr.json.js +165 -3
- package/dist/admin/translations/fr.json.js.map +1 -1
- package/dist/admin/translations/fr.json.mjs +165 -4
- package/dist/admin/translations/fr.json.mjs.map +1 -1
- package/dist/admin/translations/id.json.js +93 -23
- package/dist/admin/translations/id.json.js.map +1 -1
- package/dist/admin/translations/id.json.mjs +93 -23
- package/dist/admin/translations/id.json.mjs.map +1 -1
- package/dist/admin/translations/it.json.js +75 -6
- package/dist/admin/translations/it.json.js.map +1 -1
- package/dist/admin/translations/it.json.mjs +75 -6
- package/dist/admin/translations/it.json.mjs.map +1 -1
- package/dist/admin/translations/ja.json.js +191 -5
- package/dist/admin/translations/ja.json.js.map +1 -1
- package/dist/admin/translations/ja.json.mjs +191 -6
- package/dist/admin/translations/ja.json.mjs.map +1 -1
- package/dist/admin/translations/ko.json.js +70 -16
- package/dist/admin/translations/ko.json.js.map +1 -1
- package/dist/admin/translations/ko.json.mjs +70 -16
- package/dist/admin/translations/ko.json.mjs.map +1 -1
- package/dist/admin/translations/ms.json.js +104 -31
- package/dist/admin/translations/ms.json.js.map +1 -1
- package/dist/admin/translations/ms.json.mjs +104 -31
- package/dist/admin/translations/ms.json.mjs.map +1 -1
- package/dist/admin/translations/nl.json.js +95 -15
- package/dist/admin/translations/nl.json.js.map +1 -1
- package/dist/admin/translations/nl.json.mjs +95 -15
- package/dist/admin/translations/nl.json.mjs.map +1 -1
- package/dist/admin/translations/pl.json.js +55 -11
- package/dist/admin/translations/pl.json.js.map +1 -1
- package/dist/admin/translations/pl.json.mjs +55 -11
- package/dist/admin/translations/pl.json.mjs.map +1 -1
- package/dist/admin/translations/pt-BR.json.js +54 -10
- package/dist/admin/translations/pt-BR.json.js.map +1 -1
- package/dist/admin/translations/pt-BR.json.mjs +54 -10
- package/dist/admin/translations/pt-BR.json.mjs.map +1 -1
- package/dist/admin/translations/pt.json.js +187 -2
- package/dist/admin/translations/pt.json.js.map +1 -1
- package/dist/admin/translations/pt.json.mjs +187 -3
- package/dist/admin/translations/pt.json.mjs.map +1 -1
- package/dist/admin/translations/ru.json.js +26 -1
- package/dist/admin/translations/ru.json.js.map +1 -1
- package/dist/admin/translations/ru.json.mjs +26 -1
- package/dist/admin/translations/ru.json.mjs.map +1 -1
- package/dist/admin/translations/sk.json.js +21 -1
- package/dist/admin/translations/sk.json.js.map +1 -1
- package/dist/admin/translations/sk.json.mjs +21 -1
- package/dist/admin/translations/sk.json.mjs.map +1 -1
- package/dist/admin/translations/sv.json.js +21 -1
- package/dist/admin/translations/sv.json.js.map +1 -1
- package/dist/admin/translations/sv.json.mjs +21 -1
- package/dist/admin/translations/sv.json.mjs.map +1 -1
- package/dist/admin/translations/th.json.js +21 -1
- package/dist/admin/translations/th.json.js.map +1 -1
- package/dist/admin/translations/th.json.mjs +21 -1
- package/dist/admin/translations/th.json.mjs.map +1 -1
- package/dist/admin/translations/tr.json.js +21 -1
- package/dist/admin/translations/tr.json.js.map +1 -1
- package/dist/admin/translations/tr.json.mjs +21 -1
- package/dist/admin/translations/tr.json.mjs.map +1 -1
- package/dist/admin/translations/uk.json.js +21 -2
- package/dist/admin/translations/uk.json.js.map +1 -1
- package/dist/admin/translations/uk.json.mjs +21 -2
- package/dist/admin/translations/uk.json.mjs.map +1 -1
- package/dist/admin/translations/zh-Hans.json.js +222 -133
- package/dist/admin/translations/zh-Hans.json.js.map +1 -1
- package/dist/admin/translations/zh-Hans.json.mjs +222 -133
- package/dist/admin/translations/zh-Hans.json.mjs.map +1 -1
- package/dist/admin/translations/zh.json.js +21 -1
- package/dist/admin/translations/zh.json.js.map +1 -1
- package/dist/admin/translations/zh.json.mjs +21 -1
- package/dist/admin/translations/zh.json.mjs.map +1 -1
- package/dist/server/index.js +2 -0
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +2 -0
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/register.js +98 -0
- package/dist/server/register.js.map +1 -0
- package/dist/server/register.mjs +96 -0
- package/dist/server/register.mjs.map +1 -0
- package/dist/server/src/controllers/ai/auth.d.ts +1 -0
- package/dist/server/src/controllers/ai/auth.d.ts.map +1 -0
- package/dist/server/src/controllers/ai/index.d.ts +1 -0
- package/dist/server/src/controllers/ai/index.d.ts.map +1 -0
- package/dist/server/src/index.d.ts +1 -0
- package/dist/server/src/index.d.ts.map +1 -1
- package/dist/server/src/register.d.ts +11 -0
- package/dist/server/src/register.d.ts.map +1 -0
- package/package.json +12 -5
- package/dist/admin/components/DataManager/utils/formatSchemas.js +0 -21
- package/dist/admin/components/DataManager/utils/formatSchemas.js.map +0 -1
- package/dist/admin/components/DataManager/utils/formatSchemas.mjs +0 -18
- 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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"}
|