UNPKG

carbon-components-angular

Version:
206 lines 16.8 kB
import { Component, EventEmitter, Input, Output, ViewChild } from "@angular/core"; import { BaseIconButton } from "./base-icon-button.component"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "carbon-components-angular/tooltip"; import * as i3 from "./button.directive"; /** * Get started with importing the module: * * ```typescript * import { ButtonModule } from 'carbon-components-angular'; * ``` * * [See demo](../../?path=/story/components-button-icon-button--basic) */ export class IconButton extends BaseIconButton { constructor(renderer) { super(); this.renderer = renderer; /** * Override id */ this.buttonId = `icon-btn-${IconButton.iconButtonCounter++}`; /** * Sets the button type. */ this.kind = "primary"; /** * Specify the size of the button. */ this.size = "lg"; /** * Set button type, `button` by default */ this.type = "button"; /** * Set to `true` to make button expressive */ this.isExpressive = false; /** * Set to `true` to disable button */ this.disabled = false; /** * Common button events */ this.click = new EventEmitter(); this.focus = new EventEmitter(); this.blur = new EventEmitter(); /** * Event to emit when click event is fired from tooltip */ this.tooltipClick = new EventEmitter(); this.classList = {}; this.attributeList = {}; } /** * Pass global carbon classes to icon button */ set buttonNgClass(obj) { this.classList = Object.assign({ "cds--btn--disabled": this.disabled }, obj); } get buttonNgClass() { return this.classList; } /** * @param obj: { [key: string]: string * User can pass additional button attributes if component property does not already exist * Key is the attribute name & value is the attribute value for the button */ set buttonAttributes(obj) { if (this.button) { // Remove old attributes Object.keys(this.attributeList).forEach((key) => { this.renderer.removeAttribute(this.button.nativeElement, key); }); // Set new attributes Object.keys(obj).forEach((key) => { this.renderer.setAttribute(this.button.nativeElement, key, obj[key]); }); } // Set new attributes this.attributeList = obj; } get buttonAttributes() { return this.buttonAttributes; } ngAfterViewInit() { // Set attributes once element is found this.buttonAttributes = this.attributeList; } /** * Stop propogation of click event * Else double fires (click) event */ emitClickEvent(event, element = "button") { event.preventDefault(); event.stopPropagation(); // Prevents (click) event from bubbling since it would appear user clicked the `button` if (element === "tooltip") { this.tooltipClick.emit(event); return; } this.click.emit(event); } } IconButton.iconButtonCounter = 0; IconButton.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: IconButton, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); IconButton.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: IconButton, selector: "cds-icon-button, ibm-icon-button", inputs: { buttonNgClass: "buttonNgClass", buttonAttributes: "buttonAttributes", buttonId: "buttonId", kind: "kind", size: "size", type: "type", isExpressive: "isExpressive", disabled: "disabled", description: "description" }, outputs: { click: "click", focus: "focus", blur: "blur", tooltipClick: "tooltipClick" }, viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }], usesInheritance: true, ngImport: i0, template: ` <cds-tooltip class="cds--icon-tooltip" [description]="description" [disabled]="disabled" [caret]="caret" [dropShadow]="dropShadow" [highContrast]="highContrast" [isOpen]="isOpen" [align]="align" [autoAlign]="autoAlign" [enterDelayMs]="enterDelayMs" [leaveDelayMs]="leaveDelayMs" (click)="emitClickEvent($event, 'tooltip')"> <button #button [id]="buttonId" [disabled]="disabled" [attr.type]="type" [iconOnly]="true" [ngClass]="buttonNgClass" [cdsButton]="kind" [size]="size" [isExpressive]="isExpressive" (click)="emitClickEvent($event)" (focus)="focus.emit($event)" (blur)="blur.emit($event)"> <ng-content></ng-content> </button> </cds-tooltip> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.Tooltip, selector: "cds-tooltip, ibm-tooltip", inputs: ["id", "enterDelayMs", "leaveDelayMs", "disabled", "description", "templateContext"] }, { kind: "directive", type: i3.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: IconButton, decorators: [{ type: Component, args: [{ selector: "cds-icon-button, ibm-icon-button", template: ` <cds-tooltip class="cds--icon-tooltip" [description]="description" [disabled]="disabled" [caret]="caret" [dropShadow]="dropShadow" [highContrast]="highContrast" [isOpen]="isOpen" [align]="align" [autoAlign]="autoAlign" [enterDelayMs]="enterDelayMs" [leaveDelayMs]="leaveDelayMs" (click)="emitClickEvent($event, 'tooltip')"> <button #button [id]="buttonId" [disabled]="disabled" [attr.type]="type" [iconOnly]="true" [ngClass]="buttonNgClass" [cdsButton]="kind" [size]="size" [isExpressive]="isExpressive" (click)="emitClickEvent($event)" (focus)="focus.emit($event)" (blur)="blur.emit($event)"> <ng-content></ng-content> </button> </cds-tooltip> ` }] }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { buttonNgClass: [{ type: Input }], buttonAttributes: [{ type: Input }], button: [{ type: ViewChild, args: ["button"] }], buttonId: [{ type: Input }], kind: [{ type: Input }], size: [{ type: Input }], type: [{ type: Input }], isExpressive: [{ type: Input }], disabled: [{ type: Input }], description: [{ type: Input }], click: [{ type: Output }], focus: [{ type: Output }], blur: [{ type: Output }], tooltipClick: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon-button.component.js","sourceRoot":"","sources":["../../../src/button/icon-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tElementRef,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tRenderer2,\n\tTemplateRef,\n\tViewChild\n} from \"@angular/core\";\nimport { BaseIconButton } from \"./base-icon-button.component\";\nimport { ButtonSize, ButtonType } from \"./button.types\";\n\n/**\n * Get started with importing the module:\n *\n * ```typescript\n * import { ButtonModule } from 'carbon-components-angular';\n * ```\n *\n * [See demo](../../?path=/story/components-button-icon-button--basic)\n */\n@Component({\n\tselector: \"cds-icon-button, ibm-icon-button\",\n\ttemplate: `\n\t<cds-tooltip\n\t\tclass=\"cds--icon-tooltip\"\n\t\t[description]=\"description\"\n\t\t[disabled]=\"disabled\"\n\t\t[caret]=\"caret\"\n\t\t[dropShadow]=\"dropShadow\"\n\t\t[highContrast]=\"highContrast\"\n\t\t[isOpen]=\"isOpen\"\n\t\t[align]=\"align\"\n\t\t[autoAlign]=\"autoAlign\"\n\t\t[enterDelayMs]=\"enterDelayMs\"\n\t\t[leaveDelayMs]=\"leaveDelayMs\"\n\t\t(click)=\"emitClickEvent($event, 'tooltip')\">\n\t\t<button\n\t\t\t#button\n\t\t\t[id]=\"buttonId\"\n\t\t\t[disabled]=\"disabled\"\n\t\t\t[attr.type]=\"type\"\n\t\t\t[iconOnly]=\"true\"\n\t\t\t[ngClass]=\"buttonNgClass\"\n\t\t\t[cdsButton]=\"kind\"\n\t\t\t[size]=\"size\"\n\t\t\t[isExpressive]=\"isExpressive\"\n\t\t\t(click)=\"emitClickEvent($event)\"\n\t\t\t(focus)=\"focus.emit($event)\"\n\t\t\t(blur)=\"blur.emit($event)\">\n\t\t\t<ng-content></ng-content>\n\t\t</button>\n\t</cds-tooltip>\n\t`\n})\nexport class IconButton extends BaseIconButton implements AfterViewInit {\n\t/**\n\t * Pass global carbon classes to icon button\n\t */\n\t@Input() set buttonNgClass(obj: { [key: string]: boolean }) {\n\t\tthis.classList = Object.assign({ \"cds--btn--disabled\": this.disabled }, obj);\n\t}\n\n\tget buttonNgClass() {\n\t\treturn this.classList;\n\t}\n\n\t/**\n\t * @param obj: { [key: string]: string\n\t * User can pass additional button attributes if component property does not already exist\n\t * Key is the attribute name & value is the attribute value for the button\n\t */\n\t@Input() set buttonAttributes(obj: { [key: string]: string }) {\n\t\tif (this.button) {\n\t\t\t// Remove old attributes\n\t\t\tObject.keys(this.attributeList).forEach((key: string) => {\n\t\t\t\tthis.renderer.removeAttribute(this.button.nativeElement, key);\n\t\t\t});\n\t\t\t// Set new attributes\n\t\t\tObject.keys(obj).forEach((key: string) => {\n\t\t\t\tthis.renderer.setAttribute(this.button.nativeElement, key, obj[key]);\n\t\t\t});\n\t\t}\n\t\t// Set new attributes\n\t\tthis.attributeList = obj;\n\t}\n\n\tget buttonAttributes() {\n\t\treturn this.buttonAttributes;\n\t}\n\n\tstatic iconButtonCounter = 0;\n\n\t@ViewChild(\"button\") button: ElementRef;\n\n\t/**\n\t * Override id\n\t */\n\t@Input() buttonId = `icon-btn-${IconButton.iconButtonCounter++}`;\n\t/**\n\t * Sets the button type.\n\t */\n\t@Input() kind: ButtonType = \"primary\";\n\t/**\n\t * Specify the size of the button.\n\t */\n\t@Input() size: ButtonSize = \"lg\";\n\t/**\n\t * Set button type, `button` by default\n\t */\n\t@Input() type = \"button\";\n\t/**\n\t * Set to `true` to make button expressive\n\t */\n\t@Input() isExpressive = false;\n\t/**\n\t * Set to `true` to disable button\n\t */\n\t@Input() disabled = false;\n\t/**\n\t * The string or template content to be exposed by the tooltip.\n\t */\n\t@Input() description: string | TemplateRef<any>;\n\n\t/**\n\t * Common button events\n\t */\n\t@Output() click = new EventEmitter<Event>();\n\t@Output() focus = new EventEmitter<Event>();\n\t@Output() blur = new EventEmitter<Event>();\n\t/**\n\t * Event to emit when click event is fired from tooltip\n\t */\n\t@Output() tooltipClick = new EventEmitter<Event>();\n\n\tprivate classList: { [key: string]: boolean } = {};\n\tprivate attributeList: { [key: string]: string } = {};\n\n\tconstructor(private renderer: Renderer2) {\n\t\tsuper();\n\t}\n\n\tngAfterViewInit(): void {\n\t\t// Set attributes once element is found\n\t\tthis.buttonAttributes = this.attributeList;\n\t}\n\n\t/**\n\t * Stop propogation of click event\n\t * Else double fires (click) event\n\t */\n\temitClickEvent(event, element: \"tooltip\" | \"button\" = \"button\") {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\t// Prevents (click) event from bubbling since it would appear user clicked the `button`\n\t\tif (element === \"tooltip\") {\n\t\t\tthis.tooltipClick.emit(event);\n\t\t\treturn;\n\t\t}\n\t\tthis.click.emit(event);\n\t}\n}\n"]}