@coreui/angular
Version:
CoreUI Components Library for Angular
96 lines • 15.4 kB
JavaScript
import { booleanAttribute, Component, computed, contentChildren, effect, input } from '@angular/core';
import { NgClass, NgTemplateOutlet } from '@angular/common';
import { TemplateIdDirective } from '../../shared';
import { CardBodyComponent, CardComponent, CardFooterComponent } from '../../card';
import * as i0 from "@angular/core";
export class WidgetStatFComponent extends CardComponent {
constructor() {
super(...arguments);
/**
* Sets the color context of the component to one of CoreUI’s themed colors.
* @type Colors
*/
// override readonly color = input<Colors>();
/**
* Sets the text-color context of the component to one of CoreUI’s themed colors.
* @type Colors
*/
// override readonly textColor = input<TextColors | 'white' | 'muted'>();
/**
* Footer for your widget
* @type string
*/
this.footer = input();
/**
* Icon for your widget
* @type string
*/
this.icon = input();
/**
* Set padding of your component.
* @type boolean
*/
this.padding = input(false, { transform: booleanAttribute });
/**
* Title of the widget to display
* @type string
*/
this.title = input();
/**
* Value for your widget to display
* @type string
*/
this.value = input();
this.templates = {};
this.contentTemplates = contentChildren(TemplateIdDirective, { descendants: true });
this.contentTemplatesEffect = effect(() => {
this.contentTemplates().forEach((child) => {
this.templates[child.id] = child.templateRef;
});
});
this.cardBodyClasses = computed(() => {
return {
'd-flex': true,
'align-items-center': true,
'p-0': !this.padding()
};
});
this.iconClasses = computed(() => {
const color = this.color();
const padding = this.padding();
return {
'me-3': !this.textColor(),
'text-white': true,
[`bg-${color}`]: !!color,
'p-3': padding,
'p-4': !padding,
'rounded-start-1': !padding
};
});
this.titleClasses = computed(() => {
const textColor = this.textColor();
return {
'text-body-secondary': !textColor,
small: true,
'text-uppercase': true,
'fw-semibold': true,
[`text-${textColor}`]: !!textColor
};
});
this.valueClasses = computed(() => {
const textColor = this.textColor();
return {
'fs-6': !textColor,
'fw-semibold': true,
[`text-${textColor}`]: !!textColor
};
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: WidgetStatFComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: WidgetStatFComponent, isStandalone: true, selector: "c-widget-stat-f", inputs: { footer: { classPropertyName: "footer", publicName: "footer", isSignal: true, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, padding: { classPropertyName: "padding", publicName: "padding", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "hostClasses()" }, classAttribute: "card" }, queries: [{ propertyName: "contentTemplates", predicate: TemplateIdDirective, descendants: true, isSignal: true }], exportAs: ["cWidgetStatB"], usesInheritance: true, ngImport: i0, template: "<ng-container>\n <c-card-body [ngClass]=\"cardBodyClasses()\">\n <div [ngClass]=\"iconClasses()\">\n <ng-container *ngTemplateOutlet=\"templates?.['widgetIconTemplate'] || defaultWidgetIconTemplate\" />\n </div>\n <div>\n <div [ngClass]=\"valueClasses()\">{{ value() }}</div>\n <div [ngClass]=\"titleClasses()\">{{ title() }}</div>\n </div>\n </c-card-body>\n @if (footer() || templates?.['widgetFooterTemplate']) {\n <c-card-footer>\n <ng-container *ngTemplateOutlet=\"templates?.['widgetFooterTemplate'] || defaultFooterIconTemplate\" />\n </c-card-footer>\n }\n</ng-container>\n\n<ng-template #defaultWidgetIconTemplate>\n <span>{{ icon() }}</span>\n</ng-template>\n\n<ng-template #defaultFooterIconTemplate>\n <span>{{ footer() }}</span>\n</ng-template>\n", dependencies: [{ kind: "component", type: CardBodyComponent, selector: "c-card-body, [c-card-body]" }, { kind: "component", type: CardFooterComponent, selector: "c-card-footer, [c-card-footer]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: WidgetStatFComponent, decorators: [{
type: Component,
args: [{ selector: 'c-widget-stat-f', exportAs: 'cWidgetStatB', standalone: true, imports: [CardBodyComponent, CardFooterComponent, NgClass, NgTemplateOutlet], host: { class: 'card', '[class]': 'hostClasses()' }, template: "<ng-container>\n <c-card-body [ngClass]=\"cardBodyClasses()\">\n <div [ngClass]=\"iconClasses()\">\n <ng-container *ngTemplateOutlet=\"templates?.['widgetIconTemplate'] || defaultWidgetIconTemplate\" />\n </div>\n <div>\n <div [ngClass]=\"valueClasses()\">{{ value() }}</div>\n <div [ngClass]=\"titleClasses()\">{{ title() }}</div>\n </div>\n </c-card-body>\n @if (footer() || templates?.['widgetFooterTemplate']) {\n <c-card-footer>\n <ng-container *ngTemplateOutlet=\"templates?.['widgetFooterTemplate'] || defaultFooterIconTemplate\" />\n </c-card-footer>\n }\n</ng-container>\n\n<ng-template #defaultWidgetIconTemplate>\n <span>{{ icon() }}</span>\n</ng-template>\n\n<ng-template #defaultFooterIconTemplate>\n <span>{{ footer() }}</span>\n</ng-template>\n" }]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-stat-f.component.js","sourceRoot":"","sources":["../../../../../../projects/coreui-angular/src/lib/widget/widget-stat-f/widget-stat-f.component.ts","../../../../../../projects/coreui-angular/src/lib/widget/widget-stat-f/widget-stat-f.component.html"],"names":[],"mappings":"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","sourcesContent":["import { booleanAttribute, Component, computed, contentChildren, effect, input, TemplateRef } from '@angular/core';\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\n\nimport { Colors } from '../../coreui.types';\nimport { TemplateIdDirective } from '../../shared';\nimport { CardBodyComponent, CardComponent, CardFooterComponent } from '../../card';\n\n@Component({\n  selector: 'c-widget-stat-f',\n  templateUrl: './widget-stat-f.component.html',\n  exportAs: 'cWidgetStatB',\n  standalone: true,\n  imports: [CardBodyComponent, CardFooterComponent, NgClass, NgTemplateOutlet],\n  host: { class: 'card', '[class]': 'hostClasses()' }\n})\nexport class WidgetStatFComponent extends CardComponent {\n  /**\n   * Sets the color context of the component to one of CoreUI’s themed colors.\n   * @type Colors\n   */\n  // override readonly color = input<Colors>();\n\n  /**\n   * Sets the text-color context of the component to one of CoreUI’s themed colors.\n   * @type Colors\n   */\n  // override readonly textColor = input<TextColors | 'white' | 'muted'>();\n\n  /**\n   * Footer for your widget\n   * @type string\n   */\n  readonly footer = input<string>();\n\n  /**\n   * Icon for your widget\n   * @type string\n   */\n  readonly icon = input<string>();\n\n  /**\n   * Set padding of your component.\n   * @type boolean\n   */\n  readonly padding = input(false, { transform: booleanAttribute });\n\n  /**\n   * Title of the widget to display\n   * @type string\n   */\n  readonly title = input<string>();\n\n  /**\n   * Value for your widget to display\n   * @type string\n   */\n  readonly value = input<string | number>();\n\n  templates: Record<string, TemplateRef<any>> = {};\n  readonly contentTemplates = contentChildren(TemplateIdDirective, { descendants: true });\n\n  readonly contentTemplatesEffect = effect(() => {\n    this.contentTemplates().forEach((child: TemplateIdDirective) => {\n      this.templates[child.id] = child.templateRef;\n    });\n  });\n\n  readonly cardBodyClasses = computed(() => {\n    return {\n      'd-flex': true,\n      'align-items-center': true,\n      'p-0': !this.padding()\n    } as Record<string, boolean>;\n  });\n\n  readonly iconClasses = computed(() => {\n    const color = this.color();\n    const padding = this.padding();\n\n    return {\n      'me-3': !this.textColor(),\n      'text-white': true,\n      [`bg-${color}`]: !!color,\n      'p-3': padding,\n      'p-4': !padding,\n      'rounded-start-1': !padding\n    } as Record<string, boolean>;\n  });\n\n  readonly titleClasses = computed(() => {\n    const textColor = this.textColor();\n    return {\n      'text-body-secondary': !textColor,\n      small: true,\n      'text-uppercase': true,\n      'fw-semibold': true,\n      [`text-${textColor}`]: !!textColor\n    } as Record<string, boolean>;\n  });\n\n  readonly valueClasses = computed(() => {\n    const textColor = this.textColor();\n    return {\n      'fs-6': !textColor,\n      'fw-semibold': true,\n      [`text-${textColor}`]: !!textColor\n    } as Record<string, boolean>;\n  });\n}\n","<ng-container>\n  <c-card-body [ngClass]=\"cardBodyClasses()\">\n    <div [ngClass]=\"iconClasses()\">\n      <ng-container *ngTemplateOutlet=\"templates?.['widgetIconTemplate'] || defaultWidgetIconTemplate\" />\n    </div>\n    <div>\n      <div [ngClass]=\"valueClasses()\">{{ value() }}</div>\n      <div [ngClass]=\"titleClasses()\">{{ title() }}</div>\n    </div>\n  </c-card-body>\n  @if (footer() || templates?.['widgetFooterTemplate']) {\n    <c-card-footer>\n      <ng-container *ngTemplateOutlet=\"templates?.['widgetFooterTemplate'] || defaultFooterIconTemplate\" />\n    </c-card-footer>\n  }\n</ng-container>\n\n<ng-template #defaultWidgetIconTemplate>\n  <span>{{ icon() }}</span>\n</ng-template>\n\n<ng-template #defaultFooterIconTemplate>\n  <span>{{ footer() }}</span>\n</ng-template>\n"]}