@casus-campus/ngx-gallery 0.5.1 → 0.7.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.
Files changed (93) hide show
  1. package/README.md +4 -1
  2. package/casus-campus-ngx-gallery.d.ts +1 -1
  3. package/esm2020/casus-campus-ngx-gallery.mjs +5 -0
  4. package/esm2020/lib/cc-custom-options.mjs +141 -0
  5. package/esm2020/lib/image/ngx-gallery-image-svg.component.mjs +142 -0
  6. package/{esm2015/lib/models/ngx-gallery-action.model.js → esm2020/lib/models/ngx-gallery-action.model.mjs} +0 -0
  7. package/{esm2015/lib/models/ngx-gallery-animation.model.js → esm2020/lib/models/ngx-gallery-animation.model.mjs} +0 -0
  8. package/{esm2015/lib/models/ngx-gallery-image-size.model.js → esm2020/lib/models/ngx-gallery-image-size.model.mjs} +0 -0
  9. package/{esm2015/lib/models/ngx-gallery-image.model.js → esm2020/lib/models/ngx-gallery-image.model.mjs} +0 -0
  10. package/{esm2015/lib/models/ngx-gallery-layout.model.js → esm2020/lib/models/ngx-gallery-layout.model.mjs} +0 -0
  11. package/{esm2015/lib/models/ngx-gallery-options.model.js → esm2020/lib/models/ngx-gallery-options.model.mjs} +0 -0
  12. package/{esm2015/lib/models/ngx-gallery-order.model.js → esm2020/lib/models/ngx-gallery-order.model.mjs} +0 -0
  13. package/{esm2015/lib/models/ngx-gallery-ordered-image.model.js → esm2020/lib/models/ngx-gallery-ordered-image.model.mjs} +0 -0
  14. package/esm2020/lib/ngx-gallery-action/ngx-gallery-action.component.mjs +47 -0
  15. package/esm2020/lib/ngx-gallery-arrows/ngx-gallery-arrows.component.mjs +67 -0
  16. package/esm2020/lib/ngx-gallery-bullets/ngx-gallery-bullets.component.mjs +38 -0
  17. package/{esm2015/lib/ngx-gallery-helper.service.js → esm2020/lib/ngx-gallery-helper.service.mjs} +9 -10
  18. package/esm2020/lib/ngx-gallery-image/ngx-gallery-image.component.mjs +265 -0
  19. package/esm2020/lib/ngx-gallery-preview/ngx-gallery-preview.component.mjs +565 -0
  20. package/esm2020/lib/ngx-gallery-thumbnails/ngx-gallery-thumbnails.component.mjs +288 -0
  21. package/esm2020/lib/ngx-gallery-video/ngx-gallery-video.component.mjs +68 -0
  22. package/esm2020/lib/ngx-gallery.component.mjs +560 -0
  23. package/esm2020/lib/ngx-gallery.module.mjs +78 -0
  24. package/{esm2015/lib/svg/arrow.model.js → esm2020/lib/svg/arrow.model.mjs} +0 -0
  25. package/{esm2015/lib/svg/icon.model.js → esm2020/lib/svg/icon.model.mjs} +0 -0
  26. package/esm2020/lib/svg/ngx-gallery-svg-arrow.component.mjs +22 -0
  27. package/esm2020/lib/svg/ngx-gallery-svg-icon.component.mjs +49 -0
  28. package/esm2020/lib/svg/ngx-gallery-svg-polygon.component.mjs +34 -0
  29. package/esm2020/lib/svg/ngx-gallery-svg-text.component.mjs +25 -0
  30. package/{esm2015/lib/svg/point.model.js → esm2020/lib/svg/point.model.mjs} +0 -0
  31. package/{esm2015/lib/svg/polygon.model.js → esm2020/lib/svg/polygon.model.mjs} +0 -0
  32. package/esm2020/lib/utils/cc-media.service.mjs +185 -0
  33. package/esm2020/lib/utils/custom-hammer-config.service.mjs +18 -0
  34. package/esm2020/lib/utils/logging.service.mjs +21 -0
  35. package/{esm2015/lib/utils/media-dimension.interface.js → esm2020/lib/utils/media-dimension.interface.mjs} +0 -0
  36. package/{esm2015/lib/utils/ngx-gallery-dimensions.interface.js → esm2020/lib/utils/ngx-gallery-dimensions.interface.mjs} +0 -0
  37. package/esm2020/lib/utils/ngx-preview-loader.component.mjs +240 -0
  38. package/esm2020/lib/utils/utils-script.component.mjs +34 -0
  39. package/{esm2015/lib/utils/videourl.model.js → esm2020/lib/utils/videourl.model.mjs} +0 -0
  40. package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
  41. package/fesm2015/casus-campus-ngx-gallery.mjs +3052 -0
  42. package/fesm2015/casus-campus-ngx-gallery.mjs.map +1 -0
  43. package/fesm2020/casus-campus-ngx-gallery.mjs +3059 -0
  44. package/fesm2020/casus-campus-ngx-gallery.mjs.map +1 -0
  45. package/lib/image/ngx-gallery-image-svg.component.d.ts +3 -0
  46. package/lib/ngx-gallery-action/ngx-gallery-action.component.d.ts +3 -0
  47. package/lib/ngx-gallery-arrows/ngx-gallery-arrows.component.d.ts +3 -0
  48. package/lib/ngx-gallery-bullets/ngx-gallery-bullets.component.d.ts +3 -0
  49. package/lib/ngx-gallery-helper.service.d.ts +3 -0
  50. package/lib/ngx-gallery-image/ngx-gallery-image.component.d.ts +3 -0
  51. package/lib/ngx-gallery-preview/ngx-gallery-preview.component.d.ts +3 -0
  52. package/lib/ngx-gallery-thumbnails/ngx-gallery-thumbnails.component.d.ts +3 -0
  53. package/lib/ngx-gallery-video/ngx-gallery-video.component.d.ts +3 -0
  54. package/lib/ngx-gallery.component.d.ts +3 -0
  55. package/lib/ngx-gallery.module.d.ts +21 -0
  56. package/lib/svg/ngx-gallery-svg-arrow.component.d.ts +3 -0
  57. package/lib/svg/ngx-gallery-svg-icon.component.d.ts +3 -0
  58. package/lib/svg/ngx-gallery-svg-polygon.component.d.ts +3 -0
  59. package/lib/svg/ngx-gallery-svg-text.component.d.ts +3 -0
  60. package/lib/utils/cc-media.service.d.ts +3 -0
  61. package/lib/utils/custom-hammer-config.service.d.ts +3 -0
  62. package/lib/utils/logging.service.d.ts +3 -0
  63. package/lib/utils/ngx-preview-loader.component.d.ts +3 -0
  64. package/lib/utils/utils-script.component.d.ts +3 -0
  65. package/package.json +25 -13
  66. package/bundles/casus-campus-ngx-gallery.umd.js +0 -3232
  67. package/bundles/casus-campus-ngx-gallery.umd.js.map +0 -1
  68. package/bundles/casus-campus-ngx-gallery.umd.min.js +0 -2
  69. package/bundles/casus-campus-ngx-gallery.umd.min.js.map +0 -1
  70. package/casus-campus-ngx-gallery.metadata.json +0 -1
  71. package/esm2015/casus-campus-ngx-gallery.js +0 -6
  72. package/esm2015/lib/cc-custom-options.js +0 -141
  73. package/esm2015/lib/image/ngx-gallery-image-svg.component.js +0 -130
  74. package/esm2015/lib/ngx-gallery-action/ngx-gallery-action.component.js +0 -35
  75. package/esm2015/lib/ngx-gallery-arrows/ngx-gallery-arrows.component.js +0 -46
  76. package/esm2015/lib/ngx-gallery-bullets/ngx-gallery-bullets.component.js +0 -31
  77. package/esm2015/lib/ngx-gallery-image/ngx-gallery-image.component.js +0 -225
  78. package/esm2015/lib/ngx-gallery-preview/ngx-gallery-preview.component.js +0 -513
  79. package/esm2015/lib/ngx-gallery-thumbnails/ngx-gallery-thumbnails.component.js +0 -265
  80. package/esm2015/lib/ngx-gallery-video/ngx-gallery-video.component.js +0 -63
  81. package/esm2015/lib/ngx-gallery.component.js +0 -540
  82. package/esm2015/lib/ngx-gallery.module.js +0 -54
  83. package/esm2015/lib/svg/ngx-gallery-svg-arrow.component.js +0 -24
  84. package/esm2015/lib/svg/ngx-gallery-svg-icon.component.js +0 -51
  85. package/esm2015/lib/svg/ngx-gallery-svg-polygon.component.js +0 -37
  86. package/esm2015/lib/svg/ngx-gallery-svg-text.component.js +0 -28
  87. package/esm2015/lib/utils/cc-media.service.js +0 -177
  88. package/esm2015/lib/utils/custom-hammer-config.service.js +0 -15
  89. package/esm2015/lib/utils/logging.service.js +0 -19
  90. package/esm2015/lib/utils/ngx-preview-loader.component.js +0 -187
  91. package/esm2015/lib/utils/utils-script.component.js +0 -32
  92. package/fesm2015/casus-campus-ngx-gallery.js +0 -2857
  93. package/fesm2015/casus-campus-ngx-gallery.js.map +0 -1
