oasys-lib 2.6.0-rc.0 → 2.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/alert/alert-cancel.directive.mjs +22 -0
- package/esm2022/lib/components/alert/alert-confirm.directive.mjs +22 -0
- package/esm2022/lib/components/alert/alert-content.directive.mjs +14 -0
- package/esm2022/lib/components/alert/alert-title.directive.mjs +14 -0
- package/esm2022/lib/components/alert/alert.component.mjs +78 -0
- package/esm2022/lib/components/alert/alert.module.mjs +40 -0
- package/esm2022/lib/components/alert/index.mjs +7 -0
- package/esm2022/lib/components/banner/banner.component.mjs +62 -0
- package/esm2022/lib/components/banner/banner.module.mjs +16 -0
- package/esm2022/lib/components/banner/index.mjs +3 -0
- package/esm2022/lib/components/button/button.component.mjs +120 -0
- package/esm2022/lib/components/button/button.mjs +2 -0
- package/esm2022/lib/components/button/button.module.mjs +16 -0
- package/esm2022/lib/components/button/index.mjs +4 -0
- package/esm2022/lib/components/button-group/button-group.component.mjs +55 -0
- package/esm2022/lib/components/button-group/button-group.module.mjs +16 -0
- package/esm2022/lib/components/button-group/index.mjs +3 -0
- package/esm2022/lib/components/card/card.component.mjs +87 -0
- package/esm2022/lib/components/card/card.mjs +2 -0
- package/esm2022/lib/components/card/card.module.mjs +16 -0
- package/esm2022/lib/components/card/index.mjs +3 -0
- package/esm2022/lib/components/carousel/carousel.component.mjs +289 -0
- package/esm2022/lib/components/carousel/carousel.module.mjs +16 -0
- package/esm2022/lib/components/carousel/index.mjs +3 -0
- package/esm2022/lib/components/divider/divider.component.mjs +22 -0
- package/esm2022/lib/components/divider/divider.mjs +2 -0
- package/esm2022/lib/components/divider/divider.module.mjs +16 -0
- package/esm2022/lib/components/divider/index.mjs +3 -0
- package/esm2022/lib/components/form/checkbox/checkbox.component.mjs +81 -0
- package/esm2022/lib/components/form/checkbox/checkbox.module.mjs +16 -0
- package/esm2022/lib/components/form/checkbox/index.mjs +3 -0
- package/esm2022/lib/components/form/chip/chip.component.mjs +88 -0
- package/esm2022/lib/components/form/chip/chip.module.mjs +16 -0
- package/esm2022/lib/components/form/chip/index.mjs +3 -0
- package/esm2022/lib/components/form/combobox/combobox.component.mjs +478 -0
- package/esm2022/lib/components/form/combobox/combobox.mjs +2 -0
- package/esm2022/lib/components/form/combobox/combobox.module.mjs +82 -0
- package/esm2022/lib/components/form/combobox/index.mjs +3 -0
- package/esm2022/lib/components/form/errors/form-errors.component.mjs +26 -0
- package/esm2022/lib/components/form/errors/form-errors.module.mjs +16 -0
- package/esm2022/lib/components/form/errors/index.mjs +3 -0
- package/esm2022/lib/components/form/errors-summary/errors-summary-item/form-errors-summary-item.component.mjs +47 -0
- package/esm2022/lib/components/form/errors-summary/errors-summary-title/form-errors-summary-title.component.mjs +21 -0
- package/esm2022/lib/components/form/errors-summary/form-errors-summary.component.mjs +30 -0
- package/esm2022/lib/components/form/errors-summary/index.mjs +4 -0
- package/esm2022/lib/components/form/form-group/form-group.component.mjs +32 -0
- package/esm2022/lib/components/form/form-group/form-group.module.mjs +16 -0
- package/esm2022/lib/components/form/form-group/index.mjs +3 -0
- package/esm2022/lib/components/form/forms.mjs +2 -0
- package/esm2022/lib/components/form/radio/index.mjs +3 -0
- package/esm2022/lib/components/form/radio/radio.component.mjs +80 -0
- package/esm2022/lib/components/form/radio/radio.module.mjs +16 -0
- package/esm2022/lib/components/form/text-input/index.mjs +4 -0
- package/esm2022/lib/components/form/text-input/text-input.component.mjs +204 -0
- package/esm2022/lib/components/form/text-input/text-input.mjs +2 -0
- package/esm2022/lib/components/form/text-input/text-input.module.mjs +16 -0
- package/esm2022/lib/components/heading/heading.component.mjs +107 -0
- package/esm2022/lib/components/heading/heading.mjs +2 -0
- package/esm2022/lib/components/heading/heading.module.mjs +16 -0
- package/esm2022/lib/components/heading/index.mjs +3 -0
- package/esm2022/lib/components/hero/hero.component.mjs +109 -0
- package/esm2022/lib/components/hero/hero.module.mjs +16 -0
- package/esm2022/lib/components/hero/index.mjs +3 -0
- package/esm2022/lib/components/icon/icon.component.mjs +61 -0
- package/esm2022/lib/components/icon/icon.mjs +2 -0
- package/esm2022/lib/components/icon/icon.module.mjs +16 -0
- package/esm2022/lib/components/icon/index.mjs +4 -0
- package/esm2022/lib/components/image/image.component.mjs +154 -0
- package/esm2022/lib/components/image/image.mjs +2 -0
- package/esm2022/lib/components/image/image.module.mjs +16 -0
- package/esm2022/lib/components/image/index.mjs +3 -0
- package/esm2022/lib/components/label/index.mjs +3 -0
- package/esm2022/lib/components/label/label.component.mjs +69 -0
- package/esm2022/lib/components/label/label.module.mjs +16 -0
- package/esm2022/lib/components/layout/Layout.mjs +2 -0
- package/esm2022/lib/components/layout/box/box.component.mjs +183 -0
- package/esm2022/lib/components/layout/box/box.mjs +3 -0
- package/esm2022/lib/components/layout/container/container.component.mjs +44 -0
- package/esm2022/lib/components/layout/grid/grid-column.component.mjs +55 -0
- package/esm2022/lib/components/layout/grid/grid.component.mjs +53 -0
- package/esm2022/lib/components/layout/index.mjs +8 -0
- package/esm2022/lib/components/layout/layout.module.mjs +40 -0
- package/esm2022/lib/components/layout/stack/stack.component.mjs +64 -0
- package/esm2022/lib/components/navigation/breadcrumbs/breadcrumbs.component.mjs +37 -0
- package/esm2022/lib/components/navigation/breadcrumbs/breadcrumbs.module.mjs +16 -0
- package/esm2022/lib/components/navigation/breadcrumbs/index.mjs +3 -0
- package/esm2022/lib/components/navigation/tabs/tab/tab.component.mjs +33 -0
- package/esm2022/lib/components/navigation/tabs/tab-active/tab-active.component.mjs +19 -0
- package/esm2022/lib/components/navigation/tabs/tab-group/index.mjs +4 -0
- package/esm2022/lib/components/navigation/tabs/tab-group/tab-group.component.mjs +38 -0
- package/esm2022/lib/components/navigation/tabs/tab-group/tab-group.module.mjs +27 -0
- package/esm2022/lib/components/navigation/tabs/tab-header/tab-header.component.mjs +70 -0
- package/esm2022/lib/components/pill/index.mjs +3 -0
- package/esm2022/lib/components/pill/pill.component.mjs +21 -0
- package/esm2022/lib/components/pill/pill.mjs +2 -0
- package/esm2022/lib/components/pill/pill.module.mjs +16 -0
- package/esm2022/lib/components/pill-group/index.mjs +3 -0
- package/esm2022/lib/components/pill-group/pill-group.component.mjs +41 -0
- package/esm2022/lib/components/pill-group/pill-group.module.mjs +16 -0
- package/esm2022/lib/components/price/index.mjs +3 -0
- package/esm2022/lib/components/price/price.component.mjs +32 -0
- package/esm2022/lib/components/price/price.module.mjs +16 -0
- package/esm2022/lib/components/progress-bar/index.mjs +2 -0
- package/esm2022/lib/components/progress-bar/progress-bar.component.mjs +23 -0
- package/esm2022/lib/components/promo-card/index.mjs +3 -0
- package/esm2022/lib/components/promo-card/promo-card.component.mjs +87 -0
- package/esm2022/lib/components/promo-card/promo-card.module.mjs +16 -0
- package/esm2022/lib/components/section/index.mjs +3 -0
- package/esm2022/lib/components/section/section.component.mjs +119 -0
- package/esm2022/lib/components/section/section.module.mjs +16 -0
- package/esm2022/lib/components/select-card/index.mjs +3 -0
- package/esm2022/lib/components/select-card/select-card.component.mjs +94 -0
- package/esm2022/lib/components/select-card/select-card.module.mjs +16 -0
- package/esm2022/lib/components/seo-block/index.mjs +3 -0
- package/esm2022/lib/components/seo-block/seo-block.component.mjs +84 -0
- package/esm2022/lib/components/seo-block/seo-block.module.mjs +16 -0
- package/esm2022/lib/components/text/index.mjs +3 -0
- package/esm2022/lib/components/text/text.component.mjs +29 -0
- package/esm2022/lib/components/text/text.mjs +2 -0
- package/esm2022/lib/components/text/text.module.mjs +16 -0
- package/esm2022/lib/directives/autofocus/autofocus.directive.mjs +31 -0
- package/esm2022/lib/directives/emphasis/emphasis.directive.mjs +38 -0
- package/esm2022/lib/directives/href/href.directive.mjs +26 -0
- package/esm2022/lib/services/breakpoint.service.mjs +49 -0
- package/esm2022/lib/services/image.service.mjs +68 -0
- package/esm2022/lib/services/index.mjs +4 -0
- package/esm2022/lib/services/media-base-url.provider.mjs +3 -0
- package/esm2022/lib/services/routing-handler.provider.mjs +3 -0
- package/esm2022/lib/services/swiper.provider.mjs +13 -0
- package/esm2022/lib/services/token.service.mjs +71 -0
- package/esm2022/oasys-lib.mjs +5 -0
- package/esm2022/public-api.mjs +38 -0
- package/fesm2022/oasys-lib.mjs +297 -278
- package/fesm2022/oasys-lib.mjs.map +1 -1
- package/lib/components/form/text-input/index.d.ts +2 -1
- package/lib/components/form/text-input/index.d.ts.map +1 -1
- package/lib/components/form/text-input/text-input.component.d.ts +7 -3
- package/lib/components/form/text-input/text-input.component.d.ts.map +1 -1
- package/package.json +5 -3
- package/src/assets/bloomandwild/variables.css +1 -1
- package/src/assets/bloomon/variables.css +1 -1
- package/src/assets/global/scss-breakpoints.scss +1 -1
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
import { DOCUMENT, NgClass, NgIf } from '@angular/common';
|
|
2
|
+
import { Component, ElementRef, Input, ViewChild, ViewEncapsulation, Inject, EventEmitter, Output, CUSTOM_ELEMENTS_SCHEMA, inject, } from '@angular/core';
|
|
3
|
+
import { TokenService } from '../../services/token.service';
|
|
4
|
+
import { LayoutBoxComponent } from '../layout/box/box.component';
|
|
5
|
+
import { LayoutStackComponent } from '../layout/stack/stack.component';
|
|
6
|
+
import { OasysButtonComponent } from '../button/button.component';
|
|
7
|
+
import { SWIPER_PROVIDER_TOKEN } from '../../services';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../../services/token.service";
|
|
10
|
+
/* This component wraps around the swiper.js library WebComponent */
|
|
11
|
+
export class CarouselComponent {
|
|
12
|
+
tokenService;
|
|
13
|
+
document;
|
|
14
|
+
element;
|
|
15
|
+
// The swiper instance
|
|
16
|
+
swiper;
|
|
17
|
+
carouselscrollbarplaceholder;
|
|
18
|
+
carouselctastack;
|
|
19
|
+
// Rewinds the slides back to the start when the user reaches the end when set to true
|
|
20
|
+
rewind = false;
|
|
21
|
+
carousel_overflow = false;
|
|
22
|
+
carousel_gap = 'default';
|
|
23
|
+
carousel_pagination = 'none';
|
|
24
|
+
carousel_slides_per_view_desktop = 4;
|
|
25
|
+
carousel_slides_per_view_laptop = 3;
|
|
26
|
+
carousel_slides_per_view_tablet = 2.5;
|
|
27
|
+
carousel_slides_per_view_mobile = 1.25;
|
|
28
|
+
text_for_left_arrow = 'previous slide';
|
|
29
|
+
text_for_right_arrow = 'next slide';
|
|
30
|
+
carousel_rows_per_row_mobile = 1; // Required for CATEGORY_CARD experiment. Remove if experiment fails.
|
|
31
|
+
carousel_loading = 'lazy'; // If we don't have multiple carousels on page and want to prioritise UI loading on time
|
|
32
|
+
carousel_free_mode = false; // Enables scrolling with mousewheel / smoother momentum swiping experience
|
|
33
|
+
center_insufficient_slides = true; // Centers the slides if there are not enough to fill the space
|
|
34
|
+
center_active_slide = false; // Centers the active slide
|
|
35
|
+
start_slide = 0; // Start slide index
|
|
36
|
+
offset_scrollbar_top = false; // Offset the scrollbar to the top of the carousel
|
|
37
|
+
activeIndexOnSlideChange = new EventEmitter();
|
|
38
|
+
constructor(tokenService, document, element) {
|
|
39
|
+
this.tokenService = tokenService;
|
|
40
|
+
this.document = document;
|
|
41
|
+
this.element = element;
|
|
42
|
+
inject(SWIPER_PROVIDER_TOKEN).ensureSwiperRegistered();
|
|
43
|
+
}
|
|
44
|
+
ngOnInit() {
|
|
45
|
+
if (this.carousel_loading === 'lazy') {
|
|
46
|
+
this.setUpIntersectionObserver();
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
this.initSwiper();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Set up the intersection observer with the relevant options
|
|
54
|
+
*/
|
|
55
|
+
setUpIntersectionObserver() {
|
|
56
|
+
// Set IntersectionObserver options
|
|
57
|
+
const options = {
|
|
58
|
+
root: null,
|
|
59
|
+
rootMargin: '0px',
|
|
60
|
+
threshold: 0.5,
|
|
61
|
+
once: true,
|
|
62
|
+
};
|
|
63
|
+
// Set up the IntersectionObserver
|
|
64
|
+
const observer = new IntersectionObserver(this.onIntersection.bind(this), options);
|
|
65
|
+
observer.observe(this.element.nativeElement);
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* This function gets called just before the user scrolls this component into view
|
|
69
|
+
* @param entries - An array of interswection observer entries
|
|
70
|
+
* @param observer - Intersection observer
|
|
71
|
+
*/
|
|
72
|
+
onIntersection(entries, observer) {
|
|
73
|
+
entries.forEach((entry) => {
|
|
74
|
+
if (entry.isIntersecting) {
|
|
75
|
+
// Initialise swiper
|
|
76
|
+
this.initSwiper();
|
|
77
|
+
observer.unobserve(entry.target);
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
getStyle(element, style) {
|
|
82
|
+
return this.document.defaultView.getComputedStyle(element, null).getPropertyValue(style);
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Set the scrollbar placement and width based on carouselscrollbarplaceholder and carouselctastack
|
|
86
|
+
*/
|
|
87
|
+
setupScrollbarLayoutProperties() {
|
|
88
|
+
if (this.carousel_pagination === 'none') {
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
const carouselStack = this.carouselctastack?.nativeElement;
|
|
92
|
+
const scrollbarElement = this.carouselscrollbarplaceholder?.nativeElement;
|
|
93
|
+
const scrollbarHeight = this.document.defaultView
|
|
94
|
+
.getComputedStyle(document.documentElement)
|
|
95
|
+
.getPropertyValue('--swiper-scrollbar-size');
|
|
96
|
+
if (carouselStack && this.carousel_pagination === 'scroll-arrows') {
|
|
97
|
+
this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-width', `${scrollbarElement?.offsetWidth - parseInt(this.getStyle(carouselStack, 'gap'), 10)}px`);
|
|
98
|
+
this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-offset-top', `${parseInt(this.getStyle(carouselStack, 'gap'), 10) + scrollbarElement?.offsetHeight / 2 + parseInt(scrollbarHeight, 10) / 2}px`);
|
|
99
|
+
this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-height', '2px');
|
|
100
|
+
}
|
|
101
|
+
if (carouselStack && this.carousel_pagination === 'scroll-bar') {
|
|
102
|
+
this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-width', '100%');
|
|
103
|
+
this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-offset-top', `${this.offset_scrollbar_top ? parseInt(this.getStyle(carouselStack, 'gap'), 10) + 'px' : '0px'}`);
|
|
104
|
+
this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-height', '4px');
|
|
105
|
+
this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-left', '0px');
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Set the dynamic swiper params and initialise the swiper instance
|
|
110
|
+
*/
|
|
111
|
+
// eslint-disable-next-line complexity
|
|
112
|
+
initSwiper() {
|
|
113
|
+
// Colour overides
|
|
114
|
+
const scrollbarBackgroundColour = this.tokenService.getTokenValue('--oasys-color-linen-grey-200');
|
|
115
|
+
const scrollbarSliderColour = this.tokenService.getTokenValue('--oasys-color-brand-foreground-primary');
|
|
116
|
+
// swiper element
|
|
117
|
+
const swiperEl = this.swiper.nativeElement;
|
|
118
|
+
const carouselGap = this.tokenService.getTokenValue(`--oasys-spacing-${this.carousel_gap}`);
|
|
119
|
+
// swiper parameters
|
|
120
|
+
const swiperParams = {
|
|
121
|
+
rewind: this.rewind,
|
|
122
|
+
grabCursor: true,
|
|
123
|
+
spaceBetween: parseInt(carouselGap.replace('.', ''), 10) || 0,
|
|
124
|
+
centeredSlides: this.center_active_slide,
|
|
125
|
+
initialSlide: this.start_slide,
|
|
126
|
+
scrollbar: {
|
|
127
|
+
enabled: this.carousel_pagination === 'scroll-arrows' || this.carousel_pagination === 'scroll-bar',
|
|
128
|
+
draggable: true,
|
|
129
|
+
},
|
|
130
|
+
centerInsufficientSlides: this.center_insufficient_slides,
|
|
131
|
+
freeMode: this.carousel_free_mode
|
|
132
|
+
? {
|
|
133
|
+
enabled: true,
|
|
134
|
+
sticky: true,
|
|
135
|
+
momentumVelocityRatio: 0.75,
|
|
136
|
+
momentumRatio: 0.75,
|
|
137
|
+
}
|
|
138
|
+
: false,
|
|
139
|
+
mousewheel: this.carousel_free_mode
|
|
140
|
+
? {
|
|
141
|
+
forceToAxis: true,
|
|
142
|
+
}
|
|
143
|
+
: false,
|
|
144
|
+
injectStyles: [
|
|
145
|
+
`
|
|
146
|
+
.swiper {
|
|
147
|
+
overflow: ${this.carousel_overflow ? 'visible' : 'hidden'} !important;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
.swiper-scrollbar.swiper-scrollbar-horizontal {
|
|
151
|
+
position: relative;
|
|
152
|
+
top: var(--ui-carousel-scrollbar-offset-top);
|
|
153
|
+
width: var(--ui-carousel-scrollbar-width);
|
|
154
|
+
height: var(--ui-carousel-scrollbar-height);
|
|
155
|
+
left: ${this.carousel_pagination === 'scroll-bar' ? 'var(--ui-carousel-scrollbar-left)' : '1%'};
|
|
156
|
+
background: ${scrollbarBackgroundColour}
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
.swiper-scrollbar-drag {
|
|
160
|
+
background: ${scrollbarSliderColour}
|
|
161
|
+
}`,
|
|
162
|
+
],
|
|
163
|
+
breakpoints: {
|
|
164
|
+
0: {
|
|
165
|
+
scrollbar: {
|
|
166
|
+
enabled: this.carousel_pagination === 'scroll-arrows' ||
|
|
167
|
+
this.carousel_pagination === 'scroll-bar',
|
|
168
|
+
draggable: true,
|
|
169
|
+
},
|
|
170
|
+
slidesPerView: this.carousel_slides_per_view_mobile,
|
|
171
|
+
grid: {
|
|
172
|
+
rows: this.carousel_rows_per_row_mobile,
|
|
173
|
+
fill: 'row',
|
|
174
|
+
},
|
|
175
|
+
},
|
|
176
|
+
767: {
|
|
177
|
+
scrollbar: {
|
|
178
|
+
enabled: this.carousel_pagination === 'scroll-arrows' ||
|
|
179
|
+
this.carousel_pagination === 'scroll-bar',
|
|
180
|
+
draggable: true,
|
|
181
|
+
},
|
|
182
|
+
slidesPerView: this.carousel_slides_per_view_tablet,
|
|
183
|
+
},
|
|
184
|
+
1080: {
|
|
185
|
+
scrollbar: {
|
|
186
|
+
enabled: this.carousel_pagination === 'scroll-arrows' ||
|
|
187
|
+
this.carousel_pagination === 'scroll-bar',
|
|
188
|
+
draggable: true,
|
|
189
|
+
},
|
|
190
|
+
slidesPerView: this.carousel_slides_per_view_laptop,
|
|
191
|
+
},
|
|
192
|
+
1440: {
|
|
193
|
+
scrollbar: {
|
|
194
|
+
enabled: this.carousel_pagination === 'scroll-arrows' ||
|
|
195
|
+
this.carousel_pagination === 'scroll-bar',
|
|
196
|
+
draggable: true,
|
|
197
|
+
},
|
|
198
|
+
slidesPerView: this.carousel_slides_per_view_desktop,
|
|
199
|
+
},
|
|
200
|
+
},
|
|
201
|
+
on: {
|
|
202
|
+
slideChange: this.onSlideChange.bind(this),
|
|
203
|
+
},
|
|
204
|
+
};
|
|
205
|
+
// now we need to assign all parameters to the Swiper element
|
|
206
|
+
Object.assign(swiperEl, swiperParams);
|
|
207
|
+
// and now initialize it
|
|
208
|
+
swiperEl.initialize();
|
|
209
|
+
// Set up scrollbar and ensure this is recalculated on resize events
|
|
210
|
+
this.setupScrollbarLayoutProperties();
|
|
211
|
+
swiperEl.addEventListener('resize', () => {
|
|
212
|
+
this.setupScrollbarLayoutProperties();
|
|
213
|
+
});
|
|
214
|
+
}
|
|
215
|
+
/**
|
|
216
|
+
* Move the carousel on to the next slide
|
|
217
|
+
*/
|
|
218
|
+
nextSlide() {
|
|
219
|
+
this.swiper.nativeElement.swiper.slideNext();
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Move the carousel back to the previous slide
|
|
223
|
+
*/
|
|
224
|
+
previousSlide() {
|
|
225
|
+
this.swiper.nativeElement.swiper.slidePrev();
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Emit event when the slide changes
|
|
229
|
+
* @param swiper
|
|
230
|
+
*/
|
|
231
|
+
onSlideChange(swiper) {
|
|
232
|
+
this.activeIndexOnSlideChange.emit(swiper.activeIndex);
|
|
233
|
+
}
|
|
234
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CarouselComponent, deps: [{ token: i1.TokenService }, { token: DOCUMENT }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
235
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CarouselComponent, isStandalone: true, selector: "ui-carousel", inputs: { rewind: "rewind", carousel_overflow: "carousel_overflow", carousel_gap: "carousel_gap", carousel_pagination: "carousel_pagination", carousel_slides_per_view_desktop: "carousel_slides_per_view_desktop", carousel_slides_per_view_laptop: "carousel_slides_per_view_laptop", carousel_slides_per_view_tablet: "carousel_slides_per_view_tablet", carousel_slides_per_view_mobile: "carousel_slides_per_view_mobile", text_for_left_arrow: "text_for_left_arrow", text_for_right_arrow: "text_for_right_arrow", carousel_rows_per_row_mobile: "carousel_rows_per_row_mobile", carousel_loading: "carousel_loading", carousel_free_mode: "carousel_free_mode", center_insufficient_slides: "center_insufficient_slides", center_active_slide: "center_active_slide", start_slide: "start_slide", offset_scrollbar_top: "offset_scrollbar_top" }, outputs: { activeIndexOnSlideChange: "activeIndexOnSlideChange" }, providers: [TokenService], viewQueries: [{ propertyName: "swiper", first: true, predicate: ["swiper"], descendants: true, static: true }, { propertyName: "carouselscrollbarplaceholder", first: true, predicate: ["carouselscrollbarplaceholder"], descendants: true, read: ElementRef }, { propertyName: "carouselctastack", first: true, predicate: ["carouselctastack"], descendants: true, read: ElementRef }], ngImport: i0, template: "<ui-box\n class=\"ui-carousel\"\n [ngClass]=\"{ 'ui-carousel-overflow': carousel_overflow }\"\n box_align_y=\"center\"\n box_space=\"none\"\n [box_content_fill_width]=\"true\"\n box_background=\"transparent\"\n>\n <ui-stack #carouselctastack>\n <!-- Custom navigation buttons -->\n <ui-stack\n *ngIf=\"carousel_pagination === 'small-arrows'\"\n stack_direction=\"x\"\n stack_align=\"center\"\n stack_distribute=\"end\"\n >\n <ui-box\n box_space=\"none\"\n box_fill_mode=\"fit\"\n box_space_bottom=\"none\"\n [box_space_right]=\"{ mobile: 'tight', tablet: 'none', laptop: 'none', desktop: 'none' }\"\n box_background=\"transparent\"\n >\n <div\n *ngIf=\"!(swiper?.swiper?.isBeginning && swiper?.swiper?.isEnd)\"\n class=\"ui-carousel__small-arrows\"\n >\n <!-- Previous button-->\n <ui-button\n class=\"ui-carousel__previous\"\n button_size=\"small\"\n button_icon_placement=\"iconOnly\"\n button_icon=\"arrow-left\"\n button_type=\"tertiary\"\n [aria_label]=\"text_for_left_arrow\"\n (clicked)=\"previousSlide()\"\n >\n Prevous slide\n </ui-button>\n <!-- Next button-->\n <ui-button\n class=\"ui-carousel__next\"\n button_size=\"small\"\n button_icon_placement=\"iconOnly\"\n button_icon=\"arrow-right\"\n button_type=\"tertiary\"\n [aria_label]=\"text_for_right_arrow\"\n (clicked)=\"nextSlide()\"\n >\n Next slide\n </ui-button>\n </div>\n </ui-box>\n </ui-stack>\n\n <!-- Swiper WebComponent-->\n <swiper-container\n #swiper\n init=\"false\"\n touch-start-prevent-default=\"false\"\n prevent-clicks-propagation=\"true\"\n >\n <ng-content></ng-content>\n </swiper-container>\n\n <!-- Custom navigation buttons -->\n <ui-stack\n stack_direction=\"x\"\n stack_align=\"center\"\n *ngIf=\"carousel_pagination === 'scroll-arrows' || carousel_pagination === 'scroll-bar'\"\n >\n <div class=\"ui-carousel-scrollbar-placeholder\" #carouselscrollbarplaceholder></div>\n <ui-box\n *ngIf=\"carousel_pagination === 'scroll-arrows'\"\n box_space=\"none\"\n box_fill_mode=\"fit\"\n [box_space_right]=\"{ mobile: 'tight', tablet: 'none', laptop: 'none', desktop: 'none' }\"\n box_background=\"transparent\"\n >\n <ui-stack\n *ngIf=\"!(swiper?.swiper?.isBeginning && swiper?.swiper?.isEnd)\"\n stack_direction=\"x\"\n stack_gap=\"near\"\n >\n <!-- Previous button-->\n <ui-button\n class=\"ui-carousel__previous\"\n button_size=\"large\"\n button_icon_placement=\"iconOnly\"\n button_icon=\"arrow-left\"\n button_type=\"secondary\"\n [aria_label]=\"text_for_left_arrow\"\n (clicked)=\"previousSlide()\"\n >\n Prevous slide\n </ui-button>\n <!-- Next button-->\n <ui-button\n class=\"ui-carousel__next\"\n button_size=\"large\"\n button_icon_placement=\"iconOnly\"\n button_icon=\"arrow-right\"\n button_type=\"secondary\"\n [aria_label]=\"text_for_right_arrow\"\n (clicked)=\"nextSlide()\"\n >\n Next slide\n </ui-button>\n </ui-stack>\n </ui-box>\n </ui-stack>\n </ui-stack>\n</ui-box>\n", styles: [":root{--swiper-scrollbar-size: 4px}.ui-carousel{touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.ui-carousel swiper-container{width:100%}.ui-carousel .ui-carousel-scrollbar-placeholder{width:100%;display:flex;align-self:stretch}.ui-carousel swiper-slide img{-webkit-user-drag:none}.ui-carousel__small-arrows{align-items:center;display:flex;flex-direction:row;gap:var(--oasys-spacing-near);justify-content:center}@media only screen and (max-width: 767px){.ui-carousel__small-arrows{gap:var(--oasys-spacing-tight)}}\n"], dependencies: [{ kind: "component", type: LayoutBoxComponent, selector: "ui-box", inputs: ["box_space", "box_space_top", "box_space_right", "box_space_bottom", "box_space_left", "box_align_x", "box_align_y", "box_fill_mode", "box_background", "box_content_fill_width", "box_border_color", "box_border_width", "box_border_style", "box_border_radius"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: LayoutStackComponent, selector: "ui-stack", inputs: ["stack_gap", "stack_align", "stack_direction", "stack_distribute", "stack_wrap", "stack_collapse_below"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: OasysButtonComponent, selector: "ui-button", inputs: ["button_icon", "button_icon_placement", "button_size", "button_type", "button_full_width", "button_event_type", "button_disabled", "button_selected", "button_text_nowrap", "aria_label", "aria_role", "href"], outputs: ["clicked"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
236
|
+
}
|
|
237
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CarouselComponent, decorators: [{
|
|
238
|
+
type: Component,
|
|
239
|
+
args: [{ selector: 'ui-carousel', encapsulation: ViewEncapsulation.None, standalone: true, imports: [LayoutBoxComponent, NgClass, LayoutStackComponent, NgIf, OasysButtonComponent], schemas: [CUSTOM_ELEMENTS_SCHEMA], providers: [TokenService], template: "<ui-box\n class=\"ui-carousel\"\n [ngClass]=\"{ 'ui-carousel-overflow': carousel_overflow }\"\n box_align_y=\"center\"\n box_space=\"none\"\n [box_content_fill_width]=\"true\"\n box_background=\"transparent\"\n>\n <ui-stack #carouselctastack>\n <!-- Custom navigation buttons -->\n <ui-stack\n *ngIf=\"carousel_pagination === 'small-arrows'\"\n stack_direction=\"x\"\n stack_align=\"center\"\n stack_distribute=\"end\"\n >\n <ui-box\n box_space=\"none\"\n box_fill_mode=\"fit\"\n box_space_bottom=\"none\"\n [box_space_right]=\"{ mobile: 'tight', tablet: 'none', laptop: 'none', desktop: 'none' }\"\n box_background=\"transparent\"\n >\n <div\n *ngIf=\"!(swiper?.swiper?.isBeginning && swiper?.swiper?.isEnd)\"\n class=\"ui-carousel__small-arrows\"\n >\n <!-- Previous button-->\n <ui-button\n class=\"ui-carousel__previous\"\n button_size=\"small\"\n button_icon_placement=\"iconOnly\"\n button_icon=\"arrow-left\"\n button_type=\"tertiary\"\n [aria_label]=\"text_for_left_arrow\"\n (clicked)=\"previousSlide()\"\n >\n Prevous slide\n </ui-button>\n <!-- Next button-->\n <ui-button\n class=\"ui-carousel__next\"\n button_size=\"small\"\n button_icon_placement=\"iconOnly\"\n button_icon=\"arrow-right\"\n button_type=\"tertiary\"\n [aria_label]=\"text_for_right_arrow\"\n (clicked)=\"nextSlide()\"\n >\n Next slide\n </ui-button>\n </div>\n </ui-box>\n </ui-stack>\n\n <!-- Swiper WebComponent-->\n <swiper-container\n #swiper\n init=\"false\"\n touch-start-prevent-default=\"false\"\n prevent-clicks-propagation=\"true\"\n >\n <ng-content></ng-content>\n </swiper-container>\n\n <!-- Custom navigation buttons -->\n <ui-stack\n stack_direction=\"x\"\n stack_align=\"center\"\n *ngIf=\"carousel_pagination === 'scroll-arrows' || carousel_pagination === 'scroll-bar'\"\n >\n <div class=\"ui-carousel-scrollbar-placeholder\" #carouselscrollbarplaceholder></div>\n <ui-box\n *ngIf=\"carousel_pagination === 'scroll-arrows'\"\n box_space=\"none\"\n box_fill_mode=\"fit\"\n [box_space_right]=\"{ mobile: 'tight', tablet: 'none', laptop: 'none', desktop: 'none' }\"\n box_background=\"transparent\"\n >\n <ui-stack\n *ngIf=\"!(swiper?.swiper?.isBeginning && swiper?.swiper?.isEnd)\"\n stack_direction=\"x\"\n stack_gap=\"near\"\n >\n <!-- Previous button-->\n <ui-button\n class=\"ui-carousel__previous\"\n button_size=\"large\"\n button_icon_placement=\"iconOnly\"\n button_icon=\"arrow-left\"\n button_type=\"secondary\"\n [aria_label]=\"text_for_left_arrow\"\n (clicked)=\"previousSlide()\"\n >\n Prevous slide\n </ui-button>\n <!-- Next button-->\n <ui-button\n class=\"ui-carousel__next\"\n button_size=\"large\"\n button_icon_placement=\"iconOnly\"\n button_icon=\"arrow-right\"\n button_type=\"secondary\"\n [aria_label]=\"text_for_right_arrow\"\n (clicked)=\"nextSlide()\"\n >\n Next slide\n </ui-button>\n </ui-stack>\n </ui-box>\n </ui-stack>\n </ui-stack>\n</ui-box>\n", styles: [":root{--swiper-scrollbar-size: 4px}.ui-carousel{touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.ui-carousel swiper-container{width:100%}.ui-carousel .ui-carousel-scrollbar-placeholder{width:100%;display:flex;align-self:stretch}.ui-carousel swiper-slide img{-webkit-user-drag:none}.ui-carousel__small-arrows{align-items:center;display:flex;flex-direction:row;gap:var(--oasys-spacing-near);justify-content:center}@media only screen and (max-width: 767px){.ui-carousel__small-arrows{gap:var(--oasys-spacing-tight)}}\n"] }]
|
|
240
|
+
}], ctorParameters: () => [{ type: i1.TokenService }, { type: Document, decorators: [{
|
|
241
|
+
type: Inject,
|
|
242
|
+
args: [DOCUMENT]
|
|
243
|
+
}] }, { type: i0.ElementRef }], propDecorators: { swiper: [{
|
|
244
|
+
type: ViewChild,
|
|
245
|
+
args: ['swiper', { static: true }]
|
|
246
|
+
}], carouselscrollbarplaceholder: [{
|
|
247
|
+
type: ViewChild,
|
|
248
|
+
args: ['carouselscrollbarplaceholder', { static: false, read: ElementRef }]
|
|
249
|
+
}], carouselctastack: [{
|
|
250
|
+
type: ViewChild,
|
|
251
|
+
args: ['carouselctastack', { static: false, read: ElementRef }]
|
|
252
|
+
}], rewind: [{
|
|
253
|
+
type: Input
|
|
254
|
+
}], carousel_overflow: [{
|
|
255
|
+
type: Input
|
|
256
|
+
}], carousel_gap: [{
|
|
257
|
+
type: Input
|
|
258
|
+
}], carousel_pagination: [{
|
|
259
|
+
type: Input
|
|
260
|
+
}], carousel_slides_per_view_desktop: [{
|
|
261
|
+
type: Input
|
|
262
|
+
}], carousel_slides_per_view_laptop: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], carousel_slides_per_view_tablet: [{
|
|
265
|
+
type: Input
|
|
266
|
+
}], carousel_slides_per_view_mobile: [{
|
|
267
|
+
type: Input
|
|
268
|
+
}], text_for_left_arrow: [{
|
|
269
|
+
type: Input
|
|
270
|
+
}], text_for_right_arrow: [{
|
|
271
|
+
type: Input
|
|
272
|
+
}], carousel_rows_per_row_mobile: [{
|
|
273
|
+
type: Input
|
|
274
|
+
}], carousel_loading: [{
|
|
275
|
+
type: Input
|
|
276
|
+
}], carousel_free_mode: [{
|
|
277
|
+
type: Input
|
|
278
|
+
}], center_insufficient_slides: [{
|
|
279
|
+
type: Input
|
|
280
|
+
}], center_active_slide: [{
|
|
281
|
+
type: Input
|
|
282
|
+
}], start_slide: [{
|
|
283
|
+
type: Input
|
|
284
|
+
}], offset_scrollbar_top: [{
|
|
285
|
+
type: Input
|
|
286
|
+
}], activeIndexOnSlideChange: [{
|
|
287
|
+
type: Output
|
|
288
|
+
}] } });
|
|
289
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../projects/oasys-lib/src/lib/components/carousel/carousel.component.ts","../../../../../../projects/oasys-lib/src/lib/components/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, NgClass, NgIf } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation,\n  Inject,\n  EventEmitter,\n  Output,\n  CUSTOM_ELEMENTS_SCHEMA,\n  inject,\n} from '@angular/core';\nimport Swiper from 'swiper';\nimport { SwiperOptions } from 'swiper/types';\nimport { TokenService } from '../../services/token.service';\nimport { SwiperContainer } from 'swiper/element';\nimport { LayoutBoxComponent } from '../layout/box/box.component';\nimport { LayoutStackComponent } from '../layout/stack/stack.component';\nimport { OasysButtonComponent } from '../button/button.component';\nimport { SWIPER_PROVIDER_TOKEN } from '../../services';\n\n/* This component wraps around the swiper.js library WebComponent */\n\n@Component({\n  selector: 'ui-carousel',\n  templateUrl: './carousel.component.html',\n  styleUrls: ['./carousel.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [LayoutBoxComponent, NgClass, LayoutStackComponent, NgIf, OasysButtonComponent],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  providers: [TokenService],\n})\nexport class CarouselComponent implements OnInit {\n  // The swiper instance\n  @ViewChild('swiper', { static: true }) swiper: ElementRef<SwiperContainer>;\n  @ViewChild('carouselscrollbarplaceholder', { static: false, read: ElementRef })\n  carouselscrollbarplaceholder: ElementRef;\n  @ViewChild('carouselctastack', { static: false, read: ElementRef }) carouselctastack: ElementRef;\n\n  // Rewinds the slides back to the start when the user reaches the end when set to true\n  @Input() rewind: boolean = false;\n\n  @Input() carousel_overflow: boolean = false;\n\n  @Input() carousel_gap: 'default' | 'tight' | 'near' | 'none' = 'default';\n\n  @Input() carousel_pagination: 'scroll-arrows' | 'none' | 'scroll-bar' | 'small-arrows' = 'none';\n\n  @Input() carousel_slides_per_view_desktop: number = 4;\n  @Input() carousel_slides_per_view_laptop: number = 3;\n  @Input() carousel_slides_per_view_tablet: number = 2.5;\n  @Input() carousel_slides_per_view_mobile: number = 1.25;\n  @Input() text_for_left_arrow: string = 'previous slide';\n  @Input() text_for_right_arrow: string = 'next slide';\n\n  @Input() carousel_rows_per_row_mobile: 1 | 2 = 1; // Required for CATEGORY_CARD experiment. Remove if experiment fails.\n\n  @Input() carousel_loading: 'lazy' | 'eager' = 'lazy'; // If we don't have multiple carousels on page and want to prioritise UI loading on time\n  @Input() carousel_free_mode: boolean = false; // Enables scrolling with mousewheel / smoother momentum swiping experience\n  @Input() center_insufficient_slides: boolean = true; // Centers the slides if there are not enough to fill the space\n  @Input() center_active_slide: boolean = false; // Centers the active slide\n  @Input() start_slide: number = 0; // Start slide index\n  @Input() offset_scrollbar_top: boolean = false; // Offset the scrollbar to the top of the carousel\n\n  @Output() activeIndexOnSlideChange = new EventEmitter<number>();\n\n  constructor(\n    private tokenService: TokenService,\n    @Inject(DOCUMENT) private document: Document,\n    private element: ElementRef,\n  ) {\n    inject(SWIPER_PROVIDER_TOKEN).ensureSwiperRegistered();\n  }\n\n  ngOnInit(): void {\n    if (this.carousel_loading === 'lazy') {\n      this.setUpIntersectionObserver();\n    } else {\n      this.initSwiper();\n    }\n  }\n\n  /**\n   * Set up the intersection observer with the relevant options\n   */\n  setUpIntersectionObserver(): void {\n    // Set IntersectionObserver options\n    const options = {\n      root: null,\n      rootMargin: '0px',\n      threshold: 0.5,\n      once: true,\n    };\n    // Set up the IntersectionObserver\n    const observer = new IntersectionObserver(this.onIntersection.bind(this), options);\n    observer.observe(this.element.nativeElement);\n  }\n\n  /**\n   * This function gets called just before the user scrolls this component into view\n   * @param entries - An array of interswection observer entries\n   * @param observer - Intersection observer\n   */\n  onIntersection(entries: IntersectionObserverEntry[], observer: IntersectionObserver): void {\n    entries.forEach((entry): void => {\n      if (entry.isIntersecting) {\n        // Initialise swiper\n        this.initSwiper();\n        observer.unobserve(entry.target);\n      }\n    });\n  }\n\n  getStyle(element: HTMLElement, style: string): string {\n    return this.document.defaultView.getComputedStyle(element, null).getPropertyValue(style);\n  }\n\n  /**\n   * Set the scrollbar placement and width based on carouselscrollbarplaceholder and carouselctastack\n   */\n  setupScrollbarLayoutProperties(): void {\n    if (this.carousel_pagination === 'none') {\n      return;\n    }\n\n    const carouselStack: HTMLElement = this.carouselctastack?.nativeElement;\n    const scrollbarElement: HTMLElement = this.carouselscrollbarplaceholder?.nativeElement;\n\n    const scrollbarHeight = this.document.defaultView\n      .getComputedStyle(document.documentElement)\n      .getPropertyValue('--swiper-scrollbar-size');\n\n    if (carouselStack && this.carousel_pagination === 'scroll-arrows') {\n      this.element?.nativeElement?.style?.setProperty(\n        '--ui-carousel-scrollbar-width',\n        `${scrollbarElement?.offsetWidth - parseInt(this.getStyle(carouselStack, 'gap'), 10)}px`,\n      );\n\n      this.element?.nativeElement?.style?.setProperty(\n        '--ui-carousel-scrollbar-offset-top',\n        `${parseInt(this.getStyle(carouselStack, 'gap'), 10) + scrollbarElement?.offsetHeight / 2 + parseInt(scrollbarHeight, 10) / 2}px`,\n      );\n\n      this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-height', '2px');\n    }\n\n    if (carouselStack && this.carousel_pagination === 'scroll-bar') {\n      this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-width', '100%');\n\n      this.element?.nativeElement?.style?.setProperty(\n        '--ui-carousel-scrollbar-offset-top',\n        `${this.offset_scrollbar_top ? parseInt(this.getStyle(carouselStack, 'gap'), 10) + 'px' : '0px'}`,\n      );\n\n      this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-height', '4px');\n\n      this.element?.nativeElement?.style?.setProperty('--ui-carousel-scrollbar-left', '0px');\n    }\n  }\n\n  /**\n   * Set the dynamic swiper params and initialise the swiper instance\n   */\n  // eslint-disable-next-line complexity\n  initSwiper(): void {\n    // Colour overides\n    const scrollbarBackgroundColour = this.tokenService.getTokenValue(\n      '--oasys-color-linen-grey-200',\n    );\n    const scrollbarSliderColour = this.tokenService.getTokenValue(\n      '--oasys-color-brand-foreground-primary',\n    );\n\n    // swiper element\n    const swiperEl = this.swiper.nativeElement;\n\n    const carouselGap = this.tokenService.getTokenValue(`--oasys-spacing-${this.carousel_gap}`);\n\n    // swiper parameters\n    const swiperParams: SwiperOptions = {\n      rewind: this.rewind,\n      grabCursor: true,\n      spaceBetween: parseInt(carouselGap.replace('.', ''), 10) || 0,\n      centeredSlides: this.center_active_slide,\n      initialSlide: this.start_slide,\n      scrollbar: {\n        enabled:\n          this.carousel_pagination === 'scroll-arrows' || this.carousel_pagination === 'scroll-bar',\n        draggable: true,\n      },\n      centerInsufficientSlides: this.center_insufficient_slides,\n      freeMode: this.carousel_free_mode\n        ? {\n            enabled: true,\n            sticky: true,\n            momentumVelocityRatio: 0.75,\n            momentumRatio: 0.75,\n          }\n        : false,\n      mousewheel: this.carousel_free_mode\n        ? {\n            forceToAxis: true,\n          }\n        : false,\n      injectStyles: [\n        `\n        .swiper {\n          overflow: ${this.carousel_overflow ? 'visible' : 'hidden'} !important;\n        }\n\n        .swiper-scrollbar.swiper-scrollbar-horizontal {\n          position: relative;\n          top: var(--ui-carousel-scrollbar-offset-top);\n          width: var(--ui-carousel-scrollbar-width);\n          height: var(--ui-carousel-scrollbar-height);\n          left: ${this.carousel_pagination === 'scroll-bar' ? 'var(--ui-carousel-scrollbar-left)' : '1%'};\n          background: ${scrollbarBackgroundColour}\n        }\n\n        .swiper-scrollbar-drag {\n          background: ${scrollbarSliderColour}\n        }`,\n      ],\n      breakpoints: {\n        0: {\n          scrollbar: {\n            enabled:\n              this.carousel_pagination === 'scroll-arrows' ||\n              this.carousel_pagination === 'scroll-bar',\n            draggable: true,\n          },\n          slidesPerView: this.carousel_slides_per_view_mobile,\n          grid: {\n            rows: this.carousel_rows_per_row_mobile,\n            fill: 'row',\n          },\n        },\n        767: {\n          scrollbar: {\n            enabled:\n              this.carousel_pagination === 'scroll-arrows' ||\n              this.carousel_pagination === 'scroll-bar',\n            draggable: true,\n          },\n          slidesPerView: this.carousel_slides_per_view_tablet,\n        },\n        1080: {\n          scrollbar: {\n            enabled:\n              this.carousel_pagination === 'scroll-arrows' ||\n              this.carousel_pagination === 'scroll-bar',\n            draggable: true,\n          },\n          slidesPerView: this.carousel_slides_per_view_laptop,\n        },\n        1440: {\n          scrollbar: {\n            enabled:\n              this.carousel_pagination === 'scroll-arrows' ||\n              this.carousel_pagination === 'scroll-bar',\n            draggable: true,\n          },\n          slidesPerView: this.carousel_slides_per_view_desktop,\n        },\n      },\n      on: {\n        slideChange: this.onSlideChange.bind(this),\n      },\n    };\n\n    // now we need to assign all parameters to the Swiper element\n    Object.assign(swiperEl, swiperParams);\n\n    // and now initialize it\n    swiperEl.initialize();\n\n    // Set up scrollbar and ensure this is recalculated on resize events\n    this.setupScrollbarLayoutProperties();\n\n    swiperEl.addEventListener('resize', (): void => {\n      this.setupScrollbarLayoutProperties();\n    });\n  }\n\n  /**\n   * Move the carousel on to the next slide\n   */\n  nextSlide(): void {\n    this.swiper.nativeElement.swiper.slideNext();\n  }\n\n  /**\n   * Move the carousel back to the previous slide\n   */\n  previousSlide(): void {\n    this.swiper.nativeElement.swiper.slidePrev();\n  }\n\n  /**\n   * Emit event when the slide changes\n   * @param swiper\n   */\n  onSlideChange(swiper: Swiper): void {\n    this.activeIndexOnSlideChange.emit(swiper.activeIndex);\n  }\n}\n","<ui-box\n  class=\"ui-carousel\"\n  [ngClass]=\"{ 'ui-carousel-overflow': carousel_overflow }\"\n  box_align_y=\"center\"\n  box_space=\"none\"\n  [box_content_fill_width]=\"true\"\n  box_background=\"transparent\"\n>\n  <ui-stack #carouselctastack>\n    <!-- Custom navigation buttons -->\n    <ui-stack\n      *ngIf=\"carousel_pagination === 'small-arrows'\"\n      stack_direction=\"x\"\n      stack_align=\"center\"\n      stack_distribute=\"end\"\n    >\n      <ui-box\n        box_space=\"none\"\n        box_fill_mode=\"fit\"\n        box_space_bottom=\"none\"\n        [box_space_right]=\"{ mobile: 'tight', tablet: 'none', laptop: 'none', desktop: 'none' }\"\n        box_background=\"transparent\"\n      >\n        <div\n          *ngIf=\"!(swiper?.swiper?.isBeginning && swiper?.swiper?.isEnd)\"\n          class=\"ui-carousel__small-arrows\"\n        >\n          <!-- Previous button-->\n          <ui-button\n            class=\"ui-carousel__previous\"\n            button_size=\"small\"\n            button_icon_placement=\"iconOnly\"\n            button_icon=\"arrow-left\"\n            button_type=\"tertiary\"\n            [aria_label]=\"text_for_left_arrow\"\n            (clicked)=\"previousSlide()\"\n          >\n            Prevous slide\n          </ui-button>\n          <!-- Next button-->\n          <ui-button\n            class=\"ui-carousel__next\"\n            button_size=\"small\"\n            button_icon_placement=\"iconOnly\"\n            button_icon=\"arrow-right\"\n            button_type=\"tertiary\"\n            [aria_label]=\"text_for_right_arrow\"\n            (clicked)=\"nextSlide()\"\n          >\n            Next slide\n          </ui-button>\n        </div>\n      </ui-box>\n    </ui-stack>\n\n    <!-- Swiper WebComponent-->\n    <swiper-container\n      #swiper\n      init=\"false\"\n      touch-start-prevent-default=\"false\"\n      prevent-clicks-propagation=\"true\"\n    >\n      <ng-content></ng-content>\n    </swiper-container>\n\n    <!-- Custom navigation buttons -->\n    <ui-stack\n      stack_direction=\"x\"\n      stack_align=\"center\"\n      *ngIf=\"carousel_pagination === 'scroll-arrows' || carousel_pagination === 'scroll-bar'\"\n    >\n      <div class=\"ui-carousel-scrollbar-placeholder\" #carouselscrollbarplaceholder></div>\n      <ui-box\n        *ngIf=\"carousel_pagination === 'scroll-arrows'\"\n        box_space=\"none\"\n        box_fill_mode=\"fit\"\n        [box_space_right]=\"{ mobile: 'tight', tablet: 'none', laptop: 'none', desktop: 'none' }\"\n        box_background=\"transparent\"\n      >\n        <ui-stack\n          *ngIf=\"!(swiper?.swiper?.isBeginning && swiper?.swiper?.isEnd)\"\n          stack_direction=\"x\"\n          stack_gap=\"near\"\n        >\n          <!-- Previous button-->\n          <ui-button\n            class=\"ui-carousel__previous\"\n            button_size=\"large\"\n            button_icon_placement=\"iconOnly\"\n            button_icon=\"arrow-left\"\n            button_type=\"secondary\"\n            [aria_label]=\"text_for_left_arrow\"\n            (clicked)=\"previousSlide()\"\n          >\n            Prevous slide\n          </ui-button>\n          <!-- Next button-->\n          <ui-button\n            class=\"ui-carousel__next\"\n            button_size=\"large\"\n            button_icon_placement=\"iconOnly\"\n            button_icon=\"arrow-right\"\n            button_type=\"secondary\"\n            [aria_label]=\"text_for_right_arrow\"\n            (clicked)=\"nextSlide()\"\n          >\n            Next slide\n          </ui-button>\n        </ui-stack>\n      </ui-box>\n    </ui-stack>\n  </ui-stack>\n</ui-box>\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CarouselComponent } from './carousel.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class OasysCarouselModule {
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OasysCarouselModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
6
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: OasysCarouselModule, imports: [CarouselComponent], exports: [CarouselComponent] });
|
|
7
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OasysCarouselModule });
|
|
8
|
+
}
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OasysCarouselModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
imports: [CarouselComponent],
|
|
13
|
+
exports: [CarouselComponent],
|
|
14
|
+
}]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2Fyb3VzZWwubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb2FzeXMtbGliL3NyYy9saWIvY29tcG9uZW50cy9jYXJvdXNlbC9jYXJvdXNlbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFNekQsTUFBTSxPQUFPLG1CQUFtQjt3R0FBbkIsbUJBQW1CO3lHQUFuQixtQkFBbUIsWUFIcEIsaUJBQWlCLGFBQ2pCLGlCQUFpQjt5R0FFaEIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUovQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO29CQUM1QixPQUFPLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztpQkFDN0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2Fyb3VzZWxDb21wb25lbnQgfSBmcm9tICcuL2Nhcm91c2VsLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDYXJvdXNlbENvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtDYXJvdXNlbENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIE9hc3lzQ2Fyb3VzZWxNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './carousel.component';
|
|
2
|
+
export * from './carousel.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vYXN5cy1saWIvc3JjL2xpYi9jb21wb25lbnRzL2Nhcm91c2VsL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2Fyb3VzZWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2Fyb3VzZWwubW9kdWxlJztcbiJdfQ==
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { Component } from '@angular/core';
|
|
3
|
+
import { LayoutBoxComponent } from '../layout/box/box.component';
|
|
4
|
+
import { NgClass } from '@angular/common';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class DividerComponent {
|
|
7
|
+
divider_type = 'secondary';
|
|
8
|
+
getClass() {
|
|
9
|
+
return this.divider_type === 'secondary'
|
|
10
|
+
? `ui-divider--type-${this.divider_type}`
|
|
11
|
+
: `ui-divider--type-${this.divider_type}`;
|
|
12
|
+
}
|
|
13
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DividerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
14
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DividerComponent, isStandalone: true, selector: "ui-divider", inputs: { divider_type: "divider_type" }, ngImport: i0, template: "<ui-box\n box_fill_mode=\"fill\"\n box_space=\"none\"\n box_background=\"core-secondary\"\n [ngClass]=\"getClass()\"\n></ui-box>\n", styles: ["ui-divider{display:block;width:100%}ui-divider ui-box.ui-divider--type-secondary:after{content:\"\";display:block;height:var(--oasys-size-unit-1);width:100%}ui-divider ui-box.ui-divider--type-primary:after{content:\"\";display:block;height:var(--oasys-size-unit-8);width:100%}\n"], dependencies: [{ kind: "component", type: LayoutBoxComponent, selector: "ui-box", inputs: ["box_space", "box_space_top", "box_space_right", "box_space_bottom", "box_space_left", "box_align_x", "box_align_y", "box_fill_mode", "box_background", "box_content_fill_width", "box_border_color", "box_border_width", "box_border_style", "box_border_radius"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DividerComponent, decorators: [{
|
|
17
|
+
type: Component,
|
|
18
|
+
args: [{ selector: 'ui-divider', encapsulation: ViewEncapsulation.None, standalone: true, imports: [LayoutBoxComponent, NgClass], template: "<ui-box\n box_fill_mode=\"fill\"\n box_space=\"none\"\n box_background=\"core-secondary\"\n [ngClass]=\"getClass()\"\n></ui-box>\n", styles: ["ui-divider{display:block;width:100%}ui-divider ui-box.ui-divider--type-secondary:after{content:\"\";display:block;height:var(--oasys-size-unit-1);width:100%}ui-divider ui-box.ui-divider--type-primary:after{content:\"\";display:block;height:var(--oasys-size-unit-8);width:100%}\n"] }]
|
|
19
|
+
}], propDecorators: { divider_type: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}] } });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGl2aWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vYXN5cy1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RpdmlkZXIvZGl2aWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vYXN5cy1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RpdmlkZXIvZGl2aWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDakUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQVUxQyxNQUFNLE9BQU8sZ0JBQWdCO0lBRTNCLFlBQVksR0FBZ0IsV0FBVyxDQUFDO0lBRXhDLFFBQVE7UUFDTixPQUFPLElBQUksQ0FBQyxZQUFZLEtBQUssV0FBVztZQUN0QyxDQUFDLENBQUMsb0JBQW9CLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDekMsQ0FBQyxDQUFDLG9CQUFvQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDOUMsQ0FBQzt3R0FSVSxnQkFBZ0I7NEZBQWhCLGdCQUFnQixnSENkN0Isd0lBTUEsZ1ZETVksa0JBQWtCLGdVQUFFLE9BQU87OzRGQUUxQixnQkFBZ0I7a0JBUjVCLFNBQVM7K0JBQ0UsWUFBWSxpQkFHUCxpQkFBaUIsQ0FBQyxJQUFJLGNBQ3pCLElBQUksV0FDUCxDQUFDLGtCQUFrQixFQUFFLE9BQU8sQ0FBQzs4QkFJdEMsWUFBWTtzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpdmlkZXJUeXBlIH0gZnJvbSAnLi9kaXZpZGVyJztcbmltcG9ydCB7IExheW91dEJveENvbXBvbmVudCB9IGZyb20gJy4uL2xheW91dC9ib3gvYm94LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOZ0NsYXNzIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndWktZGl2aWRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9kaXZpZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGl2aWRlci5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTGF5b3V0Qm94Q29tcG9uZW50LCBOZ0NsYXNzXSxcbn0pXG5leHBvcnQgY2xhc3MgRGl2aWRlckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIGRpdmlkZXJfdHlwZTogRGl2aWRlclR5cGUgPSAnc2Vjb25kYXJ5JztcblxuICBnZXRDbGFzcygpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmRpdmlkZXJfdHlwZSA9PT0gJ3NlY29uZGFyeSdcbiAgICAgID8gYHVpLWRpdmlkZXItLXR5cGUtJHt0aGlzLmRpdmlkZXJfdHlwZX1gXG4gICAgICA6IGB1aS1kaXZpZGVyLS10eXBlLSR7dGhpcy5kaXZpZGVyX3R5cGV9YDtcbiAgfVxufVxuIiwiPHVpLWJveFxuICBib3hfZmlsbF9tb2RlPVwiZmlsbFwiXG4gIGJveF9zcGFjZT1cIm5vbmVcIlxuICBib3hfYmFja2dyb3VuZD1cImNvcmUtc2Vjb25kYXJ5XCJcbiAgW25nQ2xhc3NdPVwiZ2V0Q2xhc3MoKVwiXG4+PC91aS1ib3g+XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGl2aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29hc3lzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvZGl2aWRlci9kaXZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBEaXZpZGVyVHlwZSA9ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknO1xuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { DividerComponent } from './divider.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class OasysDividerModule {
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OasysDividerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
6
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: OasysDividerModule, imports: [DividerComponent], exports: [DividerComponent] });
|
|
7
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OasysDividerModule });
|
|
8
|
+
}
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OasysDividerModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
imports: [DividerComponent],
|
|
13
|
+
exports: [DividerComponent],
|
|
14
|
+
}]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGl2aWRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vYXN5cy1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RpdmlkZXIvZGl2aWRlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7QUFNdkQsTUFBTSxPQUFPLGtCQUFrQjt3R0FBbEIsa0JBQWtCO3lHQUFsQixrQkFBa0IsWUFIbkIsZ0JBQWdCLGFBQ2hCLGdCQUFnQjt5R0FFZixrQkFBa0I7OzRGQUFsQixrQkFBa0I7a0JBSjlCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7b0JBQzNCLE9BQU8sRUFBRSxDQUFDLGdCQUFnQixDQUFDO2lCQUM1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEaXZpZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9kaXZpZGVyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtEaXZpZGVyQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW0RpdmlkZXJDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBPYXN5c0RpdmlkZXJNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './divider.component';
|
|
2
|
+
export * from './divider.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vYXN5cy1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RpdmlkZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kaXZpZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RpdmlkZXIubW9kdWxlJztcbiJdfQ==
|