angular-techs-logos 0.1.5 → 0.1.6

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.
@@ -20,12 +20,16 @@ export class AngularTechsLogosComponent {
20
20
  }
21
21
  ngOnChanges(changes) {
22
22
  // Atualize os sinais com os novos valores dos inputs
23
+ console.log('changes: ', changes);
23
24
  if (changes['list']) {
24
25
  this.listSignal.set(this.list);
25
26
  }
26
27
  if (changes['hiddenLogos']) {
27
28
  this.hiddenLogosSignal.set(this.hiddenLogos);
28
29
  }
30
+ if (!this.name) {
31
+ this.updateTechs();
32
+ }
29
33
  }
30
34
  updateTechs() {
31
35
  // Use os sinais para atualizar dinamicamente a lista de techs
@@ -90,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
90
94
  type: ViewChild,
91
95
  args: ['iconContainer', { read: ViewContainerRef }]
92
96
  }] } });
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-techs-logos.component.js","sourceRoot":"","sources":["../../../../projects/angular-techs-logos/src/lib/angular-techs-logos.component.ts","../../../../projects/angular-techs-logos/src/lib/angular-techs-logos.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  ViewChild,\n  ViewContainerRef,\n  Type,\n  ViewEncapsulation,\n  ChangeDetectorRef\n} from '@angular/core';\n\nimport { techs } from './techs/techs-data';\nimport { signal } from '@angular/core'; // Importe signal do Angular Core\n\ninterface Tech {\n  name: string;\n  icon: Type<any>;\n}\n\n@Component({\n  selector: 'angular-techs-logos',\n  templateUrl: './angular-techs-logos.component.html',\n  styleUrls: ['./angular-techs-logos.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class AngularTechsLogosComponent implements OnInit, OnChanges {\n  @Input() list: string[] | undefined;\n  @Input() name: string | undefined;\n  @Input() size: string | undefined;\n  @Input() label: string | undefined;\n  @Input() hiddenLabel: boolean | undefined;\n  @Input() class: string | undefined;\n  @Input() hiddenLogos: string[] | undefined;\n\n  @ViewChild('iconContainer', { read: ViewContainerRef }) iconContainer!: ViewContainerRef;\n\n  techs: Tech[] = techs;\n\n  // Declare sinais reativos para list e hiddenLogos\n  listSignal = signal<string[] | undefined>([]);\n  hiddenLogosSignal = signal<string[] | undefined>([]);\n\n  // Sinal para a lista dinâmica de techs a ser exibida no template\n  techsList = signal<Tech[]>(this.techs);\n\n  constructor(\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    if (!this.name) {\n      this.updateTechs();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Atualize os sinais com os novos valores dos inputs\n    if (changes['list']) {\n      this.listSignal.set(this.list);\n    }\n    if (changes['hiddenLogos']) {\n      this.hiddenLogosSignal.set(this.hiddenLogos);\n    }\n  }\n\n  private updateTechs(): void {\n    // Use os sinais para atualizar dinamicamente a lista de techs\n    const currentList = this.listSignal();\n    const currentHiddenLogos = this.hiddenLogosSignal();\n\n    if (currentList && currentList.length > 0) {\n      this.techsList.set(this.getTechs(currentList));\n    } else if (currentHiddenLogos && currentHiddenLogos.length > 0) {\n      this.techsList.set(this.hiddenTechs(currentHiddenLogos));\n    } else {\n      this.techsList.set(techs); // Volte para o valor inicial se nenhum sinal estiver definido\n    }\n  }\n\n  public techClass(name: string): string[] {\n    const className = name?.toLowerCase() || '';\n    return [this.class || '', className];\n  }\n\n  public getTech(name: string): Tech | undefined {\n    return this.techsList().find(item => item.name.toLowerCase() === name.toLowerCase());\n  }\n\n  private getTechs(items: string[]): Tech[] {\n    return this.techsList().filter(tech => {\n      if (typeof tech.name !== 'string') return false;\n      return items.some(item => {\n        if (typeof item !== 'string') return false;\n        return tech.name.toLowerCase() === item.toLowerCase();\n      });\n    });\n  }\n\n  private hiddenTechs(items: string[]): Tech[] {\n    return this.techsList().filter(tech => !items.includes(tech.name.toLowerCase()));\n  }\n\n  public getIcon(name: string): Type<any> | null {\n    const tech = this.getTech(name);\n    return tech ? tech.icon : null;\n  }\n}\n","<div class=\"techs\" [ngClass]=\"class\">\n  <ng-container *ngIf=\"name && getTech(name) && !list\">\n    <figure\n      class=\"tech-container\"\n      [ngClass]=\"techClass(name)\"\n      [style.width]=\"size ? size : '100px'\"\n    >\n      <ng-container *ngComponentOutlet=\"getIcon(name)\" />\n      <figcaption [ngClass]=\"{ tooltip: hiddenLabel }\">\n        {{ label ? label : getTech(name)?.name }}\n      </figcaption>\n    </figure>\n  </ng-container>\n  <ng-container *ngIf=\"!name && (list || techsList)\">\n    <figure\n      class=\"tech-container\"\n      *ngFor=\"let tech of techsList()\"\n      [ngClass]=\"[tech.name.toLowerCase()]\"\n      [style.width]=\"size ? size : '100px'\"\n      [attr.key]=\"tech.name\"\n    >\n      <ng-container *ngComponentOutlet=\"getIcon(tech.name)\" />\n      <figcaption [ngClass]=\"{ tooltip: hiddenLabel }\">\n        {{ tech.name }}\n      </figcaption>\n    </figure>\n  </ng-container>\n</div>\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-techs-logos.component.js","sourceRoot":"","sources":["../../../../projects/angular-techs-logos/src/lib/angular-techs-logos.component.ts","../../../../projects/angular-techs-logos/src/lib/angular-techs-logos.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  ViewChild,\n  ViewContainerRef,\n  Type,\n  ViewEncapsulation,\n  ChangeDetectorRef\n} from '@angular/core';\n\nimport { techs } from './techs/techs-data';\nimport { signal } from '@angular/core'; // Importe signal do Angular Core\n\ninterface Tech {\n  name: string;\n  icon: Type<any>;\n}\n\n@Component({\n  selector: 'angular-techs-logos',\n  templateUrl: './angular-techs-logos.component.html',\n  styleUrls: ['./angular-techs-logos.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class AngularTechsLogosComponent implements OnInit, OnChanges {\n  @Input() list: string[] | undefined;\n  @Input() name: string | undefined;\n  @Input() size: string | undefined;\n  @Input() label: string | undefined;\n  @Input() hiddenLabel: boolean | undefined;\n  @Input() class: string | undefined;\n  @Input() hiddenLogos: string[] | undefined;\n\n  @ViewChild('iconContainer', { read: ViewContainerRef }) iconContainer!: ViewContainerRef;\n\n  techs: Tech[] = techs;\n\n  // Declare sinais reativos para list e hiddenLogos\n  listSignal = signal<string[] | undefined>([]);\n  hiddenLogosSignal = signal<string[] | undefined>([]);\n\n  // Sinal para a lista dinâmica de techs a ser exibida no template\n  techsList = signal<Tech[]>(this.techs);\n\n  constructor(\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    if (!this.name) {\n      this.updateTechs();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Atualize os sinais com os novos valores dos inputs\n    console.log('changes: ', changes)\n\n    if (changes['list']) {\n      this.listSignal.set(this.list);\n    }\n    if (changes['hiddenLogos']) {\n      this.hiddenLogosSignal.set(this.hiddenLogos);\n    }\n\n    if (!this.name) {\n      this.updateTechs();\n    }\n  }\n\n  private updateTechs(): void {\n    // Use os sinais para atualizar dinamicamente a lista de techs\n    const currentList = this.listSignal();\n    const currentHiddenLogos = this.hiddenLogosSignal();\n\n    if (currentList && currentList.length > 0) {\n      this.techsList.set(this.getTechs(currentList));\n    } else if (currentHiddenLogos && currentHiddenLogos.length > 0) {\n      this.techsList.set(this.hiddenTechs(currentHiddenLogos));\n    } else {\n      this.techsList.set(techs); // Volte para o valor inicial se nenhum sinal estiver definido\n    }\n  }\n\n  public techClass(name: string): string[] {\n    const className = name?.toLowerCase() || '';\n    return [this.class || '', className];\n  }\n\n  public getTech(name: string): Tech | undefined {\n    return this.techsList().find(item => item.name.toLowerCase() === name.toLowerCase());\n  }\n\n  private getTechs(items: string[]): Tech[] {\n    return this.techsList().filter(tech => {\n      if (typeof tech.name !== 'string') return false;\n      return items.some(item => {\n        if (typeof item !== 'string') return false;\n        return tech.name.toLowerCase() === item.toLowerCase();\n      });\n    });\n  }\n\n  private hiddenTechs(items: string[]): Tech[] {\n    return this.techsList().filter(tech => !items.includes(tech.name.toLowerCase()));\n  }\n\n  public getIcon(name: string): Type<any> | null {\n    const tech = this.getTech(name);\n    return tech ? tech.icon : null;\n  }\n}\n","<div class=\"techs\" [ngClass]=\"class\">\n  <ng-container *ngIf=\"name && getTech(name) && !list\">\n    <figure\n      class=\"tech-container\"\n      [ngClass]=\"techClass(name)\"\n      [style.width]=\"size ? size : '100px'\"\n    >\n      <ng-container *ngComponentOutlet=\"getIcon(name)\" />\n      <figcaption [ngClass]=\"{ tooltip: hiddenLabel }\">\n        {{ label ? label : getTech(name)?.name }}\n      </figcaption>\n    </figure>\n  </ng-container>\n  <ng-container *ngIf=\"!name && (list || techsList)\">\n    <figure\n      class=\"tech-container\"\n      *ngFor=\"let tech of techsList()\"\n      [ngClass]=\"[tech.name.toLowerCase()]\"\n      [style.width]=\"size ? size : '100px'\"\n      [attr.key]=\"tech.name\"\n    >\n      <ng-container *ngComponentOutlet=\"getIcon(tech.name)\" />\n      <figcaption [ngClass]=\"{ tooltip: hiddenLabel }\">\n        {{ tech.name }}\n      </figcaption>\n    </figure>\n  </ng-container>\n</div>\n"]}
@@ -1425,12 +1425,16 @@ class AngularTechsLogosComponent {
1425
1425
  }
1426
1426
  ngOnChanges(changes) {
1427
1427
  // Atualize os sinais com os novos valores dos inputs
1428
+ console.log('changes: ', changes);
1428
1429
  if (changes['list']) {
1429
1430
  this.listSignal.set(this.list);
1430
1431
  }
1431
1432
  if (changes['hiddenLogos']) {
1432
1433
  this.hiddenLogosSignal.set(this.hiddenLogos);
1433
1434
  }
1435
+ if (!this.name) {
1436
+ this.updateTechs();
1437
+ }
1434
1438
  }
1435
1439
  updateTechs() {
1436
1440
  // Use os sinais para atualizar dinamicamente a lista de techs