@kms-ngx-ui/presentational 16.8.4 → 16.9.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.
@@ -0,0 +1,15 @@
1
+ /**
2
+ * General Image Model
3
+ */
4
+ export declare class ImageSnippet {
5
+ src: string;
6
+ fileName: string;
7
+ srcType: ImageSourceType;
8
+ status: string;
9
+ constructor(src: string, fileName: string, srcType?: ImageSourceType);
10
+ }
11
+ export declare enum ImageSourceType {
12
+ Ident = "Idnet",
13
+ ByteArray = "ByteArray",
14
+ URL = "URL"
15
+ }
@@ -1,4 +1,5 @@
1
1
  export * from './iconSize.enum';
2
+ export * from './image-snippet.model';
2
3
  export * from './is-value.function';
3
4
  export * from './types/attached-file-dto.model';
4
5
  export * from './types/nullable.type';
@@ -1,16 +1,24 @@
1
1
  /**
2
2
  * @copyright KMS GmbH
3
3
  */
4
- import { EventEmitter } from '@angular/core';
5
- import { ImageSnippet } from '../../models/image-snippet.model';
4
+ import { CdkDragDrop } from '@angular/cdk/drag-drop';
5
+ import { AfterViewInit, ElementRef, EventEmitter, OnChanges } from '@angular/core';
6
+ import { ImageSnippet } from '../../models/image-snippet';
6
7
  import * as i0 from "@angular/core";
7
- export declare class ImageSliderComponent {
8
- slides: string[] | undefined;
8
+ export declare class ImageSliderComponent implements OnChanges, AfterViewInit {
9
+ private el;
10
+ slides?: string[];
9
11
  editMode: boolean;
10
- imagesTOSave: ImageSnippet[] | undefined;
11
- orderChanged: EventEmitter<ImageSnippet[]>;
12
+ imagesToSave?: ImageSnippet[];
12
13
  deleteImageEvent: EventEmitter<number>;
14
+ orderChanged: EventEmitter<ImageSnippet[]>;
15
+ constructor(el: ElementRef);
16
+ ngAfterViewInit(): void;
17
+ ngOnChanges(): void;
18
+ initializeSwipers(): void;
19
+ private updateSwipers;
13
20
  deleteImage(index: number): void;
21
+ onOrderChanged(event: CdkDragDrop<string[]>): void;
14
22
  static ɵfac: i0.ɵɵFactoryDeclaration<ImageSliderComponent, never>;
15
- static ɵcmp: i0.ɵɵComponentDeclaration<ImageSliderComponent, "kms-image-slider", never, { "slides": { "alias": "slides"; "required": false; }; "editMode": { "alias": "editMode"; "required": false; }; "imagesTOSave": { "alias": "imagesTOSave"; "required": false; }; }, { "orderChanged": "orderChanged"; "deleteImageEvent": "deleteImageEvent"; }, never, ["[description]", "*"], false, never>;
23
+ static ɵcmp: i0.ɵɵComponentDeclaration<ImageSliderComponent, "kms-image-slider", never, { "slides": { "alias": "slides"; "required": false; }; "editMode": { "alias": "editMode"; "required": false; }; "imagesToSave": { "alias": "imagesToSave"; "required": false; }; }, { "deleteImageEvent": "deleteImageEvent"; "orderChanged": "orderChanged"; }, never, never, false, never>;
16
24
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kms-ngx-ui/presentational",
3
- "version": "16.8.4",
3
+ "version": "16.9.0",
4
4
  "peerDependencies": {
5
5
  "@angular/cdk": "16.2.12",
6
6
  "@angular/common": "16.2.12",
package/public-api.d.ts CHANGED
@@ -4,6 +4,7 @@ export * from './lib/kms-ngx-ui-presentational.service';
4
4
  export * from './lib/services/viewport.service';
5
5
  export * from './lib/models/button-response-types.enum';
6
6
  export * from './lib/models/iconSize.enum';
7
+ export * from './lib/models/image-snippet.model';
7
8
  export * from './lib/models/salutation.enum';
8
9
  export * from './lib/models/types/nullable.type';
9
10
  export * from './lib/ui/back-to-top/back-to-top.component';
@@ -1,67 +1,56 @@
1
1
  @mixin image-slider-theme() {
2
- .image-slider {
2
+ .image-slider-container {
3
3
  swiper-container {
4
- width: 768px !important;
5
- height: 100%;
6
- max-width: 100vw;
7
- max-height: 100vh;
8
- margin-left: auto;
9
- margin-right: auto;
10
- }
11
-
12
- swiper-slide {
13
- text-align: center;
14
- font-size: 18px;
15
- background: var(--white);
16
- background-size: cover;
17
- background-position: center;
18
- display: flex;
19
- justify-content: center;
20
- align-items: center;
4
+ max-width: 800px;
21
5
 
22
- img {
23
- display: block;
24
- width: 100%;
25
- height: 100%;
26
- object-fit: cover;
27
- }
6
+ --swiper-navigation-color: #fff;
7
+ --swiper-pagination-color: #fff;
28
8
  }
29
9
 
30
- &__swiper-container {
31
- --swiper-navigation-size: 20px;
32
- --swiper-navigation-color: var(--black);
33
- --swiper-pagination-color: var(--black);
34
-
35
- height: 80%;
36
- width: 100%;
10
+ swiper-container.swiper-main-view-container {
11
+ height: 600px;
12
+ margin: 20px auto;
37
13
  }
38
14
 
39
- &__swiper-preview-container {
40
- height: 20%;
15
+ swiper-container.swiper-carousel-container {
16
+ height: 200px;
17
+ width: 100%;
41
18
  box-sizing: border-box;
42
- padding: 10px 0;
43
19
 
20
+ swiper-slide {
21
+ width: calc(25% - 10px) !important;
22
+ margin-right: 10px;
23
+ opacity: 0.5;
24
+ position: relative;
25
+ .mat-mdc-menu-item {
26
+ position: absolute;
27
+ top: 0;
28
+ &.delete-button {
29
+ background: rgba(255, 255, 255, 0.6);
30
+ width: 44px;
31
+ height: 44px;
32
+ right: 0;
33
+ border-end-start-radius: 30px;
34
+ }
35
+ &.drag-button {
36
+ width: 100%;
37
+ height: 100%;
38
+ left: 0;
39
+ }
40
+ }
41
+ }
44
42
  .swiper-slide-thumb-active {
45
43
  opacity: 1;
46
44
  }
45
+ }
47
46
 
48
- swiper-slide {
49
- width: 25%;
47
+ swiper-slide {
48
+ img {
49
+ display: block;
50
+ width: 100%;
50
51
  height: 100%;
51
- opacity: 0.4;
52
-
53
- img {
54
- border: 1px solid var(--grey08);
55
- border-radius: 8px;
56
- }
52
+ object-fit: cover;
57
53
  }
58
54
  }
59
-
60
- &__delete-button.mat-mdc-menu-item {
61
- position: absolute;
62
- top: 0;
63
- width: fit-content;
64
- right: 0;
65
- }
66
55
  }
67
56
  }