angular-techs-logos 0.1.3 → 0.1.4
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.
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
import { Component, Input, ViewChild, ViewContainerRef, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { techs } from './techs/techs-data';
|
|
3
|
+
import { signal } from '@angular/core'; // Importe signal do Angular Core
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/common";
|
|
5
6
|
export class AngularTechsLogosComponent {
|
|
6
7
|
constructor(cdr) {
|
|
7
8
|
this.cdr = cdr;
|
|
8
9
|
this.techs = techs;
|
|
10
|
+
// Declare sinais reativos para list e hiddenLogos
|
|
11
|
+
this.listSignal = signal([]);
|
|
12
|
+
this.hiddenLogosSignal = signal([]);
|
|
9
13
|
}
|
|
10
14
|
ngOnInit() {
|
|
11
15
|
if (!this.name) {
|
|
@@ -13,19 +17,26 @@ export class AngularTechsLogosComponent {
|
|
|
13
17
|
}
|
|
14
18
|
}
|
|
15
19
|
ngOnChanges(changes) {
|
|
16
|
-
|
|
17
|
-
|
|
20
|
+
// Atualize os sinais com os novos valores dos inputs
|
|
21
|
+
if (changes['list']) {
|
|
22
|
+
this.listSignal.set(this.list);
|
|
23
|
+
}
|
|
24
|
+
if (changes['hiddenLogos']) {
|
|
25
|
+
this.hiddenLogosSignal.set(this.hiddenLogos);
|
|
18
26
|
}
|
|
19
27
|
}
|
|
20
28
|
updateTechs() {
|
|
21
|
-
|
|
22
|
-
|
|
29
|
+
// Use os sinais para atualizar dinamicamente a lista de techs
|
|
30
|
+
const currentList = this.listSignal();
|
|
31
|
+
const currentHiddenLogos = this.hiddenLogosSignal();
|
|
32
|
+
if (currentList && currentList.length > 0) {
|
|
33
|
+
this.techs = this.getTechs(currentList);
|
|
23
34
|
}
|
|
24
|
-
else if (
|
|
25
|
-
this.techs = this.hiddenTechs(
|
|
35
|
+
else if (currentHiddenLogos && currentHiddenLogos.length > 0) {
|
|
36
|
+
this.techs = this.hiddenTechs(currentHiddenLogos);
|
|
26
37
|
}
|
|
27
38
|
else {
|
|
28
|
-
this.techs =
|
|
39
|
+
this.techs = techs; // Volte para o valor inicial se nenhum sinal estiver definido
|
|
29
40
|
}
|
|
30
41
|
}
|
|
31
42
|
techClass(name) {
|
|
@@ -77,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
|
|
|
77
88
|
type: ViewChild,
|
|
78
89
|
args: ['iconContainer', { read: ViewContainerRef }]
|
|
79
90
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# 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  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.techs = this.getTechs(currentList);\n    } else if (currentHiddenLogos && currentHiddenLogos.length > 0) {\n      this.techs = this.hiddenTechs(currentHiddenLogos);\n    } else {\n      this.techs = 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.techs.find(item => item.name.toLowerCase() === name.toLowerCase());\n  }\n\n  private getTechs(items: string[]): Tech[] {\n    return this.techs.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.techs.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 || techs)\">\n    <figure\n      class=\"tech-container\"\n      *ngFor=\"let tech of techs\"\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"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Injectable, Component, ViewContainerRef, ViewEncapsulation, Input, ViewChild, NgModule } from '@angular/core';
|
|
2
|
+
import { Injectable, Component, signal, ViewContainerRef, ViewEncapsulation, Input, ViewChild, NgModule } from '@angular/core';
|
|
3
3
|
import * as i1 from '@angular/common';
|
|
4
4
|
import { CommonModule } from '@angular/common';
|
|
5
5
|
|
|
@@ -1412,6 +1412,9 @@ class AngularTechsLogosComponent {
|
|
|
1412
1412
|
constructor(cdr) {
|
|
1413
1413
|
this.cdr = cdr;
|
|
1414
1414
|
this.techs = techs;
|
|
1415
|
+
// Declare sinais reativos para list e hiddenLogos
|
|
1416
|
+
this.listSignal = signal([]);
|
|
1417
|
+
this.hiddenLogosSignal = signal([]);
|
|
1415
1418
|
}
|
|
1416
1419
|
ngOnInit() {
|
|
1417
1420
|
if (!this.name) {
|
|
@@ -1419,19 +1422,26 @@ class AngularTechsLogosComponent {
|
|
|
1419
1422
|
}
|
|
1420
1423
|
}
|
|
1421
1424
|
ngOnChanges(changes) {
|
|
1422
|
-
|
|
1423
|
-
|
|
1425
|
+
// Atualize os sinais com os novos valores dos inputs
|
|
1426
|
+
if (changes['list']) {
|
|
1427
|
+
this.listSignal.set(this.list);
|
|
1428
|
+
}
|
|
1429
|
+
if (changes['hiddenLogos']) {
|
|
1430
|
+
this.hiddenLogosSignal.set(this.hiddenLogos);
|
|
1424
1431
|
}
|
|
1425
1432
|
}
|
|
1426
1433
|
updateTechs() {
|
|
1427
|
-
|
|
1428
|
-
|
|
1434
|
+
// Use os sinais para atualizar dinamicamente a lista de techs
|
|
1435
|
+
const currentList = this.listSignal();
|
|
1436
|
+
const currentHiddenLogos = this.hiddenLogosSignal();
|
|
1437
|
+
if (currentList && currentList.length > 0) {
|
|
1438
|
+
this.techs = this.getTechs(currentList);
|
|
1429
1439
|
}
|
|
1430
|
-
else if (
|
|
1431
|
-
this.techs = this.hiddenTechs(
|
|
1440
|
+
else if (currentHiddenLogos && currentHiddenLogos.length > 0) {
|
|
1441
|
+
this.techs = this.hiddenTechs(currentHiddenLogos);
|
|
1432
1442
|
}
|
|
1433
1443
|
else {
|
|
1434
|
-
this.techs =
|
|
1444
|
+
this.techs = techs; // Volte para o valor inicial se nenhum sinal estiver definido
|
|
1435
1445
|
}
|
|
1436
1446
|
}
|
|
1437
1447
|
techClass(name) {
|