You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 4-6.RSVP
Socket
Book a DemoInstallSign in
Socket

angular2-promise-buttons

Package Overview
Dependencies
Maintainers
1
Versions
37
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

angular2-promise-buttons - npm Package Compare versions

Comparing version

to
6.0.0

angular2-promise-buttons.module.ngfactory.d.ts

3

angular2-promise-buttons.d.ts
/**
* Generated bundle index. Do not edit.
*/
/// <amd-module name="angular2-promise-buttons" />
export * from './index';
export { PromiseBtnConfig as ɵb } from './promise-btn-config';
export { userCfg as ɵa } from './user-cfg';
import { ModuleWithProviders } from '@angular/core';
import { PromiseBtnConfig } from './promise-btn-config';
import * as i0 from "@angular/core";
import * as i1 from "./promise-btn.directive";
export declare class Angular2PromiseButtonModule {
static forRoot(config?: PromiseBtnConfig): ModuleWithProviders<Angular2PromiseButtonModule>;
static ɵfac: i0.ɵɵFactoryDeclaration<Angular2PromiseButtonModule, never>;
static ɵmod: i0.ɵɵNgModuleDeclaration<Angular2PromiseButtonModule, [typeof i1.PromiseBtnDirective], never, [typeof i1.PromiseBtnDirective]>;
static ɵinj: i0.ɵɵInjectorDeclaration<Angular2PromiseButtonModule>;
}
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('rxjs')) :
typeof define === 'function' && define.amd ? define('angular2-promise-buttons', ['exports', '@angular/core', 'rxjs'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global['angular2-promise-buttons'] = {}, global.ng.core, global.rxjs));
}(this, (function (exports, core, rxjs) { 'use strict';
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["angular2-promise-buttons"] = {}, global.ng.core, global.rxjs));
})(this, (function (exports, i0, rxjs) { 'use strict';
function _interopNamespace(e) {
if (e && e.__esModule) return e;
var n = Object.create(null);
if (e) {
Object.keys(e).forEach(function (k) {
if (k !== 'default') {
var d = Object.getOwnPropertyDescriptor(e, k);
Object.defineProperty(n, k, d.get ? d : {
enumerable: true,
get: function () { return e[k]; }
});
}
});
}
n["default"] = e;
return Object.freeze(n);
}
var i0__namespace = /*#__PURE__*/_interopNamespace(i0);
var DEFAULT_CFG = {

@@ -15,3 +35,3 @@ spinnerTpl: '<span class="btn-spinner"></span>',

var userCfg = new core.InjectionToken('cfg');
var userCfg = new i0.InjectionToken('cfg');

@@ -224,16 +244,23 @@ var PromiseBtnDirective = /** @class */ (function () {

}());
PromiseBtnDirective.decorators = [
{ type: core.Directive, args: [{
selector: '[promiseBtn]'
},] }
];
PromiseBtnDirective.ctorParameters = function () { return [
{ type: core.ElementRef },
{ type: undefined, decorators: [{ type: core.Inject, args: [userCfg,] }] }
]; };
PromiseBtnDirective.propDecorators = {
isDisabledFromTheOutsideSetter: [{ type: core.Input, args: ['disabled',] }],
promiseBtn: [{ type: core.Input }],
handleCurrentBtnOnly: [{ type: core.HostListener, args: ['click',] }]
};
PromiseBtnDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: PromiseBtnDirective, deps: [{ token: i0__namespace.ElementRef }, { token: userCfg }], target: i0__namespace.ɵɵFactoryTarget.Directive });
PromiseBtnDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: PromiseBtnDirective, selector: "[promiseBtn]", inputs: { isDisabledFromTheOutsideSetter: ["disabled", "isDisabledFromTheOutsideSetter"], promiseBtn: "promiseBtn" }, host: { listeners: { "click": "handleCurrentBtnOnly()" } }, ngImport: i0__namespace });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: PromiseBtnDirective, decorators: [{
type: i0.Directive,
args: [{
selector: '[promiseBtn]'
}]
}], ctorParameters: function () {
return [{ type: i0__namespace.ElementRef }, { type: undefined, decorators: [{
type: i0.Inject,
args: [userCfg]
}] }];
}, propDecorators: { isDisabledFromTheOutsideSetter: [{
type: i0.Input,
args: ['disabled']
}], promiseBtn: [{
type: i0.Input
}], handleCurrentBtnOnly: [{
type: i0.HostListener,
args: ['click']
}] } });

