@bcrumbs.net/inbox 0.0.49 → 0.0.50

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.cjs.js CHANGED
@@ -70362,36 +70362,24 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
70362
70362
  } : {
70363
70363
  target: "er7h0t71",
70364
70364
  label: "Wrapper"
70365
- })(process.env.NODE_ENV === "production" ? {
70366
- name: "17nuu5a",
70367
- styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden;position:relative"
70368
- } : {
70369
- name: "17nuu5a",
70370
- styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden;position:relative",
70371
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAoB2B","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: 8px 0 0 8px;\r\n    transition: background 0.2s ease, right 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { right: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (_jsx(ChevronRightIcon, { width: 18, height: 18 })) : (_jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
70372
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70373
- });
70365
+ })("height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden;position:relative;direction:", ({
70366
+ rtl
70367
+ }) => rtl ? 'rtl' : 'ltr', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAoB2B","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\ndirection: ${({ rtl }) => (rtl ? 'rtl' : 'ltr')};\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: ${({ rtl }) => (rtl ? '0 8px 8px 0' : '8px 0 0 8px')};\r\n    transition: background 0.2s ease, inset-inline-end 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { rtl: !!rtl, type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { insetInlineEnd: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (rtl ? _jsx(ChevronLeftIcon, { width: 18, height: 18 }) : _jsx(ChevronRightIcon, { width: 18, height: 18 })) : (rtl ? _jsx(ChevronRightIcon, { width: 18, height: 18 }) : _jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */"));
70374
70368
  const DetailsToggleButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
70375
70369
  target: "er7h0t70"
70376
70370
  } : {
70377
70371
  target: "er7h0t70",
70378
70372
  label: "DetailsToggleButton"
70379
- })(process.env.NODE_ENV === "production" ? {
70380
- name: "ditf6g",
70381
- styles: "width:28px;height:40px;border:none;cursor:pointer;background:#fff;color:#1f2937;display:flex;align-items:center;justify-content:center;border-radius:8px 0 0 8px;transition:background 0.2s ease,right 0.2s ease;position:absolute;top:50%;transform:translateY(-50%);z-index:2;&:hover{background:#e5e7eb;}"
70382
- } : {
70383
- name: "ditf6g",
70384
- styles: "width:28px;height:40px;border:none;cursor:pointer;background:#fff;color:#1f2937;display:flex;align-items:center;justify-content:center;border-radius:8px 0 0 8px;transition:background 0.2s ease,right 0.2s ease;position:absolute;top:50%;transform:translateY(-50%);z-index:2;&:hover{background:#e5e7eb;}",
70385
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AA6B0C","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: 8px 0 0 8px;\r\n    transition: background 0.2s ease, right 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { right: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (_jsx(ChevronRightIcon, { width: 18, height: 18 })) : (_jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
70386
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70387
- });
70373
+ })("width:28px;height:40px;border:none;cursor:pointer;background:#fff;color:#1f2937;display:flex;align-items:center;justify-content:center;border-radius:", ({
70374
+ rtl
70375
+ }) => rtl ? '0 8px 8px 0' : '8px 0 0 8px', ";transition:background 0.2s ease,inset-inline-end 0.2s ease;position:absolute;top:50%;transform:translateY(-50%);z-index:2;&:hover{background:#e5e7eb;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AA8B0C","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\ndirection: ${({ rtl }) => (rtl ? 'rtl' : 'ltr')};\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: ${({ rtl }) => (rtl ? '0 8px 8px 0' : '8px 0 0 8px')};\r\n    transition: background 0.2s ease, inset-inline-end 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { rtl: !!rtl, type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { insetInlineEnd: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (rtl ? _jsx(ChevronLeftIcon, { width: 18, height: 18 }) : _jsx(ChevronRightIcon, { width: 18, height: 18 })) : (rtl ? _jsx(ChevronRightIcon, { width: 18, height: 18 }) : _jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */"));
70388
70376
  const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
70389
70377
  name: "6kx8eo",
70390
70378
  styles: "gap:40px;display:flex;flex-direction:column;padding:0px;max-width:750px;min-height:500pxjustify-content :space-between"
70391
70379
  } : {
70392
70380
  name: "1fw2k1b-NewStartConvModalStyle",
70393
70381
  styles: "gap:40px;display:flex;flex-direction:column;padding:0px;max-width:750px;min-height:500pxjustify-content :space-between;label:NewStartConvModalStyle;",
70394
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAiDmC","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: 8px 0 0 8px;\r\n    transition: background 0.2s ease, right 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { right: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (_jsx(ChevronRightIcon, { width: 18, height: 18 })) : (_jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
70382
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAkDmC","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\ndirection: ${({ rtl }) => (rtl ? 'rtl' : 'ltr')};\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: ${({ rtl }) => (rtl ? '0 8px 8px 0' : '8px 0 0 8px')};\r\n    transition: background 0.2s ease, inset-inline-end 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { rtl: !!rtl, type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { insetInlineEnd: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (rtl ? _jsx(ChevronLeftIcon, { width: 18, height: 18 }) : _jsx(ChevronRightIcon, { width: 18, height: 18 })) : (rtl ? _jsx(ChevronRightIcon, { width: 18, height: 18 }) : _jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
70395
70383
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70396
70384
  };
70397
70385
  window.__FEATURE_FLAG_crumby_enabled__ = true;
@@ -70578,13 +70566,20 @@ const Inbox = ({
70578
70566
  clientSectionPlaceholder: clientSectionPlaceholder
70579
70567
  })
70580
70568
  }), conv && showDetails && jsx$1(DetailsToggleButton, {
70569
+ rtl: !!rtl,
70581
70570
  type: "button",
70582
70571
  onClick: () => setIsDetailsOpen(prev => !prev),
70583
70572
  "aria-label": isDetailsOpen ? 'Close details panel' : 'Open details panel',
70584
70573
  style: {
70585
- right: isDetailsOpen ? '320px' : '0px'
70574
+ insetInlineEnd: isDetailsOpen ? '320px' : '0px'
70586
70575
  },
70587
- children: isDetailsOpen ? jsx$1(reactIcons.ChevronRightIcon, {
70576
+ children: isDetailsOpen ? rtl ? jsx$1(reactIcons.ChevronLeftIcon, {
70577
+ width: 18,
70578
+ height: 18
70579
+ }) : jsx$1(reactIcons.ChevronRightIcon, {
70580
+ width: 18,
70581
+ height: 18
70582
+ }) : rtl ? jsx$1(reactIcons.ChevronRightIcon, {
70588
70583
  width: 18,
70589
70584
  height: 18
70590
70585
  }) : jsx$1(reactIcons.ChevronLeftIcon, {
package/index.esm.js CHANGED
@@ -70344,36 +70344,24 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
70344
70344
  } : {
70345
70345
  target: "er7h0t71",
70346
70346
  label: "Wrapper"
70347
- })(process.env.NODE_ENV === "production" ? {
70348
- name: "17nuu5a",
70349
- styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden;position:relative"
70350
- } : {
70351
- name: "17nuu5a",
70352
- styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden;position:relative",
70353
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAoB2B","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: 8px 0 0 8px;\r\n    transition: background 0.2s ease, right 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { right: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (_jsx(ChevronRightIcon, { width: 18, height: 18 })) : (_jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
70354
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70355
- });
70347
+ })("height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden;position:relative;direction:", ({
70348
+ rtl
70349
+ }) => rtl ? 'rtl' : 'ltr', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAoB2B","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\ndirection: ${({ rtl }) => (rtl ? 'rtl' : 'ltr')};\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: ${({ rtl }) => (rtl ? '0 8px 8px 0' : '8px 0 0 8px')};\r\n    transition: background 0.2s ease, inset-inline-end 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { rtl: !!rtl, type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { insetInlineEnd: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (rtl ? _jsx(ChevronLeftIcon, { width: 18, height: 18 }) : _jsx(ChevronRightIcon, { width: 18, height: 18 })) : (rtl ? _jsx(ChevronRightIcon, { width: 18, height: 18 }) : _jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */"));
70356
70350
  const DetailsToggleButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
70357
70351
  target: "er7h0t70"
70358
70352
  } : {
70359
70353
  target: "er7h0t70",
70360
70354
  label: "DetailsToggleButton"
70361
- })(process.env.NODE_ENV === "production" ? {
70362
- name: "ditf6g",
70363
- styles: "width:28px;height:40px;border:none;cursor:pointer;background:#fff;color:#1f2937;display:flex;align-items:center;justify-content:center;border-radius:8px 0 0 8px;transition:background 0.2s ease,right 0.2s ease;position:absolute;top:50%;transform:translateY(-50%);z-index:2;&:hover{background:#e5e7eb;}"
70364
- } : {
70365
- name: "ditf6g",
70366
- styles: "width:28px;height:40px;border:none;cursor:pointer;background:#fff;color:#1f2937;display:flex;align-items:center;justify-content:center;border-radius:8px 0 0 8px;transition:background 0.2s ease,right 0.2s ease;position:absolute;top:50%;transform:translateY(-50%);z-index:2;&:hover{background:#e5e7eb;}",
70367
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AA6B0C","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: 8px 0 0 8px;\r\n    transition: background 0.2s ease, right 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { right: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (_jsx(ChevronRightIcon, { width: 18, height: 18 })) : (_jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
70368
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70369
- });
70355
+ })("width:28px;height:40px;border:none;cursor:pointer;background:#fff;color:#1f2937;display:flex;align-items:center;justify-content:center;border-radius:", ({
70356
+ rtl
70357
+ }) => rtl ? '0 8px 8px 0' : '8px 0 0 8px', ";transition:background 0.2s ease,inset-inline-end 0.2s ease;position:absolute;top:50%;transform:translateY(-50%);z-index:2;&:hover{background:#e5e7eb;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AA8B0C","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\ndirection: ${({ rtl }) => (rtl ? 'rtl' : 'ltr')};\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: ${({ rtl }) => (rtl ? '0 8px 8px 0' : '8px 0 0 8px')};\r\n    transition: background 0.2s ease, inset-inline-end 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { rtl: !!rtl, type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { insetInlineEnd: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (rtl ? _jsx(ChevronLeftIcon, { width: 18, height: 18 }) : _jsx(ChevronRightIcon, { width: 18, height: 18 })) : (rtl ? _jsx(ChevronRightIcon, { width: 18, height: 18 }) : _jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */"));
70370
70358
  const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
70371
70359
  name: "6kx8eo",
70372
70360
  styles: "gap:40px;display:flex;flex-direction:column;padding:0px;max-width:750px;min-height:500pxjustify-content :space-between"
70373
70361
  } : {
70374
70362
  name: "1fw2k1b-NewStartConvModalStyle",
70375
70363
  styles: "gap:40px;display:flex;flex-direction:column;padding:0px;max-width:750px;min-height:500pxjustify-content :space-between;label:NewStartConvModalStyle;",
70376
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAiDmC","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: 8px 0 0 8px;\r\n    transition: background 0.2s ease, right 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { right: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (_jsx(ChevronRightIcon, { width: 18, height: 18 })) : (_jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
70364
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAkDmC","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 { ChevronLeftIcon, ChevronRightIcon } from '@radix-ui/react-icons';\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 { sanitizePhone } from '../utils/textUtils';\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';\nimport ContactInfo from '../app/contact/components/ContactInfo';\nconst Wrapper = styled.div `\r\nheight: 100%;\r\ndisplay: flex;\r\nflex-direction: row;\r\nflex-wrap: nowrap;\r\nalign-items: stretch;\r\noverflow: hidden;\r\nposition: relative;\r\ndirection: ${({ rtl }) => (rtl ? 'rtl' : 'ltr')};\r\n`;\nconst DetailsToggleButton = styled.button `\r\n    width: 28px;\r\n    height: 40px;\r\n    border: none;\r\n    cursor: pointer;\r\n    background: #fff;\r\n    color: #1f2937;\r\n    display: flex;\r\n    align-items: center;\r\n    justify-content: center;\r\n    border-radius: ${({ rtl }) => (rtl ? '0 8px 8px 0' : '8px 0 0 8px')};\r\n    transition: background 0.2s ease, inset-inline-end 0.2s ease;\r\n    position: absolute;\r\n    top: 50%;\r\n    transform: translateY(-50%);\r\n    z-index: 2;\r\n    &:hover {\r\n        background: #e5e7eb;\r\n    }\r\n`;\nconst NewStartConvModalStyle = css `\r\n  gap: 40px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  padding: 0px;\r\n  max-width: 750px;\r\n  min-height:500px\r\n  justify-content : space-between;\r\n`;\nwindow.__FEATURE_FLAG_crumby_enabled__ = true;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder, mobileBreakpoint = MOBILE_DIMENSION, }) => {\n    const [pageWidth] = useWindowSize();\n    const [conv, setConv] = useState();\n    const [showStartConv, setShowStartConv] = useState(false);\n    const [startConvInitialPhone, setStartConvInitialPhone] = useState();\n    const [showAddContact, setShowAddContact] = useState(false);\n    const [addContactInitialData, setAddContactInitialData] = useState();\n    const [activePage, setActivePage] = useState('convList');\n    const [filters, setFilters] = useState(initialFilters || {});\n    const [isDetailsOpen, setIsDetailsOpen] = useState(true);\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, 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    // Handler for \"Message\" action on contact message cards\n    const handleContactMessage = useCallback((contact) => {\n        // Open start conversation modal with phone pre-filled\n        if (contact.phone) {\n            setStartConvInitialPhone(sanitizePhone(contact.phone));\n            setShowStartConv(true);\n        }\n    }, []);\n    // Handler for \"Add Contact\" action on contact message cards\n    const handleContactAddContact = useCallback((contact) => {\n        // Open add contact modal with contact data pre-filled (sanitize phone)\n        const sanitizedContact = Object.assign(Object.assign({}, contact), { phone: sanitizePhone(contact.phone) });\n        setAddContactInitialData(sanitizedContact);\n        setShowAddContact(true);\n    }, []);\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 <= mobileBreakpoint) {\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, mobileBreakpoint]);\n    if (pageWidth > mobileBreakpoint) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '320px', 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && isDetailsOpen && (_jsx(\"div\", { style: { width: '320px', 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                                }, clientSectionPlaceholder: clientSectionPlaceholder }) })), conv && showDetails && (_jsx(DetailsToggleButton, { rtl: !!rtl, type: \"button\", onClick: () => setIsDetailsOpen((prev) => !prev), \"aria-label\": isDetailsOpen ? 'Close details panel' : 'Open details panel', style: { insetInlineEnd: isDetailsOpen ? '320px' : '0px' }, children: isDetailsOpen ? (rtl ? _jsx(ChevronLeftIcon, { width: 18, height: 18 }) : _jsx(ChevronRightIcon, { width: 18, height: 18 })) : (rtl ? _jsx(ChevronRightIcon, { width: 18, height: 18 }) : _jsx(ChevronLeftIcon, { width: 18, height: 18 })) }))] }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                        setShowStartConv(false);\n                        setStartConvInitialPhone(undefined);\n                    }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                        setShowAddContact(false);\n                        setAddContactInitialData(undefined);\n                    }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), 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), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact })) : 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, clientSectionPlaceholder: clientSectionPlaceholder })) : (_jsx(InboxNoSelectionContainer, {})) }), _jsx(BCNewDialog, { isOpen: showStartConv, closeDialog: () => {\n                    setShowStartConv(false);\n                    setStartConvInitialPhone(undefined);\n                }, dialogBody: _jsx(NewStartConv, { setAddContactIsOpen: setShowStartConv, initialPhone: startConvInitialPhone }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(BCNewDialog, { isOpen: showAddContact, closeDialog: () => {\n                    setShowAddContact(false);\n                    setAddContactInitialData(undefined);\n                }, dialogBody: _jsx(ContactInfo, { setContactInfoIsOpen: setShowAddContact, contactInfoIsOpen: showAddContact, initialContactData: addContactInitialData }), contentCssStyle: NewStartConvModalStyle, rtl: rtl }), _jsx(MobileMenu, { embeddedMode: true, setActivePage: setActivePage, activePage: activePage, hideDetails: !showDetails })] }));\n};\n//# sourceMappingURL=inbox.js.map"]} */",
70377
70365
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70378
70366
  };
70379
70367
  window.__FEATURE_FLAG_crumby_enabled__ = true;
@@ -70560,13 +70548,20 @@ const Inbox = ({
70560
70548
  clientSectionPlaceholder: clientSectionPlaceholder
70561
70549
  })
70562
70550
  }), conv && showDetails && jsx$1(DetailsToggleButton, {
70551
+ rtl: !!rtl,
70563
70552
  type: "button",
70564
70553
  onClick: () => setIsDetailsOpen(prev => !prev),
70565
70554
  "aria-label": isDetailsOpen ? 'Close details panel' : 'Open details panel',
70566
70555
  style: {
70567
- right: isDetailsOpen ? '320px' : '0px'
70556
+ insetInlineEnd: isDetailsOpen ? '320px' : '0px'
70568
70557
  },
70569
- children: isDetailsOpen ? jsx$1(ChevronRightIcon, {
70558
+ children: isDetailsOpen ? rtl ? jsx$1(ChevronLeftIcon, {
70559
+ width: 18,
70560
+ height: 18
70561
+ }) : jsx$1(ChevronRightIcon, {
70562
+ width: 18,
70563
+ height: 18
70564
+ }) : rtl ? jsx$1(ChevronRightIcon, {
70570
70565
  width: 18,
70571
70566
  height: 18
70572
70567
  }) : jsx$1(ChevronLeftIcon, {
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.49",
4
+ "version": "0.0.50",
5
5
  "keyword": [
6
6
  "bcrumbs",
7
7
  "bc-ui",
@@ -1,3 +1,4 @@
1
+ /// <reference types="react" />
1
2
  import { TFunction } from "i18next";
2
3
  import { Row, Action } from "@bcrumbs.net/bc-ui";
3
4
  import { ResourceDefinition } from "../../config";