@copilotkit/react-textarea 1.51.4 → 1.51.5-next.1
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/.attw.json +3 -0
- package/CHANGELOG.md +18 -0
- package/dist/index.cjs +1918 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.css +10 -639
- package/dist/index.css.map +1 -1
- package/dist/index.d.cts +318 -0
- package/dist/index.d.cts.map +1 -0
- package/dist/index.d.mts +318 -0
- package/dist/index.d.mts.map +1 -0
- package/dist/index.mjs +1879 -61
- package/dist/index.mjs.map +1 -1
- package/dist/index.umd.js +1900 -123
- package/dist/index.umd.js.map +1 -1
- package/package.json +18 -16
- package/src/components/copilot-textarea/copilot-textarea.tsx +1 -1
- package/tsdown.config.ts +60 -0
- package/vitest.config.mjs +11 -0
- package/dist/chunk-2C7O2EVM.mjs +0 -27
- package/dist/chunk-2C7O2EVM.mjs.map +0 -1
- package/dist/chunk-2X3CZVEP.mjs +0 -32
- package/dist/chunk-2X3CZVEP.mjs.map +0 -1
- package/dist/chunk-3WLGLZTY.mjs +0 -232
- package/dist/chunk-3WLGLZTY.mjs.map +0 -1
- package/dist/chunk-5UNJXFUO.mjs +0 -29
- package/dist/chunk-5UNJXFUO.mjs.map +0 -1
- package/dist/chunk-7GZWOXE4.mjs +0 -70
- package/dist/chunk-7GZWOXE4.mjs.map +0 -1
- package/dist/chunk-7V4ORVQX.mjs +0 -17
- package/dist/chunk-7V4ORVQX.mjs.map +0 -1
- package/dist/chunk-A6YGJFQI.mjs +0 -111
- package/dist/chunk-A6YGJFQI.mjs.map +0 -1
- package/dist/chunk-AHNPJMBR.mjs +0 -90
- package/dist/chunk-AHNPJMBR.mjs.map +0 -1
- package/dist/chunk-ARLBRSB7.mjs +0 -140
- package/dist/chunk-ARLBRSB7.mjs.map +0 -1
- package/dist/chunk-AZ7RF6ED.mjs +0 -120
- package/dist/chunk-AZ7RF6ED.mjs.map +0 -1
- package/dist/chunk-CFCMZVQ2.mjs +0 -136
- package/dist/chunk-CFCMZVQ2.mjs.map +0 -1
- package/dist/chunk-CMKGYQFX.mjs +0 -45
- package/dist/chunk-CMKGYQFX.mjs.map +0 -1
- package/dist/chunk-DE5K76I2.mjs +0 -1
- package/dist/chunk-DE5K76I2.mjs.map +0 -1
- package/dist/chunk-DZMQBOPG.mjs +0 -36
- package/dist/chunk-DZMQBOPG.mjs.map +0 -1
- package/dist/chunk-E7C63KQP.mjs +0 -64
- package/dist/chunk-E7C63KQP.mjs.map +0 -1
- package/dist/chunk-EGBZSVLK.mjs +0 -25
- package/dist/chunk-EGBZSVLK.mjs.map +0 -1
- package/dist/chunk-FTG7P3NP.mjs +0 -25
- package/dist/chunk-FTG7P3NP.mjs.map +0 -1
- package/dist/chunk-H4VKQGVU.mjs +0 -1
- package/dist/chunk-H4VKQGVU.mjs.map +0 -1
- package/dist/chunk-IBZTDP72.mjs +0 -56
- package/dist/chunk-IBZTDP72.mjs.map +0 -1
- package/dist/chunk-IU3WTXLQ.mjs +0 -1
- package/dist/chunk-IU3WTXLQ.mjs.map +0 -1
- package/dist/chunk-KNQIEOFP.mjs +0 -19
- package/dist/chunk-KNQIEOFP.mjs.map +0 -1
- package/dist/chunk-L7VVZH4Q.mjs +0 -1
- package/dist/chunk-L7VVZH4Q.mjs.map +0 -1
- package/dist/chunk-LYNGBKJR.mjs +0 -58
- package/dist/chunk-LYNGBKJR.mjs.map +0 -1
- package/dist/chunk-M7GTVHFB.mjs +0 -188
- package/dist/chunk-M7GTVHFB.mjs.map +0 -1
- package/dist/chunk-MCNXIA4Q.mjs +0 -75
- package/dist/chunk-MCNXIA4Q.mjs.map +0 -1
- package/dist/chunk-MMVDU6DF.mjs +0 -1
- package/dist/chunk-MMVDU6DF.mjs.map +0 -1
- package/dist/chunk-MQBPYOOZ.mjs +0 -97
- package/dist/chunk-MQBPYOOZ.mjs.map +0 -1
- package/dist/chunk-MQXYWOE2.mjs +0 -32
- package/dist/chunk-MQXYWOE2.mjs.map +0 -1
- package/dist/chunk-MRXNTQOX.mjs +0 -59
- package/dist/chunk-MRXNTQOX.mjs.map +0 -1
- package/dist/chunk-NFMCLTJU.mjs +0 -39
- package/dist/chunk-NFMCLTJU.mjs.map +0 -1
- package/dist/chunk-O4WCM57A.mjs +0 -30
- package/dist/chunk-O4WCM57A.mjs.map +0 -1
- package/dist/chunk-PDFIUPCS.mjs +0 -108
- package/dist/chunk-PDFIUPCS.mjs.map +0 -1
- package/dist/chunk-QFXR6DOA.mjs +0 -64
- package/dist/chunk-QFXR6DOA.mjs.map +0 -1
- package/dist/chunk-RUV6NBIF.mjs +0 -1
- package/dist/chunk-RUV6NBIF.mjs.map +0 -1
- package/dist/chunk-SWX3MRZ4.mjs +0 -278
- package/dist/chunk-SWX3MRZ4.mjs.map +0 -1
- package/dist/chunk-TGN3YVSO.mjs +0 -85
- package/dist/chunk-TGN3YVSO.mjs.map +0 -1
- package/dist/chunk-UB4Y22EF.mjs +0 -21
- package/dist/chunk-UB4Y22EF.mjs.map +0 -1
- package/dist/chunk-UIBUYQPG.mjs +0 -79
- package/dist/chunk-UIBUYQPG.mjs.map +0 -1
- package/dist/chunk-VBPZTMXB.mjs +0 -13
- package/dist/chunk-VBPZTMXB.mjs.map +0 -1
- package/dist/chunk-VH7INUR5.mjs +0 -82
- package/dist/chunk-VH7INUR5.mjs.map +0 -1
- package/dist/chunk-VVRGAA43.mjs +0 -59
- package/dist/chunk-VVRGAA43.mjs.map +0 -1
- package/dist/chunk-VYLLLBUP.mjs +0 -50
- package/dist/chunk-VYLLLBUP.mjs.map +0 -1
- package/dist/chunk-WADHCMPK.mjs +0 -1
- package/dist/chunk-WADHCMPK.mjs.map +0 -1
- package/dist/chunk-WJHSY5T6.mjs +0 -1
- package/dist/chunk-WJHSY5T6.mjs.map +0 -1
- package/dist/chunk-WXKPRNNO.mjs +0 -32
- package/dist/chunk-WXKPRNNO.mjs.map +0 -1
- package/dist/chunk-YINY56BI.mjs +0 -49
- package/dist/chunk-YINY56BI.mjs.map +0 -1
- package/dist/chunk-ZBP4SABT.mjs +0 -117
- package/dist/chunk-ZBP4SABT.mjs.map +0 -1
- package/dist/chunk-ZWI5KPQ5.mjs +0 -31
- package/dist/chunk-ZWI5KPQ5.mjs.map +0 -1
- package/dist/components/base-copilot-textarea/base-copilot-textarea.css +0 -9
- package/dist/components/base-copilot-textarea/base-copilot-textarea.css.map +0 -1
- package/dist/components/base-copilot-textarea/base-copilot-textarea.d.ts +0 -43
- package/dist/components/base-copilot-textarea/base-copilot-textarea.js +0 -1849
- package/dist/components/base-copilot-textarea/base-copilot-textarea.js.map +0 -1
- package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs +0 -40
- package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs.map +0 -1
- package/dist/components/base-copilot-textarea/render-element.d.ts +0 -7
- package/dist/components/base-copilot-textarea/render-element.js +0 -75
- package/dist/components/base-copilot-textarea/render-element.js.map +0 -1
- package/dist/components/base-copilot-textarea/render-element.mjs +0 -8
- package/dist/components/base-copilot-textarea/render-element.mjs.map +0 -1
- package/dist/components/base-copilot-textarea/render-placeholder.d.ts +0 -7
- package/dist/components/base-copilot-textarea/render-placeholder.js +0 -72
- package/dist/components/base-copilot-textarea/render-placeholder.js.map +0 -1
- package/dist/components/base-copilot-textarea/render-placeholder.mjs +0 -8
- package/dist/components/base-copilot-textarea/render-placeholder.mjs.map +0 -1
- package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.d.ts +0 -8
- package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.js +0 -112
- package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.js.map +0 -1
- package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs +0 -9
- package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs.map +0 -1
- package/dist/components/base-copilot-textarea/use-add-branding-css.d.ts +0 -3
- package/dist/components/base-copilot-textarea/use-add-branding-css.js +0 -83
- package/dist/components/base-copilot-textarea/use-add-branding-css.js.map +0 -1
- package/dist/components/base-copilot-textarea/use-add-branding-css.mjs +0 -8
- package/dist/components/base-copilot-textarea/use-add-branding-css.mjs.map +0 -1
- package/dist/components/copilot-textarea/copilot-textarea.css +0 -9
- package/dist/components/copilot-textarea/copilot-textarea.css.map +0 -1
- package/dist/components/copilot-textarea/copilot-textarea.d.ts +0 -171
- package/dist/components/copilot-textarea/copilot-textarea.js +0 -2356
- package/dist/components/copilot-textarea/copilot-textarea.js.map +0 -1
- package/dist/components/copilot-textarea/copilot-textarea.mjs +0 -49
- package/dist/components/copilot-textarea/copilot-textarea.mjs.map +0 -1
- package/dist/components/hovering-toolbar/hovering-editor-provider.d.ts +0 -18
- package/dist/components/hovering-toolbar/hovering-editor-provider.js +0 -46
- package/dist/components/hovering-toolbar/hovering-editor-provider.js.map +0 -1
- package/dist/components/hovering-toolbar/hovering-editor-provider.mjs +0 -10
- package/dist/components/hovering-toolbar/hovering-editor-provider.mjs.map +0 -1
- package/dist/components/hovering-toolbar/hovering-toolbar-components.d.ts +0 -18
- package/dist/components/hovering-toolbar/hovering-toolbar-components.js +0 -158
- package/dist/components/hovering-toolbar/hovering-toolbar-components.js.map +0 -1
- package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs +0 -16
- package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs.map +0 -1
- package/dist/components/hovering-toolbar/hovering-toolbar.d.ts +0 -12
- package/dist/components/hovering-toolbar/hovering-toolbar.js +0 -934
- package/dist/components/hovering-toolbar/hovering-toolbar.js.map +0 -1
- package/dist/components/hovering-toolbar/hovering-toolbar.mjs +0 -23
- package/dist/components/hovering-toolbar/hovering-toolbar.mjs.map +0 -1
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.d.ts +0 -16
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.js +0 -649
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.js.map +0 -1
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs +0 -18
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs.map +0 -1
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.d.ts +0 -13
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.js +0 -672
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.js.map +0 -1
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs +0 -19
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs.map +0 -1
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.d.ts +0 -16
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.js +0 -144
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.js.map +0 -1
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.mjs +0 -12
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.mjs.map +0 -1
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.d.ts +0 -4
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.js +0 -672
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.js.map +0 -1
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs +0 -20
- package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs.map +0 -1
- package/dist/components/index.css +0 -9
- package/dist/components/index.css.map +0 -1
- package/dist/components/index.d.ts +0 -15
- package/dist/components/index.js +0 -2360
- package/dist/components/index.js.map +0 -1
- package/dist/components/index.mjs +0 -53
- package/dist/components/index.mjs.map +0 -1
- package/dist/components/manual-ui/chip-with-icon.d.ts +0 -10
- package/dist/components/manual-ui/chip-with-icon.js +0 -49
- package/dist/components/manual-ui/chip-with-icon.js.map +0 -1
- package/dist/components/manual-ui/chip-with-icon.mjs +0 -26
- package/dist/components/manual-ui/chip-with-icon.mjs.map +0 -1
- package/dist/components/source-search-box/source-search-box.d.ts +0 -16
- package/dist/components/source-search-box/source-search-box.js +0 -263
- package/dist/components/source-search-box/source-search-box.js.map +0 -1
- package/dist/components/source-search-box/source-search-box.mjs +0 -13
- package/dist/components/source-search-box/source-search-box.mjs.map +0 -1
- package/dist/components/ui/button.d.ts +0 -14
- package/dist/components/ui/button.js +0 -120
- package/dist/components/ui/button.js.map +0 -1
- package/dist/components/ui/button.mjs +0 -11
- package/dist/components/ui/button.mjs.map +0 -1
- package/dist/components/ui/command.d.ts +0 -53
- package/dist/components/ui/command.js +0 -323
- package/dist/components/ui/command.js.map +0 -1
- package/dist/components/ui/command.mjs +0 -26
- package/dist/components/ui/command.mjs.map +0 -1
- package/dist/components/ui/dialog.d.ts +0 -19
- package/dist/components/ui/dialog.js +0 -205
- package/dist/components/ui/dialog.js.map +0 -1
- package/dist/components/ui/dialog.mjs +0 -21
- package/dist/components/ui/dialog.mjs.map +0 -1
- package/dist/components/ui/label.d.ts +0 -8
- package/dist/components/ui/label.js +0 -93
- package/dist/components/ui/label.js.map +0 -1
- package/dist/components/ui/label.mjs +0 -9
- package/dist/components/ui/label.mjs.map +0 -1
- package/dist/context/index.d.ts +0 -2
- package/dist/context/index.js +0 -19
- package/dist/context/index.js.map +0 -1
- package/dist/context/index.mjs +0 -2
- package/dist/context/index.mjs.map +0 -1
- package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.d.ts +0 -15
- package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.js +0 -194
- package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.js.map +0 -1
- package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs +0 -11
- package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs.map +0 -1
- package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.d.ts +0 -8
- package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.js +0 -194
- package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.js.map +0 -1
- package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs +0 -9
- package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs.map +0 -1
- package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.d.ts +0 -7
- package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.js +0 -180
- package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.js.map +0 -1
- package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs +0 -10
- package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs.map +0 -1
- package/dist/hooks/index.d.ts +0 -2
- package/dist/hooks/index.js +0 -19
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/index.mjs +0 -2
- package/dist/hooks/index.mjs.map +0 -1
- package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.d.ts +0 -22
- package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.js +0 -142
- package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.js.map +0 -1
- package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs +0 -9
- package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs.map +0 -1
- package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.d.ts +0 -23
- package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.js +0 -248
- package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.js.map +0 -1
- package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs +0 -9
- package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs.map +0 -1
- package/dist/hooks/misc/use-autosize-textarea.d.ts +0 -5
- package/dist/hooks/misc/use-autosize-textarea.js +0 -37
- package/dist/hooks/misc/use-autosize-textarea.js.map +0 -1
- package/dist/hooks/misc/use-autosize-textarea.mjs +0 -8
- package/dist/hooks/misc/use-autosize-textarea.mjs.map +0 -1
- package/dist/index.d.ts +0 -15
- package/dist/index.js +0 -2365
- package/dist/index.js.map +0 -1
- package/dist/lib/debouncer.d.ts +0 -11
- package/dist/lib/debouncer.js +0 -76
- package/dist/lib/debouncer.js.map +0 -1
- package/dist/lib/debouncer.mjs +0 -8
- package/dist/lib/debouncer.mjs.map +0 -1
- package/dist/lib/editor-to-text.d.ts +0 -7
- package/dist/lib/editor-to-text.js +0 -69
- package/dist/lib/editor-to-text.js.map +0 -1
- package/dist/lib/editor-to-text.mjs +0 -8
- package/dist/lib/editor-to-text.mjs.map +0 -1
- package/dist/lib/get-text-around-cursor.d.ts +0 -15
- package/dist/lib/get-text-around-cursor.js +0 -131
- package/dist/lib/get-text-around-cursor.js.map +0 -1
- package/dist/lib/get-text-around-cursor.mjs +0 -14
- package/dist/lib/get-text-around-cursor.mjs.map +0 -1
- package/dist/lib/retry.d.ts +0 -3
- package/dist/lib/retry.js +0 -43
- package/dist/lib/retry.js.map +0 -1
- package/dist/lib/retry.mjs +0 -8
- package/dist/lib/retry.mjs.map +0 -1
- package/dist/lib/slatejs-edits/add-autocompletions.d.ts +0 -8
- package/dist/lib/slatejs-edits/add-autocompletions.js +0 -51
- package/dist/lib/slatejs-edits/add-autocompletions.js.map +0 -1
- package/dist/lib/slatejs-edits/add-autocompletions.mjs +0 -8
- package/dist/lib/slatejs-edits/add-autocompletions.mjs.map +0 -1
- package/dist/lib/slatejs-edits/clear-autocompletions.d.ts +0 -8
- package/dist/lib/slatejs-edits/clear-autocompletions.js +0 -49
- package/dist/lib/slatejs-edits/clear-autocompletions.js.map +0 -1
- package/dist/lib/slatejs-edits/clear-autocompletions.mjs +0 -8
- package/dist/lib/slatejs-edits/clear-autocompletions.mjs.map +0 -1
- package/dist/lib/slatejs-edits/replace-text.d.ts +0 -5
- package/dist/lib/slatejs-edits/replace-text.js +0 -53
- package/dist/lib/slatejs-edits/replace-text.js.map +0 -1
- package/dist/lib/slatejs-edits/replace-text.mjs +0 -8
- package/dist/lib/slatejs-edits/replace-text.mjs.map +0 -1
- package/dist/lib/slatejs-edits/with-partial-history.d.ts +0 -8
- package/dist/lib/slatejs-edits/with-partial-history.js +0 -133
- package/dist/lib/slatejs-edits/with-partial-history.js.map +0 -1
- package/dist/lib/slatejs-edits/with-partial-history.mjs +0 -10
- package/dist/lib/slatejs-edits/with-partial-history.mjs.map +0 -1
- package/dist/lib/stream-promise-flatten.d.ts +0 -12
- package/dist/lib/stream-promise-flatten.js +0 -72
- package/dist/lib/stream-promise-flatten.js.map +0 -1
- package/dist/lib/stream-promise-flatten.mjs +0 -8
- package/dist/lib/stream-promise-flatten.mjs.map +0 -1
- package/dist/lib/utils.d.ts +0 -9
- package/dist/lib/utils.js +0 -94
- package/dist/lib/utils.js.map +0 -1
- package/dist/lib/utils.mjs +0 -16
- package/dist/lib/utils.mjs.map +0 -1
- package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.d.ts +0 -23
- package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.js +0 -19
- package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.js.map +0 -1
- package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs +0 -1
- package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs.map +0 -1
- package/dist/types/autosuggestions-config/autosuggestions-config.d.ts +0 -20
- package/dist/types/autosuggestions-config/autosuggestions-config.js +0 -287
- package/dist/types/autosuggestions-config/autosuggestions-config.js.map +0 -1
- package/dist/types/autosuggestions-config/autosuggestions-config.mjs +0 -13
- package/dist/types/autosuggestions-config/autosuggestions-config.mjs.map +0 -1
- package/dist/types/autosuggestions-config/editing-api-config.d.ts +0 -15
- package/dist/types/autosuggestions-config/editing-api-config.js +0 -108
- package/dist/types/autosuggestions-config/editing-api-config.js.map +0 -1
- package/dist/types/autosuggestions-config/editing-api-config.mjs +0 -12
- package/dist/types/autosuggestions-config/editing-api-config.mjs.map +0 -1
- package/dist/types/autosuggestions-config/index.d.ts +0 -10
- package/dist/types/autosuggestions-config/index.js +0 -287
- package/dist/types/autosuggestions-config/index.js.map +0 -1
- package/dist/types/autosuggestions-config/index.mjs +0 -14
- package/dist/types/autosuggestions-config/index.mjs.map +0 -1
- package/dist/types/autosuggestions-config/insertions-api-config.d.ts +0 -15
- package/dist/types/autosuggestions-config/insertions-api-config.js +0 -101
- package/dist/types/autosuggestions-config/insertions-api-config.js.map +0 -1
- package/dist/types/autosuggestions-config/insertions-api-config.mjs +0 -12
- package/dist/types/autosuggestions-config/insertions-api-config.mjs.map +0 -1
- package/dist/types/autosuggestions-config/subtypes/make-system-prompt.d.ts +0 -3
- package/dist/types/autosuggestions-config/subtypes/make-system-prompt.js +0 -19
- package/dist/types/autosuggestions-config/subtypes/make-system-prompt.js.map +0 -1
- package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs +0 -1
- package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs.map +0 -1
- package/dist/types/autosuggestions-config/suggestions-api-config.d.ts +0 -15
- package/dist/types/autosuggestions-config/suggestions-api-config.js +0 -90
- package/dist/types/autosuggestions-config/suggestions-api-config.js.map +0 -1
- package/dist/types/autosuggestions-config/suggestions-api-config.mjs +0 -12
- package/dist/types/autosuggestions-config/suggestions-api-config.mjs.map +0 -1
- package/dist/types/base/autosuggestion-state.d.ts +0 -8
- package/dist/types/base/autosuggestion-state.js +0 -19
- package/dist/types/base/autosuggestion-state.js.map +0 -1
- package/dist/types/base/autosuggestion-state.mjs +0 -1
- package/dist/types/base/autosuggestion-state.mjs.map +0 -1
- package/dist/types/base/autosuggestions-bare-function.d.ts +0 -19
- package/dist/types/base/autosuggestions-bare-function.js +0 -19
- package/dist/types/base/autosuggestions-bare-function.js.map +0 -1
- package/dist/types/base/autosuggestions-bare-function.mjs +0 -1
- package/dist/types/base/autosuggestions-bare-function.mjs.map +0 -1
- package/dist/types/base/base-autosuggestions-config.d.ts +0 -87
- package/dist/types/base/base-autosuggestions-config.js +0 -54
- package/dist/types/base/base-autosuggestions-config.js.map +0 -1
- package/dist/types/base/base-autosuggestions-config.mjs +0 -8
- package/dist/types/base/base-autosuggestions-config.mjs.map +0 -1
- package/dist/types/base/base-copilot-textarea-props.d.ts +0 -5
- package/dist/types/base/base-copilot-textarea-props.js +0 -19
- package/dist/types/base/base-copilot-textarea-props.js.map +0 -1
- package/dist/types/base/base-copilot-textarea-props.mjs +0 -1
- package/dist/types/base/base-copilot-textarea-props.mjs.map +0 -1
- package/dist/types/base/custom-editor.d.ts +0 -29
- package/dist/types/base/custom-editor.js +0 -19
- package/dist/types/base/custom-editor.js.map +0 -1
- package/dist/types/base/custom-editor.mjs +0 -1
- package/dist/types/base/custom-editor.mjs.map +0 -1
- package/dist/types/base/editor-autocomplete-state.d.ts +0 -10
- package/dist/types/base/editor-autocomplete-state.js +0 -40
- package/dist/types/base/editor-autocomplete-state.js.map +0 -1
- package/dist/types/base/editor-autocomplete-state.mjs +0 -9
- package/dist/types/base/editor-autocomplete-state.mjs.map +0 -1
- package/dist/types/base/index.d.ts +0 -54
- package/dist/types/base/index.js +0 -56
- package/dist/types/base/index.js.map +0 -1
- package/dist/types/base/index.mjs +0 -9
- package/dist/types/base/index.mjs.map +0 -1
- package/dist/types/html-copilot-textarea-element.d.ts +0 -7
- package/dist/types/html-copilot-textarea-element.js +0 -19
- package/dist/types/html-copilot-textarea-element.js.map +0 -1
- package/dist/types/html-copilot-textarea-element.mjs +0 -2
- package/dist/types/html-copilot-textarea-element.mjs.map +0 -1
- package/dist/types/index.d.ts +0 -13
- package/dist/types/index.js +0 -289
- package/dist/types/index.js.map +0 -1
- package/dist/types/index.mjs +0 -19
- package/dist/types/index.mjs.map +0 -1
- package/jest.config.js +0 -5
- package/rollup.config.mjs +0 -64
- package/tsup.config.ts +0 -15
package/dist/chunk-SWX3MRZ4.mjs
DELETED
|
@@ -1,278 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
addAutocompletionsToEditor
|
|
3
|
-
} from "./chunk-2C7O2EVM.mjs";
|
|
4
|
-
import {
|
|
5
|
-
clearAutocompletionsFromEditor
|
|
6
|
-
} from "./chunk-EGBZSVLK.mjs";
|
|
7
|
-
import {
|
|
8
|
-
useAutosuggestions
|
|
9
|
-
} from "./chunk-ZBP4SABT.mjs";
|
|
10
|
-
import {
|
|
11
|
-
useCopilotTextareaEditor
|
|
12
|
-
} from "./chunk-7GZWOXE4.mjs";
|
|
13
|
-
import {
|
|
14
|
-
usePopulateCopilotTextareaRef
|
|
15
|
-
} from "./chunk-TGN3YVSO.mjs";
|
|
16
|
-
import {
|
|
17
|
-
replaceEditorText
|
|
18
|
-
} from "./chunk-5UNJXFUO.mjs";
|
|
19
|
-
import {
|
|
20
|
-
useAddBrandingCss
|
|
21
|
-
} from "./chunk-VVRGAA43.mjs";
|
|
22
|
-
import {
|
|
23
|
-
HoveringToolbar
|
|
24
|
-
} from "./chunk-AZ7RF6ED.mjs";
|
|
25
|
-
import {
|
|
26
|
-
HoveringEditorProvider,
|
|
27
|
-
useHoveringEditorContext
|
|
28
|
-
} from "./chunk-UB4Y22EF.mjs";
|
|
29
|
-
import {
|
|
30
|
-
defaultBaseAutosuggestionsConfig
|
|
31
|
-
} from "./chunk-O4WCM57A.mjs";
|
|
32
|
-
import {
|
|
33
|
-
makeRenderElementFunction
|
|
34
|
-
} from "./chunk-NFMCLTJU.mjs";
|
|
35
|
-
import {
|
|
36
|
-
makeRenderPlaceholderFunction
|
|
37
|
-
} from "./chunk-FTG7P3NP.mjs";
|
|
38
|
-
import {
|
|
39
|
-
TrackerTextEditedSinceLastCursorMovement
|
|
40
|
-
} from "./chunk-YINY56BI.mjs";
|
|
41
|
-
import {
|
|
42
|
-
getFullEditorTextWithNewlines,
|
|
43
|
-
getTextAroundCollapsedCursor
|
|
44
|
-
} from "./chunk-A6YGJFQI.mjs";
|
|
45
|
-
import {
|
|
46
|
-
__objRest,
|
|
47
|
-
__spreadProps,
|
|
48
|
-
__spreadValues
|
|
49
|
-
} from "./chunk-MRXNTQOX.mjs";
|
|
50
|
-
|
|
51
|
-
// src/components/base-copilot-textarea/base-copilot-textarea.tsx
|
|
52
|
-
import React, { useCallback, useEffect, useMemo, useState } from "react";
|
|
53
|
-
import { Editor } from "slate";
|
|
54
|
-
import { Editable, Slate } from "slate-react";
|
|
55
|
-
import { twMerge } from "tailwind-merge";
|
|
56
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
57
|
-
var BaseCopilotTextarea = React.forwardRef(
|
|
58
|
-
(props, ref) => {
|
|
59
|
-
return /* @__PURE__ */ jsx(HoveringEditorProvider, { children: /* @__PURE__ */ jsx(BaseCopilotTextareaWithHoveringContext, __spreadProps(__spreadValues({}, props), { ref })) });
|
|
60
|
-
}
|
|
61
|
-
);
|
|
62
|
-
var BaseCopilotTextareaWithHoveringContext = React.forwardRef(
|
|
63
|
-
(props, ref) => {
|
|
64
|
-
const autosuggestionsConfig = __spreadValues(__spreadValues({}, defaultBaseAutosuggestionsConfig), props.baseAutosuggestionsConfig);
|
|
65
|
-
const valueOnInitialRender = useMemo(() => {
|
|
66
|
-
var _a2;
|
|
67
|
-
return (_a2 = props.value) != null ? _a2 : "";
|
|
68
|
-
}, []);
|
|
69
|
-
const [lastKnownFullEditorText, setLastKnownFullEditorText] = useState(valueOnInitialRender);
|
|
70
|
-
const [cursorMovedSinceLastTextChange, setCursorMovedSinceLastTextChange] = useState(false);
|
|
71
|
-
const [isUserInputActive, setIsUserInputActive] = useState(false);
|
|
72
|
-
const initialValue = useMemo(() => {
|
|
73
|
-
return [
|
|
74
|
-
{
|
|
75
|
-
type: "paragraph",
|
|
76
|
-
children: [{ text: valueOnInitialRender }]
|
|
77
|
-
}
|
|
78
|
-
];
|
|
79
|
-
}, [valueOnInitialRender]);
|
|
80
|
-
const editor = useCopilotTextareaEditor();
|
|
81
|
-
const {
|
|
82
|
-
isDisplayed: hoveringEditorIsDisplayed,
|
|
83
|
-
setIsDisplayed: setHoveringEditorIsDisplayed
|
|
84
|
-
} = useHoveringEditorContext();
|
|
85
|
-
const insertText = useCallback(
|
|
86
|
-
(autosuggestion) => {
|
|
87
|
-
Editor.insertText(editor, autosuggestion.text, {
|
|
88
|
-
at: autosuggestion.point
|
|
89
|
-
});
|
|
90
|
-
},
|
|
91
|
-
[editor]
|
|
92
|
-
);
|
|
93
|
-
const shouldDisableAutosuggestions = (
|
|
94
|
-
// textarea is manually disabled:
|
|
95
|
-
autosuggestionsConfig.disabled || // hovering editor is displayed:
|
|
96
|
-
hoveringEditorIsDisplayed || // the cursor has moved since the last text change AND we are configured to disable autosuggestions in this case:
|
|
97
|
-
cursorMovedSinceLastTextChange && autosuggestionsConfig.temporarilyDisableWhenMovingCursorWithoutChangingText || // not user input and we want to disable non-trusted events (like text insertion from autocomplete plugins):
|
|
98
|
-
!isUserInputActive && autosuggestionsConfig.temporarilyDisableNotTrustedEvents
|
|
99
|
-
);
|
|
100
|
-
const {
|
|
101
|
-
currentAutocompleteSuggestion,
|
|
102
|
-
onChangeHandler: onChangeHandlerForAutocomplete,
|
|
103
|
-
onKeyDownHandler: onKeyDownHandlerForAutocomplete,
|
|
104
|
-
onTouchStartHandler: onTouchStartHandlerForAutocomplete
|
|
105
|
-
} = useAutosuggestions(
|
|
106
|
-
autosuggestionsConfig.debounceTime,
|
|
107
|
-
autosuggestionsConfig.shouldAcceptAutosuggestionOnKeyPress,
|
|
108
|
-
autosuggestionsConfig.shouldAcceptAutosuggestionOnTouch,
|
|
109
|
-
autosuggestionsConfig.apiConfig.autosuggestionsFunction,
|
|
110
|
-
insertText,
|
|
111
|
-
autosuggestionsConfig.disableWhenEmpty,
|
|
112
|
-
shouldDisableAutosuggestions
|
|
113
|
-
);
|
|
114
|
-
const onKeyDownHandlerForHoveringEditor = useCallback(
|
|
115
|
-
(event) => {
|
|
116
|
-
var _a2;
|
|
117
|
-
if (autosuggestionsConfig.shouldToggleHoveringEditorOnKeyPress(
|
|
118
|
-
event,
|
|
119
|
-
(_a2 = props.shortcut) != null ? _a2 : "k"
|
|
120
|
-
)) {
|
|
121
|
-
event.preventDefault();
|
|
122
|
-
setHoveringEditorIsDisplayed(!hoveringEditorIsDisplayed);
|
|
123
|
-
}
|
|
124
|
-
},
|
|
125
|
-
[
|
|
126
|
-
hoveringEditorIsDisplayed,
|
|
127
|
-
setHoveringEditorIsDisplayed,
|
|
128
|
-
autosuggestionsConfig.shouldToggleHoveringEditorOnKeyPress
|
|
129
|
-
]
|
|
130
|
-
);
|
|
131
|
-
useEffect(() => {
|
|
132
|
-
clearAutocompletionsFromEditor(editor);
|
|
133
|
-
if (currentAutocompleteSuggestion) {
|
|
134
|
-
addAutocompletionsToEditor(
|
|
135
|
-
editor,
|
|
136
|
-
currentAutocompleteSuggestion.text,
|
|
137
|
-
currentAutocompleteSuggestion.point
|
|
138
|
-
);
|
|
139
|
-
}
|
|
140
|
-
}, [currentAutocompleteSuggestion]);
|
|
141
|
-
const suggestionStyleAugmented = useMemo(() => {
|
|
142
|
-
return __spreadValues({
|
|
143
|
-
fontStyle: "italic",
|
|
144
|
-
color: "gray"
|
|
145
|
-
}, props.suggestionsStyle);
|
|
146
|
-
}, [props.suggestionsStyle]);
|
|
147
|
-
const renderElementMemoized = useMemo(() => {
|
|
148
|
-
return makeRenderElementFunction(suggestionStyleAugmented);
|
|
149
|
-
}, [suggestionStyleAugmented]);
|
|
150
|
-
const renderPlaceholderMemoized = useMemo(() => {
|
|
151
|
-
const placeholderStyleSlatejsOverrides = {
|
|
152
|
-
top: void 0
|
|
153
|
-
};
|
|
154
|
-
const placeholderStyleAugmented = __spreadValues(__spreadValues({}, placeholderStyleSlatejsOverrides), props.placeholderStyle);
|
|
155
|
-
return makeRenderPlaceholderFunction(placeholderStyleAugmented);
|
|
156
|
-
}, [props.placeholderStyle]);
|
|
157
|
-
useEffect(() => {
|
|
158
|
-
var _a2, _b;
|
|
159
|
-
if (props.value === lastKnownFullEditorText) {
|
|
160
|
-
return;
|
|
161
|
-
}
|
|
162
|
-
setLastKnownFullEditorText((_a2 = props.value) != null ? _a2 : "");
|
|
163
|
-
replaceEditorText(editor, (_b = props.value) != null ? _b : "");
|
|
164
|
-
}, [props.value]);
|
|
165
|
-
const _a = props, {
|
|
166
|
-
placeholderStyle,
|
|
167
|
-
value,
|
|
168
|
-
hoverMenuClassname,
|
|
169
|
-
onValueChange,
|
|
170
|
-
baseAutosuggestionsConfig: autosuggestionsConfigFromProps,
|
|
171
|
-
className,
|
|
172
|
-
onChange,
|
|
173
|
-
onKeyDown,
|
|
174
|
-
disableBranding
|
|
175
|
-
} = _a, propsToForward = __objRest(_a, [
|
|
176
|
-
"placeholderStyle",
|
|
177
|
-
"value",
|
|
178
|
-
"hoverMenuClassname",
|
|
179
|
-
"onValueChange",
|
|
180
|
-
"baseAutosuggestionsConfig",
|
|
181
|
-
"className",
|
|
182
|
-
"onChange",
|
|
183
|
-
"onKeyDown",
|
|
184
|
-
"disableBranding"
|
|
185
|
-
]);
|
|
186
|
-
useAddBrandingCss(suggestionStyleAugmented, disableBranding);
|
|
187
|
-
usePopulateCopilotTextareaRef(editor, ref);
|
|
188
|
-
const moddedClassName = (() => {
|
|
189
|
-
const baseClassName = "copilot-textarea";
|
|
190
|
-
const brandingClass = disableBranding ? "no-branding" : "with-branding";
|
|
191
|
-
const defaultTailwindClassName = "bg-white overflow-y-auto resize-y";
|
|
192
|
-
const mergedClassName = twMerge(
|
|
193
|
-
defaultTailwindClassName,
|
|
194
|
-
className != null ? className : ""
|
|
195
|
-
);
|
|
196
|
-
return `${baseClassName} ${brandingClass} ${mergedClassName}`;
|
|
197
|
-
})();
|
|
198
|
-
return /* @__PURE__ */ jsxs(
|
|
199
|
-
Slate,
|
|
200
|
-
{
|
|
201
|
-
editor,
|
|
202
|
-
initialValue,
|
|
203
|
-
onChange: (value2) => {
|
|
204
|
-
var _a2, _b;
|
|
205
|
-
const newEditorState = getTextAroundCollapsedCursor(editor);
|
|
206
|
-
const fullEditorText = newEditorState ? newEditorState.textBeforeCursor + newEditorState.textAfterCursor : getFullEditorTextWithNewlines(editor);
|
|
207
|
-
setLastKnownFullEditorText((prev) => {
|
|
208
|
-
if (prev !== fullEditorText) {
|
|
209
|
-
setCursorMovedSinceLastTextChange(false);
|
|
210
|
-
}
|
|
211
|
-
return fullEditorText;
|
|
212
|
-
});
|
|
213
|
-
onChangeHandlerForAutocomplete(newEditorState);
|
|
214
|
-
(_a2 = props.onValueChange) == null ? void 0 : _a2.call(props, fullEditorText);
|
|
215
|
-
(_b = props.onChange) == null ? void 0 : _b.call(props, makeSemiFakeReactTextAreaEvent(fullEditorText));
|
|
216
|
-
},
|
|
217
|
-
children: [
|
|
218
|
-
/* @__PURE__ */ jsx(
|
|
219
|
-
TrackerTextEditedSinceLastCursorMovement,
|
|
220
|
-
{
|
|
221
|
-
setCursorMovedSinceLastTextChange
|
|
222
|
-
}
|
|
223
|
-
),
|
|
224
|
-
/* @__PURE__ */ jsx(
|
|
225
|
-
HoveringToolbar,
|
|
226
|
-
{
|
|
227
|
-
apiConfig: autosuggestionsConfig.apiConfig,
|
|
228
|
-
contextCategories: autosuggestionsConfig.contextCategories,
|
|
229
|
-
hoverMenuClassname
|
|
230
|
-
}
|
|
231
|
-
),
|
|
232
|
-
/* @__PURE__ */ jsx(
|
|
233
|
-
Editable,
|
|
234
|
-
__spreadValues({
|
|
235
|
-
renderElement: renderElementMemoized,
|
|
236
|
-
renderPlaceholder: renderPlaceholderMemoized,
|
|
237
|
-
onKeyDown: (event) => {
|
|
238
|
-
var _a2;
|
|
239
|
-
setIsUserInputActive(true);
|
|
240
|
-
onKeyDownHandlerForHoveringEditor(event);
|
|
241
|
-
onKeyDownHandlerForAutocomplete(event);
|
|
242
|
-
(_a2 = props.onKeyDown) == null ? void 0 : _a2.call(props, event);
|
|
243
|
-
},
|
|
244
|
-
onTouchStart: (event) => {
|
|
245
|
-
onTouchStartHandlerForAutocomplete(event);
|
|
246
|
-
},
|
|
247
|
-
"data-testid": "copilot-textarea-editable",
|
|
248
|
-
className: moddedClassName,
|
|
249
|
-
onBlur: (ev) => {
|
|
250
|
-
var _a2;
|
|
251
|
-
(_a2 = props.onBlur) == null ? void 0 : _a2.call(props, ev);
|
|
252
|
-
clearAutocompletionsFromEditor(editor);
|
|
253
|
-
setIsUserInputActive(false);
|
|
254
|
-
}
|
|
255
|
-
}, propsToForward)
|
|
256
|
-
)
|
|
257
|
-
]
|
|
258
|
-
}
|
|
259
|
-
);
|
|
260
|
-
}
|
|
261
|
-
);
|
|
262
|
-
function makeSemiFakeReactTextAreaEvent(currentText) {
|
|
263
|
-
return {
|
|
264
|
-
target: {
|
|
265
|
-
value: currentText,
|
|
266
|
-
type: "copilot-textarea"
|
|
267
|
-
},
|
|
268
|
-
currentTarget: {
|
|
269
|
-
value: currentText,
|
|
270
|
-
type: "copilot-textarea"
|
|
271
|
-
}
|
|
272
|
-
};
|
|
273
|
-
}
|
|
274
|
-
|
|
275
|
-
export {
|
|
276
|
-
BaseCopilotTextarea
|
|
277
|
-
};
|
|
278
|
-
//# sourceMappingURL=chunk-SWX3MRZ4.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/base-copilot-textarea/base-copilot-textarea.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport { Descendant, Editor } from \"slate\";\nimport { Editable, Slate } from \"slate-react\";\nimport { twMerge } from \"tailwind-merge\";\nimport { useAutosuggestions } from \"../../hooks/base-copilot-textarea-implementation/use-autosuggestions\";\nimport { useCopilotTextareaEditor } from \"../../hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor\";\nimport { usePopulateCopilotTextareaRef } from \"../../hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref\";\nimport {\n getFullEditorTextWithNewlines,\n getTextAroundCollapsedCursor,\n} from \"../../lib/get-text-around-cursor\";\nimport { addAutocompletionsToEditor } from \"../../lib/slatejs-edits/add-autocompletions\";\nimport { clearAutocompletionsFromEditor } from \"../../lib/slatejs-edits/clear-autocompletions\";\nimport { replaceEditorText } from \"../../lib/slatejs-edits/replace-text\";\nimport {\n BaseAutosuggestionsConfig,\n defaultBaseAutosuggestionsConfig,\n} from \"../../types/base\";\nimport { AutosuggestionState } from \"../../types/base/autosuggestion-state\";\nimport { BaseCopilotTextareaProps } from \"../../types/base/base-copilot-textarea-props\";\nimport \"./base-copilot-textarea.css\";\nimport { HoveringToolbar } from \"../hovering-toolbar/hovering-toolbar\";\nimport { makeRenderElementFunction } from \"./render-element\";\nimport { makeRenderPlaceholderFunction } from \"./render-placeholder\";\nimport { useAddBrandingCss } from \"./use-add-branding-css\";\nimport {\n HoveringEditorProvider,\n useHoveringEditorContext,\n} from \"../hovering-toolbar/hovering-editor-provider\";\nimport { TrackerTextEditedSinceLastCursorMovement } from \"./track-cursor-moved-since-last-text-change\";\n\n/**\n * Purpose: to be used as the `ref` type for `CopilotTextarea` and `BaseCopilotTextarea`.\n *\n * This interface extends `HTMLElement`, and is the subset of `HTMLTextAreaElement` that \"actually matters\".\n * It provides the core functionality that consumers of `HTMLTextAreaElement` need 99.9% of the time:\n * - `value`: the current value of the textarea\n * - `focus`: make the textarea focused\n * - `blur`: make the textarea unfocused\n */\nexport interface HTMLCopilotTextAreaElement extends HTMLElement {\n /**\n * The current value of the textarea.\n */\n value: string;\n\n /**\n * focus on the textarea\n */\n focus: () => void;\n\n /**\n * unfocus the textarea.\n *\n * Called `blur` for syntactic compatibility with `HTMLTextAreaElement`.\n */\n blur: () => void;\n}\n\n/**\n * Not intended for direct use. Use CopilotTextarea instead.\n *\n * The `BaseCopilotTextarea` includes the basic UX component,\n * without the business logic / AI logic that makes the content useful and coherent.\n *\n * It is useful if you want to build your own backend, with fully custom business logic\n * for figuring out which contnet to fill in.\n */\nexport const BaseCopilotTextarea = React.forwardRef(\n (\n props: BaseCopilotTextareaProps,\n ref: React.Ref<HTMLCopilotTextAreaElement>,\n ) => {\n return (\n <HoveringEditorProvider>\n <BaseCopilotTextareaWithHoveringContext {...props} ref={ref} />\n </HoveringEditorProvider>\n );\n },\n);\n\n/**\n * Not intended for direct use. Use `CopilotTextarea` instead.\n *\n * This is the private core of the `BaseCopilotTextarea` component.\n * For practical purposes the implementation is cleaner assuming containment in a `HoveringEditorProviderContext`.\n *\n * Therefore we separate the core logic into this component,\n * and wrap it in a `HoveringEditorProviderContext` in `BaseCopilotTextarea`.\n */\nconst BaseCopilotTextareaWithHoveringContext = React.forwardRef(\n (\n props: BaseCopilotTextareaProps,\n ref: React.Ref<HTMLCopilotTextAreaElement>,\n ) => {\n const autosuggestionsConfig: BaseAutosuggestionsConfig = {\n ...defaultBaseAutosuggestionsConfig,\n ...props.baseAutosuggestionsConfig,\n };\n\n const valueOnInitialRender = useMemo(() => props.value ?? \"\", []);\n const [lastKnownFullEditorText, setLastKnownFullEditorText] =\n useState(valueOnInitialRender);\n const [cursorMovedSinceLastTextChange, setCursorMovedSinceLastTextChange] =\n useState(false);\n const [isUserInputActive, setIsUserInputActive] = useState(false);\n\n // // When the editor text changes, we want to reset the `textEditedSinceLastCursorMovement` state.\n // useEffect(() => {\n // setCursorMovedSinceLastTextChange(false);\n // }, [lastKnownFullEditorText]);\n\n const initialValue: Descendant[] = useMemo(() => {\n return [\n {\n type: \"paragraph\",\n children: [{ text: valueOnInitialRender }],\n },\n ];\n }, [valueOnInitialRender]);\n\n const editor = useCopilotTextareaEditor();\n\n const {\n isDisplayed: hoveringEditorIsDisplayed,\n setIsDisplayed: setHoveringEditorIsDisplayed,\n } = useHoveringEditorContext();\n\n const insertText = useCallback(\n (autosuggestion: AutosuggestionState) => {\n Editor.insertText(editor, autosuggestion.text, {\n at: autosuggestion.point,\n });\n },\n [editor],\n );\n\n const shouldDisableAutosuggestions =\n // textarea is manually disabled:\n autosuggestionsConfig.disabled ||\n // hovering editor is displayed:\n hoveringEditorIsDisplayed ||\n // the cursor has moved since the last text change AND we are configured to disable autosuggestions in this case:\n (cursorMovedSinceLastTextChange &&\n autosuggestionsConfig.temporarilyDisableWhenMovingCursorWithoutChangingText) ||\n // not user input and we want to disable non-trusted events (like text insertion from autocomplete plugins):\n (!isUserInputActive &&\n autosuggestionsConfig.temporarilyDisableNotTrustedEvents);\n\n const {\n currentAutocompleteSuggestion,\n onChangeHandler: onChangeHandlerForAutocomplete,\n onKeyDownHandler: onKeyDownHandlerForAutocomplete,\n onTouchStartHandler: onTouchStartHandlerForAutocomplete,\n } = useAutosuggestions(\n autosuggestionsConfig.debounceTime,\n autosuggestionsConfig.shouldAcceptAutosuggestionOnKeyPress,\n autosuggestionsConfig.shouldAcceptAutosuggestionOnTouch,\n autosuggestionsConfig.apiConfig.autosuggestionsFunction,\n insertText,\n autosuggestionsConfig.disableWhenEmpty,\n shouldDisableAutosuggestions,\n );\n\n const onKeyDownHandlerForHoveringEditor = useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (\n autosuggestionsConfig.shouldToggleHoveringEditorOnKeyPress(\n event,\n props.shortcut ?? \"k\",\n )\n ) {\n event.preventDefault();\n setHoveringEditorIsDisplayed(!hoveringEditorIsDisplayed);\n }\n },\n [\n hoveringEditorIsDisplayed,\n setHoveringEditorIsDisplayed,\n autosuggestionsConfig.shouldToggleHoveringEditorOnKeyPress,\n ],\n );\n\n // sync autosuggestions state with the editor\n useEffect(() => {\n clearAutocompletionsFromEditor(editor);\n if (currentAutocompleteSuggestion) {\n addAutocompletionsToEditor(\n editor,\n currentAutocompleteSuggestion.text,\n currentAutocompleteSuggestion.point,\n );\n }\n }, [currentAutocompleteSuggestion]);\n\n const suggestionStyleAugmented: React.CSSProperties = useMemo(() => {\n return {\n fontStyle: \"italic\",\n color: \"gray\",\n ...props.suggestionsStyle,\n };\n }, [props.suggestionsStyle]);\n\n const renderElementMemoized = useMemo(() => {\n return makeRenderElementFunction(suggestionStyleAugmented);\n }, [suggestionStyleAugmented]);\n\n const renderPlaceholderMemoized = useMemo(() => {\n // For some reason slateJS specifies a top value of 0, which makes for strange styling. We override this here.\n const placeholderStyleSlatejsOverrides: React.CSSProperties = {\n top: undefined,\n };\n\n const placeholderStyleAugmented: React.CSSProperties = {\n ...placeholderStyleSlatejsOverrides,\n ...props.placeholderStyle,\n };\n\n return makeRenderPlaceholderFunction(placeholderStyleAugmented);\n }, [props.placeholderStyle]);\n\n // update the editor text, but only when the value changes from outside the component\n useEffect(() => {\n if (props.value === lastKnownFullEditorText) {\n return;\n }\n\n setLastKnownFullEditorText(props.value ?? \"\");\n replaceEditorText(editor, props.value ?? \"\");\n }, [props.value]);\n\n // separate into TextareaHTMLAttributes<HTMLDivElement> and CopilotTextareaProps\n const {\n placeholderStyle,\n value,\n hoverMenuClassname,\n onValueChange,\n baseAutosuggestionsConfig: autosuggestionsConfigFromProps,\n className,\n onChange,\n onKeyDown,\n disableBranding,\n ...propsToForward\n } = props;\n\n useAddBrandingCss(suggestionStyleAugmented, disableBranding);\n usePopulateCopilotTextareaRef(editor, ref);\n\n const moddedClassName = (() => {\n const baseClassName = \"copilot-textarea\";\n const brandingClass = disableBranding ? \"no-branding\" : \"with-branding\";\n const defaultTailwindClassName = \"bg-white overflow-y-auto resize-y\";\n const mergedClassName = twMerge(\n defaultTailwindClassName,\n className ?? \"\",\n );\n return `${baseClassName} ${brandingClass} ${mergedClassName}`;\n })();\n\n return (\n <Slate\n editor={editor}\n initialValue={initialValue}\n onChange={(value) => {\n const newEditorState = getTextAroundCollapsedCursor(editor);\n\n const fullEditorText = newEditorState\n ? newEditorState.textBeforeCursor + newEditorState.textAfterCursor\n : getFullEditorTextWithNewlines(editor); // we don't double-parse the editor. When `newEditorState` is null, we didn't parse the editor yet.\n\n setLastKnownFullEditorText((prev) => {\n if (prev !== fullEditorText) {\n setCursorMovedSinceLastTextChange(false);\n }\n return fullEditorText;\n });\n\n onChangeHandlerForAutocomplete(newEditorState);\n\n props.onValueChange?.(fullEditorText);\n props.onChange?.(makeSemiFakeReactTextAreaEvent(fullEditorText));\n }}\n >\n <TrackerTextEditedSinceLastCursorMovement\n setCursorMovedSinceLastTextChange={setCursorMovedSinceLastTextChange}\n />\n <HoveringToolbar\n apiConfig={autosuggestionsConfig.apiConfig}\n contextCategories={autosuggestionsConfig.contextCategories}\n hoverMenuClassname={hoverMenuClassname}\n />\n <Editable\n renderElement={renderElementMemoized}\n renderPlaceholder={renderPlaceholderMemoized}\n onKeyDown={(event) => {\n setIsUserInputActive(true);\n onKeyDownHandlerForHoveringEditor(event); // forward the event for internal use\n onKeyDownHandlerForAutocomplete(event); // forward the event for internal use\n props.onKeyDown?.(event); // forward the event for external use\n }}\n onTouchStart={(event) => {\n onTouchStartHandlerForAutocomplete(event); // forward the event for internal use\n }}\n data-testid=\"copilot-textarea-editable\"\n className={moddedClassName}\n onBlur={(ev) => {\n // clear autocompletion on blur\n props.onBlur?.(ev);\n clearAutocompletionsFromEditor(editor);\n setIsUserInputActive(false);\n }}\n {...propsToForward}\n />\n </Slate>\n );\n },\n);\n\n// Consumers of <textarea> expect a `onChange: (React.ChangeEvent<HTMLTextAreaElement>) => void` event handler to be passed in.\n// This is *extremely* common, and we want to support it.\n//\n// We can't support the full functionality, but in 99% of cases, the consumer only cares about the `event.target.value` property --\n// that's how they get the new value of the textarea.\n//\n// So, the tradeoff we are making is minimizing compiler complaint, with a small chance of runtime error.\n// The alternative would be defining a different onChange entrypoint (we actually do have that in `onValueChange`),\n// And starting to explain subtleties to users the moment they try to use the component for the first time for very basic functionality.\n//\n// If this proves problematic, we can always revisit this decision.\nfunction makeSemiFakeReactTextAreaEvent(\n currentText: string,\n): React.ChangeEvent<HTMLTextAreaElement> {\n return {\n target: {\n value: currentText,\n type: \"copilot-textarea\",\n },\n currentTarget: {\n value: currentText,\n type: \"copilot-textarea\",\n },\n } as React.ChangeEvent<HTMLTextAreaElement>;\n}\n"],"mappings":"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","names":["_a","value"]}
|
package/dist/chunk-TGN3YVSO.mjs
DELETED
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
replaceEditorText
|
|
3
|
-
} from "./chunk-5UNJXFUO.mjs";
|
|
4
|
-
import {
|
|
5
|
-
getFullEditorTextWithNewlines
|
|
6
|
-
} from "./chunk-A6YGJFQI.mjs";
|
|
7
|
-
|
|
8
|
-
// src/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.ts
|
|
9
|
-
import React from "react";
|
|
10
|
-
import { ReactEditor } from "slate-react";
|
|
11
|
-
function usePopulateCopilotTextareaRef(editor, ref) {
|
|
12
|
-
React.useImperativeHandle(ref, () => {
|
|
13
|
-
class Combined {
|
|
14
|
-
constructor(customMethods2, editorHtmlElement2) {
|
|
15
|
-
this.customMethods = customMethods2;
|
|
16
|
-
this.editorHtmlElement = editorHtmlElement2;
|
|
17
|
-
}
|
|
18
|
-
get(target, propKey) {
|
|
19
|
-
if (this.isKeyOfCustomMethods(propKey)) {
|
|
20
|
-
const value = this.customMethods[propKey];
|
|
21
|
-
if (typeof value === "function") {
|
|
22
|
-
return value.bind(this.customMethods);
|
|
23
|
-
}
|
|
24
|
-
return value;
|
|
25
|
-
} else if (this.isKeyOfHTMLElement(propKey)) {
|
|
26
|
-
const value = this.editorHtmlElement[propKey];
|
|
27
|
-
if (typeof value === "function") {
|
|
28
|
-
return value.bind(this.editorHtmlElement);
|
|
29
|
-
}
|
|
30
|
-
return value;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
set(target, propKey, value) {
|
|
34
|
-
if (this.isKeyOfCustomMethods(propKey)) {
|
|
35
|
-
this.customMethods[propKey] = value;
|
|
36
|
-
} else if (this.isKeyOfHTMLElement(propKey)) {
|
|
37
|
-
this.editorHtmlElement[propKey] = value;
|
|
38
|
-
} else {
|
|
39
|
-
target[propKey] = value;
|
|
40
|
-
}
|
|
41
|
-
return true;
|
|
42
|
-
}
|
|
43
|
-
isKeyOfCustomMethods(key) {
|
|
44
|
-
return key in this.customMethods;
|
|
45
|
-
}
|
|
46
|
-
isKeyOfHTMLElement(key) {
|
|
47
|
-
return key in this.editorHtmlElement;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
const handler = {
|
|
51
|
-
get(target, propKey) {
|
|
52
|
-
return target.get(target, propKey);
|
|
53
|
-
},
|
|
54
|
-
set(target, propKey, value) {
|
|
55
|
-
return target.set(target, propKey, value);
|
|
56
|
-
}
|
|
57
|
-
};
|
|
58
|
-
class CustomMethods {
|
|
59
|
-
constructor(editor2) {
|
|
60
|
-
this.editor = editor2;
|
|
61
|
-
}
|
|
62
|
-
focus() {
|
|
63
|
-
ReactEditor.focus(this.editor);
|
|
64
|
-
}
|
|
65
|
-
blur() {
|
|
66
|
-
ReactEditor.blur(this.editor);
|
|
67
|
-
}
|
|
68
|
-
get value() {
|
|
69
|
-
return getFullEditorTextWithNewlines(this.editor);
|
|
70
|
-
}
|
|
71
|
-
set value(value) {
|
|
72
|
-
replaceEditorText(this.editor, value);
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
const editorHtmlElement = ReactEditor.toDOMNode(editor, editor);
|
|
76
|
-
const customMethods = new CustomMethods(editor);
|
|
77
|
-
const combined = new Combined(customMethods, editorHtmlElement);
|
|
78
|
-
return new Proxy(combined, handler);
|
|
79
|
-
}, [editor]);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
export {
|
|
83
|
-
usePopulateCopilotTextareaRef
|
|
84
|
-
};
|
|
85
|
-
//# sourceMappingURL=chunk-TGN3YVSO.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.ts"],"sourcesContent":["import React from \"react\";\nimport { Editor } from \"slate\";\nimport { ReactEditor } from \"slate-react\";\nimport { getFullEditorTextWithNewlines } from \"../../lib/get-text-around-cursor\";\nimport { replaceEditorText } from \"../../lib/slatejs-edits/replace-text\";\nimport { HTMLCopilotTextAreaElement } from \"../../types\";\nimport { CustomEditor } from \"../../types/base/custom-editor\";\n\nexport function usePopulateCopilotTextareaRef(\n editor: Editor,\n ref: React.Ref<HTMLCopilotTextAreaElement>,\n) {\n React.useImperativeHandle(ref, () => {\n class Combined {\n constructor(\n private customMethods: CustomMethods,\n private editorHtmlElement: HTMLElement,\n ) {}\n\n [key: string]: any;\n\n get(target: any, propKey: string): any {\n if (this.isKeyOfCustomMethods(propKey)) {\n const value = this.customMethods[propKey];\n if (typeof value === \"function\") {\n return value.bind(this.customMethods);\n }\n return value;\n } else if (this.isKeyOfHTMLElement(propKey)) {\n const value = this.editorHtmlElement[propKey];\n if (typeof value === \"function\") {\n return value.bind(this.editorHtmlElement);\n }\n return value;\n }\n }\n\n set(target: any, propKey: string, value: any): boolean {\n if (this.isKeyOfCustomMethods(propKey)) {\n (this.customMethods as any)[propKey] = value;\n } else if (this.isKeyOfHTMLElement(propKey)) {\n (this.editorHtmlElement as any)[propKey] = value;\n } else {\n // Default behavior (optional)\n target[propKey] = value;\n }\n return true;\n }\n\n private isKeyOfCustomMethods(key: string): key is keyof CustomMethods {\n return key in this.customMethods;\n }\n\n private isKeyOfHTMLElement(key: string): key is keyof HTMLElement {\n return key in this.editorHtmlElement;\n }\n }\n\n const handler = {\n get(target: any, propKey: keyof CustomMethods | keyof HTMLElement) {\n return target.get(target, propKey);\n },\n set(\n target: any,\n propKey: keyof CustomMethods | keyof HTMLElement,\n value: any,\n ) {\n return target.set(target, propKey, value);\n },\n };\n\n class CustomMethods {\n constructor(private editor: CustomEditor) {}\n\n focus() {\n ReactEditor.focus(this.editor);\n }\n\n blur() {\n ReactEditor.blur(this.editor);\n }\n\n get value() {\n return getFullEditorTextWithNewlines(this.editor);\n }\n set value(value: string) {\n replaceEditorText(this.editor, value);\n }\n }\n\n const editorHtmlElement = ReactEditor.toDOMNode(editor, editor);\n const customMethods = new CustomMethods(editor);\n\n const combined = new Combined(customMethods, editorHtmlElement);\n return new Proxy(combined, handler);\n }, [editor]);\n}\n"],"mappings":";;;;;;;;AAAA,OAAO,WAAW;AAElB,SAAS,mBAAmB;AAMrB,SAAS,8BACd,QACA,KACA;AACA,QAAM,oBAAoB,KAAK,MAAM;AACnC,UAAM,SAAS;AAAA,MACb,YACUA,gBACAC,oBACR;AAFQ,6BAAAD;AACA,iCAAAC;AAAA,MACP;AAAA,MAIH,IAAI,QAAa,SAAsB;AACrC,YAAI,KAAK,qBAAqB,OAAO,GAAG;AACtC,gBAAM,QAAQ,KAAK,cAAc,OAAO;AACxC,cAAI,OAAO,UAAU,YAAY;AAC/B,mBAAO,MAAM,KAAK,KAAK,aAAa;AAAA,UACtC;AACA,iBAAO;AAAA,QACT,WAAW,KAAK,mBAAmB,OAAO,GAAG;AAC3C,gBAAM,QAAQ,KAAK,kBAAkB,OAAO;AAC5C,cAAI,OAAO,UAAU,YAAY;AAC/B,mBAAO,MAAM,KAAK,KAAK,iBAAiB;AAAA,UAC1C;AACA,iBAAO;AAAA,QACT;AAAA,MACF;AAAA,MAEA,IAAI,QAAa,SAAiB,OAAqB;AACrD,YAAI,KAAK,qBAAqB,OAAO,GAAG;AACtC,UAAC,KAAK,cAAsB,OAAO,IAAI;AAAA,QACzC,WAAW,KAAK,mBAAmB,OAAO,GAAG;AAC3C,UAAC,KAAK,kBAA0B,OAAO,IAAI;AAAA,QAC7C,OAAO;AAEL,iBAAO,OAAO,IAAI;AAAA,QACpB;AACA,eAAO;AAAA,MACT;AAAA,MAEQ,qBAAqB,KAAyC;AACpE,eAAO,OAAO,KAAK;AAAA,MACrB;AAAA,MAEQ,mBAAmB,KAAuC;AAChE,eAAO,OAAO,KAAK;AAAA,MACrB;AAAA,IACF;AAEA,UAAM,UAAU;AAAA,MACd,IAAI,QAAa,SAAkD;AACjE,eAAO,OAAO,IAAI,QAAQ,OAAO;AAAA,MACnC;AAAA,MACA,IACE,QACA,SACA,OACA;AACA,eAAO,OAAO,IAAI,QAAQ,SAAS,KAAK;AAAA,MAC1C;AAAA,IACF;AAEA,UAAM,cAAc;AAAA,MAClB,YAAoBC,SAAsB;AAAtB,sBAAAA;AAAA,MAAuB;AAAA,MAE3C,QAAQ;AACN,oBAAY,MAAM,KAAK,MAAM;AAAA,MAC/B;AAAA,MAEA,OAAO;AACL,oBAAY,KAAK,KAAK,MAAM;AAAA,MAC9B;AAAA,MAEA,IAAI,QAAQ;AACV,eAAO,8BAA8B,KAAK,MAAM;AAAA,MAClD;AAAA,MACA,IAAI,MAAM,OAAe;AACvB,0BAAkB,KAAK,QAAQ,KAAK;AAAA,MACtC;AAAA,IACF;AAEA,UAAM,oBAAoB,YAAY,UAAU,QAAQ,MAAM;AAC9D,UAAM,gBAAgB,IAAI,cAAc,MAAM;AAE9C,UAAM,WAAW,IAAI,SAAS,eAAe,iBAAiB;AAC9D,WAAO,IAAI,MAAM,UAAU,OAAO;AAAA,EACpC,GAAG,CAAC,MAAM,CAAC;AACb;","names":["customMethods","editorHtmlElement","editor"]}
|
package/dist/chunk-UB4Y22EF.mjs
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
// src/components/hovering-toolbar/hovering-editor-provider.tsx
|
|
2
|
-
import { createContext, useState, useContext } from "react";
|
|
3
|
-
import { jsx } from "react/jsx-runtime";
|
|
4
|
-
var HoveringEditorContext = createContext({
|
|
5
|
-
isDisplayed: false,
|
|
6
|
-
setIsDisplayed: () => {
|
|
7
|
-
}
|
|
8
|
-
});
|
|
9
|
-
var HoveringEditorProvider = ({
|
|
10
|
-
children
|
|
11
|
-
}) => {
|
|
12
|
-
const [isDisplayed, setIsDisplayed] = useState(false);
|
|
13
|
-
return /* @__PURE__ */ jsx(HoveringEditorContext.Provider, { value: { isDisplayed, setIsDisplayed }, children });
|
|
14
|
-
};
|
|
15
|
-
var useHoveringEditorContext = () => useContext(HoveringEditorContext);
|
|
16
|
-
|
|
17
|
-
export {
|
|
18
|
-
HoveringEditorProvider,
|
|
19
|
-
useHoveringEditorContext
|
|
20
|
-
};
|
|
21
|
-
//# sourceMappingURL=chunk-UB4Y22EF.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/hovering-toolbar/hovering-editor-provider.tsx"],"sourcesContent":["import { createContext, useState, useContext, ReactNode } from \"react\";\n\ninterface HoveringEditorContextProps {\n isDisplayed: boolean;\n setIsDisplayed: (value: boolean) => void;\n}\n\nconst HoveringEditorContext = createContext<HoveringEditorContextProps>({\n isDisplayed: false,\n setIsDisplayed: () => {},\n});\n\nexport interface HoveringEditorProviderProps {\n children: ReactNode;\n}\n\n/**\n * A context provider for the hovering editor over the `CopilotTextarea`\n * (used to edit and insert text into the `CopilotTextarea`).\n */\nexport const HoveringEditorProvider = ({\n children,\n}: HoveringEditorProviderProps) => {\n const [isDisplayed, setIsDisplayed] = useState<boolean>(false);\n\n return (\n <HoveringEditorContext.Provider value={{ isDisplayed, setIsDisplayed }}>\n {children}\n </HoveringEditorContext.Provider>\n );\n};\n\nexport const useHoveringEditorContext = () => useContext(HoveringEditorContext);\n"],"mappings":";AAAA,SAAS,eAAe,UAAU,kBAA6B;AA0B3D;AAnBJ,IAAM,wBAAwB,cAA0C;AAAA,EACtE,aAAa;AAAA,EACb,gBAAgB,MAAM;AAAA,EAAC;AACzB,CAAC;AAUM,IAAM,yBAAyB,CAAC;AAAA,EACrC;AACF,MAAmC;AACjC,QAAM,CAAC,aAAa,cAAc,IAAI,SAAkB,KAAK;AAE7D,SACE,oBAAC,sBAAsB,UAAtB,EAA+B,OAAO,EAAE,aAAa,eAAe,GAClE,UACH;AAEJ;AAEO,IAAM,2BAA2B,MAAM,WAAW,qBAAqB;","names":[]}
|
package/dist/chunk-UIBUYQPG.mjs
DELETED
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
retry
|
|
3
|
-
} from "./chunk-KNQIEOFP.mjs";
|
|
4
|
-
import {
|
|
5
|
-
__async,
|
|
6
|
-
__spreadValues
|
|
7
|
-
} from "./chunk-MRXNTQOX.mjs";
|
|
8
|
-
|
|
9
|
-
// src/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.tsx
|
|
10
|
-
import { COPILOT_CLOUD_PUBLIC_API_KEY_HEADER } from "@copilotkit/shared";
|
|
11
|
-
import { useCopilotContext } from "@copilotkit/react-core";
|
|
12
|
-
import { useCallback } from "react";
|
|
13
|
-
import {
|
|
14
|
-
Role,
|
|
15
|
-
TextMessage,
|
|
16
|
-
convertGqlOutputToMessages
|
|
17
|
-
} from "@copilotkit/runtime-client-gql";
|
|
18
|
-
function useMakeStandardAutosuggestionFunction(textareaPurpose, contextCategories, apiConfig) {
|
|
19
|
-
const runtimeClient = { generateCopilotResponse: (...args) => {
|
|
20
|
-
} };
|
|
21
|
-
const { getContextString, copilotApiConfig } = useCopilotContext();
|
|
22
|
-
const {
|
|
23
|
-
chatApiEndpoint: url,
|
|
24
|
-
publicApiKey,
|
|
25
|
-
credentials,
|
|
26
|
-
properties
|
|
27
|
-
} = copilotApiConfig;
|
|
28
|
-
const headers = __spreadValues(__spreadValues({}, copilotApiConfig.headers), publicApiKey ? { [COPILOT_CLOUD_PUBLIC_API_KEY_HEADER]: publicApiKey } : {});
|
|
29
|
-
const { maxTokens, stop, temperature = 0 } = apiConfig;
|
|
30
|
-
return useCallback(
|
|
31
|
-
(editorState, abortSignal) => __async(this, null, function* () {
|
|
32
|
-
const res = yield retry(() => __async(this, null, function* () {
|
|
33
|
-
var _a, _b, _c;
|
|
34
|
-
const messages = [
|
|
35
|
-
new TextMessage({
|
|
36
|
-
role: Role.System,
|
|
37
|
-
content: apiConfig.makeSystemPrompt(
|
|
38
|
-
textareaPurpose,
|
|
39
|
-
getContextString([], contextCategories)
|
|
40
|
-
)
|
|
41
|
-
}),
|
|
42
|
-
...apiConfig.fewShotMessages,
|
|
43
|
-
editorState.textAfterCursor != "" ? new TextMessage({
|
|
44
|
-
role: Role.User,
|
|
45
|
-
content: editorState.textAfterCursor
|
|
46
|
-
}) : null,
|
|
47
|
-
new TextMessage({
|
|
48
|
-
role: Role.User,
|
|
49
|
-
content: `<TextAfterCursor>${editorState.textAfterCursor}</TextAfterCursor>`
|
|
50
|
-
}),
|
|
51
|
-
new TextMessage({
|
|
52
|
-
role: Role.User,
|
|
53
|
-
content: `<TextBeforeCursor>${editorState.textBeforeCursor}</TextBeforeCursor>`
|
|
54
|
-
})
|
|
55
|
-
].filter(Boolean);
|
|
56
|
-
const response = {};
|
|
57
|
-
let result = "";
|
|
58
|
-
for (const message of convertGqlOutputToMessages(
|
|
59
|
-
(_c = (_b = (_a = response.data) == null ? void 0 : _a.generateCopilotResponse) == null ? void 0 : _b.messages) != null ? _c : []
|
|
60
|
-
)) {
|
|
61
|
-
if (abortSignal.aborted) {
|
|
62
|
-
break;
|
|
63
|
-
}
|
|
64
|
-
if (message.isTextMessage()) {
|
|
65
|
-
result += message.content;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
return result;
|
|
69
|
-
}));
|
|
70
|
-
return res;
|
|
71
|
-
}),
|
|
72
|
-
[apiConfig, getContextString, contextCategories, textareaPurpose]
|
|
73
|
-
);
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
export {
|
|
77
|
-
useMakeStandardAutosuggestionFunction
|
|
78
|
-
};
|
|
79
|
-
//# sourceMappingURL=chunk-UIBUYQPG.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.tsx"],"sourcesContent":["import { COPILOT_CLOUD_PUBLIC_API_KEY_HEADER } from \"@copilotkit/shared\";\nimport { useCopilotContext } from \"@copilotkit/react-core\";\nimport { useCallback } from \"react\";\nimport { AutosuggestionsBareFunction } from \"../../types\";\nimport { retry } from \"../../lib/retry\";\nimport { InsertionEditorState } from \"../../types/base/autosuggestions-bare-function\";\nimport { SuggestionsApiConfig } from \"../../types/autosuggestions-config/suggestions-api-config\";\nimport {\n Message,\n Role,\n TextMessage,\n convertGqlOutputToMessages,\n convertMessagesToGqlInput,\n filterAgentStateMessages,\n CopilotRequestType,\n} from \"@copilotkit/runtime-client-gql\";\n\n/**\n * Returns a memoized function that sends a request to the specified API endpoint to get an autosuggestion for the user's input.\n * The function takes in the text before and after the cursor, and an abort signal.\n * It sends a POST request to the API endpoint with the messages array containing the system message, few shot messages, and user messages.\n * The function returns the suggestion from the API response.\n *\n * @param textareaPurpose - The purpose of the textarea. This is included in the system message.\n * @param apiEndpoint - The API endpoint to send the autosuggestion request to.\n * @param makeSystemMessage - A function that takes in a context string and returns a system message to include in the autosuggestion request.\n * @param fewShotMessages - An array of few shot messages to include in the autosuggestion request.\n * @param contextCategories - The categories of context strings we want to include. By default, we include the (default) \"global\" context category.\n * @returns A memoized function that sends a request to the specified API endpoint to get an autosuggestion for the user's input.\n */\nexport function useMakeStandardAutosuggestionFunction(\n textareaPurpose: string,\n contextCategories: string[],\n apiConfig: SuggestionsApiConfig,\n): AutosuggestionsBareFunction {\n const runtimeClient = { generateCopilotResponse: (...args: any[]) => {} };\n const { getContextString, copilotApiConfig } = useCopilotContext();\n const {\n chatApiEndpoint: url,\n publicApiKey,\n credentials,\n properties,\n } = copilotApiConfig;\n const headers = {\n ...copilotApiConfig.headers,\n ...(publicApiKey\n ? { [COPILOT_CLOUD_PUBLIC_API_KEY_HEADER]: publicApiKey }\n : {}),\n };\n const { maxTokens, stop, temperature = 0 } = apiConfig;\n\n return useCallback(\n async (editorState: InsertionEditorState, abortSignal: AbortSignal) => {\n const res = await retry(async () => {\n // @ts-expect-error -- Passing null is forbidden, but we're filtering it later\n const messages: Message[] = [\n new TextMessage({\n role: Role.System,\n content: apiConfig.makeSystemPrompt(\n textareaPurpose,\n getContextString([], contextCategories),\n ),\n }),\n ...apiConfig.fewShotMessages,\n editorState.textAfterCursor != \"\"\n ? new TextMessage({\n role: Role.User,\n content: editorState.textAfterCursor,\n })\n : null,\n new TextMessage({\n role: Role.User,\n content: `<TextAfterCursor>${editorState.textAfterCursor}</TextAfterCursor>`,\n }),\n new TextMessage({\n role: Role.User,\n content: `<TextBeforeCursor>${editorState.textBeforeCursor}</TextBeforeCursor>`,\n }),\n ].filter(Boolean);\n\n // const response = await runtimeClient\n // .generateCopilotResponse({\n // data: {\n // frontend: {\n // actions: [],\n // url: window.location.href,\n // },\n // messages: convertMessagesToGqlInput(filterAgentStateMessages(messages)),\n // metadata: {\n // requestType: CopilotRequestType.TextareaCompletion,\n // },\n // forwardedParameters: {\n // maxTokens,\n // stop,\n // temperature,\n // },\n // },\n // properties,\n // signal: abortSignal,\n // })\n // .toPromise();\n const response: any = {};\n\n let result = \"\";\n for (const message of convertGqlOutputToMessages(\n response.data?.generateCopilotResponse?.messages ?? [],\n )) {\n if (abortSignal.aborted) {\n break;\n }\n if (message.isTextMessage()) {\n result += message.content;\n }\n }\n\n return result;\n });\n\n return res;\n },\n [apiConfig, getContextString, contextCategories, textareaPurpose],\n );\n}\n"],"mappings":";;;;;;;;;AAAA,SAAS,2CAA2C;AACpD,SAAS,yBAAyB;AAClC,SAAS,mBAAmB;AAK5B;AAAA,EAEE;AAAA,EACA;AAAA,EACA;AAAA,OAIK;AAeA,SAAS,sCACd,iBACA,mBACA,WAC6B;AAC7B,QAAM,gBAAgB,EAAE,yBAAyB,IAAI,SAAgB;AAAA,EAAC,EAAE;AACxE,QAAM,EAAE,kBAAkB,iBAAiB,IAAI,kBAAkB;AACjE,QAAM;AAAA,IACJ,iBAAiB;AAAA,IACjB;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI;AACJ,QAAM,UAAU,kCACX,iBAAiB,UAChB,eACA,EAAE,CAAC,mCAAmC,GAAG,aAAa,IACtD,CAAC;AAEP,QAAM,EAAE,WAAW,MAAM,cAAc,EAAE,IAAI;AAE7C,SAAO;AAAA,IACL,CAAO,aAAmC,gBAA6B;AACrE,YAAM,MAAM,MAAM,MAAM,MAAY;AArD1C;AAuDQ,cAAM,WAAsB;AAAA,UAC1B,IAAI,YAAY;AAAA,YACd,MAAM,KAAK;AAAA,YACX,SAAS,UAAU;AAAA,cACjB;AAAA,cACA,iBAAiB,CAAC,GAAG,iBAAiB;AAAA,YACxC;AAAA,UACF,CAAC;AAAA,UACD,GAAG,UAAU;AAAA,UACb,YAAY,mBAAmB,KAC3B,IAAI,YAAY;AAAA,YACd,MAAM,KAAK;AAAA,YACX,SAAS,YAAY;AAAA,UACvB,CAAC,IACD;AAAA,UACJ,IAAI,YAAY;AAAA,YACd,MAAM,KAAK;AAAA,YACX,SAAS,oBAAoB,YAAY;AAAA,UAC3C,CAAC;AAAA,UACD,IAAI,YAAY;AAAA,YACd,MAAM,KAAK;AAAA,YACX,SAAS,qBAAqB,YAAY;AAAA,UAC5C,CAAC;AAAA,QACH,EAAE,OAAO,OAAO;AAuBhB,cAAM,WAAgB,CAAC;AAEvB,YAAI,SAAS;AACb,mBAAW,WAAW;AAAA,WACpB,0BAAS,SAAT,mBAAe,4BAAf,mBAAwC,aAAxC,YAAoD,CAAC;AAAA,QACvD,GAAG;AACD,cAAI,YAAY,SAAS;AACvB;AAAA,UACF;AACA,cAAI,QAAQ,cAAc,GAAG;AAC3B,sBAAU,QAAQ;AAAA,UACpB;AAAA,QACF;AAEA,eAAO;AAAA,MACT,EAAC;AAED,aAAO;AAAA,IACT;AAAA,IACA,CAAC,WAAW,kBAAkB,mBAAmB,eAAe;AAAA,EAClE;AACF;","names":[]}
|
package/dist/chunk-VBPZTMXB.mjs
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
arraysAreEqual
|
|
3
|
-
} from "./chunk-VYLLLBUP.mjs";
|
|
4
|
-
|
|
5
|
-
// src/types/base/editor-autocomplete-state.ts
|
|
6
|
-
function areEqual_autocompleteState(prev, next) {
|
|
7
|
-
return prev.cursorPoint.offset === next.cursorPoint.offset && arraysAreEqual(prev.cursorPoint.path, next.cursorPoint.path) && prev.textBeforeCursor === next.textBeforeCursor && prev.textAfterCursor === next.textAfterCursor;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export {
|
|
11
|
-
areEqual_autocompleteState
|
|
12
|
-
};
|
|
13
|
-
//# sourceMappingURL=chunk-VBPZTMXB.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/types/base/editor-autocomplete-state.ts"],"sourcesContent":["import { BasePoint } from \"slate\";\nimport { arraysAreEqual } from \"../../lib/utils\";\n\nexport interface EditorAutocompleteState {\n cursorPoint: BasePoint;\n textBeforeCursor: string;\n textAfterCursor: string;\n}\n\nexport function areEqual_autocompleteState(\n prev: EditorAutocompleteState,\n next: EditorAutocompleteState,\n) {\n return (\n prev.cursorPoint.offset === next.cursorPoint.offset &&\n arraysAreEqual(prev.cursorPoint.path, next.cursorPoint.path) &&\n prev.textBeforeCursor === next.textBeforeCursor &&\n prev.textAfterCursor === next.textAfterCursor\n );\n}\n"],"mappings":";;;;;AASO,SAAS,2BACd,MACA,MACA;AACA,SACE,KAAK,YAAY,WAAW,KAAK,YAAY,UAC7C,eAAe,KAAK,YAAY,MAAM,KAAK,YAAY,IAAI,KAC3D,KAAK,qBAAqB,KAAK,oBAC/B,KAAK,oBAAoB,KAAK;AAElC;","names":[]}
|
package/dist/chunk-VH7INUR5.mjs
DELETED
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
// src/types/autosuggestions-config/editing-api-config.tsx
|
|
2
|
-
import { Role, TextMessage } from "@copilotkit/runtime-client-gql";
|
|
3
|
-
var defaultEditingMakeSystemPrompt = (textareaPurpose, contextString) => {
|
|
4
|
-
return `You are a versatile writing assistant helping the user edit a portion of their text.
|
|
5
|
-
|
|
6
|
-
The user is writing some text.
|
|
7
|
-
The purpose is: "${textareaPurpose}"
|
|
8
|
-
|
|
9
|
-
The following external context is also provided. Use it when relevant.
|
|
10
|
-
\`\`\`
|
|
11
|
-
${contextString}
|
|
12
|
-
\`\`\`
|
|
13
|
-
|
|
14
|
-
The user has provided you with a PROMPT for EDITING a PORTION of the text.
|
|
15
|
-
Your job is to come up with a new EDITED version OF THE SEGMENT IN QUESTION - AS BEST YOU CAN.
|
|
16
|
-
Only rewrite the portion of the text that the user has marked as "TextToEdit"!!!
|
|
17
|
-
|
|
18
|
-
Adjust yourself to the user's style and implied intent.
|
|
19
|
-
|
|
20
|
-
The conversation will be structured as follows:
|
|
21
|
-
<TextBeforeCursor>
|
|
22
|
-
<TextToEdit>
|
|
23
|
-
<TextAfterCursor>
|
|
24
|
-
<EditingPrompt>
|
|
25
|
-
|
|
26
|
-
<YourEditSuggestion>
|
|
27
|
-
`;
|
|
28
|
-
};
|
|
29
|
-
var defaultEditingFewShotMessages = [
|
|
30
|
-
new TextMessage({
|
|
31
|
-
role: Role.User,
|
|
32
|
-
content: "<TextBeforeCursor>This morning I woke up and went straight to the grocery store. </TextBeforeCursor>"
|
|
33
|
-
}),
|
|
34
|
-
new TextMessage({
|
|
35
|
-
role: Role.User,
|
|
36
|
-
content: "<TextToEdit>While I was there I picked up some apples, oranges, and bananas. </TextToEdit>"
|
|
37
|
-
}),
|
|
38
|
-
new TextMessage({
|
|
39
|
-
role: Role.User,
|
|
40
|
-
content: "<TextAfterCursor>The grocery store was having a sale on fruit, so I decided to stock up.</TextAfterCursor>"
|
|
41
|
-
}),
|
|
42
|
-
new TextMessage({
|
|
43
|
-
role: Role.User,
|
|
44
|
-
content: "<EditingPrompt>I also bought a big watermelon</EditingPrompt>"
|
|
45
|
-
}),
|
|
46
|
-
new TextMessage({
|
|
47
|
-
role: Role.Assistant,
|
|
48
|
-
content: "While I was there I picked up some apples, oranges, and bananas, and a big watermelon."
|
|
49
|
-
}),
|
|
50
|
-
new TextMessage({
|
|
51
|
-
role: Role.User,
|
|
52
|
-
content: "<TextBeforeCursor>Yesterday, I spent the afternoon working on my new project.</TextBeforeCursor>"
|
|
53
|
-
}),
|
|
54
|
-
new TextMessage({
|
|
55
|
-
role: Role.User,
|
|
56
|
-
content: "<TextToEdit>It's quite challenging and requires a lot of focus.</TextToEdit>"
|
|
57
|
-
}),
|
|
58
|
-
new TextMessage({
|
|
59
|
-
role: Role.User,
|
|
60
|
-
content: "<TextAfterCursor>I'm really excited about the potential outcomes of this project.</TextAfterCursor>"
|
|
61
|
-
}),
|
|
62
|
-
new TextMessage({
|
|
63
|
-
role: Role.User,
|
|
64
|
-
content: "<EditingPrompt>emphasize the complexity and my enthusiasm for the project</EditingPrompt>"
|
|
65
|
-
}),
|
|
66
|
-
new TextMessage({
|
|
67
|
-
role: Role.Assistant,
|
|
68
|
-
content: "It's a highly complex task that demands intense concentration, but I'm incredibly enthusiastic about the promising prospects of this project."
|
|
69
|
-
})
|
|
70
|
-
];
|
|
71
|
-
var defaultEditingApiConfig = {
|
|
72
|
-
makeSystemPrompt: defaultEditingMakeSystemPrompt,
|
|
73
|
-
fewShotMessages: defaultEditingFewShotMessages,
|
|
74
|
-
forwardedParams: void 0
|
|
75
|
-
};
|
|
76
|
-
|
|
77
|
-
export {
|
|
78
|
-
defaultEditingMakeSystemPrompt,
|
|
79
|
-
defaultEditingFewShotMessages,
|
|
80
|
-
defaultEditingApiConfig
|
|
81
|
-
};
|
|
82
|
-
//# sourceMappingURL=chunk-VH7INUR5.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/types/autosuggestions-config/editing-api-config.tsx"],"sourcesContent":["import { Message, Role, TextMessage } from \"@copilotkit/runtime-client-gql\";\nimport { MakeSystemPrompt } from \"./subtypes/make-system-prompt\";\n\nexport interface EditingApiConfig {\n makeSystemPrompt: MakeSystemPrompt;\n fewShotMessages: Message[];\n forwardedParams: { [key: string]: any } | undefined;\n}\n\nexport const defaultEditingMakeSystemPrompt: MakeSystemPrompt = (\n textareaPurpose,\n contextString,\n) => {\n return `You are a versatile writing assistant helping the user edit a portion of their text.\n \nThe user is writing some text.\nThe purpose is: \\\"${textareaPurpose}\\\"\n\nThe following external context is also provided. Use it when relevant.\n\\`\\`\\`\n${contextString}\n\\`\\`\\`\n\nThe user has provided you with a PROMPT for EDITING a PORTION of the text. \nYour job is to come up with a new EDITED version OF THE SEGMENT IN QUESTION - AS BEST YOU CAN.\nOnly rewrite the portion of the text that the user has marked as \"TextToEdit\"!!!\n\nAdjust yourself to the user's style and implied intent.\n\nThe conversation will be structured as follows:\n<TextBeforeCursor>\n<TextToEdit>\n<TextAfterCursor>\n<EditingPrompt>\n\n<YourEditSuggestion>\n`;\n};\n\nexport const defaultEditingFewShotMessages: Message[] = [\n new TextMessage({\n role: Role.User,\n content:\n \"<TextBeforeCursor>This morning I woke up and went straight to the grocery store. </TextBeforeCursor>\",\n }),\n new TextMessage({\n role: Role.User,\n content:\n \"<TextToEdit>While I was there I picked up some apples, oranges, and bananas. </TextToEdit>\",\n }),\n new TextMessage({\n role: Role.User,\n content:\n \"<TextAfterCursor>The grocery store was having a sale on fruit, so I decided to stock up.</TextAfterCursor>\",\n }),\n new TextMessage({\n role: Role.User,\n content: \"<EditingPrompt>I also bought a big watermelon</EditingPrompt>\",\n }),\n new TextMessage({\n role: Role.Assistant,\n content:\n \"While I was there I picked up some apples, oranges, and bananas, and a big watermelon.\",\n }),\n\n new TextMessage({\n role: Role.User,\n content:\n \"<TextBeforeCursor>Yesterday, I spent the afternoon working on my new project.</TextBeforeCursor>\",\n }),\n new TextMessage({\n role: Role.User,\n content:\n \"<TextToEdit>It's quite challenging and requires a lot of focus.</TextToEdit>\",\n }),\n new TextMessage({\n role: Role.User,\n content:\n \"<TextAfterCursor>I'm really excited about the potential outcomes of this project.</TextAfterCursor>\",\n }),\n new TextMessage({\n role: Role.User,\n content:\n \"<EditingPrompt>emphasize the complexity and my enthusiasm for the project</EditingPrompt>\",\n }),\n new TextMessage({\n role: Role.Assistant,\n content:\n \"It's a highly complex task that demands intense concentration, but I'm incredibly enthusiastic about the promising prospects of this project.\",\n }),\n];\n\nexport const defaultEditingApiConfig: EditingApiConfig = {\n makeSystemPrompt: defaultEditingMakeSystemPrompt,\n fewShotMessages: defaultEditingFewShotMessages,\n forwardedParams: undefined,\n};\n"],"mappings":";AAAA,SAAkB,MAAM,mBAAmB;AASpC,IAAM,iCAAmD,CAC9D,iBACA,kBACG;AACH,SAAO;AAAA;AAAA;AAAA,mBAGW;AAAA;AAAA;AAAA;AAAA,EAIlB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAiBF;AAEO,IAAM,gCAA2C;AAAA,EACtD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AAAA,EACD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AAAA,EACD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AAAA,EACD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SAAS;AAAA,EACX,CAAC;AAAA,EACD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AAAA,EAED,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AAAA,EACD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AAAA,EACD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AAAA,EACD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AAAA,EACD,IAAI,YAAY;AAAA,IACd,MAAM,KAAK;AAAA,IACX,SACE;AAAA,EACJ,CAAC;AACH;AAEO,IAAM,0BAA4C;AAAA,EACvD,kBAAkB;AAAA,EAClB,iBAAiB;AAAA,EACjB,iBAAiB;AACnB;","names":[]}
|