@ti-tecnologico-de-monterrey-oficial/ds-ng 1.5.1319-b → 1.5.1319-d

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.
@@ -30,8 +30,8 @@ export declare class BmbCardButtonComponent {
30
30
  iconTemplate: TemplateRef<any> | null;
31
31
  isTemplate: import("@angular/core").InputSignal<boolean>;
32
32
  textLink: import("@angular/core").InputSignal<IBmbLinkConfiguration | undefined>;
33
- onAddContentClick: import("@angular/core").OutputEmitterRef<MouseEvent>;
34
- onTitleClick: import("@angular/core").OutputEmitterRef<MouseEvent>;
33
+ onAddContentClick: import("@angular/core").OutputEmitterRef<MouseEvent | KeyboardEvent>;
34
+ onTitleClick: import("@angular/core").OutputEmitterRef<MouseEvent | KeyboardEvent>;
35
35
  onSmallClick: import("@angular/core").OutputEmitterRef<MouseEvent>;
36
36
  isSmall: import("@angular/core").InputSignal<boolean>;
37
37
  botIcon: import("@angular/core").InputSignal<string>;
@@ -43,8 +43,8 @@ export declare class BmbCardButtonComponent {
43
43
  customContent: TemplateRef<any>;
44
44
  truncateText(text: string, maxLength: number): string;
45
45
  handleSmallClick(event: MouseEvent): void;
46
- handleTitleClick(event: MouseEvent): void;
47
- handleAddContent(event: MouseEvent): void;
46
+ handleTitleClick(event: MouseEvent | KeyboardEvent): void;
47
+ handleAddContent(event: MouseEvent | KeyboardEvent): void;
48
48
  static ɵfac: i0.ɵɵFactoryDeclaration<BmbCardButtonComponent, never>;
49
49
  static ɵcmp: i0.ɵɵComponentDeclaration<BmbCardButtonComponent, "bmb-card-button", never, { "isFullInteractive": { "alias": "isFullInteractive"; "required": false; "isSignal": true; }; "title": { "alias": "title"; "required": false; "isSignal": true; }; "body": { "alias": "body"; "required": false; "isSignal": true; }; "badge": { "alias": "badge"; "required": false; "isSignal": true; }; "icon": { "alias": "icon"; "required": false; "isSignal": true; }; "leftContentIcon": { "alias": "leftContentIcon"; "required": false; "isSignal": true; }; "leftContentImage": { "alias": "leftContentImage"; "required": false; "isSignal": true; }; "leftContent": { "alias": "leftContent"; "required": false; "isSignal": true; }; "hasMenu": { "alias": "hasMenu"; "required": false; "isSignal": true; }; "menuItems": { "alias": "menuItems"; "required": false; "isSignal": true; }; "isTemplate": { "alias": "isTemplate"; "required": false; "isSignal": true; }; "textLink": { "alias": "textLink"; "required": false; "isSignal": true; }; "isSmall": { "alias": "isSmall"; "required": false; "isSignal": true; }; "botIcon": { "alias": "botIcon"; "required": false; "isSignal": true; }; "botImage": { "alias": "botImage"; "required": false; "isSignal": true; }; "smallIcon": { "alias": "smallIcon"; "required": false; "isSignal": true; }; "smallTitle": { "alias": "smallTitle"; "required": false; "isSignal": true; }; "smallDescription": { "alias": "smallDescription"; "required": false; "isSignal": true; }; }, { "onAddContentClick": "onAddContentClick"; "onTitleClick": "onTitleClick"; "onSmallClick": "onSmallClick"; }, ["customContent"], ["*"], true, never>;
50
50
  }
@@ -8,16 +8,16 @@ export declare class BmbChatBubblesComponent {
8
8
  isThinking: import("@angular/core").InputSignal<boolean>;
9
9
  iconBotDefault: import("@angular/core").Signal<string>;
10
10
  gptActiveIcons: import("@angular/core").InputSignal<IBmbChatGptIcons>;
11
- onRepeatRequest: import("@angular/core").OutputEmitterRef<MouseEvent>;
12
- onVoice: import("@angular/core").OutputEmitterRef<MouseEvent>;
13
- onCopy: import("@angular/core").OutputEmitterRef<MouseEvent>;
14
- onLike: import("@angular/core").OutputEmitterRef<MouseEvent>;
15
- onDislike: import("@angular/core").OutputEmitterRef<MouseEvent>;
16
- handleRepeat(event: MouseEvent): void;
17
- handleVoice(event: MouseEvent): void;
18
- handleCopyContent(event: MouseEvent): void;
19
- handleLike(event: MouseEvent): void;
20
- handleDislike(event: MouseEvent): void;
11
+ onRepeatRequest: import("@angular/core").OutputEmitterRef<MouseEvent | KeyboardEvent>;
12
+ onVoice: import("@angular/core").OutputEmitterRef<MouseEvent | KeyboardEvent>;
13
+ onCopy: import("@angular/core").OutputEmitterRef<MouseEvent | KeyboardEvent>;
14
+ onLike: import("@angular/core").OutputEmitterRef<MouseEvent | KeyboardEvent>;
15
+ onDislike: import("@angular/core").OutputEmitterRef<MouseEvent | KeyboardEvent>;
16
+ handleRepeat(event: MouseEvent | KeyboardEvent): void;
17
+ handleVoice(event: MouseEvent | KeyboardEvent): void;
18
+ handleCopyContent(event: MouseEvent | KeyboardEvent): void;
19
+ handleLike(event: MouseEvent | KeyboardEvent): void;
20
+ handleDislike(event: MouseEvent | KeyboardEvent): void;
21
21
  static ɵfac: i0.ɵɵFactoryDeclaration<BmbChatBubblesComponent, never>;
22
22
  static ɵcmp: i0.ɵɵComponentDeclaration<BmbChatBubblesComponent, "bmb-chat-bubble", never, { "iconBot": { "alias": "iconBot"; "required": false; "isSignal": true; }; "message": { "alias": "message"; "required": true; "isSignal": true; }; "gptBot": { "alias": "gptBot"; "required": false; "isSignal": true; }; "gptIcons": { "alias": "gptIcons"; "required": false; "isSignal": true; }; "isThinking": { "alias": "isThinking"; "required": false; "isSignal": true; }; "gptActiveIcons": { "alias": "gptActiveIcons"; "required": false; "isSignal": true; }; }, { "onRepeatRequest": "onRepeatRequest"; "onVoice": "onVoice"; "onCopy": "onCopy"; "onLike": "onLike"; "onDislike": "onDislike"; }, never, never, true, never>;
23
23
  }
@@ -0,0 +1,13 @@
1
+ import { FormControl, FormGroup } from '@angular/forms';
2
+ import * as i0 from "@angular/core";
3
+ export type IBmbTextEditorPromptType = 'link' | 'image';
4
+ export declare class BmbTextEditorPromptComponent {
5
+ type: import("@angular/core").InputSignal<IBmbTextEditorPromptType>;
6
+ formValues: import("@angular/core").OutputEmitterRef<Record<string, unknown>>;
7
+ cancelForm: import("@angular/core").OutputEmitterRef<void>;
8
+ formGroup: FormGroup;
9
+ getFormControl(name: string): FormControl;
10
+ handleFormGroupState(): void;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<BmbTextEditorPromptComponent, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<BmbTextEditorPromptComponent, "app-bmb-text-editor-prompt", never, { "type": { "alias": "type"; "required": true; "isSignal": true; }; }, { "formValues": "formValues"; "cancelForm": "cancelForm"; }, never, never, true, never>;
13
+ }
@@ -1,28 +1,34 @@
1
- import { ElementRef } from '@angular/core';
1
+ import { AfterViewInit, ElementRef, OnInit } from '@angular/core';
2
2
  import { FormControl } from '@angular/forms';
3
3
  import { DomSanitizer, SafeHtml } from '@angular/platform-browser';
4
+ import { BmbProjectionContentService } from '../../services/projection/projection.service';
5
+ import { IBmbTextEditorPromptType } from './bmb-text-editor-prompt/bmb-text-editor-prompt.component';
4
6
  import * as i0 from "@angular/core";
5
- export declare class BmbTextEditorComponent {
6
- private sanitizer;
7
+ export declare class BmbTextEditorComponent implements AfterViewInit, OnInit {
8
+ private readonly sanitizer;
9
+ private readonly projectionContent;
7
10
  control: import("@angular/core").InputSignal<FormControl<any>>;
8
11
  editor: ElementRef<HTMLDivElement>;
9
- htmlContent: string;
10
- sanitizedContent: SafeHtml;
12
+ sanitizedContent: import("@angular/core").WritableSignal<SafeHtml>;
11
13
  currentAlignment: string;
12
14
  showTableDialog: boolean;
13
15
  tableRows: number;
14
16
  tableColumns: number;
17
+ userSelection: Range | null;
15
18
  detectAlignment(): void;
16
19
  applyAlignment(alignment: string): void;
17
- constructor(sanitizer: DomSanitizer);
20
+ constructor(sanitizer: DomSanitizer, projectionContent: BmbProjectionContentService);
21
+ ngOnInit(): void;
18
22
  ngAfterViewInit(): void;
19
23
  handleChange(event: Event, type: string): void;
20
24
  execCommand(command: string, value?: string | null): void;
21
- insertLink(): void;
25
+ openPrompt(type: IBmbTextEditorPromptType, event: MouseEvent): void;
26
+ handleClosePrompt(values: Record<string, unknown>): void;
27
+ insertLink(values: Record<string, unknown>): void;
28
+ insertImage(values: Record<string, unknown>): void;
22
29
  updateContent(): void;
23
30
  clearFormatting(): void;
24
31
  getCurrentState(): any;
25
- insertImage(): void;
26
32
  isValidImageUrl(url: string): boolean;
27
33
  openTableDialog(): void;
28
34
  closeTableDialog(): void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ti-tecnologico-de-monterrey-oficial/ds-ng",
3
- "version": "1.5.1319-b",
3
+ "version": "1.5.1319-d",
4
4
  "description": "Design System oficial del Tecnológico de Monterrey - Descubre cómo nuestro Design System no solo da forma a la estética, sino que también impulsa la consistencia en cada rincón de nuestro diseño, proporcionando una base sólida para construir experiencias memorables y coherentes. Únete a nosotros en este viaje donde la creatividad, coherencia y elegancia se encuentran para dar vida a un mundo visualmente armonioso y funcionalmente fluido.",
5
5
  "keywords": [
6
6
  "angular",