@docsearch/modal 4.5.4 → 4.6.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.
@@ -1,4 +1,4 @@
1
- import { DocSearchModalProps as DocSearchModalProps$1 } from '@docsearch/react/modal';
1
+ import { DocSearchModalProps as DocSearchModalProps$1 } from '@docsearch/react';
2
2
  import { JSX } from 'react';
3
3
 
4
4
  type DocSearchModalProps = Omit<DocSearchModalProps$1, 'initialScrollY' | 'isAskAiActive' | 'isHybridModeSupported' | 'keyboardShortcuts' | 'onAskAiToggle' | 'onClose' | 'theme'>;
@@ -1,6 +1,6 @@
1
1
  import { DocSearchButtonProps as DocSearchButtonProps$1 } from '@docsearch/react/button';
2
2
  import { JSX } from 'react';
3
- import { DocSearchModalProps as DocSearchModalProps$1 } from '@docsearch/react/modal';
3
+ import { DocSearchModalProps as DocSearchModalProps$1 } from '@docsearch/react';
4
4
 
5
5
  type DocSearchButtonProps = Omit<DocSearchButtonProps$1, 'keyboardShortcuts' | 'theme'>;
6
6
  declare function DocSearchButton({ onClick, ...props }: DocSearchButtonProps): JSX.Element;
@@ -1,3 +1,3 @@
1
- /*! @docsearch/modal 4.5.4 | MIT License | © Algolia, Inc. and contributors | https://docsearch.algolia.com */
1
+ /*! @docsearch/modal 4.6.0 | MIT License | © Algolia, Inc. and contributors | https://docsearch.algolia.com */
2
2
  !function(e,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("@docsearch/core"),require("@docsearch/react/button"),require("react")):"function"==typeof define&&define.amd?define(["exports","@docsearch/core","@docsearch/react/button","react"],r):r((e="undefined"!=typeof globalThis?globalThis:e||self).DocSearchModal={},e.DocSearchCore,e.button,e.React)}(this,function(e,r,t,n){"use strict";function o(){return o=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)({}).hasOwnProperty.call(t,n)&&(e[n]=t[n])}return e},o.apply(null,arguments)}var c=["onClick"];e.DocSearchButton=function(e){var a=e.onClick,i=function(e,r){if(null==e)return{};var t,n,o=function(e,r){if(null==e)return{};var t={};for(var n in e)if({}.hasOwnProperty.call(e,n)){if(-1!==r.indexOf(n))continue;t[n]=e[n]}return t}(e,r);if(Object.getOwnPropertySymbols){var c=Object.getOwnPropertySymbols(e);for(n=0;n<c.length;n++)t=c[n],-1===r.indexOf(t)&&{}.propertyIsEnumerable.call(e,t)&&(o[t]=e[t])}return o}(e,c),u=r.useDocSearch(),f=u.searchButtonRef,l=u.keyboardShortcuts,s=u.openModal;return n.createElement(t.DocSearchButton,o({ref:f,keyboardShortcuts:l,onClick:function(e){a&&a(e),s()}},i))}});
3
3
  //# sourceMappingURL=DocSearchButton.js.map
