@farris/x-ui 0.0.5 → 0.0.7

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.
@@ -10,6 +10,8 @@ export { invokeAgentWorkbenchSdkApi } from '../../src/invoke-agent-workbench-sdk
10
10
  export { createPreviewIframeSdk } from '../../src/preview-iframe-sdk';
11
11
  /** @deprecated */
12
12
  export type { CreatePreviewIframeSdkOptions } from '../../src/preview-iframe-sdk';
13
+ /** 会话分屏预览:由 FXConversation 注册,供 AgentWorkbenchSDK 等聚合调用 */
14
+ export { registerPreviewChromeSdk, previewLayoutBridge, type PreviewChromeSdkHandlers, } from '../../src/preview-chrome-sdk';
13
15
  export { FXChatPreview };
14
16
  declare const _default: typeof FXChatPreview & Plugin;
15
17
  export default _default;
@@ -12,7 +12,7 @@ export interface PreviewChromeSdkHandlers {
12
12
  * 会话组件挂载时注册;卸载时执行返回函数。多实例时后进先出,避免前一个页面卸载清空后一个的句柄。
13
13
  */
14
14
  export declare function registerPreviewChromeSdk(handlers: PreviewChromeSdkHandlers): () => void;
15
- /** 实现细节:对外由 `AgentWorkbenchSDK`(`agent-workbench-sdk.ts`)聚合暴露。 */
15
+ /** 实现细节:对外由 `@farris/x-workbench` 的 `agent-workbench-sdk.ts` 聚合为 `window.AgentWorkbenchSDK`。 */
16
16
  export declare const previewLayoutBridge: {
17
17
  /**
18
18
  * 打开或更新预览:右侧空 → 单栏右侧;仅右侧已有 → 双栏(旧右→左,新→右);**左右已有 → 只替换右侧 iframe**。
package/components.d.ts CHANGED
@@ -42,8 +42,6 @@ export { default as FXPopover } from '../popover';
42
42
  export * from '../popover';
43
43
  export { default as FXSplitter, FXSplitterPane } from '../splitter';
44
44
  export * from '../splitter';
45
- export { default as FXAccordion, FXAccordionItem } from '../accordion';
46
- export * from '../accordion';
47
45
  export { default as FXNav } from '../nav';
48
46
  export * from '../nav';
49
47
  export { default as FXSearchBox, FXSearchBoxContainer } from '../search-box';
@@ -2,6 +2,6 @@ import { Plugin } from '../../vue';
2
2
  import { default as FXDynamicComponent } from '../../src/dynamic-component.component';
3
3
  export { default as FXDynamicComponent } from '../../src/dynamic-component.component';
4
4
  export * from '../../src/composition/types';
5
- export { loadDynamicComponent, unloadDynamicComponent, postDynamicComponentAssistantMessage } from '../../src/composition/dynamic-component-registry';
5
+ export { loadDynamicComponent, unloadDynamicComponent, postDynamicComponentAssistantMessage, peekDynamicComponentRegisterBootstrapId, normalizeDynamicComponentRegisterClaim, getDynamicComponentRegistryDebugSnapshot } from '../../src/composition/dynamic-component-registry';
6
6
  declare const _default: typeof FXDynamicComponent & Plugin;
7
7
  export default _default;
@@ -1,10 +1,23 @@
1
1
  import { DynamicComponentConfig, DynamicComponentAPI, DynamicComponentAssistantMessagePayload } from '../../../../types';
2
2
 
3
+ /** 与对话 mock 「口令规范化」同源:隐蔽字符会导致 pending key 肉眼一致却 get 失败 */
4
+ export declare function normalizeDynamicComponentRegisterClaim(raw: unknown): string;
5
+ /** 供调试:`import { peekDynamicComponentRegisterBootstrapId } from '@farris/x-ui'` */
6
+ export declare function peekDynamicComponentRegisterBootstrapId(): string | undefined;
7
+ /** 控制台联调快照 */
8
+ export declare function getDynamicComponentRegistryDebugSnapshot(): {
9
+ pendingKeys: string[];
10
+ bootstrapQueue: string[];
11
+ activeKeys: string[];
12
+ windowBootstrapPeek?: string;
13
+ };
3
14
  export declare function loadDynamicComponent(config: DynamicComponentConfig): Promise<DynamicComponentAPI>;
4
15
  export declare function unloadDynamicComponent(id: string): void;
5
16
  export declare function postDynamicComponentAssistantMessage(id: string, payload: DynamicComponentAssistantMessagePayload): boolean;
6
17
  declare global {
7
18
  interface Window {
8
19
  __fluens_dynamic_component_register: (id: string, api: DynamicComponentAPI) => void;
20
+ __fluens_dynamic_component_bootstrap_instance_id?: string;
21
+ __fluens_get_dynamic_component_registry_debug_snapshot?: typeof getDynamicComponentRegistryDebugSnapshot;
9
22
  }
10
23
  }
@@ -12,18 +12,20 @@ export interface DynamicComponentConfig {
12
12
  isFullscreen?: boolean;
13
13
  autoOpen?: boolean;
14
14
  fileRe?: string;
15
+ /** 打开后落位目标面板,默认 'preview' */
16
+ target?: 'preview' | 'previewExtra';
15
17
  }
16
18
  export interface DynamicComponentAssistantMessagePayload {
17
19
  messageId: string;
18
- role: 'assistant';
19
- /** 会话内 assistant 消息的完整 content;包含 dynamic-component 围栏、markdown、复合块等结构。 */
20
+ role: 'user' | 'assistant';
21
+ /** 会话内消息的完整 content;含 dynamic-component 围栏、markdown、复合块等(与 UI 气泡一致)。 */
20
22
  content: unknown;
21
23
  }
22
24
  export interface DynamicComponentAPI {
23
25
  mount(container: HTMLElement, config: DynamicComponentConfig): void;
24
26
  unmount(): void;
25
27
  /**
26
- * 可选:接收唤起当前 dynamic-component 的 assistant 消息,以及之后同会话继续产生的 assistant 消息。
28
+ * 可选:接收同会话内用户/助手消息(与右侧 iframe 预览桥一致),用于侧栏/预览区与流式同步。
27
29
  */
28
30
  onAssistantMessage?: (payload: DynamicComponentAssistantMessagePayload) => void;
29
31
  }