@bcrumbs.net/inbox 0.0.38 → 0.0.39

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. package/index.cjs.js +19 -15
  2. package/index.esm.js +19 -15
  3. package/package.json +1 -1
package/index.cjs.js CHANGED
@@ -42913,7 +42913,7 @@ const C$2={MaxFileSize:52428800,SupportedFormats:["png","jpg","jpeg","gif","bmp"
42913
42913
  white-space: nowrap;
42914
42914
  direction: ${e=>"arb"===e.language?"rtl":"ltr"};
42915
42915
  cursor: pointer;
42916
- max-width: 90%;
42916
+ max-width: 300px;
42917
42917
  min-width: 100px;
42918
42918
  width: auto;
42919
42919
  `,I$2=({className:n,context:t,isMyMessage:i,language:a})=>{const r=React.useCallback((()=>{const e=document.getElementById(y$2),n=document.getElementById(t.replyToId);e&&n&&(e.style.scrollBehavior="smooth",n.scrollIntoView());}),[t.replyToId]);return ReactJSXRuntime.jsx(k$2,{className:n,isMyMessage:i,language:a,onClick:r,children:"image"===t.replyToType?ReactJSXRuntime.jsx("img",{src:t.replyToContent,alt:"Media preview",style:{width:"30px",height:"30px",objectFit:"cover",marginLeft:"8px",verticalAlign:"middle"}}):t.replyToContent})},E$2=newStyled.div`
@@ -64723,12 +64723,12 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
64723
64723
  target: "er7h0t70",
64724
64724
  label: "Wrapper"
64725
64725
  })(process.env.NODE_ENV === "production" ? {
64726
- name: "gf1kui",
64727
- styles: "height:100%;display:flex;flex-wrap:wrap"
64726
+ name: "1lqhi21",
64727
+ styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden"
64728
64728
  } : {
64729
- name: "gf1kui",
64730
- styles: "height:100%;display:flex;flex-wrap:wrap",
64731
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAiB2B","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport Chat from '../app/inbox/components/Chat';\nimport { MOBILE_DIMENSION } from '../app/layout/constants';\nimport { InboxNoSelectionContainer, MobileContent, MobileMenu, MobileWrapper, defaultSelectedConvId } from '../app/inbox/components/Shared/Inbox';\nimport NewDetails from '../app/inbox/components/NewDetails';\nimport NewConvList from '../app/inbox/components/NewConvList';\nimport NewStartConv from '../app/inbox/components/Popups/NewStartConv';\nconst Wrapper = styled.div `\nheight: 100%;\ndisplay: flex;\nflex-wrap: wrap;\n`;\nconst NewStartConvModalStyle = css `\n  gap: 40px;\n  display: flex;\n  flex-direction: column;\n  padding: 24px;\n  max-width: 500px;\n`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const convListScrollRef = useRef(null);\n    const savedScrollPosition = useRef(0);\n    const { convs, loading, refetch: refetchConvs } = useConversationsPeriodicFetch(conv === null || conv === void 0 ? void 0 : conv.id, (conversation) => {\n        setConv(conversation);\n        if (onConversationChange) {\n            onConversationChange(conversation);\n        }\n    }, true, filters);\n    const { conversationTags, clientTags, clientStages, convStages, refetchTags, loadingTags } = useTags();\n    const { data: agentsData, loading: loadingAgents } = useAgentsQuery({\n        fetchPolicy: 'no-cache',\n        client: coreClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const { data: aisData } = useAisQuery({\n        fetchPolicy: 'no-cache',\n        client: botClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const onEndConv = useCallback(() => {\n        refetchTags();\n        setConv(undefined);\n    }, [refetchTags, setConv]);\n    // Select the last selected conv in case of refresh\n    useEffect(() => {\n        if (!conv && defaultSelectedConvId && convs && convs.length > 0) {\n            const targetConv = convs.find(m => m.id === defaultSelectedConvId);\n            if (targetConv)\n                setConv(targetConv);\n        }\n    }, [convs, conv]);\n    useEffect(() => {\n        if (initialFilters)\n            setFilters(initialFilters);\n    }, [initialFilters]);\n    // Restore scroll position when returning to convList view\n    useEffect(() => {\n        if (activePage === 'convList' && pageWidth <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { flex: '2.33', maxWidth: '350px', maxHeight: '100%' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '5', maxHeight: '100%' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) }) }), conv && showDetails && (_jsx(\"div\", { style: { flex: '2.33', maxWidth: '350px', maxHeight: '100%' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                } }) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl })] }));\n    }\n    // Otherwise return the mobile version\n    return (_jsxs(MobileWrapper, { className: \"row\", children: [_jsx(MobileContent, { children: activePage === 'convList' ? (_jsx(NewConvList, { convClicked: (convParam) => {\n                        if (convParam.id !== (conv === null || conv === void 0 ? void 0 : conv.id)) {\n                            if (convListScrollRef.current) {\n                                savedScrollPosition.current = convListScrollRef.current.scrollTop;\n                            }\n                            setConv(convParam);\n                            if (defaultSelectedConvId !== convParam.id) {\n                                localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, convParam.id);\n                            }\n                        }\n                        setActivePage('chat');\n                    }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                        setFilters(filters);\n                        if (onFiltersChange) {\n                            onFiltersChange(filters);\n                        }\n                    }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [], scrollContainerRef: convListScrollRef })) : activePage === 'chat' ? (_jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) })) : conv ? (_jsx(NewDetails, { clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], conv: conv, convStages: convStages })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
64729
+ name: "1lqhi21",
64730
+ styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden",
64731
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAiB2B","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport Chat from '../app/inbox/components/Chat';\nimport { MOBILE_DIMENSION } from '../app/layout/constants';\nimport { InboxNoSelectionContainer, MobileContent, MobileMenu, MobileWrapper, defaultSelectedConvId } from '../app/inbox/components/Shared/Inbox';\nimport NewDetails from '../app/inbox/components/NewDetails';\nimport NewConvList from '../app/inbox/components/NewConvList';\nimport NewStartConv from '../app/inbox/components/Popups/NewStartConv';\nconst Wrapper = styled.div `\nheight: 100%;\ndisplay: flex;\nflex-direction: row;\nflex-wrap: nowrap;\nalign-items: stretch;\noverflow: hidden;\n`;\nconst NewStartConvModalStyle = css `\n  gap: 40px;\n  display: flex;\n  flex-direction: column;\n  padding: 24px;\n  max-width: 500px;\n`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const convListScrollRef = useRef(null);\n    const savedScrollPosition = useRef(0);\n    const { convs, loading, refetch: refetchConvs } = useConversationsPeriodicFetch(conv === null || conv === void 0 ? void 0 : conv.id, (conversation) => {\n        setConv(conversation);\n        if (onConversationChange) {\n            onConversationChange(conversation);\n        }\n    }, true, filters);\n    const { conversationTags, clientTags, clientStages, convStages, refetchTags, loadingTags } = useTags();\n    const { data: agentsData, loading: loadingAgents } = useAgentsQuery({\n        fetchPolicy: 'no-cache',\n        client: coreClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const { data: aisData } = useAisQuery({\n        fetchPolicy: 'no-cache',\n        client: botClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const onEndConv = useCallback(() => {\n        refetchTags();\n        setConv(undefined);\n    }, [refetchTags, setConv]);\n    // Select the last selected conv in case of refresh\n    useEffect(() => {\n        if (!conv && defaultSelectedConvId && convs && convs.length > 0) {\n            const targetConv = convs.find(m => m.id === defaultSelectedConvId);\n            if (targetConv)\n                setConv(targetConv);\n        }\n    }, [convs, conv]);\n    useEffect(() => {\n        if (initialFilters)\n            setFilters(initialFilters);\n    }, [initialFilters]);\n    // Restore scroll position when returning to convList view\n    useEffect(() => {\n        if (activePage === 'convList' && pageWidth <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                } }) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl })] }));\n    }\n    // Otherwise return the mobile version\n    return (_jsxs(MobileWrapper, { className: \"row\", children: [_jsx(MobileContent, { children: activePage === 'convList' ? (_jsx(NewConvList, { convClicked: (convParam) => {\n                        if (convParam.id !== (conv === null || conv === void 0 ? void 0 : conv.id)) {\n                            if (convListScrollRef.current) {\n                                savedScrollPosition.current = convListScrollRef.current.scrollTop;\n                            }\n                            setConv(convParam);\n                            if (defaultSelectedConvId !== convParam.id) {\n                                localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, convParam.id);\n                            }\n                        }\n                        setActivePage('chat');\n                    }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                        setFilters(filters);\n                        if (onFiltersChange) {\n                            onFiltersChange(filters);\n                        }\n                    }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [], scrollContainerRef: convListScrollRef })) : activePage === 'chat' ? (_jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) })) : conv ? (_jsx(NewDetails, { clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], conv: conv, convStages: convStages })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
64732
64732
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
64733
64733
  });
64734
64734
  const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
@@ -64737,7 +64737,7 @@ const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
64737
64737
  } : {
64738
64738
  name: "610onk-NewStartConvModalStyle",
64739
64739
  styles: "gap:40px;display:flex;flex-direction:column;padding:24px;max-width:500px;label:NewStartConvModalStyle;",
64740
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAsBmC","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport Chat from '../app/inbox/components/Chat';\nimport { MOBILE_DIMENSION } from '../app/layout/constants';\nimport { InboxNoSelectionContainer, MobileContent, MobileMenu, MobileWrapper, defaultSelectedConvId } from '../app/inbox/components/Shared/Inbox';\nimport NewDetails from '../app/inbox/components/NewDetails';\nimport NewConvList from '../app/inbox/components/NewConvList';\nimport NewStartConv from '../app/inbox/components/Popups/NewStartConv';\nconst Wrapper = styled.div `\nheight: 100%;\ndisplay: flex;\nflex-wrap: wrap;\n`;\nconst NewStartConvModalStyle = css `\n  gap: 40px;\n  display: flex;\n  flex-direction: column;\n  padding: 24px;\n  max-width: 500px;\n`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const convListScrollRef = useRef(null);\n    const savedScrollPosition = useRef(0);\n    const { convs, loading, refetch: refetchConvs } = useConversationsPeriodicFetch(conv === null || conv === void 0 ? void 0 : conv.id, (conversation) => {\n        setConv(conversation);\n        if (onConversationChange) {\n            onConversationChange(conversation);\n        }\n    }, true, filters);\n    const { conversationTags, clientTags, clientStages, convStages, refetchTags, loadingTags } = useTags();\n    const { data: agentsData, loading: loadingAgents } = useAgentsQuery({\n        fetchPolicy: 'no-cache',\n        client: coreClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const { data: aisData } = useAisQuery({\n        fetchPolicy: 'no-cache',\n        client: botClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const onEndConv = useCallback(() => {\n        refetchTags();\n        setConv(undefined);\n    }, [refetchTags, setConv]);\n    // Select the last selected conv in case of refresh\n    useEffect(() => {\n        if (!conv && defaultSelectedConvId && convs && convs.length > 0) {\n            const targetConv = convs.find(m => m.id === defaultSelectedConvId);\n            if (targetConv)\n                setConv(targetConv);\n        }\n    }, [convs, conv]);\n    useEffect(() => {\n        if (initialFilters)\n            setFilters(initialFilters);\n    }, [initialFilters]);\n    // Restore scroll position when returning to convList view\n    useEffect(() => {\n        if (activePage === 'convList' && pageWidth <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { flex: '2.33', maxWidth: '350px', maxHeight: '100%' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '5', maxHeight: '100%' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) }) }), conv && showDetails && (_jsx(\"div\", { style: { flex: '2.33', maxWidth: '350px', maxHeight: '100%' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                } }) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl })] }));\n    }\n    // Otherwise return the mobile version\n    return (_jsxs(MobileWrapper, { className: \"row\", children: [_jsx(MobileContent, { children: activePage === 'convList' ? (_jsx(NewConvList, { convClicked: (convParam) => {\n                        if (convParam.id !== (conv === null || conv === void 0 ? void 0 : conv.id)) {\n                            if (convListScrollRef.current) {\n                                savedScrollPosition.current = convListScrollRef.current.scrollTop;\n                            }\n                            setConv(convParam);\n                            if (defaultSelectedConvId !== convParam.id) {\n                                localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, convParam.id);\n                            }\n                        }\n                        setActivePage('chat');\n                    }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                        setFilters(filters);\n                        if (onFiltersChange) {\n                            onFiltersChange(filters);\n                        }\n                    }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [], scrollContainerRef: convListScrollRef })) : activePage === 'chat' ? (_jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) })) : conv ? (_jsx(NewDetails, { clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], conv: conv, convStages: convStages })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
64740
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAyBmC","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport Chat from '../app/inbox/components/Chat';\nimport { MOBILE_DIMENSION } from '../app/layout/constants';\nimport { InboxNoSelectionContainer, MobileContent, MobileMenu, MobileWrapper, defaultSelectedConvId } from '../app/inbox/components/Shared/Inbox';\nimport NewDetails from '../app/inbox/components/NewDetails';\nimport NewConvList from '../app/inbox/components/NewConvList';\nimport NewStartConv from '../app/inbox/components/Popups/NewStartConv';\nconst Wrapper = styled.div `\nheight: 100%;\ndisplay: flex;\nflex-direction: row;\nflex-wrap: nowrap;\nalign-items: stretch;\noverflow: hidden;\n`;\nconst NewStartConvModalStyle = css `\n  gap: 40px;\n  display: flex;\n  flex-direction: column;\n  padding: 24px;\n  max-width: 500px;\n`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const convListScrollRef = useRef(null);\n    const savedScrollPosition = useRef(0);\n    const { convs, loading, refetch: refetchConvs } = useConversationsPeriodicFetch(conv === null || conv === void 0 ? void 0 : conv.id, (conversation) => {\n        setConv(conversation);\n        if (onConversationChange) {\n            onConversationChange(conversation);\n        }\n    }, true, filters);\n    const { conversationTags, clientTags, clientStages, convStages, refetchTags, loadingTags } = useTags();\n    const { data: agentsData, loading: loadingAgents } = useAgentsQuery({\n        fetchPolicy: 'no-cache',\n        client: coreClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const { data: aisData } = useAisQuery({\n        fetchPolicy: 'no-cache',\n        client: botClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const onEndConv = useCallback(() => {\n        refetchTags();\n        setConv(undefined);\n    }, [refetchTags, setConv]);\n    // Select the last selected conv in case of refresh\n    useEffect(() => {\n        if (!conv && defaultSelectedConvId && convs && convs.length > 0) {\n            const targetConv = convs.find(m => m.id === defaultSelectedConvId);\n            if (targetConv)\n                setConv(targetConv);\n        }\n    }, [convs, conv]);\n    useEffect(() => {\n        if (initialFilters)\n            setFilters(initialFilters);\n    }, [initialFilters]);\n    // Restore scroll position when returning to convList view\n    useEffect(() => {\n        if (activePage === 'convList' && pageWidth <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                } }) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl })] }));\n    }\n    // Otherwise return the mobile version\n    return (_jsxs(MobileWrapper, { className: \"row\", children: [_jsx(MobileContent, { children: activePage === 'convList' ? (_jsx(NewConvList, { convClicked: (convParam) => {\n                        if (convParam.id !== (conv === null || conv === void 0 ? void 0 : conv.id)) {\n                            if (convListScrollRef.current) {\n                                savedScrollPosition.current = convListScrollRef.current.scrollTop;\n                            }\n                            setConv(convParam);\n                            if (defaultSelectedConvId !== convParam.id) {\n                                localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, convParam.id);\n                            }\n                        }\n                        setActivePage('chat');\n                    }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                        setFilters(filters);\n                        if (onFiltersChange) {\n                            onFiltersChange(filters);\n                        }\n                    }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [], scrollContainerRef: convListScrollRef })) : activePage === 'chat' ? (_jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) })) : conv ? (_jsx(NewDetails, { clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], conv: conv, convStages: convStages })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
64741
64741
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
64742
64742
  };
64743
64743
  const Inbox = ({
@@ -64826,9 +64826,10 @@ const Inbox = ({
64826
64826
  rtl: !!rtl,
64827
64827
  children: [jsx$1("div", {
64828
64828
  style: {
64829
- flex: '2.33',
64830
- maxWidth: '350px',
64831
- maxHeight: '100%'
64829
+ width: '350px',
64830
+ flexShrink: 0,
64831
+ maxHeight: '100%',
64832
+ overflow: 'hidden'
64832
64833
  },
64833
64834
  children: jsx$1(NewConvList, {
64834
64835
  convClicked: cov => {
@@ -64855,8 +64856,10 @@ const Inbox = ({
64855
64856
  })
64856
64857
  }), jsx$1("div", {
64857
64858
  style: {
64858
- flex: '5',
64859
- maxHeight: '100%'
64859
+ flex: '1 1 auto',
64860
+ minWidth: 0,
64861
+ maxHeight: '100%',
64862
+ overflow: 'hidden'
64860
64863
  },
64861
64864
  children: jsx$1(Chat, {
64862
64865
  selectedConv: conv,
@@ -64870,9 +64873,10 @@ const Inbox = ({
64870
64873
  })
64871
64874
  }), conv && showDetails && jsx$1("div", {
64872
64875
  style: {
64873
- flex: '2.33',
64874
- maxWidth: '350px',
64875
- maxHeight: '100%'
64876
+ width: '350px',
64877
+ flexShrink: 0,
64878
+ maxHeight: '100%',
64879
+ overflow: 'hidden'
64876
64880
  },
64877
64881
  children: jsx$1(NewDetails
64878
64882
  // agentsLoading={loadingAgents}
package/index.esm.js CHANGED
@@ -42895,7 +42895,7 @@ const C$2={MaxFileSize:52428800,SupportedFormats:["png","jpg","jpeg","gif","bmp"
42895
42895
  white-space: nowrap;
42896
42896
  direction: ${e=>"arb"===e.language?"rtl":"ltr"};
42897
42897
  cursor: pointer;
42898
- max-width: 90%;
42898
+ max-width: 300px;
42899
42899
  min-width: 100px;
42900
42900
  width: auto;
42901
42901
  `,I$2=({className:n,context:t,isMyMessage:i,language:a})=>{const r=useCallback((()=>{const e=document.getElementById(y$2),n=document.getElementById(t.replyToId);e&&n&&(e.style.scrollBehavior="smooth",n.scrollIntoView());}),[t.replyToId]);return jsx$2(k$2,{className:n,isMyMessage:i,language:a,onClick:r,children:"image"===t.replyToType?jsx$2("img",{src:t.replyToContent,alt:"Media preview",style:{width:"30px",height:"30px",objectFit:"cover",marginLeft:"8px",verticalAlign:"middle"}}):t.replyToContent})},E$2=newStyled.div`
@@ -64705,12 +64705,12 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
64705
64705
  target: "er7h0t70",
64706
64706
  label: "Wrapper"
64707
64707
  })(process.env.NODE_ENV === "production" ? {
64708
- name: "gf1kui",
64709
- styles: "height:100%;display:flex;flex-wrap:wrap"
64708
+ name: "1lqhi21",
64709
+ styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden"
64710
64710
  } : {
64711
- name: "gf1kui",
64712
- styles: "height:100%;display:flex;flex-wrap:wrap",
64713
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAiB2B","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport Chat from '../app/inbox/components/Chat';\nimport { MOBILE_DIMENSION } from '../app/layout/constants';\nimport { InboxNoSelectionContainer, MobileContent, MobileMenu, MobileWrapper, defaultSelectedConvId } from '../app/inbox/components/Shared/Inbox';\nimport NewDetails from '../app/inbox/components/NewDetails';\nimport NewConvList from '../app/inbox/components/NewConvList';\nimport NewStartConv from '../app/inbox/components/Popups/NewStartConv';\nconst Wrapper = styled.div `\nheight: 100%;\ndisplay: flex;\nflex-wrap: wrap;\n`;\nconst NewStartConvModalStyle = css `\n  gap: 40px;\n  display: flex;\n  flex-direction: column;\n  padding: 24px;\n  max-width: 500px;\n`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const convListScrollRef = useRef(null);\n    const savedScrollPosition = useRef(0);\n    const { convs, loading, refetch: refetchConvs } = useConversationsPeriodicFetch(conv === null || conv === void 0 ? void 0 : conv.id, (conversation) => {\n        setConv(conversation);\n        if (onConversationChange) {\n            onConversationChange(conversation);\n        }\n    }, true, filters);\n    const { conversationTags, clientTags, clientStages, convStages, refetchTags, loadingTags } = useTags();\n    const { data: agentsData, loading: loadingAgents } = useAgentsQuery({\n        fetchPolicy: 'no-cache',\n        client: coreClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const { data: aisData } = useAisQuery({\n        fetchPolicy: 'no-cache',\n        client: botClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const onEndConv = useCallback(() => {\n        refetchTags();\n        setConv(undefined);\n    }, [refetchTags, setConv]);\n    // Select the last selected conv in case of refresh\n    useEffect(() => {\n        if (!conv && defaultSelectedConvId && convs && convs.length > 0) {\n            const targetConv = convs.find(m => m.id === defaultSelectedConvId);\n            if (targetConv)\n                setConv(targetConv);\n        }\n    }, [convs, conv]);\n    useEffect(() => {\n        if (initialFilters)\n            setFilters(initialFilters);\n    }, [initialFilters]);\n    // Restore scroll position when returning to convList view\n    useEffect(() => {\n        if (activePage === 'convList' && pageWidth <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { flex: '2.33', maxWidth: '350px', maxHeight: '100%' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '5', maxHeight: '100%' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) }) }), conv && showDetails && (_jsx(\"div\", { style: { flex: '2.33', maxWidth: '350px', maxHeight: '100%' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                } }) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl })] }));\n    }\n    // Otherwise return the mobile version\n    return (_jsxs(MobileWrapper, { className: \"row\", children: [_jsx(MobileContent, { children: activePage === 'convList' ? (_jsx(NewConvList, { convClicked: (convParam) => {\n                        if (convParam.id !== (conv === null || conv === void 0 ? void 0 : conv.id)) {\n                            if (convListScrollRef.current) {\n                                savedScrollPosition.current = convListScrollRef.current.scrollTop;\n                            }\n                            setConv(convParam);\n                            if (defaultSelectedConvId !== convParam.id) {\n                                localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, convParam.id);\n                            }\n                        }\n                        setActivePage('chat');\n                    }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                        setFilters(filters);\n                        if (onFiltersChange) {\n                            onFiltersChange(filters);\n                        }\n                    }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [], scrollContainerRef: convListScrollRef })) : activePage === 'chat' ? (_jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) })) : conv ? (_jsx(NewDetails, { clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], conv: conv, convStages: convStages })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
64711
+ name: "1lqhi21",
64712
+ styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden",
64713
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAiB2B","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport Chat from '../app/inbox/components/Chat';\nimport { MOBILE_DIMENSION } from '../app/layout/constants';\nimport { InboxNoSelectionContainer, MobileContent, MobileMenu, MobileWrapper, defaultSelectedConvId } from '../app/inbox/components/Shared/Inbox';\nimport NewDetails from '../app/inbox/components/NewDetails';\nimport NewConvList from '../app/inbox/components/NewConvList';\nimport NewStartConv from '../app/inbox/components/Popups/NewStartConv';\nconst Wrapper = styled.div `\nheight: 100%;\ndisplay: flex;\nflex-direction: row;\nflex-wrap: nowrap;\nalign-items: stretch;\noverflow: hidden;\n`;\nconst NewStartConvModalStyle = css `\n  gap: 40px;\n  display: flex;\n  flex-direction: column;\n  padding: 24px;\n  max-width: 500px;\n`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const convListScrollRef = useRef(null);\n    const savedScrollPosition = useRef(0);\n    const { convs, loading, refetch: refetchConvs } = useConversationsPeriodicFetch(conv === null || conv === void 0 ? void 0 : conv.id, (conversation) => {\n        setConv(conversation);\n        if (onConversationChange) {\n            onConversationChange(conversation);\n        }\n    }, true, filters);\n    const { conversationTags, clientTags, clientStages, convStages, refetchTags, loadingTags } = useTags();\n    const { data: agentsData, loading: loadingAgents } = useAgentsQuery({\n        fetchPolicy: 'no-cache',\n        client: coreClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const { data: aisData } = useAisQuery({\n        fetchPolicy: 'no-cache',\n        client: botClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const onEndConv = useCallback(() => {\n        refetchTags();\n        setConv(undefined);\n    }, [refetchTags, setConv]);\n    // Select the last selected conv in case of refresh\n    useEffect(() => {\n        if (!conv && defaultSelectedConvId && convs && convs.length > 0) {\n            const targetConv = convs.find(m => m.id === defaultSelectedConvId);\n            if (targetConv)\n                setConv(targetConv);\n        }\n    }, [convs, conv]);\n    useEffect(() => {\n        if (initialFilters)\n            setFilters(initialFilters);\n    }, [initialFilters]);\n    // Restore scroll position when returning to convList view\n    useEffect(() => {\n        if (activePage === 'convList' && pageWidth <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                } }) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl })] }));\n    }\n    // Otherwise return the mobile version\n    return (_jsxs(MobileWrapper, { className: \"row\", children: [_jsx(MobileContent, { children: activePage === 'convList' ? (_jsx(NewConvList, { convClicked: (convParam) => {\n                        if (convParam.id !== (conv === null || conv === void 0 ? void 0 : conv.id)) {\n                            if (convListScrollRef.current) {\n                                savedScrollPosition.current = convListScrollRef.current.scrollTop;\n                            }\n                            setConv(convParam);\n                            if (defaultSelectedConvId !== convParam.id) {\n                                localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, convParam.id);\n                            }\n                        }\n                        setActivePage('chat');\n                    }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                        setFilters(filters);\n                        if (onFiltersChange) {\n                            onFiltersChange(filters);\n                        }\n                    }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [], scrollContainerRef: convListScrollRef })) : activePage === 'chat' ? (_jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) })) : conv ? (_jsx(NewDetails, { clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], conv: conv, convStages: convStages })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
64714
64714
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
64715
64715
  });
64716
64716
  const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
@@ -64719,7 +64719,7 @@ const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
64719
64719
  } : {
64720
64720
  name: "610onk-NewStartConvModalStyle",
64721
64721
  styles: "gap:40px;display:flex;flex-direction:column;padding:24px;max-width:500px;label:NewStartConvModalStyle;",
64722
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAsBmC","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport Chat from '../app/inbox/components/Chat';\nimport { MOBILE_DIMENSION } from '../app/layout/constants';\nimport { InboxNoSelectionContainer, MobileContent, MobileMenu, MobileWrapper, defaultSelectedConvId } from '../app/inbox/components/Shared/Inbox';\nimport NewDetails from '../app/inbox/components/NewDetails';\nimport NewConvList from '../app/inbox/components/NewConvList';\nimport NewStartConv from '../app/inbox/components/Popups/NewStartConv';\nconst Wrapper = styled.div `\nheight: 100%;\ndisplay: flex;\nflex-wrap: wrap;\n`;\nconst NewStartConvModalStyle = css `\n  gap: 40px;\n  display: flex;\n  flex-direction: column;\n  padding: 24px;\n  max-width: 500px;\n`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const convListScrollRef = useRef(null);\n    const savedScrollPosition = useRef(0);\n    const { convs, loading, refetch: refetchConvs } = useConversationsPeriodicFetch(conv === null || conv === void 0 ? void 0 : conv.id, (conversation) => {\n        setConv(conversation);\n        if (onConversationChange) {\n            onConversationChange(conversation);\n        }\n    }, true, filters);\n    const { conversationTags, clientTags, clientStages, convStages, refetchTags, loadingTags } = useTags();\n    const { data: agentsData, loading: loadingAgents } = useAgentsQuery({\n        fetchPolicy: 'no-cache',\n        client: coreClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const { data: aisData } = useAisQuery({\n        fetchPolicy: 'no-cache',\n        client: botClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const onEndConv = useCallback(() => {\n        refetchTags();\n        setConv(undefined);\n    }, [refetchTags, setConv]);\n    // Select the last selected conv in case of refresh\n    useEffect(() => {\n        if (!conv && defaultSelectedConvId && convs && convs.length > 0) {\n            const targetConv = convs.find(m => m.id === defaultSelectedConvId);\n            if (targetConv)\n                setConv(targetConv);\n        }\n    }, [convs, conv]);\n    useEffect(() => {\n        if (initialFilters)\n            setFilters(initialFilters);\n    }, [initialFilters]);\n    // Restore scroll position when returning to convList view\n    useEffect(() => {\n        if (activePage === 'convList' && pageWidth <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { flex: '2.33', maxWidth: '350px', maxHeight: '100%' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '5', maxHeight: '100%' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) }) }), conv && showDetails && (_jsx(\"div\", { style: { flex: '2.33', maxWidth: '350px', maxHeight: '100%' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                } }) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl })] }));\n    }\n    // Otherwise return the mobile version\n    return (_jsxs(MobileWrapper, { className: \"row\", children: [_jsx(MobileContent, { children: activePage === 'convList' ? (_jsx(NewConvList, { convClicked: (convParam) => {\n                        if (convParam.id !== (conv === null || conv === void 0 ? void 0 : conv.id)) {\n                            if (convListScrollRef.current) {\n                                savedScrollPosition.current = convListScrollRef.current.scrollTop;\n                            }\n                            setConv(convParam);\n                            if (defaultSelectedConvId !== convParam.id) {\n                                localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, convParam.id);\n                            }\n                        }\n                        setActivePage('chat');\n                    }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                        setFilters(filters);\n                        if (onFiltersChange) {\n                            onFiltersChange(filters);\n                        }\n                    }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [], scrollContainerRef: convListScrollRef })) : activePage === 'chat' ? (_jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) })) : conv ? (_jsx(NewDetails, { clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], conv: conv, convStages: convStages })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
64722
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAyBmC","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport Chat from '../app/inbox/components/Chat';\nimport { MOBILE_DIMENSION } from '../app/layout/constants';\nimport { InboxNoSelectionContainer, MobileContent, MobileMenu, MobileWrapper, defaultSelectedConvId } from '../app/inbox/components/Shared/Inbox';\nimport NewDetails from '../app/inbox/components/NewDetails';\nimport NewConvList from '../app/inbox/components/NewConvList';\nimport NewStartConv from '../app/inbox/components/Popups/NewStartConv';\nconst Wrapper = styled.div `\nheight: 100%;\ndisplay: flex;\nflex-direction: row;\nflex-wrap: nowrap;\nalign-items: stretch;\noverflow: hidden;\n`;\nconst NewStartConvModalStyle = css `\n  gap: 40px;\n  display: flex;\n  flex-direction: column;\n  padding: 24px;\n  max-width: 500px;\n`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const convListScrollRef = useRef(null);\n    const savedScrollPosition = useRef(0);\n    const { convs, loading, refetch: refetchConvs } = useConversationsPeriodicFetch(conv === null || conv === void 0 ? void 0 : conv.id, (conversation) => {\n        setConv(conversation);\n        if (onConversationChange) {\n            onConversationChange(conversation);\n        }\n    }, true, filters);\n    const { conversationTags, clientTags, clientStages, convStages, refetchTags, loadingTags } = useTags();\n    const { data: agentsData, loading: loadingAgents } = useAgentsQuery({\n        fetchPolicy: 'no-cache',\n        client: coreClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const { data: aisData } = useAisQuery({\n        fetchPolicy: 'no-cache',\n        client: botClient,\n        variables: {\n            input: {\n                workspaceId: auth.getContext(),\n            },\n        },\n    });\n    const onEndConv = useCallback(() => {\n        refetchTags();\n        setConv(undefined);\n    }, [refetchTags, setConv]);\n    // Select the last selected conv in case of refresh\n    useEffect(() => {\n        if (!conv && defaultSelectedConvId && convs && convs.length > 0) {\n            const targetConv = convs.find(m => m.id === defaultSelectedConvId);\n            if (targetConv)\n                setConv(targetConv);\n        }\n    }, [convs, conv]);\n    useEffect(() => {\n        if (initialFilters)\n            setFilters(initialFilters);\n    }, [initialFilters]);\n    // Restore scroll position when returning to convList view\n    useEffect(() => {\n        if (activePage === 'convList' && pageWidth <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                } }) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl })] }));\n    }\n    // Otherwise return the mobile version\n    return (_jsxs(MobileWrapper, { className: \"row\", children: [_jsx(MobileContent, { children: activePage === 'convList' ? (_jsx(NewConvList, { convClicked: (convParam) => {\n                        if (convParam.id !== (conv === null || conv === void 0 ? void 0 : conv.id)) {\n                            if (convListScrollRef.current) {\n                                savedScrollPosition.current = convListScrollRef.current.scrollTop;\n                            }\n                            setConv(convParam);\n                            if (defaultSelectedConvId !== convParam.id) {\n                                localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, convParam.id);\n                            }\n                        }\n                        setActivePage('chat');\n                    }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                        setFilters(filters);\n                        if (onFiltersChange) {\n                            onFiltersChange(filters);\n                        }\n                    }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [], scrollContainerRef: convListScrollRef })) : activePage === 'chat' ? (_jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true) })) : conv ? (_jsx(NewDetails, { clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], conv: conv, convStages: convStages })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => setShowStartConv(false), dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
64723
64723
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
64724
64724
  };
64725
64725
  const Inbox = ({
@@ -64808,9 +64808,10 @@ const Inbox = ({
64808
64808
  rtl: !!rtl,
64809
64809
  children: [jsx$1("div", {
64810
64810
  style: {
64811
- flex: '2.33',
64812
- maxWidth: '350px',
64813
- maxHeight: '100%'
64811
+ width: '350px',
64812
+ flexShrink: 0,
64813
+ maxHeight: '100%',
64814
+ overflow: 'hidden'
64814
64815
  },
64815
64816
  children: jsx$1(NewConvList, {
64816
64817
  convClicked: cov => {
@@ -64837,8 +64838,10 @@ const Inbox = ({
64837
64838
  })
64838
64839
  }), jsx$1("div", {
64839
64840
  style: {
64840
- flex: '5',
64841
- maxHeight: '100%'
64841
+ flex: '1 1 auto',
64842
+ minWidth: 0,
64843
+ maxHeight: '100%',
64844
+ overflow: 'hidden'
64842
64845
  },
64843
64846
  children: jsx$1(Chat, {
64844
64847
  selectedConv: conv,
@@ -64852,9 +64855,10 @@ const Inbox = ({
64852
64855
  })
64853
64856
  }), conv && showDetails && jsx$1("div", {
64854
64857
  style: {
64855
- flex: '2.33',
64856
- maxWidth: '350px',
64857
- maxHeight: '100%'
64858
+ width: '350px',
64859
+ flexShrink: 0,
64860
+ maxHeight: '100%',
64861
+ overflow: 'hidden'
64858
64862
  },
64859
64863
  children: jsx$1(NewDetails
64860
64864
  // agentsLoading={loadingAgents}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@bcrumbs.net/inbox",
3
3
  "description": "Inbox widget for Bread Crumbs portals",
4
- "version": "0.0.38",
4
+ "version": "0.0.39",
5
5
  "keyword": [
6
6
  "bcrumbs",
7
7
  "bc-ui",