@@ -1,3 +1,3 @@
1
- /*! @docsearch/modal 4.5.4 | MIT License | © Algolia, Inc. and contributors | https://docsearch.algolia.com */
1
+ /*! @docsearch/modal 4.6.0 | MIT License | © Algolia, Inc. and contributors | https://docsearch.algolia.com */
2
2
  !function(e,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("@docsearch/core"),require("@docsearch/react/modal"),require("react"),require("react-dom")):"function"==typeof define&&define.amd?define(["exports","@docsearch/core","@docsearch/react/modal","react","react-dom"],r):r((e="undefined"!=typeof globalThis?globalThis:e||self).DocSearchModal={},e.DocSearchCore,e.modal,e.React,e.ReactDOM)}(this,function(e,r,t,o,i){"use strict";function n(e,r,t){return(r=function(e){var r=function(e,r){if("object"!=typeof e||!e)return e;var t=e[Symbol.toPrimitive];if(void 0!==t){var o=t.call(e,r||"default");if("object"!=typeof o)return o;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===r?String:Number)(e)}(e,"string");return"symbol"==typeof r?r:r+""}(r))in e?Object.defineProperty(e,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[r]=t,e}function c(e,r){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);r&&(o=o.filter(function(r){return Object.getOwnPropertyDescriptor(e,r).enumerable})),t.push.apply(t,o)}return t}function a(e){for(var r=1;r<arguments.length;r++){var t=null!=arguments[r]?arguments[r]:{};r%2?c(Object(t),!0).forEach(function(r){n(e,r,t[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):c(Object(t)).forEach(function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))})}return e}e.DocSearchModal=function(e){var n=r.useDocSearch(),c=n.isModalActive,u=n.onAskAiToggle,l=n.closeModal,s=n.isAskAiActive,f=n.initialQuery,d=n.registerView,p=n.isHybridModeSupported,b=o.useMemo(function(){var r;return null!==(r=e.portalContainer)&&void 0!==r?r:document.body},[e.portalContainer]),y=o.useMemo(function(){return window.scrollY},[]);o.useEffect(function(){d("modal")},[d]);var m=o.useMemo(function(){var r;return a(a({},e),{},{isAskAiActive:s,initialQuery:null!==(r=e.initialQuery)&&void 0!==r?r:f,initialScrollY:y,onAskAiToggle:u,onClose:l,isHybridModeSupported:p})},[e,s,f,y,u,l,p]);return c?i.createPortal(o.createElement(t.DocSearchModal,m),b):null}});
3
3
  //# sourceMappingURL=DocSearchModal.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DocSearchModal.js","sources":["../../src/DocSearchModal.tsx"],"sourcesContent":["import { useDocSearch } from '@docsearch/core';\nimport type { DocSearchModalProps as ModalProps } from '@docsearch/react/modal';\nimport { DocSearchModal as Modal } from '@docsearch/react/modal';\nimport type { JSX } from 'react';\nimport React from 'react';\nimport { createPortal } from 'react-dom';\n\nexport type DocSearchModalProps = Omit<\n ModalProps,\n | 'initialScrollY'\n | 'isAskAiActive'\n | 'isHybridModeSupported'\n | 'keyboardShortcuts'\n | 'onAskAiToggle'\n | 'onClose'\n | 'theme'\n>;\n\nexport function DocSearchModal(props: DocSearchModalProps): JSX.Element | null {\n const { isModalActive, onAskAiToggle, closeModal, isAskAiActive, initialQuery, registerView, isHybridModeSupported } =\n useDocSearch();\n\n const containerElement = React.useMemo(() => props.portalContainer ?? document.body, [props.portalContainer]);\n\n const initialScroll = React.useMemo(() => window.scrollY, []);\n\n React.useEffect(() => {\n registerView('modal');\n }, [registerView]);\n\n const modalProps: ModalProps = React.useMemo(\n () => ({\n ...props,\n isAskAiActive,\n initialQuery: props.initialQuery ?? initialQuery,\n initialScrollY: initialScroll,\n onAskAiToggle,\n onClose: closeModal,\n isHybridModeSupported,\n }),\n [props, isAskAiActive, initialQuery, initialScroll, onAskAiToggle, closeModal, isHybridModeSupported],\n );\n\n return isModalActive ? createPortal(<Modal {...modalProps} />, containerElement) : null;\n}\n"],"names":["props","_useDocSearch","useDocSearch","isModalActive","onAskAiToggle","closeModal","isAskAiActive","initialQuery","registerView","isHybridModeSupported","containerElement","React","useMemo","_props$portalContaine","portalContainer","undefined","document","body","initialScroll","window","scrollY","useEffect","modalProps","_props$initialQuery","_objectSpread","initialScrollY","onClose","createPortal","createElement","Modal"],"mappings":";i9CAkBO,SAAwBA,GAC7B,IAAAC,EACEC,EAAAA,eADMC,EAAaF,EAAbE,cAAeC,EAAaH,EAAbG,cAAeC,EAAUJ,EAAVI,WAAYC,EAAaL,EAAbK,cAAeC,EAAYN,EAAZM,aAAcC,EAAYP,EAAZO,aAAcC,EAAqBR,EAArBQ,sBAGvFC,EAAmBC,EAAMC,QAAQ,WAAA,IAAAC,EAAA,OAA2B,QAA3BA,EAAMb,EAAMc,uBAAeC,IAAAF,EAAAA,EAAIG,SAASC,IAAI,EAAE,CAACjB,EAAMc,kBAEtFI,EAAgBP,EAAMC,QAAQ,WAAA,OAAMO,OAAOC,OAAO,EAAE,IAE1DT,EAAMU,UAAU,WACdb,EAAa,QACf,EAAG,CAACA,IAEJ,IAAMc,EAAyBX,EAAMC,QACnC,WAAA,IAAAW,EAAA,OAAAC,EAAAA,EAAA,CAAA,EACKxB,GAAK,CAAA,EAAA,CACRM,cAAAA,EACAC,aAAgC,QAApBgB,EAAEvB,EAAMO,oBAAYQ,IAAAQ,EAAAA,EAAIhB,EACpCkB,eAAgBP,EAChBd,cAAAA,EACAsB,QAASrB,EACTI,sBAAAA,GAAqB,EAEvB,CAACT,EAAOM,EAAeC,EAAcW,EAAed,EAAeC,EAAYI,IAGjF,OAAON,EAAgBwB,EAAYA,aAAChB,EAAAiB,cAACC,EAAAA,eAAUP,GAAgBZ,GAAoB,IACrF"}
