@angular/aria 22.0.0-next.7 → 22.0.0-next.8
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.
- package/fesm2022/_accordion-chunk.mjs +1 -1
- package/fesm2022/_click-event-manager-chunk.mjs +1 -1
- package/fesm2022/{_signal-like-chunk.mjs → _collection-chunk.mjs} +51 -2
- package/fesm2022/_collection-chunk.mjs.map +1 -0
- package/fesm2022/_deferred-content-chunk.mjs +6 -6
- package/fesm2022/_list-chunk.mjs +4 -1
- package/fesm2022/_list-chunk.mjs.map +1 -1
- package/fesm2022/_list-navigation-chunk.mjs +1 -1
- package/fesm2022/_list-typeahead-chunk.mjs +1 -1
- package/fesm2022/_menu-chunk.mjs +1 -1
- package/fesm2022/{_combobox-listbox-chunk.mjs → _option-chunk.mjs} +3 -50
- package/fesm2022/_option-chunk.mjs.map +1 -0
- package/fesm2022/_tabs-chunk.mjs +1 -1
- package/fesm2022/_toolbar-widget-group-chunk.mjs +1 -1
- package/fesm2022/_transforms-chunk.mjs +8 -0
- package/fesm2022/_transforms-chunk.mjs.map +1 -0
- package/fesm2022/{_combobox-tree-chunk.mjs → _tree-chunk.mjs} +3 -48
- package/fesm2022/_tree-chunk.mjs.map +1 -0
- package/fesm2022/_widget-chunk.mjs +36 -15
- package/fesm2022/_widget-chunk.mjs.map +1 -1
- package/fesm2022/accordion.mjs +28 -55
- package/fesm2022/accordion.mjs.map +1 -1
- package/fesm2022/aria.mjs +1 -1
- package/fesm2022/aria.mjs.map +1 -1
- package/fesm2022/combobox-testing.mjs +79 -0
- package/fesm2022/combobox-testing.mjs.map +1 -0
- package/fesm2022/combobox.mjs +273 -307
- package/fesm2022/combobox.mjs.map +1 -1
- package/fesm2022/grid-testing.mjs +8 -0
- package/fesm2022/grid-testing.mjs.map +1 -1
- package/fesm2022/grid.mjs +68 -87
- package/fesm2022/grid.mjs.map +1 -1
- package/fesm2022/listbox-testing.mjs +4 -0
- package/fesm2022/listbox-testing.mjs.map +1 -1
- package/fesm2022/listbox.mjs +184 -205
- package/fesm2022/listbox.mjs.map +1 -1
- package/fesm2022/menu-testing.mjs +11 -0
- package/fesm2022/menu-testing.mjs.map +1 -1
- package/fesm2022/menu.mjs +42 -66
- package/fesm2022/menu.mjs.map +1 -1
- package/fesm2022/private.mjs +19 -13
- package/fesm2022/private.mjs.map +1 -1
- package/fesm2022/tabs.mjs +78 -84
- package/fesm2022/tabs.mjs.map +1 -1
- package/fesm2022/toolbar-testing.mjs +5 -1
- package/fesm2022/toolbar-testing.mjs.map +1 -1
- package/fesm2022/toolbar.mjs +21 -31
- package/fesm2022/toolbar.mjs.map +1 -1
- package/fesm2022/tree-testing.mjs +12 -0
- package/fesm2022/tree-testing.mjs.map +1 -1
- package/fesm2022/tree.mjs +118 -146
- package/fesm2022/tree.mjs.map +1 -1
- package/package.json +6 -6
- package/types/_accordion-chunk.d.ts +2 -2
- package/types/_collection-chunk.d.ts +42 -0
- package/types/_expansion-chunk.d.ts +1 -1
- package/types/_grid-chunk.d.ts +9 -3
- package/types/_keyboard-event-manager-chunk.d.ts +1 -1
- package/types/_list-chunk.d.ts +1 -1
- package/types/_list-navigation-chunk.d.ts +1 -1
- package/types/_listbox-chunk.d.ts +1 -1
- package/types/_menu-chunk.d.ts +1 -1
- package/types/_tabs-chunk.d.ts +1 -1
- package/types/_toolbar-chunk.d.ts +1 -1
- package/types/_tree-chunk.d.ts +1 -1
- package/types/accordion.d.ts +7 -13
- package/types/combobox-testing.d.ts +63 -0
- package/types/combobox.d.ts +96 -193
- package/types/grid-testing.d.ts +4 -0
- package/types/grid.d.ts +101 -97
- package/types/listbox-testing.d.ts +25 -0
- package/types/listbox.d.ts +55 -60
- package/types/menu-testing.d.ts +6 -0
- package/types/menu.d.ts +17 -13
- package/types/private.d.ts +24 -138
- package/types/tabs.d.ts +69 -72
- package/types/toolbar-testing.d.ts +4 -0
- package/types/toolbar.d.ts +5 -6
- package/types/tree-testing.d.ts +8 -0
- package/types/tree.d.ts +7 -14
- package/fesm2022/_combobox-chunk.mjs +0 -478
- package/fesm2022/_combobox-chunk.mjs.map +0 -1
- package/fesm2022/_combobox-listbox-chunk.mjs.map +0 -1
- package/fesm2022/_combobox-tree-chunk.mjs.map +0 -1
- package/fesm2022/_element-chunk.mjs +0 -6
- package/fesm2022/_element-chunk.mjs.map +0 -1
- package/fesm2022/_signal-like-chunk.mjs.map +0 -1
- package/fesm2022/simple-combobox.mjs +0 -443
- package/fesm2022/simple-combobox.mjs.map +0 -1
- package/types/_combobox-chunk.d.ts +0 -224
- package/types/_element-chunk.d.ts +0 -10
- package/types/_signal-like-chunk.d.ts +0 -14
- package/types/simple-combobox.d.ts +0 -124
package/fesm2022/private.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"private.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/private/simple-combobox/simple-combobox.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {KeyboardEventManager, ClickEventManager} from '../behaviors/event-manager';\nimport {computed, signal, untracked} from '@angular/core';\nimport {SignalLike, WritableSignalLike} from '../behaviors/signal-like/signal-like';\nimport {ExpansionItem} from '../behaviors/expansion/expansion';\n\n/** Represents the required inputs for a simple combobox. */\nexport interface SimpleComboboxInputs extends ExpansionItem {\n /** Whether the combobox should always remain expanded. */\n alwaysExpanded: SignalLike<boolean>;\n\n /** The value of the combobox. */\n value: WritableSignalLike<string>;\n\n /** The element that the combobox is attached to. */\n element: SignalLike<HTMLElement>;\n\n /** The popup associated with the combobox. */\n popup: SignalLike<SimpleComboboxPopupPattern | undefined>;\n\n /** An inline suggestion to be displayed in the input. */\n inlineSuggestion: SignalLike<string | undefined>;\n\n /** Whether the combobox is disabled. */\n disabled: SignalLike<boolean>;\n}\n\n/** Controls the state of a simple combobox. */\nexport class SimpleComboboxPattern {\n /** The expanded state of the combobox. */\n readonly isExpanded = computed(() => this.inputs.alwaysExpanded() || this.inputs.expanded());\n\n /** The value of the combobox. */\n readonly value: WritableSignalLike<string>;\n\n /** The element that the combobox is attached to. */\n readonly element = () => this.inputs.element();\n\n /** Whether the combobox is disabled. */\n readonly disabled = () => this.inputs.disabled();\n\n /** An inline suggestion to be displayed in the input. */\n readonly inlineSuggestion = () => this.inputs.inlineSuggestion();\n\n /** The ID of the active descendant in the popup. */\n readonly activeDescendant = computed(() => this.inputs.popup()?.activeDescendant());\n\n /** The ID of the popup. */\n readonly popupId = computed(() => this.inputs.popup()?.popupId());\n\n /** The type of the popup. */\n readonly popupType = computed(() => this.inputs.popup()?.popupType());\n\n /** The autocomplete behavior of the combobox. */\n readonly autocomplete = computed<'none' | 'inline' | 'list' | 'both'>(() => {\n const popupType = this.popupType();\n const hasAutocompletePopup = !!this.inputs.popup() && popupType !== 'dialog';\n const hasInlineSuggestion = !!this.inlineSuggestion();\n if (hasAutocompletePopup && hasInlineSuggestion) {\n return 'both';\n }\n if (hasAutocompletePopup) {\n return 'list';\n }\n if (hasInlineSuggestion) {\n return 'inline';\n }\n return 'none';\n });\n\n /** A relay for keyboard events to the popup. */\n readonly keyboardEventRelay = signal<KeyboardEvent | undefined>(undefined);\n\n /** Whether the combobox is focused. */\n readonly isFocused = signal(false);\n\n /** Whether the most recent input event was a deletion. */\n readonly isDeleting = signal(false);\n\n /** Whether the combobox is editable (i.e., an input or textarea). */\n readonly isEditable = computed(\n () =>\n this.element().tagName.toLowerCase() === 'input' ||\n this.element().tagName.toLowerCase() === 'textarea',\n );\n\n /** The keydown event manager for the combobox. */\n // TODO(tjshiu): Allow combo keys in combobox (#33101).\n keydown = computed(() => {\n const manager = new KeyboardEventManager();\n\n if (!this.isExpanded()) {\n manager.on('ArrowDown', () => this.inputs.expanded.set(true));\n\n if (!this.isEditable()) {\n manager.on(/^(Enter| )$/, () => this.inputs.expanded.set(true));\n }\n\n return manager;\n }\n\n manager\n .on(\n 'ArrowLeft',\n e => {\n this.keyboardEventRelay.set(e);\n },\n {preventDefault: this.popupType() !== 'listbox', ignoreRepeat: false},\n )\n .on(\n 'ArrowRight',\n e => {\n this.keyboardEventRelay.set(e);\n },\n {preventDefault: this.popupType() !== 'listbox', ignoreRepeat: false},\n )\n .on('ArrowUp', e => this.keyboardEventRelay.set(e), {ignoreRepeat: false})\n .on('ArrowDown', e => this.keyboardEventRelay.set(e), {ignoreRepeat: false})\n .on('Home', e => this.keyboardEventRelay.set(e))\n .on('End', e => this.keyboardEventRelay.set(e))\n .on('Enter', e => this.keyboardEventRelay.set(e))\n .on('PageUp', e => this.keyboardEventRelay.set(e))\n .on('PageDown', e => this.keyboardEventRelay.set(e))\n .on('Escape', () => {\n if (!this.inputs.alwaysExpanded()) {\n this.inputs.expanded.set(false);\n }\n });\n\n if (!this.isEditable()) {\n manager\n .on(' ', e => this.keyboardEventRelay.set(e))\n .on(/^.$/, e => {\n this.keyboardEventRelay.set(e);\n });\n }\n\n return manager;\n });\n\n /** The click event manager for the combobox. */\n click = computed(() => {\n const manager = new ClickEventManager<PointerEvent>();\n\n if (this.isEditable()) return manager;\n\n manager.on(() => this.inputs.expanded.update(v => !v));\n\n return manager;\n });\n\n constructor(readonly inputs: SimpleComboboxInputs) {\n this.value = inputs.value;\n }\n\n /** Handles keydown events for the combobox. */\n onKeydown(event: KeyboardEvent) {\n if (!this.inputs.disabled()) {\n this.keydown().handle(event);\n }\n }\n\n /** Handles click events for the combobox. */\n onClick(event: PointerEvent) {\n if (!this.disabled()) {\n this.click().handle(event);\n }\n }\n\n /** Handles focus in events for the combobox. */\n onFocusin() {\n this.isFocused.set(true);\n }\n\n /** Handles focus out events for the combobox. */\n onFocusout(event: FocusEvent) {\n this.isFocused.set(false);\n }\n\n /** Handles input events for the combobox. */\n onInput(event: Event) {\n if (!(event.target instanceof HTMLInputElement)) return;\n if (this.disabled()) return;\n\n this.inputs.expanded.set(true);\n this.value.set(event.target.value);\n this.isDeleting.set(event instanceof InputEvent && !!event.inputType.match(/^delete/));\n }\n\n /** Highlights the currently selected item in the combobox. */\n highlightEffect() {\n const value = this.value();\n const inlineSuggestion = this.inlineSuggestion();\n\n const isDeleting = untracked(() => this.isDeleting());\n const isFocused = untracked(() => this.isFocused());\n const isExpanded = this.isExpanded();\n\n if (!inlineSuggestion || !isFocused || !isExpanded || isDeleting) return;\n\n const inputEl = this.element() as HTMLInputElement;\n const isHighlightable = inlineSuggestion.toLowerCase().startsWith(value.toLowerCase());\n\n if (isHighlightable) {\n inputEl.value = value + inlineSuggestion.slice(value.length);\n inputEl.setSelectionRange(value.length, inlineSuggestion.length);\n }\n }\n\n /** Relays keyboard events to the popup. */\n keyboardEventRelayEffect() {\n const event = this.keyboardEventRelay();\n if (event === undefined) return;\n\n const popup = untracked(() => this.inputs.popup());\n const popupExpanded = untracked(() => this.isExpanded());\n if (popupExpanded) {\n popup?.controlTarget()?.dispatchEvent(event);\n }\n }\n\n /** Closes the popup when focus leaves the combobox and popup. */\n closePopupOnBlurEffect() {\n const expanded = this.isExpanded();\n const comboboxFocused = this.isFocused();\n const popupFocused = !!this.inputs.popup()?.isFocused();\n if (expanded && !this.inputs.alwaysExpanded() && !comboboxFocused && !popupFocused) {\n this.inputs.expanded.set(false);\n }\n }\n}\n\n/** Represents the required inputs for a simple combobox popup. */\nexport interface SimpleComboboxPopupInputs {\n /** The type of the popup. */\n popupType: SignalLike<'listbox' | 'tree' | 'grid' | 'dialog'>;\n\n /** The element that serves as the control target for the popup. */\n controlTarget: SignalLike<HTMLElement | undefined>;\n\n /** The ID of the active descendant in the popup. */\n activeDescendant: SignalLike<string | undefined>;\n\n /** The ID of the popup. */\n popupId: SignalLike<string | undefined>;\n}\n\n/** Controls the state of a simple combobox popup. */\nexport class SimpleComboboxPopupPattern {\n /** The type of the popup. */\n readonly popupType = () => this.inputs.popupType();\n\n /** The element that serves as the control target for the popup. */\n readonly controlTarget = () => this.inputs.controlTarget();\n\n /** The ID of the active descendant in the popup. */\n readonly activeDescendant = () => this.inputs.activeDescendant();\n\n /** The ID of the popup. */\n readonly popupId = () => this.inputs.popupId();\n\n /** Whether the popup is focused. */\n readonly isFocused = signal(false);\n\n constructor(readonly inputs: SimpleComboboxPopupInputs) {}\n\n /** Handles focus in events for the popup. */\n onFocusin() {\n this.isFocused.set(true);\n }\n\n /** Handles focus out events for the popup. */\n onFocusout(event: FocusEvent) {\n const focusTarget = event.relatedTarget as Element | null;\n if (this.controlTarget()?.contains(focusTarget)) return;\n\n this.isFocused.set(false);\n }\n}\n"],"names":["SimpleComboboxPattern","inputs","isExpanded","computed","alwaysExpanded","expanded","value","element","disabled","inlineSuggestion","activeDescendant","popup","popupId","popupType","autocomplete","hasAutocompletePopup","hasInlineSuggestion","keyboardEventRelay","signal","undefined","isFocused","isDeleting","isEditable","tagName","toLowerCase","keydown","manager","KeyboardEventManager","on","set","e","preventDefault","ignoreRepeat","click","ClickEventManager","update","v","constructor","onKeydown","event","handle","onClick","onFocusin","onFocusout","onInput","target","HTMLInputElement","InputEvent","inputType","match","highlightEffect","untracked","inputEl","isHighlightable","startsWith","slice","length","setSelectionRange","keyboardEventRelayEffect","popupExpanded","controlTarget","dispatchEvent","closePopupOnBlurEffect","comboboxFocused","popupFocused","SimpleComboboxPopupPattern","focusTarget","relatedTarget","contains"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"private.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/private/combobox/combobox.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {KeyboardEventManager, ClickEventManager, Modifier} from '../behaviors/event-manager';\nimport {computed, signal, untracked} from '@angular/core';\nimport {SignalLike, WritableSignalLike} from '../behaviors/signal-like/signal-like';\nimport {ExpansionItem} from '../behaviors/expansion/expansion';\n\n/** Represents the required inputs for a simple combobox. */\nexport interface ComboboxInputs extends ExpansionItem {\n /** Whether the combobox should always remain expanded. */\n alwaysExpanded: SignalLike<boolean>;\n\n /** The value of the combobox. */\n value: WritableSignalLike<string>;\n\n /** The element that the combobox is attached to. */\n element: SignalLike<HTMLElement>;\n\n /** The popup associated with the combobox. */\n popup: SignalLike<ComboboxPopupPattern | undefined>;\n\n /** An inline suggestion to be displayed in the input. */\n inlineSuggestion: SignalLike<string | undefined>;\n\n /** Whether the combobox is disabled. */\n disabled: SignalLike<boolean>;\n\n /** Whether the combobox is soft disabled. */\n softDisabled?: SignalLike<boolean>;\n}\n\n/** Controls the state of a simple combobox. */\nexport class ComboboxPattern {\n /** The expanded state of the combobox. */\n readonly isExpanded = computed(() => this.inputs.alwaysExpanded() || this.inputs.expanded());\n\n /** The value of the combobox. */\n readonly value: WritableSignalLike<string>;\n\n /** The element that the combobox is attached to. */\n readonly element = () => this.inputs.element();\n\n /** Whether the combobox is disabled. */\n readonly disabled = () => this.inputs.disabled();\n\n /** Whether the combobox is soft disabled. */\n readonly softDisabled = () => this.inputs.softDisabled?.() ?? true;\n\n /** An inline suggestion to be displayed in the input. */\n readonly inlineSuggestion = () => this.inputs.inlineSuggestion();\n\n /** The ID of the active descendant in the popup. */\n readonly activeDescendant = computed(() => this.inputs.popup()?.activeDescendant());\n\n /** The ID of the popup. */\n readonly popupId = computed(() => this.inputs.popup()?.popupId());\n\n /** The type of the popup. */\n readonly popupType = computed(() => this.inputs.popup()?.popupType());\n\n /** The autocomplete behavior of the combobox. */\n readonly autocomplete = computed<'none' | 'inline' | 'list' | 'both'>(() => {\n const popupType = this.popupType();\n const hasAutocompletePopup = !!this.inputs.popup() && popupType !== 'dialog';\n const hasInlineSuggestion = !!this.inlineSuggestion();\n if (hasAutocompletePopup && hasInlineSuggestion) {\n return 'both';\n }\n if (hasAutocompletePopup) {\n return 'list';\n }\n if (hasInlineSuggestion) {\n return 'inline';\n }\n return 'none';\n });\n\n /** A relay for keyboard events to the popup. */\n readonly keyboardEventRelay = signal<KeyboardEvent | undefined>(undefined);\n\n /** Whether the combobox is focused. */\n readonly isFocused = signal(false);\n\n /** Whether the most recent input event was a deletion. */\n readonly isDeleting = signal(false);\n\n /** Whether the combobox is editable (i.e., an input or textarea). */\n readonly isEditable = computed(\n () =>\n this.element().tagName.toLowerCase() === 'input' ||\n this.element().tagName.toLowerCase() === 'textarea',\n );\n\n /** The keydown event manager for the combobox. */\n // TODO(tjshiu): Allow combo keys in combobox (#33101).\n keydown = computed(() => {\n const manager = new KeyboardEventManager();\n\n if (!this.isExpanded()) {\n manager.on('ArrowDown', () => this.inputs.expanded.set(true));\n\n if (!this.isEditable()) {\n manager.on('Enter', () => this.inputs.expanded.set(true));\n manager.on(' ', () => this.inputs.expanded.set(true));\n }\n\n return manager;\n }\n\n manager\n .on(\n 'ArrowLeft',\n e => {\n this.keyboardEventRelay.set(e);\n },\n {preventDefault: this.popupType() !== 'listbox', ignoreRepeat: false},\n )\n .on(\n 'ArrowRight',\n e => {\n this.keyboardEventRelay.set(e);\n },\n {preventDefault: this.popupType() !== 'listbox', ignoreRepeat: false},\n )\n .on('ArrowUp', e => this.keyboardEventRelay.set(e), {ignoreRepeat: false})\n .on('ArrowDown', e => this.keyboardEventRelay.set(e), {ignoreRepeat: false})\n .on(Modifier.Shift, 'ArrowUp', e => this.keyboardEventRelay.set(e), {ignoreRepeat: false})\n .on(Modifier.Shift, 'ArrowDown', e => this.keyboardEventRelay.set(e), {ignoreRepeat: false})\n .on('Home', e => this.keyboardEventRelay.set(e))\n .on('End', e => this.keyboardEventRelay.set(e))\n .on('Enter', e => this.keyboardEventRelay.set(e))\n .on('PageUp', e => this.keyboardEventRelay.set(e))\n .on('PageDown', e => this.keyboardEventRelay.set(e))\n .on('Escape', () => {\n if (!this.inputs.alwaysExpanded()) {\n this.inputs.expanded.set(false);\n }\n });\n\n if (!this.isEditable()) {\n manager\n .on(' ', e => this.keyboardEventRelay.set(e))\n .on([Modifier.Ctrl, Modifier.Meta], 'a', e => this.keyboardEventRelay.set(e))\n .on([Modifier.Ctrl, Modifier.Meta], 'A', e => this.keyboardEventRelay.set(e))\n .on(Modifier.Shift, 'Home', e => this.keyboardEventRelay.set(e))\n .on(Modifier.Shift, 'End', e => this.keyboardEventRelay.set(e))\n .on(/^.$/, e => {\n this.keyboardEventRelay.set(e);\n });\n }\n\n return manager;\n });\n\n /** The click event manager for the combobox. */\n click = computed(() => {\n const manager = new ClickEventManager<PointerEvent>();\n\n if (this.isEditable()) return manager;\n\n manager.on(() => this.inputs.expanded.update(v => !v));\n\n return manager;\n });\n\n constructor(readonly inputs: ComboboxInputs) {\n this.value = inputs.value;\n }\n\n /** Handles keydown events for the combobox. */\n onKeydown(event: KeyboardEvent) {\n if (!this.inputs.disabled()) {\n this.keydown().handle(event);\n }\n }\n\n /** Handles click events for the combobox. */\n onClick(event: PointerEvent) {\n if (!this.disabled()) {\n this.click().handle(event);\n }\n }\n\n /** Handles focus in events for the combobox. */\n onFocusin() {\n this.isFocused.set(true);\n }\n\n /** Handles focus out events for the combobox. */\n onFocusout(event: FocusEvent) {\n this.isFocused.set(false);\n }\n\n /** Handles input events for the combobox. */\n onInput(event: Event) {\n if (!(event.target instanceof HTMLInputElement)) return;\n if (this.disabled()) return;\n\n this.inputs.expanded.set(true);\n this.value.set(event.target.value);\n this.isDeleting.set(event instanceof InputEvent && !!event.inputType.match(/^delete/));\n }\n\n /** Highlights the currently selected item in the combobox. */\n highlightEffect() {\n const value = this.value();\n const inlineSuggestion = this.inlineSuggestion();\n\n const isDeleting = untracked(() => this.isDeleting());\n const isFocused = untracked(() => this.isFocused());\n const isExpanded = this.isExpanded();\n\n if (!inlineSuggestion || !isFocused || !isExpanded || isDeleting) return;\n\n const inputEl = this.element() as HTMLInputElement;\n const isHighlightable = inlineSuggestion.toLowerCase().startsWith(value.toLowerCase());\n\n if (isHighlightable) {\n inputEl.value = value + inlineSuggestion.slice(value.length);\n inputEl.setSelectionRange(value.length, inlineSuggestion.length);\n }\n }\n\n /** Relays keyboard events to the popup. */\n keyboardEventRelayEffect() {\n const event = this.keyboardEventRelay();\n if (event === undefined) return;\n\n // Reset isDeleting when the user navigates, so that the highlight effect can run again.\n this.isDeleting.set(false);\n\n const popup = untracked(() => this.inputs.popup());\n const popupExpanded = untracked(() => this.isExpanded());\n if (popupExpanded) {\n popup?.controlTarget()?.dispatchEvent(event);\n }\n }\n\n /** Closes the popup when focus leaves the combobox and popup. */\n closePopupOnBlurEffect() {\n const expanded = this.isExpanded();\n const comboboxFocused = this.isFocused();\n const popupFocused = !!this.inputs.popup()?.isFocused();\n if (expanded && !this.inputs.alwaysExpanded() && !comboboxFocused && !popupFocused) {\n this.inputs.expanded.set(false);\n }\n }\n}\n\n/** Represents the required inputs for a simple combobox popup. */\nexport interface ComboboxPopupInputs {\n /** The type of the popup. */\n popupType: SignalLike<'listbox' | 'tree' | 'grid' | 'dialog'>;\n\n /** The element that serves as the control target for the popup. */\n controlTarget: SignalLike<HTMLElement | undefined>;\n\n /** The ID of the active descendant in the popup. */\n activeDescendant: SignalLike<string | undefined>;\n\n /** The ID of the popup. */\n popupId: SignalLike<string | undefined>;\n}\n\n/** Controls the state of a simple combobox popup. */\nexport class ComboboxPopupPattern {\n /** The type of the popup. */\n readonly popupType = () => this.inputs.popupType();\n\n /** The element that serves as the control target for the popup. */\n readonly controlTarget = () => this.inputs.controlTarget();\n\n /** The ID of the active descendant in the popup. */\n readonly activeDescendant = () => this.inputs.activeDescendant();\n\n /** The ID of the popup. */\n readonly popupId = () => this.inputs.popupId();\n\n /** Whether the popup is focused. */\n readonly isFocused = signal(false);\n\n constructor(readonly inputs: ComboboxPopupInputs) {}\n\n /** Handles focus in events for the popup. */\n onFocusin() {\n this.isFocused.set(true);\n }\n\n /** Handles focus out events for the popup. */\n onFocusout(event: FocusEvent) {\n const focusTarget = event.relatedTarget as Element | null;\n if (this.controlTarget()?.contains(focusTarget)) return;\n\n this.isFocused.set(false);\n }\n}\n"],"names":["ComboboxPattern","inputs","isExpanded","computed","alwaysExpanded","expanded","value","element","disabled","softDisabled","inlineSuggestion","activeDescendant","popup","popupId","popupType","autocomplete","hasAutocompletePopup","hasInlineSuggestion","keyboardEventRelay","signal","undefined","isFocused","isDeleting","isEditable","tagName","toLowerCase","keydown","manager","KeyboardEventManager","on","set","e","preventDefault","ignoreRepeat","Modifier","Shift","Ctrl","Meta","click","ClickEventManager","update","v","constructor","onKeydown","event","handle","onClick","onFocusin","onFocusout","onInput","target","HTMLInputElement","InputEvent","inputType","match","highlightEffect","untracked","inputEl","isHighlightable","startsWith","slice","length","setSelectionRange","keyboardEventRelayEffect","popupExpanded","controlTarget","dispatchEvent","closePopupOnBlurEffect","comboboxFocused","popupFocused","ComboboxPopupPattern","focusTarget","relatedTarget","contains"],"mappings":"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"}
|
package/fesm2022/tabs.mjs
CHANGED
|
@@ -1,15 +1,14 @@
|
|
|
1
1
|
import { _IdGenerator } from '@angular/cdk/a11y';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
|
-
import { InjectionToken, inject, ElementRef, signal, computed,
|
|
3
|
+
import { InjectionToken, inject, ElementRef, signal, computed, afterNextRender, Directive, input, booleanAttribute, model, linkedSignal, afterRenderEffect } from '@angular/core';
|
|
4
4
|
import { TabListPattern, TabPattern, TabPanelPattern } from './_tabs-chunk.mjs';
|
|
5
5
|
import { DeferredContentAware, DeferredContent } from './_deferred-content-chunk.mjs';
|
|
6
6
|
import { Directionality } from '@angular/cdk/bidi';
|
|
7
|
-
import {
|
|
7
|
+
import { SortedCollection } from './_collection-chunk.mjs';
|
|
8
8
|
import './_expansion-chunk.mjs';
|
|
9
|
-
import './_signal-like-chunk.mjs';
|
|
10
|
-
import '@angular/core/primitives/signals';
|
|
11
9
|
import './_list-navigation-chunk.mjs';
|
|
12
10
|
import './_click-event-manager-chunk.mjs';
|
|
11
|
+
import '@angular/core/primitives/signals';
|
|
13
12
|
|
|
14
13
|
const TABS = new InjectionToken('TABS');
|
|
15
14
|
const TAB_LIST = new InjectionToken('TAB_LIST');
|
|
@@ -20,46 +19,51 @@ class Tabs {
|
|
|
20
19
|
_tabList = signal(undefined, ...(ngDevMode ? [{
|
|
21
20
|
debugName: "_tabList"
|
|
22
21
|
}] : []));
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
_collection = new SortedCollection();
|
|
23
|
+
_tabPatterns = computed(() => this._tabList()?._tabPatterns(), ...(ngDevMode ? [{
|
|
24
|
+
debugName: "_tabPatterns"
|
|
25
25
|
}] : []));
|
|
26
|
-
|
|
27
|
-
debugName: "
|
|
26
|
+
_tabPanelPatterns = computed(() => this._collection.orderedItems().map(tabpanel => tabpanel._pattern), ...(ngDevMode ? [{
|
|
27
|
+
debugName: "_tabPanelPatterns"
|
|
28
28
|
}] : []));
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
29
|
+
_panelMap = computed(() => {
|
|
30
|
+
const map = new Map();
|
|
31
|
+
for (const panel of this._collection.orderedItems()) {
|
|
32
|
+
map.set(panel.value(), panel._pattern);
|
|
33
|
+
}
|
|
34
|
+
return map;
|
|
35
|
+
}, ...(ngDevMode ? [{
|
|
36
|
+
debugName: "_panelMap"
|
|
37
|
+
}] : []));
|
|
38
|
+
_tabMap = computed(() => {
|
|
39
|
+
const map = new Map();
|
|
40
|
+
const tabList = this._tabList();
|
|
41
|
+
if (tabList) {
|
|
42
|
+
for (const tab of tabList._collection.orderedItems()) {
|
|
43
|
+
map.set(tab.value(), tab._pattern);
|
|
40
44
|
}
|
|
45
|
+
}
|
|
46
|
+
return map;
|
|
47
|
+
}, ...(ngDevMode ? [{
|
|
48
|
+
debugName: "_tabMap"
|
|
49
|
+
}] : []));
|
|
50
|
+
constructor() {
|
|
51
|
+
afterNextRender(() => {
|
|
52
|
+
this._collection.startObserving(this.element);
|
|
41
53
|
});
|
|
42
54
|
}
|
|
43
|
-
|
|
44
|
-
this.
|
|
45
|
-
}
|
|
46
|
-
_unregisterList(list) {
|
|
47
|
-
this._tabList.set(undefined);
|
|
48
|
-
}
|
|
49
|
-
_registerPanel(panel) {
|
|
50
|
-
this._tabPanels().add(panel);
|
|
51
|
-
this._tabPanels.set(new Set(this._tabPanels()));
|
|
55
|
+
ngOnDestroy() {
|
|
56
|
+
this._collection.stopObserving();
|
|
52
57
|
}
|
|
53
|
-
|
|
54
|
-
this.
|
|
55
|
-
this._tabPanels.set(new Set(this._tabPanels()));
|
|
58
|
+
_register(child) {
|
|
59
|
+
this._tabList.set(child);
|
|
56
60
|
}
|
|
57
|
-
|
|
58
|
-
|
|
61
|
+
_unregister() {
|
|
62
|
+
this._tabList.set(undefined);
|
|
59
63
|
}
|
|
60
64
|
static ɵfac = i0.ɵɵngDeclareFactory({
|
|
61
65
|
minVersion: "12.0.0",
|
|
62
|
-
version: "22.0.0-next.
|
|
66
|
+
version: "22.0.0-next.10",
|
|
63
67
|
ngImport: i0,
|
|
64
68
|
type: Tabs,
|
|
65
69
|
deps: [],
|
|
@@ -67,7 +71,7 @@ class Tabs {
|
|
|
67
71
|
});
|
|
68
72
|
static ɵdir = i0.ɵɵngDeclareDirective({
|
|
69
73
|
minVersion: "14.0.0",
|
|
70
|
-
version: "22.0.0-next.
|
|
74
|
+
version: "22.0.0-next.10",
|
|
71
75
|
type: Tabs,
|
|
72
76
|
isStandalone: true,
|
|
73
77
|
selector: "[ngTabs]",
|
|
@@ -81,7 +85,7 @@ class Tabs {
|
|
|
81
85
|
}
|
|
82
86
|
i0.ɵɵngDeclareClassMetadata({
|
|
83
87
|
minVersion: "12.0.0",
|
|
84
|
-
version: "22.0.0-next.
|
|
88
|
+
version: "22.0.0-next.10",
|
|
85
89
|
ngImport: i0,
|
|
86
90
|
type: Tabs,
|
|
87
91
|
decorators: [{
|
|
@@ -102,13 +106,8 @@ class TabList {
|
|
|
102
106
|
_elementRef = inject(ElementRef);
|
|
103
107
|
element = this._elementRef.nativeElement;
|
|
104
108
|
_tabsParent = inject(TABS);
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
}] : []));
|
|
108
|
-
_sortedTabs = computed(() => [...this._tabs()].sort(sortDirectives), ...(ngDevMode ? [{
|
|
109
|
-
debugName: "_sortedTabs"
|
|
110
|
-
}] : []));
|
|
111
|
-
_tabPatterns = computed(() => [...this._sortedTabs()].map(tab => tab._pattern), ...(ngDevMode ? [{
|
|
109
|
+
_collection = new SortedCollection();
|
|
110
|
+
_tabPatterns = computed(() => this._collection.orderedItems().map(tab => tab._pattern), ...(ngDevMode ? [{
|
|
112
111
|
debugName: "_tabPatterns"
|
|
113
112
|
}] : []));
|
|
114
113
|
orientation = input('horizontal', ...(ngDevMode ? [{
|
|
@@ -156,40 +155,36 @@ class TabList {
|
|
|
156
155
|
selectedTab: this._selectedTabPattern
|
|
157
156
|
});
|
|
158
157
|
constructor() {
|
|
158
|
+
afterNextRender(() => {
|
|
159
|
+
this._collection.startObserving(this.element);
|
|
160
|
+
});
|
|
161
|
+
afterRenderEffect(() => {
|
|
162
|
+
this._pattern.setDefaultStateEffect();
|
|
163
|
+
});
|
|
159
164
|
afterRenderEffect({
|
|
160
165
|
write: () => {
|
|
161
166
|
const pattern = this._selectedTabPattern();
|
|
162
|
-
const tab = this.
|
|
167
|
+
const tab = this._collection.orderedItems().find(tab => tab._pattern == pattern);
|
|
163
168
|
this.selectedTab.set(tab?.value());
|
|
164
169
|
}
|
|
165
170
|
});
|
|
166
|
-
afterRenderEffect({
|
|
167
|
-
write: () => this._pattern.setDefaultStateEffect()
|
|
168
|
-
});
|
|
169
171
|
}
|
|
170
172
|
ngOnInit() {
|
|
171
|
-
this._tabsParent.
|
|
173
|
+
this._tabsParent._register(this);
|
|
172
174
|
}
|
|
173
175
|
ngOnDestroy() {
|
|
174
|
-
this._tabsParent.
|
|
175
|
-
|
|
176
|
-
_registerTab(child) {
|
|
177
|
-
this._tabs().add(child);
|
|
178
|
-
this._tabs.set(new Set(this._tabs()));
|
|
179
|
-
}
|
|
180
|
-
_unregisterTab(child) {
|
|
181
|
-
this._tabs().delete(child);
|
|
182
|
-
this._tabs.set(new Set(this._tabs()));
|
|
176
|
+
this._tabsParent._unregister();
|
|
177
|
+
this._collection.stopObserving();
|
|
183
178
|
}
|
|
184
179
|
open(value) {
|
|
185
180
|
return this._pattern.open(this.findTab(value)?._pattern);
|
|
186
181
|
}
|
|
187
182
|
findTab(value) {
|
|
188
|
-
return value ? this.
|
|
183
|
+
return value ? this._collection.orderedItems().find(tab => tab.value() === value) : undefined;
|
|
189
184
|
}
|
|
190
185
|
static ɵfac = i0.ɵɵngDeclareFactory({
|
|
191
186
|
minVersion: "12.0.0",
|
|
192
|
-
version: "22.0.0-next.
|
|
187
|
+
version: "22.0.0-next.10",
|
|
193
188
|
ngImport: i0,
|
|
194
189
|
type: TabList,
|
|
195
190
|
deps: [],
|
|
@@ -197,7 +192,7 @@ class TabList {
|
|
|
197
192
|
});
|
|
198
193
|
static ɵdir = i0.ɵɵngDeclareDirective({
|
|
199
194
|
minVersion: "17.1.0",
|
|
200
|
-
version: "22.0.0-next.
|
|
195
|
+
version: "22.0.0-next.10",
|
|
201
196
|
type: TabList,
|
|
202
197
|
isStandalone: true,
|
|
203
198
|
selector: "[ngTabList]",
|
|
@@ -281,7 +276,7 @@ class TabList {
|
|
|
281
276
|
}
|
|
282
277
|
i0.ɵɵngDeclareClassMetadata({
|
|
283
278
|
minVersion: "12.0.0",
|
|
284
|
-
version: "22.0.0-next.
|
|
279
|
+
version: "22.0.0-next.10",
|
|
285
280
|
ngImport: i0,
|
|
286
281
|
type: TabList,
|
|
287
282
|
decorators: [{
|
|
@@ -372,13 +367,14 @@ i0.ɵɵngDeclareClassMetadata({
|
|
|
372
367
|
class Tab {
|
|
373
368
|
_elementRef = inject(ElementRef);
|
|
374
369
|
element = this._elementRef.nativeElement;
|
|
375
|
-
_tabsWrapper = inject(TABS);
|
|
376
370
|
_tabList = inject(TAB_LIST);
|
|
377
371
|
id = input(inject(_IdGenerator).getId('ng-tab-', true), ...(ngDevMode ? [{
|
|
378
372
|
debugName: "id"
|
|
379
373
|
}] : []));
|
|
380
|
-
|
|
381
|
-
|
|
374
|
+
_tabpanelPattern = computed(() => {
|
|
375
|
+
return this._tabList._tabsParent._panelMap().get(this.value());
|
|
376
|
+
}, ...(ngDevMode ? [{
|
|
377
|
+
debugName: "_tabpanelPattern"
|
|
382
378
|
}] : []));
|
|
383
379
|
disabled = input(false, {
|
|
384
380
|
...(ngDevMode ? {
|
|
@@ -399,20 +395,20 @@ class Tab {
|
|
|
399
395
|
...this,
|
|
400
396
|
element: () => this.element,
|
|
401
397
|
tabList: () => this._tabList._pattern,
|
|
402
|
-
tabPanel:
|
|
398
|
+
tabPanel: this._tabpanelPattern
|
|
403
399
|
});
|
|
404
400
|
open() {
|
|
405
401
|
this._pattern.open();
|
|
406
402
|
}
|
|
407
403
|
ngOnInit() {
|
|
408
|
-
this._tabList.
|
|
404
|
+
this._tabList._collection.register(this);
|
|
409
405
|
}
|
|
410
406
|
ngOnDestroy() {
|
|
411
|
-
this._tabList.
|
|
407
|
+
this._tabList._collection.unregister(this);
|
|
412
408
|
}
|
|
413
409
|
static ɵfac = i0.ɵɵngDeclareFactory({
|
|
414
410
|
minVersion: "12.0.0",
|
|
415
|
-
version: "22.0.0-next.
|
|
411
|
+
version: "22.0.0-next.10",
|
|
416
412
|
ngImport: i0,
|
|
417
413
|
type: Tab,
|
|
418
414
|
deps: [],
|
|
@@ -420,7 +416,7 @@ class Tab {
|
|
|
420
416
|
});
|
|
421
417
|
static ɵdir = i0.ɵɵngDeclareDirective({
|
|
422
418
|
minVersion: "17.1.0",
|
|
423
|
-
version: "22.0.0-next.
|
|
419
|
+
version: "22.0.0-next.10",
|
|
424
420
|
type: Tab,
|
|
425
421
|
isStandalone: true,
|
|
426
422
|
selector: "[ngTab]",
|
|
@@ -466,7 +462,7 @@ class Tab {
|
|
|
466
462
|
}
|
|
467
463
|
i0.ɵɵngDeclareClassMetadata({
|
|
468
464
|
minVersion: "12.0.0",
|
|
469
|
-
version: "22.0.0-next.
|
|
465
|
+
version: "22.0.0-next.10",
|
|
470
466
|
ngImport: i0,
|
|
471
467
|
type: Tab,
|
|
472
468
|
decorators: [{
|
|
@@ -521,7 +517,9 @@ class TabPanel {
|
|
|
521
517
|
id = input(inject(_IdGenerator).getId('ng-tabpanel-', true), ...(ngDevMode ? [{
|
|
522
518
|
debugName: "id"
|
|
523
519
|
}] : []));
|
|
524
|
-
_tabPattern =
|
|
520
|
+
_tabPattern = computed(() => {
|
|
521
|
+
return this._tabs._tabMap().get(this.value());
|
|
522
|
+
}, ...(ngDevMode ? [{
|
|
525
523
|
debugName: "_tabPattern"
|
|
526
524
|
}] : []));
|
|
527
525
|
value = input.required(...(ngDevMode ? [{
|
|
@@ -535,21 +533,17 @@ class TabPanel {
|
|
|
535
533
|
tab: this._tabPattern
|
|
536
534
|
});
|
|
537
535
|
constructor() {
|
|
538
|
-
afterRenderEffect(
|
|
539
|
-
write: () => {
|
|
540
|
-
this._deferredContentAware.contentVisible.set(this.visible());
|
|
541
|
-
}
|
|
542
|
-
});
|
|
536
|
+
afterRenderEffect(() => this._deferredContentAware.contentVisible.set(this.visible()));
|
|
543
537
|
}
|
|
544
538
|
ngOnInit() {
|
|
545
|
-
this._tabs.
|
|
539
|
+
this._tabs._collection.register(this);
|
|
546
540
|
}
|
|
547
541
|
ngOnDestroy() {
|
|
548
|
-
this._tabs.
|
|
542
|
+
this._tabs._collection.unregister(this);
|
|
549
543
|
}
|
|
550
544
|
static ɵfac = i0.ɵɵngDeclareFactory({
|
|
551
545
|
minVersion: "12.0.0",
|
|
552
|
-
version: "22.0.0-next.
|
|
546
|
+
version: "22.0.0-next.10",
|
|
553
547
|
ngImport: i0,
|
|
554
548
|
type: TabPanel,
|
|
555
549
|
deps: [],
|
|
@@ -557,7 +551,7 @@ class TabPanel {
|
|
|
557
551
|
});
|
|
558
552
|
static ɵdir = i0.ɵɵngDeclareDirective({
|
|
559
553
|
minVersion: "17.1.0",
|
|
560
|
-
version: "22.0.0-next.
|
|
554
|
+
version: "22.0.0-next.10",
|
|
561
555
|
type: TabPanel,
|
|
562
556
|
isStandalone: true,
|
|
563
557
|
selector: "[ngTabPanel]",
|
|
@@ -598,7 +592,7 @@ class TabPanel {
|
|
|
598
592
|
}
|
|
599
593
|
i0.ɵɵngDeclareClassMetadata({
|
|
600
594
|
minVersion: "12.0.0",
|
|
601
|
-
version: "22.0.0-next.
|
|
595
|
+
version: "22.0.0-next.10",
|
|
602
596
|
ngImport: i0,
|
|
603
597
|
type: TabPanel,
|
|
604
598
|
decorators: [{
|
|
@@ -643,7 +637,7 @@ i0.ɵɵngDeclareClassMetadata({
|
|
|
643
637
|
class TabContent {
|
|
644
638
|
static ɵfac = i0.ɵɵngDeclareFactory({
|
|
645
639
|
minVersion: "12.0.0",
|
|
646
|
-
version: "22.0.0-next.
|
|
640
|
+
version: "22.0.0-next.10",
|
|
647
641
|
ngImport: i0,
|
|
648
642
|
type: TabContent,
|
|
649
643
|
deps: [],
|
|
@@ -651,7 +645,7 @@ class TabContent {
|
|
|
651
645
|
});
|
|
652
646
|
static ɵdir = i0.ɵɵngDeclareDirective({
|
|
653
647
|
minVersion: "14.0.0",
|
|
654
|
-
version: "22.0.0-next.
|
|
648
|
+
version: "22.0.0-next.10",
|
|
655
649
|
type: TabContent,
|
|
656
650
|
isStandalone: true,
|
|
657
651
|
selector: "ng-template[ngTabContent]",
|
|
@@ -664,7 +658,7 @@ class TabContent {
|
|
|
664
658
|
}
|
|
665
659
|
i0.ɵɵngDeclareClassMetadata({
|
|
666
660
|
minVersion: "12.0.0",
|
|
667
|
-
version: "22.0.0-next.
|
|
661
|
+
version: "22.0.0-next.10",
|
|
668
662
|
ngImport: i0,
|
|
669
663
|
type: TabContent,
|
|
670
664
|
decorators: [{
|
package/fesm2022/tabs.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tabs.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab-tokens.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tabs.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab-list.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab-panel.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab-content.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {InjectionToken} from '@angular/core';\nimport type {Tabs} from './tabs';\nimport type {TabList} from './tab-list';\n\n/** Token used to expose the `Tabs` directive to child directives. */\nexport const TABS = new InjectionToken<Tabs>('TABS');\n\n/** Token used to expose the tab list. */\nexport const TAB_LIST = new InjectionToken<TabList>('TAB_LIST');\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Directive, ElementRef, afterRenderEffect, computed, inject, signal} from '@angular/core';\nimport {TabList} from './tab-list';\nimport {TabPanel} from './tab-panel';\nimport {TABS} from './tab-tokens';\n\n/**\n * A Tabs container.\n *\n * The `ngTabs` directive represents a set of layered sections of content. It acts as the\n * overarching container for a tabbed interface, coordinating the behavior of `ngTabList`,\n * `ngTab`, and `ngTabPanel` directives.\n *\n * ```html\n * <div ngTabs>\n * <ul ngTabList [(selectedTab)]=\"selectedTabValue\">\n * <li ngTab value=\"tab1\">Tab 1</li>\n * <li ngTab value=\"tab2\">Tab 2</li>\n * <li ngTab value=\"tab3\">Tab 3</li>\n * </ul>\n *\n * <div ngTabPanel value=\"tab1\">\n * <ng-template ngTabContent>Content for Tab 1</ng-template>\n * </div>\n * <div ngTabPanel value=\"tab2\">\n * <ng-template ngTabContent>Content for Tab 2</ng-template>\n * </div>\n * <div ngTabPanel value=\"tab3\">\n * <ng-template ngTabContent>Content for Tab 3</ng-template>\n * </div>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: '[ngTabs]',\n exportAs: 'ngTabs',\n providers: [{provide: TABS, useExisting: Tabs}],\n})\nexport class Tabs {\n /** A reference to the host element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the host element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The TabList registered for this container. */\n private readonly _tabList = signal<TabList | undefined>(undefined);\n\n /** The TabPanels registered for this container. */\n private readonly _tabPanels = signal(new Set<TabPanel>());\n\n /** The TabPanels registered for this container. */\n private readonly _tabPanelsList = computed(() => [...this._tabPanels()]);\n\n constructor() {\n // This needs to be in an afterRenderEffect to ensure the tabs have all been initialized.\n // Otherwise, the lookup here can fail and it does not get re-run afterwards.\n afterRenderEffect({\n write: () => {\n if (this._tabList()) {\n for (const tab of this._tabList()!._sortedTabs()) {\n const panel = this._tabPanelsList().find(panel => panel === tab.panel());\n\n if (panel) {\n panel._tabPattern.set(tab._pattern);\n }\n }\n }\n },\n });\n }\n\n _registerList(list: TabList) {\n this._tabList.set(list);\n }\n\n _unregisterList(list: TabList) {\n this._tabList.set(undefined);\n }\n\n _registerPanel(panel: TabPanel) {\n this._tabPanels().add(panel);\n this._tabPanels.set(new Set(this._tabPanels()));\n }\n\n _unregisterPanel(panel: TabPanel) {\n this._tabPanels().delete(panel);\n this._tabPanels.set(new Set(this._tabPanels()));\n }\n\n findTabPanel(value?: string) {\n return value ? this._tabPanelsList().find(panel => panel.value() === value) : undefined;\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Directionality} from '@angular/cdk/bidi';\nimport {\n Directive,\n ElementRef,\n OnDestroy,\n OnInit,\n WritableSignal,\n afterRenderEffect,\n booleanAttribute,\n computed,\n inject,\n input,\n linkedSignal,\n model,\n signal,\n} from '@angular/core';\nimport {TabListPattern, TabPattern, sortDirectives} from '../private';\nimport {Tab} from './tab';\nimport {TABS, TAB_LIST} from './tab-tokens';\n\n/**\n * A TabList container.\n *\n * The `ngTabList` directive controls a list of `ngTab` elements. It manages keyboard\n * navigation, selection, and the overall orientation of the tabs. It should be placed\n * within an `ngTabs` container.\n *\n * ```html\n * <ul ngTabList [(selectedTab)]=\"mySelectedTab\" orientation=\"horizontal\" selectionMode=\"explicit\">\n * <li ngTab value=\"first\">First Tab</li>\n * <li ngTab value=\"second\">Second Tab</li>\n * </ul>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: '[ngTabList]',\n exportAs: 'ngTabList',\n host: {\n 'role': 'tablist',\n '[attr.tabindex]': '_pattern.tabIndex()',\n '[attr.aria-disabled]': '_pattern.disabled()',\n '[attr.aria-orientation]': '_pattern.orientation()',\n '[attr.aria-activedescendant]': '_pattern.activeDescendant()',\n '(keydown)': '_pattern.onKeydown($event)',\n '(click)': '_pattern.onClick($event)',\n '(focusin)': '_pattern.onFocusIn()',\n },\n providers: [{provide: TAB_LIST, useExisting: TabList}],\n})\nexport class TabList implements OnInit, OnDestroy {\n /** A reference to the host element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the host element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The parent Tabs container. */\n private readonly _tabsParent = inject(TABS);\n\n /** The Tabs registered for this TabList. */\n private readonly _tabs = signal(new Set<Tab>());\n\n /** The Tabs registered for this TabList. */\n readonly _sortedTabs = computed(() => [...this._tabs()].sort(sortDirectives));\n\n /** The Tab UIPatterns of the child Tabs. */\n private readonly _tabPatterns = computed(() => [...this._sortedTabs()].map(tab => tab._pattern));\n\n /** Whether the tablist is vertically or horizontally oriented. */\n readonly orientation = input<'vertical' | 'horizontal'>('horizontal');\n\n /** Text direction. */\n readonly textDirection = inject(Directionality).valueSignal;\n\n /** Whether focus should wrap when navigating. */\n readonly wrap = input(true, {transform: booleanAttribute});\n\n /**\n * Whether to allow disabled items to receive focus. When `true`, disabled items are\n * focusable but not interactive. When `false`, disabled items are skipped during navigation.\n */\n readonly softDisabled = input(true, {transform: booleanAttribute});\n\n /**\n * The focus strategy used by the tablist.\n * - `roving`: Focus is moved to the active tab using `tabindex`.\n * - `activedescendant`: Focus remains on the tablist container, and `aria-activedescendant` is used to indicate the active tab.\n */\n readonly focusMode = input<'roving' | 'activedescendant'>('roving');\n\n /**\n * The selection strategy used by the tablist.\n * - `follow`: The focused tab is automatically selected.\n * - `explicit`: Tabs are selected explicitly by the user (e.g., via click or spacebar).\n */\n readonly selectionMode = input<'follow' | 'explicit'>('follow');\n\n /** The current selected tab as a model input. */\n readonly selectedTab = model<string | undefined>();\n\n /** The current selected Tab pattern, passed to the List pattern. */\n private readonly _selectedTabPattern: WritableSignal<TabPattern | undefined> = linkedSignal(\n () => {\n const tab = this.findTab(this.selectedTab());\n\n return tab?._pattern;\n },\n );\n\n /** Whether the tablist is disabled. */\n readonly disabled = input(false, {transform: booleanAttribute});\n\n /** The TabList UIPattern. */\n readonly _pattern: TabListPattern = new TabListPattern({\n ...this,\n element: () => this._elementRef.nativeElement,\n activeItem: signal(undefined),\n items: this._tabPatterns,\n selectedTab: this._selectedTabPattern,\n });\n\n constructor() {\n // This needs to be in an afterRenderEffect to ensure the tabs have all been initialized.\n // Otherwise, the lookup here can fail and it does not get re-run afterwards.\n afterRenderEffect({\n write: () => {\n const pattern = this._selectedTabPattern();\n const tab = this._sortedTabs().find(tab => tab._pattern == pattern);\n\n this.selectedTab.set(tab?.value());\n },\n });\n\n afterRenderEffect({write: () => this._pattern.setDefaultStateEffect()});\n }\n\n ngOnInit() {\n this._tabsParent._registerList(this);\n }\n\n ngOnDestroy() {\n this._tabsParent._registerList(this);\n }\n\n _registerTab(child: Tab) {\n this._tabs().add(child);\n this._tabs.set(new Set(this._tabs()));\n }\n\n _unregisterTab(child: Tab) {\n this._tabs().delete(child);\n this._tabs.set(new Set(this._tabs()));\n }\n\n /** Opens the tab panel with the specified value. */\n open(value: string): boolean {\n return this._pattern.open(this.findTab(value)?._pattern);\n }\n\n findTab(value?: string) {\n return value ? this._sortedTabs().find(tab => tab.value() === value) : undefined;\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {_IdGenerator} from '@angular/cdk/a11y';\nimport {\n Directive,\n ElementRef,\n OnDestroy,\n OnInit,\n booleanAttribute,\n computed,\n inject,\n input,\n} from '@angular/core';\nimport {TabPattern, HasElement} from '../private';\nimport {TABS, TAB_LIST} from './tab-tokens';\n\n/**\n * A selectable tab in a TabList.\n *\n * The `ngTab` directive represents an individual tab control within an `ngTabList`. It\n * requires a `value` that uniquely identifies it and links it to a corresponding `ngTabPanel`.\n *\n * ```html\n * <li ngTab value=\"myTabId\" [disabled]=\"isTabDisabled\">\n * My Tab Label\n * </li>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: '[ngTab]',\n exportAs: 'ngTab',\n host: {\n 'role': 'tab',\n '[attr.data-active]': 'active()',\n '[attr.id]': '_pattern.id()',\n '[attr.tabindex]': '_pattern.tabIndex()',\n '[attr.aria-selected]': 'selected()',\n '[attr.aria-disabled]': '_pattern.disabled()',\n '[attr.aria-controls]': '_pattern.controls()',\n },\n})\nexport class Tab implements HasElement, OnInit, OnDestroy {\n /** A reference to the host element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the host element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The parent Tabs wrapper. */\n private readonly _tabsWrapper = inject(TABS);\n\n /** The parent TabList. */\n private readonly _tabList = inject(TAB_LIST);\n\n /** A unique identifier for the widget. */\n readonly id = input(inject(_IdGenerator).getId('ng-tab-', true));\n\n /** The panel associated with this tab. */\n readonly panel = computed(() => this._tabsWrapper.findTabPanel(this.value()));\n\n /** Whether a tab is disabled. */\n readonly disabled = input(false, {transform: booleanAttribute});\n\n /** The remote tabpanel unique identifier. */\n readonly value = input.required<string>();\n\n /** Whether the tab is active. */\n readonly active = computed(() => this._pattern.active());\n\n /** Whether the tab is selected. */\n readonly selected = computed(() => this._pattern.selected());\n\n /** The Tab UIPattern. */\n readonly _pattern: TabPattern = new TabPattern({\n ...this,\n element: () => this.element,\n tabList: () => this._tabList._pattern,\n tabPanel: computed(() => this.panel()?._pattern),\n });\n\n /** Opens this tab panel. */\n open() {\n this._pattern.open();\n }\n\n ngOnInit() {\n this._tabList._registerTab(this);\n }\n\n ngOnDestroy() {\n this._tabList._unregisterTab(this);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {_IdGenerator} from '@angular/cdk/a11y';\nimport {\n Directive,\n ElementRef,\n OnDestroy,\n OnInit,\n WritableSignal,\n afterRenderEffect,\n computed,\n inject,\n input,\n signal,\n} from '@angular/core';\nimport {TabPattern, TabPanelPattern, DeferredContentAware} from '../private';\nimport {TABS} from './tab-tokens';\n\n/**\n * A TabPanel container for the resources of layered content associated with a tab.\n *\n * The `ngTabPanel` directive holds the content for a specific tab. It is linked to an\n * `ngTab` by a matching `value`. If a tab panel is hidden, the `inert` attribute will be\n * applied to remove it from the accessibility tree. Proper styling is required for visual hiding.\n *\n * ```html\n * <div ngTabPanel value=\"myTabId\">\n * <ng-template ngTabContent>\n * <!-- Content for the tab panel -->\n * </ng-template>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: '[ngTabPanel]',\n exportAs: 'ngTabPanel',\n host: {\n 'role': 'tabpanel',\n '[attr.id]': '_pattern.id()',\n '[attr.tabindex]': '_pattern.tabIndex()',\n '[attr.inert]': '!visible() ? true : null',\n '[attr.aria-labelledby]': '_pattern.labelledBy()',\n },\n hostDirectives: [\n {\n directive: DeferredContentAware,\n inputs: ['preserveContent'],\n },\n ],\n})\nexport class TabPanel implements OnInit, OnDestroy {\n /** A reference to the host element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the host element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The DeferredContentAware host directive. */\n private readonly _deferredContentAware = inject(DeferredContentAware);\n\n /** The parent Tabs. */\n private readonly _tabs = inject(TABS);\n\n /** A global unique identifier for the tab. */\n readonly id = input(inject(_IdGenerator).getId('ng-tabpanel-', true));\n\n /** The Tab UIPattern associated with the tabpanel */\n readonly _tabPattern: WritableSignal<TabPattern | undefined> = signal(undefined);\n\n /** A local unique identifier for the tabpanel. */\n readonly value = input.required<string>();\n\n /** Whether the tab panel is visible. */\n readonly visible = computed(() => !this._pattern.hidden());\n\n /** The TabPanel UIPattern. */\n readonly _pattern: TabPanelPattern = new TabPanelPattern({\n ...this,\n tab: this._tabPattern,\n });\n\n constructor() {\n afterRenderEffect({\n write: () => {\n this._deferredContentAware.contentVisible.set(this.visible());\n },\n });\n }\n\n ngOnInit() {\n this._tabs._registerPanel(this);\n }\n\n ngOnDestroy() {\n this._tabs._unregisterPanel(this);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Directive} from '@angular/core';\nimport {DeferredContent} from '../private';\n\n/**\n * A TabContent container for the lazy-loaded content.\n *\n * This structural directive should be applied to an `ng-template` within an `ngTabPanel`.\n * It enables lazy loading of the tab's content, meaning the content is only rendered\n * when the tab is activated for the first time.\n *\n * ```html\n * <div ngTabPanel value=\"myTabId\">\n * <ng-template ngTabContent>\n * <p>This content will be loaded when 'myTabId' is selected.</p>\n * </ng-template>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: 'ng-template[ngTabContent]',\n exportAs: 'ngTabContent',\n hostDirectives: [DeferredContent],\n})\nexport class TabContent {}\n"],"names":["TABS","InjectionToken","TAB_LIST","Tabs","_elementRef","inject","ElementRef","element","nativeElement","_tabList","signal","undefined","_tabPanels","Set","_tabPanelsList","computed","constructor","afterRenderEffect","write","tab","_sortedTabs","panel","find","_tabPattern","set","_pattern","_registerList","list","_unregisterList","_registerPanel","add","_unregisterPanel","delete","findTabPanel","value","deps","target","i0","ɵɵFactoryTarget","Directive","isStandalone","selector","providers","provide","useExisting","exportAs","ngImport","decorators","args","TabList","_tabsParent","_tabs","sort","sortDirectives","_tabPatterns","map","orientation","input","textDirection","Directionality","valueSignal","wrap","transform","booleanAttribute","softDisabled","focusMode","selectionMode","selectedTab","model","_selectedTabPattern","linkedSignal","findTab","disabled","TabListPattern","activeItem","items","pattern","setDefaultStateEffect","ngOnInit","ngOnDestroy","_registerTab","child","_unregisterTab","open","inputs","classPropertyName","publicName","isSignal","isRequired","transformFunction","outputs","host","attributes","listeners","properties","Tab","_tabsWrapper","id","_IdGenerator","getId","required","active","selected","TabPattern","tabList","tabPanel","TabPanel","_deferredContentAware","DeferredContentAware","visible","hidden","TabPanelPattern","contentVisible","hostDirectives","directive","i1","TabContent","DeferredContent"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"tabs.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab-tokens.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tabs.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab-list.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab-panel.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/src/aria/tabs/tab-content.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {InjectionToken} from '@angular/core';\nimport type {Tabs} from './tabs';\nimport type {TabList} from './tab-list';\n\n/** Token used to expose the `Tabs` directive to child directives. */\nexport const TABS = new InjectionToken<Tabs>('TABS');\n\n/** Token used to expose the tab list. */\nexport const TAB_LIST = new InjectionToken<TabList>('TAB_LIST');\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n computed,\n Directive,\n ElementRef,\n inject,\n signal,\n afterNextRender,\n OnDestroy,\n} from '@angular/core';\nimport {TabList} from './tab-list';\nimport {TabPanel} from './tab-panel';\nimport {TABS} from './tab-tokens';\nimport {SortedCollection, TabPanelPattern, TabPattern} from '../private';\n\n/**\n * A Tabs container.\n *\n * The `ngTabs` directive represents a set of layered sections of content. It acts as the\n * overarching container for a tabbed interface, coordinating the behavior of `ngTabList`,\n * `ngTab`, and `ngTabPanel` directives.\n *\n * ```html\n * <div ngTabs>\n * <ul ngTabList [(selectedTab)]=\"selectedTabValue\">\n * <li ngTab value=\"tab1\">Tab 1</li>\n * <li ngTab value=\"tab2\">Tab 2</li>\n * <li ngTab value=\"tab3\">Tab 3</li>\n * </ul>\n *\n * <div ngTabPanel value=\"tab1\">\n * <ng-template ngTabContent>Content for Tab 1</ng-template>\n * </div>\n * <div ngTabPanel value=\"tab2\">\n * <ng-template ngTabContent>Content for Tab 2</ng-template>\n * </div>\n * <div ngTabPanel value=\"tab3\">\n * <ng-template ngTabContent>Content for Tab 3</ng-template>\n * </div>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: '[ngTabs]',\n exportAs: 'ngTabs',\n providers: [{provide: TABS, useExisting: Tabs}],\n})\nexport class Tabs implements OnDestroy {\n /** A reference to the host element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the host element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The TabList registered for this container. */\n readonly _tabList = signal<TabList | undefined>(undefined);\n\n /** The collection of TabPanels. */\n readonly _collection = new SortedCollection<TabPanel>();\n\n /** The Tab UIPattern of the child Tabs. */\n readonly _tabPatterns = computed<TabPattern[] | undefined>(() => this._tabList()?._tabPatterns());\n\n /** The TabPanel UIPattern of the child TabPanels. */\n readonly _tabPanelPatterns = computed<TabPanelPattern[]>(() =>\n this._collection.orderedItems().map(tabpanel => tabpanel._pattern),\n );\n\n /** A reactive map of tab values to their TabPanelPattern. */\n readonly _panelMap = computed(() => {\n const map = new Map<string, TabPanelPattern>();\n for (const panel of this._collection.orderedItems()) {\n map.set(panel.value(), panel._pattern);\n }\n return map;\n });\n\n /** A reactive map of tab values to their TabPattern. */\n readonly _tabMap = computed(() => {\n const map = new Map<string, TabPattern>();\n const tabList = this._tabList();\n if (tabList) {\n for (const tab of tabList._collection.orderedItems()) {\n map.set(tab.value(), tab._pattern);\n }\n }\n return map;\n });\n\n constructor() {\n afterNextRender(() => {\n this._collection.startObserving(this.element);\n });\n }\n\n ngOnDestroy() {\n this._collection.stopObserving();\n }\n\n _register(child: TabList) {\n this._tabList.set(child);\n }\n\n _unregister() {\n this._tabList.set(undefined);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Directionality} from '@angular/cdk/bidi';\nimport {\n booleanAttribute,\n computed,\n Directive,\n ElementRef,\n inject,\n input,\n model,\n signal,\n afterRenderEffect,\n OnInit,\n OnDestroy,\n afterNextRender,\n linkedSignal,\n WritableSignal,\n} from '@angular/core';\nimport {SortedCollection, TabListPattern, TabPattern} from '../private';\nimport {TABS, TAB_LIST} from './tab-tokens';\nimport type {Tab} from './tab';\n\n/**\n * A TabList container.\n *\n * The `ngTabList` directive controls a list of `ngTab` elements. It manages keyboard\n * navigation, selection, and the overall orientation of the tabs. It should be placed\n * within an `ngTabs` container.\n *\n * ```html\n * <ul ngTabList [(selectedTab)]=\"mySelectedTab\" orientation=\"horizontal\" selectionMode=\"explicit\">\n * <li ngTab value=\"first\">First Tab</li>\n * <li ngTab value=\"second\">Second Tab</li>\n * </ul>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: '[ngTabList]',\n exportAs: 'ngTabList',\n host: {\n 'role': 'tablist',\n '[attr.tabindex]': '_pattern.tabIndex()',\n '[attr.aria-disabled]': '_pattern.disabled()',\n '[attr.aria-orientation]': '_pattern.orientation()',\n '[attr.aria-activedescendant]': '_pattern.activeDescendant()',\n '(keydown)': '_pattern.onKeydown($event)',\n '(click)': '_pattern.onClick($event)',\n '(focusin)': '_pattern.onFocusIn()',\n },\n providers: [{provide: TAB_LIST, useExisting: TabList}],\n})\nexport class TabList implements OnInit, OnDestroy {\n /** A reference to the host element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the host element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The parent Tabs container. */\n readonly _tabsParent = inject(TABS);\n\n /** The collection of Tabs. */\n readonly _collection = new SortedCollection<Tab>();\n\n /** The Tab UIPatterns of the child Tabs. */\n readonly _tabPatterns = computed<TabPattern[]>(() =>\n this._collection.orderedItems().map(tab => tab._pattern),\n );\n\n /** Whether the tablist is vertically or horizontally oriented. */\n readonly orientation = input<'vertical' | 'horizontal'>('horizontal');\n\n /** Text direction. */\n readonly textDirection = inject(Directionality).valueSignal;\n\n /** Whether focus should wrap when navigating. */\n readonly wrap = input(true, {transform: booleanAttribute});\n\n /**\n * Whether to allow disabled items to receive focus. When `true`, disabled items are\n * focusable but not interactive. When `false`, disabled items are skipped during navigation.\n */\n readonly softDisabled = input(true, {transform: booleanAttribute});\n\n /**\n * The focus strategy used by the tablist.\n * - `roving`: Focus is moved to the active tab using `tabindex`.\n * - `activedescendant`: Focus remains on the tablist container, and `aria-activedescendant` is used to indicate the active tab.\n */\n readonly focusMode = input<'roving' | 'activedescendant'>('roving');\n\n /**\n * The selection strategy used by the tablist.\n * - `follow`: The focused tab is automatically selected.\n * - `explicit`: Tabs are selected explicitly by the user (e.g., via click or spacebar).\n */\n readonly selectionMode = input<'follow' | 'explicit'>('follow');\n\n /** The current selected tab as a model input. */\n readonly selectedTab = model<string | undefined>();\n\n /** The current selected Tab pattern, passed to the List pattern. */\n private readonly _selectedTabPattern: WritableSignal<TabPattern | undefined> = linkedSignal(\n () => {\n const tab = this.findTab(this.selectedTab());\n\n return tab?._pattern;\n },\n );\n\n /** Whether the tablist is disabled. */\n readonly disabled = input(false, {transform: booleanAttribute});\n\n /** The TabList UIPattern. */\n readonly _pattern: TabListPattern = new TabListPattern({\n ...this,\n element: () => this._elementRef.nativeElement,\n activeItem: signal(undefined),\n items: this._tabPatterns,\n selectedTab: this._selectedTabPattern,\n });\n\n constructor() {\n afterNextRender(() => {\n this._collection.startObserving(this.element);\n });\n\n afterRenderEffect(() => {\n this._pattern.setDefaultStateEffect();\n });\n\n // This needs to be in an afterRenderEffect to ensure the tabs have all been initialized.\n // Otherwise, the lookup here can fail and it does not get re-run afterwards.\n afterRenderEffect({\n write: () => {\n const pattern = this._selectedTabPattern();\n const tab = this._collection.orderedItems().find(tab => tab._pattern == pattern);\n this.selectedTab.set(tab?.value());\n },\n });\n }\n\n ngOnInit() {\n this._tabsParent._register(this);\n }\n\n ngOnDestroy() {\n this._tabsParent._unregister();\n this._collection.stopObserving();\n }\n\n /** Opens the tab panel with the specified value. */\n open(value: string): boolean {\n return this._pattern.open(this.findTab(value)?._pattern);\n }\n\n findTab(value?: string) {\n return value ? this._collection.orderedItems().find(tab => tab.value() === value) : undefined;\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {_IdGenerator} from '@angular/cdk/a11y';\nimport {\n Directive,\n ElementRef,\n OnInit,\n OnDestroy,\n booleanAttribute,\n computed,\n inject,\n input,\n} from '@angular/core';\nimport {TabPattern, HasElement} from '../private';\nimport {TAB_LIST} from './tab-tokens';\n\n/**\n * A selectable tab in a TabList.\n *\n * The `ngTab` directive represents an individual tab control within an `ngTabList`. It\n * requires a `value` that uniquely identifies it and links it to a corresponding `ngTabPanel`.\n *\n * ```html\n * <li ngTab value=\"myTabId\" [disabled]=\"isTabDisabled\">\n * My Tab Label\n * </li>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: '[ngTab]',\n exportAs: 'ngTab',\n host: {\n 'role': 'tab',\n '[attr.data-active]': 'active()',\n '[attr.id]': '_pattern.id()',\n '[attr.tabindex]': '_pattern.tabIndex()',\n '[attr.aria-selected]': 'selected()',\n '[attr.aria-disabled]': '_pattern.disabled()',\n '[attr.aria-controls]': '_pattern.controls()',\n },\n})\nexport class Tab implements HasElement, OnInit, OnDestroy {\n /** A reference to the host element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the host element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The parent TabList. */\n private readonly _tabList = inject(TAB_LIST);\n\n /** A unique identifier for the widget. */\n readonly id = input(inject(_IdGenerator).getId('ng-tab-', true));\n\n /** The TabPanel UIPattern associated with the tab */\n private readonly _tabpanelPattern = computed(() => {\n return this._tabList._tabsParent._panelMap().get(this.value());\n });\n\n /** Whether a tab is disabled. */\n readonly disabled = input(false, {transform: booleanAttribute});\n\n /** The remote tabpanel unique identifier. */\n readonly value = input.required<string>();\n\n /** Whether the tab is active. */\n readonly active = computed(() => this._pattern.active());\n\n /** Whether the tab is selected. */\n readonly selected = computed(() => this._pattern.selected());\n\n /** The Tab UIPattern. */\n readonly _pattern: TabPattern = new TabPattern({\n ...this,\n element: () => this.element,\n tabList: () => this._tabList._pattern,\n tabPanel: this._tabpanelPattern,\n });\n\n /** Opens this tab panel. */\n open() {\n this._pattern.open();\n }\n\n ngOnInit() {\n this._tabList._collection.register(this);\n }\n\n ngOnDestroy() {\n this._tabList._collection.unregister(this);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {_IdGenerator} from '@angular/cdk/a11y';\nimport {\n computed,\n Directive,\n ElementRef,\n inject,\n input,\n afterRenderEffect,\n OnInit,\n OnDestroy,\n} from '@angular/core';\nimport {TabPanelPattern, DeferredContentAware} from '../private';\nimport {TABS} from './tab-tokens';\n\n/**\n * A TabPanel container for the resources of layered content associated with a tab.\n *\n * The `ngTabPanel` directive holds the content for a specific tab. It is linked to an\n * `ngTab` by a matching `value`. If a tab panel is hidden, the `inert` attribute will be\n * applied to remove it from the accessibility tree. Proper styling is required for visual hiding.\n *\n * ```html\n * <div ngTabPanel value=\"myTabId\">\n * <ng-template ngTabContent>\n * <!-- Content for the tab panel -->\n * </ng-template>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: '[ngTabPanel]',\n exportAs: 'ngTabPanel',\n host: {\n 'role': 'tabpanel',\n '[attr.id]': '_pattern.id()',\n '[attr.tabindex]': '_pattern.tabIndex()',\n '[attr.inert]': '!visible() ? true : null',\n '[attr.aria-labelledby]': '_pattern.labelledBy()',\n },\n hostDirectives: [\n {\n directive: DeferredContentAware,\n inputs: ['preserveContent'],\n },\n ],\n})\nexport class TabPanel implements OnInit, OnDestroy {\n /** A reference to the host element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the host element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The DeferredContentAware host directive. */\n private readonly _deferredContentAware = inject(DeferredContentAware);\n\n /** The parent Tabs. */\n private readonly _tabs = inject(TABS);\n\n /** A global unique identifier for the tab. */\n readonly id = input(inject(_IdGenerator).getId('ng-tabpanel-', true));\n\n /** The Tab UIPattern associated with the tabpanel */\n private readonly _tabPattern = computed(() => {\n return this._tabs._tabMap().get(this.value());\n });\n\n /** A local unique identifier for the tabpanel. */\n readonly value = input.required<string>();\n\n /** Whether the tab panel is visible. */\n readonly visible = computed(() => !this._pattern.hidden());\n\n /** The TabPanel UIPattern. */\n readonly _pattern: TabPanelPattern = new TabPanelPattern({\n ...this,\n tab: this._tabPattern,\n });\n\n constructor() {\n afterRenderEffect(() => this._deferredContentAware.contentVisible.set(this.visible()));\n }\n\n ngOnInit() {\n this._tabs._collection.register(this);\n }\n\n ngOnDestroy() {\n this._tabs._collection.unregister(this);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Directive} from '@angular/core';\nimport {DeferredContent} from '../private';\n\n/**\n * A TabContent container for the lazy-loaded content.\n *\n * This structural directive should be applied to an `ng-template` within an `ngTabPanel`.\n * It enables lazy loading of the tab's content, meaning the content is only rendered\n * when the tab is activated for the first time.\n *\n * ```html\n * <div ngTabPanel value=\"myTabId\">\n * <ng-template ngTabContent>\n * <p>This content will be loaded when 'myTabId' is selected.</p>\n * </ng-template>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n *\n * @see [Tabs](guide/aria/tabs)\n */\n@Directive({\n selector: 'ng-template[ngTabContent]',\n exportAs: 'ngTabContent',\n hostDirectives: [DeferredContent],\n})\nexport class TabContent {}\n"],"names":["TABS","InjectionToken","TAB_LIST","Tabs","_elementRef","inject","ElementRef","element","nativeElement","_tabList","signal","undefined","_collection","SortedCollection","_tabPatterns","computed","_tabPanelPatterns","orderedItems","map","tabpanel","_pattern","_panelMap","Map","panel","set","value","_tabMap","tabList","tab","constructor","afterNextRender","startObserving","ngOnDestroy","stopObserving","_register","child","_unregister","deps","target","i0","ɵɵFactoryTarget","Directive","isStandalone","selector","providers","provide","useExisting","exportAs","ngImport","decorators","args","TabList","_tabsParent","orientation","input","textDirection","Directionality","valueSignal","wrap","transform","booleanAttribute","softDisabled","focusMode","selectionMode","selectedTab","model","_selectedTabPattern","linkedSignal","findTab","disabled","TabListPattern","activeItem","items","afterRenderEffect","setDefaultStateEffect","write","pattern","find","ngOnInit","open","inputs","classPropertyName","publicName","isSignal","isRequired","transformFunction","outputs","host","attributes","listeners","properties","Tab","id","_IdGenerator","getId","_tabpanelPattern","get","required","active","selected","TabPattern","tabPanel","register","unregister","TabPanel","_deferredContentAware","DeferredContentAware","_tabs","_tabPattern","visible","hidden","TabPanelPattern","contentVisible","hostDirectives","directive","i1","TabContent","DeferredContent"],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ import { ContentContainerComponentHarness, HarnessPredicate, ComponentHarness }
|
|
|
3
3
|
class ToolbarWidgetHarness extends ContentContainerComponentHarness {
|
|
4
4
|
static hostSelector = '[ngToolbarWidget]';
|
|
5
5
|
static with(options = {}) {
|
|
6
|
-
return new HarnessPredicate(ToolbarWidgetHarness, options).addOption('text', options.text, (harness, pattern) => HarnessPredicate.stringMatches(harness.getText(), pattern)).addOption('active', options.active, async (harness, active) => (await harness.isActive()) === active);
|
|
6
|
+
return new HarnessPredicate(ToolbarWidgetHarness, options).addOption('text', options.text, (harness, pattern) => HarnessPredicate.stringMatches(harness.getText(), pattern)).addOption('active', options.active, async (harness, active) => (await harness.isActive()) === active).addOption('selected', options.selected, async (harness, selected) => (await harness.isSelected()) === selected);
|
|
7
7
|
}
|
|
8
8
|
async getText() {
|
|
9
9
|
return (await this.host()).text();
|
|
@@ -19,6 +19,10 @@ class ToolbarWidgetHarness extends ContentContainerComponentHarness {
|
|
|
19
19
|
const host = await this.host();
|
|
20
20
|
return (await host.getAttribute('aria-disabled')) === 'true';
|
|
21
21
|
}
|
|
22
|
+
async isSelected() {
|
|
23
|
+
const host = await this.host();
|
|
24
|
+
return (await host.getAttribute('aria-pressed')) === 'true';
|
|
25
|
+
}
|
|
22
26
|
}
|
|
23
27
|
|
|
24
28
|
class ToolbarWidgetGroupHarness extends ComponentHarness {
|