package/README.md CHANGED
@@ -40,8 +40,11 @@ Angular image gallery plugin
40
40
  - commit changes
41
41
  - when finished: merge into develop with `git checkout develop && git merge feature/f-1`
42
42
 
43
- ### Publish library
43
+ ### Publish library to NPM
44
44
 
45
+ Publishing the library is only needed, if the `develop` branch has some changes that are not already in the `production` branch. The latest `production` commit reflects the latest published version on NPM.
46
+
47
+ Perform following steps to publish a new version to NPM:
45
48
  - make sure that `develop` branch is checked out (`git checkout develop`)
46
49
  - make sure that the tests succeed (`ng test @casus-campus/ngx-gallery`)
47
50
  - increase version in `./projects/ngx-gallery/package.json` (following [SemVer](https://semver.org/))
@@ -1,5 +1,5 @@
1
1
  /**
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
+ /// <amd-module name="@casus-campus/ngx-gallery" />
4
5
  export * from './public-api';
5
- export { CustomHammerConfig as ɵa } from './lib/utils/custom-hammer-config.service';
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FzdXMtY2FtcHVzLW5neC1nYWxsZXJ5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvbmd4LWdhbGxlcnkvc3JjL2Nhc3VzLWNhbXB1cy1uZ3gtZ2FsbGVyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,141 @@
1
+ import { NgxGalleryImageSize } from './models/ngx-gallery-image-size.model';
2
+ export class CcCustomOptions {
3
+ constructor(initialOptions, initialNumberOfMedia) {
4
+ this.dimensions = {
5
+ box: { width: 0, height: 0 },
6
+ image: { width: 0, height: 0 },
7
+ thumbnail: { width: 0, height: 0 },
8
+ };
9
+ this.boxPadding = 10;
10
+ this.boxBorder = 3;
11
+ this.galleryLayout = {
12
+ border: this.boxBorder + 'px grey solid',
13
+ padding: this.boxPadding + 'px',
14
+ // TODO: move into css as it is not dynamic
15
+ 'background-color': '#D8D8D8',
16
+ };
17
+ this.defaultOptionsLargeScreen = {
18
+ width: '400px',
19
+ imageSize: NgxGalleryImageSize.Contain,
20
+ imagePercent: 88.6,
21
+ imageDescription: true,
22
+ imageInfinityMove: false,
23
+ imageArrows: false,
24
+ ccpImageAsLink: true,
25
+ image: true,
26
+ lazyLoading: true,
27
+ thumbnailsAsLinks: true,
28
+ ccpPreviewImageAsLink: true,
29
+ previewDescription: true,
30
+ previewZoom: true,
31
+ previewAutoPlay: false,
32
+ imageAutoPlay: false,
33
+ thumbnailsColumns: 3,
34
+ thumbnailsMoveSize: 3,
35
+ thumbnailSize: NgxGalleryImageSize.Contain
36
+ };
37
+ this.defaultOptionsSmallScreen = {
38
+ breakpoint: 1100,
39
+ thumbnailsColumns: 2,
40
+ thumbnailsMoveSize: 2,
41
+ image: false, // small screens - do not show image
42
+ };
43
+ this.numberOfMedia = initialNumberOfMedia;
44
+ this.originalOptions = initialOptions;
45
+ this.options = this.prepareOptions();
46
+ }
47
+ setOriginalOptions(originalOptions) {
48
+ this.originalOptions = originalOptions;
49
+ this.options = this.prepareOptions();
50
+ }
51
+ setNumberOfMedia(numberOfMedia) {
52
+ this.numberOfMedia = numberOfMedia;
53
+ this.options = this.prepareOptions();
54
+ }
55
+ getOptions() {
56
+ return this.options;
57
+ }
58
+ prepareOptions() {
59
+ const optionsForLargeScreens = this.getOptionsForNonSmallScreens(this.originalOptions.find(option => !option.breakpoint) || {});
60
+ const optionsForSmallScreens = this.getOptionsForSmallScreens(this.originalOptions.find(option => !!option.breakpoint) || {});
61
+ return [
62
+ optionsForLargeScreens,
63
+ optionsForSmallScreens,
64
+ ];
65
+ }
66
+ getOptionsForNonSmallScreens(options) {
67
+ const optionsForLargeScreens = { ...this.defaultOptionsLargeScreen, ...options };
68
+ // calc dimensions
69
+ const boxWidth = parseFloat(optionsForLargeScreens.width);
70
+ this.calcDimensions(boxWidth, optionsForLargeScreens.thumbnailsColumns);
71
+ const customOptions = {
72
+ width: this.dimensions.box.width + 'px',
73
+ height: this.dimensions.box.height + 'px',
74
+ ccpBoxLayout: this.galleryLayout,
75
+ ccpImageWidth: this.dimensions.image.width,
76
+ ccpImageHeight: this.dimensions.image.height,
77
+ thumbnails: this.numberOfMedia > 1,
78
+ thumbnailsPercent: this.getThumbnailsPercent(optionsForLargeScreens.thumbnailsColumns),
79
+ thumbnailMargin: this.getThumbnailMargin(),
80
+ };
81
+ return { ...customOptions, ...optionsForLargeScreens };
82
+ }
83
+ getOptionsForSmallScreens(options) {
84
+ const optionsForSmallScreens = { ...this.defaultOptionsSmallScreen, ...options };
85
+ const boxForSmallScreen = this.calcBoxForSmallScreens(optionsForSmallScreens.thumbnailsColumns);
86
+ const customOptions = {
87
+ width: boxForSmallScreen.width + 'px',
88
+ height: boxForSmallScreen.height + 'px',
89
+ image: this.numberOfMedia <= 1,
90
+ };
91
+ return { ...optionsForSmallScreens, ...customOptions };
92
+ }
93
+ calcDimensions(boxWidth, thumbnailColumns) {
94
+ const boxAdjustment = 2 * this.boxPadding + 2 * this.boxBorder;
95
+ const showThumbnails = this.numberOfMedia > 1;
96
+ const box = {
97
+ width: boxWidth,
98
+ height: boxWidth,
99
+ };
100
+ const image = {
101
+ width: box.width - boxAdjustment,
102
+ height: box.height - boxAdjustment,
103
+ };
104
+ const thumbnail = {
105
+ width: 0,
106
+ height: 0,
107
+ };
108
+ if (showThumbnails) {
109
+ thumbnail.width = Math.round((image.width - (thumbnailColumns - 1) * this.boxPadding) / thumbnailColumns);
110
+ thumbnail.height = thumbnail.width;
111
+ box.height = image.height + thumbnail.height + boxAdjustment + this.boxPadding;
112
+ }
113
+ this.dimensions = {
114
+ box,
115
+ image,
116
+ thumbnail,
117
+ };
118
+ }
119
+ calcBoxForSmallScreens(thumbnailColumnsSmallScreen) {
120
+ const showThumbnails = this.numberOfMedia > 1;
121
+ if (showThumbnails) {
122
+ return {
123
+ height: this.dimensions.thumbnail.height + 2 * this.boxPadding + this.boxBorder,
124
+ width: this.dimensions.thumbnail.width * thumbnailColumnsSmallScreen
125
+ + (1 + thumbnailColumnsSmallScreen) * this.boxPadding
126
+ + 2 * this.boxBorder,
127
+ };
128
+ }
129
+ return {
130
+ width: this.dimensions.image.width,
131
+ height: this.dimensions.image.height,
132
+ };
133
+ }
134
+ getThumbnailsPercent(thumbnailsColumns) {
135
+ return Math.round((100 - this.boxPadding) / thumbnailsColumns);
136
+ }
137
+ getThumbnailMargin() {
138
+ return this.boxPadding;
139
+ }
140
+ }
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cc-custom-options.js","sourceRoot":"","sources":["../../../../projects/ngx-gallery/src/lib/cc-custom-options.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgxGalleryImageSize } from './models/ngx-gallery-image-size.model';\nimport { NgxGalleryOptions } from './models/ngx-gallery-options.model';\nimport { NgxGalleryDimensions } from './utils/ngx-gallery-dimensions.interface';\n\nexport class CcCustomOptions {\n\n  dimensions: NgxGalleryDimensions = {\n    box: { width: 0, height: 0 },\n    image: { width: 0, height: 0 },\n    thumbnail: { width: 0, height: 0 },\n  };\n\n  private originalOptions: NgxGalleryOptions[];\n  private options: NgxGalleryOptions[];\n  private numberOfMedia: number;\n\n  private boxPadding = 10;\n  private boxBorder = 3;\n  private galleryLayout = {\n    border: this.boxBorder + 'px grey solid',\n    padding: this.boxPadding + 'px',\n    // TODO: move into css as it is not dynamic\n    'background-color': '#D8D8D8',\n  };\n\n  private defaultOptionsLargeScreen: NgxGalleryOptions = {\n    width: '400px',  // originally 400\n    imageSize: NgxGalleryImageSize.Contain,\n    imagePercent: 88.6, // before: 80\n    imageDescription: true,\n    imageInfinityMove: false,\n    imageArrows: false,\n    ccpImageAsLink: true,\n    image: true,\n    lazyLoading: true,\n    thumbnailsAsLinks: true,\n    ccpPreviewImageAsLink: true,\n    previewDescription: true,\n    previewZoom: true,\n    previewAutoPlay: false, // setting to true needs coding in preview component!\n    imageAutoPlay: false, // parameter set by author dynamically TODO\n    thumbnailsColumns: 3,\n    thumbnailsMoveSize: 3,\n    thumbnailSize: NgxGalleryImageSize.Contain\n  };\n\n  private defaultOptionsSmallScreen: NgxGalleryOptions = {\n    breakpoint: 1100,\n    thumbnailsColumns: 2,\n    thumbnailsMoveSize: 2,\n    image: false, // small screens - do not show image\n  };\n\n  constructor(initialOptions: NgxGalleryOptions[], initialNumberOfMedia: number) {\n    this.numberOfMedia = initialNumberOfMedia;\n    this.originalOptions = initialOptions;\n    this.options = this.prepareOptions();\n  }\n\n  setOriginalOptions(originalOptions: NgxGalleryOptions[]) {\n    this.originalOptions = originalOptions;\n    this.options = this.prepareOptions();\n  }\n\n  setNumberOfMedia(numberOfMedia: number) {\n    this.numberOfMedia = numberOfMedia;\n    this.options = this.prepareOptions();\n  }\n\n  getOptions(): NgxGalleryOptions[] {\n    return this.options;\n  }\n\n  private prepareOptions(): NgxGalleryOptions[] {\n    const optionsForLargeScreens = this.getOptionsForNonSmallScreens(this.originalOptions.find(option => !option.breakpoint) || {});\n    const optionsForSmallScreens = this.getOptionsForSmallScreens(this.originalOptions.find(option => !!option.breakpoint) || {});\n\n    return [\n      optionsForLargeScreens,\n      optionsForSmallScreens,\n    ];\n  }\n\n  private getOptionsForNonSmallScreens(options: NgxGalleryOptions): NgxGalleryOptions {\n    const optionsForLargeScreens: NgxGalleryOptions = { ...this.defaultOptionsLargeScreen, ...options };\n\n    // calc dimensions\n    const boxWidth = parseFloat(optionsForLargeScreens.width);\n    this.calcDimensions(boxWidth, optionsForLargeScreens.thumbnailsColumns);\n\n    const customOptions = {\n      width: this.dimensions.box.width + 'px',\n      height: this.dimensions.box.height + 'px',\n      ccpBoxLayout: this.galleryLayout,\n      ccpImageWidth: this.dimensions.image.width,\n      ccpImageHeight: this.dimensions.image.height,\n      thumbnails: this.numberOfMedia > 1,\n      thumbnailsPercent: this.getThumbnailsPercent(optionsForLargeScreens.thumbnailsColumns),\n      thumbnailMargin: this.getThumbnailMargin(),\n    };\n\n    return { ...customOptions, ...optionsForLargeScreens };\n  }\n\n  private getOptionsForSmallScreens(options: NgxGalleryOptions): NgxGalleryOptions {\n    const optionsForSmallScreens: NgxGalleryOptions = { ...this.defaultOptionsSmallScreen, ...options };\n\n    const boxForSmallScreen = this.calcBoxForSmallScreens(optionsForSmallScreens.thumbnailsColumns);\n    const customOptions = {\n      width: boxForSmallScreen.width + 'px',\n      height: boxForSmallScreen.height + 'px',\n      image: this.numberOfMedia <= 1,\n    };\n\n    return { ...optionsForSmallScreens, ...customOptions };\n  }\n\n  private calcDimensions(boxWidth: number, thumbnailColumns: number) {\n    const boxAdjustment = 2 * this.boxPadding + 2 * this.boxBorder;\n    const showThumbnails = this.numberOfMedia > 1;\n\n    const box = {\n      width: boxWidth,\n      height: boxWidth,\n    };\n\n    const image = {\n      width: box.width - boxAdjustment,\n      height: box.height - boxAdjustment,\n    };\n\n    const thumbnail = {\n      width: 0,\n      height: 0,\n    };\n\n    if (showThumbnails) {\n      thumbnail.width = Math.round((image.width - (thumbnailColumns - 1) * this.boxPadding) / thumbnailColumns);\n      thumbnail.height = thumbnail.width;\n\n      box.height = image.height + thumbnail.height + boxAdjustment + this.boxPadding;\n    }\n\n    this.dimensions = {\n      box,\n      image,\n      thumbnail,\n    };\n  }\n\n  private calcBoxForSmallScreens(thumbnailColumnsSmallScreen: number) {\n    const showThumbnails = this.numberOfMedia > 1;\n\n    if (showThumbnails) {\n      return {\n        height: this.dimensions.thumbnail.height + 2 * this.boxPadding + this.boxBorder, // not 2 * this.BoxBorder?\n        width: this.dimensions.thumbnail.width * thumbnailColumnsSmallScreen\n          + (1 + thumbnailColumnsSmallScreen) * this.boxPadding\n          + 2 * this.boxBorder,\n      };\n    }\n\n    return {\n      width: this.dimensions.image.width,\n      height: this.dimensions.image.height,\n    };\n  }\n\n  private getThumbnailsPercent(thumbnailsColumns: number): number {\n    return Math.round((100 - this.boxPadding) / thumbnailsColumns);\n  }\n\n  private getThumbnailMargin() {\n    return this.boxPadding;\n  }\n}\n"]}
@@ -0,0 +1,142 @@
1
+ import { ChangeDetectorRef, Component, ElementRef, Input, ViewChild, } from '@angular/core';
2
+ import { MediumAddOnType, MediumUrlType, } from '@casus-campus/cc-support';
3
+ import { Arrow } from '../svg/arrow.model';
4
+ import { Icon } from '../svg/icon.model';
5
+ import { Point } from '../svg/point.model';
6
+ import { Polygon } from '../svg/polygon.model';
7
+ import { CcMediaService } from '../utils/cc-media.service';
8
+ import { LogService } from '../utils/logging.service';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../utils/logging.service";
11
+ import * as i2 from "../utils/cc-media.service";
12
+ import * as i3 from "../svg/ngx-gallery-svg-arrow.component";
13
+ import * as i4 from "../svg/ngx-gallery-svg-polygon.component";
14
+ import * as i5 from "../svg/ngx-gallery-svg-icon.component";
15
+ import * as i6 from "../svg/ngx-gallery-svg-text.component";
16
+ import * as i7 from "@angular/common";
17
+ export class NgxGalleryImageSvgComponent {
18
+ constructor(logService, ccMediaService, cdRef) {
19
+ this.logService = logService;
20
+ this.ccMediaService = ccMediaService;
21
+ this.cdRef = cdRef;
22
+ this.svgArrows = [];
23
+ this.svgPolygons = [];
24
+ this.svgIcons = [];
25
+ this.svgTexts = [];
26
+ this.scaleFactor = 1;
27
+ }
28
+ ngOnInit() {
29
+ this.logService.log('NgxGallerySvgComponent.ngOnInit', 'ngOnInit');
30
+ this.handleAddOns();
31
+ }
32
+ ngAfterViewInit() {
33
+ this.scaleFactor = this.calcScaleFactor();
34
+ this.cdRef.detectChanges();
35
+ }
36
+ ngOnChanges(changes) {
37
+ this.logService.log('NgxGallerySvgComponent.onChange', 'ngOnChanges');
38
+ if (changes.zoomValue && !changes.zoomValue.isFirstChange()) {
39
+ this.scaleFactor = this.calcScaleFactor();
40
+ }
41
+ }
42
+ handleAddOns() {
43
+ this.svgArrows = this.addOns
44
+ .filter(addOn => addOn.type === MediumAddOnType.Arrow)
45
+ .map(addOn => this.mapToArrow(addOn))
46
+ .filter(element => !!element);
47
+ this.svgIcons = this.addOns
48
+ .filter(addOn => addOn.type === MediumAddOnType.IconHyperlink)
49
+ .map(addOn => this.mapToIcon(addOn))
50
+ .filter(element => !!element);
51
+ this.svgPolygons = this.addOns
52
+ .filter(addOn => addOn.type === MediumAddOnType.HotSpot)
53
+ .map(addOn => this.mapToPolygon(addOn))
54
+ .filter(element => !!element);
55
+ this.svgTexts = this.addOns
56
+ .filter(addOn => addOn.type === MediumAddOnType.Text)
57
+ .map(addOn => this.mapToText(addOn))
58
+ .filter(element => !!element);
59
+ }
60
+ mapToArrow(arrow) {
61
+ return new Arrow(new Point(arrow.src.left, arrow.src.top, ''), new Point(arrow.dst.left, arrow.dst.top, ''), arrow.color);
62
+ }
63
+ mockExternalHyperlinkMedium(iconHyperlink) {
64
+ const url = iconHyperlink.externalUrl;
65
+ if (!url) {
66
+ return;
67
+ }
68
+ const schemeMatch = /^[a-zA-Z]+/.exec(url);
69
+ const mimeType = 'url/' + (schemeMatch && schemeMatch[0] || 'relative');
70
+ return {
71
+ name: url,
72
+ description: url,
73
+ height: 0,
74
+ width: 0,
75
+ mimeType,
76
+ urls: [{
77
+ url,
78
+ type: MediumUrlType.External,
79
+ mimeType,
80
+ }]
81
+ };
82
+ }
83
+ mapToIcon(iconHyperlink) {
84
+ const target = iconHyperlink.medium || this.mockExternalHyperlinkMedium(iconHyperlink);
85
+ if (!target) {
86
+ console.error('Found iconHyperlink without target or external url', iconHyperlink);
87
+ return;
88
+ }
89
+ const placeholderPath = this.ccMediaService.getMimeTypePlaceholderPath(target.mimeType);
90
+ return new Icon(placeholderPath, target, target.description, new Point(iconHyperlink.rect.left, iconHyperlink.rect.top, ''), iconHyperlink.rect.width, iconHyperlink.rect.height, iconHyperlink.color);
91
+ }
92
+ mapToPolygon(hotSpot) {
93
+ const points = hotSpot.polygon
94
+ .map(point => new Point(point.left, point.top, ''));
95
+ return new Polygon((hotSpot.medium && hotSpot.medium.data) || '', points, hotSpot.medium, hotSpot.color);
96
+ }
97
+ mapToText(text) {
98
+ return new Point(text.position.left, text.position.top, text.text, text.color);
99
+ }
100
+ // Returns multiplicator for elements that should keep the same dimensions
101
+ calcScaleFactor() {
102
+ const originalWidth = parseFloat(this.viewBox.split(' ')[2]);
103
+ const currentWidth = this.svgElement.nativeElement.clientWidth * parseFloat(this.zoomValue);
104
+ const widthScaleFactor = originalWidth / currentWidth;
105
+ const originalHeight = parseFloat(this.viewBox.split(' ')[3]);
106
+ const currentHeigth = this.svgElement.nativeElement.clientHeight * parseFloat(this.zoomValue);
107
+ const heightScaleFactor = originalHeight / currentHeigth;
108
+ return Math.max(widthScaleFactor, heightScaleFactor);
109
+ }
110
+ }
111
+ NgxGalleryImageSvgComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryImageSvgComponent, deps: [{ token: i1.LogService }, { token: i2.CcMediaService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
112
+ NgxGalleryImageSvgComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: NgxGalleryImageSvgComponent, selector: "cc-imagesvg", inputs: { width: "width", height: "height", viewBox: "viewBox", posLeft: "posLeft", posTop: "posTop", zoomValue: "zoomValue", animation: "animation", addOns: "addOns", classGrab: "classGrab", styleTransform: "styleTransform", preview: "preview" }, viewQueries: [{ propertyName: "svgElement", first: true, predicate: ["svgElement"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" preserveAspectRatio=\"xMidYMid meet\"\n [attr.width]=\"width\" [attr.height]=\"height\" [attr.viewBox]=\"viewBox\" class=\"ngx-gallery-center\"\n [class.animation]=\"animation\" [class.ngx-gallery-preview-svg]=\"preview\" [class.ngx-gallery-image-svg]=\"!preview\"\n [class.ngx-gallery-grab]=\"classGrab\" [style.transform]=\"styleTransform\" [style.left]=\"posLeft\" [style.top]=\"posTop\"\n (click)=\"$event.stopPropagation()\" #svgElement>\n <svg:g *ngIf=\"!!svgArrows.length\" svg-arrow [svgArrows]=\"svgArrows\"></svg:g>\n <svg:g *ngIf=\"!!svgPolygons.length\" svg-polygon [svgPolygons]=\"svgPolygons\"></svg:g>\n <svg:g *ngIf=\"!!svgIcons.length\" svg-icon [svgIcons]=\"svgIcons\" [scaleFactor]=\"scaleFactor\"></svg:g>\n <svg:g *ngIf=\"!!svgTexts.length\" svg-text [svgTexts]=\"svgTexts\"></svg:g>\n</svg>\n", styles: [".ngx-gallery-center{position:absolute;left:0;right:0;bottom:0;margin:auto;top:0}.ngx-gallery-image-svg{margin:0}.ngx-gallery-preview-svg{opacity:1;max-width:90%;max-height:90%;-webkit-user-select:none;user-select:none;transition:transform .5s}.ngx-gallery-preview-svg.animation{transition:opacity .5s linear,transform .5s}.ngx-gallery-preview-svg.ngx-gallery-active{opacity:1}.ngx-gallery-preview-svg.ngx-gallery-grab{cursor:grab;cursor:-webkit-grab}\n"], components: [{ type: i3.NgxGallerySvgArrowComponent, selector: "[svg-arrow]", inputs: ["svgArrows"] }, { type: i4.NgxGallerySvgPolygonComponent, selector: "[svg-polygon]", inputs: ["svgPolygons"] }, { type: i5.NgxGallerySvgIconComponent, selector: "[svg-icon]", inputs: ["svgIcons", "scaleFactor"] }, { type: i6.NgxGallerySvgTextComponent, selector: "[svg-text]", inputs: ["svgTexts"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
113
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryImageSvgComponent, decorators: [{
114
+ type: Component,
115
+ args: [{ selector: 'cc-imagesvg', template: "<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" preserveAspectRatio=\"xMidYMid meet\"\n [attr.width]=\"width\" [attr.height]=\"height\" [attr.viewBox]=\"viewBox\" class=\"ngx-gallery-center\"\n [class.animation]=\"animation\" [class.ngx-gallery-preview-svg]=\"preview\" [class.ngx-gallery-image-svg]=\"!preview\"\n [class.ngx-gallery-grab]=\"classGrab\" [style.transform]=\"styleTransform\" [style.left]=\"posLeft\" [style.top]=\"posTop\"\n (click)=\"$event.stopPropagation()\" #svgElement>\n <svg:g *ngIf=\"!!svgArrows.length\" svg-arrow [svgArrows]=\"svgArrows\"></svg:g>\n <svg:g *ngIf=\"!!svgPolygons.length\" svg-polygon [svgPolygons]=\"svgPolygons\"></svg:g>\n <svg:g *ngIf=\"!!svgIcons.length\" svg-icon [svgIcons]=\"svgIcons\" [scaleFactor]=\"scaleFactor\"></svg:g>\n <svg:g *ngIf=\"!!svgTexts.length\" svg-text [svgTexts]=\"svgTexts\"></svg:g>\n</svg>\n", styles: [".ngx-gallery-center{position:absolute;left:0;right:0;bottom:0;margin:auto;top:0}.ngx-gallery-image-svg{margin:0}.ngx-gallery-preview-svg{opacity:1;max-width:90%;max-height:90%;-webkit-user-select:none;user-select:none;transition:transform .5s}.ngx-gallery-preview-svg.animation{transition:opacity .5s linear,transform .5s}.ngx-gallery-preview-svg.ngx-gallery-active{opacity:1}.ngx-gallery-preview-svg.ngx-gallery-grab{cursor:grab;cursor:-webkit-grab}\n"] }]
116
+ }], ctorParameters: function () { return [{ type: i1.LogService }, { type: i2.CcMediaService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { width: [{
117
+ type: Input
118
+ }], height: [{
119
+ type: Input
120
+ }], viewBox: [{
121
+ type: Input
122
+ }], posLeft: [{
123
+ type: Input
124
+ }], posTop: [{
125
+ type: Input
126
+ }], zoomValue: [{
127
+ type: Input
128
+ }], animation: [{
129
+ type: Input
130
+ }], addOns: [{
131
+ type: Input
132
+ }], classGrab: [{
133
+ type: Input
134
+ }], styleTransform: [{
135
+ type: Input
136
+ }], preview: [{
137
+ type: Input
138
+ }], svgElement: [{
139
+ type: ViewChild,
140
+ args: ['svgElement', { static: true }]
141
+ }] } });
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-gallery-image-svg.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-gallery/src/lib/image/ngx-gallery-image-svg.component.ts","../../../../../projects/ngx-gallery/src/lib/image/ngx-gallery-image-svg.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport {\n  IMedium,\n  IMediumAddOn,\n  IMediumAddOnArrow,\n  IMediumAddOnHotSpot,\n  IMediumAddOnIconHyperlink,\n  IMediumAddOnText,\n  MediumAddOnType,\n  MediumUrlType,\n} from '@casus-campus/cc-support';\n\nimport { Arrow } from '../svg/arrow.model';\nimport { Icon } from '../svg/icon.model';\nimport { Point } from '../svg/point.model';\nimport { Polygon } from '../svg/polygon.model';\nimport { CcMediaService } from '../utils/cc-media.service';\nimport { LogService } from '../utils/logging.service';\n\n@Component({\n  /* eslint-disable @angular-eslint/component-selector */\n  selector: 'cc-imagesvg',\n  templateUrl: './ngx-gallery-image-svg.component.html',\n  styleUrls: ['./ngx-gallery-image-svg.component.scss'],\n})\n\nexport class NgxGalleryImageSvgComponent implements OnInit, OnChanges, AfterViewInit {\n\n  @Input() width: number;\n  @Input() height: number;\n  @Input() viewBox: string;\n  @Input() posLeft: string;\n  @Input() posTop: string;\n  @Input() zoomValue: string;\n  @Input() animation: string;\n  @Input() addOns: IMediumAddOn[];\n  @Input() classGrab: boolean;\n  @Input() styleTransform: string;\n  @Input() preview: boolean;\n\n  svgArrows: Arrow[] = [];\n  svgPolygons: Polygon[] = [];\n  svgIcons: Icon[] = [];\n  svgTexts: Point[] = [];\n\n  scaleFactor = 1;\n\n  @ViewChild('svgElement', { static: true }) svgElement: ElementRef;\n\n  constructor(private logService: LogService, private ccMediaService: CcMediaService, private cdRef: ChangeDetectorRef) { }\n\n  ngOnInit() {\n    this.logService.log('NgxGallerySvgComponent.ngOnInit', 'ngOnInit');\n    this.handleAddOns();\n  }\n\n  ngAfterViewInit() {\n    this.scaleFactor = this.calcScaleFactor();\n    this.cdRef.detectChanges();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.logService.log('NgxGallerySvgComponent.onChange', 'ngOnChanges');\n    if (changes.zoomValue && !changes.zoomValue.isFirstChange()) {\n      this.scaleFactor = this.calcScaleFactor();\n    }\n  }\n\n  private handleAddOns(): void {\n    this.svgArrows = this.addOns\n      .filter(addOn => addOn.type === MediumAddOnType.Arrow)\n      .map(addOn => this.mapToArrow(addOn as IMediumAddOnArrow))\n      .filter(element => !!element);\n    this.svgIcons = this.addOns\n      .filter(addOn => addOn.type === MediumAddOnType.IconHyperlink)\n      .map(addOn => this.mapToIcon(addOn as IMediumAddOnIconHyperlink))\n      .filter(element => !!element);\n    this.svgPolygons = this.addOns\n      .filter(addOn => addOn.type === MediumAddOnType.HotSpot)\n      .map(addOn => this.mapToPolygon(addOn as IMediumAddOnHotSpot))\n      .filter(element => !!element);\n    this.svgTexts = this.addOns\n      .filter(addOn => addOn.type === MediumAddOnType.Text)\n      .map(addOn => this.mapToText(addOn as IMediumAddOnText))\n      .filter(element => !!element);\n  }\n\n  private mapToArrow(arrow: IMediumAddOnArrow): Arrow {\n    return new Arrow(\n      new Point(arrow.src.left, arrow.src.top, ''),\n      new Point(arrow.dst.left, arrow.dst.top, ''),\n      arrow.color\n    );\n  }\n\n  private mockExternalHyperlinkMedium(iconHyperlink: IMediumAddOnIconHyperlink): IMedium {\n    const url = iconHyperlink.externalUrl;\n    if (!url) {\n      return;\n    }\n    const schemeMatch = /^[a-zA-Z]+/.exec(url);\n    const mimeType = 'url/' + (schemeMatch && schemeMatch[0] || 'relative');\n    return {\n      name: url,\n      description: url,\n      height: 0,\n      width: 0,\n      mimeType,\n      urls: [{\n        url,\n        type: MediumUrlType.External,\n        mimeType,\n      }]\n    };\n  }\n\n  private mapToIcon(iconHyperlink: IMediumAddOnIconHyperlink): Icon {\n    const target = iconHyperlink.medium || this.mockExternalHyperlinkMedium(iconHyperlink);\n    if (!target) {\n      console.error('Found iconHyperlink without target or external url', iconHyperlink);\n      return;\n    }\n\n    const placeholderPath = this.ccMediaService.getMimeTypePlaceholderPath(target.mimeType);\n    return new Icon(\n      placeholderPath,\n      target,\n      target.description,\n      new Point(iconHyperlink.rect.left, iconHyperlink.rect.top, ''),\n      iconHyperlink.rect.width,\n      iconHyperlink.rect.height,\n      iconHyperlink.color\n    );\n  }\n\n  private mapToPolygon(hotSpot: IMediumAddOnHotSpot): Polygon {\n    const points = hotSpot.polygon\n      .map(point => new Point(point.left, point.top, ''));\n    return new Polygon(\n      (hotSpot.medium && hotSpot.medium.data) || '',\n      points,\n      hotSpot.medium,\n      hotSpot.color\n    );\n\n  }\n\n  private mapToText(text: IMediumAddOnText): Point {\n    return new Point(\n      text.position.left,\n      text.position.top,\n      text.text,\n      text.color\n    );\n  }\n\n  // Returns multiplicator for elements that should keep the same dimensions\n  private calcScaleFactor(): number {\n\n    const originalWidth = parseFloat(this.viewBox.split(' ')[2]);\n    const currentWidth = this.svgElement.nativeElement.clientWidth * parseFloat(this.zoomValue);\n    const widthScaleFactor = originalWidth / currentWidth;\n\n    const originalHeight = parseFloat(this.viewBox.split(' ')[3]);\n    const currentHeigth = this.svgElement.nativeElement.clientHeight * parseFloat(this.zoomValue);\n    const heightScaleFactor = originalHeight / currentHeigth;\n\n    return Math.max(widthScaleFactor, heightScaleFactor);\n  }\n}\n","<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" preserveAspectRatio=\"xMidYMid meet\"\n  [attr.width]=\"width\" [attr.height]=\"height\" [attr.viewBox]=\"viewBox\" class=\"ngx-gallery-center\"\n  [class.animation]=\"animation\" [class.ngx-gallery-preview-svg]=\"preview\" [class.ngx-gallery-image-svg]=\"!preview\"\n  [class.ngx-gallery-grab]=\"classGrab\" [style.transform]=\"styleTransform\" [style.left]=\"posLeft\" [style.top]=\"posTop\"\n  (click)=\"$event.stopPropagation()\" #svgElement>\n  <svg:g *ngIf=\"!!svgArrows.length\" svg-arrow [svgArrows]=\"svgArrows\"></svg:g>\n  <svg:g *ngIf=\"!!svgPolygons.length\" svg-polygon [svgPolygons]=\"svgPolygons\"></svg:g>\n  <svg:g *ngIf=\"!!svgIcons.length\" svg-icon [svgIcons]=\"svgIcons\" [scaleFactor]=\"scaleFactor\"></svg:g>\n  <svg:g *ngIf=\"!!svgTexts.length\" svg-text [svgTexts]=\"svgTexts\"></svg:g>\n</svg>\n"]}
@@ -0,0 +1,47 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class NgxGalleryActionComponent {
4
+ constructor() {
5
+ this.disabled = false;
6
+ this.titleText = '';
7
+ this.onClick = new EventEmitter();
8
+ }
9
+ handleClick(event) {
10
+ if (!this.disabled) {
11
+ this.onClick.emit(event);
12
+ }
13
+ event.stopPropagation();
14
+ event.preventDefault();
15
+ }
16
+ }
17
+ NgxGalleryActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryActionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
18
+ NgxGalleryActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: NgxGalleryActionComponent, selector: "ngx-gallery-action", inputs: { icon: "icon", disabled: "disabled", titleText: "titleText" }, outputs: { onClick: "onClick" }, ngImport: i0, template: `
19
+ <div class="ngx-gallery-icon" [class.ngx-gallery-icon-disabled]="disabled"
20
+ aria-hidden="true"
21
+ title="{{ titleText }}"
22
+ (click)="handleClick($event)">
23
+ <i class="ngx-gallery-icon-content {{ icon }}"></i>
24
+ </div>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryActionComponent, decorators: [{
26
+ type: Component,
27
+ args: [{
28
+ selector: 'ngx-gallery-action',
29
+ template: `
30
+ <div class="ngx-gallery-icon" [class.ngx-gallery-icon-disabled]="disabled"
31
+ aria-hidden="true"
32
+ title="{{ titleText }}"
33
+ (click)="handleClick($event)">
34
+ <i class="ngx-gallery-icon-content {{ icon }}"></i>
35
+ </div>`,
36
+ changeDetection: ChangeDetectionStrategy.OnPush
37
+ }]
38
+ }], propDecorators: { icon: [{
39
+ type: Input
40
+ }], disabled: [{
41
+ type: Input
42
+ }], titleText: [{
43
+ type: Input
44
+ }], onClick: [{
45
+ type: Output
46
+ }] } });
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWdhbGxlcnktYWN0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1nYWxsZXJ5L3NyYy9saWIvbmd4LWdhbGxlcnktYWN0aW9uL25neC1nYWxsZXJ5LWFjdGlvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFhaEcsTUFBTSxPQUFPLHlCQUF5QjtJQVh0QztRQWFXLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsY0FBUyxHQUFHLEVBQUUsQ0FBQztRQUVkLFlBQU8sR0FBd0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztLQVU3RDtJQVJDLFdBQVcsQ0FBQyxLQUFZO1FBQ3RCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQzFCO1FBRUQsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN6QixDQUFDOztzSEFkVSx5QkFBeUI7MEdBQXpCLHlCQUF5QixtS0FUMUI7Ozs7OztXQU1EOzJGQUdFLHlCQUF5QjtrQkFYckMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixRQUFRLEVBQUU7Ozs7OztXQU1EO29CQUNULGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRDs4QkFFVSxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVJLE9BQU87c0JBQWhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbmd4LWdhbGxlcnktYWN0aW9uJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwibmd4LWdhbGxlcnktaWNvblwiIFtjbGFzcy5uZ3gtZ2FsbGVyeS1pY29uLWRpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICB0aXRsZT1cInt7IHRpdGxlVGV4dCB9fVwiXG4gICAgICAoY2xpY2spPVwiaGFuZGxlQ2xpY2soJGV2ZW50KVwiPlxuICAgICAgICA8aSBjbGFzcz1cIm5neC1nYWxsZXJ5LWljb24tY29udGVudCB7eyBpY29uIH19XCI+PC9pPlxuICAgIDwvZGl2PmAsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIE5neEdhbGxlcnlBY3Rpb25Db21wb25lbnQge1xuICBASW5wdXQoKSBpY29uOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XG4gIEBJbnB1dCgpIHRpdGxlVGV4dCA9ICcnO1xuXG4gIEBPdXRwdXQoKSBvbkNsaWNrOiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIGhhbmRsZUNsaWNrKGV2ZW50OiBFdmVudCkge1xuICAgIGlmICghdGhpcy5kaXNhYmxlZCkge1xuICAgICAgdGhpcy5vbkNsaWNrLmVtaXQoZXZlbnQpO1xuICAgIH1cblxuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,67 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class NgxGalleryArrowsComponent {
4
+ constructor() {
5
+ this.onPrevClick = new EventEmitter();
6
+ this.onNextClick = new EventEmitter();
7
+ }
8
+ handlePrevClick() {
9
+ this.onPrevClick.emit();
10
+ }
11
+ handleNextClick() {
12
+ this.onNextClick.emit();
13
+ }
14
+ }
15
+ NgxGalleryArrowsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryArrowsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
16
+ NgxGalleryArrowsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: NgxGalleryArrowsComponent, selector: "ngx-gallery-arrows", inputs: { prevDisabled: "prevDisabled", nextDisabled: "nextDisabled", arrowPrevIcon: "arrowPrevIcon", arrowNextIcon: "arrowNextIcon" }, outputs: { onPrevClick: "onPrevClick", onNextClick: "onNextClick" }, ngImport: i0, template: `
17
+ <div class="ngx-gallery-arrow-wrapper ngx-gallery-arrow-left">
18
+ <div class="ngx-gallery-icon ngx-gallery-arrow"
19
+ aria-hidden="true"
20
+ (click)="handlePrevClick()"
21
+ [class.ngx-gallery-disabled]="prevDisabled">
22
+ <i class="ngx-gallery-icon-content {{arrowPrevIcon}}"></i>
23
+ </div>
24
+ </div>
25
+ <div class="ngx-gallery-arrow-wrapper ngx-gallery-arrow-right">
26
+ <div class="ngx-gallery-icon ngx-gallery-arrow"
27
+ aria-hidden="true"
28
+ (click)="handleNextClick()"
29
+ [class.ngx-gallery-disabled]="nextDisabled">
30
+ <i class="ngx-gallery-icon-content {{arrowNextIcon}}"></i>
31
+ </div>
32
+ </div>
33
+ `, isInline: true, styles: [".ngx-gallery-arrow-wrapper{position:absolute;height:100%;width:1px;display:table;z-index:2000;table-layout:fixed}.ngx-gallery-arrow-left{left:0px}.ngx-gallery-arrow-right{right:0px}.ngx-gallery-arrow{top:50%;transform:translateY(-50%);background:#ffffff8c;cursor:pointer}.ngx-gallery-arrow.ngx-gallery-disabled{opacity:.6;cursor:default}.ngx-gallery-arrow-left .ngx-gallery-arrow{left:10px}.ngx-gallery-arrow-right .ngx-gallery-arrow{right:10px}\n"] });
34
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryArrowsComponent, decorators: [{
35
+ type: Component,
36
+ args: [{ selector: 'ngx-gallery-arrows', template: `
37
+ <div class="ngx-gallery-arrow-wrapper ngx-gallery-arrow-left">
38
+ <div class="ngx-gallery-icon ngx-gallery-arrow"
39
+ aria-hidden="true"
40
+ (click)="handlePrevClick()"
41
+ [class.ngx-gallery-disabled]="prevDisabled">
42
+ <i class="ngx-gallery-icon-content {{arrowPrevIcon}}"></i>
43
+ </div>
44
+ </div>
45
+ <div class="ngx-gallery-arrow-wrapper ngx-gallery-arrow-right">
46
+ <div class="ngx-gallery-icon ngx-gallery-arrow"
47
+ aria-hidden="true"
48
+ (click)="handleNextClick()"
49
+ [class.ngx-gallery-disabled]="nextDisabled">
50
+ <i class="ngx-gallery-icon-content {{arrowNextIcon}}"></i>
51
+ </div>
52
+ </div>
53
+ `, styles: [".ngx-gallery-arrow-wrapper{position:absolute;height:100%;width:1px;display:table;z-index:2000;table-layout:fixed}.ngx-gallery-arrow-left{left:0px}.ngx-gallery-arrow-right{right:0px}.ngx-gallery-arrow{top:50%;transform:translateY(-50%);background:#ffffff8c;cursor:pointer}.ngx-gallery-arrow.ngx-gallery-disabled{opacity:.6;cursor:default}.ngx-gallery-arrow-left .ngx-gallery-arrow{left:10px}.ngx-gallery-arrow-right .ngx-gallery-arrow{right:10px}\n"] }]
54
+ }], propDecorators: { prevDisabled: [{
55
+ type: Input
56
+ }], nextDisabled: [{
57
+ type: Input
58
+ }], arrowPrevIcon: [{
59
+ type: Input
60
+ }], arrowNextIcon: [{
61
+ type: Input
62
+ }], onPrevClick: [{
63
+ type: Output
64
+ }], onNextClick: [{
65
+ type: Output
66
+ }] } });
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWdhbGxlcnktYXJyb3dzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1nYWxsZXJ5L3NyYy9saWIvbmd4LWdhbGxlcnktYXJyb3dzL25neC1nYWxsZXJ5LWFycm93cy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUF3QnZFLE1BQU0sT0FBTyx5QkFBeUI7SUF0QnRDO1FBNEJZLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUNqQyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7S0FTNUM7SUFQQyxlQUFlO1FBQ2IsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDMUIsQ0FBQzs7c0hBZlUseUJBQXlCOzBHQUF6Qix5QkFBeUIsdVFBcEIxQjs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FpQlA7MkZBR1EseUJBQXlCO2tCQXRCckMsU0FBUzsrQkFDRSxvQkFBb0IsWUFDcEI7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBaUJQOzhCQUlNLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBRUksV0FBVztzQkFBcEIsTUFBTTtnQkFDRyxXQUFXO3NCQUFwQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbmd4LWdhbGxlcnktYXJyb3dzJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwibmd4LWdhbGxlcnktYXJyb3ctd3JhcHBlciBuZ3gtZ2FsbGVyeS1hcnJvdy1sZWZ0XCI+XG4gICAgICA8ZGl2IGNsYXNzPVwibmd4LWdhbGxlcnktaWNvbiBuZ3gtZ2FsbGVyeS1hcnJvd1wiXG4gICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgIChjbGljayk9XCJoYW5kbGVQcmV2Q2xpY2soKVwiXG4gICAgICAgIFtjbGFzcy5uZ3gtZ2FsbGVyeS1kaXNhYmxlZF09XCJwcmV2RGlzYWJsZWRcIj5cbiAgICAgICAgPGkgY2xhc3M9XCJuZ3gtZ2FsbGVyeS1pY29uLWNvbnRlbnQge3thcnJvd1ByZXZJY29ufX1cIj48L2k+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwibmd4LWdhbGxlcnktYXJyb3ctd3JhcHBlciBuZ3gtZ2FsbGVyeS1hcnJvdy1yaWdodFwiPlxuICAgICAgPGRpdiBjbGFzcz1cIm5neC1nYWxsZXJ5LWljb24gbmd4LWdhbGxlcnktYXJyb3dcIlxuICAgICAgICBhcmlhLWhpZGRlbj1cInRydWVcIlxuICAgICAgICAoY2xpY2spPVwiaGFuZGxlTmV4dENsaWNrKClcIlxuICAgICAgICBbY2xhc3Mubmd4LWdhbGxlcnktZGlzYWJsZWRdPVwibmV4dERpc2FibGVkXCI+XG4gICAgICAgIDxpIGNsYXNzPVwibmd4LWdhbGxlcnktaWNvbi1jb250ZW50IHt7YXJyb3dOZXh0SWNvbn19XCI+PC9pPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vbmd4LWdhbGxlcnktYXJyb3dzLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgTmd4R2FsbGVyeUFycm93c0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHByZXZEaXNhYmxlZDogYm9vbGVhbjtcbiAgQElucHV0KCkgbmV4dERpc2FibGVkOiBib29sZWFuO1xuICBASW5wdXQoKSBhcnJvd1ByZXZJY29uOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGFycm93TmV4dEljb246IHN0cmluZztcblxuICBAT3V0cHV0KCkgb25QcmV2Q2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG4gIEBPdXRwdXQoKSBvbk5leHRDbGljayA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBoYW5kbGVQcmV2Q2xpY2soKTogdm9pZCB7XG4gICAgdGhpcy5vblByZXZDbGljay5lbWl0KCk7XG4gIH1cblxuICBoYW5kbGVOZXh0Q2xpY2soKTogdm9pZCB7XG4gICAgdGhpcy5vbk5leHRDbGljay5lbWl0KCk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,38 @@
1
+ import { Component, Input, Output, EventEmitter, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ export class NgxGalleryBulletsComponent {
5
+ constructor() {
6
+ this.active = 0;
7
+ this.onChange = new EventEmitter();
8
+ }
9
+ getBullets() {
10
+ return Array(this.count);
11
+ }
12
+ handleChange(event, index) {
13
+ this.onChange.emit(index);
14
+ }
15
+ }
16
+ NgxGalleryBulletsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryBulletsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
17
+ NgxGalleryBulletsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: NgxGalleryBulletsComponent, selector: "ngx-gallery-bullets", inputs: { count: "count", active: "active" }, outputs: { onChange: "onChange" }, ngImport: i0, template: `
18
+ <div class="ngx-gallery-bullet"
19
+ *ngFor="let bullet of getBullets(); let i = index;" (click)="handleChange($event, i)"
20
+ [ngClass]="{ 'ngx-gallery-active': i === active }">
21
+ </div>
22
+ `, isInline: true, styles: [":host{position:absolute;z-index:2000;display:inline-flex;left:50%;transform:translate(-50%);bottom:0px;padding:10px}.ngx-gallery-bullet{width:10px;height:10px;border-radius:50%;cursor:pointer;background:white}.ngx-gallery-bullet:not(:first-child){margin-left:5px}.ngx-gallery-bullet:hover,.ngx-gallery-bullet.ngx-gallery-active{background:black}\n"], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
23
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryBulletsComponent, decorators: [{
24
+ type: Component,
25
+ args: [{ selector: 'ngx-gallery-bullets', template: `
26
+ <div class="ngx-gallery-bullet"
27
+ *ngFor="let bullet of getBullets(); let i = index;" (click)="handleChange($event, i)"
28
+ [ngClass]="{ 'ngx-gallery-active': i === active }">
29
+ </div>
30
+ `, styles: [":host{position:absolute;z-index:2000;display:inline-flex;left:50%;transform:translate(-50%);bottom:0px;padding:10px}.ngx-gallery-bullet{width:10px;height:10px;border-radius:50%;cursor:pointer;background:white}.ngx-gallery-bullet:not(:first-child){margin-left:5px}.ngx-gallery-bullet:hover,.ngx-gallery-bullet.ngx-gallery-active{background:black}\n"] }]
31
+ }], propDecorators: { count: [{
32
+ type: Input
33
+ }], active: [{
34
+ type: Input
35
+ }], onChange: [{
36
+ type: Output
37
+ }] } });
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWdhbGxlcnktYnVsbGV0cy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZ2FsbGVyeS9zcmMvbGliL25neC1nYWxsZXJ5LWJ1bGxldHMvbmd4LWdhbGxlcnktYnVsbGV0cy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFlBQVksR0FBRyxNQUFNLGVBQWUsQ0FBQzs7O0FBWXhFLE1BQU0sT0FBTywwQkFBMEI7SUFWdkM7UUFZVyxXQUFNLEdBQUcsQ0FBQyxDQUFDO1FBRVYsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7S0FTekM7SUFQQyxVQUFVO1FBQ1IsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRCxZQUFZLENBQUMsS0FBWSxFQUFFLEtBQWE7UUFDdEMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUIsQ0FBQzs7dUhBWlUsMEJBQTBCOzJHQUExQiwwQkFBMEIsNElBUjNCOzs7OztHQUtUOzJGQUdVLDBCQUEwQjtrQkFWdEMsU0FBUzsrQkFDRSxxQkFBcUIsWUFDckI7Ozs7O0dBS1Q7OEJBSVEsS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFFSSxRQUFRO3NCQUFqQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25neC1nYWxsZXJ5LWJ1bGxldHMnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJuZ3gtZ2FsbGVyeS1idWxsZXRcIlxuICAgICAgKm5nRm9yPVwibGV0IGJ1bGxldCBvZiBnZXRCdWxsZXRzKCk7IGxldCBpID0gaW5kZXg7XCIgKGNsaWNrKT1cImhhbmRsZUNoYW5nZSgkZXZlbnQsIGkpXCJcbiAgICAgIFtuZ0NsYXNzXT1cInsgJ25neC1nYWxsZXJ5LWFjdGl2ZSc6IGkgPT09IGFjdGl2ZSB9XCI+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL25neC1nYWxsZXJ5LWJ1bGxldHMuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBOZ3hHYWxsZXJ5QnVsbGV0c0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGNvdW50OiBudW1iZXI7XG4gIEBJbnB1dCgpIGFjdGl2ZSA9IDA7XG5cbiAgQE91dHB1dCgpIG9uQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIGdldEJ1bGxldHMoKTogbnVtYmVyW10ge1xuICAgIHJldHVybiBBcnJheSh0aGlzLmNvdW50KTtcbiAgfVxuXG4gIGhhbmRsZUNoYW5nZShldmVudDogRXZlbnQsIGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2hhbmdlLmVtaXQoaW5kZXgpO1xuICB9XG59XG4iXX0=
@@ -42,13 +42,12 @@ export class NgxGalleryHelperService {
42
42
  this.swipeHandlers.delete(id);
43
43
  }
44
44
  }
45
- NgxGalleryHelperService.ɵprov = i0.ɵɵdefineInjectable({ factory: function NgxGalleryHelperService_Factory() { return new NgxGalleryHelperService(i0.ɵɵinject(i0.Renderer2)); }, token: NgxGalleryHelperService, providedIn: "root" });
46
- NgxGalleryHelperService.decorators = [
47
- { type: Injectable, args: [{
48
- providedIn: 'root'
49
- },] }
50
- ];
51
- NgxGalleryHelperService.ctorParameters = () => [
52
- { type: Renderer2 }
53
- ];
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWdhbGxlcnktaGVscGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZ2FsbGVyeS9zcmMvbGliL25neC1nYWxsZXJ5LWhlbHBlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxVQUFVLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUtsRSxNQUFNLE9BQU8sdUJBQXVCO0lBSWxDLFlBQW9CLFFBQW1CO1FBQW5CLGFBQVEsR0FBUixRQUFRLENBQVc7UUFGL0Isa0JBQWEsR0FBZ0MsSUFBSSxHQUFHLEVBQTBCLENBQUM7SUFFNUMsQ0FBQztJQUU1QyxXQUFXLENBQ1QsTUFBZSxFQUNmLE9BQW1CLEVBQ25CLEVBQVUsRUFDVixXQUF1QixFQUN2QixXQUF1QjtRQUd2QixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxDQUFDLENBQUM7UUFFM0Msc0VBQXNFO1FBQ3RFLElBQUk7WUFDRixJQUFJLE1BQU0sSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDdkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFO29CQUN6QixJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLFdBQVcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxXQUFXLEVBQUUsQ0FBQztvQkFDN0UsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxZQUFZLEVBQUUsR0FBRyxFQUFFLENBQUMsV0FBVyxFQUFFLENBQUM7aUJBQy9FLENBQUMsQ0FBQzthQUNKO2lCQUFNLElBQUksQ0FBQyxNQUFNLElBQUksUUFBUSxFQUFFO2dCQUM5QixRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO2dCQUNyQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsRUFBRSxDQUFDLENBQUM7YUFDOUI7U0FDRjtRQUFDLE9BQU8sQ0FBQyxFQUFFLEdBQUc7SUFDakIsQ0FBQztJQUVELGdCQUFnQixDQUFDLFFBQWdCO1FBQy9CLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixPQUFPO1NBQ1I7UUFDRCxPQUFPLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxHQUFHLEtBQUssQ0FBQztJQUN2RCxDQUFDO0lBRU8sV0FBVyxDQUFDLEdBQVc7UUFDN0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUU7WUFDaEIsT0FBTyxHQUFHLENBQUM7U0FDWjtRQUNELE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLEVBQUUsS0FBSyxDQUFDO2FBQzVDLE9BQU8sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVPLGdCQUFnQixDQUFDLEVBQVU7UUFDakMsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRU8sbUJBQW1CLENBQUMsRUFBVTtRQUNwQyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNoQyxDQUFDOzs7O1lBdERGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBSmdDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbGVtZW50UmVmLCBJbmplY3RhYmxlLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgTmd4R2FsbGVyeUhlbHBlclNlcnZpY2Uge1xuXG4gIHByaXZhdGUgc3dpcGVIYW5kbGVyczogTWFwPHN0cmluZywgKCgpID0+IHZvaWQpW10+ID0gbmV3IE1hcDxzdHJpbmcsICgoKSA9PiB2b2lkKVtdPigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMikgeyB9XG5cbiAgbWFuYWdlU3dpcGUoXG4gICAgc3RhdHVzOiBib29sZWFuLFxuICAgIGVsZW1lbnQ6IEVsZW1lbnRSZWYsXG4gICAgaWQ6IHN0cmluZyxcbiAgICBuZXh0SGFuZGxlcjogKCkgPT4gdm9pZCxcbiAgICBwcmV2SGFuZGxlcjogKCkgPT4gdm9pZFxuICApOiB2b2lkIHtcblxuICAgIGNvbnN0IGhhbmRsZXJzID0gdGhpcy5nZXRTd2lwZUhhbmRsZXJzKGlkKTtcblxuICAgIC8vIHN3aXBlbGVmdCBhbmQgc3dpcGVyaWdodCBhcmUgYXZhaWxhYmxlIG9ubHkgaWYgaGFtbWVyanMgaXMgaW5jbHVkZWRcbiAgICB0cnkge1xuICAgICAgaWYgKHN0YXR1cyAmJiAhaGFuZGxlcnMpIHtcbiAgICAgICAgdGhpcy5zd2lwZUhhbmRsZXJzLnNldChpZCwgW1xuICAgICAgICAgIHRoaXMucmVuZGVyZXIubGlzdGVuKGVsZW1lbnQubmF0aXZlRWxlbWVudCwgJ3N3aXBlbGVmdCcsICgpID0+IG5leHRIYW5kbGVyKCkpLFxuICAgICAgICAgIHRoaXMucmVuZGVyZXIubGlzdGVuKGVsZW1lbnQubmF0aXZlRWxlbWVudCwgJ3N3aXBlcmlnaHQnLCAoKSA9PiBwcmV2SGFuZGxlcigpKVxuICAgICAgICBdKTtcbiAgICAgIH0gZWxzZSBpZiAoIXN0YXR1cyAmJiBoYW5kbGVycykge1xuICAgICAgICBoYW5kbGVycy5tYXAoKGhhbmRsZXIpID0+IGhhbmRsZXIoKSk7XG4gICAgICAgIHRoaXMucmVtb3ZlU3dpcGVIYW5kbGVycyhpZCk7XG4gICAgICB9XG4gICAgfSBjYXRjaCAoZSkgeyB9XG4gIH1cblxuICBnZXRCYWNrZ3JvdW5kVXJsKGltYWdlVXJsOiBzdHJpbmcpIHtcbiAgICBpZiAoIWltYWdlVXJsKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHJldHVybiAndXJsKFxcJycgKyB0aGlzLnZhbGlkYXRlVXJsKGltYWdlVXJsKSArICdcXCcpJztcbiAgfVxuXG4gIHByaXZhdGUgdmFsaWRhdGVVcmwodXJsOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIGlmICghdXJsLnJlcGxhY2UpIHtcbiAgICAgIHJldHVybiB1cmw7XG4gICAgfVxuICAgIHJldHVybiB1cmwucmVwbGFjZShuZXcgUmVnRXhwKCcgJywgJ2cnKSwgJyUyMCcpXG4gICAgICAucmVwbGFjZShuZXcgUmVnRXhwKCdcXCcnLCAnZycpLCAnJTI3Jyk7XG4gIH1cblxuICBwcml2YXRlIGdldFN3aXBlSGFuZGxlcnMoaWQ6IHN0cmluZyk6ICgoKSA9PiB2b2lkKVtdIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy5zd2lwZUhhbmRsZXJzLmdldChpZCk7XG4gIH1cblxuICBwcml2YXRlIHJlbW92ZVN3aXBlSGFuZGxlcnMoaWQ6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuc3dpcGVIYW5kbGVycy5kZWxldGUoaWQpO1xuICB9XG59XG4iXX0=
45
+ NgxGalleryHelperService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryHelperService, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Injectable });
46
+ NgxGalleryHelperService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryHelperService, providedIn: 'root' });
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxGalleryHelperService, decorators: [{
48
+ type: Injectable,
49
+ args: [{
50
+ providedIn: 'root'
51
+ }]
52
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; } });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWdhbGxlcnktaGVscGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZ2FsbGVyeS9zcmMvbGliL25neC1nYWxsZXJ5LWhlbHBlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxVQUFVLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUtsRSxNQUFNLE9BQU8sdUJBQXVCO0lBSWxDLFlBQW9CLFFBQW1CO1FBQW5CLGFBQVEsR0FBUixRQUFRLENBQVc7UUFGL0Isa0JBQWEsR0FBZ0MsSUFBSSxHQUFHLEVBQTBCLENBQUM7SUFFNUMsQ0FBQztJQUU1QyxXQUFXLENBQ1QsTUFBZSxFQUNmLE9BQW1CLEVBQ25CLEVBQVUsRUFDVixXQUF1QixFQUN2QixXQUF1QjtRQUd2QixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxDQUFDLENBQUM7UUFFM0Msc0VBQXNFO1FBQ3RFLElBQUk7WUFDRixJQUFJLE1BQU0sSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDdkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFO29CQUN6QixJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLFdBQVcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxXQUFXLEVBQUUsQ0FBQztvQkFDN0UsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxZQUFZLEVBQUUsR0FBRyxFQUFFLENBQUMsV0FBVyxFQUFFLENBQUM7aUJBQy9FLENBQUMsQ0FBQzthQUNKO2lCQUFNLElBQUksQ0FBQyxNQUFNLElBQUksUUFBUSxFQUFFO2dCQUM5QixRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO2dCQUNyQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsRUFBRSxDQUFDLENBQUM7YUFDOUI7U0FDRjtRQUFDLE9BQU8sQ0FBQyxFQUFFLEdBQUc7SUFDakIsQ0FBQztJQUVELGdCQUFnQixDQUFDLFFBQWdCO1FBQy9CLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixPQUFPO1NBQ1I7UUFDRCxPQUFPLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxHQUFHLEtBQUssQ0FBQztJQUN2RCxDQUFDO0lBRU8sV0FBVyxDQUFDLEdBQVc7UUFDN0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUU7WUFDaEIsT0FBTyxHQUFHLENBQUM7U0FDWjtRQUNELE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLEVBQUUsS0FBSyxDQUFDO2FBQzVDLE9BQU8sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVPLGdCQUFnQixDQUFDLEVBQVU7UUFDakMsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRU8sbUJBQW1CLENBQUMsRUFBVTtRQUNwQyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNoQyxDQUFDOztvSEFuRFUsdUJBQXVCO3dIQUF2Qix1QkFBdUIsY0FGdEIsTUFBTTsyRkFFUCx1QkFBdUI7a0JBSG5DLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudFJlZiwgSW5qZWN0YWJsZSwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIE5neEdhbGxlcnlIZWxwZXJTZXJ2aWNlIHtcblxuICBwcml2YXRlIHN3aXBlSGFuZGxlcnM6IE1hcDxzdHJpbmcsICgoKSA9PiB2b2lkKVtdPiA9IG5ldyBNYXA8c3RyaW5nLCAoKCkgPT4gdm9pZClbXT4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIpIHsgfVxuXG4gIG1hbmFnZVN3aXBlKFxuICAgIHN0YXR1czogYm9vbGVhbixcbiAgICBlbGVtZW50OiBFbGVtZW50UmVmLFxuICAgIGlkOiBzdHJpbmcsXG4gICAgbmV4dEhhbmRsZXI6ICgpID0+IHZvaWQsXG4gICAgcHJldkhhbmRsZXI6ICgpID0+IHZvaWRcbiAgKTogdm9pZCB7XG5cbiAgICBjb25zdCBoYW5kbGVycyA9IHRoaXMuZ2V0U3dpcGVIYW5kbGVycyhpZCk7XG5cbiAgICAvLyBzd2lwZWxlZnQgYW5kIHN3aXBlcmlnaHQgYXJlIGF2YWlsYWJsZSBvbmx5IGlmIGhhbW1lcmpzIGlzIGluY2x1ZGVkXG4gICAgdHJ5IHtcbiAgICAgIGlmIChzdGF0dXMgJiYgIWhhbmRsZXJzKSB7XG4gICAgICAgIHRoaXMuc3dpcGVIYW5kbGVycy5zZXQoaWQsIFtcbiAgICAgICAgICB0aGlzLnJlbmRlcmVyLmxpc3RlbihlbGVtZW50Lm5hdGl2ZUVsZW1lbnQsICdzd2lwZWxlZnQnLCAoKSA9PiBuZXh0SGFuZGxlcigpKSxcbiAgICAgICAgICB0aGlzLnJlbmRlcmVyLmxpc3RlbihlbGVtZW50Lm5hdGl2ZUVsZW1lbnQsICdzd2lwZXJpZ2h0JywgKCkgPT4gcHJldkhhbmRsZXIoKSlcbiAgICAgICAgXSk7XG4gICAgICB9IGVsc2UgaWYgKCFzdGF0dXMgJiYgaGFuZGxlcnMpIHtcbiAgICAgICAgaGFuZGxlcnMubWFwKChoYW5kbGVyKSA9PiBoYW5kbGVyKCkpO1xuICAgICAgICB0aGlzLnJlbW92ZVN3aXBlSGFuZGxlcnMoaWQpO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGUpIHsgfVxuICB9XG5cbiAgZ2V0QmFja2dyb3VuZFVybChpbWFnZVVybDogc3RyaW5nKSB7XG4gICAgaWYgKCFpbWFnZVVybCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICByZXR1cm4gJ3VybChcXCcnICsgdGhpcy52YWxpZGF0ZVVybChpbWFnZVVybCkgKyAnXFwnKSc7XG4gIH1cblxuICBwcml2YXRlIHZhbGlkYXRlVXJsKHVybDogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBpZiAoIXVybC5yZXBsYWNlKSB7XG4gICAgICByZXR1cm4gdXJsO1xuICAgIH1cbiAgICByZXR1cm4gdXJsLnJlcGxhY2UobmV3IFJlZ0V4cCgnICcsICdnJyksICclMjAnKVxuICAgICAgLnJlcGxhY2UobmV3IFJlZ0V4cCgnXFwnJywgJ2cnKSwgJyUyNycpO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXRTd2lwZUhhbmRsZXJzKGlkOiBzdHJpbmcpOiAoKCkgPT4gdm9pZClbXSB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIHRoaXMuc3dpcGVIYW5kbGVycy5nZXQoaWQpO1xuICB9XG5cbiAgcHJpdmF0ZSByZW1vdmVTd2lwZUhhbmRsZXJzKGlkOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLnN3aXBlSGFuZGxlcnMuZGVsZXRlKGlkKTtcbiAgfVxufVxuIl19