@bcrumbs.net/inbox 0.0.45 → 0.0.48

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
@@ -16111,7 +16111,8 @@ var __POSTHOG_ERROR_MESSAGES = {
16111
16111
  const useCrumbyEnabled = () => {
16112
16112
  const posthog = usePostHog();
16113
16113
  const posthogValue = posthog === null || posthog === void 0 ? void 0 : posthog.getFeatureFlag('crumby_enabled');
16114
- return posthogValue;
16114
+ const crumbyEnabledByDefault = window.__FEATURE_FLAG_crumby_enabled__;
16115
+ return crumbyEnabledByDefault || posthogValue;
16115
16116
  };
16116
16117
 
16117
16118
  /**
@@ -70333,36 +70334,6 @@ const ContactInfo = ({
70333
70334
  });
70334
70335
  };
70335
70336
 
70336
- function useTracking() {
70337
- const posthog = usePostHog();
70338
- const history = useHistory();
70339
- const {
70340
- id,
70341
- email
70342
- } = useCurrentUser();
70343
- React.useEffect(() => {
70344
- if (!(id && posthog)) {
70345
- return undefined;
70346
- }
70347
- posthog.identify(id, {
70348
- email
70349
- });
70350
- posthog.startSessionRecording();
70351
- // Track page views for either history API shape.
70352
- const trackPageView = () => {
70353
- posthog.capture('$pageview');
70354
- };
70355
- const historyApi = history;
70356
- const unlistenOrUnsubscribe = typeof historyApi.listen === 'function' ? historyApi.listen(trackPageView) : typeof historyApi.subscribe === 'function' ? historyApi.subscribe(trackPageView) : undefined;
70357
- return () => {
70358
- if (typeof unlistenOrUnsubscribe === 'function') {
70359
- unlistenOrUnsubscribe();
70360
- }
70361
- };
70362
- // eslint-disable-next-line react-hooks/exhaustive-deps
70363
- }, [id, posthog]);
70364
- }
70365
-
70366
70337
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
70367
70338
  const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
70368
70339
  target: "er7h0t70"
@@ -70375,7 +70346,7 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
70375
70346
  } : {
70376
70347
  name: "1lqhi21",
70377
70348
  styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden",
70378
- 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 { 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';\nimport useTracking from '../app/auth/hooks/useTracking';\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\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`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder }) => {\n    useTracking();\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 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 <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                }, clientSectionPlaceholder: clientSectionPlaceholder }) }))] }), _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"]} */",
70349
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAmB2B","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport { 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\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 }) => {\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 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 <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                }, clientSectionPlaceholder: clientSectionPlaceholder }) }))] }), _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"]} */",
70379
70350
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70380
70351
  });
70381
70352
  const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
@@ -70384,9 +70355,10 @@ const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
70384
70355
  } : {
70385
70356
  name: "1fw2k1b-NewStartConvModalStyle",
70386
70357
  styles: "gap:40px;display:flex;flex-direction:column;padding:0px;max-width:750px;min-height:500pxjustify-content :space-between;label:NewStartConvModalStyle;",
70387
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AA4BmC","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport { 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';\nimport useTracking from '../app/auth/hooks/useTracking';\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\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`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder }) => {\n    useTracking();\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 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 <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                }, clientSectionPlaceholder: clientSectionPlaceholder }) }))] }), _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"]} */",
70358
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AA2BmC","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport { 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\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 }) => {\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 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 <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                }, clientSectionPlaceholder: clientSectionPlaceholder }) }))] }), _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
70359
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70389
70360
  };
