@agnos-ui/angular-bootstrap 0.6.0-next.0 → 0.6.0-next.2

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.
@@ -256,28 +256,28 @@ class SliderDefaultStructureSlotComponent {
256
256
  <div [auUse]="directives.clickableAreaDirective"></div>
257
257
  @if (state.showMinMaxLabels()) {
258
258
  <div [auUse]="directives.minLabelDirective">
259
- <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.min()}"></ng-template>
259
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.min()}" />
260
260
  </div>
261
261
  <div [auUse]="directives.maxLabelDirective">
262
- <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.max()}"></ng-template>
262
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.max()}" />
263
263
  </div>
264
264
  }
265
265
  @if (state.showValueLabels() && state.combinedLabelDisplay()) {
266
266
  <div [auUse]="directives.combinedHandleLabelDisplayDirective">
267
267
  @if (state.rtl()) {
268
- <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[1]}"></ng-template> -
269
- <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[0]}"></ng-template>
268
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[1]}" /> -
269
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[0]}" />
270
270
  } @else {
271
- <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[0]}"></ng-template> -
272
- <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[1]}"></ng-template>
271
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[0]}" /> -
272
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[1]}" />
273
273
  }
274
274
  </div>
275
275
  }
276
276
  @for (item of state.sortedHandles(); track item.id; let i = $index) {
277
- <ng-template [auSlot]="state.handle()" [auSlotProps]="{state, api, directives, item}"></ng-template>
277
+ <ng-template [auSlot]="state.handle()" [auSlotProps]="{state, api, directives, item}" />
278
278
  @if (state.showValueLabels() && !state.combinedLabelDisplay()) {
279
279
  <div [auUse]="[directives.handleLabelDisplayDirective, {index: i}]">
280
- <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.values()[i]}"></ng-template>
280
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.values()[i]}" />
281
281
  </div>
282
282
  }
283
283
  }
@@ -396,7 +396,7 @@ export class SliderComponent extends BaseWidgetDirective {
396
396
  host: {
397
397
  '(blur)': 'handleBlur()',
398
398
  },
399
- template: ` <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template> `,
399
+ template: ` <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}" /> `,
400
400
  }]
401
401
  }], () => [], { className: [{
402
402
  type: Input,
@@ -460,4 +460,4 @@ export class SliderComponent extends BaseWidgetDirective {
460
460
  args: [SliderHandleDirective, { static: false }]
461
461
  }] }); })();
