@memberjunction/ng-conversations 5.40.2 → 5.41.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +57 -0
- package/dist/__tests__/channel-optional-surface.test.d.ts +2 -0
- package/dist/__tests__/channel-optional-surface.test.d.ts.map +1 -0
- package/dist/__tests__/channel-optional-surface.test.js +53 -0
- package/dist/__tests__/channel-optional-surface.test.js.map +1 -0
- package/dist/__tests__/chat-events.test.d.ts +14 -0
- package/dist/__tests__/chat-events.test.d.ts.map +1 -0
- package/dist/__tests__/chat-events.test.js +109 -0
- package/dist/__tests__/chat-events.test.js.map +1 -0
- package/dist/__tests__/conversation-naming.test.d.ts +2 -0
- package/dist/__tests__/conversation-naming.test.d.ts.map +1 -0
- package/dist/__tests__/conversation-naming.test.js +110 -0
- package/dist/__tests__/conversation-naming.test.js.map +1 -0
- package/dist/__tests__/delegation-result-parser.test.d.ts +2 -0
- package/dist/__tests__/delegation-result-parser.test.d.ts.map +1 -0
- package/dist/__tests__/delegation-result-parser.test.js +107 -0
- package/dist/__tests__/delegation-result-parser.test.js.map +1 -0
- package/dist/__tests__/event-wiring.test.d.ts +15 -0
- package/dist/__tests__/event-wiring.test.d.ts.map +1 -0
- package/dist/__tests__/event-wiring.test.js +100 -0
- package/dist/__tests__/event-wiring.test.js.map +1 -0
- package/dist/__tests__/narration-template.test.d.ts +2 -0
- package/dist/__tests__/narration-template.test.d.ts.map +1 -0
- package/dist/__tests__/narration-template.test.js +76 -0
- package/dist/__tests__/narration-template.test.js.map +1 -0
- package/dist/__tests__/realtime-agent-picker-models.test.d.ts +2 -0
- package/dist/__tests__/realtime-agent-picker-models.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-agent-picker-models.test.js +49 -0
- package/dist/__tests__/realtime-agent-picker-models.test.js.map +1 -0
- package/dist/__tests__/realtime-audio-visuals.test.d.ts +2 -0
- package/dist/__tests__/realtime-audio-visuals.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-audio-visuals.test.js +123 -0
- package/dist/__tests__/realtime-audio-visuals.test.js.map +1 -0
- package/dist/__tests__/realtime-delegation-card-cancel.test.d.ts +2 -0
- package/dist/__tests__/realtime-delegation-card-cancel.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-delegation-card-cancel.test.js +48 -0
- package/dist/__tests__/realtime-delegation-card-cancel.test.js.map +1 -0
- package/dist/__tests__/realtime-disclosure.test.d.ts +2 -0
- package/dist/__tests__/realtime-disclosure.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-disclosure.test.js +164 -0
- package/dist/__tests__/realtime-disclosure.test.js.map +1 -0
- package/dist/__tests__/realtime-pairing.test.d.ts +2 -0
- package/dist/__tests__/realtime-pairing.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-pairing.test.js +207 -0
- package/dist/__tests__/realtime-pairing.test.js.map +1 -0
- package/dist/__tests__/realtime-review-lifecycle.test.d.ts +2 -0
- package/dist/__tests__/realtime-review-lifecycle.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-review-lifecycle.test.js +154 -0
- package/dist/__tests__/realtime-review-lifecycle.test.js.map +1 -0
- package/dist/__tests__/realtime-session-cancel-usage.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-cancel-usage.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-cancel-usage.test.js +230 -0
- package/dist/__tests__/realtime-session-cancel-usage.test.js.map +1 -0
- package/dist/__tests__/realtime-session-channels.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-channels.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-channels.test.js +252 -0
- package/dist/__tests__/realtime-session-channels.test.js.map +1 -0
- package/dist/__tests__/realtime-session-client-tools.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-client-tools.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-client-tools.test.js +103 -0
- package/dist/__tests__/realtime-session-client-tools.test.js.map +1 -0
- package/dist/__tests__/realtime-session-minimized.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-minimized.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-minimized.test.js +32 -0
- package/dist/__tests__/realtime-session-minimized.test.js.map +1 -0
- package/dist/__tests__/realtime-session-mint.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-mint.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-mint.test.js +69 -0
- package/dist/__tests__/realtime-session-mint.test.js.map +1 -0
- package/dist/__tests__/realtime-session-policy.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-policy.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-policy.test.js +303 -0
- package/dist/__tests__/realtime-session-policy.test.js.map +1 -0
- package/dist/__tests__/realtime-session-review.service.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-review.service.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-review.service.test.js +743 -0
- package/dist/__tests__/realtime-session-review.service.test.js.map +1 -0
- package/dist/__tests__/realtime-session-state.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-state.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-state.test.js +83 -0
- package/dist/__tests__/realtime-session-state.test.js.map +1 -0
- package/dist/__tests__/realtime-session-timeline-card.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-timeline-card.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-timeline-card.test.js +106 -0
- package/dist/__tests__/realtime-session-timeline-card.test.js.map +1 -0
- package/dist/__tests__/realtime-session-timeline.test.d.ts +2 -0
- package/dist/__tests__/realtime-session-timeline.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-session-timeline.test.js +142 -0
- package/dist/__tests__/realtime-session-timeline.test.js.map +1 -0
- package/dist/__tests__/realtime-sessions-adapter.test.d.ts +19 -0
- package/dist/__tests__/realtime-sessions-adapter.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-sessions-adapter.test.js +188 -0
- package/dist/__tests__/realtime-sessions-adapter.test.js.map +1 -0
- package/dist/__tests__/realtime-surface-panel-prefs.test.d.ts +2 -0
- package/dist/__tests__/realtime-surface-panel-prefs.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-surface-panel-prefs.test.js +100 -0
- package/dist/__tests__/realtime-surface-panel-prefs.test.js.map +1 -0
- package/dist/__tests__/realtime-surface-tabs-model.test.d.ts +2 -0
- package/dist/__tests__/realtime-surface-tabs-model.test.d.ts.map +1 -0
- package/dist/__tests__/realtime-surface-tabs-model.test.js +193 -0
- package/dist/__tests__/realtime-surface-tabs-model.test.js.map +1 -0
- package/dist/__tests__/remote-browser-audio-player.test.d.ts +2 -0
- package/dist/__tests__/remote-browser-audio-player.test.d.ts.map +1 -0
- package/dist/__tests__/remote-browser-audio-player.test.js +137 -0
- package/dist/__tests__/remote-browser-audio-player.test.js.map +1 -0
- package/dist/__tests__/remote-browser-channel.test.d.ts +2 -0
- package/dist/__tests__/remote-browser-channel.test.d.ts.map +1 -0
- package/dist/__tests__/remote-browser-channel.test.js +423 -0
- package/dist/__tests__/remote-browser-channel.test.js.map +1 -0
- package/dist/__tests__/slot-defaults.test.d.ts +24 -0
- package/dist/__tests__/slot-defaults.test.d.ts.map +1 -0
- package/dist/__tests__/slot-defaults.test.js +63 -0
- package/dist/__tests__/slot-defaults.test.js.map +1 -0
- package/dist/__tests__/user-authorization.test.d.ts +2 -0
- package/dist/__tests__/user-authorization.test.d.ts.map +1 -0
- package/dist/__tests__/user-authorization.test.js +97 -0
- package/dist/__tests__/user-authorization.test.js.map +1 -0
- package/dist/__tests__/voice-session-narration.test.d.ts +2 -0
- package/dist/__tests__/voice-session-narration.test.d.ts.map +1 -0
- package/dist/__tests__/voice-session-narration.test.js +609 -0
- package/dist/__tests__/voice-session-narration.test.js.map +1 -0
- package/dist/__tests__/whiteboard-artifact-viewer.test.d.ts +2 -0
- package/dist/__tests__/whiteboard-artifact-viewer.test.d.ts.map +1 -0
- package/dist/__tests__/whiteboard-artifact-viewer.test.js +101 -0
- package/dist/__tests__/whiteboard-artifact-viewer.test.js.map +1 -0
- package/dist/__tests__/whiteboard-channel.test.d.ts +2 -0
- package/dist/__tests__/whiteboard-channel.test.d.ts.map +1 -0
- package/dist/__tests__/whiteboard-channel.test.js +260 -0
- package/dist/__tests__/whiteboard-channel.test.js.map +1 -0
- package/dist/__tests__/whiteboard-restore-state.test.d.ts +2 -0
- package/dist/__tests__/whiteboard-restore-state.test.d.ts.map +1 -0
- package/dist/__tests__/whiteboard-restore-state.test.js +108 -0
- package/dist/__tests__/whiteboard-restore-state.test.js.map +1 -0
- package/dist/lib/components/conversation/conversation-chat-area.component.d.ts +205 -3
- package/dist/lib/components/conversation/conversation-chat-area.component.d.ts.map +1 -1
- package/dist/lib/components/conversation/conversation-chat-area.component.js +911 -342
- package/dist/lib/components/conversation/conversation-chat-area.component.js.map +1 -1
- package/dist/lib/components/mention/mention-dropdown.component.js +35 -17
- package/dist/lib/components/mention/mention-dropdown.component.js.map +1 -1
- package/dist/lib/components/mention/mention-editor.component.d.ts +4 -0
- package/dist/lib/components/mention/mention-editor.component.d.ts.map +1 -1
- package/dist/lib/components/mention/mention-editor.component.js +43 -19
- package/dist/lib/components/mention/mention-editor.component.js.map +1 -1
- package/dist/lib/components/message/message-input-box.component.d.ts +17 -1
- package/dist/lib/components/message/message-input-box.component.d.ts.map +1 -1
- package/dist/lib/components/message/message-input-box.component.js +73 -15
- package/dist/lib/components/message/message-input-box.component.js.map +1 -1
- package/dist/lib/components/message/message-input.component.d.ts +142 -6
- package/dist/lib/components/message/message-input.component.d.ts.map +1 -1
- package/dist/lib/components/message/message-input.component.js +328 -82
- package/dist/lib/components/message/message-input.component.js.map +1 -1
- package/dist/lib/components/message/message-item.component.d.ts +28 -3
- package/dist/lib/components/message/message-item.component.d.ts.map +1 -1
- package/dist/lib/components/message/message-item.component.js +180 -108
- package/dist/lib/components/message/message-item.component.js.map +1 -1
- package/dist/lib/components/message/message-list.component.d.ts +81 -2
- package/dist/lib/components/message/message-list.component.d.ts.map +1 -1
- package/dist/lib/components/message/message-list.component.js +252 -87
- package/dist/lib/components/message/message-list.component.js.map +1 -1
- package/dist/lib/components/realtime/channels/base-realtime-channel-client.d.ts +282 -0
- package/dist/lib/components/realtime/channels/base-realtime-channel-client.d.ts.map +1 -0
- package/dist/lib/components/realtime/channels/base-realtime-channel-client.js +158 -0
- package/dist/lib/components/realtime/channels/base-realtime-channel-client.js.map +1 -0
- package/dist/lib/components/realtime/channels/channel-onboarding-panel.component.d.ts +25 -0
- package/dist/lib/components/realtime/channels/channel-onboarding-panel.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/channels/channel-onboarding-panel.component.js +140 -0
- package/dist/lib/components/realtime/channels/channel-onboarding-panel.component.js.map +1 -0
- package/dist/lib/components/realtime/channels/realtime-channel-pane.component.d.ts +35 -0
- package/dist/lib/components/realtime/channels/realtime-channel-pane.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/channels/realtime-channel-pane.component.js +58 -0
- package/dist/lib/components/realtime/channels/realtime-channel-pane.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-activity-rail.component.d.ts +63 -0
- package/dist/lib/components/realtime/realtime-activity-rail.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-activity-rail.component.js +260 -0
- package/dist/lib/components/realtime/realtime-activity-rail.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-agent-banner.component.d.ts +117 -0
- package/dist/lib/components/realtime/realtime-agent-banner.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-agent-banner.component.js +504 -0
- package/dist/lib/components/realtime/realtime-agent-banner.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-agent-picker.component.d.ts +168 -0
- package/dist/lib/components/realtime/realtime-agent-picker.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-agent-picker.component.js +556 -0
- package/dist/lib/components/realtime/realtime-agent-picker.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-audio-visuals.d.ts +97 -0
- package/dist/lib/components/realtime/realtime-audio-visuals.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-audio-visuals.js +139 -0
- package/dist/lib/components/realtime/realtime-audio-visuals.js.map +1 -0
- package/dist/lib/components/realtime/realtime-channel-strip.component.d.ts +29 -0
- package/dist/lib/components/realtime/realtime-channel-strip.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-channel-strip.component.js +69 -0
- package/dist/lib/components/realtime/realtime-channel-strip.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-composer.component.d.ts +65 -0
- package/dist/lib/components/realtime/realtime-composer.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-composer.component.js +256 -0
- package/dist/lib/components/realtime/realtime-composer.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-delegation-card.component.d.ts +71 -0
- package/dist/lib/components/realtime/realtime-delegation-card.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-delegation-card.component.js +324 -0
- package/dist/lib/components/realtime/realtime-delegation-card.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-disclosure.d.ts +135 -0
- package/dist/lib/components/realtime/realtime-disclosure.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-disclosure.js +188 -0
- package/dist/lib/components/realtime/realtime-disclosure.js.map +1 -0
- package/dist/lib/components/realtime/realtime-session-overlay.component.d.ts +491 -0
- package/dist/lib/components/realtime/realtime-session-overlay.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-session-overlay.component.js +1274 -0
- package/dist/lib/components/realtime/realtime-session-overlay.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-session-state.d.ts +191 -0
- package/dist/lib/components/realtime/realtime-session-state.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-session-state.js +244 -0
- package/dist/lib/components/realtime/realtime-session-state.js.map +1 -0
- package/dist/lib/components/realtime/realtime-session-thread.component.d.ts +56 -0
- package/dist/lib/components/realtime/realtime-session-thread.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-session-thread.component.js +246 -0
- package/dist/lib/components/realtime/realtime-session-thread.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-session-timeline-card.component.d.ts +51 -0
- package/dist/lib/components/realtime/realtime-session-timeline-card.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-session-timeline-card.component.js +193 -0
- package/dist/lib/components/realtime/realtime-session-timeline-card.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-surface-panel-prefs.d.ts +77 -0
- package/dist/lib/components/realtime/realtime-surface-panel-prefs.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-surface-panel-prefs.js +114 -0
- package/dist/lib/components/realtime/realtime-surface-panel-prefs.js.map +1 -0
- package/dist/lib/components/realtime/realtime-surface-tabs.component.d.ts +173 -0
- package/dist/lib/components/realtime/realtime-surface-tabs.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-surface-tabs.component.js +496 -0
- package/dist/lib/components/realtime/realtime-surface-tabs.component.js.map +1 -0
- package/dist/lib/components/realtime/realtime-surface-tabs.model.d.ts +181 -0
- package/dist/lib/components/realtime/realtime-surface-tabs.model.d.ts.map +1 -0
- package/dist/lib/components/realtime/realtime-surface-tabs.model.js +223 -0
- package/dist/lib/components/realtime/realtime-surface-tabs.model.js.map +1 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-audio-player.d.ts +163 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-audio-player.d.ts.map +1 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-audio-player.js +309 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-audio-player.js.map +1 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-channel.d.ts +168 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-channel.d.ts.map +1 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-channel.js +524 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-channel.js.map +1 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-surface.component.d.ts +346 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-surface.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-surface.component.js +851 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-surface.component.js.map +1 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-tools.d.ts +86 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-tools.d.ts.map +1 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-tools.js +210 -0
- package/dist/lib/components/realtime/remote-browser/remote-browser-tools.js.map +1 -0
- package/dist/lib/components/realtime/whiteboard/whiteboard-artifact-viewer.component.d.ts +48 -0
- package/dist/lib/components/realtime/whiteboard/whiteboard-artifact-viewer.component.d.ts.map +1 -0
- package/dist/lib/components/realtime/whiteboard/whiteboard-artifact-viewer.component.js +180 -0
- package/dist/lib/components/realtime/whiteboard/whiteboard-artifact-viewer.component.js.map +1 -0
- package/dist/lib/components/realtime/whiteboard/whiteboard-channel.d.ts +119 -0
- package/dist/lib/components/realtime/whiteboard/whiteboard-channel.d.ts.map +1 -0
- package/dist/lib/components/realtime/whiteboard/whiteboard-channel.js +274 -0
- package/dist/lib/components/realtime/whiteboard/whiteboard-channel.js.map +1 -0
- package/dist/lib/components/slots/mj-chat-agent-presence-default.component.d.ts +11 -0
- package/dist/lib/components/slots/mj-chat-agent-presence-default.component.d.ts.map +1 -0
- package/dist/lib/components/slots/mj-chat-agent-presence-default.component.js +98 -0
- package/dist/lib/components/slots/mj-chat-agent-presence-default.component.js.map +1 -0
- package/dist/lib/components/slots/mj-chat-demonstration-surface-default.component.d.ts +9 -0
- package/dist/lib/components/slots/mj-chat-demonstration-surface-default.component.d.ts.map +1 -0
- package/dist/lib/components/slots/mj-chat-demonstration-surface-default.component.js +35 -0
- package/dist/lib/components/slots/mj-chat-demonstration-surface-default.component.js.map +1 -0
- package/dist/lib/components/slots/mj-chat-empty-state-default.component.d.ts +28 -0
- package/dist/lib/components/slots/mj-chat-empty-state-default.component.d.ts.map +1 -0
- package/dist/lib/components/slots/mj-chat-empty-state-default.component.js +104 -0
- package/dist/lib/components/slots/mj-chat-empty-state-default.component.js.map +1 -0
- package/dist/lib/components/slots/mj-chat-header-default.component.d.ts +11 -0
- package/dist/lib/components/slots/mj-chat-header-default.component.d.ts.map +1 -0
- package/dist/lib/components/slots/mj-chat-header-default.component.js +103 -0
- package/dist/lib/components/slots/mj-chat-header-default.component.js.map +1 -0
- package/dist/lib/components/slots/mj-chat-message-bubble-default.component.d.ts +15 -0
- package/dist/lib/components/slots/mj-chat-message-bubble-default.component.d.ts.map +1 -0
- package/dist/lib/components/slots/mj-chat-message-bubble-default.component.js +73 -0
- package/dist/lib/components/slots/mj-chat-message-bubble-default.component.js.map +1 -0
- package/dist/lib/components/slots/mj-chat-message-extra-default.component.d.ts +9 -0
- package/dist/lib/components/slots/mj-chat-message-extra-default.component.d.ts.map +1 -0
- package/dist/lib/components/slots/mj-chat-message-extra-default.component.js +34 -0
- package/dist/lib/components/slots/mj-chat-message-extra-default.component.js.map +1 -0
- package/dist/lib/components/slots/slot-interfaces.d.ts +95 -0
- package/dist/lib/components/slots/slot-interfaces.d.ts.map +1 -0
- package/dist/lib/components/slots/slot-interfaces.js +18 -0
- package/dist/lib/components/slots/slot-interfaces.js.map +1 -0
- package/dist/lib/components/workspace/conversation-workspace.component.d.ts +11 -0
- package/dist/lib/components/workspace/conversation-workspace.component.d.ts.map +1 -1
- package/dist/lib/components/workspace/conversation-workspace.component.js +28 -4
- package/dist/lib/components/workspace/conversation-workspace.component.js.map +1 -1
- package/dist/lib/conversations.module.d.ts +12 -1
- package/dist/lib/conversations.module.d.ts.map +1 -1
- package/dist/lib/conversations.module.js +93 -5
- package/dist/lib/conversations.module.js.map +1 -1
- package/dist/lib/directives/chat-slot.directive.d.ts +44 -0
- package/dist/lib/directives/chat-slot.directive.d.ts.map +1 -0
- package/dist/lib/directives/chat-slot.directive.js +54 -0
- package/dist/lib/directives/chat-slot.directive.js.map +1 -0
- package/dist/lib/events/chat-events.d.ts +137 -0
- package/dist/lib/events/chat-events.d.ts.map +1 -0
- package/dist/lib/events/chat-events.js +189 -0
- package/dist/lib/events/chat-events.js.map +1 -0
- package/dist/lib/models/conversation-state.model.d.ts +2 -1
- package/dist/lib/models/conversation-state.model.d.ts.map +1 -1
- package/dist/lib/models/conversation-state.model.js.map +1 -1
- package/dist/lib/services/artifact-state.service.d.ts.map +1 -1
- package/dist/lib/services/artifact-state.service.js +23 -6
- package/dist/lib/services/artifact-state.service.js.map +1 -1
- package/dist/lib/services/conversation-agent.service.d.ts +60 -74
- package/dist/lib/services/conversation-agent.service.d.ts.map +1 -1
- package/dist/lib/services/conversation-agent.service.js +100 -313
- package/dist/lib/services/conversation-agent.service.js.map +1 -1
- package/dist/lib/services/conversation-bridge.service.d.ts +11 -70
- package/dist/lib/services/conversation-bridge.service.d.ts.map +1 -1
- package/dist/lib/services/conversation-bridge.service.js +51 -85
- package/dist/lib/services/conversation-bridge.service.js.map +1 -1
- package/dist/lib/services/conversation-naming.d.ts +63 -0
- package/dist/lib/services/conversation-naming.d.ts.map +1 -0
- package/dist/lib/services/conversation-naming.js +58 -0
- package/dist/lib/services/conversation-naming.js.map +1 -0
- package/dist/lib/services/conversation-streaming.service.d.ts +24 -154
- package/dist/lib/services/conversation-streaming.service.d.ts.map +1 -1
- package/dist/lib/services/conversation-streaming.service.js +39 -361
- package/dist/lib/services/conversation-streaming.service.js.map +1 -1
- package/dist/lib/services/conversations-runtime-bootstrap.service.d.ts +10 -0
- package/dist/lib/services/conversations-runtime-bootstrap.service.d.ts.map +1 -0
- package/dist/lib/services/conversations-runtime-bootstrap.service.js +104 -0
- package/dist/lib/services/conversations-runtime-bootstrap.service.js.map +1 -0
- package/dist/lib/services/delegation-result-parser.d.ts +45 -0
- package/dist/lib/services/delegation-result-parser.d.ts.map +1 -0
- package/dist/lib/services/delegation-result-parser.js +48 -0
- package/dist/lib/services/delegation-result-parser.js.map +1 -0
- package/dist/lib/services/mention-autocomplete.service.d.ts +19 -4
- package/dist/lib/services/mention-autocomplete.service.d.ts.map +1 -1
- package/dist/lib/services/mention-autocomplete.service.js +65 -4
- package/dist/lib/services/mention-autocomplete.service.js.map +1 -1
- package/dist/lib/services/mention-parser.service.d.ts +8 -53
- package/dist/lib/services/mention-parser.service.d.ts.map +1 -1
- package/dist/lib/services/mention-parser.service.js +32 -243
- package/dist/lib/services/mention-parser.service.js.map +1 -1
- package/dist/lib/services/narration-template.d.ts +42 -0
- package/dist/lib/services/narration-template.d.ts.map +1 -0
- package/dist/lib/services/narration-template.js +73 -0
- package/dist/lib/services/narration-template.js.map +1 -0
- package/dist/lib/services/realtime-pairing.d.ts +120 -0
- package/dist/lib/services/realtime-pairing.d.ts.map +1 -0
- package/dist/lib/services/realtime-pairing.js +150 -0
- package/dist/lib/services/realtime-pairing.js.map +1 -0
- package/dist/lib/services/realtime-session-review.service.d.ts +233 -0
- package/dist/lib/services/realtime-session-review.service.d.ts.map +1 -0
- package/dist/lib/services/realtime-session-review.service.js +417 -0
- package/dist/lib/services/realtime-session-review.service.js.map +1 -0
- package/dist/lib/services/realtime-session.service.d.ts +739 -0
- package/dist/lib/services/realtime-session.service.d.ts.map +1 -0
- package/dist/lib/services/realtime-session.service.js +1647 -0
- package/dist/lib/services/realtime-session.service.js.map +1 -0
- package/dist/lib/services/realtime-sessions-adapter.d.ts +54 -0
- package/dist/lib/services/realtime-sessions-adapter.d.ts.map +1 -0
- package/dist/lib/services/realtime-sessions-adapter.js +154 -0
- package/dist/lib/services/realtime-sessions-adapter.js.map +1 -0
- package/dist/lib/services/user-authorization.d.ts +67 -0
- package/dist/lib/services/user-authorization.d.ts.map +1 -0
- package/dist/lib/services/user-authorization.js +66 -0
- package/dist/lib/services/user-authorization.js.map +1 -0
- package/dist/lib/utils/realtime-session-timeline.d.ts +84 -0
- package/dist/lib/utils/realtime-session-timeline.d.ts.map +1 -0
- package/dist/lib/utils/realtime-session-timeline.js +94 -0
- package/dist/lib/utils/realtime-session-timeline.js.map +1 -0
- package/dist/public-api.d.ts +41 -0
- package/dist/public-api.d.ts.map +1 -1
- package/dist/public-api.js +50 -0
- package/dist/public-api.js.map +1 -1
- package/package.json +27 -24
- package/dist/__tests__/conversation-bridge.service.test.d.ts +0 -2
- package/dist/__tests__/conversation-bridge.service.test.d.ts.map +0 -1
- package/dist/__tests__/conversation-bridge.service.test.js +0 -98
- package/dist/__tests__/conversation-bridge.service.test.js.map +0 -1
- package/dist/__tests__/mention-parser.test.d.ts +0 -2
- package/dist/__tests__/mention-parser.test.d.ts.map +0 -1
- package/dist/__tests__/mention-parser.test.js +0 -154
- package/dist/__tests__/mention-parser.test.js.map +0 -1
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach } from 'vitest';
|
|
2
|
-
import { ConversationBridgeService } from '../lib/services/conversation-bridge.service';
|
|
3
|
-
describe('ConversationBridgeService', () => {
|
|
4
|
-
let service;
|
|
5
|
-
beforeEach(() => {
|
|
6
|
-
service = new ConversationBridgeService();
|
|
7
|
-
});
|
|
8
|
-
describe('ActiveConversationID$', () => {
|
|
9
|
-
it('should start with null', () => {
|
|
10
|
-
expect(service.ActiveConversationID$.value).toBeNull();
|
|
11
|
-
});
|
|
12
|
-
it('should update when set from overlay', () => {
|
|
13
|
-
service.SetActiveFromOverlay('conv-123');
|
|
14
|
-
expect(service.ActiveConversationID$.value).toBe('conv-123');
|
|
15
|
-
});
|
|
16
|
-
it('should update when set from workspace', () => {
|
|
17
|
-
service.SetActiveFromWorkspace('conv-456');
|
|
18
|
-
expect(service.ActiveConversationID$.value).toBe('conv-456');
|
|
19
|
-
});
|
|
20
|
-
it('should allow clearing active conversation', () => {
|
|
21
|
-
service.SetActiveFromOverlay('conv-123');
|
|
22
|
-
service.SetActiveFromOverlay(null);
|
|
23
|
-
expect(service.ActiveConversationID$.value).toBeNull();
|
|
24
|
-
});
|
|
25
|
-
});
|
|
26
|
-
describe('SwitchToWorkspace', () => {
|
|
27
|
-
it('should emit switch event with correct source and target', () => {
|
|
28
|
-
const events = [];
|
|
29
|
-
service.SwitchEvent$.subscribe(e => events.push(e));
|
|
30
|
-
service.SwitchToWorkspace('conv-123');
|
|
31
|
-
expect(events).toHaveLength(1);
|
|
32
|
-
expect(events[0].ConversationID).toBe('conv-123');
|
|
33
|
-
expect(events[0].Source).toBe('overlay');
|
|
34
|
-
expect(events[0].Target).toBe('workspace');
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
describe('SwitchToOverlay', () => {
|
|
38
|
-
it('should emit switch event with correct source and target', () => {
|
|
39
|
-
const events = [];
|
|
40
|
-
service.SwitchEvent$.subscribe(e => events.push(e));
|
|
41
|
-
service.SwitchToOverlay('conv-456');
|
|
42
|
-
expect(events).toHaveLength(1);
|
|
43
|
-
expect(events[0].Source).toBe('workspace');
|
|
44
|
-
expect(events[0].Target).toBe('overlay');
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
describe('NavigateToConversation', () => {
|
|
48
|
-
it('should set active conversation and emit deep link', () => {
|
|
49
|
-
const deepLinks = [];
|
|
50
|
-
service.DeepLinkRequest$.subscribe(dl => deepLinks.push(dl));
|
|
51
|
-
service.NavigateToConversation({
|
|
52
|
-
ConversationID: 'conv-789',
|
|
53
|
-
OpenIn: 'workspace'
|
|
54
|
-
});
|
|
55
|
-
expect(service.ActiveConversationID$.value).toBe('conv-789');
|
|
56
|
-
expect(deepLinks).toHaveLength(1);
|
|
57
|
-
expect(deepLinks[0].OpenIn).toBe('workspace');
|
|
58
|
-
});
|
|
59
|
-
it('should support optional message ID', () => {
|
|
60
|
-
const deepLinks = [];
|
|
61
|
-
service.DeepLinkRequest$.subscribe(dl => deepLinks.push(dl));
|
|
62
|
-
service.NavigateToConversation({
|
|
63
|
-
ConversationID: 'conv-789',
|
|
64
|
-
MessageID: 'msg-42'
|
|
65
|
-
});
|
|
66
|
-
expect(deepLinks[0].MessageID).toBe('msg-42');
|
|
67
|
-
});
|
|
68
|
-
});
|
|
69
|
-
describe('OverlayActive$ and WorkspaceActive$', () => {
|
|
70
|
-
it('should track overlay state', () => {
|
|
71
|
-
service.NotifyOverlayActive(true);
|
|
72
|
-
expect(service.OverlayActive$.value).toBe(true);
|
|
73
|
-
service.NotifyOverlayActive(false);
|
|
74
|
-
expect(service.OverlayActive$.value).toBe(false);
|
|
75
|
-
});
|
|
76
|
-
it('should track workspace state', () => {
|
|
77
|
-
service.NotifyWorkspaceActive(true);
|
|
78
|
-
expect(service.WorkspaceActive$.value).toBe(true);
|
|
79
|
-
});
|
|
80
|
-
});
|
|
81
|
-
describe('ShouldResumeInOverlay', () => {
|
|
82
|
-
it('should return true when workspace is inactive and conversation exists', () => {
|
|
83
|
-
service.NotifyWorkspaceActive(false);
|
|
84
|
-
service.SetActiveFromOverlay('conv-123');
|
|
85
|
-
expect(service.ShouldResumeInOverlay()).toBe(true);
|
|
86
|
-
});
|
|
87
|
-
it('should return false when workspace is active', () => {
|
|
88
|
-
service.NotifyWorkspaceActive(true);
|
|
89
|
-
service.SetActiveFromOverlay('conv-123');
|
|
90
|
-
expect(service.ShouldResumeInOverlay()).toBe(false);
|
|
91
|
-
});
|
|
92
|
-
it('should return false when no active conversation', () => {
|
|
93
|
-
service.NotifyWorkspaceActive(false);
|
|
94
|
-
expect(service.ShouldResumeInOverlay()).toBe(false);
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
});
|
|
98
|
-
//# sourceMappingURL=conversation-bridge.service.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"conversation-bridge.service.test.js","sourceRoot":"","sources":["../../src/__tests__/conversation-bridge.service.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, it, expect, beforeEach, vi } from 'vitest';\nimport {\n ConversationBridgeService,\n ConversationSwitchEvent,\n ConversationDeepLink\n} from '../lib/services/conversation-bridge.service';\n\ndescribe('ConversationBridgeService', () => {\n let service: ConversationBridgeService;\n\n beforeEach(() => {\n service = new ConversationBridgeService();\n });\n\n describe('ActiveConversationID$', () => {\n it('should start with null', () => {\n expect(service.ActiveConversationID$.value).toBeNull();\n });\n\n it('should update when set from overlay', () => {\n service.SetActiveFromOverlay('conv-123');\n expect(service.ActiveConversationID$.value).toBe('conv-123');\n });\n\n it('should update when set from workspace', () => {\n service.SetActiveFromWorkspace('conv-456');\n expect(service.ActiveConversationID$.value).toBe('conv-456');\n });\n\n it('should allow clearing active conversation', () => {\n service.SetActiveFromOverlay('conv-123');\n service.SetActiveFromOverlay(null);\n expect(service.ActiveConversationID$.value).toBeNull();\n });\n });\n\n describe('SwitchToWorkspace', () => {\n it('should emit switch event with correct source and target', () => {\n const events: ConversationSwitchEvent[] = [];\n service.SwitchEvent$.subscribe(e => events.push(e));\n\n service.SwitchToWorkspace('conv-123');\n\n expect(events).toHaveLength(1);\n expect(events[0].ConversationID).toBe('conv-123');\n expect(events[0].Source).toBe('overlay');\n expect(events[0].Target).toBe('workspace');\n });\n });\n\n describe('SwitchToOverlay', () => {\n it('should emit switch event with correct source and target', () => {\n const events: ConversationSwitchEvent[] = [];\n service.SwitchEvent$.subscribe(e => events.push(e));\n\n service.SwitchToOverlay('conv-456');\n\n expect(events).toHaveLength(1);\n expect(events[0].Source).toBe('workspace');\n expect(events[0].Target).toBe('overlay');\n });\n });\n\n describe('NavigateToConversation', () => {\n it('should set active conversation and emit deep link', () => {\n const deepLinks: ConversationDeepLink[] = [];\n service.DeepLinkRequest$.subscribe(dl => deepLinks.push(dl));\n\n service.NavigateToConversation({\n ConversationID: 'conv-789',\n OpenIn: 'workspace'\n });\n\n expect(service.ActiveConversationID$.value).toBe('conv-789');\n expect(deepLinks).toHaveLength(1);\n expect(deepLinks[0].OpenIn).toBe('workspace');\n });\n\n it('should support optional message ID', () => {\n const deepLinks: ConversationDeepLink[] = [];\n service.DeepLinkRequest$.subscribe(dl => deepLinks.push(dl));\n\n service.NavigateToConversation({\n ConversationID: 'conv-789',\n MessageID: 'msg-42'\n });\n\n expect(deepLinks[0].MessageID).toBe('msg-42');\n });\n });\n\n describe('OverlayActive$ and WorkspaceActive$', () => {\n it('should track overlay state', () => {\n service.NotifyOverlayActive(true);\n expect(service.OverlayActive$.value).toBe(true);\n\n service.NotifyOverlayActive(false);\n expect(service.OverlayActive$.value).toBe(false);\n });\n\n it('should track workspace state', () => {\n service.NotifyWorkspaceActive(true);\n expect(service.WorkspaceActive$.value).toBe(true);\n });\n });\n\n describe('ShouldResumeInOverlay', () => {\n it('should return true when workspace is inactive and conversation exists', () => {\n service.NotifyWorkspaceActive(false);\n service.SetActiveFromOverlay('conv-123');\n expect(service.ShouldResumeInOverlay()).toBe(true);\n });\n\n it('should return false when workspace is active', () => {\n service.NotifyWorkspaceActive(true);\n service.SetActiveFromOverlay('conv-123');\n expect(service.ShouldResumeInOverlay()).toBe(false);\n });\n\n it('should return false when no active conversation', () => {\n service.NotifyWorkspaceActive(false);\n expect(service.ShouldResumeInOverlay()).toBe(false);\n });\n });\n});\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mention-parser.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/mention-parser.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
|
-
// Mock Angular and MJ deps
|
|
3
|
-
vi.mock('@angular/core', () => ({ Injectable: () => () => { } }));
|
|
4
|
-
vi.mock('@memberjunction/ai-core-plus', () => ({
|
|
5
|
-
MJAIAgentEntityExtended: class {
|
|
6
|
-
},
|
|
7
|
-
ConversationUtility: {
|
|
8
|
-
ToPlainText: vi.fn((text) => text.replace(/@\{[^}]+\}/g, '@MockName'))
|
|
9
|
-
}
|
|
10
|
-
}));
|
|
11
|
-
vi.mock('@memberjunction/core', () => ({
|
|
12
|
-
UserInfo: class {
|
|
13
|
-
ID = '';
|
|
14
|
-
Name = '';
|
|
15
|
-
Email = '';
|
|
16
|
-
}
|
|
17
|
-
}));
|
|
18
|
-
import { MentionParserService } from '../lib/services/mention-parser.service';
|
|
19
|
-
// Create mock agents matching MJAIAgentEntityExtended shape
|
|
20
|
-
function createMockAgent(id, name) {
|
|
21
|
-
return { ID: id, Name: name };
|
|
22
|
-
}
|
|
23
|
-
function createMockUser(id, name, email) {
|
|
24
|
-
return { ID: id, Name: name, Email: email };
|
|
25
|
-
}
|
|
26
|
-
describe('MentionParserService', () => {
|
|
27
|
-
let service;
|
|
28
|
-
beforeEach(() => {
|
|
29
|
-
service = new MentionParserService();
|
|
30
|
-
});
|
|
31
|
-
describe('parseMentions - JSON format', () => {
|
|
32
|
-
it('should parse JSON mention format', () => {
|
|
33
|
-
const text = '@{"type":"agent","id":"123","name":"Sage"} help me';
|
|
34
|
-
const agents = [createMockAgent('123', 'Sage')];
|
|
35
|
-
const result = service.parseMentions(text, agents);
|
|
36
|
-
expect(result.mentions).toHaveLength(1);
|
|
37
|
-
expect(result.mentions[0].type).toBe('agent');
|
|
38
|
-
expect(result.mentions[0].id).toBe('123');
|
|
39
|
-
expect(result.mentions[0].name).toBe('Sage');
|
|
40
|
-
expect(result.agentMention).not.toBeNull();
|
|
41
|
-
});
|
|
42
|
-
it('should parse JSON mention with config', () => {
|
|
43
|
-
const text = '@{"type":"agent","id":"123","name":"Sage","configId":"cfg-1"} hello';
|
|
44
|
-
const agents = [createMockAgent('123', 'Sage')];
|
|
45
|
-
const result = service.parseMentions(text, agents);
|
|
46
|
-
expect(result.mentions[0].configurationId).toBe('cfg-1');
|
|
47
|
-
});
|
|
48
|
-
it('should handle invalid JSON gracefully', () => {
|
|
49
|
-
const text = '@{invalid json} hello';
|
|
50
|
-
const agents = [];
|
|
51
|
-
const result = service.parseMentions(text, agents);
|
|
52
|
-
expect(result.mentions).toHaveLength(0);
|
|
53
|
-
});
|
|
54
|
-
it('should skip mentions missing required fields', () => {
|
|
55
|
-
const text = '@{"type":"agent"} hello';
|
|
56
|
-
const agents = [];
|
|
57
|
-
const result = service.parseMentions(text, agents);
|
|
58
|
-
expect(result.mentions).toHaveLength(0);
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
describe('parseMentions - legacy format', () => {
|
|
62
|
-
it('should match agent by exact name', () => {
|
|
63
|
-
const text = '@Sage help me';
|
|
64
|
-
const agents = [createMockAgent('a1', 'Sage')];
|
|
65
|
-
const result = service.parseMentions(text, agents);
|
|
66
|
-
expect(result.mentions).toHaveLength(1);
|
|
67
|
-
expect(result.agentMention).not.toBeNull();
|
|
68
|
-
expect(result.agentMention.name).toBe('Sage');
|
|
69
|
-
});
|
|
70
|
-
it('should match quoted names with spaces', () => {
|
|
71
|
-
const text = '@"Data Agent" help me';
|
|
72
|
-
const agents = [createMockAgent('a2', 'Data Agent')];
|
|
73
|
-
const result = service.parseMentions(text, agents);
|
|
74
|
-
expect(result.mentions).toHaveLength(1);
|
|
75
|
-
expect(result.agentMention.name).toBe('Data Agent');
|
|
76
|
-
});
|
|
77
|
-
it('should match agent by starts-with', () => {
|
|
78
|
-
const text = '@Sag help me';
|
|
79
|
-
const agents = [createMockAgent('a1', 'Sage')];
|
|
80
|
-
const result = service.parseMentions(text, agents);
|
|
81
|
-
expect(result.mentions).toHaveLength(1);
|
|
82
|
-
});
|
|
83
|
-
it('should match users if no agent matches', () => {
|
|
84
|
-
const text = '@John hello';
|
|
85
|
-
const agents = [];
|
|
86
|
-
const users = [createMockUser('u1', 'John Doe', 'john@test.com')];
|
|
87
|
-
const result = service.parseMentions(text, agents, users);
|
|
88
|
-
expect(result.mentions).toHaveLength(1);
|
|
89
|
-
expect(result.mentions[0].type).toBe('user');
|
|
90
|
-
expect(result.userMentions).toHaveLength(1);
|
|
91
|
-
});
|
|
92
|
-
it('should separate agent and user mentions', () => {
|
|
93
|
-
const result = service.parseMentions('hello', []);
|
|
94
|
-
expect(result.agentMention).toBeNull();
|
|
95
|
-
expect(result.userMentions).toHaveLength(0);
|
|
96
|
-
});
|
|
97
|
-
});
|
|
98
|
-
describe('extractMentionNames', () => {
|
|
99
|
-
it('should extract names from JSON mentions', () => {
|
|
100
|
-
const text = '@{"type":"agent","id":"1","name":"Sage"} and @{"type":"user","id":"2","name":"John"}';
|
|
101
|
-
const names = service.extractMentionNames(text);
|
|
102
|
-
expect(names).toContain('Sage');
|
|
103
|
-
expect(names).toContain('John');
|
|
104
|
-
});
|
|
105
|
-
it('should extract names from legacy mentions', () => {
|
|
106
|
-
const text = '@Sage and @"John Doe" hello';
|
|
107
|
-
const names = service.extractMentionNames(text);
|
|
108
|
-
expect(names).toContain('Sage');
|
|
109
|
-
expect(names).toContain('John Doe');
|
|
110
|
-
});
|
|
111
|
-
it('should return empty for no mentions', () => {
|
|
112
|
-
const names = service.extractMentionNames('no mentions here');
|
|
113
|
-
expect(names).toHaveLength(0);
|
|
114
|
-
});
|
|
115
|
-
});
|
|
116
|
-
describe('validateMentions', () => {
|
|
117
|
-
it('should return invalid JSON mentions', () => {
|
|
118
|
-
const text = '@{"type":"agent","id":"1","name":"Unknown"}';
|
|
119
|
-
const agents = [];
|
|
120
|
-
const invalid = service.validateMentions(text, agents);
|
|
121
|
-
expect(invalid).toContain('Unknown');
|
|
122
|
-
});
|
|
123
|
-
it('should return empty for valid mentions', () => {
|
|
124
|
-
const text = '@{"type":"agent","id":"1","name":"Sage"}';
|
|
125
|
-
const agents = [createMockAgent('1', 'Sage')];
|
|
126
|
-
const invalid = service.validateMentions(text, agents);
|
|
127
|
-
expect(invalid).toHaveLength(0);
|
|
128
|
-
});
|
|
129
|
-
it('should validate legacy mentions against agents', () => {
|
|
130
|
-
const text = '@Unknown hello';
|
|
131
|
-
const agents = [];
|
|
132
|
-
const invalid = service.validateMentions(text, agents);
|
|
133
|
-
expect(invalid).toContain('Unknown');
|
|
134
|
-
});
|
|
135
|
-
});
|
|
136
|
-
describe('formatMentions', () => {
|
|
137
|
-
it('should format mentions with proper names', () => {
|
|
138
|
-
const text = '@"sage" hello';
|
|
139
|
-
const mentions = [{ type: 'agent', id: '1', name: 'Sage' }];
|
|
140
|
-
const formatted = service.formatMentions(text, mentions);
|
|
141
|
-
expect(formatted).toContain('@Sage');
|
|
142
|
-
});
|
|
143
|
-
});
|
|
144
|
-
describe('toPlainText', () => {
|
|
145
|
-
it('should return empty string for empty input', () => {
|
|
146
|
-
expect(service.toPlainText('')).toBe('');
|
|
147
|
-
});
|
|
148
|
-
it('should delegate to ConversationUtility.ToPlainText', () => {
|
|
149
|
-
const result = service.toPlainText('@{"type":"agent","id":"1","name":"Sage"} hello');
|
|
150
|
-
expect(result).toBeDefined();
|
|
151
|
-
});
|
|
152
|
-
});
|
|
153
|
-
});
|
|
154
|
-
//# sourceMappingURL=mention-parser.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mention-parser.test.js","sourceRoot":"","sources":["../../src/__tests__/mention-parser.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, it, expect, vi, beforeEach } from 'vitest';\n\n// Mock Angular and MJ deps\nvi.mock('@angular/core', () => ({ Injectable: () => () => {} }));\nvi.mock('@memberjunction/ai-core-plus', () => ({\n MJAIAgentEntityExtended: class {},\n ConversationUtility: {\n ToPlainText: vi.fn((text: string) => text.replace(/@\\{[^}]+\\}/g, '@MockName'))\n }\n}));\nvi.mock('@memberjunction/core', () => ({\n UserInfo: class { ID = ''; Name = ''; Email = ''; }\n}));\n\nimport { MentionParserService } from '../lib/services/mention-parser.service';\n\n// Create mock agents matching MJAIAgentEntityExtended shape\nfunction createMockAgent(id: string, name: string): { ID: string; Name: string } {\n return { ID: id, Name: name };\n}\n\nfunction createMockUser(id: string, name: string, email?: string): { ID: string; Name: string; Email?: string } {\n return { ID: id, Name: name, Email: email };\n}\n\ndescribe('MentionParserService', () => {\n let service: MentionParserService;\n\n beforeEach(() => {\n service = new MentionParserService();\n });\n\n describe('parseMentions - JSON format', () => {\n it('should parse JSON mention format', () => {\n const text = '@{\"type\":\"agent\",\"id\":\"123\",\"name\":\"Sage\"} help me';\n const agents = [createMockAgent('123', 'Sage')] as never[];\n const result = service.parseMentions(text, agents);\n\n expect(result.mentions).toHaveLength(1);\n expect(result.mentions[0].type).toBe('agent');\n expect(result.mentions[0].id).toBe('123');\n expect(result.mentions[0].name).toBe('Sage');\n expect(result.agentMention).not.toBeNull();\n });\n\n it('should parse JSON mention with config', () => {\n const text = '@{\"type\":\"agent\",\"id\":\"123\",\"name\":\"Sage\",\"configId\":\"cfg-1\"} hello';\n const agents = [createMockAgent('123', 'Sage')] as never[];\n const result = service.parseMentions(text, agents);\n\n expect(result.mentions[0].configurationId).toBe('cfg-1');\n });\n\n it('should handle invalid JSON gracefully', () => {\n const text = '@{invalid json} hello';\n const agents: never[] = [];\n const result = service.parseMentions(text, agents);\n expect(result.mentions).toHaveLength(0);\n });\n\n it('should skip mentions missing required fields', () => {\n const text = '@{\"type\":\"agent\"} hello';\n const agents: never[] = [];\n const result = service.parseMentions(text, agents);\n expect(result.mentions).toHaveLength(0);\n });\n });\n\n describe('parseMentions - legacy format', () => {\n it('should match agent by exact name', () => {\n const text = '@Sage help me';\n const agents = [createMockAgent('a1', 'Sage')] as never[];\n const result = service.parseMentions(text, agents);\n\n expect(result.mentions).toHaveLength(1);\n expect(result.agentMention).not.toBeNull();\n expect(result.agentMention!.name).toBe('Sage');\n });\n\n it('should match quoted names with spaces', () => {\n const text = '@\"Data Agent\" help me';\n const agents = [createMockAgent('a2', 'Data Agent')] as never[];\n const result = service.parseMentions(text, agents);\n\n expect(result.mentions).toHaveLength(1);\n expect(result.agentMention!.name).toBe('Data Agent');\n });\n\n it('should match agent by starts-with', () => {\n const text = '@Sag help me';\n const agents = [createMockAgent('a1', 'Sage')] as never[];\n const result = service.parseMentions(text, agents);\n\n expect(result.mentions).toHaveLength(1);\n });\n\n it('should match users if no agent matches', () => {\n const text = '@John hello';\n const agents: never[] = [];\n const users = [createMockUser('u1', 'John Doe', 'john@test.com')] as never[];\n const result = service.parseMentions(text, agents, users);\n\n expect(result.mentions).toHaveLength(1);\n expect(result.mentions[0].type).toBe('user');\n expect(result.userMentions).toHaveLength(1);\n });\n\n it('should separate agent and user mentions', () => {\n const result = service.parseMentions('hello', [] as never[]);\n expect(result.agentMention).toBeNull();\n expect(result.userMentions).toHaveLength(0);\n });\n });\n\n describe('extractMentionNames', () => {\n it('should extract names from JSON mentions', () => {\n const text = '@{\"type\":\"agent\",\"id\":\"1\",\"name\":\"Sage\"} and @{\"type\":\"user\",\"id\":\"2\",\"name\":\"John\"}';\n const names = service.extractMentionNames(text);\n expect(names).toContain('Sage');\n expect(names).toContain('John');\n });\n\n it('should extract names from legacy mentions', () => {\n const text = '@Sage and @\"John Doe\" hello';\n const names = service.extractMentionNames(text);\n expect(names).toContain('Sage');\n expect(names).toContain('John Doe');\n });\n\n it('should return empty for no mentions', () => {\n const names = service.extractMentionNames('no mentions here');\n expect(names).toHaveLength(0);\n });\n });\n\n describe('validateMentions', () => {\n it('should return invalid JSON mentions', () => {\n const text = '@{\"type\":\"agent\",\"id\":\"1\",\"name\":\"Unknown\"}';\n const agents: never[] = [];\n const invalid = service.validateMentions(text, agents);\n expect(invalid).toContain('Unknown');\n });\n\n it('should return empty for valid mentions', () => {\n const text = '@{\"type\":\"agent\",\"id\":\"1\",\"name\":\"Sage\"}';\n const agents = [createMockAgent('1', 'Sage')] as never[];\n const invalid = service.validateMentions(text, agents);\n expect(invalid).toHaveLength(0);\n });\n\n it('should validate legacy mentions against agents', () => {\n const text = '@Unknown hello';\n const agents: never[] = [];\n const invalid = service.validateMentions(text, agents);\n expect(invalid).toContain('Unknown');\n });\n });\n\n describe('formatMentions', () => {\n it('should format mentions with proper names', () => {\n const text = '@\"sage\" hello';\n const mentions = [{ type: 'agent' as const, id: '1', name: 'Sage' }];\n const formatted = service.formatMentions(text, mentions);\n expect(formatted).toContain('@Sage');\n });\n });\n\n describe('toPlainText', () => {\n it('should return empty string for empty input', () => {\n expect(service.toPlainText('')).toBe('');\n });\n\n it('should delegate to ConversationUtility.ToPlainText', () => {\n const result = service.toPlainText('@{\"type\":\"agent\",\"id\":\"1\",\"name\":\"Sage\"} hello');\n expect(result).toBeDefined();\n });\n });\n});\n"]}
|