carbon-components-angular
Version:
Next generation components
203 lines • 18.4 kB
JavaScript
import { Directive, HostBinding, Input } from "@angular/core";
import * as i0 from "@angular/core";
/**
* A convenience directive for applying styling to a button. Get started with importing the module:
*
* ```typescript
* import { ButtonModule } from 'carbon-components-angular';
* ```
*
* Example:
*
* ```html
* <button cdsButton>A button</button>
* <button cdsButton="secondary">A secondary button</button>
* ```
*
* See the [vanilla carbon docs](http://www.carbondesignsystem.com/components/button/code) for more detail.
*
* [See demo](../../?path=/story/components-button--basic)
*/
export class Button {
constructor() {
/**
* Sets the button type
* Accepts `ButtonType` or nothing (empty string which is equivalent to "primary")
* Empty string has been added as an option for Angular 16+ to resolve type errors
*/
this.cdsButton = "primary";
/**
* Set to `true` for a skeleton state button
*/
this.skeleton = false;
/**
* Set to `true` if the button contains only an icon
* This should only be used for creating custom icon buttons, otherwise use
* `<cds-icon-button></cds-icon-button>` component
*/
this.iconOnly = false;
/**
* Set to `true` for a "expressive" style button
*/
this.isExpressive = false;
// a whole lot of HostBindings ... this way we don't have to touch the elementRef directly
this.baseClass = true;
}
/**
* @deprecated as of v5 - Use `cdsButton` input property instead
*/
set ibmButton(type) {
this.cdsButton = type;
}
get primaryButton() {
return this.cdsButton === "primary" || !this.cdsButton;
}
get secondaryButton() {
return this.cdsButton === "secondary";
}
get tertiaryButton() {
return this.cdsButton === "tertiary";
}
get ghostButton() {
return this.cdsButton === "ghost";
}
get dangerButton() {
return this.cdsButton === "danger" || this.cdsButton === "danger--primary";
}
get dangerTertiary() {
return this.cdsButton === "danger--tertiary";
}
get dangerGhost() {
return this.cdsButton === "danger--ghost";
}
/**
* @todo remove `cds--btn--${size}` classes in v12
*/
get extraSmallSize() {
return this.size === "xs" && !this.isExpressive;
}
get smallSize() {
return this.size === "sm" && !this.isExpressive;
}
get mediumSize() {
return this.size === "md" && !this.isExpressive;
}
get largeSize() {
return this.size === "lg";
}
get extraLargeSize() {
return this.size === "xl";
}
get twoExtraLargeSize() {
return this.size === "2xl";
}
// Size classes
get extraSmallLayoutSize() {
return this.size === "xs" && !this.isExpressive;
}
get smallLayoutSize() {
return this.size === "sm" && !this.isExpressive;
}
get mediumLayoutSize() {
return this.size === "md" && !this.isExpressive;
}
get largeLayoutSize() {
return this.size === "lg";
}
get extraLargeLayoutSize() {
return this.size === "xl";
}
get twoExtraLargeLayoutSize() {
return this.size === "2xl";
}
}
Button.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Button, deps: [], target: i0.ɵɵFactoryTarget.Directive });
Button.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: Button, selector: "[cdsButton], [ibmButton]", inputs: { ibmButton: "ibmButton", cdsButton: "cdsButton", size: "size", skeleton: "skeleton", iconOnly: "iconOnly", isExpressive: "isExpressive" }, host: { properties: { "class.cds--skeleton": "this.skeleton", "class.cds--btn--icon-only": "this.iconOnly", "class.cds--btn--expressive": "this.isExpressive", "class.cds--btn": "this.baseClass", "class.cds--btn--primary": "this.primaryButton", "class.cds--btn--secondary": "this.secondaryButton", "class.cds--btn--tertiary": "this.tertiaryButton", "class.cds--btn--ghost": "this.ghostButton", "class.cds--btn--danger": "this.dangerButton", "class.cds--btn--danger--tertiary": "this.dangerTertiary", "class.cds--btn--danger--ghost": "this.dangerGhost", "class.cds--btn--xs": "this.extraSmallSize", "class.cds--btn--sm": "this.smallSize", "class.cds--btn--md": "this.mediumSize", "class.cds--btn--lg": "this.largeSize", "class.cds--btn--xl": "this.extraLargeSize", "class.cds--btn--2xl": "this.twoExtraLargeSize", "class.cds--layout--size-xs": "this.extraSmallLayoutSize", "class.cds--layout--size-sm": "this.smallLayoutSize", "class.cds--layout--size-md": "this.mediumLayoutSize", "class.cds--layout--size-lg": "this.largeLayoutSize", "class.cds--layout--size-xl": "this.extraLargeLayoutSize", "class.cds--layout--size-2xl": "this.twoExtraLargeLayoutSize" } }, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Button, decorators: [{
type: Directive,
args: [{
selector: "[cdsButton], [ibmButton]"
}]
}], propDecorators: { ibmButton: [{
type: Input
}], cdsButton: [{
type: Input
}], size: [{
type: Input
}], skeleton: [{
type: HostBinding,
args: ["class.cds--skeleton"]
}, {
type: Input
}], iconOnly: [{
type: HostBinding,
args: ["class.cds--btn--icon-only"]
}, {
type: Input
}], isExpressive: [{
type: HostBinding,
args: ["class.cds--btn--expressive"]
}, {
type: Input
}], baseClass: [{
type: HostBinding,
args: ["class.cds--btn"]
}], primaryButton: [{
type: HostBinding,
args: ["class.cds--btn--primary"]
}], secondaryButton: [{
type: HostBinding,
args: ["class.cds--btn--secondary"]
}], tertiaryButton: [{
type: HostBinding,
args: ["class.cds--btn--tertiary"]
}], ghostButton: [{
type: HostBinding,
args: ["class.cds--btn--ghost"]
}], dangerButton: [{
type: HostBinding,
args: ["class.cds--btn--danger"]
}], dangerTertiary: [{
type: HostBinding,
args: ["class.cds--btn--danger--tertiary"]
}], dangerGhost: [{
type: HostBinding,
args: ["class.cds--btn--danger--ghost"]
}], extraSmallSize: [{
type: HostBinding,
args: ["class.cds--btn--xs"]
}], smallSize: [{
type: HostBinding,
args: ["class.cds--btn--sm"]
}], mediumSize: [{
type: HostBinding,
args: ["class.cds--btn--md"]
}], largeSize: [{
type: HostBinding,
args: ["class.cds--btn--lg"]
}], extraLargeSize: [{
type: HostBinding,
args: ["class.cds--btn--xl"]
}], twoExtraLargeSize: [{
type: HostBinding,
args: ["class.cds--btn--2xl"]
}], extraSmallLayoutSize: [{
type: HostBinding,
args: ["class.cds--layout--size-xs"]
}], smallLayoutSize: [{
type: HostBinding,
args: ["class.cds--layout--size-sm"]
}], mediumLayoutSize: [{
type: HostBinding,
args: ["class.cds--layout--size-md"]
}], largeLayoutSize: [{
type: HostBinding,
args: ["class.cds--layout--size-lg"]
}], extraLargeLayoutSize: [{
type: HostBinding,
args: ["class.cds--layout--size-xl"]
}], twoExtraLargeLayoutSize: [{
type: HostBinding,
args: ["class.cds--layout--size-2xl"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.directive.js","sourceRoot":"","sources":["../../../src/button/button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tHostBinding,\n\tInput\n} from \"@angular/core\";\nimport { ButtonSize, ButtonType } from \"./button.types\";\n\n/**\n * A convenience directive for applying styling to a button. Get started with importing the module:\n *\n * ```typescript\n * import { ButtonModule } from 'carbon-components-angular';\n * ```\n *\n * Example:\n *\n * ```html\n * <button cdsButton>A button</button>\n * <button cdsButton=\"secondary\">A secondary button</button>\n * ```\n *\n * See the [vanilla carbon docs](http://www.carbondesignsystem.com/components/button/code) for more detail.\n *\n * [See demo](../../?path=/story/components-button--basic)\n */\n@Directive({\n\tselector: \"[cdsButton], [ibmButton]\"\n})\nexport class Button {\n\t/**\n\t * @deprecated as of v5 - Use `cdsButton` input property instead\n\t */\n\t@Input() set ibmButton(type: ButtonType) {\n\t\tthis.cdsButton = type;\n\t}\n\t/**\n\t * Sets the button type\n\t * Accepts `ButtonType` or nothing (empty string which is equivalent to \"primary\")\n\t * Empty string has been added as an option for Angular 16+ to resolve type errors\n\t */\n\t@Input() cdsButton: ButtonType | \"\" = \"primary\";\n\t/**\n\t * Specify the size of the button\n\t */\n\t@Input() size: ButtonSize;\n\t/**\n\t * Set to `true` for a skeleton state button\n\t */\n\t@HostBinding(\"class.cds--skeleton\") @Input() skeleton = false;\n\t/**\n\t * Set to `true` if the button contains only an icon\n\t * This should only be used for creating custom icon buttons, otherwise use\n\t * `<cds-icon-button></cds-icon-button>` component\n\t */\n\t@HostBinding(\"class.cds--btn--icon-only\") @Input() iconOnly = false;\n\n\t/**\n\t * Set to `true` for a \"expressive\" style button\n\t */\n\t@HostBinding(\"class.cds--btn--expressive\") @Input() isExpressive = false;\n\n\t// a whole lot of HostBindings ... this way we don't have to touch the elementRef directly\n\t@HostBinding(\"class.cds--btn\") baseClass = true;\n\t@HostBinding(\"class.cds--btn--primary\") get primaryButton() {\n\t\treturn this.cdsButton === \"primary\" || !this.cdsButton;\n\t}\n\t@HostBinding(\"class.cds--btn--secondary\") get secondaryButton() {\n\t\treturn this.cdsButton === \"secondary\";\n\t}\n\t@HostBinding(\"class.cds--btn--tertiary\") get tertiaryButton() {\n\t\treturn this.cdsButton === \"tertiary\";\n\t}\n\t@HostBinding(\"class.cds--btn--ghost\") get ghostButton() {\n\t\treturn this.cdsButton === \"ghost\";\n\t}\n\t@HostBinding(\"class.cds--btn--danger\") get dangerButton() {\n\t\treturn this.cdsButton === \"danger\" || this.cdsButton === \"danger--primary\";\n\t}\n\t@HostBinding(\"class.cds--btn--danger--tertiary\") get dangerTertiary() {\n\t\treturn this.cdsButton === \"danger--tertiary\";\n\t}\n\t@HostBinding(\"class.cds--btn--danger--ghost\") get dangerGhost() {\n\t\treturn this.cdsButton === \"danger--ghost\";\n\t}\n\t/**\n\t * @todo remove `cds--btn--${size}` classes in v12\n\t */\n\t@HostBinding(\"class.cds--btn--xs\") get extraSmallSize() {\n\t\treturn this.size === \"xs\" && !this.isExpressive;\n\t}\n\t@HostBinding(\"class.cds--btn--sm\") get smallSize() {\n\t\treturn this.size === \"sm\" && !this.isExpressive;\n\t}\n\t@HostBinding(\"class.cds--btn--md\") get mediumSize() {\n\t\treturn this.size === \"md\" && !this.isExpressive;\n\t}\n\t@HostBinding(\"class.cds--btn--lg\") get largeSize() {\n\t\treturn this.size === \"lg\";\n\t}\n\t@HostBinding(\"class.cds--btn--xl\") get extraLargeSize() {\n\t\treturn this.size === \"xl\";\n\t}\n\t@HostBinding(\"class.cds--btn--2xl\") get twoExtraLargeSize() {\n\t\treturn this.size === \"2xl\";\n\t}\n\n\t// Size classes\n\t@HostBinding(\"class.cds--layout--size-xs\") get extraSmallLayoutSize() {\n\t\treturn this.size === \"xs\" && !this.isExpressive;\n\t}\n\t@HostBinding(\"class.cds--layout--size-sm\") get smallLayoutSize() {\n\t\treturn this.size === \"sm\" && !this.isExpressive;\n\t}\n\t@HostBinding(\"class.cds--layout--size-md\") get mediumLayoutSize() {\n\t\treturn this.size === \"md\" && !this.isExpressive;\n\t}\n\t@HostBinding(\"class.cds--layout--size-lg\") get largeLayoutSize() {\n\t\treturn this.size === \"lg\";\n\t}\n\t@HostBinding(\"class.cds--layout--size-xl\") get extraLargeLayoutSize() {\n\t\treturn this.size === \"xl\";\n\t}\n\t@HostBinding(\"class.cds--layout--size-2xl\") get twoExtraLargeLayoutSize() {\n\t\treturn this.size === \"2xl\";\n\t}\n\n\n}\n"]}