462
462
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SliderComponent, { className: "SliderComponent", filePath: "components/slider/slider.component.ts", lineNumber: 153 }); })();
463
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../src/components/slider/slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tViewEncapsulation,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {callWidgetFactory} from '../../config';\nimport type {SliderContext, SliderSlotHandleContext, SliderSlotLabelContext, SliderWidget} from './slider.gen';\nimport {createSlider} from './slider.gen';\n\n/**\n * Directive to provide a template reference for slider labels.\n *\n * This directive uses a template reference to render the {@link SliderSlotLabelContext}.\n */\n@Directive({selector: 'ng-template[auSliderLabel]', standalone: true})\nexport class SliderLabelDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotLabelContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderLabelDirective, context: unknown): context is SliderSlotLabelContext {\n\t\treturn true;\n\t}\n}\n/**\n * Directive representing a handle for a slider component.\n *\n * This directive uses a template reference to render the {@link SliderSlotLabelContext}.\n */\n@Directive({selector: 'ng-template[auSliderHandle]', standalone: true})\nexport class SliderHandleDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotLabelContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderHandleDirective, context: unknown): context is SliderSlotHandleContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SliderHandleDirective],\n\ttemplate: `\n\t\t<ng-template auSliderHandle #handle let-state=\"state\" let-directives=\"directives\" let-item=\"item\">\n\t\t\t<button [auUse]=\"[directives.handleDirective, {item}]\">&nbsp;</button>\n\t\t</ng-template>\n\t`,\n})\nclass SliderDefaultHandleSlotComponent {\n\t@ViewChild('handle', {static: true}) readonly handle!: TemplateRef<SliderSlotHandleContext>;\n}\n\n/**\n * A constant representing the default slot handle for the slider component.\n */\nexport const sliderDefaultSlotHandle: SlotContent<SliderSlotHandleContext> = new ComponentTemplate(SliderDefaultHandleSlotComponent, 'handle');\n\n/**\n * Directive that provides structure for the slider component.\n *\n * This directive uses a `TemplateRef` to handle the context of the slider slot.\n */\n@Directive({selector: 'ng-template[auSliderStructure]', standalone: true})\nexport class SliderStructureDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotHandleContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderStructureDirective, context: unknown): context is SliderSlotHandleContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, SliderStructureDirective, UseDirective],\n\ttemplate: `\n\t\t<ng-template auSliderStructure #structure let-state=\"state\" let-directives=\"directives\" let-api=\"api\">\n\t\t\t@for (option of state.progressDisplayOptions(); track option) {\n\t\t\t\t<div [auUse]=\"[directives.progressDisplayDirective, {option}]\"></div>\n\t\t\t}\n\t\t\t<div [auUse]=\"directives.clickableAreaDirective\"></div>\n\t\t\t@if (state.showMinMaxLabels()) {\n\t\t\t\t<div [auUse]=\"directives.minLabelDirective\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.min()}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t\t<div [auUse]=\"directives.maxLabelDirective\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.max()}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t@if (state.showValueLabels() && state.combinedLabelDisplay()) {\n\t\t\t\t<div [auUse]=\"directives.combinedHandleLabelDisplayDirective\">\n\t\t\t\t\t@if (state.rtl()) {\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[1]}\"></ng-template> -\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[0]}\"></ng-template>\n\t\t\t\t\t} @else {\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[0]}\"></ng-template> -\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[1]}\"></ng-template>\n\t\t\t\t\t}\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t@for (item of state.sortedHandles(); track item.id; let i = $index) {\n\t\t\t\t<ng-template [auSlot]=\"state.handle()\" [auSlotProps]=\"{state, api, directives, item}\"></ng-template>\n\t\t\t\t@if (state.showValueLabels() && !state.combinedLabelDisplay()) {\n\t\t\t\t\t<div [auUse]=\"[directives.handleLabelDisplayDirective, {index: i}]\">\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.values()[i]}\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t}\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nclass SliderDefaultStructureSlotComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<SliderContext>;\n}\n\n/**\n * Represents the default slot structure for the slider component.\n */\nexport const sliderDefaultSlotStructure: SlotContent<SliderContext> = new ComponentTemplate(SliderDefaultStructureSlotComponent, 'structure');\n\n/**\n * SliderComponent is an Angular component that extends the BaseWidgetDirective\n * to provide a customizable slider widget. This component allows for various\n * configurations and customizations through its inputs and outputs.\n */\n@Component({\n\tselector: '[auSlider]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SliderComponent), multi: true}],\n\timports: [SlotDirective],\n\thost: {\n\t\t'(blur)': 'handleBlur()',\n\t},\n\ttemplate: ` <ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\"></ng-template> `,\n})\nexport class SliderComponent extends BaseWidgetDirective<SliderWidget> {\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * Minimum value that can be assigned to the slider\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auMin', transform: auNumberAttribute})\n\tmin: number | undefined;\n\n\t/**\n\t * Maximum value that can be assigned to the slider\n\t *\n\t * @defaultValue `100`\n\t */\n\t@Input({alias: 'auMax', transform: auNumberAttribute})\n\tmax: number | undefined;\n\n\t/**\n\t * Unit value between slider steps\n\t *\n\t * @defaultValue `1`\n\t */\n\t@Input({alias: 'auStepSize', transform: auNumberAttribute})\n\tstepSize: number | undefined;\n\n\t/**\n\t * Current slider values\n\t *\n\t * @defaultValue `[0]`\n\t */\n\t@Input('auValues')\n\tvalues: number[] | undefined;\n\n\t/**\n\t * It `true` slider display is inversed\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auRtl', transform: auBooleanAttribute})\n\trtl: boolean | undefined;\n\n\t/**\n\t * If `true` the value labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auShowValueLabels', transform: auBooleanAttribute}) showValueLabels: boolean | undefined;\n\n\t/**\n\t * If `true` the min and max labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auShowMinMaxLabels', transform: auBooleanAttribute}) showMinMaxLabels: boolean | undefined;\n\n\t/**\n\t * Return the value for the 'aria-label' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\t@Input('auAriaLabelHandle') ariaLabelHandle: ((value: number, sortedIndex: number, index: number) => string) | undefined;\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\t@Input('auAriaValueText') ariaValueText: ((value: number, sortedIndex: number, index: number) => string) | undefined;\n\n\t/**\n\t * If `true` slider value cannot be changed but the slider is still focusable\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auReadonly', transform: auBooleanAttribute})\n\treadonly: boolean | undefined;\n\n\t/**\n\t * If `true` slider value cannot be changed and the slider cannot be focused\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute})\n\tdisabled: boolean | undefined;\n\n\t/**\n\t * If `true` is vertically positioned otherwise it is horizontal\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auVertical', transform: auBooleanAttribute})\n\tvertical: boolean | undefined;\n\n\t/**\n\t * An event emitted when slider values are changed\n\t *\n\t * Event payload equals to the updated slider values\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auValuesChange')\n\tvaluesChange = new EventEmitter<number[]>();\n\n\t/**\n\t * Slot to change the default labels of the slider\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({value}: SliderSlotLabelContext) => '' + value\n\t * ```\n\t */\n\t@Input('auLabel') label: SlotContent<SliderSlotLabelContext>;\n\t@ContentChild(SliderLabelDirective, {static: false}) slotLabelFromContent: SliderLabelDirective | undefined;\n\n\t/**\n\t * Slot to change the default display of the slider\n\t */\n\t@Input('auStructure') structure: SlotContent<SliderContext>;\n\t@ContentChild(SliderStructureDirective, {static: false}) slotStructureFromContent: SliderStructureDirective | undefined;\n\n\t/**\n\t * Slot to change the handlers\n\t */\n\t@Input('auHandle') handle: SlotContent<SliderSlotHandleContext>;\n\t@ContentChild(SliderHandleDirective, {static: false}) slotHandleFromContent: SliderHandleDirective | undefined;\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createSlider,\n\t\t\t\twidgetName: 'slider',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: sliderDefaultSlotStructure,\n\t\t\t\t\thandle: sliderDefaultSlotHandle,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonValuesChange: (event) => {\n\t\t\t\t\t\tthis.onChange(event);\n\t\t\t\t\t\tthis.onTouched();\n\t\t\t\t\t\tthis.valuesChange.emit(event);\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t\tafterInit: (widget) => {\n\t\t\t\t\tuseDirectiveForHost(widget.directives.sliderDirective);\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\thandle: this.slotHandleFromContent?.templateRef,\n\t\t\t\t\tlabel: this.slotLabelFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t}),\n\t\t);\n\t}\n\n\t/**\n\t * Control value accessor methods\n\t */\n\tonChange = (_: any) => {};\n\n\tonTouched = () => {};\n\n\tregisterOnChange(fn: (value: any) => any): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => any): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\twriteValue(value: any): void {\n\t\tif (Array.isArray(value)) {\n\t\t\tthis['_widget'].patch({\n\t\t\t\tvalues: value,\n\t\t\t});\n\t\t} else {\n\t\t\tthis['_widget'].patch({\n\t\t\t\tvalues: [value],\n\t\t\t});\n\t\t}\n\t}\n\n\tsetDisabledState(isDisabled: boolean) {\n\t\tthis['_widget'].patch({\n\t\t\tdisabled: isDisabled,\n\t\t});\n\t}\n\n\thandleBlur() {\n\t\tthis.onTouched();\n\t}\n}\n"]}
463
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../src/components/slider/slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tViewEncapsulation,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {callWidgetFactory} from '../../config';\nimport type {SliderContext, SliderSlotHandleContext, SliderSlotLabelContext, SliderWidget} from './slider.gen';\nimport {createSlider} from './slider.gen';\n\n/**\n * Directive to provide a template reference for slider labels.\n *\n * This directive uses a template reference to render the {@link SliderSlotLabelContext}.\n */\n@Directive({selector: 'ng-template[auSliderLabel]', standalone: true})\nexport class SliderLabelDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotLabelContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderLabelDirective, context: unknown): context is SliderSlotLabelContext {\n\t\treturn true;\n\t}\n}\n/**\n * Directive representing a handle for a slider component.\n *\n * This directive uses a template reference to render the {@link SliderSlotLabelContext}.\n */\n@Directive({selector: 'ng-template[auSliderHandle]', standalone: true})\nexport class SliderHandleDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotLabelContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderHandleDirective, context: unknown): context is SliderSlotHandleContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SliderHandleDirective],\n\ttemplate: `\n\t\t<ng-template auSliderHandle #handle let-state=\"state\" let-directives=\"directives\" let-item=\"item\">\n\t\t\t<button [auUse]=\"[directives.handleDirective, {item}]\">&nbsp;</button>\n\t\t</ng-template>\n\t`,\n})\nclass SliderDefaultHandleSlotComponent {\n\t@ViewChild('handle', {static: true}) readonly handle!: TemplateRef<SliderSlotHandleContext>;\n}\n\n/**\n * A constant representing the default slot handle for the slider component.\n */\nexport const sliderDefaultSlotHandle: SlotContent<SliderSlotHandleContext> = new ComponentTemplate(SliderDefaultHandleSlotComponent, 'handle');\n\n/**\n * Directive that provides structure for the slider component.\n *\n * This directive uses a `TemplateRef` to handle the context of the slider slot.\n */\n@Directive({selector: 'ng-template[auSliderStructure]', standalone: true})\nexport class SliderStructureDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotHandleContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderStructureDirective, context: unknown): context is SliderSlotHandleContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, SliderStructureDirective, UseDirective],\n\ttemplate: `\n\t\t<ng-template auSliderStructure #structure let-state=\"state\" let-directives=\"directives\" let-api=\"api\">\n\t\t\t@for (option of state.progressDisplayOptions(); track option) {\n\t\t\t\t<div [auUse]=\"[directives.progressDisplayDirective, {option}]\"></div>\n\t\t\t}\n\t\t\t<div [auUse]=\"directives.clickableAreaDirective\"></div>\n\t\t\t@if (state.showMinMaxLabels()) {\n\t\t\t\t<div [auUse]=\"directives.minLabelDirective\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.min()}\" />\n\t\t\t\t</div>\n\t\t\t\t<div [auUse]=\"directives.maxLabelDirective\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.max()}\" />\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t@if (state.showValueLabels() && state.combinedLabelDisplay()) {\n\t\t\t\t<div [auUse]=\"directives.combinedHandleLabelDisplayDirective\">\n\t\t\t\t\t@if (state.rtl()) {\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[1]}\" /> -\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[0]}\" />\n\t\t\t\t\t} @else {\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[0]}\" /> -\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[1]}\" />\n\t\t\t\t\t}\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t@for (item of state.sortedHandles(); track item.id; let i = $index) {\n\t\t\t\t<ng-template [auSlot]=\"state.handle()\" [auSlotProps]=\"{state, api, directives, item}\" />\n\t\t\t\t@if (state.showValueLabels() && !state.combinedLabelDisplay()) {\n\t\t\t\t\t<div [auUse]=\"[directives.handleLabelDisplayDirective, {index: i}]\">\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.values()[i]}\" />\n\t\t\t\t\t</div>\n\t\t\t\t}\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nclass SliderDefaultStructureSlotComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<SliderContext>;\n}\n\n/**\n * Represents the default slot structure for the slider component.\n */\nexport const sliderDefaultSlotStructure: SlotContent<SliderContext> = new ComponentTemplate(SliderDefaultStructureSlotComponent, 'structure');\n\n/**\n * SliderComponent is an Angular component that extends the BaseWidgetDirective\n * to provide a customizable slider widget. This component allows for various\n * configurations and customizations through its inputs and outputs.\n */\n@Component({\n\tselector: '[auSlider]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SliderComponent), multi: true}],\n\timports: [SlotDirective],\n\thost: {\n\t\t'(blur)': 'handleBlur()',\n\t},\n\ttemplate: ` <ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\" /> `,\n})\nexport class SliderComponent extends BaseWidgetDirective<SliderWidget> {\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * Minimum value that can be assigned to the slider\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auMin', transform: auNumberAttribute})\n\tmin: number | undefined;\n\n\t/**\n\t * Maximum value that can be assigned to the slider\n\t *\n\t * @defaultValue `100`\n\t */\n\t@Input({alias: 'auMax', transform: auNumberAttribute})\n\tmax: number | undefined;\n\n\t/**\n\t * Unit value between slider steps\n\t *\n\t * @defaultValue `1`\n\t */\n\t@Input({alias: 'auStepSize', transform: auNumberAttribute})\n\tstepSize: number | undefined;\n\n\t/**\n\t * Current slider values\n\t *\n\t * @defaultValue `[0]`\n\t */\n\t@Input('auValues')\n\tvalues: number[] | undefined;\n\n\t/**\n\t * It `true` slider display is inversed\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auRtl', transform: auBooleanAttribute})\n\trtl: boolean | undefined;\n\n\t/**\n\t * If `true` the value labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auShowValueLabels', transform: auBooleanAttribute}) showValueLabels: boolean | undefined;\n\n\t/**\n\t * If `true` the min and max labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auShowMinMaxLabels', transform: auBooleanAttribute}) showMinMaxLabels: boolean | undefined;\n\n\t/**\n\t * Return the value for the 'aria-label' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\t@Input('auAriaLabelHandle') ariaLabelHandle: ((value: number, sortedIndex: number, index: number) => string) | undefined;\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\t@Input('auAriaValueText') ariaValueText: ((value: number, sortedIndex: number, index: number) => string) | undefined;\n\n\t/**\n\t * If `true` slider value cannot be changed but the slider is still focusable\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auReadonly', transform: auBooleanAttribute})\n\treadonly: boolean | undefined;\n\n\t/**\n\t * If `true` slider value cannot be changed and the slider cannot be focused\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute})\n\tdisabled: boolean | undefined;\n\n\t/**\n\t * If `true` is vertically positioned otherwise it is horizontal\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auVertical', transform: auBooleanAttribute})\n\tvertical: boolean | undefined;\n\n\t/**\n\t * An event emitted when slider values are changed\n\t *\n\t * Event payload equals to the updated slider values\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auValuesChange')\n\tvaluesChange = new EventEmitter<number[]>();\n\n\t/**\n\t * Slot to change the default labels of the slider\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({value}: SliderSlotLabelContext) => '' + value\n\t * ```\n\t */\n\t@Input('auLabel') label: SlotContent<SliderSlotLabelContext>;\n\t@ContentChild(SliderLabelDirective, {static: false}) slotLabelFromContent: SliderLabelDirective | undefined;\n\n\t/**\n\t * Slot to change the default display of the slider\n\t */\n\t@Input('auStructure') structure: SlotContent<SliderContext>;\n\t@ContentChild(SliderStructureDirective, {static: false}) slotStructureFromContent: SliderStructureDirective | undefined;\n\n\t/**\n\t * Slot to change the handlers\n\t */\n\t@Input('auHandle') handle: SlotContent<SliderSlotHandleContext>;\n\t@ContentChild(SliderHandleDirective, {static: false}) slotHandleFromContent: SliderHandleDirective | undefined;\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createSlider,\n\t\t\t\twidgetName: 'slider',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: sliderDefaultSlotStructure,\n\t\t\t\t\thandle: sliderDefaultSlotHandle,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonValuesChange: (event) => {\n\t\t\t\t\t\tthis.onChange(event);\n\t\t\t\t\t\tthis.onTouched();\n\t\t\t\t\t\tthis.valuesChange.emit(event);\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t\tafterInit: (widget) => {\n\t\t\t\t\tuseDirectiveForHost(widget.directives.sliderDirective);\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\thandle: this.slotHandleFromContent?.templateRef,\n\t\t\t\t\tlabel: this.slotLabelFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t}),\n\t\t);\n\t}\n\n\t/**\n\t * Control value accessor methods\n\t */\n\tonChange = (_: any) => {};\n\n\tonTouched = () => {};\n\n\tregisterOnChange(fn: (value: any) => any): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => any): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\twriteValue(value: any): void {\n\t\tif (Array.isArray(value)) {\n\t\t\tthis['_widget'].patch({\n\t\t\t\tvalues: value,\n\t\t\t});\n\t\t} else {\n\t\t\tthis['_widget'].patch({\n\t\t\t\tvalues: [value],\n\t\t\t});\n\t\t}\n\t}\n\n\tsetDisabledState(isDisabled: boolean) {\n\t\tthis['_widget'].patch({\n\t\t\tdisabled: isDisabled,\n\t\t});\n\t}\n\n\thandleBlur() {\n\t\tthis.onTouched();\n\t}\n}\n"]}
@@ -142,14 +142,14 @@ class ToastDefaultSlotsComponent {
142
142
  template: ` <ng-template auToastStructure #structure let-state="state" let-api="api" let-directives="directives">
143
143
  @if (state.header()) {
144
144
  <div class="toast-header">
145
- <ng-template [auSlot]="state.header()" [auSlotProps]="{state, api, directives}"></ng-template>
145
+ <ng-template [auSlot]="state.header()" [auSlotProps]="{state, api, directives}" />
146
146
  @if (state.dismissible()) {
147
147
  <button class="btn-close me-0 ms-auto" [auUse]="directives.closeButtonDirective"></button>
148
148
  }
149
149
  </div>
150
150
  }
151
151
  <div class="toast-body">
152
- <ng-template [auSlot]="state.children()" [auSlotProps]="{state, api, directives}"></ng-template>
152
+ <ng-template [auSlot]="state.children()" [auSlotProps]="{state, api, directives}" />
153
153
  </div>
154
154
  @if (state.dismissible() && !state.header()) {
155
155
  <button class="btn-close btn-close-white me-2 m-auto" [auUse]="directives.closeButtonDirective"></button>
@@ -249,7 +249,7 @@ export class ToastComponent extends BaseWidgetDirective {
249
249
  changeDetection: ChangeDetectionStrategy.OnPush,
250
250
  imports: [SlotDirective, UseMultiDirective],
251
251
  template: ` <ng-template #content>
252
- <ng-content></ng-content>
252
+ <ng-content />
253
253
  </ng-template>
254
254
  @if (!state.hidden()) {
255
255
  <div
@@ -258,7 +258,7 @@ export class ToastComponent extends BaseWidgetDirective {
258
258
  [class.toast-dismissible]="state.dismissible()"
259
259
  [auUseMulti]="[directives.autoHideDirective, directives.transitionDirective, directives.bodyDirective]"
260
260
  >
261
- <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template>
261
+ <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}" />
262
262
  </div>
263
263
  }`,
264
264
  }]
@@ -321,4 +321,4 @@ export class ToastComponent extends BaseWidgetDirective {
321
321
  args: ['content', { static: true }]
322
322
  }] }); })();
323
323
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ToastComponent, { className: "ToastComponent", filePath: "components/toast/toast.component.ts", lineNumber: 117 }); })();
324
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../src/components/toast/toast.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\nimport {callWidgetFactory} from '../../config';\n\nimport type {ToastContext, ToastWidget} from './toast.gen';\nimport {createToast} from './toast.gen';\n\n/**\n * Directive to represent the body of a toast notification.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastBody]', standalone: true})\nexport class ToastBodyDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastBodyDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to define the structure of a toast component.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastStructure]', standalone: true})\nexport class ToastStructureDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastStructureDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive representing the header of a toast component.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastHeader]', standalone: true})\nexport class ToastHeaderDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastHeaderDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, ToastStructureDirective, UseDirective],\n\ttemplate: ` <ng-template auToastStructure #structure let-state=\"state\" let-api=\"api\" let-directives=\"directives\">\n\t\t@if (state.header()) {\n\t\t\t<div class=\"toast-header\">\n\t\t\t\t<ng-template [auSlot]=\"state.header()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t\t\t@if (state.dismissible()) {\n\t\t\t\t\t<button class=\"btn-close me-0 ms-auto\" [auUse]=\"directives.closeButtonDirective\"></button>\n\t\t\t\t}\n\t\t\t</div>\n\t\t}\n\t\t<div class=\"toast-body\">\n\t\t\t<ng-template [auSlot]=\"state.children()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t</div>\n\t\t@if (state.dismissible() && !state.header()) {\n\t\t\t<button class=\"btn-close btn-close-white me-2 m-auto\" [auUse]=\"directives.closeButtonDirective\"></button>\n\t\t}\n\t</ng-template>`,\n})\nclass ToastDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<ToastContext>;\n}\n\n/**\n * Represents the default slot structure for the toast component.\n */\nexport const toastDefaultSlotStructure: SlotContent<ToastContext> = new ComponentTemplate(ToastDefaultSlotsComponent, 'structure');\n\n/**\n * The `ToastComponent` is a UI component that displays a toast notification.\n * It extends the `BaseWidgetDirective` and provides various configurable properties\n * and events to control the behavior and appearance of the toast.\n */\n@Component({\n\tselector: '[auToast]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, UseMultiDirective],\n\ttemplate: ` <ng-template #content>\n\t\t\t<ng-content></ng-content>\n\t\t</ng-template>\n\t\t@if (!state.hidden()) {\n\t\t\t<div\n\t\t\t\tclass=\"toast\"\n\t\t\t\t[class.d-flex]=\"!state.header()\"\n\t\t\t\t[class.toast-dismissible]=\"state.dismissible()\"\n\t\t\t\t[auUseMulti]=\"[directives.autoHideDirective, directives.transitionDirective, directives.bodyDirective]\"\n\t\t\t>\n\t\t\t\t<ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t\t</div>\n\t\t}`,\n})\nexport class ToastComponent extends BaseWidgetDirective<ToastWidget> {\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auDismissible', transform: auBooleanAttribute})\n\tdismissible: boolean | undefined;\n\n\t/**\n\t * The transition function will be executed when the alert is displayed or hidden.\n\t *\n\t * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\t@Input('auTransition')\n\ttransition: TransitionFn | undefined;\n\n\t/**\n\t * If `true` the alert is visible to the user\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute})\n\tvisible: boolean | undefined;\n\n\t/**\n\t * If `true`, alert opening will be animated.\n\t *\n\t * Animation is triggered  when the `.open()` function is called\n\t * or the visible prop is changed\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auAnimatedOnInit', transform: auBooleanAttribute})\n\tanimatedOnInit: boolean | undefined;\n\n\t/**\n\t * If `true`, alert closing will be animated.\n\t *\n\t * Animation is triggered  when clicked on the close button (×),\n\t * via the `.close()` function or the visible prop is changed\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute})\n\tanimated: boolean | undefined;\n\n\t/**\n\t * If `true` automatically hides the toast after the delay.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auAutoHide', transform: auBooleanAttribute})\n\tautoHide: boolean | undefined;\n\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t *\n\t * @defaultValue `5000`\n\t */\n\t@Input({alias: 'auDelay', transform: auNumberAttribute})\n\tdelay: number | undefined;\n\n\t/**\n\t * Accessibility close button label\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t/**\n\t * Template for the toast content\n\t */\n\t@Input('auChildren') children: SlotContent<ToastContext>;\n\t@ContentChild(ToastBodyDirective, {static: false})\n\tslotDefaultFromContent: ToastBodyDirective | undefined;\n\n\t/**\n\t * Global template for the toast component\n\t */\n\t@Input('auStructure') structure: SlotContent<ToastContext>;\n\t@ContentChild(ToastStructureDirective, {static: false}) slotStructureFromContent: ToastStructureDirective | undefined;\n\n\t/**\n\t * Header template for the toast component\n\t */\n\t@Input('auHeader') header: SlotContent<ToastContext>;\n\t@ContentChild(ToastHeaderDirective, {static: false}) slotHeaderFromContent: ToastHeaderDirective | undefined;\n\n\t/**\n\t * Callback called when the alert visibility changed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Callback called when the alert is hidden.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Callback called when the alert is shown.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t@ViewChild('content', {static: true})\n\tslotChildren?: TemplateRef<void>;\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createToast,\n\t\t\t\twidgetName: 'toast',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: toastDefaultSlotStructure,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t\t\t\tonShown: () => this.shown.emit(),\n\t\t\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tchildren: this.slotDefaultFromContent?.templateRef,\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t\tslotChildren: () => this.slotChildren,\n\t\t\t}),\n\t\t);\n\t}\n}\n"]}
324
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../src/components/toast/toast.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\nimport {callWidgetFactory} from '../../config';\n\nimport type {ToastContext, ToastWidget} from './toast.gen';\nimport {createToast} from './toast.gen';\n\n/**\n * Directive to represent the body of a toast notification.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastBody]', standalone: true})\nexport class ToastBodyDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastBodyDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to define the structure of a toast component.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastStructure]', standalone: true})\nexport class ToastStructureDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastStructureDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive representing the header of a toast component.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastHeader]', standalone: true})\nexport class ToastHeaderDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastHeaderDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, ToastStructureDirective, UseDirective],\n\ttemplate: ` <ng-template auToastStructure #structure let-state=\"state\" let-api=\"api\" let-directives=\"directives\">\n\t\t@if (state.header()) {\n\t\t\t<div class=\"toast-header\">\n\t\t\t\t<ng-template [auSlot]=\"state.header()\" [auSlotProps]=\"{state, api, directives}\" />\n\t\t\t\t@if (state.dismissible()) {\n\t\t\t\t\t<button class=\"btn-close me-0 ms-auto\" [auUse]=\"directives.closeButtonDirective\"></button>\n\t\t\t\t}\n\t\t\t</div>\n\t\t}\n\t\t<div class=\"toast-body\">\n\t\t\t<ng-template [auSlot]=\"state.children()\" [auSlotProps]=\"{state, api, directives}\" />\n\t\t</div>\n\t\t@if (state.dismissible() && !state.header()) {\n\t\t\t<button class=\"btn-close btn-close-white me-2 m-auto\" [auUse]=\"directives.closeButtonDirective\"></button>\n\t\t}\n\t</ng-template>`,\n})\nclass ToastDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<ToastContext>;\n}\n\n/**\n * Represents the default slot structure for the toast component.\n */\nexport const toastDefaultSlotStructure: SlotContent<ToastContext> = new ComponentTemplate(ToastDefaultSlotsComponent, 'structure');\n\n/**\n * The `ToastComponent` is a UI component that displays a toast notification.\n * It extends the `BaseWidgetDirective` and provides various configurable properties\n * and events to control the behavior and appearance of the toast.\n */\n@Component({\n\tselector: '[auToast]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, UseMultiDirective],\n\ttemplate: ` <ng-template #content>\n\t\t\t<ng-content />\n\t\t</ng-template>\n\t\t@if (!state.hidden()) {\n\t\t\t<div\n\t\t\t\tclass=\"toast\"\n\t\t\t\t[class.d-flex]=\"!state.header()\"\n\t\t\t\t[class.toast-dismissible]=\"state.dismissible()\"\n\t\t\t\t[auUseMulti]=\"[directives.autoHideDirective, directives.transitionDirective, directives.bodyDirective]\"\n\t\t\t>\n\t\t\t\t<ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\" />\n\t\t\t</div>\n\t\t}`,\n})\nexport class ToastComponent extends BaseWidgetDirective<ToastWidget> {\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auDismissible', transform: auBooleanAttribute})\n\tdismissible: boolean | undefined;\n\n\t/**\n\t * The transition function will be executed when the alert is displayed or hidden.\n\t *\n\t * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\t@Input('auTransition')\n\ttransition: TransitionFn | undefined;\n\n\t/**\n\t * If `true` the alert is visible to the user\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute})\n\tvisible: boolean | undefined;\n\n\t/**\n\t * If `true`, alert opening will be animated.\n\t *\n\t * Animation is triggered  when the `.open()` function is called\n\t * or the visible prop is changed\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auAnimatedOnInit', transform: auBooleanAttribute})\n\tanimatedOnInit: boolean | undefined;\n\n\t/**\n\t * If `true`, alert closing will be animated.\n\t *\n\t * Animation is triggered  when clicked on the close button (×),\n\t * via the `.close()` function or the visible prop is changed\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute})\n\tanimated: boolean | undefined;\n\n\t/**\n\t * If `true` automatically hides the toast after the delay.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auAutoHide', transform: auBooleanAttribute})\n\tautoHide: boolean | undefined;\n\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t *\n\t * @defaultValue `5000`\n\t */\n\t@Input({alias: 'auDelay', transform: auNumberAttribute})\n\tdelay: number | undefined;\n\n\t/**\n\t * Accessibility close button label\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t/**\n\t * Template for the toast content\n\t */\n\t@Input('auChildren') children: SlotContent<ToastContext>;\n\t@ContentChild(ToastBodyDirective, {static: false})\n\tslotDefaultFromContent: ToastBodyDirective | undefined;\n\n\t/**\n\t * Global template for the toast component\n\t */\n\t@Input('auStructure') structure: SlotContent<ToastContext>;\n\t@ContentChild(ToastStructureDirective, {static: false}) slotStructureFromContent: ToastStructureDirective | undefined;\n\n\t/**\n\t * Header template for the toast component\n\t */\n\t@Input('auHeader') header: SlotContent<ToastContext>;\n\t@ContentChild(ToastHeaderDirective, {static: false}) slotHeaderFromContent: ToastHeaderDirective | undefined;\n\n\t/**\n\t * Callback called when the alert visibility changed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Callback called when the alert is hidden.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Callback called when the alert is shown.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t@ViewChild('content', {static: true})\n\tslotChildren?: TemplateRef<void>;\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createToast,\n\t\t\t\twidgetName: 'toast',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: toastDefaultSlotStructure,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t\t\t\tonShown: () => this.shown.emit(),\n\t\t\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tchildren: this.slotDefaultFromContent?.templateRef,\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t\tslotChildren: () => this.slotChildren,\n\t\t\t}),\n\t\t);\n\t}\n}\n"]}
@@ -31,7 +31,9 @@ const _c2 = ["toggle"];
31
31
  const _c3 = a0 => ({ item: a0 });
32
32
  const _c4 = (a0, a1) => [a0, a1];
33
33
  function TreeDefaultItemToggleSlotComponent_ng_template_0_Conditional_0_Template(rf, ctx) { if (rf & 1) {
34
- i0.ɵɵelement(0, "button", 2);
34
+ i0.ɵɵelementStart(0, "button", 2);
35
+ i0.ɵɵelement(1, "span", 4);
36
+ i0.ɵɵelementEnd();
35
37
  } if (rf & 2) {
36
38
  const ctx_r0 = i0.ɵɵnextContext();
37
39
  const directives_r2 = ctx_r0.directives;
@@ -42,7 +44,7 @@ function TreeDefaultItemToggleSlotComponent_ng_template_0_Conditional_1_Template
42
44
  i0.ɵɵelement(0, "span", 3);
43
45
  } }
44
46
  function TreeDefaultItemToggleSlotComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
45
- i0.ɵɵtemplate(0, TreeDefaultItemToggleSlotComponent_ng_template_0_Conditional_0_Template, 1, 6, "button", 2)(1, TreeDefaultItemToggleSlotComponent_ng_template_0_Conditional_1_Template, 1, 0, "span", 3);
47
+ i0.ɵɵtemplate(0, TreeDefaultItemToggleSlotComponent_ng_template_0_Conditional_0_Template, 2, 6, "button", 2)(1, TreeDefaultItemToggleSlotComponent_ng_template_0_Conditional_1_Template, 1, 0, "span", 3);
46
48
  } if (rf & 2) {
47
49
  const item_r3 = ctx.item;
48
50
  i0.ɵɵconditional(item_r3.children.length > 0 ? 0 : 1);
@@ -147,7 +149,7 @@ class TreeDefaultStructureSlotComponent {
147
149
  <ng-template auTreeStructure #structure let-state="state" let-directives="directives" let-api="api">
148
150
  <ul role="tree" class="au-tree {{ state.className() }}" [auUse]="directives.navigationDirective">
149
151
  @for (node of state.normalizedNodes(); track trackNode($index, node)) {
150
- <ng-template [auSlot]="state.item()" [auSlotProps]="{state, api, directives, item: node}"></ng-template>
152
+ <ng-template [auSlot]="state.item()" [auSlotProps]="{state, api, directives, item: node}" />
151
153
  }
152
154
  </ul>
153
155
  </ng-template>
@@ -188,7 +190,7 @@ class TreeDefaultItemToggleSlotComponent {
188
190
  } if (rf & 2) {
189
191
  let _t;
190
192
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.toggle = _t.first);
191
- } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["toggle", ""], ["auTreeItemToggle", ""], [3, "auUse"], [1, "au-tree-expand-icon-placeholder"]], template: function TreeDefaultItemToggleSlotComponent_Template(rf, ctx) { if (rf & 1) {
193
+ } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["toggle", ""], ["auTreeItemToggle", ""], [3, "auUse"], [1, "au-tree-expand-icon-placeholder"], [1, "au-tree-expand-icon-svg"]], template: function TreeDefaultItemToggleSlotComponent_Template(rf, ctx) { if (rf & 1) {
192
194
  i0.ɵɵtemplate(0, TreeDefaultItemToggleSlotComponent_ng_template_0_Template, 2, 1, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
193
195
  } }, dependencies: [UseDirective, TreeItemToggleDirective], encapsulation: 2, changeDetection: 0 }); }
194
196
  }
@@ -201,7 +203,9 @@ class TreeDefaultItemToggleSlotComponent {
201
203
  template: `
202
204
  <ng-template auTreeItemToggle #toggle let-directives="directives" let-item="item">
203
205
  @if (item.children.length > 0) {
204
- <button [auUse]="[directives.itemToggleDirective, {item}]"></button>
206
+ <button [auUse]="[directives.itemToggleDirective, {item}]">
207
+ <span class="au-tree-expand-icon-svg"></span>
208
+ </button>
205
209
  } @else {
206
210
  <span class="au-tree-expand-icon-placeholder"></span>
207
211
  }
@@ -212,7 +216,7 @@ class TreeDefaultItemToggleSlotComponent {
212
216
  type: ViewChild,
213
217
  args: ['toggle', { static: true }]
214
218
  }] }); })();
215
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemToggleSlotComponent, { className: "TreeDefaultItemToggleSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 85 }); })();
219
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemToggleSlotComponent, { className: "TreeDefaultItemToggleSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 87 }); })();
216
220
  /**
217
221
  * A constant representing the default slot for tree item toggle.
218
222
  */
@@ -256,7 +260,7 @@ class TreeDefaultItemContentSlotComponent {
256
260
  template: `
257
261
  <ng-template auTreeItem #treeItemContent let-state="state" let-directives="directives" let-item="item" let-api="api">
258
262
  <span class="au-tree-item">
259
- <ng-template [auSlot]="state.itemToggle()" [auSlotProps]="{state, api, directives, item}"></ng-template>
263
+ <ng-template [auSlot]="state.itemToggle()" [auSlotProps]="{state, api, directives, item}" />
260
264
  {{ item.label }}
261
265
  </span>
262
266
  </ng-template>
@@ -266,7 +270,7 @@ class TreeDefaultItemContentSlotComponent {
266
270
  type: ViewChild,
267
271
  args: ['treeItemContent', { static: true }]
268
272
  }] }); })();
269
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemContentSlotComponent, { className: "TreeDefaultItemContentSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 120 }); })();
273
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemContentSlotComponent, { className: "TreeDefaultItemContentSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 122 }); })();
270
274
  /**
271
275
  * A constant representing the default slot for tree item.
272
276
  */
@@ -313,11 +317,11 @@ class TreeDefaultItemSlotComponent {
313
317
  template: `
314
318
  <ng-template auTreeItem #treeItem let-state="state" let-directives="directives" let-item="item" let-api="api">
315
319
  <li [auUse]="[directives.itemAttributesDirective, {item}]">
316
- <ng-template [auSlot]="state.itemContent()" [auSlotProps]="{state, api, directives, item}"></ng-template>
320
+ <ng-template [auSlot]="state.itemContent()" [auSlotProps]="{state, api, directives, item}" />
317
321
  @if (state.expandedMap().get(item)) {
318
322
  <ul role="group">
319
323
  @for (child of item.children; track trackNode($index, child)) {
320
- <ng-template [auSlot]="state.item()" [auSlotProps]="{state, api, directives, item: child}"></ng-template>
324
+ <ng-template [auSlot]="state.item()" [auSlotProps]="{state, api, directives, item: child}" />
321
325
  }
322
326
  </ul>
323
327
  }
@@ -329,7 +333,7 @@ class TreeDefaultItemSlotComponent {
329
333
  type: ViewChild,
330
334
  args: ['treeItem', { static: true }]
331
335
  }] }); })();
