pb-sxp-ui 1.9.1 → 1.9.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/pb-ui.js CHANGED
@@ -313,6 +313,17 @@
313
313
  });
314
314
  return value !== null && value !== void 0 ? value : '';
315
315
  }
316
+ function getScreenReader() {
317
+ let userAgent = self.navigator.userAgent;
318
+ if (!userAgent)
319
+ return false;
320
+ return (/TalkBack/i.test(userAgent) ||
321
+ /Funtouch/i.test(userAgent) ||
322
+ /VoiceOver/i.test(userAgent) ||
323
+ /NVDA/i.test(userAgent) ||
324
+ /JAWS/i.test(userAgent) ||
325
+ /ChromeVox/i.test(userAgent));
326
+ }
316
327
 
317
328
  function unzip(b64Data) {
318
329
  const strData = atob(b64Data);
@@ -2594,6 +2605,119 @@
2594
2605
  return (Array.isArray(el) ? el : [el]).filter(e => !!e);
2595
2606
  }
2596
2607
 
2608
+ /* eslint-disable consistent-return */
2609
+ function Keyboard(_ref) {
2610
+ let {
2611
+ swiper,
2612
+ extendParams,
2613
+ on,
2614
+ emit
2615
+ } = _ref;
2616
+ const document = getDocument();
2617
+ const window = getWindow();
2618
+ swiper.keyboard = {
2619
+ enabled: false
2620
+ };
2621
+ extendParams({
2622
+ keyboard: {
2623
+ enabled: false,
2624
+ onlyInViewport: true,
2625
+ pageUpDown: true
2626
+ }
2627
+ });
2628
+ function handle(event) {
2629
+ if (!swiper.enabled) return;
2630
+ const {
2631
+ rtlTranslate: rtl
2632
+ } = swiper;
2633
+ let e = event;
2634
+ if (e.originalEvent) e = e.originalEvent; // jquery fix
2635
+ const kc = e.keyCode || e.charCode;
2636
+ const pageUpDown = swiper.params.keyboard.pageUpDown;
2637
+ const isPageUp = pageUpDown && kc === 33;
2638
+ const isPageDown = pageUpDown && kc === 34;
2639
+ const isArrowLeft = kc === 37;
2640
+ const isArrowRight = kc === 39;
2641
+ const isArrowUp = kc === 38;
2642
+ const isArrowDown = kc === 40;
2643
+ // Directions locks
2644
+ if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {
2645
+ return false;
2646
+ }
2647
+ if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {
2648
+ return false;
2649
+ }
2650
+ if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {
2651
+ return undefined;
2652
+ }
2653
+ if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {
2654
+ return undefined;
2655
+ }
2656
+ if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {
2657
+ let inView = false;
2658
+ // Check that swiper should be inside of visible area of window
2659
+ if (elementParents(swiper.el, `.${swiper.params.slideClass}, swiper-slide`).length > 0 && elementParents(swiper.el, `.${swiper.params.slideActiveClass}`).length === 0) {
2660
+ return undefined;
2661
+ }
2662
+ const el = swiper.el;
2663
+ const swiperWidth = el.clientWidth;
2664
+ const swiperHeight = el.clientHeight;
2665
+ const windowWidth = window.innerWidth;
2666
+ const windowHeight = window.innerHeight;
2667
+ const swiperOffset = elementOffset(el);
2668
+ if (rtl) swiperOffset.left -= el.scrollLeft;
2669
+ const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];
2670
+ for (let i = 0; i < swiperCoord.length; i += 1) {
2671
+ const point = swiperCoord[i];
2672
+ if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {
2673
+ if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line
2674
+ inView = true;
2675
+ }
2676
+ }
2677
+ if (!inView) return undefined;
2678
+ }
2679
+ if (swiper.isHorizontal()) {
2680
+ if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {
2681
+ if (e.preventDefault) e.preventDefault();else e.returnValue = false;
2682
+ }
2683
+ if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();
2684
+ if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();
2685
+ } else {
2686
+ if (isPageUp || isPageDown || isArrowUp || isArrowDown) {
2687
+ if (e.preventDefault) e.preventDefault();else e.returnValue = false;
2688
+ }
2689
+ if (isPageDown || isArrowDown) swiper.slideNext();
2690
+ if (isPageUp || isArrowUp) swiper.slidePrev();
2691
+ }
2692
+ emit('keyPress', kc);
2693
+ return undefined;
2694
+ }
2695
+ function enable() {
2696
+ if (swiper.keyboard.enabled) return;
2697
+ document.addEventListener('keydown', handle);
2698
+ swiper.keyboard.enabled = true;
2699
+ }
2700
+ function disable() {
2701
+ if (!swiper.keyboard.enabled) return;
2702
+ document.removeEventListener('keydown', handle);
2703
+ swiper.keyboard.enabled = false;
2704
+ }
2705
+ on('init', () => {
2706
+ if (swiper.params.keyboard.enabled) {
2707
+ enable();
2708
+ }
2709
+ });
2710
+ on('destroy', () => {
2711
+ if (swiper.keyboard.enabled) {
2712
+ disable();
2713
+ }
2714
+ });
2715
+ Object.assign(swiper.keyboard, {
2716
+ enable,
2717
+ disable
2718
+ });
2719
+ }
2720
+
2597
2721
  /* eslint-disable consistent-return */