@@ -253,14 +280,18 @@ var Angular2PromiseButtonModule = /** @class */ (function () {

}());
Angular2PromiseButtonModule.decorators = [
{ type: core.NgModule, args: [{
declarations: [
PromiseBtnDirective,
],
imports: [],
exports: [
PromiseBtnDirective,
],
providers: []
},] }
];
Angular2PromiseButtonModule.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: Angular2PromiseButtonModule, deps: [], target: i0__namespace.ɵɵFactoryTarget.NgModule });
Angular2PromiseButtonModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: Angular2PromiseButtonModule, declarations: [PromiseBtnDirective], exports: [PromiseBtnDirective] });
Angular2PromiseButtonModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: Angular2PromiseButtonModule, providers: [], imports: [[]] });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: Angular2PromiseButtonModule, decorators: [{
type: i0.NgModule,
args: [{
declarations: [
PromiseBtnDirective,
],
imports: [],
exports: [
PromiseBtnDirective,
],
providers: []
}]
}] });

@@ -273,7 +304,6 @@ /**

exports.PromiseBtnDirective = PromiseBtnDirective;
exports.ɵa = userCfg;
Object.defineProperty(exports, '__esModule', { value: true });
})));
}));
//# sourceMappingURL=angular2-promise-buttons.umd.js.map

@@ -5,3 +5,2 @@ /**

export * from './index';
export { userCfg as ɵa } from './user-cfg';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhcjItcHJvbWlzZS1idXR0b25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhcjItcHJvbWlzZS1idXR0b25zL3NyYy9hbmd1bGFyMi1wcm9taXNlLWJ1dHRvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQztBQUd4QixPQUFPLEVBQUMsT0FBTyxJQUFJLEVBQUUsRUFBQyxNQUFNLFlBQVksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG5cbmV4cG9ydCB7UHJvbWlzZUJ0bkNvbmZpZyBhcyDJtWJ9IGZyb20gJy4vcHJvbWlzZS1idG4tY29uZmlnJztcbmV4cG9ydCB7dXNlckNmZyBhcyDJtWF9IGZyb20gJy4vdXNlci1jZmcnOyJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhcjItcHJvbWlzZS1idXR0b25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhcjItcHJvbWlzZS1idXR0b25zL3NyYy9hbmd1bGFyMi1wcm9taXNlLWJ1dHRvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
import { NgModule } from '@angular/core';
import { PromiseBtnDirective } from './promise-btn.directive';
import { userCfg } from './user-cfg';
import * as i0 from "@angular/core";
export class Angular2PromiseButtonModule {

@@ -14,14 +15,18 @@ // add forRoot to make it configurable

}
Angular2PromiseButtonModule.decorators = [
{ type: NgModule, args: [{
declarations: [
PromiseBtnDirective,
],
imports: [],
exports: [
PromiseBtnDirective,
],
providers: []
},] }
];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhcjItcHJvbWlzZS1idXR0b25zLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIyLXByb21pc2UtYnV0dG9ucy9zcmMvYW5ndWxhcjItcHJvbWlzZS1idXR0b25zLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXNCLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUU1RCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sWUFBWSxDQUFDO0FBWW5DLE1BQU0sT0FBTywyQkFBMkI7SUFDdEMsc0NBQXNDO0lBQ3RDLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBeUI7UUFDdEMsK0RBQStEO1FBQy9ELE9BQU87WUFDTCxRQUFRLEVBQUUsMkJBQTJCO1lBQ3JDLFNBQVMsRUFBRSxDQUFDLEVBQUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFDLENBQUM7U0FDbEQsQ0FBQztJQUNKLENBQUM7OztZQWxCRixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFO29CQUNaLG1CQUFtQjtpQkFDcEI7Z0JBQ0QsT0FBTyxFQUFFLEVBQUU7Z0JBQ1gsT0FBTyxFQUFFO29CQUNQLG1CQUFtQjtpQkFDcEI7Z0JBQ0QsU0FBUyxFQUFFLEVBQUU7YUFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtQcm9taXNlQnRuRGlyZWN0aXZlfSBmcm9tICcuL3Byb21pc2UtYnRuLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1Byb21pc2VCdG5Db25maWd9IGZyb20gJy4vcHJvbWlzZS1idG4tY29uZmlnJztcbmltcG9ydCB7dXNlckNmZ30gZnJvbSAnLi91c2VyLWNmZyc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFByb21pc2VCdG5EaXJlY3RpdmUsXG4gIF0sXG4gIGltcG9ydHM6IFtdLFxuICBleHBvcnRzOiBbXG4gICAgUHJvbWlzZUJ0bkRpcmVjdGl2ZSxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbXVxufSlcbmV4cG9ydCBjbGFzcyBBbmd1bGFyMlByb21pc2VCdXR0b25Nb2R1bGUge1xuICAvLyBhZGQgZm9yUm9vdCB0byBtYWtlIGl0IGNvbmZpZ3VyYWJsZVxuICBzdGF0aWMgZm9yUm9vdChjb25maWc/OiBQcm9taXNlQnRuQ29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVyczxBbmd1bGFyMlByb21pc2VCdXR0b25Nb2R1bGU+IHtcbiAgICAvLyBOT1RFOiB0aGlzIGlzIG5ldmVyIGFsbG93ZWQgdG8gY29udGFpbiBhbnkgY29uZGl0aW9uYWwgbG9naWNcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEFuZ3VsYXIyUHJvbWlzZUJ1dHRvbk1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW3twcm92aWRlOiB1c2VyQ2ZnLCB1c2VWYWx1ZTogY29uZmlnfV1cbiAgICB9O1xuICB9XG59XG4iXX0=
Angular2PromiseButtonModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: Angular2PromiseButtonModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
Angular2PromiseButtonModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: Angular2PromiseButtonModule, declarations: [PromiseBtnDirective], exports: [PromiseBtnDirective] });
Angular2PromiseButtonModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: Angular2PromiseButtonModule, providers: [], imports: [[]] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: Angular2PromiseButtonModule, decorators: [{
type: NgModule,
args: [{
declarations: [
PromiseBtnDirective,
],
imports: [],
exports: [
PromiseBtnDirective,
],
providers: []
}]
}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhcjItcHJvbWlzZS1idXR0b25zLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIyLXByb21pc2UtYnV0dG9ucy9zcmMvYW5ndWxhcjItcHJvbWlzZS1idXR0b25zLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXNCLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUU1RCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sWUFBWSxDQUFDOztBQVluQyxNQUFNLE9BQU8sMkJBQTJCO0lBQ3RDLHNDQUFzQztJQUN0QyxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXlCO1FBQ3RDLCtEQUErRDtRQUMvRCxPQUFPO1lBQ0wsUUFBUSxFQUFFLDJCQUEyQjtZQUNyQyxTQUFTLEVBQUUsQ0FBQyxFQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBQyxDQUFDO1NBQ2xELENBQUM7SUFDSixDQUFDOzt5SEFSVSwyQkFBMkI7MEhBQTNCLDJCQUEyQixpQkFScEMsbUJBQW1CLGFBSW5CLG1CQUFtQjswSEFJViwyQkFBMkIsYUFGM0IsRUFBRSxZQUpKLEVBQUU7NEZBTUEsMkJBQTJCO2tCQVZ2QyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRSxFQUFFO29CQUNYLE9BQU8sRUFBRTt3QkFDUCxtQkFBbUI7cUJBQ3BCO29CQUNELFNBQVMsRUFBRSxFQUFFO2lCQUNkIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1Byb21pc2VCdG5EaXJlY3RpdmV9IGZyb20gJy4vcHJvbWlzZS1idG4uZGlyZWN0aXZlJztcbmltcG9ydCB7UHJvbWlzZUJ0bkNvbmZpZ30gZnJvbSAnLi9wcm9taXNlLWJ0bi1jb25maWcnO1xuaW1wb3J0IHt1c2VyQ2ZnfSBmcm9tICcuL3VzZXItY2ZnJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgUHJvbWlzZUJ0bkRpcmVjdGl2ZSxcbiAgXSxcbiAgaW1wb3J0czogW10sXG4gIGV4cG9ydHM6IFtcbiAgICBQcm9taXNlQnRuRGlyZWN0aXZlLFxuICBdLFxuICBwcm92aWRlcnM6IFtdXG59KVxuZXhwb3J0IGNsYXNzIEFuZ3VsYXIyUHJvbWlzZUJ1dHRvbk1vZHVsZSB7XG4gIC8vIGFkZCBmb3JSb290IHRvIG1ha2UgaXQgY29uZmlndXJhYmxlXG4gIHN0YXRpYyBmb3JSb290KGNvbmZpZz86IFByb21pc2VCdG5Db25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPEFuZ3VsYXIyUHJvbWlzZUJ1dHRvbk1vZHVsZT4ge1xuICAgIC8vIE5PVEU6IHRoaXMgaXMgbmV2ZXIgYWxsb3dlZCB0byBjb250YWluIGFueSBjb25kaXRpb25hbCBsb2dpY1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogQW5ndWxhcjJQcm9taXNlQnV0dG9uTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbe3Byb3ZpZGU6IHVzZXJDZmcsIHVzZVZhbHVlOiBjb25maWd9XVxuICAgIH07XG4gIH1cbn1cbiJdfQ==

@@ -1,5 +0,6 @@

import { Directive, ElementRef, HostListener, Inject, Input } from '@angular/core';
import { Directive, HostListener, Inject, Input } from '@angular/core';
import { Observable, Subscription } from 'rxjs';
import { DEFAULT_CFG } from './default-promise-btn-config';
import { userCfg } from './user-cfg';
import * as i0 from "@angular/core";
export class PromiseBtnDirective {

@@ -199,16 +200,21 @@ constructor(el, cfg) {

}
PromiseBtnDirective.decorators = [
{ type: Directive, args: [{
selector: '[promiseBtn]'
},] }
];
PromiseBtnDirective.ctorParameters = () => [
{ type: ElementRef },
{ type: undefined, decorators: [{ type: Inject, args: [userCfg,] }] }
];
PromiseBtnDirective.propDecorators = {
isDisabledFromTheOutsideSetter: [{ type: Input, args: ['disabled',] }],
promiseBtn: [{ type: Input }],
handleCurrentBtnOnly: [{ type: HostListener, args: ['click',] }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"promise-btn.directive.js","sourceRoot":"","sources":["../../../projects/angular2-promise-buttons/src/promise-btn.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterContentInit, Directive, ElementRef, HostListener, Inject, Input, OnDestroy} from '@angular/core';\nimport {Observable, Subscription} from 'rxjs';\nimport {DEFAULT_CFG} from './default-promise-btn-config';\nimport {PromiseBtnConfig} from './promise-btn-config';\nimport {userCfg} from './user-cfg';\n\n@Directive({\n  selector: '[promiseBtn]'\n})\n\nexport class PromiseBtnDirective implements OnDestroy, AfterContentInit {\n  cfg: PromiseBtnConfig;\n  // the timeout used for min duration display\n  minDurationTimeout: number;\n  // boolean to determine minDurationTimeout state\n  isMinDurationTimeoutDone: boolean;\n  // boolean to determine if promise was resolved\n  isPromiseDone: boolean;\n  // the promise button button element\n  btnEl: HTMLElement;\n  // the promise itself or a function expression\n  // NOTE: we need the type any here as we might deal with custom promises like bluebird\n  promise: any;\n\n  // this is added to fix the overriding of the disabled state by the loading indicator button.\n  // https://github.com/johannesjo/angular2-promise-buttons/issues/34\n  @Input('disabled')\n  set isDisabledFromTheOutsideSetter(v: boolean) {\n    this.isDisabledFromTheOutside = v;\n    if (v) {\n      // disabled means always disabled\n      this.btnEl.setAttribute('disabled', 'disabled');\n    } else if (this.isPromiseDone || this.isPromiseDone === undefined) {\n      this.btnEl.removeAttribute('disabled');\n    }\n    // else the button is loading, so do not change the disabled loading state.\n  }\n\n  isDisabledFromTheOutside: boolean;\n\n  private _fakePromiseResolve: () => void;\n\n  constructor(el: ElementRef,\n              @Inject(userCfg) cfg: PromiseBtnConfig) {\n    // provide configuration\n    this.cfg = Object.assign({}, DEFAULT_CFG, cfg);\n\n    // save element\n    this.btnEl = el.nativeElement;\n  }\n\n  @Input()\n  set promiseBtn(passedValue: any) {\n    const isObservable: boolean = passedValue instanceof Observable;\n    const isSubscription: boolean = passedValue instanceof Subscription;\n    const isBoolean: boolean = typeof passedValue === 'boolean';\n    const isPromise: boolean = passedValue instanceof Promise || (\n      passedValue !== null &&\n      typeof passedValue === 'object' &&\n      typeof passedValue.then === 'function' &&\n      typeof passedValue.catch === 'function'\n    );\n\n    if (isObservable) {\n      throw new TypeError('promiseBtn must be an instance of Subscription, instance of Observable given');\n    } else if (isSubscription) {\n      const sub: Subscription = passedValue;\n      if (!sub.closed) {\n        this.promise = new Promise((resolve) => {\n          sub.add(resolve);\n        });\n      }\n    } else if (isPromise) {\n      this.promise = passedValue;\n    } else if (isBoolean) {\n      this.promise = this.createPromiseFromBoolean(passedValue);\n    }\n\n    this.checkAndInitPromiseHandler(this.btnEl);\n  }\n\n  ngAfterContentInit() {\n    this.prepareBtnEl(this.btnEl);\n    // trigger changes once to handle initial promises\n    this.checkAndInitPromiseHandler(this.btnEl);\n  }\n\n  ngOnDestroy() {\n    // cleanup\n    if (this.minDurationTimeout) {\n      clearTimeout(this.minDurationTimeout);\n    }\n  }\n\n  createPromiseFromBoolean(val: boolean): Promise<any> {\n    if (val) {\n      return new Promise((resolve) => {\n        this._fakePromiseResolve = resolve;\n      });\n    } else {\n      if (this._fakePromiseResolve) {\n        this._fakePromiseResolve();\n      }\n      return this.promise;\n    }\n  }\n\n  /**\n   * Initializes all html and event handlers\n   */\n  prepareBtnEl(btnEl: HTMLElement) {\n    // handle promises passed via promiseBtn attribute\n    this.appendSpinnerTpl(btnEl);\n  }\n\n  /**\n   * Checks if all required parameters are there and inits the promise handler\n   */\n  checkAndInitPromiseHandler(btnEl: HTMLElement) {\n    // check if element and promise is set\n    if (btnEl && this.promise) {\n      this.initPromiseHandler(btnEl);\n    }\n  }\n\n  /**\n   * Helper FN to add class\n   */\n  addLoadingClass(el: any) {\n    if (typeof this.cfg.btnLoadingClass === 'string') {\n      el.classList.add(this.cfg.btnLoadingClass);\n    }\n  }\n\n  /**\n   * Helper FN to remove classes\n   */\n  removeLoadingClass(el: any) {\n    if (typeof this.cfg.btnLoadingClass === 'string') {\n      el.classList.remove(this.cfg.btnLoadingClass);\n    }\n  }\n\n  /**\n   * Handles everything to be triggered when the button is set\n   * to loading state.\n   */\n  initLoadingState(btnEl: HTMLElement) {\n    this.addLoadingClass(btnEl);\n    this.disableBtn(btnEl);\n  }\n\n  /**\n   * Handles everything to be triggered when loading is finished\n   */\n  cancelLoadingStateIfPromiseAndMinDurationDone(btnEl: HTMLElement) {\n    if ((!this.cfg.minDuration || this.isMinDurationTimeoutDone) && this.isPromiseDone) {\n      this.removeLoadingClass(btnEl);\n      this.enableBtn(btnEl);\n    }\n  }\n\n  disableBtn(btnEl: HTMLElement) {\n    if (this.cfg.disableBtn) {\n      btnEl.setAttribute('disabled', 'disabled');\n    }\n  }\n\n  enableBtn(btnEl: HTMLElement) {\n    if (this.cfg.disableBtn) {\n      if (this.isDisabledFromTheOutside) {\n        btnEl.setAttribute('disabled', 'disabled');\n      } else {\n        btnEl.removeAttribute('disabled');\n      }\n    }\n  }\n\n  /**\n   * Initializes a watcher for the promise. Also takes\n   * this.cfg.minDuration into account if given.\n   */\n\n  initPromiseHandler(btnEl: HTMLElement) {\n    const promise = this.promise;\n\n    // watch promise to resolve or fail\n    this.isMinDurationTimeoutDone = false;\n    this.isPromiseDone = false;\n\n    // create timeout if option is set\n    if (this.cfg.minDuration) {\n      this.minDurationTimeout = window.setTimeout(() => {\n        this.isMinDurationTimeoutDone = true;\n        this.cancelLoadingStateIfPromiseAndMinDurationDone(btnEl);\n      }, this.cfg.minDuration);\n    }\n\n    const resolveLoadingState = () => {\n      this.isPromiseDone = true;\n      this.cancelLoadingStateIfPromiseAndMinDurationDone(btnEl);\n    };\n\n    if (!this.cfg.handleCurrentBtnOnly) {\n      this.initLoadingState(btnEl);\n    }\n    // native Promise doesn't have finally\n    if (promise.finally) {\n      promise.finally(resolveLoadingState);\n    } else {\n      promise\n        .then(resolveLoadingState)\n        .catch(resolveLoadingState);\n    }\n\n  }\n\n\n  /**\n   * $compile and append the spinner template to the button.\n   */\n  appendSpinnerTpl(btnEl: HTMLElement) {\n    // TODO add some kind of compilation later on\n    btnEl.insertAdjacentHTML('beforeend', this.cfg.spinnerTpl as string);\n  }\n\n  /**\n   * Limit loading state to show only for the currently clicked button.\n   * Executed only if this.cfg.handleCurrentBtnOnly is set\n   */\n  @HostListener('click')\n  handleCurrentBtnOnly() {\n    if (!this.cfg.handleCurrentBtnOnly) {\n      return true; // return true for testing\n    }\n\n    // Click triggers @Input update\n    // We need to use timeout to wait for @Input to update\n    window.setTimeout(() => {\n      // return if something else than a promise is passed\n      if (!this.promise) {\n        return;\n      }\n\n      this.initLoadingState(this.btnEl);\n    }, 0);\n  }\n}\n"]}
PromiseBtnDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PromiseBtnDirective, deps: [{ token: i0.ElementRef }, { token: userCfg }], target: i0.ɵɵFactoryTarget.Directive });
PromiseBtnDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: PromiseBtnDirective, selector: "[promiseBtn]", inputs: { isDisabledFromTheOutsideSetter: ["disabled", "isDisabledFromTheOutsideSetter"], promiseBtn: "promiseBtn" }, host: { listeners: { "click": "handleCurrentBtnOnly()" } }, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PromiseBtnDirective, decorators: [{
type: Directive,
args: [{
selector: '[promiseBtn]'
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: undefined, decorators: [{
type: Inject,
args: [userCfg]
}] }]; }, propDecorators: { isDisabledFromTheOutsideSetter: [{
type: Input,
args: ['disabled']
}], promiseBtn: [{
type: Input
}], handleCurrentBtnOnly: [{
type: HostListener,
args: ['click']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"promise-btn.directive.js","sourceRoot":"","sources":["../../../projects/angular2-promise-buttons/src/promise-btn.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterContentInit, Directive, ElementRef, HostListener, Inject, Input, OnDestroy} from '@angular/core';\nimport {Observable, Subscription} from 'rxjs';\nimport {DEFAULT_CFG} from './default-promise-btn-config';\nimport {PromiseBtnConfig} from './promise-btn-config';\nimport {userCfg} from './user-cfg';\n\n@Directive({\n  selector: '[promiseBtn]'\n})\n\nexport class PromiseBtnDirective implements OnDestroy, AfterContentInit {\n  cfg: PromiseBtnConfig;\n  // the timeout used for min duration display\n  minDurationTimeout: number;\n  // boolean to determine minDurationTimeout state\n  isMinDurationTimeoutDone: boolean;\n  // boolean to determine if promise was resolved\n  isPromiseDone: boolean;\n  // the promise button button element\n  btnEl: HTMLElement;\n  // the promise itself or a function expression\n  // NOTE: we need the type any here as we might deal with custom promises like bluebird\n  promise: any;\n\n  // this is added to fix the overriding of the disabled state by the loading indicator button.\n  // https://github.com/johannesjo/angular2-promise-buttons/issues/34\n  @Input('disabled')\n  set isDisabledFromTheOutsideSetter(v: boolean) {\n    this.isDisabledFromTheOutside = v;\n    if (v) {\n      // disabled means always disabled\n      this.btnEl.setAttribute('disabled', 'disabled');\n    } else if (this.isPromiseDone || this.isPromiseDone === undefined) {\n      this.btnEl.removeAttribute('disabled');\n    }\n    // else the button is loading, so do not change the disabled loading state.\n  }\n\n  isDisabledFromTheOutside: boolean;\n\n  private _fakePromiseResolve: (value: void) => void;\n\n  constructor(el: ElementRef,\n              @Inject(userCfg) cfg: PromiseBtnConfig) {\n    // provide configuration\n    this.cfg = Object.assign({}, DEFAULT_CFG, cfg);\n\n    // save element\n    this.btnEl = el.nativeElement;\n  }\n\n  @Input()\n  set promiseBtn(passedValue: any) {\n    const isObservable: boolean = passedValue instanceof Observable;\n    const isSubscription: boolean = passedValue instanceof Subscription;\n    const isBoolean: boolean = typeof passedValue === 'boolean';\n    const isPromise: boolean = passedValue instanceof Promise || (\n      passedValue !== null &&\n      typeof passedValue === 'object' &&\n      typeof passedValue.then === 'function' &&\n      typeof passedValue.catch === 'function'\n    );\n\n    if (isObservable) {\n      throw new TypeError('promiseBtn must be an instance of Subscription, instance of Observable given');\n    } else if (isSubscription) {\n      const sub: Subscription = passedValue;\n      if (!sub.closed) {\n        this.promise = new Promise((resolve) => {\n          sub.add(resolve);\n        });\n      }\n    } else if (isPromise) {\n      this.promise = passedValue;\n    } else if (isBoolean) {\n      this.promise = this.createPromiseFromBoolean(passedValue);\n    }\n\n    this.checkAndInitPromiseHandler(this.btnEl);\n  }\n\n  ngAfterContentInit() {\n    this.prepareBtnEl(this.btnEl);\n    // trigger changes once to handle initial promises\n    this.checkAndInitPromiseHandler(this.btnEl);\n  }\n\n  ngOnDestroy() {\n    // cleanup\n    if (this.minDurationTimeout) {\n      clearTimeout(this.minDurationTimeout);\n    }\n  }\n\n  createPromiseFromBoolean(val: boolean): Promise<any> {\n    if (val) {\n      return new Promise((resolve) => {\n        this._fakePromiseResolve = resolve;\n      });\n    } else {\n      if (this._fakePromiseResolve) {\n        this._fakePromiseResolve();\n      }\n      return this.promise;\n    }\n  }\n\n  /**\n   * Initializes all html and event handlers\n   */\n  prepareBtnEl(btnEl: HTMLElement) {\n    // handle promises passed via promiseBtn attribute\n    this.appendSpinnerTpl(btnEl);\n  }\n\n  /**\n   * Checks if all required parameters are there and inits the promise handler\n   */\n  checkAndInitPromiseHandler(btnEl: HTMLElement) {\n    // check if element and promise is set\n    if (btnEl && this.promise) {\n      this.initPromiseHandler(btnEl);\n    }\n  }\n\n  /**\n   * Helper FN to add class\n   */\n  addLoadingClass(el: any) {\n    if (typeof this.cfg.btnLoadingClass === 'string') {\n      el.classList.add(this.cfg.btnLoadingClass);\n    }\n  }\n\n  /**\n   * Helper FN to remove classes\n   */\n  removeLoadingClass(el: any) {\n    if (typeof this.cfg.btnLoadingClass === 'string') {\n      el.classList.remove(this.cfg.btnLoadingClass);\n    }\n  }\n\n  /**\n   * Handles everything to be triggered when the button is set\n   * to loading state.\n   */\n  initLoadingState(btnEl: HTMLElement) {\n    this.addLoadingClass(btnEl);\n    this.disableBtn(btnEl);\n  }\n\n  /**\n   * Handles everything to be triggered when loading is finished\n   */\n  cancelLoadingStateIfPromiseAndMinDurationDone(btnEl: HTMLElement) {\n    if ((!this.cfg.minDuration || this.isMinDurationTimeoutDone) && this.isPromiseDone) {\n      this.removeLoadingClass(btnEl);\n      this.enableBtn(btnEl);\n    }\n  }\n\n  disableBtn(btnEl: HTMLElement) {\n    if (this.cfg.disableBtn) {\n      btnEl.setAttribute('disabled', 'disabled');\n    }\n  }\n\n  enableBtn(btnEl: HTMLElement) {\n    if (this.cfg.disableBtn) {\n      if (this.isDisabledFromTheOutside) {\n        btnEl.setAttribute('disabled', 'disabled');\n      } else {\n        btnEl.removeAttribute('disabled');\n      }\n    }\n  }\n\n  /**\n   * Initializes a watcher for the promise. Also takes\n   * this.cfg.minDuration into account if given.\n   */\n\n  initPromiseHandler(btnEl: HTMLElement) {\n    const promise = this.promise;\n\n    // watch promise to resolve or fail\n    this.isMinDurationTimeoutDone = false;\n    this.isPromiseDone = false;\n\n    // create timeout if option is set\n    if (this.cfg.minDuration) {\n      this.minDurationTimeout = window.setTimeout(() => {\n        this.isMinDurationTimeoutDone = true;\n        this.cancelLoadingStateIfPromiseAndMinDurationDone(btnEl);\n      }, this.cfg.minDuration);\n    }\n\n    const resolveLoadingState = () => {\n      this.isPromiseDone = true;\n      this.cancelLoadingStateIfPromiseAndMinDurationDone(btnEl);\n    };\n\n    if (!this.cfg.handleCurrentBtnOnly) {\n      this.initLoadingState(btnEl);\n    }\n    // native Promise doesn't have finally\n    if (promise.finally) {\n      promise.finally(resolveLoadingState);\n    } else {\n      promise\n        .then(resolveLoadingState)\n        .catch(resolveLoadingState);\n    }\n\n  }\n\n\n  /**\n   * $compile and append the spinner template to the button.\n   */\n  appendSpinnerTpl(btnEl: HTMLElement) {\n    // TODO add some kind of compilation later on\n    btnEl.insertAdjacentHTML('beforeend', this.cfg.spinnerTpl as string);\n  }\n\n  /**\n   * Limit loading state to show only for the currently clicked button.\n   * Executed only if this.cfg.handleCurrentBtnOnly is set\n   */\n  @HostListener('click')\n  handleCurrentBtnOnly() {\n    if (!this.cfg.handleCurrentBtnOnly) {\n      return true; // return true for testing\n    }\n\n    // Click triggers @Input update\n    // We need to use timeout to wait for @Input to update\n    window.setTimeout(() => {\n      // return if something else than a promise is passed\n      if (!this.promise) {\n        return;\n      }\n\n      this.initLoadingState(this.btnEl);\n    }, 0);\n  }\n}\n"]}

@@ -1,2 +0,3 @@

import { InjectionToken, Directive, ElementRef, Inject, Input, HostListener, NgModule } from '@angular/core';
import * as i0 from '@angular/core';
import { InjectionToken, Directive, Inject, Input, HostListener, NgModule } from '@angular/core';
import { Observable, Subscription } from 'rxjs';

@@ -208,16 +209,21 @@

}
PromiseBtnDirective.decorators = [
{ type: Directive, args: [{
selector: '[promiseBtn]'
},] }
];
PromiseBtnDirective.ctorParameters = () => [
{ type: ElementRef },
{ type: undefined, decorators: [{ type: Inject, args: [userCfg,] }] }
];
PromiseBtnDirective.propDecorators = {
isDisabledFromTheOutsideSetter: [{ type: Input, args: ['disabled',] }],
promiseBtn: [{ type: Input }],
handleCurrentBtnOnly: [{ type: HostListener, args: ['click',] }]
};
PromiseBtnDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PromiseBtnDirective, deps: [{ token: i0.ElementRef }, { token: userCfg }], target: i0.ɵɵFactoryTarget.Directive });
PromiseBtnDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: PromiseBtnDirective, selector: "[promiseBtn]", inputs: { isDisabledFromTheOutsideSetter: ["disabled", "isDisabledFromTheOutsideSetter"], promiseBtn: "promiseBtn" }, host: { listeners: { "click": "handleCurrentBtnOnly()" } }, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PromiseBtnDirective, decorators: [{
type: Directive,
args: [{
selector: '[promiseBtn]'
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: undefined, decorators: [{
type: Inject,
args: [userCfg]
}] }]; }, propDecorators: { isDisabledFromTheOutsideSetter: [{
type: Input,
args: ['disabled']
}], promiseBtn: [{
type: Input
}], handleCurrentBtnOnly: [{
type: HostListener,
args: ['click']
}] } });