332
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemSlotComponent, { className: "TreeDefaultItemSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 164 }); })();
336
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemSlotComponent, { className: "TreeDefaultItemSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 166 }); })();
333
337
  /**
334
338
  * A constant representing the default slot for tree item.
335
339
  */
@@ -388,15 +392,16 @@ export class TreeComponent extends BaseWidgetDirective {
388
392
  i0.ɵɵtemplate(0, TreeComponent_ng_template_0_Template, 0, 0, "ng-template", 0);
389
393
  } if (rf & 2) {
390
394
  i0.ɵɵproperty("auSlot", ctx.state.structure())("auSlotProps", i0.ɵɵpureFunction3(2, _c8, ctx.state, ctx.api, ctx.directives));
391
- } }, dependencies: [SlotDirective], encapsulation: 2 }); }
395
+ } }, dependencies: [SlotDirective], encapsulation: 2, changeDetection: 0 }); }
392
396
  }
393
397
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeComponent, [{
394
398
  type: Component,
395
399
  args: [{
400
+ changeDetection: ChangeDetectionStrategy.OnPush,
396
401
  selector: '[auTree]',
397
402
  standalone: true,
398
403
  imports: [SlotDirective],
399
- template: ` <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template> `,
404
+ template: ` <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}" /> `,
400
405
  }]
401
406
  }], () => [], { ariaLabel: [{
402
407
  type: Input,
@@ -441,5 +446,5 @@ export class TreeComponent extends BaseWidgetDirective {
441
446
  type: ContentChild,
442
447
  args: [TreeItemDirective, { static: false }]
443
448
  }] }); })();
