UNPKG

carbon-components-angular

Version:
191 lines 17.1 kB
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 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 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--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-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"] }], 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"] }], 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--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-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"]}