2598
2722
  function Mousewheel(_ref) {
2599
2723
  let {
@@ -3001,6 +3125,202 @@
3001
3125
  return params;
3002
3126
  }
3003
3127
 
3128
+ function Navigation(_ref) {
3129
+ let {
3130
+ swiper,
3131
+ extendParams,
3132
+ on,
3133
+ emit
3134
+ } = _ref;
3135
+ extendParams({
3136
+ navigation: {
3137
+ nextEl: null,
3138
+ prevEl: null,
3139
+ hideOnClick: false,
3140
+ disabledClass: 'swiper-button-disabled',
3141
+ hiddenClass: 'swiper-button-hidden',
3142
+ lockClass: 'swiper-button-lock',
3143
+ navigationDisabledClass: 'swiper-navigation-disabled'
3144
+ }
3145
+ });
3146
+ swiper.navigation = {
3147
+ nextEl: null,
3148
+ prevEl: null
3149
+ };
3150
+ function getEl(el) {
3151
+ let res;
3152
+ if (el && typeof el === 'string' && swiper.isElement) {
3153
+ res = swiper.el.querySelector(el);
3154
+ if (res) return res;
3155
+ }
3156
+ if (el) {
3157
+ if (typeof el === 'string') res = [...document.querySelectorAll(el)];
3158
+ if (swiper.params.uniqueNavElements && typeof el === 'string' && res && res.length > 1 && swiper.el.querySelectorAll(el).length === 1) {
3159
+ res = swiper.el.querySelector(el);
3160
+ } else if (res && res.length === 1) {
3161
+ res = res[0];
3162
+ }
3163
+ }
3164
+ if (el && !res) return el;
3165
+ // if (Array.isArray(res) && res.length === 1) res = res[0];
3166
+ return res;
3167
+ }
3168
+ function toggleEl(el, disabled) {
3169
+ const params = swiper.params.navigation;
3170
+ el = makeElementsArray(el);
3171
+ el.forEach(subEl => {
3172
+ if (subEl) {
3173
+ subEl.classList[disabled ? 'add' : 'remove'](...params.disabledClass.split(' '));
3174
+ if (subEl.tagName === 'BUTTON') subEl.disabled = disabled;
3175
+ if (swiper.params.watchOverflow && swiper.enabled) {
3176
+ subEl.classList[swiper.isLocked ? 'add' : 'remove'](params.lockClass);
3177
+ }
3178
+ }
3179
+ });
3180
+ }
3181
+ function update() {
3182
+ // Update Navigation Buttons
3183
+ const {
3184
+ nextEl,
3185
+ prevEl
3186
+ } = swiper.navigation;
3187
+ if (swiper.params.loop) {
3188
+ toggleEl(prevEl, false);
3189
+ toggleEl(nextEl, false);
3190
+ return;
3191
+ }
3192
+ toggleEl(prevEl, swiper.isBeginning && !swiper.params.rewind);
3193
+ toggleEl(nextEl, swiper.isEnd && !swiper.params.rewind);
3194
+ }
3195
+ function onPrevClick(e) {
3196
+ e.preventDefault();
3197
+ if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) return;
3198
+ swiper.slidePrev();
3199
+ emit('navigationPrev');
3200
+ }
3201
+ function onNextClick(e) {
3202
+ e.preventDefault();
3203
+ if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return;
3204
+ swiper.slideNext();
3205
+ emit('navigationNext');
3206
+ }
3207
+ function init() {
3208
+ const params = swiper.params.navigation;
3209
+ swiper.params.navigation = createElementIfNotDefined(swiper, swiper.originalParams.navigation, swiper.params.navigation, {
3210
+ nextEl: 'swiper-button-next',
3211
+ prevEl: 'swiper-button-prev'
3212
+ });
3213
+ if (!(params.nextEl || params.prevEl)) return;
3214
+ let nextEl = getEl(params.nextEl);
3215
+ let prevEl = getEl(params.prevEl);
3216
+ Object.assign(swiper.navigation, {
3217
+ nextEl,
3218
+ prevEl
3219
+ });
3220
+ nextEl = makeElementsArray(nextEl);
3221
+ prevEl = makeElementsArray(prevEl);
3222
+ const initButton = (el, dir) => {
3223
+ if (el) {
3224
+ el.addEventListener('click', dir === 'next' ? onNextClick : onPrevClick);
3225
+ }
3226
+ if (!swiper.enabled && el) {
3227
+ el.classList.add(...params.lockClass.split(' '));
3228
+ }
3229
+ };
3230
+ nextEl.forEach(el => initButton(el, 'next'));
3231
+ prevEl.forEach(el => initButton(el, 'prev'));
3232
+ }
3233
+ function destroy() {
3234
+ let {
3235
+ nextEl,
3236
+ prevEl
3237
+ } = swiper.navigation;
3238
+ nextEl = makeElementsArray(nextEl);
3239
+ prevEl = makeElementsArray(prevEl);
3240
+ const destroyButton = (el, dir) => {
3241
+ el.removeEventListener('click', dir === 'next' ? onNextClick : onPrevClick);
3242
+ el.classList.remove(...swiper.params.navigation.disabledClass.split(' '));
3243
+ };
3244
+ nextEl.forEach(el => destroyButton(el, 'next'));
3245
+ prevEl.forEach(el => destroyButton(el, 'prev'));
3246
+ }
3247
+ on('init', () => {
3248
+ if (swiper.params.navigation.enabled === false) {
3249
+ // eslint-disable-next-line
3250
+ disable();
3251
+ } else {
3252
+ init();
3253
+ update();
3254
+ }
3255
+ });
3256
+ on('toEdge fromEdge lock unlock', () => {
3257
+ update();
3258
+ });
3259
+ on('destroy', () => {
3260
+ destroy();
3261
+ });
3262
+ on('enable disable', () => {
3263
+ let {
3264
+ nextEl,
3265
+ prevEl
3266
+ } = swiper.navigation;
3267
+ nextEl = makeElementsArray(nextEl);
3268
+ prevEl = makeElementsArray(prevEl);
3269
+ if (swiper.enabled) {
3270
+ update();
3271
+ return;
3272
+ }
3273
+ [...nextEl, ...prevEl].filter(el => !!el).forEach(el => el.classList.add(swiper.params.navigation.lockClass));
3274
+ });
3275
+ on('click', (_s, e) => {
3276
+ let {
3277
+ nextEl,
3278
+ prevEl
3279
+ } = swiper.navigation;
3280
+ nextEl = makeElementsArray(nextEl);
3281
+ prevEl = makeElementsArray(prevEl);
3282
+ const targetEl = e.target;
3283
+ let targetIsButton = prevEl.includes(targetEl) || nextEl.includes(targetEl);
3284
+ if (swiper.isElement && !targetIsButton) {
3285
+ const path = e.path || e.composedPath && e.composedPath();
3286
+ if (path) {
3287
+ targetIsButton = path.find(pathEl => nextEl.includes(pathEl) || prevEl.includes(pathEl));
3288
+ }
3289
+ }
3290
+ if (swiper.params.navigation.hideOnClick && !targetIsButton) {
3291
+ if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return;
3292
+ let isHidden;
3293
+ if (nextEl.length) {
3294
+ isHidden = nextEl[0].classList.contains(swiper.params.navigation.hiddenClass);
3295
+ } else if (prevEl.length) {
3296
+ isHidden = prevEl[0].classList.contains(swiper.params.navigation.hiddenClass);
3297
+ }
3298
+ if (isHidden === true) {
3299
+ emit('navigationShow');
3300
+ } else {
3301
+ emit('navigationHide');
3302
+ }
3303
+ [...nextEl, ...prevEl].filter(el => !!el).forEach(el => el.classList.toggle(swiper.params.navigation.hiddenClass));
3304
+ }
3305
+ });
3306
+ const enable = () => {
3307
+ swiper.el.classList.remove(...swiper.params.navigation.navigationDisabledClass.split(' '));
3308
+ init();
3309
+ update();
3310
+ };
3311
+ const disable = () => {
3312
+ swiper.el.classList.add(...swiper.params.navigation.navigationDisabledClass.split(' '));
3313
+ destroy();
3314
+ };
3315
+ Object.assign(swiper.navigation, {
3316
+ enable,
3317
+ disable,
3318
+ update,
3319
+ init,
3320
+ destroy
3321
+ });
3322
+ }
3323
+
3004
3324
  function classesToSelector(classes) {
3005
3325
  if (classes === void 0) {
3006
3326
  classes = '';
@@ -3807,6 +4127,374 @@
3807
4127
  });
3808
4128
  }
