@clr/angular
Version:
Angular components for Clarity
175 lines • 16.4 kB
JavaScript
/*
* Copyright (c) 2016-2025 Broadcom. All Rights Reserved.
* The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
* This software is released under MIT license.
* The full license information can be found in LICENSE in the root directory of this project.
*/
import { Component, EventEmitter, Input, Optional, Output, SkipSelf, ViewChild } from '@angular/core';
import { uniqueIdFactory } from '../../utils/id-generator/id-generator.service';
import { ClrLoadingState } from '../../utils/loading/loading';
import { LoadingListener } from '../../utils/loading/loading-listener';
import * as i0 from "@angular/core";
import * as i1 from "@angular/router";
import * as i2 from "../providers/button-in-group.service";
import * as i3 from "@angular/common";
export class ClrButton {
constructor(routerLinkActive, buttonInGroupService) {
this.routerLinkActive = routerLinkActive;
this.buttonInGroupService = buttonInGroupService;
this._click = new EventEmitter(false);
this._inMenu = false;
this._enableService = false;
this._classNames = 'btn';
this._name = null;
this._type = null;
this._disabled = null;
this._id = uniqueIdFactory();
}
get inMenu() {
return this._inMenu;
}
set inMenu(value) {
value = !!value;
if (this._inMenu !== value) {
this._inMenu = value;
// We check if the service flag is enabled
// and if the service exists because the service is optional
if (this._enableService && this.buttonInGroupService) {
this.buttonInGroupService.updateButtonGroup(this);
}
}
}
get classNames() {
return this.routerLinkActive?.isActive ? `${this._classNames} ${this.routerLinkActiveClasses}` : this._classNames;
}
set classNames(value) {
if (typeof value === 'string') {
const classNames = value.split(' ');
if (classNames.indexOf('btn') === -1) {
classNames.push('btn');
}
this._classNames = classNames.join(' ');
}
}
get name() {
return this._name;
}
set name(value) {
if (typeof value === 'string') {
this._name = value;
}
}
get type() {
return this._type;
}
set type(value) {
if (typeof value === 'string') {
this._type = value;
}
}
get id() {
return this._id;
}
set id(value) {
if (typeof value === 'string') {
this._id = value;
}
}
get disabled() {
return this._disabled;
}
set disabled(value) {
if (value !== null && value !== false) {
this._disabled = '';
}
else {
this._disabled = null;
}
}
get role() {
return this.inMenu ? 'menuitem' : null;
}
ngAfterViewInit() {
this._enableService = true;
}
loadingStateChange(state) {
this.loading = state === ClrLoadingState.LOADING;
}
emitClick() {
this._click.emit(true);
}
}
ClrButton.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrButton, deps: [{ token: i1.RouterLinkActive, optional: true }, { token: i2.ButtonInGroupService, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component });
ClrButton.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.2", type: ClrButton, selector: "clr-button", inputs: { routerLinkActiveClasses: ["routerLinkActive", "routerLinkActiveClasses"], inMenu: ["clrInMenu", "inMenu"], classNames: ["class", "classNames"], name: "name", type: "type", id: "id", disabled: "disabled" }, outputs: { _click: "click" }, providers: [{ provide: LoadingListener, useExisting: ClrButton }], viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["buttonProjectedRef"], descendants: true, static: true }], ngImport: i0, template: `
<ng-template #buttonProjectedRef>
<button
[class]="classNames"
(click)="emitClick()"
[attr.type]="type"
[attr.name]="name"
[attr.disabled]="disabled"
[attr.role]="role"
[attr.id]="id"
>
<span class="spinner spinner-inline" *ngIf="loading"></span>
<ng-content></ng-content>
</button>
</ng-template>
`, isInline: true, dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrButton, decorators: [{
type: Component,
args: [{
selector: 'clr-button',
template: `
<ng-template #buttonProjectedRef>
<button
[class]="classNames"
(click)="emitClick()"
[attr.type]="type"
[attr.name]="name"
[attr.disabled]="disabled"
[attr.role]="role"
[attr.id]="id"
>
<span class="spinner spinner-inline" *ngIf="loading"></span>
<ng-content></ng-content>
</button>
</ng-template>
`,
providers: [{ provide: LoadingListener, useExisting: ClrButton }],
}]
}], ctorParameters: function () { return [{ type: i1.RouterLinkActive, decorators: [{
type: Optional
}] }, { type: i2.ButtonInGroupService, decorators: [{
type: SkipSelf
}, {
type: Optional
}] }]; }, propDecorators: { _click: [{
type: Output,
args: ['click']
}], routerLinkActiveClasses: [{
type: Input,
args: ['routerLinkActive']
}], templateRef: [{
type: ViewChild,
args: ['buttonProjectedRef', { static: true }]
}], inMenu: [{
type: Input,
args: ['clrInMenu']
}], classNames: [{
type: Input,
args: ['class']
}], name: [{
type: Input,
args: ['name']
}], type: [{
type: Input,
args: ['type']
}], id: [{
type: Input,
args: ['id']
}], disabled: [{
type: Input,
args: ['disabled']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.js","sourceRoot":"","sources":["../../../../../projects/angular/src/button/button-group/button.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n * The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n * This software is released under MIT license.\n * The full license information can be found in LICENSE in the root directory of this project.\n */\n\nimport { Component, EventEmitter, Input, Optional, Output, SkipSelf, TemplateRef, ViewChild } from '@angular/core';\nimport { RouterLinkActive } from '@angular/router';\n\nimport { uniqueIdFactory } from '../../utils/id-generator/id-generator.service';\nimport { ClrLoadingState } from '../../utils/loading/loading';\nimport { LoadingListener } from '../../utils/loading/loading-listener';\nimport { ButtonInGroupService } from '../providers/button-in-group.service';\n\n@Component({\n  selector: 'clr-button',\n  template: `\n    <ng-template #buttonProjectedRef>\n      <button\n        [class]=\"classNames\"\n        (click)=\"emitClick()\"\n        [attr.type]=\"type\"\n        [attr.name]=\"name\"\n        [attr.disabled]=\"disabled\"\n        [attr.role]=\"role\"\n        [attr.id]=\"id\"\n      >\n        <span class=\"spinner spinner-inline\" *ngIf=\"loading\"></span>\n        <ng-content></ng-content>\n      </button>\n    </ng-template>\n  `,\n  providers: [{ provide: LoadingListener, useExisting: ClrButton }],\n})\nexport class ClrButton implements LoadingListener {\n  @Output('click') _click = new EventEmitter<boolean>(false);\n  @Input('routerLinkActive') routerLinkActiveClasses: string;\n\n  @ViewChild('buttonProjectedRef', { static: true }) templateRef: TemplateRef<ClrButton>;\n\n  loading: boolean;\n\n  private _inMenu = false;\n  private _enableService = false;\n  private _classNames = 'btn';\n  private _name: string = null;\n  private _type: string = null;\n  private _disabled: any = null;\n  private _id: string = uniqueIdFactory();\n\n  constructor(\n    @Optional() private readonly routerLinkActive: RouterLinkActive,\n    @SkipSelf() @Optional() public buttonInGroupService: ButtonInGroupService\n  ) {}\n\n  @Input('clrInMenu')\n  get inMenu(): boolean {\n    return this._inMenu;\n  }\n  set inMenu(value: boolean) {\n    value = !!value;\n    if (this._inMenu !== value) {\n      this._inMenu = value;\n      // We check if the service flag is enabled\n      // and if the service exists because the service is optional\n      if (this._enableService && this.buttonInGroupService) {\n        this.buttonInGroupService.updateButtonGroup(this);\n      }\n    }\n  }\n\n  @Input('class')\n  get classNames(): string {\n    return this.routerLinkActive?.isActive ? `${this._classNames} ${this.routerLinkActiveClasses}` : this._classNames;\n  }\n  set classNames(value: string) {\n    if (typeof value === 'string') {\n      const classNames: string[] = value.split(' ');\n      if (classNames.indexOf('btn') === -1) {\n        classNames.push('btn');\n      }\n      this._classNames = classNames.join(' ');\n    }\n  }\n\n  @Input('name')\n  get name(): string {\n    return this._name;\n  }\n  set name(value: string) {\n    if (typeof value === 'string') {\n      this._name = value;\n    }\n  }\n\n  @Input('type')\n  get type(): string {\n    return this._type;\n  }\n  set type(value: string) {\n    if (typeof value === 'string') {\n      this._type = value;\n    }\n  }\n\n  @Input('id')\n  get id(): string {\n    return this._id;\n  }\n  set id(value: string) {\n    if (typeof value === 'string') {\n      this._id = value;\n    }\n  }\n\n  @Input('disabled')\n  get disabled(): any {\n    return this._disabled;\n  }\n  set disabled(value: any) {\n    if (value !== null && value !== false) {\n      this._disabled = '';\n    } else {\n      this._disabled = null;\n    }\n  }\n\n  get role(): string {\n    return this.inMenu ? 'menuitem' : null;\n  }\n\n  ngAfterViewInit() {\n    this._enableService = true;\n  }\n\n  loadingStateChange(state: ClrLoadingState): void {\n    this.loading = state === ClrLoadingState.LOADING;\n  }\n\n  emitClick(): void {\n    this._click.emit(true);\n  }\n}\n"]}