UNPKG

fundamental-ngx

Version:

SAP Fundamentals, implemented in Angular

252 lines 17.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core'; import { SplitButtonActionTitle } from './split-button-utils/split-button.directives'; /** * Split Button component, used to enhance standard HTML button and add possibility to put some dropdown with * additional options. * * ```html * <fd-split-button> * Action Button * <div fd-split-button-menu> * <fd-menu> * <ul fd-menu-list> * <li fd-menu-item> * <a [routerLink]="'/'">option</a> * </li> * <li fd-menu-item> * <a [routerLink]="'/'">option2</a> * </li> * </ul> * </fd-menu> * </div> * </fd-split-button> * ``` */ var SplitButtonComponent = /** @class */ (function () { function SplitButtonComponent() { /** * The trigger events that will open/close the popover. * Accepts any [HTML DOM Events](https://www.w3schools.com/jsref/dom_obj_event.asp). */ this.triggers = ['click']; /** * Whether the popover should close when a click is made outside its boundaries. */ this.closeOnOutsideClick = true; /** * Whether the popover should close when the escape key is pressed. */ this.closeOnEscapeKey = true; /** * Whether the popover should be focusTrapped. */ this.focusTrapped = false; /** * The icon to include in the button. See the icon page for the list of icons. */ this.glyph = 'slim-arrow-down'; /** * Preset options for the popover body width. * * `at-least` will apply a minimum width to the body equivalent to the width of the control. * * `equal` will apply a width to the body equivalent to the width of the control. * * Leave blank for no effect. */ this.fillControlMode = 'at-least'; /** * @hidden */ this.isOpen = false; /** * Event sent when is open popover changed */ this.isOpenChange = new EventEmitter(); /** * Event sent when primary button is clicked */ this.primaryButtonClicked = new EventEmitter(); } /** * Handles primary button click * */ /** * Handles primary button click * * @param {?} $event * @return {?} */ SplitButtonComponent.prototype.buttonClick = /** * Handles primary button click * * @param {?} $event * @return {?} */ function ($event) { this.primaryButtonClicked.emit(); $event.stopPropagation(); }; /** * Toggles the popover open state. */ /** * Toggles the popover open state. * @return {?} */ SplitButtonComponent.prototype.toggle = /** * Toggles the popover open state. * @return {?} */ function () { if (this.isOpen) { this.close(); } else { this.open(); } }; /** * Closes the popover. */ /** * Closes the popover. * @return {?} */ SplitButtonComponent.prototype.close = /** * Closes the popover. * @return {?} */ function () { if (this.isOpen) { this.isOpen = false; this.isOpenChange.emit(this.isOpen); } }; /** * Opens the popover. */ /** * Opens the popover. * @return {?} */ SplitButtonComponent.prototype.open = /** * Opens the popover. * @return {?} */ function () { if (!this.isOpen) { this.isOpen = true; this.isOpenChange.emit(this.isOpen); } }; SplitButtonComponent.decorators = [ { type: Component, args: [{ selector: 'fd-split-button', template: "<fd-popover [(isOpen)]=\"isOpen\"\n [focusTrapped]=\"focusTrapped\"\n [closeOnEscapeKey]=\"closeOnEscapeKey\"\n [closeOnOutsideClick]=\"closeOnOutsideClick\"\n [disabled]=\"disabled\"\n [triggers]=\"triggers\"\n [fillControlMode]=\"fillControlMode\">\n <fd-popover-control>\n <div class=\"fd-button-split\">\n <button fd-button\n [fdType]=\"fdType\"\n [options]=\"options\"\n [compact]=\"compact\"\n (click)=\"buttonClick($event)\"\n [disabled]=\"disabled\">\n <ng-container *ngIf=\"titleTemplate\">\n <ng-container [fd-split-button-load-action-title]=\"titleTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!titleTemplate\">\n {{mainActionTitle}}\n </ng-container>\n </button>\n <button fd-button\n [attr.aria-expanded]=\"disabled ? false : isOpen\"\n [attr.aria-disabled]=\"disabled\"\n aria-haspopup=\"true\"\n [fdType]=\"fdType\"\n [options]=\"options\"\n [compact]=\"compact\"\n [glyph]=\"glyph\">\n </button>\n </div>\n </fd-popover-control>\n <fd-popover-body>\n <ng-content select=\"[fd-split-button-menu]\"></ng-content>\n </fd-popover-body>\n</fd-popover>\n" }] } ]; SplitButtonComponent.propDecorators = { titleTemplate: [{ type: ContentChild, args: [SplitButtonActionTitle, { read: TemplateRef },] }], triggers: [{ type: Input }], closeOnOutsideClick: [{ type: Input }], closeOnEscapeKey: [{ type: Input }], focusTrapped: [{ type: Input }], compact: [{ type: Input }], glyph: [{ type: Input }], disabled: [{ type: Input }], mainActionTitle: [{ type: Input }], fdType: [{ type: Input }], options: [{ type: Input }], fillControlMode: [{ type: Input }], isOpen: [{ type: Input }], isOpenChange: [{ type: Output }], primaryButtonClicked: [{ type: Output }] }; return SplitButtonComponent; }()); export { SplitButtonComponent }; if (false) { /** * @hidden * @type {?} */ SplitButtonComponent.prototype.titleTemplate; /** * The trigger events that will open/close the popover. * Accepts any [HTML DOM Events](https://www.w3schools.com/jsref/dom_obj_event.asp). * @type {?} */ SplitButtonComponent.prototype.triggers; /** * Whether the popover should close when a click is made outside its boundaries. * @type {?} */ SplitButtonComponent.prototype.closeOnOutsideClick; /** * Whether the popover should close when the escape key is pressed. * @type {?} */ SplitButtonComponent.prototype.closeOnEscapeKey; /** * Whether the popover should be focusTrapped. * @type {?} */ SplitButtonComponent.prototype.focusTrapped; /** * Whether to apply compact mode to the button. * @type {?} */ SplitButtonComponent.prototype.compact; /** * The icon to include in the button. See the icon page for the list of icons. * @type {?} */ SplitButtonComponent.prototype.glyph; /** * The icon to include in the button. See the icon page for the list of icons. * @type {?} */ SplitButtonComponent.prototype.disabled; /** * The Title for main action button * @type {?} */ SplitButtonComponent.prototype.mainActionTitle; /** * The type of the button. Types include 'standard', 'positive', 'medium', and 'negative'. * Leave empty for default (Action button).' * @type {?} */ SplitButtonComponent.prototype.fdType; /** * Button options. Options include 'emphasized' and 'light'. Leave empty for default.' * @type {?} */ SplitButtonComponent.prototype.options; /** * Preset options for the popover body width. * * `at-least` will apply a minimum width to the body equivalent to the width of the control. * * `equal` will apply a width to the body equivalent to the width of the control. * * Leave blank for no effect. * @type {?} */ SplitButtonComponent.prototype.fillControlMode; /** * @hidden * @type {?} */ SplitButtonComponent.prototype.isOpen; /** * Event sent when is open popover changed * @type {?} */ SplitButtonComponent.prototype.isOpenChange; /** * Event sent when primary button is clicked * @type {?} */ SplitButtonComponent.prototype.primaryButtonClicked; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"split-button.component.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/split-button/split-button.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAClG,OAAO,EAAE,sBAAsB,EAAE,MAAM,8CAA8C,CAAC;;;;;;;;;;;;;;;;;;;;;;;AAyBtF;IAAA;;;;;QAaI,aAAQ,GAAa,CAAC,OAAO,CAAC,CAAC;;;;QAI/B,wBAAmB,GAAY,IAAI,CAAC;;;;QAIpC,qBAAgB,GAAY,IAAI,CAAC;;;;QAIjC,iBAAY,GAAY,KAAK,CAAC;;;;QAQ9B,UAAK,GAAW,iBAAiB,CAAC;;;;;;;QA0BlC,oBAAe,GAAoB,UAAU,CAAC;;;;QAI9C,WAAM,GAAY,KAAK,CAAC;;;;QAIf,iBAAY,GAA0B,IAAI,YAAY,EAAW,CAAC;;;;QAIlE,yBAAoB,GAA0B,IAAI,YAAY,EAAW,CAAC;IAyCvF,CAAC;IAvCG;;UAEM;;;;;;;IACC,0CAAW;;;;;;IAAlB,UAAmB,MAAM;QACrB,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC;QACjC,MAAM,CAAC,eAAe,EAAE,CAAC;IAC7B,CAAC;IAED;;OAEG;;;;;IACI,qCAAM;;;;IAAb;QACI,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;aAAM;YACH,IAAI,CAAC,IAAI,EAAE,CAAC;SACf;IACL,CAAC;IAED;;OAEG;;;;;IACI,oCAAK;;;;IAAZ;QACI,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACvC;IACL,CAAC;IAED;;OAEG;;;;;IACI,mCAAI;;;;IAAX;QACI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACvC;IACL,CAAC;;gBA9GJ,SAAS,SAAC;oBACP,QAAQ,EAAE,iBAAiB;oBAC3B,giDAA0C;iBAC7C;;;gCAII,YAAY,SAAC,sBAAsB,EAAE,EAAC,IAAI,EAAE,WAAW,EAAC;2BAKxD,KAAK;sCAIL,KAAK;mCAIL,KAAK;+BAIL,KAAK;0BAIL,KAAK;wBAIL,KAAK;2BAIL,KAAK;kCAIL,KAAK;yBAKL,KAAK;0BAIL,KAAK;kCASL,KAAK;yBAIL,KAAK;+BAIL,MAAM;uCAIN,MAAM;;IA0CX,2BAAC;CAAA,AAhHD,IAgHC;SA5GY,oBAAoB;;;;;;IAG7B,6CACgC;;;;;;IAIhC,wCAC+B;;;;;IAG/B,mDACoC;;;;;IAGpC,gDACiC;;;;;IAGjC,4CAC8B;;;;;IAG9B,uCACiB;;;;;IAGjB,qCACkC;;;;;IAGlC,wCACkB;;;;;IAGlB,+CACwB;;;;;;IAIxB,sCACe;;;;;IAGf,uCAC2B;;;;;;;;IAQ3B,+CAC8C;;;;;IAG9C,sCACwB;;;;;IAGxB,4CAC2E;;;;;IAG3E,oDACmF","sourcesContent":["import { Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { SplitButtonActionTitle } from './split-button-utils/split-button.directives';\nimport { PopoverFillMode } from '../popover/popover-directive/popover.directive';\n\n/**\n * Split Button component, used to enhance standard HTML button and add possibility to put some dropdown with\n * additional options.\n *\n * ```html\n *    <fd-split-button>\n *        Action Button\n *        <div fd-split-button-menu>\n *            <fd-menu>\n *                <ul fd-menu-list>\n *                    <li fd-menu-item>\n *                       <a [routerLink]=\"'/'\">option</a>\n *                    </li>\n *                    <li fd-menu-item>\n *                       <a [routerLink]=\"'/'\">option2</a>\n *                    </li>\n *                </ul>\n *            </fd-menu>\n *        </div>\n *    </fd-split-button>\n * ```\n */\n@Component({\n    selector: 'fd-split-button',\n    templateUrl: 'split-button.component.html'\n})\nexport class SplitButtonComponent {\n\n    /** @hidden */\n    @ContentChild(SplitButtonActionTitle, {read: TemplateRef})\n    titleTemplate: TemplateRef<any>;\n\n    /** The trigger events that will open/close the popover.\n     *  Accepts any [HTML DOM Events](https://www.w3schools.com/jsref/dom_obj_event.asp). */\n    @Input()\n    triggers: string[] = ['click'];\n\n    /** Whether the popover should close when a click is made outside its boundaries. */\n    @Input()\n    closeOnOutsideClick: boolean = true;\n\n    /** Whether the popover should close when the escape key is pressed. */\n    @Input()\n    closeOnEscapeKey: boolean = true;\n\n    /** Whether the popover should be focusTrapped. */\n    @Input()\n    focusTrapped: boolean = false;\n\n    /** Whether to apply compact mode to the button. */\n    @Input()\n    compact: boolean;\n\n    /** The icon to include in the button. See the icon page for the list of icons. */\n    @Input()\n    glyph: string = 'slim-arrow-down';\n\n    /** The icon to include in the button. See the icon page for the list of icons. */\n    @Input()\n    disabled: boolean;\n\n    /** The Title for main  action button */\n    @Input()\n    mainActionTitle: string;\n\n    /** The type of the button. Types include 'standard', 'positive', 'medium', and 'negative'.\n     * Leave empty for default (Action button).'*/\n    @Input()\n    fdType: string;\n\n    /** Button options.  Options include 'emphasized' and 'light'. Leave empty for default.' */\n    @Input()\n    options: string | string[];\n\n    /**\n     * Preset options for the popover body width.\n     * * `at-least` will apply a minimum width to the body equivalent to the width of the control.\n     * * `equal` will apply a width to the body equivalent to the width of the control.\n     * * Leave blank for no effect.\n     */\n    @Input()\n    fillControlMode: PopoverFillMode = 'at-least';\n\n    /** @hidden */\n    @Input()\n    isOpen: boolean = false;\n\n    /** Event sent when is open popover changed */\n    @Output()\n    readonly isOpenChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /** Event sent when primary button is clicked */\n    @Output()\n    readonly primaryButtonClicked: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /**\n     *  Handles primary button click\n     *  */\n    public buttonClick($event) {\n        this.primaryButtonClicked.emit();\n        $event.stopPropagation();\n    }\n\n    /**\n     * Toggles the popover open state.\n     */\n    public toggle(): void {\n        if (this.isOpen) {\n            this.close();\n        } else {\n            this.open();\n        }\n    }\n\n    /**\n     * Closes the popover.\n     */\n    public close(): void {\n        if (this.isOpen) {\n            this.isOpen = false;\n            this.isOpenChange.emit(this.isOpen);\n        }\n    }\n\n    /**\n     * Opens the popover.\n     */\n    public open(): void {\n        if (!this.isOpen) {\n            this.isOpen = true;\n            this.isOpenChange.emit(this.isOpen);\n        }\n    }\n\n}\n"]}