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

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.
@@ -12,4 +12,4 @@ export { export_getSelectDefaultConfig as getSelectDefaultConfig };
12
12
  */
13
13
  const export_createSelect = createSelect;
14
14
  export { export_createSelect as createSelect };
15
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.gen.js","sourceRoot":"","sources":["../../../../src/components/select/select.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAE,YAAY,EAAC,MAAM,4CAA4C,CAAC;AAMhG;;;GAGG;AACH,MAAM,6BAA6B,GAA2B,sBAA6B,CAAC;AAC5F,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC;AAmXjE;;;;GAIG;AACH,MAAM,mBAAmB,GAA0E,YAAmB,CAAC;AACvH,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getSelectDefaultConfig, createSelect} from '@agnos-ui/core-bootstrap/components/select';\nimport type {WidgetSlotContext, SlotContent, Widget, PropsConfig, HasFocus, FloatingUI, Directive} from '@agnos-ui/angular-headless';\nimport type {Placement} from '@floating-ui/dom';\n\n\n\n/**\n * Retrieve a shallow copy of the default Select config\n * @returns the default Select config\n */\nconst export_getSelectDefaultConfig: () => SelectProps<any> = getSelectDefaultConfig as any;\nexport {export_getSelectDefaultConfig as getSelectDefaultConfig};\n\n\n\n/**\n * Interface for the slot context of the pagination widget\n * @template Item - The type of the items in the Select component.\n */\nexport interface SelectContext<Item> extends WidgetSlotContext<SelectWidget<Item>> {}\n\n\n\n/**\n * Represents the context for a select item, extending the base `SelectContext` with additional\n * contextual data specific to an item.\n *\n * @template Item - The type of the item within the select context.\n */\nexport interface SelectItemContext<Item> extends SelectContext<Item> {\n\t/**\n\t * Contextual data related to an item\n\t */\n\titemContext: ItemContext<Item>;\n}\n\n/**\n * Represents the state of a Select component.\n *\n * @template Item - The type of the items in the select component.\n */\nexport interface SelectState<Item> {\n\t\n\t/**\n\t * List of item contexts, to be displayed in the menu\n\t */\n\tvisibleItems: ItemContext<Item>[];\n\t\n\n\t/**\n\t * List of selected items to be display\n\t */\n\tselectedContexts: ItemContext<Item>[];\n\t\n\n\t/**\n\t * Highlighted item context.\n\t * It is designed to define the highlighted item in the dropdown menu\n\t */\n\thighlighted: ItemContext<Item> | undefined;\n\t\n\n\t/**\n\t * Current placement of the dropdown\n\t */\n\tplacement: Placement | undefined;\n\t\n\t/**\n\t * id used for the input inside the select\n\t */\n\tid: string | undefined;\n\t\n\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'Select'`\n\t */\n\tariaLabel: string | undefined;\n\t\n\n\t/**\n\t * List of selected item ids\n\t *\n\t * @defaultValue `[]`\n\t */\n\tselected: Item[];\n\t\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t *\n\t * @defaultValue `''`\n\t */\n\tfilterText: string;\n\t\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\n\t */\n\topen: boolean;\n\t\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuClassName: string;\n\t\n\n\t/**\n\t * Class to be added on menu items\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuItemClassName: string;\n\t\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t *\n\t * @defaultValue `''`\n\t */\n\tbadgeClassName: string;\n\t\n\n\t/**\n\t * true if a loading process is being done\n\t *\n\t * @defaultValue `false`\n\t */\n\tloading: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\tbadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\titemLabel: SlotContent<SelectItemContext<Item>>;\n}\n\n/**\n * Represents the properties for the Select component.\n *\n * @template Item - The type of the items in the select component.\n */\nexport interface SelectProps<Item> {\n\t\n\t/**\n\t * List of available items for the dropdown\n\t *\n\t * @defaultValue `[]`\n\t */\n\titems: Item[];\n\t\n\n\t/**\n\t * List of allowed placements for the dropdown.\n\t * This refers to the [allowedPlacements from floating UI](https://floating-ui.com/docs/autoPlacement#allowedplacements), given the different [Placement possibilities](https://floating-ui.com/docs/computePosition#placement).\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ['bottom-start', 'top-start', 'bottom-end', 'top-end']\n\t * ```\n\t */\n\tallowedPlacements: Placement[];\n\t\n\n\t/**\n\t * Custom function to get the id of an item\n\t * By default, the item is returned\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (item: any) => '' + item\n\t * ```\n\t */\n\titemIdFn(item: Item): string;\n\t\n\n\t/**\n\t * Retrieves navigable elements within an HTML element containing badges and the input.\n\t *\n\t * @param node - HTMLElement that contains the badges and the input\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (node: HTMLElement) => node.querySelectorAll('.au-select-badge,input')\n\t * ```\n\t */\n\tnavSelector(node: HTMLElement): NodeListOf<HTMLSpanElement | HTMLInputElement>;\n\t\n\n\t// Event callbacks\n\n\t/**\n\t * Callback called dropdown open state change\n\t * @param isOpen - updated open state\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonOpenChange(isOpen: boolean): void;\n\t\n\n\t/**\n\t * Callback called when the text filter change\n\t * @param text - Filtered text\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonFilterTextChange(text: string): void;\n\t\n\n\t/**\n\t * Callback called when the selection change\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonSelectedChange(selected: Item[]): void;\n\t\n\t/**\n\t * id used for the input inside the select\n\t */\n\tid: string | undefined;\n\t\n\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'Select'`\n\t */\n\tariaLabel: string | undefined;\n\t\n\n\t/**\n\t * List of selected item ids\n\t *\n\t * @defaultValue `[]`\n\t */\n\tselected: Item[];\n\t\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t *\n\t * @defaultValue `''`\n\t */\n\tfilterText: string;\n\t\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\n\t */\n\topen: boolean;\n\t\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuClassName: string;\n\t\n\n\t/**\n\t * Class to be added on menu items\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuItemClassName: string;\n\t\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t *\n\t * @defaultValue `''`\n\t */\n\tbadgeClassName: string;\n\t\n\n\t/**\n\t * true if a loading process is being done\n\t *\n\t * @defaultValue `false`\n\t */\n\tloading: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\tbadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\titemLabel: SlotContent<SelectItemContext<Item>>;\n}\n\n\n\n/**\n * Represents a Select widget component.\n *\n * @template Item - The type of the items that the select widget will handle.\n */\nexport type SelectWidget<Item> = Widget<SelectProps<Item>, SelectState<Item>, SelectApi<Item>, SelectDirectives<Item>>;\n\n\n\n/**\n * Creates a new select widget instance.\n * @param config - config of the modal, either as a store or as an object containing values or stores.\n * @returns a new select widget instance\n */\nconst export_createSelect: <Item>(config?: PropsConfig<SelectProps<Item>>) => SelectWidget<Item> = createSelect as any;\nexport {export_createSelect as createSelect};\n\n\n\n/**\n * Item representation built from the items provided in parameters\n */\nexport interface ItemContext<T> {\n\t/**\n\t * Original item given in the parameters\n\t */\n\titem: T;\n\n\t/**\n\t * Unique id to identify the item\n\t */\n\tid: string;\n\n\t/**\n\t * Specify if the item is checked\n\t */\n\tselected: boolean;\n}\n\n/**\n * Interface representing the API for a Select component.\n */\nexport interface SelectApi<Item> {\n\t\n\t/**\n\t * Clear all the selected items\n\t */\n\tclear(): void;\n\t\n\n\t/**\n\t * Clear the filter text\n\t */\n\tclearText(): void;\n\t\n\n\t/**\n\t * Highlight the given item, if there is a corresponding match among the visible list\n\t */\n\thighlight(item: Item): void;\n\t\n\n\t/**\n\t * Highlight the first item among the visible list\n\t */\n\thighlightFirst(): void;\n\t\n\n\t/**\n\t * Highlight the previous item among the visible list\n\t * Loop to the last item if needed\n\t */\n\thighlightPrevious(): void;\n\t\n\n\t/**\n\t * Highlight the next item among the visible list.\n\t * Loop to the first item if needed\n\t */\n\thighlightNext(): void;\n\t\n\n\t/**\n\t * Highlight the last item among the visible list\n\t */\n\thighlightLast(): void;\n\t\n\n\t/**\n\t * Select the provided item.\n\t * The selected list is used to\n\t * @param item - the item to select\n\t */\n\tselect(item: Item): void;\n\t\n\t/**\n\t * Unselect the provided item.\n\t * @param item - the item to unselect\n\t */\n\tunselect(item: Item): void;\n\t\n\t/**\n\t * Toggle the selection of an item\n\t * @param item - the item to toggle\n\t * @param selected - an optional boolean to enforce the selected/unselected state instead of toggling\n\t */\n\ttoggleItem(item: Item, selected?: boolean): void;\n\t\n\n\t/**\n\t * open the select\n\t */\n\topen(): void;\n\t\n\t/**\n\t * close the select\n\t */\n\tclose(): void;\n\t\n\t/**\n\t * Toggle the dropdown menu\n\t * @param isOpen - If specified, set the menu in the defined state.\n\t */\n\ttoggle(isOpen?: boolean): void;\n}\n\n/**\n * Interface representing the directives used in the Select component.\n */\nexport interface SelectDirectives<Item> {\n\t\n\t/**\n\t * Directive to be used in the input group and the menu containers\n\t */\n\thasFocusDirective: HasFocus['directive'];\n\t\n\n\t/**\n\t * Directive that enables dynamic positioning of menu element\n\t */\n\tfloatingDirective: FloatingUI['directives']['floatingDirective'];\n\t\n\n\t/**\n\t * A directive to be applied to the input group element serves as the base for menu positioning\n\t */\n\treferenceDirective: FloatingUI['directives']['referenceDirective'];\n\t\n\n\t/**\n\t * A directive to be applied to the element that contains the badges and the input\n\t */\n\tinputContainerDirective: Directive;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the container badges\n\t */\n\tbadgeAttributesDirective: Directive<ItemContext<Item>>;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the dropdown menu\n\t */\n\tmenuAttributesDirective: Directive;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the dropdown item\n\t */\n\titemAttributesDirective: Directive<ItemContext<Item>>;\n\t\n\n\t/**\n\t * A directive to be applied to the input\n\t */\n\tinputDirective: Directive;\n\t\n\t/**\n\t * A directive to be applied to a button that closes a badge\n\t */\n\tbadgeCloseButtonDirective: Directive<ItemContext<Item>>;\n}\n\n"]}
15
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.gen.js","sourceRoot":"","sources":["../../../../src/components/select/select.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAE,YAAY,EAAC,MAAM,4CAA4C,CAAC;AAMhG;;;GAGG;AACH,MAAM,6BAA6B,GAA2B,sBAA6B,CAAC;AAC5F,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC;AAmXjE;;;;GAIG;AACH,MAAM,mBAAmB,GAA0E,YAAmB,CAAC;AACvH,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getSelectDefaultConfig, createSelect} from '@agnos-ui/core-bootstrap/components/select';\nimport type {WidgetSlotContext, SlotContent, Widget, PropsConfig, HasFocus, FloatingUI, Directive} from '@agnos-ui/angular-headless';\nimport type {Placement} from '@floating-ui/dom';\n\n\n\n/**\n * Retrieve a shallow copy of the default Select config\n * @returns the default Select config\n */\nconst export_getSelectDefaultConfig: () => SelectProps<any> = getSelectDefaultConfig as any;\nexport {export_getSelectDefaultConfig as getSelectDefaultConfig};\n\n\n\n/**\n * Interface for the slot context of the pagination widget\n * @template Item - The type of the items in the Select component.\n */\nexport interface SelectContext<Item> extends WidgetSlotContext<SelectWidget<Item>> {}\n\n\n\n/**\n * Represents the context for a select item, extending the base `SelectContext` with additional\n * contextual data specific to an item.\n *\n * @template Item - The type of the item within the select context.\n */\nexport interface SelectItemContext<Item> extends SelectContext<Item> {\n\t/**\n\t * Contextual data related to an item\n\t */\n\titemContext: ItemContext<Item>;\n}\n\n/**\n * Represents the state of a Select component.\n *\n * @template Item - The type of the items in the select component.\n */\nexport interface SelectState<Item> {\n\t\n\t/**\n\t * List of item contexts, to be displayed in the menu\n\t */\n\tvisibleItems: ItemContext<Item>[];\n\t\n\n\t/**\n\t * List of selected items to be display\n\t */\n\tselectedContexts: ItemContext<Item>[];\n\t\n\n\t/**\n\t * Highlighted item context.\n\t * It is designed to define the highlighted item in the dropdown menu\n\t */\n\thighlighted: ItemContext<Item> | undefined;\n\t\n\n\t/**\n\t * Current placement of the dropdown\n\t */\n\tplacement: Placement | undefined;\n\t\n\t/**\n\t * id used for the input inside the select\n\t */\n\tid: string | undefined;\n\t\n\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'Select'`\n\t */\n\tariaLabel: string | undefined;\n\t\n\n\t/**\n\t * List of selected item ids\n\t *\n\t * @defaultValue `[]`\n\t */\n\tselected: Item[];\n\t\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t *\n\t * @defaultValue `''`\n\t */\n\tfilterText: string;\n\t\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\n\t */\n\topen: boolean;\n\t\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuClassName: string;\n\t\n\n\t/**\n\t * Class to be added on menu items\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuItemClassName: string;\n\t\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t *\n\t * @defaultValue `''`\n\t */\n\tbadgeClassName: string;\n\t\n\n\t/**\n\t * true if a loading process is being done\n\t *\n\t * @defaultValue `false`\n\t */\n\tloading: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\tbadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\titemLabel: SlotContent<SelectItemContext<Item>>;\n}\n\n/**\n * Represents the properties for the Select component.\n *\n * @template Item - The type of the items in the select component.\n */\nexport interface SelectProps<Item> {\n\t\n\t/**\n\t * List of available items for the dropdown\n\t *\n\t * @defaultValue `[]`\n\t */\n\titems: Item[];\n\t\n\n\t/**\n\t * List of allowed placements for the dropdown.\n\t * This refers to the [allowedPlacements from floating UI](https://floating-ui.com/docs/autoPlacement#allowedplacements), given the different [Placement possibilities](https://floating-ui.com/docs/computePosition#placement).\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ['bottom-start', 'top-start', 'bottom-end', 'top-end']\n\t * ```\n\t */\n\tallowedPlacements: Placement[];\n\t\n\n\t/**\n\t * Custom function to get the id of an item\n\t * By default, the item is returned\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (item: any) => '' + item\n\t * ```\n\t */\n\titemIdFn(item: Item): string;\n\t\n\n\t/**\n\t * Retrieves navigable elements within an HTML element containing badges and the input.\n\t *\n\t * @param node - HTMLElement that contains the badges and the input\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (node: HTMLElement) => node.querySelectorAll('.au-select-badge,input')\n\t * ```\n\t */\n\tnavSelector(node: HTMLElement): NodeListOf<HTMLSpanElement | HTMLInputElement>;\n\t\n\n\t// Event callbacks\n\n\t/**\n\t * Callback called dropdown open state change\n\t * @param isOpen - updated open state\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonOpenChange(isOpen: boolean): void;\n\t\n\n\t/**\n\t * Callback called when the text filter change\n\t * @param text - Filtered text\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonFilterTextChange(text: string): void;\n\t\n\n\t/**\n\t * Callback called when the selection change\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonSelectedChange(selected: Item[]): void;\n\t\n\t/**\n\t * id used for the input inside the select\n\t */\n\tid: string | undefined;\n\t\n\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'Select'`\n\t */\n\tariaLabel: string | undefined;\n\t\n\n\t/**\n\t * List of selected item ids\n\t *\n\t * @defaultValue `[]`\n\t */\n\tselected: Item[];\n\t\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t *\n\t * @defaultValue `''`\n\t */\n\tfilterText: string;\n\t\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\n\t */\n\topen: boolean;\n\t\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuClassName: string;\n\t\n\n\t/**\n\t * Class to be added on menu items\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuItemClassName: string;\n\t\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t *\n\t * @defaultValue `''`\n\t */\n\tbadgeClassName: string;\n\t\n\n\t/**\n\t * true if a loading process is being done\n\t *\n\t * @defaultValue `false`\n\t */\n\tloading: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\tbadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\titemLabel: SlotContent<SelectItemContext<Item>>;\n}\n\n\n\n/**\n * Represents a Select widget component.\n *\n * @template Item - The type of the items that the select widget will handle.\n */\nexport type SelectWidget<Item> = Widget<SelectProps<Item>, SelectState<Item>, SelectApi<Item>, SelectDirectives<Item>>;\n\n\n\n/**\n * Creates a new select widget instance.\n * @param config - config of the modal, either as a store or as an object containing values or stores.\n * @returns a new select widget instance\n */\nconst export_createSelect: <Item>(config?: PropsConfig<SelectProps<Item>>) => SelectWidget<Item> = createSelect as any;\nexport {export_createSelect as createSelect};\n\n\n\n/**\n * Item representation built from the items provided in parameters\n *\n * @template T - The type of the Select Items\n */\nexport interface ItemContext<T> {\n\t/**\n\t * Original item given in the parameters\n\t */\n\titem: T;\n\n\t/**\n\t * Unique id to identify the item\n\t */\n\tid: string;\n\n\t/**\n\t * Specify if the item is checked\n\t */\n\tselected: boolean;\n}\n\n/**\n * Interface representing the API for a Select component.\n *\n * @template Item - The type of the Select Items\n */\nexport interface SelectApi<Item> {\n\t\n\t/**\n\t * Clear all the selected items\n\t */\n\tclear(): void;\n\t\n\n\t/**\n\t * Clear the filter text\n\t */\n\tclearText(): void;\n\t\n\n\t/**\n\t * Highlight the given item, if there is a corresponding match among the visible list\n\t */\n\thighlight(item: Item): void;\n\t\n\n\t/**\n\t * Highlight the first item among the visible list\n\t */\n\thighlightFirst(): void;\n\t\n\n\t/**\n\t * Highlight the previous item among the visible list\n\t * Loop to the last item if needed\n\t */\n\thighlightPrevious(): void;\n\t\n\n\t/**\n\t * Highlight the next item among the visible list.\n\t * Loop to the first item if needed\n\t */\n\thighlightNext(): void;\n\t\n\n\t/**\n\t * Highlight the last item among the visible list\n\t */\n\thighlightLast(): void;\n\t\n\n\t/**\n\t * Select the provided item.\n\t * The selected list is used to\n\t * @param item - the item to select\n\t */\n\tselect(item: Item): void;\n\t\n\t/**\n\t * Unselect the provided item.\n\t * @param item - the item to unselect\n\t */\n\tunselect(item: Item): void;\n\t\n\t/**\n\t * Toggle the selection of an item\n\t * @param item - the item to toggle\n\t * @param selected - an optional boolean to enforce the selected/unselected state instead of toggling\n\t */\n\ttoggleItem(item: Item, selected?: boolean): void;\n\t\n\n\t/**\n\t * open the select\n\t */\n\topen(): void;\n\t\n\t/**\n\t * close the select\n\t */\n\tclose(): void;\n\t\n\t/**\n\t * Toggle the dropdown menu\n\t * @param isOpen - If specified, set the menu in the defined state.\n\t */\n\ttoggle(isOpen?: boolean): void;\n}\n\n/**\n * Interface representing the directives used in the Select component.\n *\n * @template Item - The type of the Select Items\n */\nexport interface SelectDirectives<Item> {\n\t\n\t/**\n\t * Directive to be used in the input group and the menu containers\n\t */\n\thasFocusDirective: HasFocus['directive'];\n\t\n\n\t/**\n\t * Directive that enables dynamic positioning of menu element\n\t */\n\tfloatingDirective: FloatingUI['directives']['floatingDirective'];\n\t\n\n\t/**\n\t * A directive to be applied to the input group element serves as the base for menu positioning\n\t */\n\treferenceDirective: FloatingUI['directives']['referenceDirective'];\n\t\n\n\t/**\n\t * A directive to be applied to the element that contains the badges and the input\n\t */\n\tinputContainerDirective: Directive;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the container badges\n\t */\n\tbadgeAttributesDirective: Directive<ItemContext<Item>>;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the dropdown menu\n\t */\n\tmenuAttributesDirective: Directive;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the dropdown item\n\t */\n\titemAttributesDirective: Directive<ItemContext<Item>>;\n\t\n\n\t/**\n\t * A directive to be applied to the input\n\t */\n\tinputDirective: Directive;\n\t\n\t/**\n\t * A directive to be applied to a button that closes a badge\n\t */\n\tbadgeCloseButtonDirective: Directive<ItemContext<Item>>;\n}\n\n"]}
@@ -0,0 +1,3 @@
1
+ export * from './tree.component';
2
+ export * from './tree.gen';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy90cmVlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RyZWUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdHJlZS5nZW4nO1xuIl19
@@ -0,0 +1,445 @@
1
+ import { BaseWidgetDirective, callWidgetFactory, ComponentTemplate, SlotDirective, UseDirective } from '@agnos-ui/angular-headless';
2
+ import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, inject, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
3
+ import { createTree } from './tree.gen';
4
+ import * as i0 from "@angular/core";
5
+ const _c0 = ["structure"];
6
+ const _c1 = (a0, a1, a2, a3) => ({ state: a0, api: a1, directives: a2, item: a3 });
7
+ function TreeDefaultStructureSlotComponent_ng_template_0_For_2_ng_template_0_Template(rf, ctx) { }
8
+ function TreeDefaultStructureSlotComponent_ng_template_0_For_2_Template(rf, ctx) { if (rf & 1) {
9
+ i0.ɵɵtemplate(0, TreeDefaultStructureSlotComponent_ng_template_0_For_2_ng_template_0_Template, 0, 0, "ng-template", 3);
10
+ } if (rf & 2) {
11
+ const node_r1 = ctx.$implicit;
12
+ const ctx_r1 = i0.ɵɵnextContext();
13
+ const state_r3 = ctx_r1.state;
14
+ const directives_r4 = ctx_r1.directives;
15
+ const api_r5 = ctx_r1.api;
16
+ i0.ɵɵproperty("auSlot", state_r3.item())("auSlotProps", i0.ɵɵpureFunction4(2, _c1, state_r3, api_r5, directives_r4, node_r1));
17
+ } }
18
+ function TreeDefaultStructureSlotComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
19
+ i0.ɵɵelementStart(0, "ul", 2);
20
+ i0.ɵɵrepeaterCreate(1, TreeDefaultStructureSlotComponent_ng_template_0_For_2_Template, 1, 7, null, 3, i0.ɵɵcomponentInstance().trackNode, true);
21
+ i0.ɵɵelementEnd();
22
+ } if (rf & 2) {
23
+ const state_r3 = ctx.state;
24
+ const directives_r4 = ctx.directives;
25
+ i0.ɵɵclassMapInterpolate1("au-tree ", state_r3.className(), "");
26
+ i0.ɵɵproperty("auUse", directives_r4.navigationDirective);
27
+ i0.ɵɵadvance();
28
+ i0.ɵɵrepeater(state_r3.normalizedNodes());
29
+ } }
30
+ const _c2 = ["toggle"];
31
+ const _c3 = a0 => ({ item: a0 });
32
+ const _c4 = (a0, a1) => [a0, a1];
33
+ function TreeDefaultItemToggleSlotComponent_ng_template_0_Conditional_0_Template(rf, ctx) { if (rf & 1) {
34
+ i0.ɵɵelement(0, "button", 2);
35
+ } if (rf & 2) {
36
+ const ctx_r0 = i0.ɵɵnextContext();
37
+ const directives_r2 = ctx_r0.directives;
38
+ const item_r3 = ctx_r0.item;
39
+ i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(3, _c4, directives_r2.itemToggleDirective, i0.ɵɵpureFunction1(1, _c3, item_r3)));
40
+ } }
41
+ function TreeDefaultItemToggleSlotComponent_ng_template_0_Conditional_1_Template(rf, ctx) { if (rf & 1) {
42
+ i0.ɵɵelement(0, "span", 3);
43
+ } }
44
+ 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);
46
+ } if (rf & 2) {
47
+ const item_r3 = ctx.item;
48
+ i0.ɵɵconditional(item_r3.children.length > 0 ? 0 : 1);
49
+ } }
50
+ const _c5 = ["treeItemContent"];
51
+ function TreeDefaultItemContentSlotComponent_ng_template_0_ng_template_1_Template(rf, ctx) { }
52
+ function TreeDefaultItemContentSlotComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
53
+ i0.ɵɵelementStart(0, "span", 2);
54
+ i0.ɵɵtemplate(1, TreeDefaultItemContentSlotComponent_ng_template_0_ng_template_1_Template, 0, 0, "ng-template", 3);
55
+ i0.ɵɵtext(2);
56
+ i0.ɵɵelementEnd();
57
+ } if (rf & 2) {
58
+ const state_r1 = ctx.state;
59
+ const directives_r2 = ctx.directives;
60
+ const item_r3 = ctx.item;
61
+ const api_r4 = ctx.api;
62
+ i0.ɵɵadvance();
63
+ i0.ɵɵproperty("auSlot", state_r1.itemToggle())("auSlotProps", i0.ɵɵpureFunction4(3, _c1, state_r1, api_r4, directives_r2, item_r3));
64
+ i0.ɵɵadvance();
65
+ i0.ɵɵtextInterpolate1(" ", item_r3.label, " ");
66
+ } }
67
+ const _c6 = ["treeItem"];
68
+ function TreeDefaultItemSlotComponent_ng_template_0_ng_template_1_Template(rf, ctx) { }
69
+ function TreeDefaultItemSlotComponent_ng_template_0_Conditional_2_For_2_ng_template_0_Template(rf, ctx) { }
70
+ function TreeDefaultItemSlotComponent_ng_template_0_Conditional_2_For_2_Template(rf, ctx) { if (rf & 1) {
71
+ i0.ɵɵtemplate(0, TreeDefaultItemSlotComponent_ng_template_0_Conditional_2_For_2_ng_template_0_Template, 0, 0, "ng-template", 3);
72
+ } if (rf & 2) {
73
+ const child_r1 = ctx.$implicit;
74
+ const ctx_r1 = i0.ɵɵnextContext(2);
75
+ const state_r3 = ctx_r1.state;
76
+ const directives_r4 = ctx_r1.directives;
77
+ const api_r5 = ctx_r1.api;
78
+ i0.ɵɵproperty("auSlot", state_r3.item())("auSlotProps", i0.ɵɵpureFunction4(2, _c1, state_r3, api_r5, directives_r4, child_r1));
79
+ } }
80
+ function TreeDefaultItemSlotComponent_ng_template_0_Conditional_2_Template(rf, ctx) { if (rf & 1) {
81
+ i0.ɵɵelementStart(0, "ul", 4);
82
+ i0.ɵɵrepeaterCreate(1, TreeDefaultItemSlotComponent_ng_template_0_Conditional_2_For_2_Template, 1, 7, null, 3, i0.ɵɵcomponentInstance().trackNode, true);
83
+ i0.ɵɵelementEnd();
84
+ } if (rf & 2) {
85
+ const item_r6 = i0.ɵɵnextContext().item;
86
+ i0.ɵɵadvance();
87
+ i0.ɵɵrepeater(item_r6.children);
88
+ } }
89
+ function TreeDefaultItemSlotComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
90
+ i0.ɵɵelementStart(0, "li", 2);
91
+ i0.ɵɵtemplate(1, TreeDefaultItemSlotComponent_ng_template_0_ng_template_1_Template, 0, 0, "ng-template", 3)(2, TreeDefaultItemSlotComponent_ng_template_0_Conditional_2_Template, 3, 0, "ul", 4);
92
+ i0.ɵɵelementEnd();
93
+ } if (rf & 2) {
94
+ const state_r3 = ctx.state;
95
+ const directives_r4 = ctx.directives;
96
+ const item_r6 = ctx.item;
97
+ const api_r5 = ctx.api;
98
+ i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(6, _c4, directives_r4.itemAttributesDirective, i0.ɵɵpureFunction1(4, _c3, item_r6)));
99
+ i0.ɵɵadvance();
100
+ i0.ɵɵproperty("auSlot", state_r3.itemContent())("auSlotProps", i0.ɵɵpureFunction4(9, _c1, state_r3, api_r5, directives_r4, item_r6));
101
+ i0.ɵɵadvance();
102
+ i0.ɵɵconditional(state_r3.expandedMap().get(item_r6) ? 2 : -1);
103
+ } }
104
+ const _c7 = ["auTree", ""];
105
+ const _c8 = (a0, a1, a2) => ({ state: a0, api: a1, directives: a2 });
106
+ function TreeComponent_ng_template_0_Template(rf, ctx) { }
107
+ /**
108
+ * Directive to provide a template reference for tree structure.
109
+ *
110
+ * This directive uses a template reference to render the {@link TreeContext}.
111
+ */
112
+ export class TreeStructureDirective {
113
+ constructor() {
114
+ this.templateRef = inject((TemplateRef));
115
+ }
116
+ static ngTemplateContextGuard(_dir, context) {
117
+ return true;
118
+ }
119
+ static { this.ɵfac = function TreeStructureDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeStructureDirective)(); }; }
120
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TreeStructureDirective, selectors: [["ng-template", "auTreeStructure", ""]], standalone: true }); }
121
+ }
122
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeStructureDirective, [{
123
+ type: Directive,
124
+ args: [{ selector: 'ng-template[auTreeStructure]', standalone: true }]
125
+ }], null, null); })();
126
+ class TreeDefaultStructureSlotComponent {
127
+ trackNode(index, node) {
128
+ return node.label + node.level + index;
129
+ }
130
+ static { this.ɵfac = function TreeDefaultStructureSlotComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeDefaultStructureSlotComponent)(); }; }
131
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TreeDefaultStructureSlotComponent, selectors: [["ng-component"]], viewQuery: function TreeDefaultStructureSlotComponent_Query(rf, ctx) { if (rf & 1) {
132
+ i0.ɵɵviewQuery(_c0, 7);
133
+ } if (rf & 2) {
134
+ let _t;
135
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first);
136
+ } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["structure", ""], ["auTreeStructure", ""], ["role", "tree", 3, "auUse"], [3, "auSlot", "auSlotProps"]], template: function TreeDefaultStructureSlotComponent_Template(rf, ctx) { if (rf & 1) {
137
+ i0.ɵɵtemplate(0, TreeDefaultStructureSlotComponent_ng_template_0_Template, 3, 4, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
138
+ } }, dependencies: [UseDirective, TreeStructureDirective, SlotDirective], encapsulation: 2, changeDetection: 0 }); }
139
+ }
140
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeDefaultStructureSlotComponent, [{
141
+ type: Component,
142
+ args: [{
143
+ standalone: true,
144
+ changeDetection: ChangeDetectionStrategy.OnPush,
145
+ imports: [UseDirective, TreeStructureDirective, SlotDirective],
146
+ template: `
147
+ <ng-template auTreeStructure #structure let-state="state" let-directives="directives" let-api="api">
148
+ <ul role="tree" class="au-tree {{ state.className() }}" [auUse]="directives.navigationDirective">
149
+ @for (node of state.normalizedNodes(); track trackNode($index, node)) {
150
+ <ng-template [auSlot]="state.item()" [auSlotProps]="{state, api, directives, item: node}"></ng-template>
151
+ }
152
+ </ul>
153
+ </ng-template>
154
+ `,
155
+ }]
156
+ }], null, { structure: [{
157
+ type: ViewChild,
158
+ args: ['structure', { static: true }]
159
+ }] }); })();
160
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultStructureSlotComponent, { className: "TreeDefaultStructureSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 45 }); })();
161
+ /**
162
+ * A constant representing the default slot for tree structure.
163
+ */
164
+ export const treeDefaultSlotStructure = new ComponentTemplate(TreeDefaultStructureSlotComponent, 'structure');
165
+ /**
166
+ * Directive to provide a template reference for tree item toggle.
167
+ *
168
+ * This directive uses a template reference to render the {@link TreeSlotItemContext}.
169
+ */
170
+ export class TreeItemToggleDirective {
171
+ constructor() {
172
+ this.templateRef = inject((TemplateRef));
173
+ }
174
+ static ngTemplateContextGuard(_dir, context) {
175
+ return true;
176
+ }
177
+ static { this.ɵfac = function TreeItemToggleDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeItemToggleDirective)(); }; }
178
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TreeItemToggleDirective, selectors: [["ng-template", "auTreeItemToggle", ""]], standalone: true }); }
179
+ }
180
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeItemToggleDirective, [{
181
+ type: Directive,
182
+ args: [{ selector: 'ng-template[auTreeItemToggle]', standalone: true }]
183
+ }], null, null); })();
184
+ class TreeDefaultItemToggleSlotComponent {
185
+ static { this.ɵfac = function TreeDefaultItemToggleSlotComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeDefaultItemToggleSlotComponent)(); }; }
186
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TreeDefaultItemToggleSlotComponent, selectors: [["ng-component"]], viewQuery: function TreeDefaultItemToggleSlotComponent_Query(rf, ctx) { if (rf & 1) {
187
+ i0.ɵɵviewQuery(_c2, 7);
188
+ } if (rf & 2) {
189
+ let _t;
190
+ 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) {
192
+ i0.ɵɵtemplate(0, TreeDefaultItemToggleSlotComponent_ng_template_0_Template, 2, 1, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
193
+ } }, dependencies: [UseDirective, TreeItemToggleDirective], encapsulation: 2, changeDetection: 0 }); }
194
+ }
195
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeDefaultItemToggleSlotComponent, [{
196
+ type: Component,
197
+ args: [{
198
+ standalone: true,
199
+ changeDetection: ChangeDetectionStrategy.OnPush,
200
+ imports: [UseDirective, TreeItemToggleDirective],
201
+ template: `
202
+ <ng-template auTreeItemToggle #toggle let-directives="directives" let-item="item">
203
+ @if (item.children.length > 0) {
204
+ <button [auUse]="[directives.itemToggleDirective, {item}]"></button>
205
+ } @else {
206
+ <span class="au-tree-expand-icon-placeholder"></span>
207
+ }
208
+ </ng-template>
209
+ `,
210
+ }]
211
+ }], null, { toggle: [{
212
+ type: ViewChild,
213
+ args: ['toggle', { static: true }]
214
+ }] }); })();
215
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemToggleSlotComponent, { className: "TreeDefaultItemToggleSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 85 }); })();
216
+ /**
217
+ * A constant representing the default slot for tree item toggle.
218
+ */
219
+ export const treeDefaultItemToggle = new ComponentTemplate(TreeDefaultItemToggleSlotComponent, 'toggle');
220
+ /**
221
+ * Directive to provide a template reference for tree item content.
222
+ *
223
+ * This directive uses a template reference to render the {@link TreeSlotItemContext}.
224
+ */
225
+ export class TreeItemContentDirective {
226
+ constructor() {
227
+ this.templateRef = inject((TemplateRef));
228
+ }
229
+ static ngTemplateContextGuard(_dir, context) {
230
+ return true;
231
+ }
232
+ static { this.ɵfac = function TreeItemContentDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeItemContentDirective)(); }; }
233
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TreeItemContentDirective, selectors: [["ng-template", "auTreeItemContent", ""]], standalone: true }); }
234
+ }
235
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeItemContentDirective, [{
236
+ type: Directive,
237
+ args: [{ selector: 'ng-template[auTreeItemContent]', standalone: true }]
238
+ }], null, null); })();
239
+ class TreeDefaultItemContentSlotComponent {
240
+ static { this.ɵfac = function TreeDefaultItemContentSlotComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeDefaultItemContentSlotComponent)(); }; }
241
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TreeDefaultItemContentSlotComponent, selectors: [["ng-component"]], viewQuery: function TreeDefaultItemContentSlotComponent_Query(rf, ctx) { if (rf & 1) {
242
+ i0.ɵɵviewQuery(_c5, 7);
243
+ } if (rf & 2) {
244
+ let _t;
245
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.treeItemContent = _t.first);
246
+ } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["treeItemContent", ""], ["auTreeItem", ""], [1, "au-tree-item"], [3, "auSlot", "auSlotProps"]], template: function TreeDefaultItemContentSlotComponent_Template(rf, ctx) { if (rf & 1) {
247
+ i0.ɵɵtemplate(0, TreeDefaultItemContentSlotComponent_ng_template_0_Template, 3, 8, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
248
+ } }, dependencies: [SlotDirective], encapsulation: 2, changeDetection: 0 }); }
249
+ }
250
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeDefaultItemContentSlotComponent, [{
251
+ type: Component,
252
+ args: [{
253
+ standalone: true,
254
+ changeDetection: ChangeDetectionStrategy.OnPush,
255
+ imports: [UseDirective, SlotDirective, TreeItemContentDirective],
256
+ template: `
257
+ <ng-template auTreeItem #treeItemContent let-state="state" let-directives="directives" let-item="item" let-api="api">
258
+ <span class="au-tree-item">
259
+ <ng-template [auSlot]="state.itemToggle()" [auSlotProps]="{state, api, directives, item}"></ng-template>
260
+ {{ item.label }}
261
+ </span>
262
+ </ng-template>
263
+ `,
264
+ }]
265
+ }], null, { treeItemContent: [{
266
+ type: ViewChild,
267
+ args: ['treeItemContent', { static: true }]
268
+ }] }); })();
269
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemContentSlotComponent, { className: "TreeDefaultItemContentSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 120 }); })();
270
+ /**
271
+ * A constant representing the default slot for tree item.
272
+ */
273
+ export const treeDefaultSlotItemContent = new ComponentTemplate(TreeDefaultItemContentSlotComponent, 'treeItemContent');
274
+ /**
275
+ * Directive to provide a template reference for tree item.
276
+ *
277
+ * This directive uses a template reference to render the {@link TreeSlotItemContext}.
278
+ */
279
+ export class TreeItemDirective {
280
+ constructor() {
281
+ this.templateRef = inject((TemplateRef));
282
+ }
283
+ static ngTemplateContextGuard(_dir, context) {
284
+ return true;
285
+ }
286
+ static { this.ɵfac = function TreeItemDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeItemDirective)(); }; }
287
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TreeItemDirective, selectors: [["ng-template", "auTreeItem", ""]], standalone: true }); }
288
+ }
289
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeItemDirective, [{
290
+ type: Directive,
291
+ args: [{ selector: 'ng-template[auTreeItem]', standalone: true }]
292
+ }], null, null); })();
293
+ class TreeDefaultItemSlotComponent {
294
+ trackNode(index, node) {
295
+ return node.label + node.level + index;
296
+ }
297
+ static { this.ɵfac = function TreeDefaultItemSlotComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeDefaultItemSlotComponent)(); }; }
298
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TreeDefaultItemSlotComponent, selectors: [["ng-component"]], viewQuery: function TreeDefaultItemSlotComponent_Query(rf, ctx) { if (rf & 1) {
299
+ i0.ɵɵviewQuery(_c6, 7);
300
+ } if (rf & 2) {
301
+ let _t;
302
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.treeItem = _t.first);
303
+ } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["treeItem", ""], ["auTreeItem", ""], [3, "auUse"], [3, "auSlot", "auSlotProps"], ["role", "group"]], template: function TreeDefaultItemSlotComponent_Template(rf, ctx) { if (rf & 1) {
304
+ i0.ɵɵtemplate(0, TreeDefaultItemSlotComponent_ng_template_0_Template, 3, 14, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
305
+ } }, dependencies: [UseDirective, SlotDirective, TreeItemDirective], encapsulation: 2, changeDetection: 0 }); }
306
+ }
307
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeDefaultItemSlotComponent, [{
308
+ type: Component,
309
+ args: [{
310
+ standalone: true,
311
+ changeDetection: ChangeDetectionStrategy.OnPush,
312
+ imports: [UseDirective, SlotDirective, TreeItemDirective],
313
+ template: `
314
+ <ng-template auTreeItem #treeItem let-state="state" let-directives="directives" let-item="item" let-api="api">
315
+ <li [auUse]="[directives.itemAttributesDirective, {item}]">
316
+ <ng-template [auSlot]="state.itemContent()" [auSlotProps]="{state, api, directives, item}"></ng-template>
317
+ @if (state.expandedMap().get(item)) {
318
+ <ul role="group">
319
+ @for (child of item.children; track trackNode($index, child)) {
320
+ <ng-template [auSlot]="state.item()" [auSlotProps]="{state, api, directives, item: child}"></ng-template>
321
+ }
322
+ </ul>
323
+ }
324
+ </li>
325
+ </ng-template>
326
+ `,
327
+ }]
328
+ }], null, { treeItem: [{
329
+ type: ViewChild,
330
+ args: ['treeItem', { static: true }]
331
+ }] }); })();
332
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TreeDefaultItemSlotComponent, { className: "TreeDefaultItemSlotComponent", filePath: "components/tree/tree.component.ts", lineNumber: 164 }); })();
333
+ /**
334
+ * A constant representing the default slot for tree item.
335
+ */
336
+ export const treeDefaultSlotItem = new ComponentTemplate(TreeDefaultItemSlotComponent, 'treeItem');
337
+ /**
338
+ * TreeComponent is an Angular component that extends the BaseWidgetDirective
339
+ * to provide a customizable tree widget. This component allows for various
340
+ * configurations and customizations through its inputs and outputs.
341
+ */
342
+ export class TreeComponent extends BaseWidgetDirective {
343
+ constructor() {
344
+ super(callWidgetFactory({
345
+ factory: createTree,
346
+ widgetName: 'tree',
347
+ defaultConfig: {
348
+ structure: treeDefaultSlotStructure,
349
+ item: treeDefaultSlotItem,
350
+ itemContent: treeDefaultSlotItemContent,
351
+ itemToggle: treeDefaultItemToggle,
352
+ },
353
+ events: {
354
+ onExpandToggle: (item) => this.expandToggle.emit(item),
355
+ },
356
+ slotTemplates: () => ({
357
+ structure: this.slotStructureFromContent?.templateRef,
358
+ item: this.slotItemFromContent?.templateRef,
359
+ itemContent: this.slotItemContentFromContent?.templateRef,
360
+ itemToggle: this.slotItemToggleFromContent?.templateRef,
361
+ }),
362
+ }));
363
+ /**
364
+ * An event emitted when the user toggles the expand of the TreeItem.
365
+ *
366
+ * Event payload is equal to the TreeItem clicked.
367
+ *
368
+ * @defaultValue
369
+ * ```ts
370
+ * () => {}
371
+ * ```
372
+ */
373
+ this.expandToggle = new EventEmitter();
374
+ }
375
+ static { this.ɵfac = function TreeComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TreeComponent)(); }; }
376
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TreeComponent, selectors: [["", "auTree", ""]], contentQueries: function TreeComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
377
+ i0.ɵɵcontentQuery(dirIndex, TreeItemContentDirective, 5);
378
+ i0.ɵɵcontentQuery(dirIndex, TreeStructureDirective, 5);
379
+ i0.ɵɵcontentQuery(dirIndex, TreeItemToggleDirective, 5);
380
+ i0.ɵɵcontentQuery(dirIndex, TreeItemDirective, 5);
381
+ } if (rf & 2) {
382
+ let _t;
383
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotItemContentFromContent = _t.first);
384
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first);
385
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotItemToggleFromContent = _t.first);
386
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotItemFromContent = _t.first);
387
+ } }, inputs: { ariaLabel: [0, "auAriaLabel", "ariaLabel"], nodes: [0, "auNodes", "nodes"], className: [0, "auClassName", "className"], navSelector: [0, "auNavSelector", "navSelector"], ariaLabelToggleFn: [0, "auAriaLabelToggleFn", "ariaLabelToggleFn"], item: [0, "auItemContent", "item"], structure: [0, "auStructure", "structure"], toggle: [0, "auToggle", "toggle"], root: [0, "auItem", "root"] }, outputs: { expandToggle: "auExpandToggle" }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c7, decls: 1, vars: 6, consts: [[3, "auSlot", "auSlotProps"]], template: function TreeComponent_Template(rf, ctx) { if (rf & 1) {
388
+ i0.ɵɵtemplate(0, TreeComponent_ng_template_0_Template, 0, 0, "ng-template", 0);
389
+ } if (rf & 2) {
390
+ i0.ɵɵproperty("auSlot", ctx.state.structure())("auSlotProps", i0.ɵɵpureFunction3(2, _c8, ctx.state, ctx.api, ctx.directives));
391
+ } }, dependencies: [SlotDirective], encapsulation: 2 }); }
392
+ }
393
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeComponent, [{
394
+ type: Component,
395
+ args: [{
396
+ selector: '[auTree]',
397
+ standalone: true,
398
+ imports: [SlotDirective],
399
+ template: ` <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template> `,
400
+ }]
401
+ }], () => [], { ariaLabel: [{
402
+ type: Input,
403
+ args: ['auAriaLabel']
404
+ }], nodes: [{
405
+ type: Input,
406
+ args: ['auNodes']
407
+ }], className: [{
408
+ type: Input,
409
+ args: ['auClassName']
410
+ }], navSelector: [{
411
+ type: Input,
412
+ args: ['auNavSelector']
413
+ }], ariaLabelToggleFn: [{
414
+ type: Input,
415
+ args: ['auAriaLabelToggleFn']
416
+ }], expandToggle: [{
417
+ type: Output,
418
+ args: ['auExpandToggle']
419
+ }], item: [{
420
+ type: Input,
421
+ args: ['auItemContent']
422
+ }], slotItemContentFromContent: [{
423
+ type: ContentChild,
424
+ args: [TreeItemContentDirective, { static: false }]
425
+ }], structure: [{
426
+ type: Input,
427
+ args: ['auStructure']
428
+ }], slotStructureFromContent: [{
429
+ type: ContentChild,
430
+ args: [TreeStructureDirective, { static: false }]
431
+ }], toggle: [{
432
+ type: Input,
433
+ args: ['auToggle']
434
+ }], slotItemToggleFromContent: [{
435
+ type: ContentChild,
436
+ args: [TreeItemToggleDirective, { static: false }]
437
+ }], root: [{
438
+ type: Input,
439
+ args: ['auItem']
440
+ }], slotItemFromContent: [{
441
+ type: ContentChild,
442
+ args: [TreeItemDirective, { static: false }]
443
+ }] }); })();
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"]}
@@ -0,0 +1,15 @@
1
+ import { getTreeDefaultConfig, createTree } from '@agnos-ui/core-bootstrap/components/tree';
2
+ /**
3
+ * Retrieve a shallow copy of the default Tree config
4
+ * @returns the default Tree config
5
+ */
6
+ const export_getTreeDefaultConfig = getTreeDefaultConfig;
7
+ export { export_getTreeDefaultConfig as getTreeDefaultConfig };
8
+ /**
9
+ * Create a Tree with given config props
10
+ * @param config - an optional tree config
11
+ * @returns a TreeWidget
12
+ */
13
+ const export_createTree = createTree;
14
+ export { export_createTree as createTree };
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS5nZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy90cmVlL3RyZWUuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxvQkFBb0IsRUFBRSxVQUFVLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUsxRjs7O0dBR0c7QUFDSCxNQUFNLDJCQUEyQixHQUFvQixvQkFBMkIsQ0FBQztBQUNqRixPQUFPLEVBQUMsMkJBQTJCLElBQUksb0JBQW9CLEVBQUMsQ0FBQztBQTZKN0Q7Ozs7R0FJRztBQUNILE1BQU0saUJBQWlCLEdBQThCLFVBQWlCLENBQUM7QUFDdkUsT0FBTyxFQUFDLGlCQUFpQixJQUFJLFVBQVUsRUFBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtnZXRUcmVlRGVmYXVsdENvbmZpZywgY3JlYXRlVHJlZX0gZnJvbSAnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvdHJlZSc7XG5pbXBvcnQgdHlwZSB7V2lkZ2V0U2xvdENvbnRleHQsIFNsb3RDb250ZW50LCBXaWRnZXQsIFdpZGdldEZhY3RvcnksIERpcmVjdGl2ZX0gZnJvbSAnQGFnbm9zLXVpL2FuZ3VsYXItaGVhZGxlc3MnO1xuXG5cblxuLyoqXG4gKiBSZXRyaWV2ZSBhIHNoYWxsb3cgY29weSBvZiB0aGUgZGVmYXVsdCBUcmVlIGNvbmZpZ1xuICogQHJldHVybnMgdGhlIGRlZmF1bHQgVHJlZSBjb25maWdcbiAqL1xuY29uc3QgZXhwb3J0X2dldFRyZWVEZWZhdWx0Q29uZmlnOiAoKSA9PiBUcmVlUHJvcHMgPSBnZXRUcmVlRGVmYXVsdENvbmZpZyBhcyBhbnk7XG5leHBvcnQge2V4cG9ydF9nZXRUcmVlRGVmYXVsdENvbmZpZyBhcyBnZXRUcmVlRGVmYXVsdENvbmZpZ307XG5cblxuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIGNvbnRleHQgZm9yIGEgVHJlZSB3aWRnZXQuXG4gKiBUaGlzIGludGVyZmFjZSBpcyBhbiBhbGlhcyBmb3IgYFdpZGdldFNsb3RDb250ZXh0PFRyZWVXaWRnZXQ+YC5cbiAqL1xuZXhwb3J0IHR5cGUgVHJlZUNvbnRleHQgPSBXaWRnZXRTbG90Q29udGV4dDxUcmVlV2lkZ2V0PjtcblxuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIGNvbnRleHQgZm9yIGEgdHJlZSBpdGVtLCBleHRlbmRpbmcgdGhlIGJhc2UgYFRyZWVDb250ZXh0YFxuICogd2l0aCBhbiBhZGRpdGlvbmFsIGBpdGVtYCBwcm9wZXJ0eS5cbiAqL1xuZXhwb3J0IHR5cGUgVHJlZVNsb3RJdGVtQ29udGV4dCA9IFRyZWVDb250ZXh0ICYge2l0ZW06IE5vcm1hbGl6ZWRUcmVlSXRlbX07XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgc3RhdGUgb2YgYSBUcmVlIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmVlU3RhdGUge1xuXHRcblx0LyoqXG5cdCAqIEFycmF5IG9mIG5vcm1hbGl6ZWQgdHJlZSBub2Rlc1xuXHQgKi9cblx0bm9ybWFsaXplZE5vZGVzOiBOb3JtYWxpemVkVHJlZUl0ZW1bXTtcblx0XG5cdC8qKlxuXHQgKiBHZXR0ZXIgb2YgZXhwYW5kZWQgc3RhdGUgZm9yIGVhY2ggdHJlZSBub2RlXG5cdCAqL1xuXHRleHBhbmRlZE1hcDoge2dldChpdGVtOiBOb3JtYWxpemVkVHJlZUl0ZW0pOiBib29sZWFuIHwgdW5kZWZpbmVkfTtcblx0XG5cdC8qKlxuXHQgKiBPcHRpb25hbCBhY2Nlc3NpYmlsaXR5IGxhYmVsIGZvciB0aGUgdHJlZSBpZiB0aGVyZSBpcyBubyBleHBsaWNpdCBsYWJlbFxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGFyaWFMYWJlbD86IHN0cmluZztcblx0XG5cdC8qKlxuXHQgKiBDU1MgY2xhc3NlcyB0byBiZSBhcHBsaWVkIG9uIHRoZSB3aWRnZXQgbWFpbiBjb250YWluZXJcblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJydgXG5cdCAqL1xuXHRjbGFzc05hbWU6IHN0cmluZztcblx0XG5cdC8qKlxuXHQgKiBTbG90IHRvIGNoYW5nZSB0aGUgZGVmYXVsdCBkaXNwbGF5IG9mIHRoZSB0cmVlXG5cdCAqL1xuXHRzdHJ1Y3R1cmU6IFNsb3RDb250ZW50PFRyZWVDb250ZXh0Pjtcblx0XG5cdC8qKlxuXHQgKiBTbG90IHRvIGNoYW5nZSB0aGUgZGVmYXVsdCB0cmVlIGl0ZW1cblx0ICovXG5cdGl0ZW06IFNsb3RDb250ZW50PFRyZWVTbG90SXRlbUNvbnRleHQ+O1xuXHRcblx0LyoqXG5cdCAqIFNsb3QgdG8gY2hhbmdlIHRoZSBkZWZhdWx0IHRyZWUgaXRlbSBjb250ZW50XG5cdCAqL1xuXHRpdGVtQ29udGVudDogU2xvdENvbnRlbnQ8VHJlZVNsb3RJdGVtQ29udGV4dD47XG5cdFxuXHQvKipcblx0ICogU2xvdCB0byBjaGFuZ2UgdGhlIGRlZmF1bHQgdHJlZSBpdGVtIHRvZ2dsZVxuXHQgKi9cblx0aXRlbVRvZ2dsZTogU2xvdENvbnRlbnQ8VHJlZVNsb3RJdGVtQ29udGV4dD47XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgcHJvcGVydGllcyBmb3IgdGhlIFRyZWUgY29tcG9uZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyZWVQcm9wcyB7XG5cdFxuXHQvKipcblx0ICogQXJyYXkgb2YgdGhlIHRyZWUgbm9kZXMgdG8gZGlzcGxheVxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGBbXWBcblx0ICovXG5cdG5vZGVzOiBUcmVlSXRlbVtdO1xuXHRcblx0LyoqXG5cdCAqIEFuIGV2ZW50IGVtaXR0ZWQgd2hlbiB0aGUgdXNlciB0b2dnbGVzIHRoZSBleHBhbmQgb2YgdGhlIFRyZWVJdGVtLlxuXHQgKlxuXHQgKiBFdmVudCBwYXlsb2FkIGlzIGVxdWFsIHRvIHRoZSBUcmVlSXRlbSBjbGlja2VkLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlXG5cdCAqIGBgYHRzXG5cdCAqICgpID0+IHt9XG5cdCAqIGBgYFxuXHQgKi9cblx0b25FeHBhbmRUb2dnbGU6IChub2RlOiBOb3JtYWxpemVkVHJlZUl0ZW0pID0+IHZvaWQ7XG5cdFxuXHQvKipcblx0ICogUmV0cmlldmVzIGV4cGFuZCBpdGVtcyBvZiB0aGUgVHJlZUl0ZW1cblx0ICpcblx0ICogQHBhcmFtIG5vZGUgLSBIVE1MIGVsZW1lbnQgdGhhdCBpcyByZXByZXNlbnRpbmcgdGhlIGV4cGFuZCBpdGVtXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWVcblx0ICogYGBgdHNcblx0ICogKG5vZGU6IEhUTUxFbGVtZW50KSA9PiBub2RlLnF1ZXJ5U2VsZWN0b3JBbGwoJ2J1dHRvbicpXG5cdCAqIGBgYFxuXHQgKi9cblx0bmF2U2VsZWN0b3Iobm9kZTogSFRNTEVsZW1lbnQpOiBOb2RlTGlzdE9mPEhUTUxCdXR0b25FbGVtZW50Pjtcblx0XG5cdC8qKlxuXHQgKiBSZXR1cm4gdGhlIHZhbHVlIGZvciB0aGUgJ2FyaWEtbGFiZWwnIGF0dHJpYnV0ZSBvZiB0aGUgdG9nZ2xlXG5cdCAqIEBwYXJhbSBsYWJlbCAtIHRyZWUgaXRlbSBsYWJlbFxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlXG5cdCAqIGBgYHRzXG5cdCAqIChsYWJlbDogc3RyaW5nKSA9PiBgVG9nZ2xlICR7bGFiZWx9YFxuXHQgKiBgYGBcblx0ICovXG5cdGFyaWFMYWJlbFRvZ2dsZUZuOiAobGFiZWw6IHN0cmluZykgPT4gc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIE9wdGlvbmFsIGFjY2Vzc2liaWxpdHkgbGFiZWwgZm9yIHRoZSB0cmVlIGlmIHRoZXJlIGlzIG5vIGV4cGxpY2l0IGxhYmVsXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCcnYFxuXHQgKi9cblx0YXJpYUxhYmVsPzogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIENTUyBjbGFzc2VzIHRvIGJlIGFwcGxpZWQgb24gdGhlIHdpZGdldCBtYWluIGNvbnRhaW5lclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGNsYXNzTmFtZTogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIFNsb3QgdG8gY2hhbmdlIHRoZSBkZWZhdWx0IGRpc3BsYXkgb2YgdGhlIHRyZWVcblx0ICovXG5cdHN0cnVjdHVyZTogU2xvdENvbnRlbnQ8VHJlZUNvbnRleHQ+O1xuXHRcblx0LyoqXG5cdCAqIFNsb3QgdG8gY2hhbmdlIHRoZSBkZWZhdWx0IHRyZWUgaXRlbVxuXHQgKi9cblx0aXRlbTogU2xvdENvbnRlbnQ8VHJlZVNsb3RJdGVtQ29udGV4dD47XG5cdFxuXHQvKipcblx0ICogU2xvdCB0byBjaGFuZ2UgdGhlIGRlZmF1bHQgdHJlZSBpdGVtIGNvbnRlbnRcblx0ICovXG5cdGl0ZW1Db250ZW50OiBTbG90Q29udGVudDxUcmVlU2xvdEl0ZW1Db250ZXh0Pjtcblx0XG5cdC8qKlxuXHQgKiBTbG90IHRvIGNoYW5nZSB0aGUgZGVmYXVsdCB0cmVlIGl0ZW0gdG9nZ2xlXG5cdCAqL1xuXHRpdGVtVG9nZ2xlOiBTbG90Q29udGVudDxUcmVlU2xvdEl0ZW1Db250ZXh0Pjtcbn1cblxuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBUcmVlIHdpZGdldCBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCB0eXBlIFRyZWVXaWRnZXQgPSBXaWRnZXQ8VHJlZVByb3BzLCBUcmVlU3RhdGUsIFRyZWVBcGksIFRyZWVEaXJlY3RpdmVzPjtcblxuXG5cbi8qKlxuICogQ3JlYXRlIGEgVHJlZSB3aXRoIGdpdmVuIGNvbmZpZyBwcm9wc1xuICogQHBhcmFtIGNvbmZpZyAtIGFuIG9wdGlvbmFsIHRyZWUgY29uZmlnXG4gKiBAcmV0dXJucyBhIFRyZWVXaWRnZXRcbiAqL1xuY29uc3QgZXhwb3J0X2NyZWF0ZVRyZWU6IFdpZGdldEZhY3Rvcnk8VHJlZVdpZGdldD4gPSBjcmVhdGVUcmVlIGFzIGFueTtcbmV4cG9ydCB7ZXhwb3J0X2NyZWF0ZVRyZWUgYXMgY3JlYXRlVHJlZX07XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIHRyZWUgaXRlbSBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHJlZUl0ZW0ge1xuXHRcblx0LyoqXG5cdCAqIE9wdGlvbmFsIGFjY2Vzc2liaWxpdHkgbGFiZWwgZm9yIHRoZSBub2RlXG5cdCAqL1xuXHRhcmlhTGFiZWw/OiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogT3B0aW9uYWwgYXJyYXkgb2YgY2hpbGRyZW4gbm9kZXNcblx0ICovXG5cdGNoaWxkcmVuPzogVHJlZUl0ZW1bXTtcblx0XG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAgdGhlIG5vZGUgaXMgZXhwYW5kZWRcblx0ICovXG5cdGlzRXhwYW5kZWQ/OiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIFN0cmluZyB0aXRsZSBvZiB0aGUgbm9kZVxuXHQgKi9cblx0bGFiZWw6IHN0cmluZztcbn1cblxuLyoqXG4gKiBOb3JtYWxpemVkIFRyZWVJdGVtIG9iamVjdFxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5vcm1hbGl6ZWRUcmVlSXRlbSB7XG5cdFxuXHQvKipcblx0ICogQWNjZXNzaWJpbGl0eSBsYWJlbCBmb3IgdGhlIG5vZGVcblx0ICovXG5cdGFyaWFMYWJlbDogc3RyaW5nO1xuXHRcblxuXHQvKipcblx0ICogTGV2ZWwgaW4gdGhlIGhpZXJhcmNoeSwgc3RhcnRzIHdpdGggMCBmb3IgYSByb290IG5vZGVcblx0ICovXG5cdGxldmVsOiBudW1iZXI7XG5cdFxuXG5cdC8qKlxuXHQgKiBBbiBhcnJheSBvZiBjaGlsZHJlbiBub2Rlc1xuXHQgKi9cblx0Y2hpbGRyZW46IE5vcm1hbGl6ZWRUcmVlSXRlbVtdO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCB0aGUgbm9kZSBpcyBleHBhbmRlZFxuXHQgKi9cblx0aXNFeHBhbmRlZD86IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogU3RyaW5nIHRpdGxlIG9mIHRoZSBub2RlXG5cdCAqL1xuXHRsYWJlbDogc3RyaW5nO1xufVxuXG4vKipcbiAqIEludGVyZmFjZSByZXByZXNlbnRpbmcgdGhlIEFQSSBmb3IgYSBUcmVlIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmVlQXBpIHtcbn1cblxuLyoqXG4gKiBJbnRlcmZhY2UgcmVwcmVzZW50aW5nIHZhcmlvdXMgZGlyZWN0aXZlcyB1c2VkIGluIHRoZSBUcmVlIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmVlRGlyZWN0aXZlcyB7XG5cdFxuXHQvKipcblx0ICogRGlyZWN0aXZlIHRvIGF0dGFjaCBuYXZNYW5hZ2VyIGZvciB0aGUgdHJlZVxuXHQgKi9cblx0bmF2aWdhdGlvbkRpcmVjdGl2ZTogRGlyZWN0aXZlO1xuXHRcblx0LyoqXG5cdCAqIERpcmVjdGl2ZSB0byBoYW5kbGUgdG9nZ2xlIGZvciB0aGUgdHJlZSBpdGVtXG5cdCAqL1xuXHRpdGVtVG9nZ2xlRGlyZWN0aXZlOiBEaXJlY3RpdmU8e2l0ZW06IE5vcm1hbGl6ZWRUcmVlSXRlbX0+O1xuXHRcblx0LyoqXG5cdCAqIERpcmVjdGl2ZSB0byBoYW5kbGUgYXR0cmlidXRlcyBmb3IgdGhlIHRyZWUgaXRlbVxuXHQgKi9cblx0aXRlbUF0dHJpYnV0ZXNEaXJlY3RpdmU6IERpcmVjdGl2ZTx7aXRlbTogTm9ybWFsaXplZFRyZWVJdGVtfT47XG59XG5cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmdlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7QWNjb3JkaW9uUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9hY2NvcmRpb24nO1xuaW1wb3J0IHR5cGUge0FsZXJ0UHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9hbGVydCc7XG5pbXBvcnQgdHlwZSB7Q29sbGFwc2VQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL2NvbGxhcHNlJztcbmltcG9ydCB0eXBlIHtNb2RhbFByb3BzfSBmcm9tICcuL2NvbXBvbmVudHMvbW9kYWwnO1xuaW1wb3J0IHR5cGUge1BhZ2luYXRpb25Qcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3BhZ2luYXRpb24nO1xuaW1wb3J0IHR5cGUge1Byb2dyZXNzYmFyUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9wcm9ncmVzc2Jhcic7XG5pbXBvcnQgdHlwZSB7UmF0aW5nUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9yYXRpbmcnO1xuaW1wb3J0IHR5cGUge1NlbGVjdFByb3BzfSBmcm9tICcuL2NvbXBvbmVudHMvc2VsZWN0JztcbmltcG9ydCB0eXBlIHtTbGlkZXJQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3NsaWRlcic7XG5pbXBvcnQgdHlwZSB7VG9hc3RQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3RvYXN0JztcblxuZXhwb3J0IHR5cGUgV2lkZ2V0c0NvbmZpZyA9IHtcblx0LyoqXG5cdCAqIHRoZSBhY2NvcmRpb24gd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0YWNjb3JkaW9uOiBBY2NvcmRpb25Qcm9wcztcblx0LyoqXG5cdCAqIHRoZSBhbGVydCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRhbGVydDogQWxlcnRQcm9wcztcblx0LyoqXG5cdCAqIHRoZSBjb2xsYXBzZSB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRjb2xsYXBzZTogQ29sbGFwc2VQcm9wcztcblx0LyoqXG5cdCAqIHRoZSBtb2RhbCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRtb2RhbDogTW9kYWxQcm9wczxhbnk+O1xuXHQvKipcblx0ICogdGhlIHBhZ2luYXRpb24gd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0cGFnaW5hdGlvbjogUGFnaW5hdGlvblByb3BzO1xuXHQvKipcblx0ICogdGhlIHByb2dyZXNzYmFyIHdpZGdldCBjb25maWdcblx0ICovXG5cdHByb2dyZXNzYmFyOiBQcm9ncmVzc2JhclByb3BzO1xuXHQvKipcblx0ICogdGhlIHJhdGluZyB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRyYXRpbmc6IFJhdGluZ1Byb3BzO1xuXHQvKipcblx0ICogdGhlIHNlbGVjdCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRzZWxlY3Q6IFNlbGVjdFByb3BzPGFueT47XG5cdC8qKlxuXHQgKiB0aGUgc2xpZGVyIHdpZGdldCBjb25maWdcblx0ICovXG5cdHNsaWRlcjogU2xpZGVyUHJvcHM7XG5cdC8qKlxuXHQgKiB0aGUgdG9hc3Qgd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0dG9hc3Q6IFRvYXN0UHJvcHM7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmdlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7QWNjb3JkaW9uUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9hY2NvcmRpb24nO1xuaW1wb3J0IHR5cGUge0FsZXJ0UHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9hbGVydCc7XG5pbXBvcnQgdHlwZSB7Q29sbGFwc2VQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL2NvbGxhcHNlJztcbmltcG9ydCB0eXBlIHtNb2RhbFByb3BzfSBmcm9tICcuL2NvbXBvbmVudHMvbW9kYWwnO1xuaW1wb3J0IHR5cGUge1BhZ2luYXRpb25Qcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3BhZ2luYXRpb24nO1xuaW1wb3J0IHR5cGUge1Byb2dyZXNzYmFyUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9wcm9ncmVzc2Jhcic7XG5pbXBvcnQgdHlwZSB7UmF0aW5nUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9yYXRpbmcnO1xuaW1wb3J0IHR5cGUge1NlbGVjdFByb3BzfSBmcm9tICcuL2NvbXBvbmVudHMvc2VsZWN0JztcbmltcG9ydCB0eXBlIHtTbGlkZXJQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3NsaWRlcic7XG5pbXBvcnQgdHlwZSB7VG9hc3RQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3RvYXN0JztcbmltcG9ydCB0eXBlIHtUcmVlUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy90cmVlJztcblxuZXhwb3J0IHR5cGUgV2lkZ2V0c0NvbmZpZyA9IHtcblx0LyoqXG5cdCAqIHRoZSBhY2NvcmRpb24gd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0YWNjb3JkaW9uOiBBY2NvcmRpb25Qcm9wcztcblx0LyoqXG5cdCAqIHRoZSBhbGVydCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRhbGVydDogQWxlcnRQcm9wcztcblx0LyoqXG5cdCAqIHRoZSBjb2xsYXBzZSB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRjb2xsYXBzZTogQ29sbGFwc2VQcm9wcztcblx0LyoqXG5cdCAqIHRoZSBtb2RhbCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRtb2RhbDogTW9kYWxQcm9wczxhbnk+O1xuXHQvKipcblx0ICogdGhlIHBhZ2luYXRpb24gd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0cGFnaW5hdGlvbjogUGFnaW5hdGlvblByb3BzO1xuXHQvKipcblx0ICogdGhlIHByb2dyZXNzYmFyIHdpZGdldCBjb25maWdcblx0ICovXG5cdHByb2dyZXNzYmFyOiBQcm9ncmVzc2JhclByb3BzO1xuXHQvKipcblx0ICogdGhlIHJhdGluZyB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRyYXRpbmc6IFJhdGluZ1Byb3BzO1xuXHQvKipcblx0ICogdGhlIHNlbGVjdCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRzZWxlY3Q6IFNlbGVjdFByb3BzPGFueT47XG5cdC8qKlxuXHQgKiB0aGUgc2xpZGVyIHdpZGdldCBjb25maWdcblx0ICovXG5cdHNsaWRlcjogU2xpZGVyUHJvcHM7XG5cdC8qKlxuXHQgKiB0aGUgdG9hc3Qgd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0dG9hc3Q6IFRvYXN0UHJvcHM7XG5cdC8qKlxuXHQgKiB0aGUgdHJlZSB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHR0cmVlOiBUcmVlUHJvcHM7XG59XG4iXX0=