fundamental-ngx
Version:
SAP Fundamentals, implemented in Angular
252 lines • 17.2 kB
JavaScript
/**
* @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"]}