70361
+ window.__FEATURE_FLAG_crumby_enabled__ = true;
70390
70362
  const Inbox = ({
70391
70363
  logo,
70392
70364
  rtl,
@@ -70396,7 +70368,6 @@ const Inbox = ({
70396
70368
  showDetails,
70397
70369
  clientSectionPlaceholder
70398
70370
  }) => {
70399
- useTracking();
70400
70371
  const [pageWidth] = bcUi.useWindowSize();
70401
70372
  const [conv, setConv] = React.useState();
70402
70373
  const [showStartConv, setShowStartConv] = React.useState(false);
package/index.esm.js CHANGED
@@ -16093,7 +16093,8 @@ var __POSTHOG_ERROR_MESSAGES = {
16093
16093
  const useCrumbyEnabled = () => {
16094
16094
  const posthog = usePostHog();
16095
16095
  const posthogValue = posthog === null || posthog === void 0 ? void 0 : posthog.getFeatureFlag('crumby_enabled');
16096
- return posthogValue;
16096
+ const crumbyEnabledByDefault = window.__FEATURE_FLAG_crumby_enabled__;
16097
+ return crumbyEnabledByDefault || posthogValue;
16097
16098
  };
16098
16099
 
16099
16100
  /**
@@ -70315,36 +70316,6 @@ const ContactInfo = ({
70315
70316
  });
70316
70317
  };
70317
70318
 
70318
- function useTracking() {
70319
- const posthog = usePostHog();
70320
- const history = useHistory();
70321
- const {
70322
- id,
70323
- email
70324
- } = useCurrentUser();
70325
- useEffect(() => {
70326
- if (!(id && posthog)) {
70327
- return undefined;
70328
- }
70329
- posthog.identify(id, {
70330
- email
70331
- });
70332
- posthog.startSessionRecording();
70333
- // Track page views for either history API shape.
70334
- const trackPageView = () => {
70335
- posthog.capture('$pageview');
70336
- };
70337
- const historyApi = history;
70338
- const unlistenOrUnsubscribe = typeof historyApi.listen === 'function' ? historyApi.listen(trackPageView) : typeof historyApi.subscribe === 'function' ? historyApi.subscribe(trackPageView) : undefined;
70339
- return () => {
70340
- if (typeof unlistenOrUnsubscribe === 'function') {
70341
- unlistenOrUnsubscribe();
70342
- }
70343
- };
70344
- // eslint-disable-next-line react-hooks/exhaustive-deps
70345
- }, [id, posthog]);
70346
- }
70347
-
70348
70319
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
70349
70320
  const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
70350
70321
  target: "er7h0t70"
@@ -70357,7 +70328,7 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
70357
70328
  } : {
70358
70329
  name: "1lqhi21",
70359
70330
  styles: "height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;overflow:hidden",
70360
- 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 { 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';\nimport useTracking from '../app/auth/hooks/useTracking';\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\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`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder }) => {\n    useTracking();\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 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 <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                }, clientSectionPlaceholder: clientSectionPlaceholder }) }))] }), _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"]} */",
70331
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AAmB2B","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport { 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\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 }) => {\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 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 <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                }, clientSectionPlaceholder: clientSectionPlaceholder }) }))] }), _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"]} */",
70361
70332
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70362
70333
  });
70363
70334
  const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