3809
4129
 
4130
+ function A11y(_ref) {
4131
+ let {
4132
+ swiper,
4133
+ extendParams,
4134
+ on
4135
+ } = _ref;
4136
+ extendParams({
4137
+ a11y: {
4138
+ enabled: true,
4139
+ notificationClass: 'swiper-notification',
4140
+ prevSlideMessage: 'Previous slide',
4141
+ nextSlideMessage: 'Next slide',
4142
+ firstSlideMessage: 'This is the first slide',
4143
+ lastSlideMessage: 'This is the last slide',
4144
+ paginationBulletMessage: 'Go to slide {{index}}',
4145
+ slideLabelMessage: '{{index}} / {{slidesLength}}',
4146
+ containerMessage: null,
4147
+ containerRoleDescriptionMessage: null,
4148
+ itemRoleDescriptionMessage: null,
4149
+ slideRole: 'group',
4150
+ id: null
4151
+ }
4152
+ });
4153
+ swiper.a11y = {
4154
+ clicked: false
4155
+ };
4156
+ let liveRegion = null;
4157
+ let preventFocusHandler;
4158
+ let focusTargetSlideEl;
4159
+ let visibilityChangedTimestamp = new Date().getTime();
4160
+ function notify(message) {
4161
+ const notification = liveRegion;
4162
+ if (notification.length === 0) return;
4163
+ notification.innerHTML = '';
4164
+ notification.innerHTML = message;
4165
+ }
4166
+ function getRandomNumber(size) {
4167
+ if (size === void 0) {
4168
+ size = 16;
4169
+ }
4170
+ const randomChar = () => Math.round(16 * Math.random()).toString(16);
4171
+ return 'x'.repeat(size).replace(/x/g, randomChar);
4172
+ }
4173
+ function makeElFocusable(el) {
4174
+ el = makeElementsArray(el);
4175
+ el.forEach(subEl => {
4176
+ subEl.setAttribute('tabIndex', '0');
4177
+ });
4178
+ }
4179
+ function makeElNotFocusable(el) {
4180
+ el = makeElementsArray(el);
4181
+ el.forEach(subEl => {
4182
+ subEl.setAttribute('tabIndex', '-1');
4183
+ });
4184
+ }
4185
+ function addElRole(el, role) {
4186
+ el = makeElementsArray(el);
4187
+ el.forEach(subEl => {
4188
+ subEl.setAttribute('role', role);
4189
+ });
4190
+ }
4191
+ function addElRoleDescription(el, description) {
4192
+ el = makeElementsArray(el);
4193
+ el.forEach(subEl => {
4194
+ subEl.setAttribute('aria-roledescription', description);
4195
+ });
4196
+ }
4197
+ function addElControls(el, controls) {
4198
+ el = makeElementsArray(el);
4199
+ el.forEach(subEl => {
4200
+ subEl.setAttribute('aria-controls', controls);
4201
+ });
4202
+ }
4203
+ function addElLabel(el, label) {
4204
+ el = makeElementsArray(el);
4205
+ el.forEach(subEl => {
4206
+ subEl.setAttribute('aria-label', label);
4207
+ });
4208
+ }
4209
+ function addElId(el, id) {
4210
+ el = makeElementsArray(el);
4211
+ el.forEach(subEl => {
4212
+ subEl.setAttribute('id', id);
4213
+ });
4214
+ }
4215
+ function addElLive(el, live) {
4216
+ el = makeElementsArray(el);
4217
+ el.forEach(subEl => {
4218
+ subEl.setAttribute('aria-live', live);
4219
+ });
4220
+ }
4221
+ function disableEl(el) {
4222
+ el = makeElementsArray(el);
4223
+ el.forEach(subEl => {
4224
+ subEl.setAttribute('aria-disabled', true);
4225
+ });
4226
+ }
4227
+ function enableEl(el) {
4228
+ el = makeElementsArray(el);
4229
+ el.forEach(subEl => {
4230
+ subEl.setAttribute('aria-disabled', false);
4231
+ });
4232
+ }
4233
+ function onEnterOrSpaceKey(e) {
4234
+ if (e.keyCode !== 13 && e.keyCode !== 32) return;
4235
+ const params = swiper.params.a11y;
4236
+ const targetEl = e.target;
4237
+ if (swiper.pagination && swiper.pagination.el && (targetEl === swiper.pagination.el || swiper.pagination.el.contains(e.target))) {
4238
+ if (!e.target.matches(classesToSelector(swiper.params.pagination.bulletClass))) return;
4239
+ }
4240
+ if (swiper.navigation && swiper.navigation.prevEl && swiper.navigation.nextEl) {
4241
+ const prevEls = makeElementsArray(swiper.navigation.prevEl);
4242
+ const nextEls = makeElementsArray(swiper.navigation.nextEl);
4243
+ if (nextEls.includes(targetEl)) {
4244
+ if (!(swiper.isEnd && !swiper.params.loop)) {
4245
+ swiper.slideNext();
4246
+ }
4247
+ if (swiper.isEnd) {
4248
+ notify(params.lastSlideMessage);
4249
+ } else {
4250
+ notify(params.nextSlideMessage);
4251
+ }
4252
+ }
4253
+ if (prevEls.includes(targetEl)) {
4254
+ if (!(swiper.isBeginning && !swiper.params.loop)) {
4255
+ swiper.slidePrev();
4256
+ }
4257
+ if (swiper.isBeginning) {
4258
+ notify(params.firstSlideMessage);
4259
+ } else {
4260
+ notify(params.prevSlideMessage);
4261
+ }
4262
+ }
4263
+ }
4264
+ if (swiper.pagination && targetEl.matches(classesToSelector(swiper.params.pagination.bulletClass))) {
4265
+ targetEl.click();
4266
+ }
4267
+ }
4268
+ function updateNavigation() {
4269
+ if (swiper.params.loop || swiper.params.rewind || !swiper.navigation) return;
4270
+ const {
4271
+ nextEl,
4272
+ prevEl
4273
+ } = swiper.navigation;
4274
+ if (prevEl) {
4275
+ if (swiper.isBeginning) {
4276
+ disableEl(prevEl);
4277
+ makeElNotFocusable(prevEl);
4278
+ } else {
4279
+ enableEl(prevEl);
4280
+ makeElFocusable(prevEl);
4281
+ }
4282
+ }
4283
+ if (nextEl) {
4284
+ if (swiper.isEnd) {
4285
+ disableEl(nextEl);
4286
+ makeElNotFocusable(nextEl);
4287
+ } else {
4288
+ enableEl(nextEl);
4289
+ makeElFocusable(nextEl);
4290
+ }
4291
+ }
4292
+ }
4293
+ function hasPagination() {
4294
+ return swiper.pagination && swiper.pagination.bullets && swiper.pagination.bullets.length;
4295
+ }
4296
+ function hasClickablePagination() {
4297
+ return hasPagination() && swiper.params.pagination.clickable;
4298
+ }
4299
+ function updatePagination() {
4300
+ const params = swiper.params.a11y;
4301
+ if (!hasPagination()) return;
4302
+ swiper.pagination.bullets.forEach(bulletEl => {
4303
+ if (swiper.params.pagination.clickable) {
4304
+ makeElFocusable(bulletEl);
4305
+ if (!swiper.params.pagination.renderBullet) {
4306
+ addElRole(bulletEl, 'button');
4307
+ addElLabel(bulletEl, params.paginationBulletMessage.replace(/\{\{index\}\}/, elementIndex(bulletEl) + 1));
4308
+ }
4309
+ }
4310
+ if (bulletEl.matches(classesToSelector(swiper.params.pagination.bulletActiveClass))) {
4311
+ bulletEl.setAttribute('aria-current', 'true');
4312
+ } else {
4313
+ bulletEl.removeAttribute('aria-current');
4314
+ }
4315
+ });
4316
+ }
4317
+ const initNavEl = (el, wrapperId, message) => {
4318
+ makeElFocusable(el);
4319
+ if (el.tagName !== 'BUTTON') {
4320
+ addElRole(el, 'button');
4321
+ el.addEventListener('keydown', onEnterOrSpaceKey);
4322
+ }
4323
+ addElLabel(el, message);
4324
+ addElControls(el, wrapperId);
4325
+ };
4326
+ const handlePointerDown = e => {
4327
+ if (focusTargetSlideEl && focusTargetSlideEl !== e.target && !focusTargetSlideEl.contains(e.target)) {
4328
+ preventFocusHandler = true;
4329
+ }
4330
+ swiper.a11y.clicked = true;
4331
+ };
4332
+ const handlePointerUp = () => {
4333
+ preventFocusHandler = false;
4334
+ requestAnimationFrame(() => {
4335
+ requestAnimationFrame(() => {
4336
+ if (!swiper.destroyed) {
4337
+ swiper.a11y.clicked = false;
4338
+ }
4339
+ });
4340
+ });
4341
+ };
4342
+ const onVisibilityChange = e => {
4343
+ visibilityChangedTimestamp = new Date().getTime();
4344
+ };
4345
+ const handleFocus = e => {
4346
+ if (swiper.a11y.clicked) return;
4347
+ if (new Date().getTime() - visibilityChangedTimestamp < 100) return;
4348
+ const slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);
4349
+ if (!slideEl || !swiper.slides.includes(slideEl)) return;
4350
+ focusTargetSlideEl = slideEl;
4351
+ const isActive = swiper.slides.indexOf(slideEl) === swiper.activeIndex;
4352
+ const isVisible = swiper.params.watchSlidesProgress && swiper.visibleSlides && swiper.visibleSlides.includes(slideEl);
4353
+ if (isActive || isVisible) return;
4354
+ if (e.sourceCapabilities && e.sourceCapabilities.firesTouchEvents) return;
4355
+ if (swiper.isHorizontal()) {
4356
+ swiper.el.scrollLeft = 0;
4357
+ } else {
4358
+ swiper.el.scrollTop = 0;
4359
+ }
4360
+ requestAnimationFrame(() => {
4361
+ if (preventFocusHandler) return;
4362
+ if (swiper.params.loop) {
4363
+ swiper.slideToLoop(parseInt(slideEl.getAttribute('data-swiper-slide-index')), 0);
4364
+ } else {
4365
+ swiper.slideTo(swiper.slides.indexOf(slideEl), 0);
4366
+ }
4367
+ preventFocusHandler = false;
4368
+ });
4369
+ };
4370
+ const initSlides = () => {
4371
+ const params = swiper.params.a11y;
4372
+ if (params.itemRoleDescriptionMessage) {
4373
+ addElRoleDescription(swiper.slides, params.itemRoleDescriptionMessage);
4374
+ }
4375
+ if (params.slideRole) {
4376
+ addElRole(swiper.slides, params.slideRole);
4377
+ }
4378
+ const slidesLength = swiper.slides.length;
4379
+ if (params.slideLabelMessage) {
4380
+ swiper.slides.forEach((slideEl, index) => {
4381
+ const slideIndex = swiper.params.loop ? parseInt(slideEl.getAttribute('data-swiper-slide-index'), 10) : index;
4382
+ const ariaLabelMessage = params.slideLabelMessage.replace(/\{\{index\}\}/, slideIndex + 1).replace(/\{\{slidesLength\}\}/, slidesLength);
4383
+ addElLabel(slideEl, ariaLabelMessage);
4384
+ });
4385
+ }
4386
+ };
4387
+ const init = () => {
4388
+ const params = swiper.params.a11y;
4389
+ swiper.el.append(liveRegion);
4390
+
4391
+ // Container
4392
+ const containerEl = swiper.el;
4393
+ if (params.containerRoleDescriptionMessage) {
4394
+ addElRoleDescription(containerEl, params.containerRoleDescriptionMessage);
4395
+ }
4396
+ if (params.containerMessage) {
4397
+ addElLabel(containerEl, params.containerMessage);
4398
+ }
4399
+
4400
+ // Wrapper
4401
+ const wrapperEl = swiper.wrapperEl;
4402
+ const wrapperId = params.id || wrapperEl.getAttribute('id') || `swiper-wrapper-${getRandomNumber(16)}`;
4403
+ const live = swiper.params.autoplay && swiper.params.autoplay.enabled ? 'off' : 'polite';
4404
+ addElId(wrapperEl, wrapperId);
4405
+ addElLive(wrapperEl, live);
4406
+
4407
+ // Slide
4408
+ initSlides();
4409
+
4410
+ // Navigation
4411
+ let {
4412
+ nextEl,
4413
+ prevEl
4414
+ } = swiper.navigation ? swiper.navigation : {};
4415
+ nextEl = makeElementsArray(nextEl);
4416
+ prevEl = makeElementsArray(prevEl);
4417
+ if (nextEl) {
4418
+ nextEl.forEach(el => initNavEl(el, wrapperId, params.nextSlideMessage));
4419
+ }
4420
+ if (prevEl) {
4421
+ prevEl.forEach(el => initNavEl(el, wrapperId, params.prevSlideMessage));
4422
+ }
4423
+
4424
+ // Pagination
4425
+ if (hasClickablePagination()) {
4426
+ const paginationEl = makeElementsArray(swiper.pagination.el);
4427
+ paginationEl.forEach(el => {
4428
+ el.addEventListener('keydown', onEnterOrSpaceKey);
4429
+ });
4430
+ }
4431
+
4432
+ // Tab focus
4433
+ const document = getDocument();
4434
+ document.addEventListener('visibilitychange', onVisibilityChange);
4435
+ swiper.el.addEventListener('focus', handleFocus, true);
4436
+ swiper.el.addEventListener('focus', handleFocus, true);
4437
+ swiper.el.addEventListener('pointerdown', handlePointerDown, true);
4438
+ swiper.el.addEventListener('pointerup', handlePointerUp, true);
4439
+ };
4440
+ function destroy() {
4441
+ if (liveRegion) liveRegion.remove();
4442
+ let {
4443
+ nextEl,
4444
+ prevEl
4445
+ } = swiper.navigation ? swiper.navigation : {};
4446
+ nextEl = makeElementsArray(nextEl);
4447
+ prevEl = makeElementsArray(prevEl);
4448
+ if (nextEl) {
4449
+ nextEl.forEach(el => el.removeEventListener('keydown', onEnterOrSpaceKey));
4450
+ }
4451
+ if (prevEl) {
4452
+ prevEl.forEach(el => el.removeEventListener('keydown', onEnterOrSpaceKey));
4453
+ }
4454
+
4455
+ // Pagination
4456
+ if (hasClickablePagination()) {
4457
+ const paginationEl = makeElementsArray(swiper.pagination.el);
4458
+ paginationEl.forEach(el => {
4459
+ el.removeEventListener('keydown', onEnterOrSpaceKey);
4460
+ });
4461
+ }
4462
+ const document = getDocument();
4463
+ document.removeEventListener('visibilitychange', onVisibilityChange);
4464
+ // Tab focus
4465
+ if (swiper.el && typeof swiper.el !== 'string') {
4466
+ swiper.el.removeEventListener('focus', handleFocus, true);
4467
+ swiper.el.removeEventListener('pointerdown', handlePointerDown, true);
4468
+ swiper.el.removeEventListener('pointerup', handlePointerUp, true);
4469
+ }
4470
+ }
4471
+ on('beforeInit', () => {
4472
+ liveRegion = createElement('span', swiper.params.a11y.notificationClass);
4473
+ liveRegion.setAttribute('aria-live', 'assertive');
4474
+ liveRegion.setAttribute('aria-atomic', 'true');
4475
+ });
4476
+ on('afterInit', () => {
4477
+ if (!swiper.params.a11y.enabled) return;
4478
+ init();
4479
+ });
4480
+ on('slidesLengthChange snapGridLengthChange slidesGridLengthChange', () => {
4481
+ if (!swiper.params.a11y.enabled) return;
4482
+ initSlides();
4483
+ });
4484
+ on('fromEdge toEdge afterInit lock unlock', () => {
4485
+ if (!swiper.params.a11y.enabled) return;
4486
+ updateNavigation();
4487
+ });
4488
+ on('paginationUpdate', () => {
4489
+ if (!swiper.params.a11y.enabled) return;
4490
+ updatePagination();
4491
+ });
4492
+ on('destroy', () => {
4493
+ if (!swiper.params.a11y.enabled) return;
4494
+ destroy();
4495
+ });
4496
+ }
4497
+
3810
4498
  /* eslint no-underscore-dangle: "off" */
