@sarasanalytics-com/design-system 0.0.96 → 0.0.97

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.
@@ -96,13 +96,21 @@ export class CardCarouselComponent {
96
96
  }
97
97
  }
98
98
  updateVisibleLogos() {
99
- if (this.cards.length > 0) {
100
- this.visibleLogos = this.cards.map((card, index) => ({
101
- ...card,
102
- index,
99
+ if (this.cards.length === 0) {
100
+ this.visibleLogos = [];
101
+ return;
102
+ }
103
+ const maxVisibleCards = Math.min(5, this.cards.length);
104
+ const startOffset = Math.floor(maxVisibleCards / 2) * -1;
105
+ const endOffset = maxVisibleCards + startOffset;
106
+ this.visibleLogos = [];
107
+ for (let i = startOffset; i < endOffset; i++) {
108
+ const index = (this.currentIndex + i + this.cards.length) % this.cards.length;
109
+ this.visibleLogos.push({
110
+ ...this.cards[index],
111
+ index: index,
103
112
  isActive: index === this.currentIndex
104
- }));
105
- this.cdr.markForCheck();
113
+ });
106
114
  }
107
115
  }
108
116
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CardCarouselComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
@@ -124,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
124
132
  }], showBrandFooter: [{
125
133
  type: Input
126
134
  }] } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card-carousel.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/card-carousel/card-carousel.component.ts","../../../../../projects/component-library/src/lib/card-carousel/card-carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, ViewEncapsulation, SimpleChanges, OnChanges, ChangeDetectionStrategy, ChangeDetectorRef, NgZone } from '@angular/core';\nimport { CardComponent } from '../card/card.component';\nimport { IconComponent } from '../icon/icon.component';\nimport { CardCustomHeaderComponent } from '../card/card-custom-header/card-custom-header.component';\nimport { CardCarousel } from '../../interfaces/card-carousel-interface';\nimport { AvatarComponent } from \"../avatar/avatar.component\";\nimport { map as _map, split as _split, words as _words } from 'lodash';\n\n@Component({\n  selector: 'sa-card-carousel',\n  standalone: true,\n  imports: [CardComponent, IconComponent, CardCustomHeaderComponent, AvatarComponent],\n  templateUrl: './card-carousel.component.html',\n  styleUrls: ['./card-carousel.component.css'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CardCarouselComponent implements OnInit, OnDestroy, OnChanges {\n  protected Math = Math;\n\n  @Input() cards: CardCarousel[] = [];\n  @Input() interval: number = 5000;\n  @Input() autoPlay: boolean = true;\n  @Input() showNavigationArrows: boolean = true;\n  @Input() showIndicators: boolean = true;\n  @Input() showBrandFooter: boolean = true;\n\n  visibleLogos: (CardCarousel & { index: number; isActive: boolean })[] = [];\n  currentIndex: number = 0;\n  private timer: any;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private ngZone: NgZone\n  ) {}\n\n  ngOnInit() {\n    this.updateVisibleLogos();\n    if (this.autoPlay && this.cards.length > 0) {\n      this.startTimer();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['cards'] && this.cards?.length > 0) {\n      this.cards = _map(this.cards, (card) => {\n        const nameWords = _words(card.title, /[A-Za-z]+/g);\n        const wordsToUse = nameWords.length > 2 \n          ? [nameWords[0], nameWords[nameWords.length - 1]]\n          : nameWords;\n        const initials = _map(wordsToUse, word => word.charAt(0).toUpperCase()).join('');\n        return { ...card, altText: initials };\n      });\n      \n      if (this.currentIndex >= this.cards.length) {\n        this.currentIndex = 0;\n      }\n      this.updateVisibleLogos();\n      if (this.autoPlay) {\n        this.resetTimer();\n      }\n      this.cdr.markForCheck();\n    }\n  }\n\n  ngOnDestroy() {\n    this.stopTimer();\n  }\n\n  startTimer() {\n    this.stopTimer();\n    this.ngZone.runOutsideAngular(() => {\n      this.timer = setInterval(() => {\n        this.ngZone.run(() => {\n          this.next();\n          this.cdr.markForCheck();\n        });\n      }, this.interval);\n    });\n  }\n\n  stopTimer() {\n    if (this.timer) {\n      clearInterval(this.timer);\n      this.timer = null;\n    }\n  }\n\n  resetTimer() {\n    this.stopTimer();\n    if (this.autoPlay && this.cards.length > 0) {\n      this.startTimer();\n    }\n  }\n\n  selectCard(index: number) {\n    if (index !== this.currentIndex && index >= 0 && index < this.cards.length) {\n      this.currentIndex = index;\n      this.updateVisibleLogos();\n      this.resetTimer();\n      this.cdr.markForCheck();\n    }\n  }\n\n  next() {\n    if (this.cards.length > 0) {\n      this.currentIndex = (this.currentIndex + 1) % this.cards.length;\n      this.updateVisibleLogos();\n      this.resetTimer();\n      this.cdr.markForCheck();\n    }\n  }\n\n  prev() {\n    if (this.cards.length > 0) {\n      this.currentIndex = (this.currentIndex - 1 + this.cards.length) % this.cards.length;\n      this.updateVisibleLogos();\n      this.resetTimer();\n      this.cdr.markForCheck();\n    }\n  }\n\n  private updateVisibleLogos() {\n    if (this.cards.length > 0) {\n      this.visibleLogos = this.cards.map((card, index) => ({\n        ...card,\n        index,\n        isActive: index === this.currentIndex\n      }));\n      this.cdr.markForCheck();\n    }\n  }\n}\n","<!-- card-carousel.component.html -->\n<div class=\"carousel-container\">\n    <div class=\"carousel-top-wrapper\">\n        <div class=\"controls\">\n            @if (showIndicators) {\n            <div class=\"dots\">\n                @for (card of cards; track card.id; let i = $index) {\n                <span class=\"dot\" [class.active]=\"i === currentIndex\" (click)=\"selectCard(i)\"></span>\n                }\n            </div>\n            }\n            @if (showNavigationArrows) {\n            <div class=\"arrow-controls\">\n                <sa-icon [icon]=\"'leftChevronCircle'\" size=\"24\" (click)=\"prev()\"></sa-icon>\n                <sa-icon [icon]=\"'rightChevronCircle'\" size=\"24\" (click)=\"next()\"></sa-icon>\n            </div>\n            }\n        </div>\n\n        <div class=\"card-container\">\n            @if (cards[currentIndex]) {\n            <sa-card [customWrapperClass]=\"'sa-card-custom-wrapper'\" [width]=\"'24.063rem'\" [column]=\"false\"\n                [showCardHeader]=\"true\" [showCardBody]=\"true\" [body]=\"cards[currentIndex]?.body\"\n                [showHeaderBodyDivider]=\"true\">\n                <sa-card-title-header>\n                    <div class=\"sa-card-custom-header-container\">\n                        <sa-avatar [altText]=\"cards[currentIndex]?.altText\" [imagePath]=\"cards[currentIndex]?.avatarIcon\" [size]=\"'extra-large'\"></sa-avatar>\n                        <div class=\"sa-card-title-subtitle-container\">\n                            <div class=\"sa-card-custom-title\">{{ cards[currentIndex]?.title }}</div>\n                            <div class=\"sa-card-subtitle\">{{ cards[currentIndex]?.subtitle }}</div>\n                        </div>\n                        <div class=\"sa-card-titleIcon\">\n                            <sa-icon [icon]=\"cards[currentIndex]?.logoIcon\" [iconUrl]=\"cards[currentIndex]?.logoUrl\" [size]=\"cards[currentIndex]?.logoSize || '50'\" customClass=\"logo-style\"></sa-icon>\n                        </div>\n                    </div>\n                </sa-card-title-header>\n            </sa-card>\n            }\n        </div>\n    </div>\n\n    @if (showBrandFooter) {\n    <div class=\"brand-logos-container\">\n        <div class=\"brand-logos\">\n            @for (logo of visibleLogos; track logo.id) {\n                <div>  \n                    <sa-icon [icon]=\"logo.logoIcon\" [iconUrl]=\"logo.logoUrl\" [size]=\"logo.logoSize || '50'\" [class.active]=\"logo.isActive\" (click)=\"selectCard(logo.index)\"\n                        [customClass]=\"'logo-style'\">\n                    </sa-icon>\n                </div>\n            }\n        </div>\n    </div>\n    }\n</div>"]}
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card-carousel.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/card-carousel/card-carousel.component.ts","../../../../../projects/component-library/src/lib/card-carousel/card-carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, ViewEncapsulation, SimpleChanges, OnChanges, ChangeDetectionStrategy, ChangeDetectorRef, NgZone } from '@angular/core';\nimport { CardComponent } from '../card/card.component';\nimport { IconComponent } from '../icon/icon.component';\nimport { CardCustomHeaderComponent } from '../card/card-custom-header/card-custom-header.component';\nimport { CardCarousel } from '../../interfaces/card-carousel-interface';\nimport { AvatarComponent } from \"../avatar/avatar.component\";\nimport { map as _map, split as _split, words as _words } from 'lodash';\n\n@Component({\n  selector: 'sa-card-carousel',\n  standalone: true,\n  imports: [CardComponent, IconComponent, CardCustomHeaderComponent, AvatarComponent],\n  templateUrl: './card-carousel.component.html',\n  styleUrls: ['./card-carousel.component.css'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CardCarouselComponent implements OnInit, OnDestroy, OnChanges {\n  protected Math = Math;\n\n  @Input() cards: CardCarousel[] = [];\n  @Input() interval: number = 5000;\n  @Input() autoPlay: boolean = true;\n  @Input() showNavigationArrows: boolean = true;\n  @Input() showIndicators: boolean = true;\n  @Input() showBrandFooter: boolean = true;\n\n  visibleLogos: (CardCarousel & { index: number; isActive: boolean })[] = [];\n  currentIndex: number = 0;\n  private timer: any;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private ngZone: NgZone\n  ) {}\n\n  ngOnInit() {\n    this.updateVisibleLogos();\n    if (this.autoPlay && this.cards.length > 0) {\n      this.startTimer();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['cards'] && this.cards?.length > 0) {\n      this.cards = _map(this.cards, (card) => {\n        const nameWords = _words(card.title, /[A-Za-z]+/g);\n        const wordsToUse = nameWords.length > 2 \n          ? [nameWords[0], nameWords[nameWords.length - 1]]\n          : nameWords;\n        const initials = _map(wordsToUse, word => word.charAt(0).toUpperCase()).join('');\n        return { ...card, altText: initials };\n      });\n      \n      if (this.currentIndex >= this.cards.length) {\n        this.currentIndex = 0;\n      }\n      this.updateVisibleLogos();\n      if (this.autoPlay) {\n        this.resetTimer();\n      }\n      this.cdr.markForCheck();\n    }\n  }\n\n  ngOnDestroy() {\n    this.stopTimer();\n  }\n\n  startTimer() {\n    this.stopTimer();\n    this.ngZone.runOutsideAngular(() => {\n      this.timer = setInterval(() => {\n        this.ngZone.run(() => {\n          this.next();\n          this.cdr.markForCheck();\n        });\n      }, this.interval);\n    });\n  }\n\n  stopTimer() {\n    if (this.timer) {\n      clearInterval(this.timer);\n      this.timer = null;\n    }\n  }\n\n  resetTimer() {\n    this.stopTimer();\n    if (this.autoPlay && this.cards.length > 0) {\n      this.startTimer();\n    }\n  }\n\n  selectCard(index: number) {\n    if (index !== this.currentIndex && index >= 0 && index < this.cards.length) {\n      this.currentIndex = index;\n      this.updateVisibleLogos();\n      this.resetTimer();\n      this.cdr.markForCheck();\n    }\n  }\n\n  next() {\n    if (this.cards.length > 0) {\n      this.currentIndex = (this.currentIndex + 1) % this.cards.length;\n      this.updateVisibleLogos();\n      this.resetTimer();\n      this.cdr.markForCheck();\n    }\n  }\n\n  prev() {\n    if (this.cards.length > 0) {\n      this.currentIndex = (this.currentIndex - 1 + this.cards.length) % this.cards.length;\n      this.updateVisibleLogos();\n      this.resetTimer();\n      this.cdr.markForCheck();\n    }\n  }\n\n  updateVisibleLogos() {\n    if (this.cards.length === 0) {\n      this.visibleLogos = [];\n      return;\n    }\n\n    const maxVisibleCards = Math.min(5, this.cards.length);\n    const startOffset = Math.floor(maxVisibleCards / 2) * -1;\n    const endOffset = maxVisibleCards + startOffset;\n    \n    this.visibleLogos = [];\n    for (let i = startOffset; i < endOffset; i++) {\n      const index = (this.currentIndex + i + this.cards.length) % this.cards.length;\n      this.visibleLogos.push({\n        ...this.cards[index],\n        index: index,\n        isActive: index === this.currentIndex\n      });\n    }\n  }\n}\n","<!-- card-carousel.component.html -->\n<div class=\"carousel-container\">\n    <div class=\"carousel-top-wrapper\">\n        <div class=\"controls\">\n            @if (showIndicators) {\n            <div class=\"dots\">\n                @for (card of cards; track card.id; let i = $index) {\n                <span class=\"dot\" [class.active]=\"i === currentIndex\" (click)=\"selectCard(i)\"></span>\n                }\n            </div>\n            }\n            @if (showNavigationArrows) {\n            <div class=\"arrow-controls\">\n                <sa-icon [icon]=\"'leftChevronCircle'\" size=\"24\" (click)=\"prev()\"></sa-icon>\n                <sa-icon [icon]=\"'rightChevronCircle'\" size=\"24\" (click)=\"next()\"></sa-icon>\n            </div>\n            }\n        </div>\n\n        <div class=\"card-container\">\n            @if (cards[currentIndex]) {\n            <sa-card [customWrapperClass]=\"'sa-card-custom-wrapper'\" [width]=\"'24.063rem'\" [column]=\"false\"\n                [showCardHeader]=\"true\" [showCardBody]=\"true\" [body]=\"cards[currentIndex]?.body\"\n                [showHeaderBodyDivider]=\"true\">\n                <sa-card-title-header>\n                    <div class=\"sa-card-custom-header-container\">\n                        <sa-avatar [altText]=\"cards[currentIndex]?.altText\" [imagePath]=\"cards[currentIndex]?.avatarIcon\" [size]=\"'extra-large'\"></sa-avatar>\n                        <div class=\"sa-card-title-subtitle-container\">\n                            <div class=\"sa-card-custom-title\">{{ cards[currentIndex]?.title }}</div>\n                            <div class=\"sa-card-subtitle\">{{ cards[currentIndex]?.subtitle }}</div>\n                        </div>\n                        <div class=\"sa-card-titleIcon\">\n                            <sa-icon [icon]=\"cards[currentIndex]?.logoIcon\" [iconUrl]=\"cards[currentIndex]?.logoUrl\" [size]=\"cards[currentIndex]?.logoSize || '50'\" customClass=\"logo-style\"></sa-icon>\n                        </div>\n                    </div>\n                </sa-card-title-header>\n            </sa-card>\n            }\n        </div>\n    </div>\n\n    @if (showBrandFooter) {\n    <div class=\"brand-logos-container\">\n        <div class=\"brand-logos\">\n            @for (logo of visibleLogos; track logo.id) {\n                <div>  \n                    <sa-icon [icon]=\"logo.logoIcon\" [iconUrl]=\"logo.logoUrl\" [size]=\"logo.logoSize || '50'\" [class.active]=\"logo.isActive\" (click)=\"selectCard(logo.index)\"\n                        [customClass]=\"'logo-style'\">\n                    </sa-icon>\n                </div>\n            }\n        </div>\n    </div>\n    }\n</div>"]}
@@ -1128,13 +1128,21 @@ class CardCarouselComponent {
1128
1128
  }
1129
1129
  }
1130
1130
  updateVisibleLogos() {
1131
- if (this.cards.length > 0) {
1132
- this.visibleLogos = this.cards.map((card, index) => ({
1133
- ...card,
1134
- index,
1131
+ if (this.cards.length === 0) {
1132
+ this.visibleLogos = [];
1133
+ return;
1134
+ }
1135
+ const maxVisibleCards = Math.min(5, this.cards.length);
1136
+ const startOffset = Math.floor(maxVisibleCards / 2) * -1;
1137
+ const endOffset = maxVisibleCards + startOffset;
1138
+ this.visibleLogos = [];
1139
+ for (let i = startOffset; i < endOffset; i++) {
1140
+ const index = (this.currentIndex + i + this.cards.length) % this.cards.length;
1141
+ this.visibleLogos.push({
1142
+ ...this.cards[index],
1143
+ index: index,
1135
1144
  isActive: index === this.currentIndex
1136
- }));
1137
- this.cdr.markForCheck();
1145
+ });
1138
1146
  }
1139
1147
  }
1140
1148
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CardCarouselComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }