From 1fcf9f77cea92c48e82f47dc9902a786ca6138ba Mon Sep 17 00:00:00 2001 From: Salem Cobalt Date: Mon, 29 Jan 2024 14:48:11 -0500 Subject: [PATCH] fix: add optional swiperElementNodeName param to allow more flexible web component usage --- src/components-shared/params-list.mjs | 1 + src/core/core.mjs | 2 +- src/core/defaults.mjs | 1 + src/swiper-vue.d.ts | 4 ++++ src/types/swiper-options.d.ts | 7 +++++++ src/vue/swiper.mjs | 1 + 6 files changed, 15 insertions(+), 1 deletion(-) diff --git a/src/components-shared/params-list.mjs b/src/components-shared/params-list.mjs index 5bf89f530..dc6272961 100644 --- a/src/components-shared/params-list.mjs +++ b/src/components-shared/params-list.mjs @@ -7,6 +7,7 @@ const paramsList = [ 'init', '_direction', 'oneWayMovement', + 'swiperElementNodeName', 'touchEventsTarget', 'initialSlide', '_speed', diff --git a/src/core/core.mjs b/src/core/core.mjs index c185b8d20..939636f57 100644 --- a/src/core/core.mjs +++ b/src/core/core.mjs @@ -504,7 +504,7 @@ class Swiper { } el.swiper = swiper; - if (el.parentNode && el.parentNode.host && el.parentNode.host.nodeName === 'SWIPER-CONTAINER') { + if (el.parentNode && el.parentNode.host && el.parentNode.host.nodeName === swiper.params.swiperElementNodeName.toUpperCase()) { swiper.isElement = true; } diff --git a/src/core/defaults.mjs b/src/core/defaults.mjs index 99848ad53..740a3d622 100644 --- a/src/core/defaults.mjs +++ b/src/core/defaults.mjs @@ -2,6 +2,7 @@ export default { init: true, direction: 'horizontal', oneWayMovement: false, + swiperElementNodeName: 'SWIPER-CONTAINER', touchEventsTarget: 'wrapper', initialSlide: 0, speed: 300, diff --git a/src/swiper-vue.d.ts b/src/swiper-vue.d.ts index c41732e44..785043619 100644 --- a/src/swiper-vue.d.ts +++ b/src/swiper-vue.d.ts @@ -51,6 +51,10 @@ declare const Swiper: DefineComponent< type: PropType; default: SwiperOptions['oneWayMovement']; }; + swiperElementNodeName: { + type: PropType; + default: SwiperOptions['swiperElementNodeName']; + }; touchEventsTarget: { type: PropType; default: undefined; diff --git a/src/types/swiper-options.d.ts b/src/types/swiper-options.d.ts index 6d0167fe5..10e406dce 100644 --- a/src/types/swiper-options.d.ts +++ b/src/types/swiper-options.d.ts @@ -100,6 +100,13 @@ export interface SwiperOptions { oneWayMovement?: boolean; + /** + * The name of the swiper element node name; used for detecting web component rendering + * + * @default 'SWIPER-CONTAINER' + */ + swiperElementNodeName?: string; + /** * Duration of transition between slides (in ms) * diff --git a/src/vue/swiper.mjs b/src/vue/swiper.mjs index 9e675be39..2b66470a8 100644 --- a/src/vue/swiper.mjs +++ b/src/vue/swiper.mjs @@ -31,6 +31,7 @@ const Swiper = { init: { type: Boolean, default: undefined }, direction: { type: String, default: undefined }, oneWayMovement: { type: Boolean, default: undefined }, + swiperElementNodeName: { type: String, default: 'SWIPER-CONTAINER' }, touchEventsTarget: { type: String, default: undefined }, initialSlide: { type: Number, default: undefined }, speed: { type: Number, default: undefined },