3811
4499
  /* eslint no-use-before-define: "off" */
3812
4500
  function Autoplay(_ref) {
@@ -8990,13 +9678,13 @@
8990
9678
  * @Author: binruan@chatlabs.com
8991
9679
  * @Date: 2023-11-02 18:34:34
8992
9680
  * @LastEditors: binruan@chatlabs.com
8993
- * @LastEditTime: 2024-11-19 14:28:41
9681
+ * @LastEditTime: 2024-11-20 18:37:10
8994
9682
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
8995
9683
  *
8996
9684
  */
8997
9685
  const closeIcon$1 = '';
8998
9686
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
8999
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0;
9687
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
9000
9688
  const touchRef = React.useRef(null);
9001
9689
  const fTouchRef = React.useRef(null);
9002
9690
  const touchMoveRef = React.useRef(null);
@@ -9051,7 +9739,7 @@
9051
9739
  }, [_popup, openState, globalConfig]);
9052
9740
  React.useEffect(() => {
9053
9741
  const trapFocus = (element) => {
9054
- var focusableEls = element === null || element === void 0 ? void 0 : element.querySelectorAll('a, a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input[type="text"]:not([disabled]), input[type="radio"]:not([disabled]), input[type="checkbox"]:not([disabled]), select:not([disabled])');
9742
+ var focusableEls = element === null || element === void 0 ? void 0 : element.querySelectorAll('[role="button"],a, a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input[type="text"]:not([disabled]), input[type="radio"]:not([disabled]), input[type="checkbox"]:not([disabled]), select:not([disabled])');
9055
9743
  var firstFocusableEl = focusableEls === null || focusableEls === void 0 ? void 0 : focusableEls[0];
9056
9744
  var lastFocusableEl = focusableEls === null || focusableEls === void 0 ? void 0 : focusableEls[(focusableEls === null || focusableEls === void 0 ? void 0 : focusableEls.length) - 1];
9057
9745
  var KEYCODE_TAB = 9;
@@ -9174,7 +9862,7 @@
9174
9862
  }
9175
9863
  })), child()),