444
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeComponent, { className: "TreeComponent", filePath: "components/tree/tree.component.ts", lineNumber: 188 }); })();
445
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../src/components/tree/tree.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent} from '@agnos-ui/angular-headless';\nimport {BaseWidgetDirective, callWidgetFactory, ComponentTemplate, SlotDirective, UseDirective} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tinject,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n} from '@angular/core';\nimport type {TreeContext, TreeItem, NormalizedTreeItem, TreeSlotItemContext, TreeWidget} from './tree.gen';\nimport {createTree} from './tree.gen';\n\n/**\n * Directive to provide a template reference for tree structure.\n *\n * This directive uses a template reference to render the {@link TreeContext}.\n */\n@Directive({selector: 'ng-template[auTreeStructure]', standalone: true})\nexport class TreeStructureDirective {\n\tpublic templateRef = inject(TemplateRef<TreeContext>);\n\tstatic ngTemplateContextGuard(_dir: TreeStructureDirective, context: unknown): context is TreeContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, TreeStructureDirective, SlotDirective],\n\ttemplate: `\n\t\t<ng-template auTreeStructure #structure let-state=\"state\" let-directives=\"directives\" let-api=\"api\">\n\t\t\t<ul role=\"tree\" class=\"au-tree {{ state.className() }}\" [auUse]=\"directives.navigationDirective\">\n\t\t\t\t@for (node of state.normalizedNodes(); track trackNode($index, node)) {\n\t\t\t\t\t<ng-template [auSlot]=\"state.item()\" [auSlotProps]=\"{state, api, directives, item: node}\"></ng-template>\n\t\t\t\t}\n\t\t\t</ul>\n\t\t</ng-template>\n\t`,\n})\nclass TreeDefaultStructureSlotComponent {\n\t@ViewChild('structure', {static: true}) readonly structure!: TemplateRef<TreeContext>;\n\n\ttrackNode(index: number, node: NormalizedTreeItem): string {\n\t\treturn node.label + node.level + index;\n\t}\n}\n\n/**\n * A constant representing the default slot for tree structure.\n */\nexport const treeDefaultSlotStructure: SlotContent<TreeContext> = new ComponentTemplate(TreeDefaultStructureSlotComponent, 'structure');\n\n/**\n * Directive to provide a template reference for tree item toggle.\n *\n * This directive uses a template reference to render the {@link TreeSlotItemContext}.\n */\n@Directive({selector: 'ng-template[auTreeItemToggle]', standalone: true})\nexport class TreeItemToggleDirective {\n\tpublic templateRef = inject(TemplateRef<TreeSlotItemContext>);\n\tstatic ngTemplateContextGuard(_dir: TreeItemToggleDirective, context: unknown): context is TreeSlotItemContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, TreeItemToggleDirective],\n\ttemplate: `\n\t\t<ng-template auTreeItemToggle #toggle let-directives=\"directives\" let-item=\"item\">\n\t\t\t@if (item.children.length > 0) {\n\t\t\t\t<button [auUse]=\"[directives.itemToggleDirective, {item}]\"></button>\n\t\t\t} @else {\n\t\t\t\t<span class=\"au-tree-expand-icon-placeholder\"></span>\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nclass TreeDefaultItemToggleSlotComponent {\n\t@ViewChild('toggle', {static: true}) readonly toggle!: TemplateRef<TreeSlotItemContext>;\n}\n\n/**\n * A constant representing the default slot for tree item toggle.\n */\nexport const treeDefaultItemToggle: SlotContent<TreeSlotItemContext> = new ComponentTemplate(TreeDefaultItemToggleSlotComponent, 'toggle');\n\n/**\n * Directive to provide a template reference for tree item content.\n *\n * This directive uses a template reference to render the {@link TreeSlotItemContext}.\n */\n@Directive({selector: 'ng-template[auTreeItemContent]', standalone: true})\nexport class TreeItemContentDirective {\n\tpublic templateRef = inject(TemplateRef<TreeSlotItemContext>);\n\tstatic ngTemplateContextGuard(_dir: TreeItemContentDirective, context: unknown): context is TreeSlotItemContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SlotDirective, TreeItemContentDirective],\n\ttemplate: `\n\t\t<ng-template auTreeItem #treeItemContent let-state=\"state\" let-directives=\"directives\" let-item=\"item\" let-api=\"api\">\n\t\t\t<span class=\"au-tree-item\">\n\t\t\t\t<ng-template [auSlot]=\"state.itemToggle()\" [auSlotProps]=\"{state, api, directives, item}\"></ng-template>\n\t\t\t\t{{ item.label }}\n\t\t\t</span>\n\t\t</ng-template>\n\t`,\n})\nclass TreeDefaultItemContentSlotComponent {\n\t@ViewChild('treeItemContent', {static: true}) readonly treeItemContent!: TemplateRef<TreeSlotItemContext>;\n}\n\n/**\n * A constant representing the default slot for tree item.\n */\nexport const treeDefaultSlotItemContent: SlotContent<TreeSlotItemContext> = new ComponentTemplate(\n\tTreeDefaultItemContentSlotComponent,\n\t'treeItemContent',\n);\n\n/**\n * Directive to provide a template reference for tree item.\n *\n * This directive uses a template reference to render the {@link TreeSlotItemContext}.\n */\n@Directive({selector: 'ng-template[auTreeItem]', standalone: true})\nexport class TreeItemDirective {\n\tpublic templateRef = inject(TemplateRef<TreeSlotItemContext>);\n\tstatic ngTemplateContextGuard(_dir: TreeItemDirective, context: unknown): context is TreeSlotItemContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SlotDirective, TreeItemDirective],\n\ttemplate: `\n\t\t<ng-template auTreeItem #treeItem let-state=\"state\" let-directives=\"directives\" let-item=\"item\" let-api=\"api\">\n\t\t\t<li [auUse]=\"[directives.itemAttributesDirective, {item}]\">\n\t\t\t\t<ng-template [auSlot]=\"state.itemContent()\" [auSlotProps]=\"{state, api, directives, item}\"></ng-template>\n\t\t\t\t@if (state.expandedMap().get(item)) {\n\t\t\t\t\t<ul role=\"group\">\n\t\t\t\t\t\t@for (child of item.children; track trackNode($index, child)) {\n\t\t\t\t\t\t\t<ng-template [auSlot]=\"state.item()\" [auSlotProps]=\"{state, api, directives, item: child}\"></ng-template>\n\t\t\t\t\t\t}\n\t\t\t\t\t</ul>\n\t\t\t\t}\n\t\t\t</li>\n\t\t</ng-template>\n\t`,\n})\nclass TreeDefaultItemSlotComponent {\n\t@ViewChild('treeItem', {static: true}) readonly treeItem!: TemplateRef<TreeSlotItemContext>;\n\n\ttrackNode(index: number, node: NormalizedTreeItem) {\n\t\treturn node.label + node.level + index;\n\t}\n}\n\n/**\n * A constant representing the default slot for tree item.\n */\nexport const treeDefaultSlotItem: SlotContent<TreeSlotItemContext> = new ComponentTemplate(TreeDefaultItemSlotComponent, 'treeItem');\n\n/**\n * TreeComponent is an Angular component that extends the BaseWidgetDirective\n * to provide a customizable tree widget. This component allows for various\n * configurations and customizations through its inputs and outputs.\n */\n@Component({\n\tselector: '[auTree]',\n\tstandalone: true,\n\timports: [SlotDirective],\n\ttemplate: ` <ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\"></ng-template> `,\n})\nexport class TreeComponent extends BaseWidgetDirective<TreeWidget> {\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createTree,\n\t\t\t\twidgetName: 'tree',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: treeDefaultSlotStructure,\n\t\t\t\t\titem: treeDefaultSlotItem,\n\t\t\t\t\titemContent: treeDefaultSlotItemContent,\n\t\t\t\t\titemToggle: treeDefaultItemToggle,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonExpandToggle: (item: NormalizedTreeItem) => this.expandToggle.emit(item),\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\titem: this.slotItemFromContent?.templateRef,\n\t\t\t\t\titemContent: this.slotItemContentFromContent?.templateRef,\n\t\t\t\t\titemToggle: this.slotItemToggleFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t}),\n\t\t);\n\t}\n\t/**\n\t * Optional accessibility label for the tree if there is no explicit label\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\t/**\n\t * Array of the tree nodes to display\n\t *\n\t * @defaultValue `[]`\n\t */\n\t@Input('auNodes') nodes: TreeItem[] | undefined;\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\t/**\n\t * Retrieves expand items of the TreeItem\n\t *\n\t * @param node - HTML element that is representing the expand item\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (node: HTMLElement) => node.querySelectorAll('button')\n\t * ```\n\t */\n\t@Input('auNavSelector') navSelector: ((node: HTMLElement) => NodeListOf<HTMLButtonElement>) | undefined;\n\t/**\n\t * Return the value for the 'aria-label' attribute of the toggle\n\t * @param label - tree item label\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (label: string) => `Toggle ${label}`\n\t * ```\n\t */\n\t@Input('auAriaLabelToggleFn') ariaLabelToggleFn: ((label: string) => string) | undefined;\n\n\t/**\n\t * An event emitted when the user toggles the expand of the TreeItem.\n\t *\n\t * Event payload is equal to the TreeItem clicked.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auExpandToggle') expandToggle = new EventEmitter<TreeItem>();\n\n\t/**\n\t * Slot to change the default tree item content\n\t */\n\t@Input('auItemContent') item: SlotContent<TreeSlotItemContext>;\n\t@ContentChild(TreeItemContentDirective, {static: false}) slotItemContentFromContent: TreeItemContentDirective | undefined;\n\n\t/**\n\t * Slot to change the default display of the tree\n\t */\n\t@Input('auStructure') structure: SlotContent<TreeContext>;\n\t@ContentChild(TreeStructureDirective, {static: false}) slotStructureFromContent: TreeStructureDirective | undefined;\n\n\t/**\n\t * Slot to change the default tree item toggle\n\t */\n\t@Input('auToggle') toggle: SlotContent<TreeSlotItemContext>;\n\t@ContentChild(TreeItemToggleDirective, {static: false}) slotItemToggleFromContent: TreeItemToggleDirective | undefined;\n\n\t/**\n\t * Slot to change the default tree item\n\t */\n\t@Input('auItem') root: SlotContent<TreeSlotItemContext>;\n\t@ContentChild(TreeItemDirective, {static: false}) slotItemFromContent: TreeItemDirective | undefined;\n}\n"]}
449
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeComponent, { className: "TreeComponent", filePath: "components/tree/tree.component.ts", lineNumber: 191 }); })();
450
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../src/components/tree/tree.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,mBAAmB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,aAAa,EAAE,YAAY,EAAC,MAAM,4BAA4B,CAAC;AAClI,OAAO,EACN,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EACL,MAAM,EACN,WAAW,EACX,SAAS,GACT,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,UAAU,EAAC,MAAM,YAAY,CAAC;;;;;;IAuBjC,sHAA4F;;;;;;;IAAvD,AAAxB,wCAAuB,qFAAqD;;;IAF3F,6BAAiG;IAChG,+IAEC;IACF,iBAAK;;;;IAJW,+DAAuC;IAAC,yDAAwC;IAC/F,cAEC;IAFD,cAAA,0BAAuB,CAEtB;;;;;;IAsCD,iCAA2D;IAC1D,0BAA6C;IAC9C,iBAAS;;;;;IAFD,0HAAkD;;;IAI1D,0BAAqD;;;IADpD,AAJF,4GAAgC,6FAIvB;;;IAJT,qDAMC;;;;;IAgCD,+BAA2B;IAC1B,kHAA4F;IAC5F,YACD;IAAA,iBAAO;;;;;;IAFO,cAA6B;IAAC,AAA9B,8CAA6B,qFAA+C;IACzF,cACD;IADC,8CACD;;;;;;IAwCI,+HAA6F;;;;;;;IAAxD,AAAxB,wCAAuB,sFAAsD;;;IAF5F,6BAAiB;IAChB,wJAEC;IACF,iBAAK;;;IAHJ,cAEC;IAFD,+BAEC;;;IANJ,6BAA2D;IAE1D,AADA,2GAA6F,qFACxD;IAOtC,iBAAK;;;;;;IATD,8HAAsD;IAC5C,cAA8B;IAAC,AAA/B,+CAA8B,qFAA+C;IAC1F,cAMC;IAND,8DAMC;;;;;AA/IL;;;;GAIG;AAEH,MAAM,OAAO,sBAAsB;IADnC;QAEQ,gBAAW,GAAG,MAAM,CAAC,CAAA,WAAwB,CAAA,CAAC,CAAC;KAItD;IAHA,MAAM,CAAC,sBAAsB,CAAC,IAA4B,EAAE,OAAgB;QAC3E,OAAO,IAAI,CAAC;IACb,CAAC;uHAJW,sBAAsB;oEAAtB,sBAAsB;;iFAAtB,sBAAsB;cADlC,SAAS;eAAC,EAAC,QAAQ,EAAE,8BAA8B,EAAE,UAAU,EAAE,IAAI,EAAC;;AAQvE,MAcM,iCAAiC;IAGtC,SAAS,CAAC,KAAa,EAAE,IAAwB;QAChD,OAAO,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACxC,CAAC;kIALI,iCAAiC;oEAAjC,iCAAiC;;;;;;YATrC,gIAAoG;4BAF3F,YAAY,EAVV,sBAAsB,EAUc,aAAa;;iFAWxD,iCAAiC;cAdtC,SAAS;eAAC;gBACV,UAAU,EAAE,IAAI;gBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,OAAO,EAAE,CAAC,YAAY,EAAE,sBAAsB,EAAE,aAAa,CAAC;gBAC9D,QAAQ,EAAE;;;;;;;;EAQT;aACD;gBAEiD,SAAS;kBAAzD,SAAS;mBAAC,WAAW,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;;kFADjC,iCAAiC;AAQvC;;GAEG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAA6B,IAAI,iBAAiB,CAAC,iCAAiC,EAAE,WAAW,CAAC,CAAC;AAExI;;;;GAIG;AAEH,MAAM,OAAO,uBAAuB;IADpC;QAEQ,gBAAW,GAAG,MAAM,CAAC,CAAA,WAAgC,CAAA,CAAC,CAAC;KAI9D;IAHA,MAAM,CAAC,sBAAsB,CAAC,IAA6B,EAAE,OAAgB;QAC5E,OAAO,IAAI,CAAC;IACb,CAAC;wHAJW,uBAAuB;oEAAvB,uBAAuB;;iFAAvB,uBAAuB;cADnC,SAAS;eAAC,EAAC,QAAQ,EAAE,+BAA+B,EAAE,UAAU,EAAE,IAAI,EAAC;;AAQxE,MAgBM,kCAAkC;mIAAlC,kCAAkC;oEAAlC,kCAAkC;;;;;;YAXtC,iIAAkF;4BAFzE,YAAY,EAVV,uBAAuB;;iFAuB9B,kCAAkC;cAhBvC,SAAS;eAAC;gBACV,UAAU,EAAE,IAAI;gBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,OAAO,EAAE,CAAC,YAAY,EAAE,uBAAuB,CAAC;gBAChD,QAAQ,EAAE;;;;;;;;;;EAUT;aACD;gBAE8C,MAAM;kBAAnD,SAAS;mBAAC,QAAQ,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;;kFAD9B,kCAAkC;AAIxC;;GAEG;AACH,MAAM,CAAC,MAAM,qBAAqB,GAAqC,IAAI,iBAAiB,CAAC,kCAAkC,EAAE,QAAQ,CAAC,CAAC;AAE3I;;;;GAIG;AAEH,MAAM,OAAO,wBAAwB;IADrC;QAEQ,gBAAW,GAAG,MAAM,CAAC,CAAA,WAAgC,CAAA,CAAC,CAAC;KAI9D;IAHA,MAAM,CAAC,sBAAsB,CAAC,IAA8B,EAAE,OAAgB;QAC7E,OAAO,IAAI,CAAC;IACb,CAAC;yHAJW,wBAAwB;oEAAxB,wBAAwB;;iFAAxB,wBAAwB;cADpC,SAAS;eAAC,EAAC,QAAQ,EAAE,gCAAgC,EAAE,UAAU,EAAE,IAAI,EAAC;;AAQzE,MAaM,mCAAmC;oIAAnC,mCAAmC;oEAAnC,mCAAmC;;;;;;YARvC,kIAAqH;4BAF9F,aAAa;;iFAUhC,mCAAmC;cAbxC,SAAS;eAAC;gBACV,UAAU,EAAE,IAAI;gBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,OAAO,EAAE,CAAC,YAAY,EAAE,aAAa,EAAE,wBAAwB,CAAC;gBAChE,QAAQ,EAAE;;;;;;;EAOT;aACD;gBAEuD,eAAe;kBAArE,SAAS;mBAAC,iBAAiB,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;;kFADvC,mCAAmC;AAIzC;;GAEG;AACH,MAAM,CAAC,MAAM,0BAA0B,GAAqC,IAAI,iBAAiB,CAChG,mCAAmC,EACnC,iBAAiB,CACjB,CAAC;AAEF;;;;GAIG;AAEH,MAAM,OAAO,iBAAiB;IAD9B;QAEQ,gBAAW,GAAG,MAAM,CAAC,CAAA,WAAgC,CAAA,CAAC,CAAC;KAI9D;IAHA,MAAM,CAAC,sBAAsB,CAAC,IAAuB,EAAE,OAAgB;QACtE,OAAO,IAAI,CAAC;IACb,CAAC;kHAJW,iBAAiB;oEAAjB,iBAAiB;;iFAAjB,iBAAiB;cAD7B,SAAS;eAAC,EAAC,QAAQ,EAAE,yBAAyB,EAAE,UAAU,EAAE,IAAI,EAAC;;AAQlE,MAmBM,4BAA4B;IAGjC,SAAS,CAAC,KAAa,EAAE,IAAwB;QAChD,OAAO,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACxC,CAAC;6HALI,4BAA4B;oEAA5B,4BAA4B;;;;;;YAdhC,4HAA8G;4BAFrG,YAAY,EAAE,aAAa,EAVzB,iBAAiB;;iFA0BxB,4BAA4B;cAnBjC,SAAS;eAAC;gBACV,UAAU,EAAE,IAAI;gBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,OAAO,EAAE,CAAC,YAAY,EAAE,aAAa,EAAE,iBAAiB,CAAC;gBACzD,QAAQ,EAAE;;;;;;;;;;;;;EAaT;aACD;gBAEgD,QAAQ;kBAAvD,SAAS;mBAAC,UAAU,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;;kFADhC,4BAA4B;AAQlC;;GAEG;AACH,MAAM,CAAC,MAAM,mBAAmB,GAAqC,IAAI,iBAAiB,CAAC,4BAA4B,EAAE,UAAU,CAAC,CAAC;AAErI;;;;GAIG;AAQH,MAAM,OAAO,aAAc,SAAQ,mBAA+B;IACjE;QACC,KAAK,CACJ,iBAAiB,CAAC;YACjB,OAAO,EAAE,UAAU;YACnB,UAAU,EAAE,MAAM;YAClB,aAAa,EAAE;gBACd,SAAS,EAAE,wBAAwB;gBACnC,IAAI,EAAE,mBAAmB;gBACzB,WAAW,EAAE,0BAA0B;gBACvC,UAAU,EAAE,qBAAqB;aACjC;YACD,MAAM,EAAE;gBACP,cAAc,EAAE,CAAC,IAAwB,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;aAC1E;YACD,aAAa,EAAE,GAAG,EAAE,CAAC,CAAC;gBACrB,SAAS,EAAE,IAAI,CAAC,wBAAwB,EAAE,WAAW;gBACrD,IAAI,EAAE,IAAI,CAAC,mBAAmB,EAAE,WAAW;gBAC3C,WAAW,EAAE,IAAI,CAAC,0BAA0B,EAAE,WAAW;gBACzD,UAAU,EAAE,IAAI,CAAC,yBAAyB,EAAE,WAAW;aACvD,CAAC;SACF,CAAC,CACF,CAAC;QA0CH;;;;;;;;;WASG;QACuB,iBAAY,GAAG,IAAI,YAAY,EAAsB,CAAC;IAnDhF,CAAC;8GAvBW,aAAa;oEAAb,aAAa;wCAgFX,wBAAwB;wCAMxB,sBAAsB;wCAMtB,uBAAuB;wCAMvB,iBAAiB;;;;;;;;YApGnB,8EAAqF;;YAA3C,AAA7B,8CAA4B,+EAAyC;4BADpF,aAAa;;iFAGX,aAAa;cAPzB,SAAS;eAAC;gBACV,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,QAAQ,EAAE,UAAU;gBACpB,UAAU,EAAE,IAAI;gBAChB,OAAO,EAAE,CAAC,aAAa,CAAC;gBACxB,QAAQ,EAAE,yFAAyF;aACnG;oBA8BsB,SAAS;kBAA9B,KAAK;mBAAC,aAAa;YAMF,KAAK;kBAAtB,KAAK;mBAAC,SAAS;YAMM,SAAS;kBAA9B,KAAK;mBAAC,aAAa;YAWI,WAAW;kBAAlC,KAAK;mBAAC,eAAe;YAUQ,iBAAiB;kBAA9C,KAAK;mBAAC,qBAAqB;YAYF,YAAY;kBAArC,MAAM;mBAAC,gBAAgB;YAKA,IAAI;kBAA3B,KAAK;mBAAC,eAAe;YACmC,0BAA0B;kBAAlF,YAAY;mBAAC,wBAAwB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;YAKjC,SAAS;kBAA9B,KAAK;mBAAC,aAAa;YACmC,wBAAwB;kBAA9E,YAAY;mBAAC,sBAAsB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;YAKlC,MAAM;kBAAxB,KAAK;mBAAC,UAAU;YACuC,yBAAyB;kBAAhF,YAAY;mBAAC,uBAAuB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;YAKrC,IAAI;kBAApB,KAAK;mBAAC,QAAQ;YACmC,mBAAmB;kBAApE,YAAY;mBAAC,iBAAiB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;;kFAlGpC,aAAa","sourcesContent":["import type {SlotContent} from '@agnos-ui/angular-headless';\nimport {BaseWidgetDirective, callWidgetFactory, ComponentTemplate, SlotDirective, UseDirective} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tinject,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n} from '@angular/core';\nimport type {TreeContext, TreeItem, NormalizedTreeItem, TreeSlotItemContext, TreeWidget} from './tree.gen';\nimport {createTree} from './tree.gen';\n\n/**\n * Directive to provide a template reference for tree structure.\n *\n * This directive uses a template reference to render the {@link TreeContext}.\n */\n@Directive({selector: 'ng-template[auTreeStructure]', standalone: true})\nexport class TreeStructureDirective {\n\tpublic templateRef = inject(TemplateRef<TreeContext>);\n\tstatic ngTemplateContextGuard(_dir: TreeStructureDirective, context: unknown): context is TreeContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, TreeStructureDirective, SlotDirective],\n\ttemplate: `\n\t\t<ng-template auTreeStructure #structure let-state=\"state\" let-directives=\"directives\" let-api=\"api\">\n\t\t\t<ul role=\"tree\" class=\"au-tree {{ state.className() }}\" [auUse]=\"directives.navigationDirective\">\n\t\t\t\t@for (node of state.normalizedNodes(); track trackNode($index, node)) {\n\t\t\t\t\t<ng-template [auSlot]=\"state.item()\" [auSlotProps]=\"{state, api, directives, item: node}\" />\n\t\t\t\t}\n\t\t\t</ul>\n\t\t</ng-template>\n\t`,\n})\nclass TreeDefaultStructureSlotComponent {\n\t@ViewChild('structure', {static: true}) readonly structure!: TemplateRef<TreeContext>;\n\n\ttrackNode(index: number, node: NormalizedTreeItem): string {\n\t\treturn node.label + node.level + index;\n\t}\n}\n\n/**\n * A constant representing the default slot for tree structure.\n */\nexport const treeDefaultSlotStructure: SlotContent<TreeContext> = new ComponentTemplate(TreeDefaultStructureSlotComponent, 'structure');\n\n/**\n * Directive to provide a template reference for tree item toggle.\n *\n * This directive uses a template reference to render the {@link TreeSlotItemContext}.\n */\n@Directive({selector: 'ng-template[auTreeItemToggle]', standalone: true})\nexport class TreeItemToggleDirective {\n\tpublic templateRef = inject(TemplateRef<TreeSlotItemContext>);\n\tstatic ngTemplateContextGuard(_dir: TreeItemToggleDirective, context: unknown): context is TreeSlotItemContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, TreeItemToggleDirective],\n\ttemplate: `\n\t\t<ng-template auTreeItemToggle #toggle let-directives=\"directives\" let-item=\"item\">\n\t\t\t@if (item.children.length > 0) {\n\t\t\t\t<button [auUse]=\"[directives.itemToggleDirective, {item}]\">\n\t\t\t\t\t<span class=\"au-tree-expand-icon-svg\"></span>\n\t\t\t\t</button>\n\t\t\t} @else {\n\t\t\t\t<span class=\"au-tree-expand-icon-placeholder\"></span>\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nclass TreeDefaultItemToggleSlotComponent {\n\t@ViewChild('toggle', {static: true}) readonly toggle!: TemplateRef<TreeSlotItemContext>;\n}\n\n/**\n * A constant representing the default slot for tree item toggle.\n */\nexport const treeDefaultItemToggle: SlotContent<TreeSlotItemContext> = new ComponentTemplate(TreeDefaultItemToggleSlotComponent, 'toggle');\n\n/**\n * Directive to provide a template reference for tree item content.\n *\n * This directive uses a template reference to render the {@link TreeSlotItemContext}.\n */\n@Directive({selector: 'ng-template[auTreeItemContent]', standalone: true})\nexport class TreeItemContentDirective {\n\tpublic templateRef = inject(TemplateRef<TreeSlotItemContext>);\n\tstatic ngTemplateContextGuard(_dir: TreeItemContentDirective, context: unknown): context is TreeSlotItemContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SlotDirective, TreeItemContentDirective],\n\ttemplate: `\n\t\t<ng-template auTreeItem #treeItemContent let-state=\"state\" let-directives=\"directives\" let-item=\"item\" let-api=\"api\">\n\t\t\t<span class=\"au-tree-item\">\n\t\t\t\t<ng-template [auSlot]=\"state.itemToggle()\" [auSlotProps]=\"{state, api, directives, item}\" />\n\t\t\t\t{{ item.label }}\n\t\t\t</span>\n\t\t</ng-template>\n\t`,\n})\nclass TreeDefaultItemContentSlotComponent {\n\t@ViewChild('treeItemContent', {static: true}) readonly treeItemContent!: TemplateRef<TreeSlotItemContext>;\n}\n\n/**\n * A constant representing the default slot for tree item.\n */\nexport const treeDefaultSlotItemContent: SlotContent<TreeSlotItemContext> = new ComponentTemplate(\n\tTreeDefaultItemContentSlotComponent,\n\t'treeItemContent',\n);\n\n/**\n * Directive to provide a template reference for tree item.\n *\n * This directive uses a template reference to render the {@link TreeSlotItemContext}.\n */\n@Directive({selector: 'ng-template[auTreeItem]', standalone: true})\nexport class TreeItemDirective {\n\tpublic templateRef = inject(TemplateRef<TreeSlotItemContext>);\n\tstatic ngTemplateContextGuard(_dir: TreeItemDirective, context: unknown): context is TreeSlotItemContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SlotDirective, TreeItemDirective],\n\ttemplate: `\n\t\t<ng-template auTreeItem #treeItem let-state=\"state\" let-directives=\"directives\" let-item=\"item\" let-api=\"api\">\n\t\t\t<li [auUse]=\"[directives.itemAttributesDirective, {item}]\">\n\t\t\t\t<ng-template [auSlot]=\"state.itemContent()\" [auSlotProps]=\"{state, api, directives, item}\" />\n\t\t\t\t@if (state.expandedMap().get(item)) {\n\t\t\t\t\t<ul role=\"group\">\n\t\t\t\t\t\t@for (child of item.children; track trackNode($index, child)) {\n\t\t\t\t\t\t\t<ng-template [auSlot]=\"state.item()\" [auSlotProps]=\"{state, api, directives, item: child}\" />\n\t\t\t\t\t\t}\n\t\t\t\t\t</ul>\n\t\t\t\t}\n\t\t\t</li>\n\t\t</ng-template>\n\t`,\n})\nclass TreeDefaultItemSlotComponent {\n\t@ViewChild('treeItem', {static: true}) readonly treeItem!: TemplateRef<TreeSlotItemContext>;\n\n\ttrackNode(index: number, node: NormalizedTreeItem) {\n\t\treturn node.label + node.level + index;\n\t}\n}\n\n/**\n * A constant representing the default slot for tree item.\n */\nexport const treeDefaultSlotItem: SlotContent<TreeSlotItemContext> = new ComponentTemplate(TreeDefaultItemSlotComponent, 'treeItem');\n\n/**\n * TreeComponent is an Angular component that extends the BaseWidgetDirective\n * to provide a customizable tree widget. This component allows for various\n * configurations and customizations through its inputs and outputs.\n */\n@Component({\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tselector: '[auTree]',\n\tstandalone: true,\n\timports: [SlotDirective],\n\ttemplate: ` <ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\" /> `,\n})\nexport class TreeComponent extends BaseWidgetDirective<TreeWidget> {\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createTree,\n\t\t\t\twidgetName: 'tree',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: treeDefaultSlotStructure,\n\t\t\t\t\titem: treeDefaultSlotItem,\n\t\t\t\t\titemContent: treeDefaultSlotItemContent,\n\t\t\t\t\titemToggle: treeDefaultItemToggle,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonExpandToggle: (item: NormalizedTreeItem) => this.expandToggle.emit(item),\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\titem: this.slotItemFromContent?.templateRef,\n\t\t\t\t\titemContent: this.slotItemContentFromContent?.templateRef,\n\t\t\t\t\titemToggle: this.slotItemToggleFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t}),\n\t\t);\n\t}\n\t/**\n\t * Optional accessibility label for the tree if there is no explicit label\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\t/**\n\t * Array of the tree nodes to display\n\t *\n\t * @defaultValue `[]`\n\t */\n\t@Input('auNodes') nodes: TreeItem[] | undefined;\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\t/**\n\t * Retrieves expand items of the TreeItem\n\t *\n\t * @param node - HTML element that is representing the expand item\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (node: HTMLElement) => node.querySelectorAll('button')\n\t * ```\n\t */\n\t@Input('auNavSelector') navSelector: ((node: HTMLElement) => NodeListOf<HTMLButtonElement>) | undefined;\n\t/**\n\t * Return the value for the 'aria-label' attribute of the toggle\n\t * @param label - tree item label\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (label: string) => `Toggle ${label}`\n\t * ```\n\t */\n\t@Input('auAriaLabelToggleFn') ariaLabelToggleFn: ((label: string) => string) | undefined;\n\n\t/**\n\t * An event emitted when the user toggles the expand of the TreeItem.\n\t *\n\t * Event payload is equal to the TreeItem clicked.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auExpandToggle') expandToggle = new EventEmitter<NormalizedTreeItem>();\n\n\t/**\n\t * Slot to change the default tree item content\n\t */\n\t@Input('auItemContent') item: SlotContent<TreeSlotItemContext>;\n\t@ContentChild(TreeItemContentDirective, {static: false}) slotItemContentFromContent: TreeItemContentDirective | undefined;\n\n\t/**\n\t * Slot to change the default display of the tree\n\t */\n\t@Input('auStructure') structure: SlotContent<TreeContext>;\n\t@ContentChild(TreeStructureDirective, {static: false}) slotStructureFromContent: TreeStructureDirective | undefined;\n\n\t/**\n\t * Slot to change the default tree item toggle\n\t */\n\t@Input('auToggle') toggle: SlotContent<TreeSlotItemContext>;\n\t@ContentChild(TreeItemToggleDirective, {static: false}) slotItemToggleFromContent: TreeItemToggleDirective | undefined;\n\n\t/**\n\t * Slot to change the default tree item\n\t */\n\t@Input('auItem') root: SlotContent<TreeSlotItemContext>;\n\t@ContentChild(TreeItemDirective, {static: false}) slotItemFromContent: TreeItemDirective | undefined;\n}\n"]}