@@ -70366,9 +70337,10 @@ const NewStartConvModalStyle = process.env.NODE_ENV === "production" ? {
70366
70337
  } : {
70367
70338
  name: "1fw2k1b-NewStartConvModalStyle",
70368
70339
  styles: "gap:40px;display:flex;flex-direction:column;padding:0px;max-width:750px;min-height:500pxjustify-content :space-between;label:NewStartConvModalStyle;",
70369
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AA4BmC","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport { 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';\nimport useTracking from '../app/auth/hooks/useTracking';\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\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`;\nexport const Inbox = ({ logo, rtl, onConversationChange, initialFilters, onFiltersChange, showDetails, clientSectionPlaceholder }) => {\n    useTracking();\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 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 <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                }, clientSectionPlaceholder: clientSectionPlaceholder }) }))] }), _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"]} */",
70340
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["inbox.tsx"],"names":[],"mappings":"AA2BmC","file":"inbox.tsx","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"@emotion/react/jsx-runtime\";\nimport { useCallback, useEffect, useRef, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { botClient, coreClient } from '@bcrumbs.net/bc-api';\nimport { auth } from '@bcrumbs.net/bc-shared';\nimport { BCNewDialog, useWindowSize } from '@bcrumbs.net/bc-ui';\nimport { useAgentsQuery, useAisQuery } from '../graphql.autogenerated';\nimport useConversationsPeriodicFetch from '../app/inbox/hooks/useConversationsPerodicFetch';\nimport useTags from '../app/inbox/hooks/useTags';\nimport localStorage, { LOCAL_STORAGE_ITEMS } from '../utils/localStorage';\nimport { 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\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 }) => {\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 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 <= MOBILE_DIMENSION) {\n            // Use requestAnimationFrame to ensure the DOM has updated and content is rendered\n            requestAnimationFrame(() => {\n                if (convListScrollRef.current) {\n                    convListScrollRef.current.scrollTop = savedScrollPosition.current;\n                }\n            });\n        }\n    }, [activePage, pageWidth]);\n    if (pageWidth > MOBILE_DIMENSION) {\n        return (_jsxs(_Fragment, { children: [_jsxs(Wrapper, { rtl: !!rtl, children: [_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewConvList, { convClicked: (cov) => {\n                                    setConv(cov);\n                                    if (defaultSelectedConvId !== cov.id) {\n                                        localStorage.set(LOCAL_STORAGE_ITEMS.SELECTED_CONV, cov.id);\n                                    }\n                                }, selectedConvId: conv === null || conv === void 0 ? void 0 : conv.id, convStages: convStages, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convs: convs || [], loading: loading || loadingAgents, onFiltersChange: (filters) => {\n                                    setFilters(filters);\n                                    if (onFiltersChange) {\n                                        onFiltersChange(filters);\n                                    }\n                                }, filters: filters, setShowStartConv: setShowStartConv, aiAgents: (aisData === null || aisData === void 0 ? void 0 : aisData.ais.nodes) || [] }) }), _jsx(\"div\", { style: { flex: '1 1 auto', minWidth: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(Chat, { selectedConv: conv, onConvEnd: onEndConv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || undefined, logo: logo, rtl: !!rtl, convsLength: (convs === null || convs === void 0 ? void 0 : convs.length) || 0, loadingConvs: loading, handleStartConversation: () => setShowStartConv(true), onContactMessage: handleContactMessage, onContactAddContact: handleContactAddContact }) }), conv && showDetails && (_jsx(\"div\", { style: { width: '350px', flexShrink: 0, maxHeight: '100%', overflow: 'hidden' }, children: _jsx(NewDetails\n                            // agentsLoading={loadingAgents}\n                            // clientStages={clientStages}\n                            , { \n                                // agentsLoading={loadingAgents}\n                                // clientStages={clientStages}\n                                clientTags: clientTags, tagsLoading: loadingTags, refetchTags: refetchTags, conversationTags: conversationTags, \n                                // selectedConv={conv}\n                                conv: conv, agents: (agentsData === null || agentsData === void 0 ? void 0 : agentsData.agents.nodes) || [], convStages: convStages, onUpdate: () => {\n                                    refetchConvs();\n                                }, clientSectionPlaceholder: clientSectionPlaceholder }) }))] }), _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
70341
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70371
70342
  };
70343
+ window.__FEATURE_FLAG_crumby_enabled__ = true;
70372
70344
  const Inbox = ({
70373
70345
  logo,
70374
70346
  rtl,
@@ -70378,7 +70350,6 @@ const Inbox = ({
70378
70350
  showDetails,
70379
70351
  clientSectionPlaceholder
70380
70352
  }) => {
70381
- useTracking();
70382
70353
  const [pageWidth] = useWindowSize();
70383
70354
  const [conv, setConv] = useState();
70384
70355
  const [showStartConv, setShowStartConv] = useState(false);
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.45",
4
+ "version": "0.0.48",
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";