Fixed #6899 - Galleria: 'Indicator' Slot, Keyboard Accessibility Broken
parent
9be739b81f
commit
1abbdabe40
|
@ -467,6 +467,14 @@ export interface GalleriaSlots {
|
||||||
* Index of the indicator item
|
* Index of the indicator item
|
||||||
*/
|
*/
|
||||||
index: number;
|
index: number;
|
||||||
|
/**
|
||||||
|
* Current active item index as a number.
|
||||||
|
*/
|
||||||
|
activeIndex: number;
|
||||||
|
/**
|
||||||
|
* Index of the element in tabbing order.
|
||||||
|
*/
|
||||||
|
tabindex: number;
|
||||||
}): VNode[];
|
}): VNode[];
|
||||||
/**
|
/**
|
||||||
* Custom thumbnail template.
|
* Custom thumbnail template.
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
:data-p-active="isIndicatorItemActive(index)"
|
:data-p-active="isIndicatorItemActive(index)"
|
||||||
>
|
>
|
||||||
<button v-if="!templates['indicator']" type="button" :tabindex="activeIndex === index ? '0' : '-1'" :class="cx('indicatorButton')" v-bind="ptm('indicatorButton', getIndicatorPTOptions(index))"></button>
|
<button v-if="!templates['indicator']" type="button" :tabindex="activeIndex === index ? '0' : '-1'" :class="cx('indicatorButton')" v-bind="ptm('indicatorButton', getIndicatorPTOptions(index))"></button>
|
||||||
<component v-if="templates.indicator" :is="templates.indicator" :index="index" />
|
<component v-if="templates.indicator" :is="templates.indicator" :index="index" :activeIndex="activeIndex" :tabindex="activeIndex === index ? '0' : '-1'" />
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
@ -216,7 +216,7 @@ export default {
|
||||||
const indicators = [...find(this.$refs.indicatorContent, '[data-pc-section="indicator"]')];
|
const indicators = [...find(this.$refs.indicatorContent, '[data-pc-section="indicator"]')];
|
||||||
const highlightedIndex = indicators.findIndex((ind) => getAttribute(ind, 'data-p-active') === true);
|
const highlightedIndex = indicators.findIndex((ind) => getAttribute(ind, 'data-p-active') === true);
|
||||||
|
|
||||||
const activeIndicator = findSingle(this.$refs.indicatorContent, '[data-pc-section="indicator"] > button[tabindex="0"]');
|
const activeIndicator = findSingle(this.$refs.indicatorContent, '[data-pc-section="indicator"] > [tabindex="0"]');
|
||||||
const activeIndex = indicators.findIndex((ind) => ind === activeIndicator.parentElement);
|
const activeIndex = indicators.findIndex((ind) => ind === activeIndicator.parentElement);
|
||||||
|
|
||||||
indicators[activeIndex].children[0].tabIndex = '-1';
|
indicators[activeIndex].children[0].tabIndex = '-1';
|
||||||
|
@ -224,7 +224,7 @@ export default {
|
||||||
},
|
},
|
||||||
findFocusedIndicatorIndex() {
|
findFocusedIndicatorIndex() {
|
||||||
const indicators = [...find(this.$refs.indicatorContent, '[data-pc-section="indicator"]')];
|
const indicators = [...find(this.$refs.indicatorContent, '[data-pc-section="indicator"]')];
|
||||||
const activeIndicator = findSingle(this.$refs.indicatorContent, '[data-pc-section="indicator"] > button[tabindex="0"]');
|
const activeIndicator = findSingle(this.$refs.indicatorContent, '[data-pc-section="indicator"] > [tabindex="0"]');
|
||||||
|
|
||||||
return indicators.findIndex((ind) => ind === activeIndicator.parentElement);
|
return indicators.findIndex((ind) => ind === activeIndicator.parentElement);
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue