carbon-components-angular
Version:
Next generation components
206 lines • 16.8 kB
JavaScript
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"
[ ]="disabled"
[ ]="caret"
[ ]="dropShadow"
[ ]="highContrast"
[ ]="isOpen"
[ ]="align"
[ ]="autoAlign"
[ ]="enterDelayMs"
[ ]="leaveDelayMs"
(click)="emitClickEvent($event, 'tooltip')">
<button
[ ]="buttonId"
[ ]="disabled"
[ ]="type"
[ ]="true"
[ ]="buttonNgClass"
[ ]="kind"
[ ]="size"
[ ]="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"
[ ]="disabled"
[ ]="caret"
[ ]="dropShadow"
[ ]="highContrast"
[ ]="isOpen"
[ ]="align"
[ ]="autoAlign"
[ ]="enterDelayMs"
[ ]="leaveDelayMs"
(click)="emitClickEvent($event, 'tooltip')">
<button
[ ]="buttonId"
[ ]="disabled"
[ ]="type"
[ ]="true"
[ ]="buttonNgClass"
[ ]="kind"
[ ]="size"
[ ]="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"]}