@@ -234,14 +240,18 @@ class Angular2PromiseButtonModule {

}
Angular2PromiseButtonModule.decorators = [
{ type: NgModule, args: [{
declarations: [
PromiseBtnDirective,
],
imports: [],
exports: [
PromiseBtnDirective,
],
providers: []
},] }
];
Angular2PromiseButtonModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: Angular2PromiseButtonModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
Angular2PromiseButtonModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: Angular2PromiseButtonModule, declarations: [PromiseBtnDirective], exports: [PromiseBtnDirective] });
Angular2PromiseButtonModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: Angular2PromiseButtonModule, providers: [], imports: [[]] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: Angular2PromiseButtonModule, decorators: [{
type: NgModule,
args: [{
declarations: [
PromiseBtnDirective,
],
imports: [],
exports: [
PromiseBtnDirective,
],
providers: []
}]
}] });

@@ -252,3 +262,3 @@ /**

export { Angular2PromiseButtonModule, PromiseBtnDirective, userCfg as ɵa };
export { Angular2PromiseButtonModule, PromiseBtnDirective };
//# sourceMappingURL=angular2-promise-buttons.js.map
{
"name": "angular2-promise-buttons",
"version": "5.0.3",
"version": "6.0.0",
"description": "Chilled loading buttons for angular",

@@ -32,4 +32,3 @@ "author": "johannesjo <contact@super-productivity.com> (http://super-productivity.com)",

"typings": "angular2-promise-buttons.d.ts",
"metadata": "angular2-promise-buttons.metadata.json",
"sideEffects": false
}
import { AfterContentInit, ElementRef, OnDestroy } from '@angular/core';
import { PromiseBtnConfig } from './promise-btn-config';
import * as i0 from "@angular/core";
export declare class PromiseBtnDirective implements OnDestroy, AfterContentInit {

@@ -59,2 +60,4 @@ cfg: PromiseBtnConfig;

handleCurrentBtnOnly(): boolean;
static ɵfac: i0.ɵɵFactoryDeclaration<PromiseBtnDirective, never>;
static ɵdir: i0.ɵɵDirectiveDeclaration<PromiseBtnDirective, "[promiseBtn]", never, { "isDisabledFromTheOutsideSetter": "disabled"; "promiseBtn": "promiseBtn"; }, {}, never>;
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet