UNPKG

design-angular-kit

Version:

Un toolkit Angular conforme alle linee guida di design per i servizi web della PA

90 lines 16.3 kB
import { ChangeDetectionStrategy, Component, Input } from '@angular/core'; import { ItAbstractComponent } from '../../../../abstracts/abstract.component'; import { ItIconComponent } from '../../../utils/icon/icon.component'; import { DatePipe, NgClass } from '@angular/common'; import { TranslateModule } from '@ngx-translate/core'; import { inputToBoolean } from '../../../../utils/coercion'; import * as i0 from "@angular/core"; import * as i1 from "@ngx-translate/core"; /** * Timeline Item * @description Represents a single event for Timeline component. */ export class ItTimelineItemComponent extends ItAbstractComponent { constructor() { super(...arguments); /** * Timeline element reference date format * @default dd/MM/yyyy */ this.dateFormat = 'dd/MM/yyyy'; /** * Timeline element PIN type * @default none */ this.pinType = 'default'; /** * Timeline element PIN icon * @default code-circle */ this.pinIcon = 'code-circle'; /** * Timeline element category label */ this.categoryLabel = 'Categoria evento: '; /** * Timeline element date label */ this.dateLabel = 'Data evento: '; /** * Timeline element show detail link * @default false */ this.showReadMore = false; /** Timeline element detail link * @default # */ this.readMoreLink = '#'; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItTimelineItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItTimelineItemComponent, isStandalone: true, selector: "it-timeline-item", inputs: { title: "title", text: "text", signature: "signature", eventDate: "eventDate", dateFormat: "dateFormat", pinText: "pinText", pinType: "pinType", pinIcon: "pinIcon", pinIconTitle: "pinIconTitle", categoryLabel: "categoryLabel", dateLabel: "dateLabel", categoryTitle: "categoryTitle", categoryLink: "categoryLink", showReadMore: ["showReadMore", "showReadMore", inputToBoolean], readMoreLink: "readMoreLink" }, usesInheritance: true, ngImport: i0, template: "<div class=\"timeline-element\">\n @if (pinType === 'now') {\n <span class=\"it-now-label d-none d-lg-flex\">{{ 'it.timeline.today' | translate }}</span>\n }\n <h3 class=\"it-pin-wrapper\" [ngClass]=\"{ 'it-evidence': pinType === 'evidence', 'it-now': pinType === 'now' }\">\n <div class=\"pin-icon\">\n @if (pinIcon) {\n <it-icon [name]=\"pinIcon\" [title]=\"pinIconTitle\" [attr.role]=\"pinIconTitle ? 'img' : null\"></it-icon>\n } @else {\n <it-icon name=\"code-circle\"></it-icon>\n }\n </div>\n <div class=\"pin-text\">\n <span>{{ pinText }}</span>\n </div>\n </h3>\n <div class=\"card-wrapper\">\n <div class=\"card\">\n <div class=\"card-body\">\n @if ((categoryTitle && categoryLink) || eventDate) {\n <div class=\"category-top\">\n @if (categoryTitle) {\n <span class=\"visually-hidden\">{{ categoryLabel }}</span>\n <a class=\"category\" [href]=\"categoryLink\">{{ categoryTitle }}</a>\n }\n @if (eventDate) {\n <span class=\"visually-hidden\">{{ dateLabel }}</span>\n <span class=\"data\">{{ eventDate | date: dateFormat }}</span>\n }\n </div>\n }\n <h4 class=\"card-title\">{{ title }}</h4>\n <p class=\"card-text\">{{ text }}</p>\n @if (signature) {\n <span class=\"card-signature\">{{ signature }}</span>\n }\n @if (showReadMore) {\n <a class=\"read-more\" [href]=\"readMoreLink\">\n <span class=\"text\">{{ 'it.timeline.read-more' | translate }}</span>\n <span class=\"visually-hidden\">{{ 'it.timeline.read-more-on' | translate: { title: title } }}</span>\n <it-icon name=\"arrow-right\"></it-icon>\n </a>\n }\n </div>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: ItIconComponent, selector: "it-icon", inputs: ["name", "size", "color", "padded", "svgClass", "title", "labelWaria"] }, { kind: "pipe", type: DatePipe, name: "date" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItTimelineItemComponent, decorators: [{ type: Component, args: [{ standalone: true, selector: 'it-timeline-item', changeDetection: ChangeDetectionStrategy.OnPush, imports: [ItIconComponent, DatePipe, TranslateModule, NgClass], template: "<div class=\"timeline-element\">\n @if (pinType === 'now') {\n <span class=\"it-now-label d-none d-lg-flex\">{{ 'it.timeline.today' | translate }}</span>\n }\n <h3 class=\"it-pin-wrapper\" [ngClass]=\"{ 'it-evidence': pinType === 'evidence', 'it-now': pinType === 'now' }\">\n <div class=\"pin-icon\">\n @if (pinIcon) {\n <it-icon [name]=\"pinIcon\" [title]=\"pinIconTitle\" [attr.role]=\"pinIconTitle ? 'img' : null\"></it-icon>\n } @else {\n <it-icon name=\"code-circle\"></it-icon>\n }\n </div>\n <div class=\"pin-text\">\n <span>{{ pinText }}</span>\n </div>\n </h3>\n <div class=\"card-wrapper\">\n <div class=\"card\">\n <div class=\"card-body\">\n @if ((categoryTitle && categoryLink) || eventDate) {\n <div class=\"category-top\">\n @if (categoryTitle) {\n <span class=\"visually-hidden\">{{ categoryLabel }}</span>\n <a class=\"category\" [href]=\"categoryLink\">{{ categoryTitle }}</a>\n }\n @if (eventDate) {\n <span class=\"visually-hidden\">{{ dateLabel }}</span>\n <span class=\"data\">{{ eventDate | date: dateFormat }}</span>\n }\n </div>\n }\n <h4 class=\"card-title\">{{ title }}</h4>\n <p class=\"card-text\">{{ text }}</p>\n @if (signature) {\n <span class=\"card-signature\">{{ signature }}</span>\n }\n @if (showReadMore) {\n <a class=\"read-more\" [href]=\"readMoreLink\">\n <span class=\"text\">{{ 'it.timeline.read-more' | translate }}</span>\n <span class=\"visually-hidden\">{{ 'it.timeline.read-more-on' | translate: { title: title } }}</span>\n <it-icon name=\"arrow-right\"></it-icon>\n </a>\n }\n </div>\n </div>\n </div>\n</div>\n" }] }], propDecorators: { title: [{ type: Input, args: [{ required: true }] }], text: [{ type: Input, args: [{ required: true }] }], signature: [{ type: Input }], eventDate: [{ type: Input }], dateFormat: [{ type: Input }], pinText: [{ type: Input, args: [{ required: true }] }], pinType: [{ type: Input }], pinIcon: [{ type: Input }], pinIconTitle: [{ type: Input }], categoryLabel: [{ type: Input }], dateLabel: [{ type: Input }], categoryTitle: [{ type: Input }], categoryLink: [{ type: Input }], showReadMore: [{ type: Input, args: [{ transform: inputToBoolean }] }], readMoreLink: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timeline-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-angular-kit/src/lib/components/core/timeline/timeline-item/timeline-item.component.ts","../../../../../../../../projects/design-angular-kit/src/lib/components/core/timeline/timeline-item/timeline-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,mBAAmB,EAAE,MAAM,0CAA0C,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAGtD,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;;;AAE5D;;;GAGG;AAQH,MAAM,OAAO,uBAAwB,SAAQ,mBAAmB;IAPhE;;QA4BE;;;WAGG;QACM,eAAU,GAAW,YAAY,CAAC;QAO3C;;;WAGG;QACM,YAAO,GAAgC,SAAS,CAAC;QAE1D;;;WAGG;QACM,YAAO,GAAyB,aAAa,CAAC;QAQvD;;WAEG;QACM,kBAAa,GAAuB,oBAAoB,CAAC;QAElE;;WAEG;QACM,cAAS,GAAuB,eAAe,CAAC;QAYzD;;;WAGG;QAEH,iBAAY,GAAY,KAAK,CAAC;QAE9B;;WAEG;QACM,iBAAY,GAAuB,GAAG,CAAC;KACjD;8GAjFY,uBAAuB;kGAAvB,uBAAuB,qaA0Ed,cAAc,kFC9FpC,y0DA+CA,4CD7BY,eAAe,+HAAE,QAAQ,4CAAE,eAAe,4FAAE,OAAO;;2FAElD,uBAAuB;kBAPnC,SAAS;iCACI,IAAI,YACN,kBAAkB,mBAEX,uBAAuB,CAAC,MAAM,WACtC,CAAC,eAAe,EAAE,QAAQ,EAAE,eAAe,EAAE,OAAO,CAAC;8BAMnC,KAAK;sBAA/B,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAKE,IAAI;sBAA9B,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAKhB,SAAS;sBAAjB,KAAK;gBAKG,SAAS;sBAAjB,KAAK;gBAMG,UAAU;sBAAlB,KAAK;gBAKqB,OAAO;sBAAjC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAMhB,OAAO;sBAAf,KAAK;gBAMG,OAAO;sBAAf,KAAK;gBAMG,YAAY;sBAApB,KAAK;gBAKG,aAAa;sBAArB,KAAK;gBAKG,SAAS;sBAAjB,KAAK;gBAKG,aAAa;sBAArB,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAON,YAAY;sBADX,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAM3B,YAAY;sBAApB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport { ItAbstractComponent } from '../../../../abstracts/abstract.component';\nimport { ItIconComponent } from '../../../utils/icon/icon.component';\nimport { DatePipe, NgClass } from '@angular/common';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { TimelinePINType } from '../../../../interfaces/core';\nimport { IconName } from '../../../../interfaces/icon';\nimport { inputToBoolean } from '../../../../utils/coercion';\n\n/**\n * Timeline Item\n * @description Represents a single event for Timeline component.\n */\n@Component({\n  standalone: true,\n  selector: 'it-timeline-item',\n  templateUrl: './timeline-item.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [ItIconComponent, DatePipe, TranslateModule, NgClass],\n})\nexport class ItTimelineItemComponent extends ItAbstractComponent {\n  /**\n   * Timeline element title\n   */\n  @Input({ required: true }) title!: string;\n\n  /**\n   * Timeline element text\n   */\n  @Input({ required: true }) text!: string;\n\n  /**\n   * Timeline element signature\n   */\n  @Input() signature: string | undefined;\n\n  /**\n   * Timeline element reference date\n   */\n  @Input() eventDate: Date | undefined;\n\n  /**\n   * Timeline element reference date format\n   * @default dd/MM/yyyy\n   */\n  @Input() dateFormat: string = 'dd/MM/yyyy';\n\n  /**\n   * Timeline element PIN text\n   */\n  @Input({ required: true }) pinText: string | undefined;\n\n  /**\n   * Timeline element PIN type\n   * @default none\n   */\n  @Input() pinType: TimelinePINType | undefined = 'default';\n\n  /**\n   * Timeline element PIN icon\n   * @default code-circle\n   */\n  @Input() pinIcon: IconName | undefined = 'code-circle';\n\n  /**\n   * Timeline element PIN icon\n   * @default code-circle\n   */\n  @Input() pinIconTitle: string | undefined;\n\n  /**\n   * Timeline element category label\n   */\n  @Input() categoryLabel: string | undefined = 'Categoria evento: ';\n\n  /**\n   * Timeline element date label\n   */\n  @Input() dateLabel: string | undefined = 'Data evento: ';\n\n  /**\n   * Timeline element category title\n   */\n  @Input() categoryTitle: string | undefined;\n\n  /**\n   * Timeline element category link\n   */\n  @Input() categoryLink: string | undefined;\n\n  /**\n   * Timeline element show detail link\n   * @default false\n   */\n  @Input({ transform: inputToBoolean })\n  showReadMore: boolean = false;\n\n  /** Timeline element detail link\n   * @default #\n   */\n  @Input() readMoreLink: string | undefined = '#';\n}\n","<div class=\"timeline-element\">\n  @if (pinType === 'now') {\n    <span class=\"it-now-label d-none d-lg-flex\">{{ 'it.timeline.today' | translate }}</span>\n  }\n  <h3 class=\"it-pin-wrapper\" [ngClass]=\"{ 'it-evidence': pinType === 'evidence', 'it-now': pinType === 'now' }\">\n    <div class=\"pin-icon\">\n      @if (pinIcon) {\n        <it-icon [name]=\"pinIcon\" [title]=\"pinIconTitle\" [attr.role]=\"pinIconTitle ? 'img' : null\"></it-icon>\n      } @else {\n        <it-icon name=\"code-circle\"></it-icon>\n      }\n    </div>\n    <div class=\"pin-text\">\n      <span>{{ pinText }}</span>\n    </div>\n  </h3>\n  <div class=\"card-wrapper\">\n    <div class=\"card\">\n      <div class=\"card-body\">\n        @if ((categoryTitle && categoryLink) || eventDate) {\n          <div class=\"category-top\">\n            @if (categoryTitle) {\n              <span class=\"visually-hidden\">{{ categoryLabel }}</span>\n              <a class=\"category\" [href]=\"categoryLink\">{{ categoryTitle }}</a>\n            }\n            @if (eventDate) {\n              <span class=\"visually-hidden\">{{ dateLabel }}</span>\n              <span class=\"data\">{{ eventDate | date: dateFormat }}</span>\n            }\n          </div>\n        }\n        <h4 class=\"card-title\">{{ title }}</h4>\n        <p class=\"card-text\">{{ text }}</p>\n        @if (signature) {\n          <span class=\"card-signature\">{{ signature }}</span>\n        }\n        @if (showReadMore) {\n          <a class=\"read-more\" [href]=\"readMoreLink\">\n            <span class=\"text\">{{ 'it.timeline.read-more' | translate }}</span>\n            <span class=\"visually-hidden\">{{ 'it.timeline.read-more-on' | translate: { title: title } }}</span>\n            <it-icon name=\"arrow-right\"></it-icon>\n          </a>\n        }\n      </div>\n    </div>\n  </div>\n</div>\n"]}