1
+ {"version":3,"file":"DocSearchModal.js","sources":["../../src/DocSearchModal.tsx"],"sourcesContent":["import { useDocSearch } from '@docsearch/core';\nimport type { DocSearchModalProps as ReactDocSearchModalProps } from '@docsearch/react';\nimport { DocSearchModal as Modal } from '@docsearch/react/modal';\nimport type { JSX } from 'react';\nimport React from 'react';\nimport { createPortal } from 'react-dom';\n\nexport type DocSearchModalProps = Omit<\n ReactDocSearchModalProps,\n | 'initialScrollY'\n | 'isAskAiActive'\n | 'isHybridModeSupported'\n | 'keyboardShortcuts'\n | 'onAskAiToggle'\n | 'onClose'\n | 'theme'\n>;\n\nexport function DocSearchModal(props: DocSearchModalProps): JSX.Element | null {\n const { isModalActive, onAskAiToggle, closeModal, isAskAiActive, initialQuery, registerView, isHybridModeSupported } =\n useDocSearch();\n\n const containerElement = React.useMemo(() => props.portalContainer ?? document.body, [props.portalContainer]);\n\n const initialScroll = React.useMemo(() => window.scrollY, []);\n\n React.useEffect(() => {\n registerView('modal');\n }, [registerView]);\n\n const modalProps: ReactDocSearchModalProps = React.useMemo(\n () => ({\n ...props,\n isAskAiActive,\n initialQuery: props.initialQuery ?? initialQuery,\n initialScrollY: initialScroll,\n onAskAiToggle,\n onClose: closeModal,\n isHybridModeSupported,\n }),\n [props, isAskAiActive, initialQuery, initialScroll, onAskAiToggle, closeModal, isHybridModeSupported],\n );\n\n return isModalActive ? createPortal(<Modal {...modalProps} />, containerElement) : null;\n}\n"],"names":["props","_useDocSearch","useDocSearch","isModalActive","onAskAiToggle","closeModal","isAskAiActive","initialQuery","registerView","isHybridModeSupported","containerElement","React","useMemo","_props$portalContaine","portalContainer","undefined","document","body","initialScroll","window","scrollY","useEffect","modalProps","_props$initialQuery","_objectSpread","initialScrollY","onClose","createPortal","createElement","Modal"],"mappings":";i9CAkBO,SAAwBA,GAC7B,IAAAC,EACEC,EAAAA,eADMC,EAAaF,EAAbE,cAAeC,EAAaH,EAAbG,cAAeC,EAAUJ,EAAVI,WAAYC,EAAaL,EAAbK,cAAeC,EAAYN,EAAZM,aAAcC,EAAYP,EAAZO,aAAcC,EAAqBR,EAArBQ,sBAGvFC,EAAmBC,EAAMC,QAAQ,WAAA,IAAAC,EAAA,OAA2B,QAA3BA,EAAMb,EAAMc,uBAAeC,IAAAF,EAAAA,EAAIG,SAASC,IAAI,EAAE,CAACjB,EAAMc,kBAEtFI,EAAgBP,EAAMC,QAAQ,WAAA,OAAMO,OAAOC,OAAO,EAAE,IAE1DT,EAAMU,UAAU,WACdb,EAAa,QACf,EAAG,CAACA,IAEJ,IAAMc,EAAuCX,EAAMC,QACjD,WAAA,IAAAW,EAAA,OAAAC,EAAAA,EAAA,CAAA,EACKxB,GAAK,CAAA,EAAA,CACRM,cAAAA,EACAC,aAAgC,QAApBgB,EAAEvB,EAAMO,oBAAYQ,IAAAQ,EAAAA,EAAIhB,EACpCkB,eAAgBP,EAChBd,cAAAA,EACAsB,QAASrB,EACTI,sBAAAA,GAAqB,EAEvB,CAACT,EAAOM,EAAeC,EAAcW,EAAed,EAAeC,EAAYI,IAGjF,OAAON,EAAgBwB,EAAYA,aAAChB,EAAAiB,cAACC,EAAAA,eAAUP,GAAgBZ,GAAoB,IACrF"}
package/dist/umd/index.js CHANGED
@@ -1,3 +1,3 @@
1
- /*! @docsearch/modal 4.5.4 | MIT License | © Algolia, Inc. and contributors | https://docsearch.algolia.com */
1
+ /*! @docsearch/modal 4.6.0 | MIT License | © Algolia, Inc. and contributors | https://docsearch.algolia.com */
2
2
  !function(e,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("@docsearch/core"),require("@docsearch/react/button"),require("react"),require("@docsearch/react/modal"),require("react-dom")):"function"==typeof define&&define.amd?define(["exports","@docsearch/core","@docsearch/react/button","react","@docsearch/react/modal","react-dom"],r):r((e="undefined"!=typeof globalThis?globalThis:e||self).DocSearchModal={},e.DocSearchCore,e.button,e.React,e.modal,e.ReactDOM)}(this,function(e,r,t,o,n,i){"use strict";function c(e,r,t){return(r=function(e){var r=function(e,r){if("object"!=typeof e||!e)return e;var t=e[Symbol.toPrimitive];if(void 0!==t){var o=t.call(e,r||"default");if("object"!=typeof o)return o;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===r?String:Number)(e)}(e,"string");return"symbol"==typeof r?r:r+""}(r))in e?Object.defineProperty(e,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[r]=t,e}function a(){return a=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var o in t)({}).hasOwnProperty.call(t,o)&&(e[o]=t[o])}return e},a.apply(null,arguments)}function u(e,r){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);r&&(o=o.filter(function(r){return Object.getOwnPropertyDescriptor(e,r).enumerable})),t.push.apply(t,o)}return t}function l(e){for(var r=1;r<arguments.length;r++){var t=null!=arguments[r]?arguments[r]:{};r%2?u(Object(t),!0).forEach(function(r){c(e,r,t[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):u(Object(t)).forEach(function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))})}return e}var f=["onClick"];e.DocSearchButton=function(e){var n=e.onClick,i=function(e,r){if(null==e)return{};var t,o,n=function(e,r){if(null==e)return{};var t={};for(var o in e)if({}.hasOwnProperty.call(e,o)){if(-1!==r.indexOf(o))continue;t[o]=e[o]}return t}(e,r);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(o=0;o<i.length;o++)t=i[o],-1===r.indexOf(t)&&{}.propertyIsEnumerable.call(e,t)&&(n[t]=e[t])}return n}(e,f),c=r.useDocSearch(),u=c.searchButtonRef,l=c.keyboardShortcuts,s=c.openModal;return o.createElement(t.DocSearchButton,a({ref:u,keyboardShortcuts:l,onClick:function(e){n&&n(e),s()}},i))},e.DocSearchModal=function(e){var t=r.useDocSearch(),c=t.isModalActive,a=t.onAskAiToggle,u=t.closeModal,f=t.isAskAiActive,s=t.initialQuery,d=t.registerView,p=t.isHybridModeSupported,b=o.useMemo(function(){var r;return null!==(r=e.portalContainer)&&void 0!==r?r:document.body},[e.portalContainer]),y=o.useMemo(function(){return window.scrollY},[]);o.useEffect(function(){d("modal")},[d]);var v=o.useMemo(function(){var r;return l(l({},e),{},{isAskAiActive:f,initialQuery:null!==(r=e.initialQuery)&&void 0!==r?r:s,initialScrollY:y,onAskAiToggle:a,onClose:u,isHybridModeSupported:p})},[e,f,s,y,a,u,p]);return c?i.createPortal(o.createElement(n.DocSearchModal,v),b):null}});
