@fundamental-ngx/ui5-webcomponents-ai 0.58.0-rc.73 → 0.58.0-rc.75

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.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fundamental-ngx-ui5-webcomponents-ai-input.mjs","sources":["../tmp-esm2022/input/index.js","../tmp-esm2022/input/fundamental-ngx-ui5-webcomponents-ai-input.js"],"sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, input, output, effect, runInInjectionContext, inject, Injector, booleanAttribute } from '@angular/core';\nimport '@ui5/webcomponents-ai/dist/Input.js';\nimport * as i0 from \"@angular/core\";\nexport class Input {\n constructor() {\n /**\n * Indicates the index of the currently displayed version.\n */\n this.currentVersion = input(0, ...(ngDevMode ? [{ debugName: \"currentVersion\" }] : []));\n /**\n * Indicates the total number of result versions available.\n \n When not set or set to 0, the versioning will be hidden.\n */\n this.totalVersions = input(0, ...(ngDevMode ? [{ debugName: \"totalVersions\" }] : []));\n /**\n * Defines whether the AI Writing Assistant is currently loading.\n \n When `true`, indicates that an AI action is in progress.\n */\n this.loading = input(false, ...(ngDevMode ? [{ debugName: \"loading\", transform: booleanAttribute }] : [{ transform: booleanAttribute }])); // className is now passed\n /**\n * Fired when the user selects the AI button.\n */\n this.ui5ButtonClick = output();\n /**\n * Fired when an item from the AI actions menu is clicked.\n */\n this.ui5ItemClick = output();\n /**\n * Fired when the user selects the \"Stop\" button to stop ongoing AI text generation.\n */\n this.ui5StopGeneration = output();\n /**\n * Fired when the user selects the version navigation buttons.\n */\n this.ui5VersionChange = output();\n /**\n * Available slots for content projection in this component.\n *\n * Slots allow you to insert custom content into predefined areas of the web component.\n * Use the `slot` attribute on child elements to target specific slots.\n *\n * - **actions**: Defines the items of the menu for the component.\n *\n * @example\n * ```html\n * <ui5-ai-input>\n * <div slot=\"header\">Custom header content</div>\n * <p>Default slot content</p>\n * </ui5-ai-input>\n * ```\n *\n * @readonly\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n */\n this.slots = [\n {\n \"name\": \"actions\",\n \"description\": \"Defines the items of the menu for the component.\"\n }\n ];\n this.elementRef = inject(ElementRef);\n this.injector = inject(Injector);\n }\n get element() {\n return this.elementRef.nativeElement;\n }\n ngAfterViewInit() {\n const wcElement = this.element;\n const inputsToSync = [\n 'currentVersion',\n 'totalVersions',\n 'loading',\n ];\n // Synchronize inputs (properties)\n for (const inputName of inputsToSync) {\n // Find the corresponding camelCase signal property on the Angular component\n const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());\n // Use the Injector to run the effect in the correct context\n if (this[signalName] && typeof this[signalName] === 'function') {\n runInInjectionContext(this.injector, () => {\n effect(() => {\n // Read the signal value\n const value = this[signalName]();\n if (wcElement) {\n // Write the value to the Web Component's property\n wcElement[inputName] = value;\n }\n });\n });\n }\n }\n const outputsToSync = [\n 'ui5ButtonClick',\n 'ui5ItemClick',\n 'ui5StopGeneration',\n 'ui5VersionChange',\n ];\n // Synchronize outputs (events)\n for (const outputName of outputsToSync) {\n // Map Angular output name to UI5 web component event name\n const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n // Ensure the output property exists and has an emit function before adding listener\n if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n // Cast the listener to the correct type to satisfy TypeScript\n wcElement.addEventListener(eventName, (e) => {\n this[outputName].emit(e);\n });\n }\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: Input, deps: [], target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"17.1.0\", version: \"20.1.4\", type: Input, isStandalone: true, selector: \"ui5-ai-input, [ui5-ai-input]\", inputs: { currentVersion: { classPropertyName: \"currentVersion\", publicName: \"currentVersion\", isSignal: true, isRequired: false, transformFunction: null }, totalVersions: { classPropertyName: \"totalVersions\", publicName: \"totalVersions\", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: \"loading\", publicName: \"loading\", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5ButtonClick: \"ui5ButtonClick\", ui5ItemClick: \"ui5ItemClick\", ui5StopGeneration: \"ui5StopGeneration\", ui5VersionChange: \"ui5VersionChange\" }, exportAs: [\"ui5Input\"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: Input, decorators: [{\n type: Component,\n args: [{\n standalone: true,\n selector: 'ui5-ai-input, [ui5-ai-input]',\n template: '<ng-content></ng-content>',\n exportAs: 'ui5Input',\n changeDetection: ChangeDetectionStrategy.OnPush,\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/ui5-webcomponents-ai/input/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,KAAK,EACL,MAAM,EAEN,MAAM,EACN,qBAAqB,EACrB,MAAM,EACN,QAAQ,EACR,gBAAgB,EAGjB,MAAM,eAAe,CAAC;AACvB,OAAO,qCAAqC,CAAC;;AAc7C,MAAM,OAAO,KAAK;IARlB;QAUE;;WAEG;QACH,mBAAc,GAAG,KAAK,CAAqD,CAAC,0DAAC,CAAC;QAE9E;;;;WAIG;QACH,kBAAa,GAAG,KAAK,CAAoD,CAAC,yDAAC,CAAC;QAE5E;;;;WAIG;QACH,YAAO,GAAG,KAAK,CAAC,KAAK,2CAAI,SAAS,EAAE,gBAAgB,OAA7B,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAC,CAAC,CAAC,0BAA0B;QAInF;;WAEG;QACH,mBAAc,GAAG,MAAM,EAA0C,CAAC;QAElE;;WAEG;QACH,iBAAY,GAAG,MAAM,EAAwC,CAAC;QAE9D;;WAEG;QACH,sBAAiB,GAAG,MAAM,EAA6C,CAAC;QAExE;;WAEG;QACH,qBAAgB,GAAG,MAAM,EAA4C,CAAC;QAEtE;;;;;;;;;;;;;;;;;;WAkBG;QACM,UAAK,GAAG;YACb;gBACI,MAAM,EAAE,SAAS;gBACjB,aAAa,EAAE,kDAAkD;aACpE;SACJ,CAAC;QAGK,eAAU,GAAuB,MAAM,CAAC,UAAU,CAAC,CAAC;QACpD,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;KA2DpC;IAzDC,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACvC,CAAC;IAED,eAAe;QACb,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC;QAE/B,MAAM,YAAY,GAAG;YACnB,gBAAgB;YAChB,eAAe;YACf,SAAS;SACV,CAAC;QAEF,kCAAkC;QAClC,KAAK,MAAM,SAAS,IAAI,YAAY,EAAE,CAAC;YACrC,4EAA4E;YAC5E,MAAM,UAAU,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;YAE/E,4DAA4D;YAC5D,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,UAAU,EAAE,CAAC;gBAC/D,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE;oBACxC,MAAM,CAAC,GAAG,EAAE;wBACV,wBAAwB;wBACxB,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;wBACjC,IAAI,SAAS,EAAE,CAAC;4BACd,kDAAkD;4BAClD,SAAS,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC;wBAC/B,CAAC;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAGD,MAAM,aAAa,GAAG;YACpB,gBAAgB;YAChB,cAAc;YACd,mBAAmB;YACnB,kBAAkB;SACnB,CAAC;QAEF,+BAA+B;QAC/B,KAAK,MAAM,UAAU,IAAI,aAAa,EAAE,CAAC;YACvC,0DAA0D;YAC1D,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YACtG,oFAAoF;YACpF,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,KAAK,UAAU,IAAI,SAAS,CAAC,gBAAgB,EAAE,CAAC;gBAClG,8DAA8D;gBAC9D,SAAS,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE;oBAE1C,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAqB,CAAC,CAAC;gBAC/C,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IAGH,CAAC;8GAjIU,KAAK;kGAAL,KAAK,wrBALN,2BAA2B;;2FAK1B,KAAK;kBARjB,SAAS;mBAAC;oBACT,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,8BAA8B;oBACxC,QAAQ,EAAE,2BAA2B;oBACrC,QAAQ,EAAE,UAAU;oBAEpB,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD","sourcesContent":["\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  input,\n  output,\n  AfterViewInit,\n  effect,\n  runInInjectionContext,\n  inject,\n  Injector,\n  booleanAttribute,\n  computed,\n  signal\n} from '@angular/core';\nimport '@ui5/webcomponents-ai/dist/Input.js';\nimport { default as _Input } from '@ui5/webcomponents-ai/dist/Input.js';\nimport { UI5CustomEvent } from '@ui5/webcomponents-base';\n\n\n\n@Component({\n  standalone: true,\n  selector: 'ui5-ai-input, [ui5-ai-input]',\n  template: '<ng-content></ng-content>',\n  exportAs: 'ui5Input',\n\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class Input implements AfterViewInit {\n\n  /**\n   * Indicates the index of the currently displayed version.\n   */\n  currentVersion = input<typeof _Input.prototype.currentVersion | undefined>(0);\n\n  /**\n   * Indicates the total number of result versions available.\n\nWhen not set or set to 0, the versioning will be hidden.\n   */\n  totalVersions = input<typeof _Input.prototype.totalVersions | undefined>(0);\n\n  /**\n   * Defines whether the AI Writing Assistant is currently loading.\n\nWhen `true`, indicates that an AI action is in progress.\n   */\n  loading = input(false, { transform: booleanAttribute }); // className is now passed\n\n\n\n  /**\n   * Fired when the user selects the AI button.\n   */\n  ui5ButtonClick = output<UI5CustomEvent<_Input, 'button-click'>>();\n\n  /**\n   * Fired when an item from the AI actions menu is clicked.\n   */\n  ui5ItemClick = output<UI5CustomEvent<_Input, 'item-click'>>();\n\n  /**\n   * Fired when the user selects the \"Stop\" button to stop ongoing AI text generation.\n   */\n  ui5StopGeneration = output<UI5CustomEvent<_Input, 'stop-generation'>>();\n\n  /**\n   * Fired when the user selects the version navigation buttons.\n   */\n  ui5VersionChange = output<UI5CustomEvent<_Input, 'version-change'>>();\n\n  /**\n   * Available slots for content projection in this component.\n   * \n   * Slots allow you to insert custom content into predefined areas of the web component.\n   * Use the `slot` attribute on child elements to target specific slots.\n   * \n   * - **actions**: Defines the items of the menu for the component.\n   * \n   * @example\n   * ```html\n   * <ui5-ai-input>\n   *   <div slot=\"header\">Custom header content</div>\n   *   <p>Default slot content</p>\n   * </ui5-ai-input>\n   * ```\n   * \n   * @readonly\n   * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n   */\n  readonly slots = [\n      {\n          \"name\": \"actions\",\n          \"description\": \"Defines the items of the menu for the component.\"\n      }\n  ];\n\n\n  public elementRef: ElementRef<_Input> = inject(ElementRef);\n  public injector = inject(Injector);\n\n  get element(): _Input {\n    return this.elementRef.nativeElement;\n  }\n\n  ngAfterViewInit(): void {\n    const wcElement = this.element;\n    \n    const inputsToSync = [\n      'currentVersion',\n      'totalVersions',\n      'loading',\n    ];\n    \n    // Synchronize inputs (properties)\n    for (const inputName of inputsToSync) {\n      // Find the corresponding camelCase signal property on the Angular component\n      const signalName = inputName.replace(/-./g, (x: string) => x[1].toUpperCase());\n\n      // Use the Injector to run the effect in the correct context\n      if (this[signalName] && typeof this[signalName] === 'function') {\n        runInInjectionContext(this.injector, () => {\n          effect(() => {\n            // Read the signal value\n            const value = this[signalName]();\n            if (wcElement) {\n              // Write the value to the Web Component's property\n              wcElement[inputName] = value;\n            }\n          });\n        });\n      }\n    }\n  \n    \n    const outputsToSync = [\n      'ui5ButtonClick',\n      'ui5ItemClick',\n      'ui5StopGeneration',\n      'ui5VersionChange',\n    ];\n    \n    // Synchronize outputs (events)\n    for (const outputName of outputsToSync) {\n      // Map Angular output name to UI5 web component event name\n      const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n      // Ensure the output property exists and has an emit function before adding listener\n      if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n        // Cast the listener to the correct type to satisfy TypeScript\n        wcElement.addEventListener(eventName, (e) => {\n\n          this[outputName].emit(e as CustomEvent<any>);\n        });\n      }\n    }\n  \n\n  }\n}\n\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWFpLWlucHV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy91aTUtd2ViY29tcG9uZW50cy1haS9pbnB1dC9mdW5kYW1lbnRhbC1uZ3gtdWk1LXdlYmNvbXBvbmVudHMtYWktaW5wdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0="],"names":[],"mappings":"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"}
@@ -0,0 +1,191 @@
1
+ import * as i0 from '@angular/core';
2
+ import { input, booleanAttribute, output, inject, ElementRef, Injector, runInInjectionContext, effect, ChangeDetectionStrategy, Component } from '@angular/core';
3
+ import '@ui5/webcomponents-ai/dist/PromptInput.js';
4
+
5
+ class PromptInput {
6
+ constructor() {
7
+ /**
8
+ * Defines the value of the component.
9
+ */
10
+ this.value = input("", ...(ngDevMode ? [{ debugName: "value" }] : []));
11
+ /**
12
+ * Defines a short hint intended to aid the user with data entry when the
13
+ component has no value.
14
+ */
15
+ this.placeholder = input(...(ngDevMode ? [undefined, { debugName: "placeholder" }] : []));
16
+ /**
17
+ * Defines the label of the input field.
18
+ */
19
+ this.label = input(...(ngDevMode ? [undefined, { debugName: "label" }] : []));
20
+ /**
21
+ * Defines whether the clear icon of the input will be shown.
22
+ */
23
+ this.showClearIcon = input(false, ...(ngDevMode ? [{ debugName: "showClearIcon", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
24
+ /**
25
+ * Determines whether the characters exceeding the maximum allowed character count are visible
26
+ in the component.
27
+
28
+ If set to `false`, the user is not allowed to enter more characters than what is set in the
29
+ `maxlength` property.
30
+ If set to `true` the characters exceeding the `maxlength` value are selected on
31
+ paste and the counter below the component displays their number.
32
+ */
33
+ this.showExceededText = input(false, ...(ngDevMode ? [{ debugName: "showExceededText", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
34
+ /**
35
+ * Defines whether the component is in disabled state.
36
+
37
+ **Note:** A disabled component is completely noninteractive.
38
+ */
39
+ this.disabled = input(false, ...(ngDevMode ? [{ debugName: "disabled", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
40
+ /**
41
+ * Defines whether the component is read-only.
42
+
43
+ **Note:** A read-only component is not editable,
44
+ but still provides visual feedback upon user interaction.
45
+ */
46
+ this.readonly = input(false, ...(ngDevMode ? [{ debugName: "readonly", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
47
+ /**
48
+ * Sets the maximum number of characters available in the input field.
49
+ */
50
+ this.maxlength = input(...(ngDevMode ? [undefined, { debugName: "maxlength" }] : []));
51
+ /**
52
+ * Defines the value state of the component.
53
+ */
54
+ this.valueState = input("None", ...(ngDevMode ? [{ debugName: "valueState" }] : []));
55
+ /**
56
+ * Defines whether the component should show suggestions, if such are present.
57
+ */
58
+ this.showSuggestions = input(false, ...(ngDevMode ? [{ debugName: "showSuggestions", transform: booleanAttribute }] : [{ transform: booleanAttribute }])); // className is now passed
59
+ /**
60
+ * Fired when the input operation has finished by pressing Enter
61
+ or AI button is clicked.
62
+ */
63
+ this.ui5Submit = output();
64
+ /**
65
+ * Fired when the value of the component changes at each keystroke,
66
+ and when a suggestion item has been selected.
67
+ */
68
+ this.ui5Input = output();
69
+ /**
70
+ * Fired when the input operation has finished by pressing Enter
71
+ or on focusout.
72
+ */
73
+ this.ui5Change = output();
74
+ /**
75
+ * Available slots for content projection in this component.
76
+ *
77
+ * Slots allow you to insert custom content into predefined areas of the web component.
78
+ * Use the `slot` attribute on child elements to target specific slots.
79
+ *
80
+ * - **(default)**: Defines the suggestion items.
81
+
82
+ **Note:** The suggestions would be displayed only if the `showSuggestions`
83
+ property is set to `true`.
84
+
85
+ **Note:** The `<ui5-suggestion-item>`, `<ui5-suggestion-item-group>` and `ui5-suggestion-item-custom` are recommended to be used as suggestion items.
86
+ * - **valueStateMessage**: Defines the value state message that will be displayed as pop up under the component.
87
+ The value state message slot should contain only one root element.
88
+
89
+ **Note:** If not specified, a default text (in the respective language) will be displayed.
90
+
91
+ **Note:** The `valueStateMessage` would be displayed,
92
+ when the component is in `Information`, `Critical` or `Negative` value state.
93
+ *
94
+ * @example
95
+ * ```html
96
+ * <ui5-ai-prompt-input>
97
+ * <div slot="header">Custom header content</div>
98
+ * <p>Default slot content</p>
99
+ * </ui5-ai-prompt-input>
100
+ * ```
101
+ *
102
+ * @readonly
103
+ * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}
104
+ */
105
+ this.slots = [
106
+ {
107
+ "name": "default",
108
+ "description": "Defines the suggestion items.\n\n**Note:** The suggestions would be displayed only if the `showSuggestions`\nproperty is set to `true`.\n\n**Note:** The `<ui5-suggestion-item>`, `<ui5-suggestion-item-group>` and `ui5-suggestion-item-custom` are recommended to be used as suggestion items."
109
+ },
110
+ {
111
+ "name": "valueStateMessage",
112
+ "description": "Defines the value state message that will be displayed as pop up under the component.\nThe value state message slot should contain only one root element.\n\n**Note:** If not specified, a default text (in the respective language) will be displayed.\n\n**Note:** The `valueStateMessage` would be displayed,\nwhen the component is in `Information`, `Critical` or `Negative` value state.",
113
+ "since": "2.0.0"
114
+ }
115
+ ];
116
+ this.elementRef = inject(ElementRef);
117
+ this.injector = inject(Injector);
118
+ }
119
+ get element() {
120
+ return this.elementRef.nativeElement;
121
+ }
122
+ ngAfterViewInit() {
123
+ const wcElement = this.element;
124
+ const inputsToSync = [
125
+ 'value',
126
+ 'placeholder',
127
+ 'label',
128
+ 'showClearIcon',
129
+ 'showExceededText',
130
+ 'disabled',
131
+ 'readonly',
132
+ 'maxlength',
133
+ 'valueState',
134
+ 'showSuggestions',
135
+ ];
136
+ // Synchronize inputs (properties)
137
+ for (const inputName of inputsToSync) {
138
+ // Find the corresponding camelCase signal property on the Angular component
139
+ const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());
140
+ // Use the Injector to run the effect in the correct context
141
+ if (this[signalName] && typeof this[signalName] === 'function') {
142
+ runInInjectionContext(this.injector, () => {
143
+ effect(() => {
144
+ // Read the signal value
145
+ const value = this[signalName]();
146
+ if (wcElement) {
147
+ // Write the value to the Web Component's property
148
+ wcElement[inputName] = value;
149
+ }
150
+ });
151
+ });
152
+ }
153
+ }
154
+ const outputsToSync = [
155
+ 'ui5Submit',
156
+ 'ui5Input',
157
+ 'ui5Change',
158
+ ];
159
+ // Synchronize outputs (events)
160
+ for (const outputName of outputsToSync) {
161
+ // Map Angular output name to UI5 web component event name
162
+ const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);
163
+ // Ensure the output property exists and has an emit function before adding listener
164
+ if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {
165
+ // Cast the listener to the correct type to satisfy TypeScript
166
+ wcElement.addEventListener(eventName, (e) => {
167
+ this[outputName].emit(e);
168
+ });
169
+ }
170
+ }
171
+ }
172
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: PromptInput, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
173
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.1.4", type: PromptInput, isStandalone: true, selector: "ui5-ai-prompt-input, [ui5-ai-prompt-input]", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, showClearIcon: { classPropertyName: "showClearIcon", publicName: "showClearIcon", isSignal: true, isRequired: false, transformFunction: null }, showExceededText: { classPropertyName: "showExceededText", publicName: "showExceededText", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, maxlength: { classPropertyName: "maxlength", publicName: "maxlength", isSignal: true, isRequired: false, transformFunction: null }, valueState: { classPropertyName: "valueState", publicName: "valueState", isSignal: true, isRequired: false, transformFunction: null }, showSuggestions: { classPropertyName: "showSuggestions", publicName: "showSuggestions", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5Submit: "ui5Submit", ui5Input: "ui5Input", ui5Change: "ui5Change" }, exportAs: ["ui5PromptInput"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
174
+ }
175
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: PromptInput, decorators: [{
176
+ type: Component,
177
+ args: [{
178
+ standalone: true,
179
+ selector: 'ui5-ai-prompt-input, [ui5-ai-prompt-input]',
180
+ template: '<ng-content></ng-content>',
181
+ exportAs: 'ui5PromptInput',
182
+ changeDetection: ChangeDetectionStrategy.OnPush,
183
+ }]
184
+ }] });
185
+
186
+ /**
187
+ * Generated bundle index. Do not edit.
188
+ */
189
+
190
+ export { PromptInput };
191
+ //# sourceMappingURL=fundamental-ngx-ui5-webcomponents-ai-prompt-input.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fundamental-ngx-ui5-webcomponents-ai-prompt-input.mjs","sources":["../tmp-esm2022/prompt-input/index.js","../tmp-esm2022/prompt-input/fundamental-ngx-ui5-webcomponents-ai-prompt-input.js"],"sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, input, output, effect, runInInjectionContext, inject, Injector, booleanAttribute } from '@angular/core';\nimport '@ui5/webcomponents-ai/dist/PromptInput.js';\nimport * as i0 from \"@angular/core\";\nexport class PromptInput {\n constructor() {\n /**\n * Defines the value of the component.\n */\n this.value = input(\"\", ...(ngDevMode ? [{ debugName: \"value\" }] : []));\n /**\n * Defines a short hint intended to aid the user with data entry when the\n component has no value.\n */\n this.placeholder = input(...(ngDevMode ? [undefined, { debugName: \"placeholder\" }] : []));\n /**\n * Defines the label of the input field.\n */\n this.label = input(...(ngDevMode ? [undefined, { debugName: \"label\" }] : []));\n /**\n * Defines whether the clear icon of the input will be shown.\n */\n this.showClearIcon = input(false, ...(ngDevMode ? [{ debugName: \"showClearIcon\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Determines whether the characters exceeding the maximum allowed character count are visible\n in the component.\n \n If set to `false`, the user is not allowed to enter more characters than what is set in the\n `maxlength` property.\n If set to `true` the characters exceeding the `maxlength` value are selected on\n paste and the counter below the component displays their number.\n */\n this.showExceededText = input(false, ...(ngDevMode ? [{ debugName: \"showExceededText\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Defines whether the component is in disabled state.\n \n **Note:** A disabled component is completely noninteractive.\n */\n this.disabled = input(false, ...(ngDevMode ? [{ debugName: \"disabled\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Defines whether the component is read-only.\n \n **Note:** A read-only component is not editable,\n but still provides visual feedback upon user interaction.\n */\n this.readonly = input(false, ...(ngDevMode ? [{ debugName: \"readonly\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Sets the maximum number of characters available in the input field.\n */\n this.maxlength = input(...(ngDevMode ? [undefined, { debugName: \"maxlength\" }] : []));\n /**\n * Defines the value state of the component.\n */\n this.valueState = input(\"None\", ...(ngDevMode ? [{ debugName: \"valueState\" }] : []));\n /**\n * Defines whether the component should show suggestions, if such are present.\n */\n this.showSuggestions = input(false, ...(ngDevMode ? [{ debugName: \"showSuggestions\", transform: booleanAttribute }] : [{ transform: booleanAttribute }])); // className is now passed\n /**\n * Fired when the input operation has finished by pressing Enter\n or AI button is clicked.\n */\n this.ui5Submit = output();\n /**\n * Fired when the value of the component changes at each keystroke,\n and when a suggestion item has been selected.\n */\n this.ui5Input = output();\n /**\n * Fired when the input operation has finished by pressing Enter\n or on focusout.\n */\n this.ui5Change = output();\n /**\n * Available slots for content projection in this component.\n *\n * Slots allow you to insert custom content into predefined areas of the web component.\n * Use the `slot` attribute on child elements to target specific slots.\n *\n * - **(default)**: Defines the suggestion items.\n \n **Note:** The suggestions would be displayed only if the `showSuggestions`\n property is set to `true`.\n \n **Note:** The `<ui5-suggestion-item>`, `<ui5-suggestion-item-group>` and `ui5-suggestion-item-custom` are recommended to be used as suggestion items.\n * - **valueStateMessage**: Defines the value state message that will be displayed as pop up under the component.\n The value state message slot should contain only one root element.\n \n **Note:** If not specified, a default text (in the respective language) will be displayed.\n \n **Note:** The `valueStateMessage` would be displayed,\n when the component is in `Information`, `Critical` or `Negative` value state.\n *\n * @example\n * ```html\n * <ui5-ai-prompt-input>\n * <div slot=\"header\">Custom header content</div>\n * <p>Default slot content</p>\n * </ui5-ai-prompt-input>\n * ```\n *\n * @readonly\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n */\n this.slots = [\n {\n \"name\": \"default\",\n \"description\": \"Defines the suggestion items.\\n\\n**Note:** The suggestions would be displayed only if the `showSuggestions`\\nproperty is set to `true`.\\n\\n**Note:** The `<ui5-suggestion-item>`, `<ui5-suggestion-item-group>` and `ui5-suggestion-item-custom` are recommended to be used as suggestion items.\"\n },\n {\n \"name\": \"valueStateMessage\",\n \"description\": \"Defines the value state message that will be displayed as pop up under the component.\\nThe value state message slot should contain only one root element.\\n\\n**Note:** If not specified, a default text (in the respective language) will be displayed.\\n\\n**Note:** The `valueStateMessage` would be displayed,\\nwhen the component is in `Information`, `Critical` or `Negative` value state.\",\n \"since\": \"2.0.0\"\n }\n ];\n this.elementRef = inject(ElementRef);\n this.injector = inject(Injector);\n }\n get element() {\n return this.elementRef.nativeElement;\n }\n ngAfterViewInit() {\n const wcElement = this.element;\n const inputsToSync = [\n 'value',\n 'placeholder',\n 'label',\n 'showClearIcon',\n 'showExceededText',\n 'disabled',\n 'readonly',\n 'maxlength',\n 'valueState',\n 'showSuggestions',\n ];\n // Synchronize inputs (properties)\n for (const inputName of inputsToSync) {\n // Find the corresponding camelCase signal property on the Angular component\n const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());\n // Use the Injector to run the effect in the correct context\n if (this[signalName] && typeof this[signalName] === 'function') {\n runInInjectionContext(this.injector, () => {\n effect(() => {\n // Read the signal value\n const value = this[signalName]();\n if (wcElement) {\n // Write the value to the Web Component's property\n wcElement[inputName] = value;\n }\n });\n });\n }\n }\n const outputsToSync = [\n 'ui5Submit',\n 'ui5Input',\n 'ui5Change',\n ];\n // Synchronize outputs (events)\n for (const outputName of outputsToSync) {\n // Map Angular output name to UI5 web component event name\n const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n // Ensure the output property exists and has an emit function before adding listener\n if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n // Cast the listener to the correct type to satisfy TypeScript\n wcElement.addEventListener(eventName, (e) => {\n this[outputName].emit(e);\n });\n }\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: PromptInput, deps: [], target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"17.1.0\", version: \"20.1.4\", type: PromptInput, isStandalone: true, selector: \"ui5-ai-prompt-input, [ui5-ai-prompt-input]\", inputs: { value: { classPropertyName: \"value\", publicName: \"value\", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: \"placeholder\", publicName: \"placeholder\", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: \"label\", publicName: \"label\", isSignal: true, isRequired: false, transformFunction: null }, showClearIcon: { classPropertyName: \"showClearIcon\", publicName: \"showClearIcon\", isSignal: true, isRequired: false, transformFunction: null }, showExceededText: { classPropertyName: \"showExceededText\", publicName: \"showExceededText\", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: \"disabled\", publicName: \"disabled\", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: \"readonly\", publicName: \"readonly\", isSignal: true, isRequired: false, transformFunction: null }, maxlength: { classPropertyName: \"maxlength\", publicName: \"maxlength\", isSignal: true, isRequired: false, transformFunction: null }, valueState: { classPropertyName: \"valueState\", publicName: \"valueState\", isSignal: true, isRequired: false, transformFunction: null }, showSuggestions: { classPropertyName: \"showSuggestions\", publicName: \"showSuggestions\", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5Submit: \"ui5Submit\", ui5Input: \"ui5Input\", ui5Change: \"ui5Change\" }, exportAs: [\"ui5PromptInput\"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: PromptInput, decorators: [{\n type: Component,\n args: [{\n standalone: true,\n selector: 'ui5-ai-prompt-input, [ui5-ai-prompt-input]',\n template: '<ng-content></ng-content>',\n exportAs: 'ui5PromptInput',\n changeDetection: ChangeDetectionStrategy.OnPush,\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/ui5-webcomponents-ai/prompt-input/index.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  input,\n  output,\n  AfterViewInit,\n  effect,\n  runInInjectionContext,\n  inject,\n  Injector,\n  booleanAttribute,\n  computed,\n  signal\n} from '@angular/core';\nimport '@ui5/webcomponents-ai/dist/PromptInput.js';\nimport { default as _PromptInput } from '@ui5/webcomponents-ai/dist/PromptInput.js';\nimport { UI5CustomEvent } from '@ui5/webcomponents-base';\n\nimport { default as ValueState } from '@ui5/webcomponents-base/dist/types/ValueState.js';\n\n@Component({\n  standalone: true,\n  selector: 'ui5-ai-prompt-input, [ui5-ai-prompt-input]',\n  template: '<ng-content></ng-content>',\n  exportAs: 'ui5PromptInput',\n\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PromptInput implements AfterViewInit {\n\n  /**\n   * Defines the value of the component.\n   */\n  value = input<typeof _PromptInput.prototype.value | undefined>(\"\");\n\n  /**\n   * Defines a short hint intended to aid the user with data entry when the\ncomponent has no value.\n   */\n  placeholder = input<typeof _PromptInput.prototype.placeholder | undefined>();\n\n  /**\n   * Defines the label of the input field.\n   */\n  label = input<typeof _PromptInput.prototype.label | undefined>();\n\n  /**\n   * Defines whether the clear icon of the input will be shown.\n   */\n  showClearIcon = input(false, { transform: booleanAttribute });\n\n  /**\n   * Determines whether the characters exceeding the maximum allowed character count are visible\nin the component.\n\nIf set to `false`, the user is not allowed to enter more characters than what is set in the\n`maxlength` property.\nIf set to `true` the characters exceeding the `maxlength` value are selected on\npaste and the counter below the component displays their number.\n   */\n  showExceededText = input(false, { transform: booleanAttribute });\n\n  /**\n   * Defines whether the component is in disabled state.\n\n**Note:** A disabled component is completely noninteractive.\n   */\n  disabled = input(false, { transform: booleanAttribute });\n\n  /**\n   * Defines whether the component is read-only.\n\n**Note:** A read-only component is not editable,\nbut still provides visual feedback upon user interaction.\n   */\n  readonly = input(false, { transform: booleanAttribute });\n\n  /**\n   * Sets the maximum number of characters available in the input field.\n   */\n  maxlength = input<typeof _PromptInput.prototype.maxlength | undefined>();\n\n  /**\n   * Defines the value state of the component.\n   */\n  valueState = input<typeof _PromptInput.prototype.valueState | undefined>(\"None\");\n\n  /**\n   * Defines whether the component should show suggestions, if such are present.\n   */\n  showSuggestions = input(false, { transform: booleanAttribute }); // className is now passed\n\n\n\n  /**\n   * Fired when the input operation has finished by pressing Enter\nor AI button is clicked.\n   */\n  ui5Submit = output<UI5CustomEvent<_PromptInput, 'submit'>>();\n\n  /**\n   * Fired when the value of the component changes at each keystroke,\nand when a suggestion item has been selected.\n   */\n  ui5Input = output<UI5CustomEvent<_PromptInput, 'input'>>();\n\n  /**\n   * Fired when the input operation has finished by pressing Enter\nor on focusout.\n   */\n  ui5Change = output<UI5CustomEvent<_PromptInput, 'change'>>();\n\n  /**\n   * Available slots for content projection in this component.\n   * \n   * Slots allow you to insert custom content into predefined areas of the web component.\n   * Use the `slot` attribute on child elements to target specific slots.\n   * \n   * - **(default)**: Defines the suggestion items.\n\n**Note:** The suggestions would be displayed only if the `showSuggestions`\nproperty is set to `true`.\n\n**Note:** The `<ui5-suggestion-item>`, `<ui5-suggestion-item-group>` and `ui5-suggestion-item-custom` are recommended to be used as suggestion items.\n   * - **valueStateMessage**: Defines the value state message that will be displayed as pop up under the component.\nThe value state message slot should contain only one root element.\n\n**Note:** If not specified, a default text (in the respective language) will be displayed.\n\n**Note:** The `valueStateMessage` would be displayed,\nwhen the component is in `Information`, `Critical` or `Negative` value state.\n   * \n   * @example\n   * ```html\n   * <ui5-ai-prompt-input>\n   *   <div slot=\"header\">Custom header content</div>\n   *   <p>Default slot content</p>\n   * </ui5-ai-prompt-input>\n   * ```\n   * \n   * @readonly\n   * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n   */\n  readonly slots = [\n      {\n          \"name\": \"default\",\n          \"description\": \"Defines the suggestion items.\\n\\n**Note:** The suggestions would be displayed only if the `showSuggestions`\\nproperty is set to `true`.\\n\\n**Note:** The `<ui5-suggestion-item>`, `<ui5-suggestion-item-group>` and `ui5-suggestion-item-custom` are recommended to be used as suggestion items.\"\n      },\n      {\n          \"name\": \"valueStateMessage\",\n          \"description\": \"Defines the value state message that will be displayed as pop up under the component.\\nThe value state message slot should contain only one root element.\\n\\n**Note:** If not specified, a default text (in the respective language) will be displayed.\\n\\n**Note:** The `valueStateMessage` would be displayed,\\nwhen the component is in `Information`, `Critical` or `Negative` value state.\",\n          \"since\": \"2.0.0\"\n      }\n  ];\n\n\n  public elementRef: ElementRef<_PromptInput> = inject(ElementRef);\n  public injector = inject(Injector);\n\n  get element(): _PromptInput {\n    return this.elementRef.nativeElement;\n  }\n\n  ngAfterViewInit(): void {\n    const wcElement = this.element;\n    \n    const inputsToSync = [\n      'value',\n      'placeholder',\n      'label',\n      'showClearIcon',\n      'showExceededText',\n      'disabled',\n      'readonly',\n      'maxlength',\n      'valueState',\n      'showSuggestions',\n    ];\n    \n    // Synchronize inputs (properties)\n    for (const inputName of inputsToSync) {\n      // Find the corresponding camelCase signal property on the Angular component\n      const signalName = inputName.replace(/-./g, (x: string) => x[1].toUpperCase());\n\n      // Use the Injector to run the effect in the correct context\n      if (this[signalName] && typeof this[signalName] === 'function') {\n        runInInjectionContext(this.injector, () => {\n          effect(() => {\n            // Read the signal value\n            const value = this[signalName]();\n            if (wcElement) {\n              // Write the value to the Web Component's property\n              wcElement[inputName] = value;\n            }\n          });\n        });\n      }\n    }\n  \n    \n    const outputsToSync = [\n      'ui5Submit',\n      'ui5Input',\n      'ui5Change',\n    ];\n    \n    // Synchronize outputs (events)\n    for (const outputName of outputsToSync) {\n      // Map Angular output name to UI5 web component event name\n      const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n      // Ensure the output property exists and has an emit function before adding listener\n      if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n        // Cast the listener to the correct type to satisfy TypeScript\n        wcElement.addEventListener(eventName, (e) => {\n\n          this[outputName].emit(e as CustomEvent<any>);\n        });\n      }\n    }\n  \n\n  }\n}\n\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWFpLXByb21wdC1pbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvdWk1LXdlYmNvbXBvbmVudHMtYWkvcHJvbXB0LWlucHV0L2Z1bmRhbWVudGFsLW5neC11aTUtd2ViY29tcG9uZW50cy1haS1wcm9tcHQtaW5wdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0="],"names":[],"mappings":"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"}
@@ -0,0 +1,127 @@
1
+ import * as i0 from '@angular/core';
2
+ import { input, booleanAttribute, output, inject, ElementRef, Injector, runInInjectionContext, effect, ChangeDetectionStrategy, Component } from '@angular/core';
3
+ import '@ui5/webcomponents-ai/dist/TextArea.js';
4
+
5
+ class TextArea {
6
+ constructor() {
7
+ /**
8
+ * Defines whether the `ui5-ai-textarea` is currently in a loading(processing) state.
9
+ */
10
+ this.loading = input(false, ...(ngDevMode ? [{ debugName: "loading", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
11
+ /**
12
+ * Defines the prompt description of the current action.
13
+ */
14
+ this.promptDescription = input("", ...(ngDevMode ? [{ debugName: "promptDescription" }] : []));
15
+ /**
16
+ * Indicates the index of the currently displayed version.
17
+ */
18
+ this.currentVersion = input(0, ...(ngDevMode ? [{ debugName: "currentVersion" }] : []));
19
+ /**
20
+ * Indicates the total number of result versions available.
21
+
22
+ Notes:
23
+ Versioning is hidden if the value is `0`
24
+ */
25
+ this.totalVersions = input(0, ...(ngDevMode ? [{ debugName: "totalVersions" }] : [])); // className is now passed
26
+ /**
27
+ * Fired when the user clicks on version navigation buttons.
28
+ */
29
+ this.ui5VersionChange = output();
30
+ /**
31
+ * Fired when the user requests to stop AI text generation.
32
+ */
33
+ this.ui5StopGeneration = output();
34
+ /**
35
+ * Available slots for content projection in this component.
36
+ *
37
+ * Slots allow you to insert custom content into predefined areas of the web component.
38
+ * Use the `slot` attribute on child elements to target specific slots.
39
+ *
40
+ * - **menu**: Defines a slot for `ui5-menu` integration. This slot allows you to pass a `ui5-menu` instance that will be associated with the assistant.
41
+ *
42
+ * @example
43
+ * ```html
44
+ * <ui5-ai-textarea>
45
+ * <div slot="header">Custom header content</div>
46
+ * <p>Default slot content</p>
47
+ * </ui5-ai-textarea>
48
+ * ```
49
+ *
50
+ * @readonly
51
+ * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}
52
+ */
53
+ this.slots = [
54
+ {
55
+ "name": "menu",
56
+ "description": "Defines a slot for `ui5-menu` integration. This slot allows you to pass a `ui5-menu` instance that will be associated with the assistant."
57
+ }
58
+ ];
59
+ this.elementRef = inject(ElementRef);
60
+ this.injector = inject(Injector);
61
+ }
62
+ get element() {
63
+ return this.elementRef.nativeElement;
64
+ }
65
+ ngAfterViewInit() {
66
+ const wcElement = this.element;
67
+ const inputsToSync = [
68
+ 'loading',
69
+ 'promptDescription',
70
+ 'currentVersion',
71
+ 'totalVersions',
72
+ ];
73
+ // Synchronize inputs (properties)
74
+ for (const inputName of inputsToSync) {
75
+ // Find the corresponding camelCase signal property on the Angular component
76
+ const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());
77
+ // Use the Injector to run the effect in the correct context
78
+ if (this[signalName] && typeof this[signalName] === 'function') {
79
+ runInInjectionContext(this.injector, () => {
80
+ effect(() => {
81
+ // Read the signal value
82
+ const value = this[signalName]();
83
+ if (wcElement) {
84
+ // Write the value to the Web Component's property
85
+ wcElement[inputName] = value;
86
+ }
87
+ });
88
+ });
89
+ }
90
+ }
91
+ const outputsToSync = [
92
+ 'ui5VersionChange',
93
+ 'ui5StopGeneration',
94
+ ];
95
+ // Synchronize outputs (events)
96
+ for (const outputName of outputsToSync) {
97
+ // Map Angular output name to UI5 web component event name
98
+ const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);
99
+ // Ensure the output property exists and has an emit function before adding listener
100
+ if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {
101
+ // Cast the listener to the correct type to satisfy TypeScript
102
+ wcElement.addEventListener(eventName, (e) => {
103
+ this[outputName].emit(e);
104
+ });
105
+ }
106
+ }
107
+ }
108
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: TextArea, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
109
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.1.4", type: TextArea, isStandalone: true, selector: "ui5-ai-textarea, [ui5-ai-textarea]", inputs: { loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, promptDescription: { classPropertyName: "promptDescription", publicName: "promptDescription", isSignal: true, isRequired: false, transformFunction: null }, currentVersion: { classPropertyName: "currentVersion", publicName: "currentVersion", isSignal: true, isRequired: false, transformFunction: null }, totalVersions: { classPropertyName: "totalVersions", publicName: "totalVersions", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5VersionChange: "ui5VersionChange", ui5StopGeneration: "ui5StopGeneration" }, exportAs: ["ui5TextArea"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
110
+ }
111
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: TextArea, decorators: [{
112
+ type: Component,
113
+ args: [{
114
+ standalone: true,
115
+ selector: 'ui5-ai-textarea, [ui5-ai-textarea]',
116
+ template: '<ng-content></ng-content>',
117
+ exportAs: 'ui5TextArea',
118
+ changeDetection: ChangeDetectionStrategy.OnPush,
119
+ }]
120
+ }] });
121
+
122
+ /**
123
+ * Generated bundle index. Do not edit.
124
+ */
125
+
126
+ export { TextArea };
127
+ //# sourceMappingURL=fundamental-ngx-ui5-webcomponents-ai-text-area.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fundamental-ngx-ui5-webcomponents-ai-text-area.mjs","sources":["../tmp-esm2022/text-area/index.js","../tmp-esm2022/text-area/fundamental-ngx-ui5-webcomponents-ai-text-area.js"],"sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, input, output, effect, runInInjectionContext, inject, Injector, booleanAttribute } from '@angular/core';\nimport '@ui5/webcomponents-ai/dist/TextArea.js';\nimport * as i0 from \"@angular/core\";\nexport class TextArea {\n constructor() {\n /**\n * Defines whether the `ui5-ai-textarea` is currently in a loading(processing) state.\n */\n this.loading = input(false, ...(ngDevMode ? [{ debugName: \"loading\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Defines the prompt description of the current action.\n */\n this.promptDescription = input(\"\", ...(ngDevMode ? [{ debugName: \"promptDescription\" }] : []));\n /**\n * Indicates the index of the currently displayed version.\n */\n this.currentVersion = input(0, ...(ngDevMode ? [{ debugName: \"currentVersion\" }] : []));\n /**\n * Indicates the total number of result versions available.\n \n Notes:\n Versioning is hidden if the value is `0`\n */\n this.totalVersions = input(0, ...(ngDevMode ? [{ debugName: \"totalVersions\" }] : [])); // className is now passed\n /**\n * Fired when the user clicks on version navigation buttons.\n */\n this.ui5VersionChange = output();\n /**\n * Fired when the user requests to stop AI text generation.\n */\n this.ui5StopGeneration = output();\n /**\n * Available slots for content projection in this component.\n *\n * Slots allow you to insert custom content into predefined areas of the web component.\n * Use the `slot` attribute on child elements to target specific slots.\n *\n * - **menu**: Defines a slot for `ui5-menu` integration. This slot allows you to pass a `ui5-menu` instance that will be associated with the assistant.\n *\n * @example\n * ```html\n * <ui5-ai-textarea>\n * <div slot=\"header\">Custom header content</div>\n * <p>Default slot content</p>\n * </ui5-ai-textarea>\n * ```\n *\n * @readonly\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n */\n this.slots = [\n {\n \"name\": \"menu\",\n \"description\": \"Defines a slot for `ui5-menu` integration. This slot allows you to pass a `ui5-menu` instance that will be associated with the assistant.\"\n }\n ];\n this.elementRef = inject(ElementRef);\n this.injector = inject(Injector);\n }\n get element() {\n return this.elementRef.nativeElement;\n }\n ngAfterViewInit() {\n const wcElement = this.element;\n const inputsToSync = [\n 'loading',\n 'promptDescription',\n 'currentVersion',\n 'totalVersions',\n ];\n // Synchronize inputs (properties)\n for (const inputName of inputsToSync) {\n // Find the corresponding camelCase signal property on the Angular component\n const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());\n // Use the Injector to run the effect in the correct context\n if (this[signalName] && typeof this[signalName] === 'function') {\n runInInjectionContext(this.injector, () => {\n effect(() => {\n // Read the signal value\n const value = this[signalName]();\n if (wcElement) {\n // Write the value to the Web Component's property\n wcElement[inputName] = value;\n }\n });\n });\n }\n }\n const outputsToSync = [\n 'ui5VersionChange',\n 'ui5StopGeneration',\n ];\n // Synchronize outputs (events)\n for (const outputName of outputsToSync) {\n // Map Angular output name to UI5 web component event name\n const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n // Ensure the output property exists and has an emit function before adding listener\n if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n // Cast the listener to the correct type to satisfy TypeScript\n wcElement.addEventListener(eventName, (e) => {\n this[outputName].emit(e);\n });\n }\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: TextArea, deps: [], target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"17.1.0\", version: \"20.1.4\", type: TextArea, isStandalone: true, selector: \"ui5-ai-textarea, [ui5-ai-textarea]\", inputs: { loading: { classPropertyName: \"loading\", publicName: \"loading\", isSignal: true, isRequired: false, transformFunction: null }, promptDescription: { classPropertyName: \"promptDescription\", publicName: \"promptDescription\", isSignal: true, isRequired: false, transformFunction: null }, currentVersion: { classPropertyName: \"currentVersion\", publicName: \"currentVersion\", isSignal: true, isRequired: false, transformFunction: null }, totalVersions: { classPropertyName: \"totalVersions\", publicName: \"totalVersions\", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5VersionChange: \"ui5VersionChange\", ui5StopGeneration: \"ui5StopGeneration\" }, exportAs: [\"ui5TextArea\"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: TextArea, decorators: [{\n type: Component,\n args: [{\n standalone: true,\n selector: 'ui5-ai-textarea, [ui5-ai-textarea]',\n template: '<ng-content></ng-content>',\n exportAs: 'ui5TextArea',\n changeDetection: ChangeDetectionStrategy.OnPush,\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/ui5-webcomponents-ai/text-area/index.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  input,\n  output,\n  AfterViewInit,\n  effect,\n  runInInjectionContext,\n  inject,\n  Injector,\n  booleanAttribute,\n  computed,\n  signal\n} from '@angular/core';\nimport '@ui5/webcomponents-ai/dist/TextArea.js';\nimport { default as _TextArea } from '@ui5/webcomponents-ai/dist/TextArea.js';\nimport { UI5CustomEvent } from '@ui5/webcomponents-base';\n\n\n\n@Component({\n  standalone: true,\n  selector: 'ui5-ai-textarea, [ui5-ai-textarea]',\n  template: '<ng-content></ng-content>',\n  exportAs: 'ui5TextArea',\n\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TextArea implements AfterViewInit {\n\n  /**\n   * Defines whether the `ui5-ai-textarea` is currently in a loading(processing) state.\n   */\n  loading = input(false, { transform: booleanAttribute });\n\n  /**\n   * Defines the prompt description of the current action.\n   */\n  promptDescription = input<typeof _TextArea.prototype.promptDescription | undefined>(\"\");\n\n  /**\n   * Indicates the index of the currently displayed version.\n   */\n  currentVersion = input<typeof _TextArea.prototype.currentVersion | undefined>(0);\n\n  /**\n   * Indicates the total number of result versions available.\n\nNotes:\nVersioning is hidden if the value is `0`\n   */\n  totalVersions = input<typeof _TextArea.prototype.totalVersions | undefined>(0); // className is now passed\n\n\n\n  /**\n   * Fired when the user clicks on version navigation buttons.\n   */\n  ui5VersionChange = output<UI5CustomEvent<_TextArea, 'version-change'>>();\n\n  /**\n   * Fired when the user requests to stop AI text generation.\n   */\n  ui5StopGeneration = output<UI5CustomEvent<_TextArea, 'stop-generation'>>();\n\n  /**\n   * Available slots for content projection in this component.\n   * \n   * Slots allow you to insert custom content into predefined areas of the web component.\n   * Use the `slot` attribute on child elements to target specific slots.\n   * \n   * - **menu**: Defines a slot for `ui5-menu` integration. This slot allows you to pass a `ui5-menu` instance that will be associated with the assistant.\n   * \n   * @example\n   * ```html\n   * <ui5-ai-textarea>\n   *   <div slot=\"header\">Custom header content</div>\n   *   <p>Default slot content</p>\n   * </ui5-ai-textarea>\n   * ```\n   * \n   * @readonly\n   * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n   */\n  readonly slots = [\n      {\n          \"name\": \"menu\",\n          \"description\": \"Defines a slot for `ui5-menu` integration. This slot allows you to pass a `ui5-menu` instance that will be associated with the assistant.\"\n      }\n  ];\n\n\n  public elementRef: ElementRef<_TextArea> = inject(ElementRef);\n  public injector = inject(Injector);\n\n  get element(): _TextArea {\n    return this.elementRef.nativeElement;\n  }\n\n  ngAfterViewInit(): void {\n    const wcElement = this.element;\n    \n    const inputsToSync = [\n      'loading',\n      'promptDescription',\n      'currentVersion',\n      'totalVersions',\n    ];\n    \n    // Synchronize inputs (properties)\n    for (const inputName of inputsToSync) {\n      // Find the corresponding camelCase signal property on the Angular component\n      const signalName = inputName.replace(/-./g, (x: string) => x[1].toUpperCase());\n\n      // Use the Injector to run the effect in the correct context\n      if (this[signalName] && typeof this[signalName] === 'function') {\n        runInInjectionContext(this.injector, () => {\n          effect(() => {\n            // Read the signal value\n            const value = this[signalName]();\n            if (wcElement) {\n              // Write the value to the Web Component's property\n              wcElement[inputName] = value;\n            }\n          });\n        });\n      }\n    }\n  \n    \n    const outputsToSync = [\n      'ui5VersionChange',\n      'ui5StopGeneration',\n    ];\n    \n    // Synchronize outputs (events)\n    for (const outputName of outputsToSync) {\n      // Map Angular output name to UI5 web component event name\n      const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n      // Ensure the output property exists and has an emit function before adding listener\n      if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n        // Cast the listener to the correct type to satisfy TypeScript\n        wcElement.addEventListener(eventName, (e) => {\n\n          this[outputName].emit(e as CustomEvent<any>);\n        });\n      }\n    }\n  \n\n  }\n}\n\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWFpLXRleHQtYXJlYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvdWk1LXdlYmNvbXBvbmVudHMtYWkvdGV4dC1hcmVhL2Z1bmRhbWVudGFsLW5neC11aTUtd2ViY29tcG9uZW50cy1haS10ZXh0LWFyZWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0="],"names":[],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Injectable } from '@angular/core';
3
+ import { WebcomponentsThemingProvider } from '@fundamental-ngx/ui5-webcomponents-base/theming';
4
+
5
+ class Ui5WebcomponentsAiThemingService extends WebcomponentsThemingProvider {
6
+ constructor() {
7
+ super(() => import('@ui5/webcomponents-ai/dist/generated/json-imports/Themes.js'));
8
+ this.name = 'ui-5-webcomponents--ai-theming-service';
9
+ }
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: Ui5WebcomponentsAiThemingService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
11
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: Ui5WebcomponentsAiThemingService, providedIn: 'root' }); }
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: Ui5WebcomponentsAiThemingService, decorators: [{
14
+ type: Injectable,
15
+ args: [{ providedIn: 'root' }]
16
+ }], ctorParameters: () => [] });
17
+
18
+ /**
19
+ * Generated bundle index. Do not edit.
20
+ */
21
+
22
+ export { Ui5WebcomponentsAiThemingService };
23
+ //# sourceMappingURL=fundamental-ngx-ui5-webcomponents-ai-theming.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fundamental-ngx-ui5-webcomponents-ai-theming.mjs","sources":["../tmp-esm2022/theming/index.js","../tmp-esm2022/theming/fundamental-ngx-ui5-webcomponents-ai-theming.js"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { WebcomponentsThemingProvider } from '@fundamental-ngx/ui5-webcomponents-base/theming';\nimport * as i0 from \"@angular/core\";\nclass Ui5WebcomponentsAiThemingService extends WebcomponentsThemingProvider {\n constructor() {\n super(() => import('@ui5/webcomponents-ai/dist/generated/json-imports/Themes.js'));\n this.name = 'ui-5-webcomponents--ai-theming-service';\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: Ui5WebcomponentsAiThemingService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: Ui5WebcomponentsAiThemingService, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: Ui5WebcomponentsAiThemingService, decorators: [{\n type: Injectable,\n args: [{ providedIn: 'root' }]\n }], ctorParameters: () => [] });\nexport { Ui5WebcomponentsAiThemingService };\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3VpNS13ZWJjb21wb25lbnRzLWFpL3RoZW1pbmcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxpREFBaUQsQ0FBQzs7QUFFL0YsTUFDTSxnQ0FBaUMsU0FBUSw0QkFBNEI7SUFFekU7UUFDRSxLQUFLLENBQ0gsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDLDZEQUE2RCxDQUFDLENBQzVFLENBQUM7UUFKSixTQUFJLEdBQUcsd0NBQXdDLENBQUM7SUFLaEQsQ0FBQzs4R0FORyxnQ0FBZ0M7a0hBQWhDLGdDQUFnQyxjQURaLE1BQU07OzJGQUMxQixnQ0FBZ0M7a0JBRHJDLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFOztBQVVsQyxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFdlYmNvbXBvbmVudHNUaGVtaW5nUHJvdmlkZXIgfSBmcm9tICdAZnVuZGFtZW50YWwtbmd4L3VpNS13ZWJjb21wb25lbnRzLWJhc2UvdGhlbWluZyc7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5jbGFzcyBVaTVXZWJjb21wb25lbnRzQWlUaGVtaW5nU2VydmljZSBleHRlbmRzIFdlYmNvbXBvbmVudHNUaGVtaW5nUHJvdmlkZXIge1xuICBuYW1lID0gJ3VpLTUtd2ViY29tcG9uZW50cy0tYWktdGhlbWluZy1zZXJ2aWNlJztcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoXG4gICAgICAoKSA9PiBpbXBvcnQoJ0B1aTUvd2ViY29tcG9uZW50cy1haS9kaXN0L2dlbmVyYXRlZC9qc29uLWltcG9ydHMvVGhlbWVzLmpzJyksXG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgeyBVaTVXZWJjb21wb25lbnRzQWlUaGVtaW5nU2VydmljZSB9O1xuIl19","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWFpLXRoZW1pbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3VpNS13ZWJjb21wb25lbnRzLWFpL3RoZW1pbmcvZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWFpLXRoZW1pbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0="],"names":[],"mappings":";;;;AAGA,MAAM,gCAAgC,SAAS,4BAA4B,CAAC;AAC5E,IAAI,WAAW,GAAG;AAClB,QAAQ,KAAK,CAAC,MAAM,OAAO,6DAA6D,CAAC,CAAC;AAC1F,QAAQ,IAAI,CAAC,IAAI,GAAG,wCAAwC;AAC5D,IAAI;AACJ,IAAI,SAAS,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC,kBAAkB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,gCAAgC,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC;AACnM,IAAI,SAAS,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,gCAAgC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC;AAC1K;AACA,EAAE,CAAC,wBAAwB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,gCAAgC,EAAE,UAAU,EAAE,CAAC;AAC1I,YAAY,IAAI,EAAE,UAAU;AAC5B,YAAY,IAAI,EAAE,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE;AACzC,SAAS,CAAC,EAAE,cAAc,EAAE,MAAM,EAAE,EAAE,CAAC;;ACdvC;AACA;AACA;;;;"}
@@ -0,0 +1,70 @@
1
+ import * as _angular_core from '@angular/core';
2
+ import { AfterViewInit, ElementRef, Injector } from '@angular/core';
3
+ import _Input from '@ui5/webcomponents-ai/dist/Input.js';
4
+ import { UI5CustomEvent } from '@ui5/webcomponents-base';
5
+
6
+ declare class Input implements AfterViewInit {
7
+ /**
8
+ * Indicates the index of the currently displayed version.
9
+ */
10
+ currentVersion: _angular_core.InputSignal<number | undefined>;
11
+ /**
12
+ * Indicates the total number of result versions available.
13
+
14
+ When not set or set to 0, the versioning will be hidden.
15
+ */
16
+ totalVersions: _angular_core.InputSignal<number | undefined>;
17
+ /**
18
+ * Defines whether the AI Writing Assistant is currently loading.
19
+
20
+ When `true`, indicates that an AI action is in progress.
21
+ */
22
+ loading: _angular_core.InputSignalWithTransform<boolean, unknown>;
23
+ /**
24
+ * Fired when the user selects the AI button.
25
+ */
26
+ ui5ButtonClick: _angular_core.OutputEmitterRef<UI5CustomEvent<_Input, "button-click">>;
27
+ /**
28
+ * Fired when an item from the AI actions menu is clicked.
29
+ */
30
+ ui5ItemClick: _angular_core.OutputEmitterRef<UI5CustomEvent<_Input, "item-click">>;
31
+ /**
32
+ * Fired when the user selects the "Stop" button to stop ongoing AI text generation.
33
+ */
34
+ ui5StopGeneration: _angular_core.OutputEmitterRef<UI5CustomEvent<_Input, "stop-generation">>;
35
+ /**
36
+ * Fired when the user selects the version navigation buttons.
37
+ */
38
+ ui5VersionChange: _angular_core.OutputEmitterRef<UI5CustomEvent<_Input, "version-change">>;
39
+ /**
40
+ * Available slots for content projection in this component.
41
+ *
42
+ * Slots allow you to insert custom content into predefined areas of the web component.
43
+ * Use the `slot` attribute on child elements to target specific slots.
44
+ *
45
+ * - **actions**: Defines the items of the menu for the component.
46
+ *
47
+ * @example
48
+ * ```html
49
+ * <ui5-ai-input>
50
+ * <div slot="header">Custom header content</div>
51
+ * <p>Default slot content</p>
52
+ * </ui5-ai-input>
53
+ * ```
54
+ *
55
+ * @readonly
56
+ * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}
57
+ */
58
+ readonly slots: {
59
+ name: string;
60
+ description: string;
61
+ }[];
62
+ elementRef: ElementRef<_Input>;
63
+ injector: Injector;
64
+ get element(): _Input;
65
+ ngAfterViewInit(): void;
66
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<Input, never>;
67
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<Input, "ui5-ai-input, [ui5-ai-input]", ["ui5Input"], { "currentVersion": { "alias": "currentVersion"; "required": false; "isSignal": true; }; "totalVersions": { "alias": "totalVersions"; "required": false; "isSignal": true; }; "loading": { "alias": "loading"; "required": false; "isSignal": true; }; }, { "ui5ButtonClick": "ui5ButtonClick"; "ui5ItemClick": "ui5ItemClick"; "ui5StopGeneration": "ui5StopGeneration"; "ui5VersionChange": "ui5VersionChange"; }, never, ["*"], true, never>;
68
+ }
69
+
70
+ export { Input };