@cossistant/next 0.0.4 → 0.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (108) hide show
  1. package/_virtual/rolldown_runtime.js +6 -0
  2. package/bubble.d.ts +1 -0
  3. package/bubble.d.ts.map +1 -1
  4. package/button.d.ts.map +1 -1
  5. package/conversation-timeline.d.ts.map +1 -1
  6. package/conversation.d.ts +5 -0
  7. package/conversation.d.ts.map +1 -0
  8. package/fallback.d.ts.map +1 -1
  9. package/hooks/index.d.ts +6 -3
  10. package/id.d.ts +9 -0
  11. package/id.d.ts.map +1 -0
  12. package/identify-visitor2.d.ts +11 -3
  13. package/identify-visitor2.d.ts.map +1 -1
  14. package/index.d.ts +19 -7
  15. package/index.js +3 -0
  16. package/index.js.map +1 -1
  17. package/index.parts.d.ts +3 -0
  18. package/index2.d.ts +24 -37
  19. package/index2.parts.d.ts +13 -0
  20. package/index3.d.ts +4 -0
  21. package/index4.d.ts +13 -0
  22. package/index5.d.ts +5 -0
  23. package/index6.d.ts +2 -0
  24. package/index7.d.ts +37 -0
  25. package/index7.d.ts.map +1 -0
  26. package/index8.d.ts +3 -0
  27. package/keys.d.ts +66 -6
  28. package/keys.d.ts.map +1 -1
  29. package/multimodal-input.d.ts.map +1 -1
  30. package/package.json +14 -20
  31. package/primitives/index.d.ts +1 -0
  32. package/provider.d.ts +2 -2
  33. package/provider2.d.ts +23 -43
  34. package/provider2.d.ts.map +1 -1
  35. package/provider3.d.ts +7 -2
  36. package/provider3.d.ts.map +1 -1
  37. package/realtime/index.d.ts +1 -0
  38. package/seen-store.d.ts +10 -0
  39. package/seen-store.d.ts.map +1 -1
  40. package/support/index.d.ts +2 -3
  41. package/support-config2.d.ts +3 -1
  42. package/support-config2.d.ts.map +1 -1
  43. package/support-provider.d.ts +1 -2
  44. package/support-provider.d.ts.map +1 -1
  45. package/support-store.d.ts +24 -1
  46. package/support-store.d.ts.map +1 -1
  47. package/support.css +2 -0
  48. package/tailwind.css +404 -0
  49. package/timeline-item-group.d.ts +4 -4
  50. package/timeline-item-group.d.ts.map +1 -1
  51. package/timeline-item.d.ts +1 -1
  52. package/timeline-item.d.ts.map +1 -1
  53. package/typing-indicator.d.ts +0 -1
  54. package/typing-indicator.d.ts.map +1 -1
  55. package/typing-store.d.ts +15 -0
  56. package/typing-store.d.ts.map +1 -1
  57. package/typing.d.ts +13 -0
  58. package/typing.d.ts.map +1 -0
  59. package/use-client-query.d.ts +5 -0
  60. package/use-client-query.d.ts.map +1 -1
  61. package/use-composer-refocus.d.ts.map +1 -1
  62. package/use-conversation-auto-seen.d.ts +9 -0
  63. package/use-conversation-auto-seen.d.ts.map +1 -1
  64. package/use-conversation-history-page.d.ts.map +1 -1
  65. package/use-conversation-lifecycle.d.ts.map +1 -1
  66. package/use-conversation-page.d.ts +6 -0
  67. package/use-conversation-page.d.ts.map +1 -1
  68. package/use-conversation-preview.d.ts +59 -0
  69. package/use-conversation-preview.d.ts.map +1 -0
  70. package/use-conversation-seen.d.ts +4 -0
  71. package/use-conversation-seen.d.ts.map +1 -1
  72. package/use-conversation-timeline-items.d.ts +4 -0
  73. package/use-conversation-timeline-items.d.ts.map +1 -1
  74. package/use-conversation-timeline.d.ts +31 -0
  75. package/use-conversation-timeline.d.ts.map +1 -0
  76. package/use-conversation-typing.d.ts +4 -0
  77. package/use-conversation-typing.d.ts.map +1 -1
  78. package/use-conversation.d.ts +11 -0
  79. package/use-conversation.d.ts.map +1 -1
  80. package/use-conversations.d.ts +12 -0
  81. package/use-conversations.d.ts.map +1 -1
  82. package/use-create-conversation.d.ts +5 -0
  83. package/use-create-conversation.d.ts.map +1 -1
  84. package/use-default-messages.d.ts.map +1 -1
  85. package/use-grouped-messages.d.ts +10 -4
  86. package/use-grouped-messages.d.ts.map +1 -1
  87. package/use-home-page.d.ts.map +1 -1
  88. package/use-message-composer.d.ts.map +1 -1
  89. package/use-multimodal-input.d.ts.map +1 -1
  90. package/use-realtime-support.d.ts.map +1 -1
  91. package/use-realtime.d.ts +8 -4
  92. package/use-realtime.d.ts.map +1 -1
  93. package/use-render-element.d.ts +25 -0
  94. package/use-render-element.d.ts.map +1 -0
  95. package/use-rest-client.d.ts.map +1 -1
  96. package/use-send-message.d.ts +9 -0
  97. package/use-send-message.d.ts.map +1 -1
  98. package/use-visitor.d.ts.map +1 -1
  99. package/use-window-visibility-focus.d.ts +4 -0
  100. package/use-window-visibility-focus.d.ts.map +1 -1
  101. package/utils/index.d.ts +5 -0
  102. package/utils/index.js +8 -0
  103. package/websocket.d.ts +8 -0
  104. package/websocket.d.ts.map +1 -1
  105. package/window.d.ts +1 -1
  106. package/config.d.ts +0 -22
  107. package/config.d.ts.map +0 -1
  108. package/index2.d.ts.map +0 -1
