@bitrix24/b24ui-nuxt
Version:
Bitrix24 UI-Kit for developing web applications REST API for NUXT & VUE
74 lines (73 loc) • 2.71 kB
text/typescript
import type { ChatStatus } from 'ai';
import type { AppConfig } from '@nuxt/schema';
import theme from '#build/b24ui/chat-prompt-submit';
import type { ButtonProps, ButtonSlots, IconComponent, LinkPropsKeys } from '../types';
import type { ComponentConfig } from '../types/tv';
type ChatPromptSubmit = ComponentConfig<typeof theme, AppConfig, 'chatPromptSubmit'>;
export interface ChatPromptSubmitProps extends Omit<ButtonProps, LinkPropsKeys | 'icon' | 'color'> {
status?: ChatStatus;
/**
* The icon displayed in the button when the status is `ready`.
* @defaultValue icons.imSend
* @IconComponent
*/
icon?: IconComponent;
/**
* The color of the button when the status is `ready`.
* @defaultValue 'air-primary'
*/
color?: ButtonProps['color'];
/**
* The icon displayed in the button when the status is `streaming`.
* @defaultValue icons.stop
* @IconComponent
*/
streamingIcon?: IconComponent;
/**
* The color of the button when the status is `streaming`.
* @defaultValue 'air-secondary-accent-2'
*/
streamingColor?: ButtonProps['color'];
/**
* The icon displayed in the button when the status is `submitted`.
* @defaultValue icons.stop
* @IconComponent
*/
submittedIcon?: IconComponent;
/**
* The color of the button when the status is `submitted`.
* @defaultValue 'air-secondary-no-accent'
*/
submittedColor?: ButtonProps['color'];
/**
* The icon displayed in the button when the status is `error`.
* @defaultValue icons.reload
* @IconComponent
*/
errorIcon?: IconComponent;
/**
* The color of the button when the status is `error`.
* @defaultValue 'air-primary-alert'
*/
errorColor?: ButtonProps['color'];
b24ui?: ChatPromptSubmit['slots'] & ButtonProps['b24ui'];
class?: any;
}
export interface ChatPromptSubmitEmits {
stop: [event: MouseEvent];
reload: [event: MouseEvent];
}
declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<ChatPromptSubmitProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
stop: (event: MouseEvent) => any;
reload: (event: MouseEvent) => any;
}, string, import("vue").PublicProps, Readonly<ChatPromptSubmitProps> & Readonly<{
onStop?: ((event: MouseEvent) => any) | undefined;
onReload?: ((event: MouseEvent) => any) | undefined;
}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, ButtonSlots>;
declare const _default: typeof __VLS_export;
export default _default;
type __VLS_WithSlots<T, S> = T & {
new (): {
$slots: S;
};
};