9176
9864
  React.createElement("button", { className: 'modal-icon-wrapper', role: 'button', "aria-label": 'close button', onClick: onClose, style: { top: scrollTop } },
9177
- React.createElement("img", { src: (_0 = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) !== null && _0 !== void 0 ? _0 : closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9865
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9178
9866
  };
9179
9867
  var Modal$1 = React.memo(Modal);
9180
9868
 
@@ -9441,7 +10129,8 @@
9441
10129
  const [showModal, setShowModal] = React.useState(false);
9442
10130
  const [show3DModal, setShow3DModal] = React.useState(false);
9443
10131
  const [checkCommodityIndex, setCheckCommodityIndex] = React.useState((_b = popupDetailData === null || popupDetailData === void 0 ? void 0 : popupDetailData.multiCheckIndex) !== null && _b !== void 0 ? _b : 0);
9444
- const ref = React.useRef();
10132
+ const swiperRef = React.useRef();
10133
+ const [swiperActiveIndex, setSwiperActiveIndex] = React.useState(0);
9445
10134
  const data = isPost ? rec : popupDetailData;
9446
10135
  let product = isPost ? data === null || data === void 0 ? void 0 : data.product : (_d = (_c = data === null || data === void 0 ? void 0 : data.video) === null || _c === void 0 ? void 0 : _c.bindProduct) !== null && _d !== void 0 ? _d : (_f = (_e = data === null || data === void 0 ? void 0 : data.video) === null || _e === void 0 ? void 0 : _e.bindProducts) === null || _f === void 0 ? void 0 : _f[0];
9447
10136
  let cta = isPost
@@ -9532,9 +10221,9 @@
9532
10221
  popupCurTimeRef.current = new Date();
9533
10222
  setCheckCommodityIndex(index);
9534
10223
  checkCommodityIndexRef.current = index;
9535
- if (ref === null || ref === void 0 ? void 0 : ref.current) {
9536
- ref.current.swiper.slideTo(0);
9537
- ref.current.swiper.autoplay.start();
10224
+ if (swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) {
10225
+ swiperRef.current.swiper.slideTo(0);
10226
+ swiperRef.current.swiper.autoplay.start();
9538
10227
  }
9539
10228
  }, []);
9540
10229
  const renderCommodityGroup = React.useCallback(() => {
@@ -9552,19 +10241,40 @@
9552
10241
  return dotsAlignClass === null || dotsAlignClass === void 0 ? void 0 : dotsAlignClass[swiper === null || swiper === void 0 ? void 0 : swiper.dotsAlign];
9553
10242
  }, [swiper === null || swiper === void 0 ? void 0 : swiper.dotsAlign]);
9554
10243
  const iframeUrl = product === null || product === void 0 ? void 0 : product.remark;
10244
+ const handleMouseEnter = React.useCallback(() => {
10245
+ if (swiperRef.current && swiperRef.current.swiper && isAlly) {
10246
+ swiperRef.current.swiper.autoplay.stop();
10247
+ }
10248
+ }, []);
10249
+ const handleMouseLeave = React.useCallback(() => {
10250
+ if (swiperRef.current && swiperRef.current.swiper && isAlly) {
10251
+ swiperRef.current.swiper.autoplay.start();
10252
+ }
10253
+ }, []);
10254
+ const handleSlideChange = React.useCallback((swiper) => {
10255
+ setSwiperActiveIndex(swiper.activeIndex);
10256
+ }, []);
10257
+ const isAlly = React.useMemo(() => getScreenReader(), []);
9555
10258
  return (React.createElement(React.Fragment, null,
9556
10259
  React.createElement("div", Object.assign({ className: css.css(Object.assign({}, style)) }, props),
9557
- React.createElement("div", { style: { position: 'relative' } },
9558
- product && ((_w = product === null || product === void 0 ? void 0 : product.homePage) === null || _w === void 0 ? void 0 : _w.length) > 0 && (React.createElement(Swiper, { a11y: {
9559
- enabled: true
9560
- }, height: height, modules: [Pagination, Autoplay], pagination: {
10260
+ React.createElement("div", { style: { position: 'relative' }, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave },
10261
+ product && ((_w = product === null || product === void 0 ? void 0 : product.homePage) === null || _w === void 0 ? void 0 : _w.length) > 0 && (React.createElement(Swiper, Object.assign({ height: height, modules: [Pagination, Autoplay, ...(isAlly ? [Navigation, A11y, Mousewheel, Keyboard] : [])], pagination: {
9561
10262
  clickable: true,
9562
10263
  bulletActiveClass: 'swipe-item-active-bullet',
9563
10264
  clickableClass: getDotsAlign,
9564
10265
  bulletElement: 'button'
9565
- }, loop: true, autoplay: {
10266
+ } }, (isAlly
10267
+ ? {
10268
+ mousewheel: true,
10269
+ keyboard: true,
10270
+ navigation: true,
10271
+ a11y: {
10272
+ enabled: true
10273
+ }
10274
+ }
10275
+ : {}), { loop: true, autoplay: {
9566
10276
  delay: (swiper === null || swiper === void 0 ? void 0 : swiper.delay) * 1000
9567
- }, ref: ref, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': { bottom: (_x = swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom) !== null && _x !== void 0 ? _x : 0, fontSize: '14px' } }, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor) && {
10277
+ }, ref: swiperRef, onSlideChange: handleSlideChange, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': { bottom: (_x = swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom) !== null && _x !== void 0 ? _x : 0, fontSize: '14px' } }, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor) && {
9568
10278
  '.swiper-pagination-bullet': {
9569
10279
  backgroundColor: swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor,
9570
10280
  opacity: 1
@@ -9574,10 +10284,10 @@
9574
10284
  backgroundColor: `${swiper === null || swiper === void 0 ? void 0 : swiper.dotsActiveColor}!important`,
9575
10285
  opacity: 1
9576
10286
  }
9577
- }))) },
9578
- React.createElement(React.Fragment, null, (_y = product === null || product === void 0 ? void 0 : product.homePage) === null || _y === void 0 ? void 0 : _y.map((src) => {
10287
+ }))) }),
10288
+ React.createElement(React.Fragment, null, (_y = product === null || product === void 0 ? void 0 : product.homePage) === null || _y === void 0 ? void 0 : _y.map((src, srcKey) => {
9579
10289
  var _a;
9580
- return (React.createElement(SwiperSlide, { key: src },
10290
+ return (React.createElement(SwiperSlide, { key: srcKey, "aria-hidden": srcKey !== swiperActiveIndex },
9581
10291
  React.createElement("div", { style: {
9582
10292
  overflow: 'hidden',
9583
10293
  width,
@@ -10330,7 +11040,8 @@
10330
11040
  const curTimeRef = React.useRef(null);
10331
11041
  const [show3DModal, setShow3DModal] = React.useState(false);
10332
11042
  const [checkCommodityIndex, setCheckCommodityIndex] = React.useState((_b = popupDetailData === null || popupDetailData === void 0 ? void 0 : popupDetailData.multiCheckIndex) !== null && _b !== void 0 ? _b : 0);
10333
- const ref = React.useRef();
11043
+ const swiperRef = React.useRef();
11044
+ const [swiperActiveIndex, setSwiperActiveIndex] = React.useState(0);
10334
11045
  const data = isPost ? rec : popupDetailData;
10335
11046
  let product = isPost ? data === null || data === void 0 ? void 0 : data.product : (_d = (_c = data === null || data === void 0 ? void 0 : data.video) === null || _c === void 0 ? void 0 : _c.bindProduct) !== null && _d !== void 0 ? _d : (_f = (_e = data === null || data === void 0 ? void 0 : data.video) === null || _e === void 0 ? void 0 : _e.bindProducts) === null || _f === void 0 ? void 0 : _f[0];
10336
11047
  let cta = isPost
@@ -10450,9 +11161,9 @@ Made in Italy` })));
10450
11161
  popupCurTimeRef.current = new Date();
10451
11162
  setCheckCommodityIndex(index);
10452
11163
  checkCommodityIndexRef.current = index;
10453
- if (ref === null || ref === void 0 ? void 0 : ref.current) {
10454
- ref.current.swiper.slideTo(0);
10455
- ref.current.swiper.autoplay.start();
11164
+ if (swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) {
11165
+ swiperRef.current.swiper.slideTo(0);
11166
+ swiperRef.current.swiper.autoplay.start();
10456
11167
  }
10457
11168
  }, []);
10458
11169
  const renderCommodityGroup = React.useCallback(() => {
@@ -10470,17 +11181,40 @@ Made in Italy` })));
10470
11181
  return dotsAlignClass === null || dotsAlignClass === void 0 ? void 0 : dotsAlignClass[swiper === null || swiper === void 0 ? void 0 : swiper.dotsAlign];
10471
11182
  }, [swiper === null || swiper === void 0 ? void 0 : swiper.dotsAlign]);
10472
11183
  const iframeUrl = product === null || product === void 0 ? void 0 : product.remark;
11184
+ const handleMouseEnter = React.useCallback(() => {
11185
+ if (swiperRef.current && swiperRef.current.swiper && isAlly) {
11186
+ swiperRef.current.swiper.autoplay.stop();
11187
+ }
11188
+ }, []);
11189
+ const handleMouseLeave = React.useCallback(() => {
11190
+ if (swiperRef.current && swiperRef.current.swiper && isAlly) {
11191
+ swiperRef.current.swiper.autoplay.start();
11192
+ }
11193
+ }, []);
11194
+ const handleSlideChange = React.useCallback((swiper) => {
11195
+ setSwiperActiveIndex(swiper.activeIndex);
11196
+ }, []);
11197
+ const isAlly = React.useMemo(() => getScreenReader(), []);
10473
11198
  return (React.createElement("div", { className: 'pb-commondityDiroNew' },
10474
11199
  React.createElement("div", Object.assign({ className: css.css(Object.assign(Object.assign({}, style), { transform: 'translate3d(0px, 0px, 0px)' })) }, props),
10475
- React.createElement("div", { style: { position: 'relative' } },
10476
- product && ((_w = product === null || product === void 0 ? void 0 : product.homePage) === null || _w === void 0 ? void 0 : _w.length) > 0 && (React.createElement(Swiper, { height: height, modules: [Pagination, Autoplay], pagination: {
11200
+ React.createElement("div", { style: { position: 'relative' }, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave },
11201
+ product && ((_w = product === null || product === void 0 ? void 0 : product.homePage) === null || _w === void 0 ? void 0 : _w.length) > 0 && (React.createElement(Swiper, Object.assign({ height: height, modules: [Pagination, Autoplay, ...(isAlly ? [Navigation, A11y, Mousewheel, Keyboard] : [])], pagination: {
10477
11202
  clickable: true,
10478
11203
  bulletActiveClass: 'swipe-item-active-bullet',
10479
11204
  clickableClass: getDotsAlign,
10480
11205
  bulletElement: 'button'
10481
- }, loop: true, autoplay: {
11206
+ } }, (isAlly
11207
+ ? {
11208
+ mousewheel: true,
11209
+ keyboard: true,
11210
+ navigation: true,
11211
+ a11y: {
11212
+ enabled: true
11213
+ }
11214
+ }
11215
+ : {}), { loop: true, ref: swiperRef, onSlideChange: handleSlideChange, autoplay: {
10482
11216
  delay: (swiper === null || swiper === void 0 ? void 0 : swiper.delay) * 1000
10483
- }, ref: ref, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': {
11217
+ }, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': {
10484
11218
  bottom: (_x = swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom) !== null && _x !== void 0 ? _x : 0,
10485
11219
  fontSize: '14px'
10486
11220
  } }, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor) && {
@@ -10493,9 +11227,9 @@ Made in Italy` })));
10493
11227
  backgroundColor: `${swiper === null || swiper === void 0 ? void 0 : swiper.dotsActiveColor}!important`,
10494
11228
  opacity: 1
10495
11229
  }
10496
- }))) }, (_y = product === null || product === void 0 ? void 0 : product.homePage) === null || _y === void 0 ? void 0 : _y.map((src) => {
11230
+ }))) }), (_y = product === null || product === void 0 ? void 0 : product.homePage) === null || _y === void 0 ? void 0 : _y.map((src, srcKey) => {
10497
11231
  var _a;
10498
- return (React.createElement(SwiperSlide, { key: src },
11232
+ return (React.createElement(SwiperSlide, { key: srcKey, "aria-hidden": srcKey !== swiperActiveIndex },
10499
11233
  React.createElement("div", { style: {
10500
11234
  overflow: 'hidden',
10501
11235
  width,
@@ -15401,7 +16135,7 @@ Made in Italy` })));
15401
16135
 
15402
16136
  const closeIcon = '';
15403
16137
  const AniLinkPopup$1 = (_a) => {
15404
- var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0;
16138
+ var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
15405
16139
  var { style, recData, ctaTempStyles, index, event, bottom_image, translateY, isTel, onClick, isExternalLink = false, isActive } = _a, props = __rest(_a, ["style", "recData", "ctaTempStyles", "index", "event", "bottom_image", "translateY", "isTel", "onClick", "isExternalLink", "isActive"]);
15406
16140
  style === null || style === void 0 ? true : delete style.transform;
15407
16141
  const { sxpParameter, globalConfig, ctaEvent, setPopupDetailData } = useSxpDataSource();
@@ -15458,12 +16192,12 @@ Made in Italy` })));
15458
16192
  paddingLeft: '6px'
15459
16193
  } }, "Cta Title")) : (React.createElement("div", Object.assign({}, props, { className: `${css.css(Object.assign(Object.assign({}, style), { '--transY': `translateY(calc(100% + ${(_r = style === null || style === void 0 ? void 0 : style.margin) !== null && _r !== void 0 ? _r : 0}px))` }))} ${styles['aniLinkPopup']} ${aniNamStyle} ${css.css(aniTimStyle)}`, onClick: handleTo }),
15460
16194
  React.createElement("div", { onClick: onClose, className: styles['modal-icon-wrapper'], style: { padding: (_s = style === null || style === void 0 ? void 0 : style['padding']) !== null && _s !== void 0 ? _s : 0 } },
15461
- React.createElement("img", { src: (_t = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) !== null && _t !== void 0 ? _t : closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
15462
- React.createElement(Img$1, { src: src, rec: recData, item: (_y = (_w = (_v = (_u = recData === null || recData === void 0 ? void 0 : recData.video) === null || _u === void 0 ? void 0 : _u.bindProducts) === null || _v === void 0 ? void 0 : _v[0]) !== null && _w !== void 0 ? _w : (_x = recData === null || recData === void 0 ? void 0 : recData.video) === null || _x === void 0 ? void 0 : _x.bindProduct) !== null && _y !== void 0 ? _y : recData === null || recData === void 0 ? void 0 : recData.video, index: index, translateY: translateY, imgStyle: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.img, isActive: isActive }),
16195
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16196
+ React.createElement(Img$1, { src: src, rec: recData, item: (_x = (_v = (_u = (_t = recData === null || recData === void 0 ? void 0 : recData.video) === null || _t === void 0 ? void 0 : _t.bindProducts) === null || _u === void 0 ? void 0 : _u[0]) !== null && _v !== void 0 ? _v : (_w = recData === null || recData === void 0 ? void 0 : recData.video) === null || _w === void 0 ? void 0 : _w.bindProduct) !== null && _x !== void 0 ? _x : recData === null || recData === void 0 ? void 0 : recData.video, index: index, translateY: translateY, imgStyle: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.img, isActive: isActive }),
15463
16197
  (!recData || (product === null || product === void 0 ? void 0 : product.title)) && (React.createElement("div", { className: styles['one-line-ellipsis'], style: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.title, dangerouslySetInnerHTML: {
15464
- __html: setFontForText((_z = product === null || product === void 0 ? void 0 : product.title) !== null && _z !== void 0 ? _z : 'Product Name', ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.title)
16198
+ __html: setFontForText((_y = product === null || product === void 0 ? void 0 : product.title) !== null && _y !== void 0 ? _y : 'Product Name', ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.title)
15465
16199
  } })),
15466
- React.createElement("div", { className: styles['one-line-ellipsis'], style: Object.assign(Object.assign({}, ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle), { lineHeight: ((_0 = ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle) === null || _0 === void 0 ? void 0 : _0.height) + 'px' }), dangerouslySetInnerHTML: {
16200
+ React.createElement("div", { className: styles['one-line-ellipsis'], style: Object.assign(Object.assign({}, ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle), { lineHeight: ((_z = ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle) === null || _z === void 0 ? void 0 : _z.height) + 'px' }), dangerouslySetInnerHTML: {
15467
16201
  __html: setFontForText(title, ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle)
15468
16202
  } })))));
15469
16203
  };
@@ -16475,15 +17209,16 @@ Made in Italy` })));
16475
17209
 
16476
17210
  const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onViewImageEndEvent, onViewImageStartEvent, imgUrlsPostConfig }) => {
16477
17211
  var _a, _b;
16478
- const ref = React.useRef();
17212
+ const swiperRef = React.useRef();
16479
17213
  const { isActive } = useSwiperSlide();
16480
17214
  const { sxpParameter, openHashtag } = useSxpDataSource();
16481
17215
  const [isLoad, setIsLoad] = React.useState(false);
16482
17216
  const [imgInfo, setImgInfo] = React.useState();
16483
17217
  const initTime = new Date();
17218
+ const [swiperActiveIndex, setSwiperActiveIndex] = React.useState(0);
16484
17219
  React.useEffect(() => {
16485
17220
  if (isLoad && isActive) {
16486
- (ref === null || ref === void 0 ? void 0 : ref.current) && ref.current.swiper.autoplay.start();
17221
+ (swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) && swiperRef.current.swiper.autoplay.start();
16487
17222
  if (openHashtag) {
16488
17223
  onViewImageEndEvent(rec);
16489
17224
  }
@@ -16492,7 +17227,7 @@ Made in Italy` })));
16492
17227
  }
16493
17228
  }
16494
17229
  else {
16495
- (ref === null || ref === void 0 ? void 0 : ref.current) && ref.current.swiper.autoplay.stop();
17230
+ (swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) && swiperRef.current.swiper.autoplay.stop();
16496
17231
  }
16497
17232
  }, [rec, isActive, onViewImageEndEvent, openHashtag, index, onViewImageStartEvent, isLoad, imgInfo]);
16498
17233
  const showFirstImageFn = React.useCallback((e) => __awaiter(void 0, void 0, void 0, function* () {
@@ -16516,27 +17251,51 @@ Made in Italy` })));
16516
17251
  SXP_EVENT_BUS.off(SXP_EVENT_TYPE.PAGE_DID_HIDE, onHide);
16517
17252
  };
16518
17253
  }, [imgInfo]);
16519
- return (React.createElement(Swiper, { ref: ref, defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay], pagination: {
16520
- clickable: true,
16521
- bulletActiveClass: 'swipe-item-active-bullet',
16522
- bulletElement: 'button'
16523
- }, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': {
16524
- bottom: (_a = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) !== null && _a !== void 0 ? _a : 0,
16525
- fontSize: '14px'
16526
- } }, ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsBgColor) && {
16527
- '.swiper-pagination-bullet': {
16528
- backgroundColor: imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsBgColor,
16529
- opacity: 1
16530
- }
16531
- })), ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsActiveColor) && {
16532
- '.swipe-item-active-bullet': {
16533
- backgroundColor: `${imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsActiveColor}!important`,
16534
- opacity: 1
17254
+ const handleMouseEnter = React.useCallback(() => {
17255
+ if (swiperRef.current && swiperRef.current.swiper && isAlly) {
17256
+ swiperRef.current.swiper.autoplay.stop();
17257
+ }
17258
+ }, []);
17259
+ const handleMouseLeave = React.useCallback(() => {
17260
+ if (swiperRef.current && swiperRef.current.swiper && isAlly) {
17261
+ swiperRef.current.swiper.autoplay.start();
17262
+ }
17263
+ }, []);
17264
+ const handleSlideChange = React.useCallback((swiper) => {
17265
+ setSwiperActiveIndex(swiper.activeIndex);
17266
+ }, []);
17267
+ const isAlly = React.useMemo(() => getScreenReader(), []);
17268
+ return (React.createElement("div", { onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave },
17269
+ React.createElement(Swiper, Object.assign({ defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay, ...(isAlly ? [Navigation, A11y, Mousewheel, Keyboard] : [])], pagination: {
17270
+ clickable: true,
17271
+ bulletActiveClass: 'swipe-item-active-bullet',
17272
+ bulletElement: 'button'
17273
+ } }, (isAlly
17274
+ ? {
17275
+ mousewheel: true,
17276
+ keyboard: true,
17277
+ navigation: true,
17278
+ a11y: {
17279
+ enabled: true
17280
+ }
16535
17281
  }
16536
- }))), height: height, loop: true, autoplay: { delay: ((_b = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.delay) !== null && _b !== void 0 ? _b : 3) * 1000 } }, imgUrls === null || imgUrls === void 0 ? void 0 : imgUrls.map((url, index) => {
16537
- return (React.createElement(SwiperSlide, { key: index },
16538
- React.createElement(Picture, { src: !isLoad && index > 0 ? '' : url, height: height, imgUrlsPostConfig: imgUrlsPostConfig, onShowFirstImage: showFirstImageFn })));
16539
- })));
17282
+ : {}), { loop: true, ref: swiperRef, onSlideChange: handleSlideChange, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': {
17283
+ bottom: (_a = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) !== null && _a !== void 0 ? _a : 0,
17284
+ fontSize: '14px'
17285
+ } }, ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsBgColor) && {
17286
+ '.swiper-pagination-bullet': {
17287
+ backgroundColor: imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsBgColor,
17288
+ opacity: 1
17289
+ }
17290
+ })), ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsActiveColor) && {
17291
+ '.swipe-item-active-bullet': {
17292
+ backgroundColor: `${imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsActiveColor}!important`,
17293
+ opacity: 1
17294
+ }
17295
+ }))), height: height, autoplay: { delay: ((_b = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.delay) !== null && _b !== void 0 ? _b : 3) * 1000 } }), imgUrls === null || imgUrls === void 0 ? void 0 : imgUrls.map((url, srcKey) => {
17296
+ return (React.createElement(SwiperSlide, { key: srcKey, "aria-hidden": srcKey !== swiperActiveIndex },
17297
+ React.createElement(Picture, { src: !isLoad && srcKey > 0 ? '' : url, height: height, imgUrlsPostConfig: imgUrlsPostConfig, onShowFirstImage: showFirstImageFn })));
17298
+ }))));
16540
17299
  };
16541
17300
  var PictureGroup$3 = React.memo(PictureGroup$2);
16542
17301