package/provider.d.ts CHANGED
@@ -1,2 +1,2 @@
1
- import { CossistantContextValue, CossistantProviderProps, SupportProvider, SupportProviderProps, useSupport } from "./provider2.js";
2
- export { CossistantContextValue, CossistantProviderProps, SupportProvider, SupportProviderProps, useSupport };
1
+ import { CossistantContextValue, CossistantProviderProps, SupportContext, SupportProvider, SupportProviderProps, UseSupportValue, useSupport } from "./provider2.js";
2
+ export { CossistantContextValue, CossistantProviderProps, SupportContext, SupportProvider, SupportProviderProps, UseSupportValue, useSupport };
package/provider2.d.ts CHANGED
@@ -1,10 +1,8 @@
1
- import * as React$1 from "react";
2
- import * as react_jsx_runtime0 from "react/jsx-runtime";
3
- import { QueryClient } from "@tanstack/react-query";
1
+ import React from "react";
4
2
 
5
3
  //#region ../react/src/provider.d.ts
6
4
  type SupportProviderProps = {
7
- children: React$1.ReactNode;
5
+ children: React.ReactNode;
8
6
  defaultOpen?: boolean;
9
7
  apiUrl?: string;
10
8
  wsUrl?: string;
@@ -15,7 +13,7 @@ type SupportProviderProps = {
15
13
  onWsConnect?: () => void;
16
14
  onWsDisconnect?: () => void;
17
15
  onWsError?: (error: Error) => void;
18
- queryClient?: QueryClient;
16
+ size?: "normal" | "larger";
19
17
  };
20
18
  type CossistantProviderProps = SupportProviderProps;
21
19
  type CossistantContextValue = {
@@ -29,7 +27,22 @@ type CossistantContextValue = {
29
27
  isLoading: boolean;
30
28
  error: Error | null;
31
29
  client: CossistantClient;
30
+ isOpen: boolean;
31
+ open: () => void;
32
+ close: () => void;
33
+ toggle: () => void;
32
34
  };
35
+ type WebsiteData = NonNullable<CossistantContextValue["website"]>;
36
+ type VisitorWithLocale = WebsiteData["visitor"] extends null | undefined ? undefined : NonNullable<WebsiteData["visitor"]> & {
37
+ locale: string | null;
38
+ };
39
+ type UseSupportValue = CossistantContextValue & {
40
+ availableHumanAgents: NonNullable<WebsiteData["availableHumanAgents"]> | [];
41
+ availableAIAgents: NonNullable<WebsiteData["availableAIAgents"]> | [];
42
+ visitor?: VisitorWithLocale;
43
+ size: "normal" | "larger";
44
+ };
45
+ declare const SupportContext: React.Context<CossistantContextValue | undefined>;
33
46
  /**
34
47
  * Hosts the entire customer support widget ecosystem by handing out context
35
48
  * about the current website, visitor, unread counts, realtime subscriptions
@@ -47,47 +60,14 @@ declare function SupportProvider({
47
60
  onWsConnect,
48
61
  onWsDisconnect,
49
62
  onWsError,
50
- queryClient
51
- }: SupportProviderProps): react_jsx_runtime0.JSX.Element;
63
+ size,
64
+ defaultOpen
65
+ }: SupportProviderProps): React.ReactElement;
52
66
  /**
53
67
  * Convenience hook that exposes the aggregated support context. Throws when it
54
68
  * is consumed outside of `SupportProvider` to catch integration mistakes.
55
69
  */
56
- declare function useSupport(): {
57
- availableHumanAgents: {
58
- id: string;
59
- name: string;
60
- image: string | null;
61
- lastSeenAt: string | null;
62
- }[];
63
- availableAIAgents: {
64
- id: string;
65
- name: string;
66
- image: string | null;
67
- }[];
68
- visitor: {
69
- locale: string | null;
70
- id: string;
71
- isBlocked: boolean;
72
- language: string | null;
73
- contact: {
74
- id: string;
75
- name: string | null;
76
- email: string | null;
77
- image: string | null;
78
- } | null;
79
- } | undefined;
80
- website: PublicWebsiteResponse | null;
81
- defaultMessages: DefaultMessage[];
82
- quickOptions: string[];
83
- setDefaultMessages: (messages: DefaultMessage[]) => void;
84
- setQuickOptions: (options: string[]) => void;
85
- unreadCount: number;
86
- setUnreadCount: (count: number) => void;
87
- isLoading: boolean;
88
- error: Error | null;
89
- client: CossistantClient;
90
- };
70
+ declare function useSupport(): UseSupportValue;
91
71
  //#endregion
92
- export { CossistantContextValue, CossistantProviderProps, SupportProvider, SupportProviderProps, useSupport };
72
+ export { CossistantContextValue, CossistantProviderProps, SupportContext, SupportProvider, SupportProviderProps, UseSupportValue, useSupport };
93
73
  //# sourceMappingURL=provider2.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"provider2.d.ts","names":[],"sources":["../../react/src/provider.tsx"],"sourcesContent":[],"mappings":";;;;;KASY,oBAAA;EAAA,QAAA,EACD,OAAA,CAAM,SADe;EAAA,WAAA,CAAA,EAAA,OAAA;QACrB,CAAA,EAAA,MAAM;OAKE,CAAA,EAAA,MAAA;WAKE,CAAA,EAAA,MAAA;iBACN,CAAA,EANI,cAMJ,EAAA;EAAW,YAAA,CAAA,EAAA,MAAA,EAAA;EAGd,WAAA,CAAA,EAAA,OAAA;EAEA,WAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EAAsB,cAAA,CAAA,EAAA,GAAA,GAAA,IAAA;WACxB,CAAA,EAAA,CAAA,KAAA,EAPW,KAOX,EAAA,GAAA,IAAA;aACQ,CAAA,EAPH,WAOG;;AAOV,KAXI,uBAAA,GAA0B,oBAW9B;AACC,KAVG,sBAAA,GAUH;EAAgB,OAAA,EATf,qBASe,GAAA,IAAA;EA+HT,eAAA,EAvIE,cAuIa,EAAA;EAAA,YAAA,EAAA,MAAA,EAAA;oBAC9B,EAAA,CAAA,QAAA,EAtI+B,cAsI/B,EAAA,EAAA,GAAA,IAAA;iBACA,EAAA,CAAA,OAAA,EAAA,MAAA,EAAA,EAAA,GAAA,IAAA;aACA,EAAA,MAAA;gBACA,EAAA,CAAA,KAAA,EAAA,MAAA,EAAA,GAAA,IAAA;WACA,EAAA,OAAA;OACA,EAtIO,KAsIP,GAAA,IAAA;QACA,EAtIQ,gBAsIR;;;;;;;;AA4Ce,iBAnDA,eAAA,CAmDU;EAAA,QAAA;EAAA,MAAA;EAAA,KAAA;EAAA,SAAA;EAAA,eAAA;EAAA,YAAA;EAAA,WAAA;EAAA,WAAA;EAAA,cAAA;EAAA,SAAA;EAAA;AAAA,CAAA,EAvCvB,oBAuCuB,CAAA,EAvCH,kBAAA,CAAA,GAAA,CAAA,OAuCG;;;;;AAnLlB,iBAmLQ,UAAA,CAAA,CAnLR,EAAA;sBACC,EAAA;IAAgB,EAAA,EAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;WATf;mBACQ;;iCAEc;;;;;SAKxB;UACC"}
1
+ {"version":3,"file":"provider2.d.ts","names":[],"sources":["../../react/src/provider.tsx"],"sourcesContent":[],"mappings":";;;AAgBY,KAAA,oBAAA,GAAoB;EACrB,QAAM,EAAN,KAAA,CAAM,SAAA;EAKE,WAAA,CAAA,EAAA,OAAA;EAKE,MAAA,CAAA,EAAA,MAAA;EAAK,KAAA,CAAA,EAAA,MAAA;EAId,SAAA,CAAA,EAAA,MAAA;EAEA,eAAA,CAAA,EAXO,cAWe,EAAA;EACxB,YAAA,CAAA,EAAA,MAAA,EAAA;EACQ,WAAA,CAAA,EAAA,OAAA;EAEc,WAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EAKxB,cAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EACC,SAAA,CAAA,EAAA,CAAA,KAAA,EAhBY,KAgBZ,EAAA,GAAA,IAAA;EAAgB,IAAA,CAAA,EAAA,QAAA,GAAA,QAAA;AAKvB,CAAA;AAIG,KArBO,uBAAA,GAA0B,oBAqBhB;AAAG,KAnBb,sBAAA,GAmBa;EAEV,OAAA,EApBL,qBAoBK,GAAA,IAAA;EAAZ,eAAA,EAnBe,cAmBf,EAAA;EAAW,YAAA,EAAA,MAAA,EAAA;EAwCF,kBAAe,EAAA,CAAA,QAAA,EAzDK,cAyDL,EAAA,EAAA,GAAA,IAAA;EAAG,eAAA,EAAA,CAAA,OAAA,EAAA,MAAA,EAAA,EAAA,GAAA,IAAA;EACK,WAAA,EAAA,MAAA;EAAZ,cAAA,EAAA,CAAA,KAAA,EAAA,MAAA,EAAA,GAAA,IAAA;EACS,SAAA,EAAA,OAAA;EAAZ,KAAA,EAtDZ,KAsDY,GAAA,IAAA;EACT,MAAA,EAtDF,gBAsDE;EAAiB,MAAA,EAAA,OAAA;EAIf,IAAA,EAAA,GAAA,GAAA,IAAA;EAmRG,KAAA,EAAA,GAAA,GAAA,IAAA;EACf,MAAA,EAAA,GAAA,GAAA,IAAA;CACA;KAxUI,WAAA,GAAc,WAyUlB,CAzU8B,sBAyU9B,CAAA,SAAA,CAAA,CAAA;KAvUI,iBAAA,GAAoB,WAwUxB,CAAA,SAAA,CAAA,SAAA,IAAA,GAAA,SAAA,GAAA,SAAA,GAtUE,WAsUF,CAtUc,WAsUd,CAAA,SAAA,CAAA,CAAA,GAAA;EACA,MAAA,EAAA,MAAA,GAAA,IAAA;CACA;AACA,KAjSW,eAAA,GAAkB,sBAiS7B,GAAA;EACA,oBAAA,EAjSsB,WAiStB,CAjSkC,WAiSlC,CAAA,sBAAA,CAAA,CAAA,GAAA,EAAA;EACA,iBAAA,EAjSmB,WAiSnB,CAjS+B,WAiS/B,CAAA,mBAAA,CAAA,CAAA,GAAA,EAAA;EACA,OAAA,CAAA,EAjSU,iBAiSV;EACA,IAAA,EAAA,QAAA,GAAA,QAAA;CACA;AACE,cAhSU,cAgSV,EAhSwB,KAAA,CAAA,OAgSxB,CAhSwB,sBAgSxB,GAAA,SAAA,CAAA;;;AAwBH;;;;iBArCgB,eAAA;;;;;;;;;;;;;GAab,uBAAuB,KAAA,CAAM;;;;;iBAwBhB,UAAA,CAAA,GAAc"}
package/provider3.d.ts CHANGED
@@ -1,5 +1,4 @@
1
1
  import React from "react";
2
- import * as react_jsx_runtime1 from "react/jsx-runtime";
3
2
 
4
3
  //#region ../react/src/realtime/provider.d.ts
5
4
  type SubscribeHandler = (event: AnyRealtimeEvent) => void;
@@ -41,6 +40,9 @@ type RealtimeContextValue = RealtimeConnectionState & {
41
40
  websiteId: string | null;
42
41
  userId: string | null;
43
42
  };
43
+ /**
44
+ * Provides websocket connectivity and heartbeating logic for realtime events.
45
+ */
44
46
  declare function RealtimeProvider({
45
47
  children,
46
48
  wsUrl,
@@ -49,7 +51,10 @@ declare function RealtimeProvider({
49
51
  onConnect,
50
52
  onDisconnect,
51
53
  onError
52
- }: RealtimeProviderProps): react_jsx_runtime1.JSX.Element;
54
+ }: RealtimeProviderProps): React.ReactElement;
55
+ /**
56
+ * Returns the realtime connection context.
57
+ */
53
58
  declare function useRealtimeConnection(): RealtimeContextValue;
54
59
  //#endregion
55
60
  export { type RealtimeAuthConfig, type RealtimeContextValue, RealtimeProvider, type RealtimeProviderProps, useRealtimeConnection };
@@ -1 +1 @@
1
- {"version":3,"file":"provider3.d.ts","names":[],"sources":["../../react/src/realtime/provider.tsx"],"sourcesContent":[],"mappings":";;;;KAuBK,gBAAA,WAA2B;KA+B3B,iBAAA;EA/BA,IAAA,EAAA,SAAA;EA+BA,SAAA,EAAA,MAAA,GAAiB,IAAA;EAOjB,SAAA,CAAA,EAAA,MAAA,GAAiB,IAAA;EAOjB,SAAA,CAAA,EAAA,MAAA,GAAkB,IAAA;CAAA;KAPlB,iBAAA,GAOqB;MAAoB,EAAA,SAAA;EAAiB,YAAA,EAAA,MAAA,GAAA,IAAA;EAW1D,SAAA,CAAA,EAAA,MAAA,GAAA,IAAqB;EAAA,MAAA,CAAA,EAAA,MAAA,GAAA,IAAA;;KAXrB,kBAAA,GAAqB,iBAcnB,GAduC,iBAcvC;KAHF,qBAAA,GAOc;EAAK,QAAA,EANb,KAAA,CAAM,SAMO;EAGnB,KAAA,CAAA,EAAA,MAAA;EAAuB,IAAA,EAPrB,kBAOqB,GAAA,IAAA;aAGpB,CAAA,EAAA,OAAA;WACO,CAAA,EAAA,GAAA,GAAA,IAAA;cAEO,CAAA,EAAA,GAAA,GAAA,IAAA;SACV,CAAA,EAAA,CAAA,KAAA,EAVO,KAUP,EAAA,GAAA,IAAA;CAAgB;AAAA,KAPvB,uBAAA,GAYoB;EA2QT,WAAA,EAAA,OAAgB;EAAA,YAAA,EAAA,OAAA;OAC/B,EArRO,KAqRP,GAAA,IAAA;MACA,EAAA,CAAA,KAAA,EArRc,gBAqRd,EAAA,GAAA,IAAA;SACA,EAAA,CAAA,IAAA,EAAA,MAAA,EAAA,GAAA,IAAA;WACA,EAAA,CAAA,OAAA,EArRqB,gBAqRrB,EAAA,GAAA,GAAA,GAAA,IAAA;WACA,EArRW,gBAqRX,GAAA,IAAA;cACA,EAAA,MAAA,GAAA,IAAA;WACA,EAAA,GAAA,GAAA,IAAA;;KAlRI,oBAAA,GAAuB,uBAmRJ,GAAA;EAAA,SAAA,EAAA,MAAA,GAAA,IAAA;EAmPR,SAAA,EAAA,MAAA,GAAA,IAAqB;;;iBA3PrB,gBAAA;;;;;;;;GAQb,wBAAqB,kBAAA,CAAA,GAAA,CAAA;iBAmPR,qBAAA,CAAA,GAAyB"}
1
+ {"version":3,"file":"provider3.d.ts","names":[],"sources":["../../react/src/realtime/provider.tsx"],"sourcesContent":[],"mappings":";;;KAuBK,gBAAA,WAA2B;AAfD,KA8C1B,iBAAA,GA/BgB;EA+BhB,IAAA,EAAA,SAAA;EAOA,SAAA,EAAA,MAAA,GAAiB,IAAA;EAOjB,SAAA,CAAA,EAAA,MAAA,GAAkB,IAAA;EAWlB,SAAA,CAAA,EAAA,MAAA,GAAA,IAAqB;CACf;KAnBN,iBAAA,GAqBE;EAIY,IAAA,EAAA,SAAA;EAAK,YAAA,EAAA,MAAA,GAAA,IAAA;EAGnB,SAAA,CAAA,EAAA,MAAA,GAAA,IAAA;EAGG,MAAA,CAAA,EAAA,MAAA,GAAA,IAAA;CACO;KAzBV,kBAAA,GAAqB,iBA2BJ,GA3BwB,iBA2BxB;KAhBjB,qBAAA,GAiBO;EAAgB,QAAA,EAhBjB,KAAA,CAAM,SAgBW;EAKvB,KAAA,CAAA,EAAA,MAAA;EA8QW,IAAA,EAjST,kBAiSyB,GAAA,IAAA;EAC/B,WAAA,CAAA,EAAA,OAAA;EACA,SAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EACA,YAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EACA,OAAA,CAAA,EAAA,CAAA,KAAA,EAjSkB,KAiSlB,EAAA,GAAA,IAAA;CACA;KA/RI,uBAAA,GAgSJ;EACA,WAAA,EAAA,OAAA;EACE,YAAA,EAAA,OAAA;EAAwB,KAAM,EA/RzB,KA+RyB,GAAA,IAAA;EAAY,IAAA,EAAA,CAAA,KAAA,EA9R9B,gBA8R8B,EAAA,GAAA,IAAA;EA6S7B,OAAA,EAAA,CAAA,IAAA,EAAA,MAAA,EAAqB,GAAA,IAAA;uBAzkBf;aACV;;;;KAKP,oBAAA,GAAuB;;;;;;;;iBA8QZ,gBAAA;;;;;;;;GAQb,wBAAwB,KAAA,CAAM;;;;iBA6SjB,qBAAA,CAAA,GAAyB"}
@@ -3,4 +3,5 @@ import { applyConversationSeenEvent, hydrateConversationSeen, upsertConversation
3
3
  import { SupportRealtimeProvider } from "../support-provider.js";
4
4
  import { applyConversationTypingEvent, clearTypingFromTimelineItem, clearTypingState, setTypingState } from "../typing-store.js";
5
5
  import { RealtimeEventHandler, RealtimeEventHandlerEntry, RealtimeEventHandlersMap, RealtimeEventMeta, useRealtime } from "../use-realtime.js";
6
+ import "../index5.js";
6
7
  export { RealtimeAuthConfig, RealtimeContextValue, RealtimeEventHandler, RealtimeEventHandlerEntry, RealtimeEventHandlersMap, RealtimeEventMeta, RealtimeProvider, RealtimeProviderProps, SupportRealtimeProvider, applyConversationSeenEvent, applyConversationTypingEvent, clearTypingFromTimelineItem, clearTypingState, hydrateConversationSeen, setTypingState, upsertConversationSeen, useRealtime, useRealtimeConnection };
package/seen-store.d.ts CHANGED
@@ -1,12 +1,22 @@
1
1
  //#region ../react/src/realtime/seen-store.d.ts
2
2
 
3
+ /**
4
+ * Seeds the seen store with initial data, typically from the REST API or SSR.
5
+ */
3
6
  declare function hydrateConversationSeen(conversationId: string, entries: ConversationSeen[]): void;
7
+ /**
8
+ * Inserts or updates a seen entry for the provided actor.
9
+ */
4
10
  declare function upsertConversationSeen(options: {
5
11
  conversationId: string;
6
12
  actorType: SeenActorType;
7
13
  actorId: string;
8
14
  lastSeenAt: Date;
9
15
  }): void;
16
+ /**
17
+ * Applies realtime `conversationSeen` events to the store while optionally
18
+ * ignoring the local visitor/user.
19
+ */
10
20
  declare function applyConversationSeenEvent(event: RealtimeEvent<"conversationSeen">, options?: {
11
21
  ignoreVisitorId?: string | null;
12
22
  ignoreUserId?: string | null;
@@ -1 +1 @@
1
- {"version":3,"file":"seen-store.d.ts","names":[],"sources":["../../react/src/realtime/seen-store.ts"],"sourcesContent":[],"mappings":";;AAkEiB,iBAXD,uBAAA,CAWC,cAAA,EAAA,MAAA,EAAA,OAAA,EATP,gBASO,EAAA,CAAA,EAAA,IAAA;AAQD,iBAZA,sBAAA,CAaR,OAAA,EAAA;;aAXI;;cAEC;;iBAQG,0BAAA,QACR"}
1
+ {"version":3,"file":"seen-store.d.ts","names":[],"sources":["../../react/src/realtime/seen-store.ts"],"sourcesContent":[],"mappings":";;;;;iBA6DgB,uBAAA,kCAEN;;;;iBAQM,sBAAA;;aAEJ;;cAEC;;;;;;iBAYG,0BAAA,QACR"}
@@ -1,5 +1,4 @@
1
- import { useSupportConfig } from "../config.js";
2
1
  import { WebSocketContextValue, WebSocketProvider, useWebSocket } from "../websocket.js";
3
- import { useSupportStore } from "../support-store.js";
4
- import { Support, SupportProps } from "../index2.js";
2
+ import { useSupportConfig, useSupportStore } from "../support-store.js";
3
+ import { Support, SupportProps } from "../index7.js";
5
4
  export { Support, type SupportProps, type WebSocketContextValue, WebSocketProvider, useSupportConfig, useSupportStore, useWebSocket };
@@ -1,3 +1,5 @@
1
+ import * as React$1 from "react";
2
+
1
3
  //#region ../react/src/support-config.d.ts
2
4
  type SupportConfigProps = {
3
5
  defaultMessages?: DefaultMessage[];
@@ -10,7 +12,7 @@ declare const SupportConfig: {
10
12
  ({
11
13
  defaultMessages,
12
14
  quickOptions
13
- }: SupportConfigProps): null;
15
+ }: SupportConfigProps): React$1.ReactElement | null;
14
16
  displayName: string;
15
17
  };
16
18
  //#endregion
@@ -1 +1 @@
1
- {"version":3,"file":"support-config2.d.ts","names":[],"sources":["../../react/src/support-config.tsx"],"sourcesContent":[],"mappings":";AAMY,KAAA,kBAAA,GAAkB;EAQjB,eAAA,CAoBZ,EA3BkB,cA2BlB,EAAA;EAAA,YAAA,CAAA,EAAA,MAAA,EAAA;;;;;cApBY;;;;KAGV"}
1
+ {"version":3,"file":"support-config2.d.ts","names":[],"sources":["../../react/src/support-config.tsx"],"sourcesContent":[],"mappings":";;;KAMY,kBAAA;EAAA,eAAA,CAAA,EACO,cAAA,EAAA;EAON,YAAA,CAAA,EAAA,MAoBZ,EAAA;;;;;AAjByC,cAH7B,aAG6B,EAAA;;;;KAAvC,qBAAqB,OAAA,CAAM"}
@@ -1,5 +1,4 @@
1
1
  import React from "react";
2
- import * as react_jsx_runtime2 from "react/jsx-runtime";
3
2
 
4
3
  //#region ../react/src/realtime/support-provider.d.ts
5
4
  type SupportRealtimeProviderProps = {
@@ -11,7 +10,7 @@ type SupportRealtimeProviderProps = {
11
10
  */
12
11
  declare function SupportRealtimeProvider({
13
12
  children
14
- }: SupportRealtimeProviderProps): react_jsx_runtime2.JSX.Element;
13
+ }: SupportRealtimeProviderProps): React.ReactElement;
15
14
  //#endregion
16
15
  export { SupportRealtimeProvider };
17
16
  //# sourceMappingURL=support-provider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"support-provider.d.ts","names":[],"sources":["../../react/src/realtime/support-provider.tsx"],"sourcesContent":[],"mappings":";;;;KAkBK,4BAAA;YACM,KAAA,CAAM;;AAjBc;AAwB/B;;;AAEG,iBAFa,uBAAA,CAEb;EAAA;AAAA,CAAA,EAAA,4BAAA,CAAA,EAA4B,kBAAA,CAAA,GAAA,CAAA,OAA5B"}
1
+ {"version":3,"file":"support-provider.d.ts","names":[],"sources":["../../react/src/realtime/support-provider.tsx"],"sourcesContent":[],"mappings":";;;KAkBK,4BAAA;YACM,KAAA,CAAM;AAjBc,CAAA;AAwB/B;;;;AAEoD,iBAFpC,uBAAA,CAEoC;EAAA;AAAA,CAAA,EAAjD,4BAAiD,CAAA,EAAlB,KAAA,CAAM,YAAY"}
@@ -1,6 +1,29 @@
1
1
  //#region ../react/src/support/store/support-store.d.ts
2
2
  type UseSupportStoreResult = SupportStoreState & Pick<SupportStore, "navigate" | "replace" | "goBack" | "open" | "close" | "toggle" | "updateConfig" | "reset">;
3
+ /**
4
+ * React hook wrapper around the shared support widget store. Exposes both the
5
+ * raw state and imperative actions so UI components can drive navigation or
6
+ * change configuration without importing the store singleton directly.
7
+ */
3
8
  declare function useSupportStore(): UseSupportStoreResult;
9
+ /**
10
+ * Shortcut hook that returns the persisted widget configuration along with
11
+ * open/close/toggle helpers for common UI bindings.
12
+ */
13
+ declare const useSupportConfig: () => {
14
+ open: () => void;
15
+ close: () => void;
16
+ toggle: () => void;
17
+ size: "normal" | "larger";
18
+ isOpen: boolean;
19
+ content: {
20
+ home?: {
21
+ header?: string;
22
+ subheader?: string;
23
+ ctaLabel?: string;
24
+ };
25
+ };
26
+ };
4
27
  //#endregion
5
- export { useSupportStore };
28
+ export { useSupportConfig, useSupportStore };
6
29
  //# sourceMappingURL=support-store.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"support-store.d.ts","names":[],"sources":["../../react/src/support/store/support-store.ts"],"sourcesContent":[],"mappings":";AA8CY,KAAA,qBAAA,GAAwB,iBAAH,GAChC,IADgC,CAE/B,YAF+B,EAAA,UAAA,GAAA,SAAA,GAAA,QAAA,GAAA,MAAA,GAAA,OAAA,GAAA,QAAA,GAAA,cAAA,GAAA,OAAA,CAAA;AAAA,iBAajB,eAAA,CAAA,CAbiB,EAaE,qBAbF"}
1
+ {"version":3,"file":"support-store.d.ts","names":[],"sources":["../../react/src/support/store/support-store.ts"],"sourcesContent":[],"mappings":";AA8CY,KAAA,qBAAA,GAAwB,iBAAH,GAChC,IADgC,CAE/B,YAF+B,EAAA,UAAA,GAAA,SAAA,GAAA,QAAA,GAAA,MAAA,GAAA,OAAA,GAAA,QAAA,GAAA,cAAA,GAAA,OAAA,CAAA;;;;;AAkBjC;AAuBa,iBAvBG,eAAA,CAAA,CAmCf,EAnCkC,qBAmClC;;;;;cAZY"}
package/support.css ADDED
@@ -0,0 +1,2 @@
1
+ /*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */
2
+ @layer base{.cossistant{border-color:var(--co-border);scroll-behavior:smooth;color-scheme:normal;--co-font-sans:var(--co-theme-font-sans,var(--font-sans,"Geist","Inter",sans-serif));--co-font-mono:var(--co-theme-font-mono,var(--font-mono,"Geist Mono","Inter Mono",monospace));--co-border-color:var(--co-theme-border-color,var(--color-border,oklch(92.2% 0 0)));--co-radius:var(--co-theme-radius,var(--radius,.625rem));--co-background-base:var(--co-theme-background,var(--background,oklch(99% 0 0)));--co-foreground-base:var(--co-theme-foreground,var(--foreground,oklch(14.5% 0 0)));--co-popover-base:var(--co-theme-popover,var(--popover,var(--co-background-base)));--co-popover-foreground-base:var(--co-theme-popover-foreground,var(--popover-foreground,var(--co-foreground-base)));--co-primary-base:var(--co-theme-primary,var(--primary,oklch(20.5% 0 0)));--co-primary-foreground-base:var(--co-theme-primary-foreground,var(--primary-foreground,oklch(98.5% 0 0)));--co-secondary-base:var(--co-theme-secondary,var(--secondary,oklch(97% 0 0)));--co-secondary-foreground-base:var(--co-theme-secondary-foreground,var(--secondary-foreground,oklch(20.5% 0 0)));--co-border-base:var(--co-theme-border,var(--border,oklch(92.2% 0 0)));--co-input-base:var(--co-theme-input,var(--input,oklch(92.2% 0 0)));--co-ring-base:var(--co-theme-ring,var(--ring,var(--co-primary-base)));--co-accent-base:var(--co-theme-accent,var(--accent,var(--co-primary-base)));--co-accent-foreground-base:var(--co-theme-accent-foreground,var(--accent-foreground,var(--co-primary-foreground-base)));--co-background-50-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-background-50-mix:color-mix(in oklch,var(--co-background-base)98%,var(--co-foreground-base))}}.cossistant{--co-background-100-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-background-100-mix:color-mix(in oklch,var(--co-background-base)97%,var(--co-foreground-base))}}.cossistant{--co-background-200-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-background-200-mix:color-mix(in oklch,var(--co-background-base)96%,var(--co-foreground-base))}}.cossistant{--co-background-300-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-background-300-mix:color-mix(in oklch,var(--co-background-base)95%,var(--co-foreground-base))}}.cossistant{--co-background-400-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-background-400-mix:color-mix(in oklch,var(--co-background-base)94%,var(--co-foreground-base))}}.cossistant{--co-background-500-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-background-500-mix:color-mix(in oklch,var(--co-background-base)93%,var(--co-foreground-base))}}.cossistant{--co-background-600-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-background-600-mix:color-mix(in oklch,var(--co-background-base)92%,var(--co-foreground-base))}}.cossistant{--co-muted-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-muted-mix:color-mix(in oklch,var(--co-background-base)85%,var(--co-foreground-base))}}.cossistant{--co-muted-foreground-mix:var(--co-foreground-base)}@supports (color:color-mix(in lab, red, red)){.cossistant{--co-muted-foreground-mix:color-mix(in oklch,var(--co-foreground-base)70%,white)}}.cossistant{--co-background:var(--co-background-base);--co-background-50:var(--co-theme-background-50,var(--co-background-50-mix,oklch(92% 0 0)));--co-background-100:var(--co-theme-background-100,var(--co-background-100-mix,oklch(93% 0 0)));--co-background-200:var(--co-theme-background-200,var(--co-background-200-mix,oklch(94% 0 0)));--co-background-300:var(--co-theme-background-300,var(--co-background-300-mix,oklch(95% 0 0)));--co-background-400:var(--co-theme-background-400,var(--co-background-400-mix,oklch(96% 0 0)));--co-background-500:var(--co-theme-background-500,var(--co-background-500-mix,oklch(97% 0 0)));--co-background-600:var(--co-theme-background-600,var(--co-background-600-mix,oklch(98% 0 0)));--co-foreground:var(--co-foreground-base);--co-popover:var(--co-popover-base);--co-popover-foreground:var(--co-popover-foreground-base);--co-primary:var(--co-primary-base);--co-primary-foreground:var(--co-primary-foreground-base);--co-secondary:var(--co-secondary-base);--co-secondary-foreground:var(--co-secondary-foreground-base);--co-muted:var(--co-theme-muted,var(--muted,var(--co-muted-mix,oklch(97% 0 0))));--co-muted-foreground:var(--co-theme-muted-foreground,var(--muted-foreground,var(--co-muted-foreground-mix,oklch(55.6% 0 0))));--co-border:var(--co-border-base);--co-input:var(--co-input-base);--co-ring:var(--co-ring-base);--co-accent:var(--co-accent-base);--co-accent-foreground:var(--co-accent-foreground-base);--co-pink:var(--co-theme-pink,oklch(76.3% .152 354));--co-yellow:var(--co-theme-yellow,oklch(86.4% .144 99));--co-blue:var(--co-theme-blue,oklch(72.5% .132 241));--co-orange:var(--co-theme-orange,oklch(74.5% .166 50));--co-destructive:var(--co-theme-destructive,oklch(57.7% .245 27.325));--co-destructive-foreground:var(--co-theme-destructive-foreground,oklch(57.7% .245 27.325));--co-success:var(--co-theme-success,oklch(71.7% .18 142));--co-success-foreground:var(--co-theme-success-foreground,oklch(26.5% .052 142.7));--co-neutral:var(--co-theme-neutral,oklch(60.8% 0 0));--co-neutral-foreground:var(--co-theme-neutral-foreground,oklch(25.6% 0 0));--co-warning:var(--co-theme-warning,oklch(86.4% .144 99));--co-warning-foreground:var(--co-theme-warning-foreground,oklch(41.4% .071 99))}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-base:var(--co-theme-background,var(--background,oklch(15.5% 0 0)));--co-foreground-base:var(--co-theme-foreground,var(--foreground,oklch(98.5% 0 0)));--co-border-color:var(--co-theme-border-color,var(--color-border,oklch(26.9% 0 0)));--co-popover-base:var(--co-theme-popover,var(--popover,oklch(14.5% 0 0)));--co-popover-foreground-base:var(--co-theme-popover-foreground,var(--popover-foreground,oklch(98.5% 0 0)));--co-primary-base:var(--co-theme-primary,var(--primary,oklch(98.5% 0 0)));--co-primary-foreground-base:var(--co-theme-primary-foreground,var(--primary-foreground,oklch(20.5% 0 0)));--co-secondary-base:var(--co-theme-secondary,var(--secondary,oklch(26.9% 0 0)));--co-secondary-foreground-base:var(--co-theme-secondary-foreground,var(--secondary-foreground,oklch(98.5% 0 0)));--co-border-base:var(--co-theme-border,var(--border,oklch(26.9% 0 0)));--co-input-base:var(--co-theme-input,var(--input,oklch(26.9% 0 0)));--co-ring-base:var(--co-theme-ring,var(--ring,var(--co-primary-base)));--co-accent-base:var(--co-theme-accent,var(--accent,var(--co-primary-base)));--co-accent-foreground-base:var(--co-theme-accent-foreground,var(--accent-foreground,var(--co-primary-foreground-base)));--co-muted-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-muted-mix:color-mix(in oklch,var(--co-background-base)55%,var(--co-foreground-base))}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-muted-foreground-mix:var(--co-foreground-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-muted-foreground-mix:color-mix(in oklch,var(--co-foreground-base)65%,white)}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-50-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-50-mix:color-mix(in oklch,var(--co-background-base)98%,var(--co-foreground-base))}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-100-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-100-mix:color-mix(in oklch,var(--co-background-base)96%,var(--co-foreground-base))}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-200-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-200-mix:color-mix(in oklch,var(--co-background-base)94%,var(--co-foreground-base))}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-300-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-300-mix:color-mix(in oklch,var(--co-background-base)92%,var(--co-foreground-base))}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-400-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-400-mix:color-mix(in oklch,var(--co-background-base)90%,var(--co-foreground-base))}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-500-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-500-mix:color-mix(in oklch,var(--co-background-base)88%,var(--co-foreground-base))}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-600-mix:var(--co-background-base)}@supports (color:color-mix(in lab, red, red)){.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-background-600-mix:color-mix(in oklch,var(--co-background-base)86%,var(--co-foreground-base))}}.dark .cossistant,.cossistant[data-color-scheme=dark]{--co-pink:var(--co-theme-pink,oklch(84.2% .109 354));--co-yellow:var(--co-theme-yellow,oklch(90.3% .111 99));--co-blue:var(--co-theme-blue,oklch(79.8% .089 241));--co-orange:var(--co-theme-orange,oklch(68.2% .194 50));--co-destructive:var(--co-theme-destructive,oklch(39.6% .141 25.723));--co-destructive-foreground:var(--co-theme-destructive-foreground,oklch(63.7% .237 25.331));--co-success:var(--co-theme-success,oklch(60% .15 142));--co-success-foreground:var(--co-theme-success-foreground,oklch(85% .12 142));--co-neutral:var(--co-theme-neutral,oklch(50% 0 0));--co-neutral-foreground:var(--co-theme-neutral-foreground,oklch(85% 0 0));--co-warning:var(--co-theme-warning,oklch(90.3% .111 99));--co-warning-foreground:var(--co-theme-warning-foreground,oklch(85% .1 99))}}@layer utilities{.cossistant .animation-delay-0{animation-delay:0s}.cossistant .animation-delay-200{animation-delay:.2s}.cossistant .animation-delay-400{animation-delay:.4s}.cossistant .dot-bounce-1{animation:1.4s infinite bounce-dot}.cossistant .dot-bounce-2{animation:1.4s .16s infinite bounce-dot}.cossistant .dot-bounce-3{animation:1.4s .32s infinite bounce-dot}}