UNPKG

ngx-bootstrap-fix-datepicker

Version:
355 lines (347 loc) 11.3 kB
import { Injectable, Component, Input, EventEmitter, Inject, Output, HostBinding, NgModule } from '@angular/core'; import { isBs3 } from 'ngx-bootstrap/utils'; import { CommonModule } from '@angular/common'; import { CollapseModule } from 'ngx-bootstrap/collapse'; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * Configuration service, provides default values for the AccordionComponent. */ var AccordionConfig = /** @class */ (function () { function AccordionConfig() { /** * Whether the other panels should be closed when a panel is opened */ this.closeOthers = false; /** * turn on/off animation */ this.isAnimated = false; } AccordionConfig.decorators = [ { type: Injectable } ]; return AccordionConfig; }()); if (false) { /** * Whether the other panels should be closed when a panel is opened * @type {?} */ AccordionConfig.prototype.closeOthers; /** * turn on/off animation * @type {?} */ AccordionConfig.prototype.isAnimated; } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * Displays collapsible content panels for presenting information in a limited amount of space. */ var AccordionComponent = /** @class */ (function () { function AccordionComponent(config) { /** * turn on/off animation */ this.isAnimated = false; this.groups = []; Object.assign(this, config); } /** * @param {?} openGroup * @return {?} */ AccordionComponent.prototype.closeOtherPanels = /** * @param {?} openGroup * @return {?} */ function (openGroup) { if (!this.closeOthers) { return; } this.groups.forEach((/** * @param {?} group * @return {?} */ function (group) { if (group !== openGroup) { group.isOpen = false; } })); }; /** * @param {?} group * @return {?} */ AccordionComponent.prototype.addGroup = /** * @param {?} group * @return {?} */ function (group) { group.isAnimated = this.isAnimated; this.groups.push(group); }; /** * @param {?} group * @return {?} */ AccordionComponent.prototype.removeGroup = /** * @param {?} group * @return {?} */ function (group) { /** @type {?} */ var index = this.groups.indexOf(group); if (index !== -1) { this.groups.splice(index, 1); } }; AccordionComponent.decorators = [ { type: Component, args: [{ selector: 'accordion', template: "<ng-content></ng-content>", host: { '[attr.aria-multiselectable]': 'closeOthers', role: 'tablist', class: 'panel-group', style: 'display: block' } }] } ]; /** @nocollapse */ AccordionComponent.ctorParameters = function () { return [ { type: AccordionConfig } ]; }; AccordionComponent.propDecorators = { isAnimated: [{ type: Input }], closeOthers: [{ type: Input }] }; return AccordionComponent; }()); if (false) { /** * turn on/off animation * @type {?} */ AccordionComponent.prototype.isAnimated; /** * if `true` expanding one item will close all others * @type {?} */ AccordionComponent.prototype.closeOthers; /** * @type {?} * @protected */ AccordionComponent.prototype.groups; } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * ### Accordion heading * Instead of using `heading` attribute on the `accordion-group`, you can use * an `accordion-heading` attribute on `any` element inside of a group that * will be used as group's header template. */ var AccordionPanelComponent = /** @class */ (function () { function AccordionPanelComponent(accordion) { /** * turn on/off animation */ this.isAnimated = false; /** * Emits when the opened state changes */ this.isOpenChange = new EventEmitter(); this._isOpen = false; this.accordion = accordion; } Object.defineProperty(AccordionPanelComponent.prototype, "isOpen", { // Questionable, maybe .panel-open should be on child div.panel element? /** Is accordion group open or closed. This property supports two-way binding */ get: // Questionable, maybe .panel-open should be on child div.panel element? /** * Is accordion group open or closed. This property supports two-way binding * @return {?} */ function () { return this._isOpen; }, set: /** * @param {?} value * @return {?} */ function (value) { var _this = this; if (value !== this.isOpen) { if (value) { this.accordion.closeOtherPanels(this); } this._isOpen = value; Promise.resolve(null).then((/** * @return {?} */ function () { _this.isOpenChange.emit(value); })) .catch((/** * @param {?} error * @return {?} */ function (error) { /* tslint:disable: no-console */ console.log(error); })); } }, enumerable: true, configurable: true }); Object.defineProperty(AccordionPanelComponent.prototype, "isBs3", { get: /** * @return {?} */ function () { return isBs3(); }, enumerable: true, configurable: true }); /** * @return {?} */ AccordionPanelComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.panelClass = this.panelClass || 'panel-default'; this.accordion.addGroup(this); }; /** * @return {?} */ AccordionPanelComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.accordion.removeGroup(this); }; /** * @return {?} */ AccordionPanelComponent.prototype.toggleOpen = /** * @return {?} */ function () { if (!this.isDisabled) { this.isOpen = !this.isOpen; } }; AccordionPanelComponent.decorators = [ { type: Component, args: [{ selector: 'accordion-group, accordion-panel', template: "<div class=\"panel card\" [ngClass]=\"panelClass\">\n <div\n class=\"panel-heading card-header\"\n role=\"tab\"\n (click)=\"toggleOpen()\"\n [ngClass]=\"isDisabled ? 'panel-disabled' : 'panel-enabled'\"\n >\n <div class=\"panel-title\">\n <div role=\"button\" class=\"accordion-toggle\" [attr.aria-expanded]=\"isOpen\">\n <button class=\"btn btn-link\" *ngIf=\"heading\" [ngClass]=\"{ 'text-muted': isDisabled }\" type=\"button\">\n {{ heading }}\n </button>\n <ng-content select=\"[accordion-heading]\"></ng-content>\n </div>\n </div>\n </div>\n <div class=\"panel-collapse collapse\" role=\"tabpanel\" [collapse]=\"!isOpen\" [isAnimated]=\"isAnimated\">\n <div class=\"panel-body card-block card-body\">\n <ng-content></ng-content>\n </div>\n </div>\n</div>\n", host: { class: 'panel', style: 'display: block' }, styles: [":host .card-header.panel-enabled{cursor:pointer}:host .card-header.panel-disabled .btn.btn-link{cursor:default;text-decoration:none}"] }] } ]; /** @nocollapse */ AccordionPanelComponent.ctorParameters = function () { return [ { type: AccordionComponent, decorators: [{ type: Inject, args: [AccordionComponent,] }] } ]; }; AccordionPanelComponent.propDecorators = { heading: [{ type: Input }], panelClass: [{ type: Input }], isDisabled: [{ type: Input }], isOpenChange: [{ type: Output }], isOpen: [{ type: HostBinding, args: ['class.panel-open',] }, { type: Input }] }; return AccordionPanelComponent; }()); if (false) { /** * turn on/off animation * @type {?} */ AccordionPanelComponent.prototype.isAnimated; /** * Clickable text in accordion's group header, check `accordion heading` below for using html in header * @type {?} */ AccordionPanelComponent.prototype.heading; /** * Provides an ability to use Bootstrap's contextual panel classes * (`panel-primary`, `panel-success`, `panel-info`, etc...). * List of all available classes [available here] * (https://getbootstrap.com/docs/3.3/components/#panels-alternatives) * @type {?} */ AccordionPanelComponent.prototype.panelClass; /** * if <code>true</code> — disables accordion group * @type {?} */ AccordionPanelComponent.prototype.isDisabled; /** * Emits when the opened state changes * @type {?} */ AccordionPanelComponent.prototype.isOpenChange; /** * @type {?} * @protected */ AccordionPanelComponent.prototype._isOpen; /** * @type {?} * @protected */ AccordionPanelComponent.prototype.accordion; } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var AccordionModule = /** @class */ (function () { function AccordionModule() { } /** * @return {?} */ AccordionModule.forRoot = /** * @return {?} */ function () { return { ngModule: AccordionModule, providers: [AccordionConfig] }; }; AccordionModule.decorators = [ { type: NgModule, args: [{ imports: [CommonModule, CollapseModule], declarations: [AccordionComponent, AccordionPanelComponent], exports: [AccordionComponent, AccordionPanelComponent] },] } ]; return AccordionModule; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ export { AccordionComponent, AccordionConfig, AccordionModule, AccordionPanelComponent }; //# sourceMappingURL=ngx-bootstrap-accordion.js.map