3
3
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/DocSearchButton.tsx","../../src/DocSearchModal.tsx"],"sourcesContent":["import { useDocSearch } from '@docsearch/core';\nimport { DocSearchButton as Button, type DocSearchButtonProps as ButtonProps } from '@docsearch/react/button';\nimport type { JSX } from 'react';\nimport React from 'react';\n\nexport type DocSearchButtonProps = Omit<ButtonProps, 'keyboardShortcuts' | 'theme'>;\n\nexport function DocSearchButton({ onClick, ...props }: DocSearchButtonProps): JSX.Element {\n const { searchButtonRef, keyboardShortcuts, openModal } = useDocSearch();\n\n return (\n <Button\n ref={searchButtonRef}\n keyboardShortcuts={keyboardShortcuts}\n onClick={(evt) => {\n if (onClick) {\n onClick(evt);\n }\n openModal();\n }}\n {...props}\n />\n );\n}\n","import { useDocSearch } from '@docsearch/core';\nimport type { DocSearchModalProps as ModalProps } from '@docsearch/react/modal';\nimport { DocSearchModal as Modal } from '@docsearch/react/modal';\nimport type { JSX } from 'react';\nimport React from 'react';\nimport { createPortal } from 'react-dom';\n\nexport type DocSearchModalProps = Omit<\n ModalProps,\n | 'initialScrollY'\n | 'isAskAiActive'\n | 'isHybridModeSupported'\n | 'keyboardShortcuts'\n | 'onAskAiToggle'\n | 'onClose'\n | 'theme'\n>;\n\nexport function DocSearchModal(props: DocSearchModalProps): JSX.Element | null {\n const { isModalActive, onAskAiToggle, closeModal, isAskAiActive, initialQuery, registerView, isHybridModeSupported } =\n useDocSearch();\n\n const containerElement = React.useMemo(() => props.portalContainer ?? document.body, [props.portalContainer]);\n\n const initialScroll = React.useMemo(() => window.scrollY, []);\n\n React.useEffect(() => {\n registerView('modal');\n }, [registerView]);\n\n const modalProps: ModalProps = React.useMemo(\n () => ({\n ...props,\n isAskAiActive,\n initialQuery: props.initialQuery ?? initialQuery,\n initialScrollY: initialScroll,\n onAskAiToggle,\n onClose: closeModal,\n isHybridModeSupported,\n }),\n [props, isAskAiActive, initialQuery, initialScroll, onAskAiToggle, closeModal, isHybridModeSupported],\n );\n\n return isModalActive ? createPortal(<Modal {...modalProps} />, containerElement) : null;\n}\n"],"names":["_ref","onClick","props","_objectWithoutProperties","_excluded","_useDocSearch","useDocSearch","searchButtonRef","keyboardShortcuts","openModal","React","createElement","Button","DocSearchButton","_extends","ref","evt","isModalActive","onAskAiToggle","closeModal","isAskAiActive","initialQuery","registerView","isHybridModeSupported","containerElement","useMemo","_props$portalContaine","portalContainer","undefined","document","body","initialScroll","window","scrollY","useEffect","modalProps","_props$initialQuery","_objectSpread","initialScrollY","onClose","createPortal","Modal"],"mappings":";owDAOO,SAAwBA,GAA2D,IAAxDC,EAAOD,EAAPC,QAAYC,+WAAKC,CAAAH,EAAAI,GACjDC,EAA0DC,EAAAA,eAAlDC,EAAeF,EAAfE,gBAAiBC,EAAiBH,EAAjBG,kBAAmBC,EAASJ,EAATI,UAE5C,OACEC,EAAAC,cAACC,EAAMC,gBAAAC,EAAA,CACLC,IAAKR,EACLC,kBAAmBA,EACnBP,QAAS,SAACe,GACJf,GACFA,EAAQe,GAEVP,GACF,GACIP,GAGV,mBCLO,SAAwBA,GAC7B,IAAAG,EACEC,EAAAA,eADMW,EAAaZ,EAAbY,cAAeC,EAAab,EAAba,cAAeC,EAAUd,EAAVc,WAAYC,EAAaf,EAAbe,cAAeC,EAAYhB,EAAZgB,aAAcC,EAAYjB,EAAZiB,aAAcC,EAAqBlB,EAArBkB,sBAGvFC,EAAmBd,EAAMe,QAAQ,WAAA,IAAAC,EAAA,OAA2B,QAA3BA,EAAMxB,EAAMyB,uBAAeC,IAAAF,EAAAA,EAAIG,SAASC,IAAI,EAAE,CAAC5B,EAAMyB,kBAEtFI,EAAgBrB,EAAMe,QAAQ,WAAA,OAAMO,OAAOC,OAAO,EAAE,IAE1DvB,EAAMwB,UAAU,WACdZ,EAAa,QACf,EAAG,CAACA,IAEJ,IAAMa,EAAyBzB,EAAMe,QACnC,WAAA,IAAAW,EAAA,OAAAC,EAAAA,EAAA,CAAA,EACKnC,GAAK,CAAA,EAAA,CACRkB,cAAAA,EACAC,aAAgC,QAApBe,EAAElC,EAAMmB,oBAAYO,IAAAQ,EAAAA,EAAIf,EACpCiB,eAAgBP,EAChBb,cAAAA,EACAqB,QAASpB,EACTI,sBAAAA,GAAqB,EAEvB,CAACrB,EAAOkB,EAAeC,EAAcU,EAAeb,EAAeC,EAAYI,IAGjF,OAAON,EAAgBuB,EAAYA,aAAC9B,EAAAC,cAAC8B,EAAAA,eAAUN,GAAgBX,GAAoB,IACrF"}
1
+ {"version":3,"file":"index.js","sources":["../../src/DocSearchButton.tsx","../../src/DocSearchModal.tsx"],"sourcesContent":["import { useDocSearch } from '@docsearch/core';\nimport { DocSearchButton as Button, type DocSearchButtonProps as ButtonProps } from '@docsearch/react/button';\nimport type { JSX } from 'react';\nimport React from 'react';\n\nexport type DocSearchButtonProps = Omit<ButtonProps, 'keyboardShortcuts' | 'theme'>;\n\nexport function DocSearchButton({ onClick, ...props }: DocSearchButtonProps): JSX.Element {\n const { searchButtonRef, keyboardShortcuts, openModal } = useDocSearch();\n\n return (\n <Button\n ref={searchButtonRef}\n keyboardShortcuts={keyboardShortcuts}\n onClick={(evt) => {\n if (onClick) {\n onClick(evt);\n }\n openModal();\n }}\n {...props}\n />\n );\n}\n","import { useDocSearch } from '@docsearch/core';\nimport type { DocSearchModalProps as ReactDocSearchModalProps } from '@docsearch/react';\nimport { DocSearchModal as Modal } from '@docsearch/react/modal';\nimport type { JSX } from 'react';\nimport React from 'react';\nimport { createPortal } from 'react-dom';\n\nexport type DocSearchModalProps = Omit<\n ReactDocSearchModalProps,\n | 'initialScrollY'\n | 'isAskAiActive'\n | 'isHybridModeSupported'\n | 'keyboardShortcuts'\n | 'onAskAiToggle'\n | 'onClose'\n | 'theme'\n>;\n\nexport function DocSearchModal(props: DocSearchModalProps): JSX.Element | null {\n const { isModalActive, onAskAiToggle, closeModal, isAskAiActive, initialQuery, registerView, isHybridModeSupported } =\n useDocSearch();\n\n const containerElement = React.useMemo(() => props.portalContainer ?? document.body, [props.portalContainer]);\n\n const initialScroll = React.useMemo(() => window.scrollY, []);\n\n React.useEffect(() => {\n registerView('modal');\n }, [registerView]);\n\n const modalProps: ReactDocSearchModalProps = React.useMemo(\n () => ({\n ...props,\n isAskAiActive,\n initialQuery: props.initialQuery ?? initialQuery,\n initialScrollY: initialScroll,\n onAskAiToggle,\n onClose: closeModal,\n isHybridModeSupported,\n }),\n [props, isAskAiActive, initialQuery, initialScroll, onAskAiToggle, closeModal, isHybridModeSupported],\n );\n\n return isModalActive ? createPortal(<Modal {...modalProps} />, containerElement) : null;\n}\n"],"names":["_ref","onClick","props","_objectWithoutProperties","_excluded","_useDocSearch","useDocSearch","searchButtonRef","keyboardShortcuts","openModal","React","createElement","Button","DocSearchButton","_extends","ref","evt","isModalActive","onAskAiToggle","closeModal","isAskAiActive","initialQuery","registerView","isHybridModeSupported","containerElement","useMemo","_props$portalContaine","portalContainer","undefined","document","body","initialScroll","window","scrollY","useEffect","modalProps","_props$initialQuery","_objectSpread","initialScrollY","onClose","createPortal","Modal"],"mappings":";owDAOO,SAAwBA,GAA2D,IAAxDC,EAAOD,EAAPC,QAAYC,+WAAKC,CAAAH,EAAAI,GACjDC,EAA0DC,EAAAA,eAAlDC,EAAeF,EAAfE,gBAAiBC,EAAiBH,EAAjBG,kBAAmBC,EAASJ,EAATI,UAE5C,OACEC,EAAAC,cAACC,EAAMC,gBAAAC,EAAA,CACLC,IAAKR,EACLC,kBAAmBA,EACnBP,QAAS,SAACe,GACJf,GACFA,EAAQe,GAEVP,GACF,GACIP,GAGV,mBCLO,SAAwBA,GAC7B,IAAAG,EACEC,EAAAA,eADMW,EAAaZ,EAAbY,cAAeC,EAAab,EAAba,cAAeC,EAAUd,EAAVc,WAAYC,EAAaf,EAAbe,cAAeC,EAAYhB,EAAZgB,aAAcC,EAAYjB,EAAZiB,aAAcC,EAAqBlB,EAArBkB,sBAGvFC,EAAmBd,EAAMe,QAAQ,WAAA,IAAAC,EAAA,OAA2B,QAA3BA,EAAMxB,EAAMyB,uBAAeC,IAAAF,EAAAA,EAAIG,SAASC,IAAI,EAAE,CAAC5B,EAAMyB,kBAEtFI,EAAgBrB,EAAMe,QAAQ,WAAA,OAAMO,OAAOC,OAAO,EAAE,IAE1DvB,EAAMwB,UAAU,WACdZ,EAAa,QACf,EAAG,CAACA,IAEJ,IAAMa,EAAuCzB,EAAMe,QACjD,WAAA,IAAAW,EAAA,OAAAC,EAAAA,EAAA,CAAA,EACKnC,GAAK,CAAA,EAAA,CACRkB,cAAAA,EACAC,aAAgC,QAApBe,EAAElC,EAAMmB,oBAAYO,IAAAQ,EAAAA,EAAIf,EACpCiB,eAAgBP,EAChBb,cAAAA,EACAqB,QAASpB,EACTI,sBAAAA,GAAqB,EAEvB,CAACrB,EAAOkB,EAAeC,EAAcU,EAAeb,EAAeC,EAAYI,IAGjF,OAAON,EAAgBuB,EAAYA,aAAC9B,EAAAC,cAAC8B,EAAAA,eAAUN,GAAgBX,GAAoB,IACrF"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@docsearch/modal",
3
3
  "description": "DocSearch modal package for keyword search and Ask AI.",
4
- "version": "4.5.4",
4
+ "version": "4.6.0",
5
5
  "license": "MIT",
6
6
  "homepage": "https://docsearch.algolia.com",
7
7
  "repository": {
@@ -43,8 +43,8 @@
43
43
  "watch": "nodemon --watch src --ext ts,tsx,js,jsx,json --ignore dist/ --ignore node_modules/ --verbose --delay 250ms --exec \"yarn on:change\""
44
44
  },
45
45
  "dependencies": {
46
- "@docsearch/core": "4.5.4",
47
- "@docsearch/react": "4.5.4"
46
+ "@docsearch/core": "4.6.0",
47
+ "@docsearch/react": "4.6.0"
48
48
  },
49
49
  "devDependencies": {
50
50
  "@rollup/plugin-replace": "6.0.2",