UNPKG

carbon-components-angular

Version:
184 lines 16.8 kB
import { Component, Input, Output, EventEmitter, HostBinding } from "@angular/core"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "carbon-components-angular/icon"; export var InlineLoadingState; (function (InlineLoadingState) { /** It hides the whole component. */ InlineLoadingState["Hidden"] = "hidden"; /** It shows the `loadingText` but no loading animation. */ InlineLoadingState["Inactive"] = "inactive"; /** It shows the `loadingText` with loading animation. */ InlineLoadingState["Active"] = "active"; /** It shows the `successText` with a success state. */ InlineLoadingState["Finished"] = "finished"; /** It shows the `errorText` with an error state. */ InlineLoadingState["Error"] = "error"; })(InlineLoadingState || (InlineLoadingState = {})); /** * Get started with importing the module: * * ```typescript * import { InlineLoadingModule } from 'carbon-components-angular'; * ``` * * [See demo](../../?path=/story/components-inline-loading--basic) */ export class InlineLoading { constructor() { this.InlineLoadingState = InlineLoadingState; /** * Specify the text description for the loading state. */ this.state = InlineLoadingState.Active; /** * Provide a delay for the `setTimeout` for success. */ this.successDelay = 1500; /** * Emits event after the success state is active */ this.onSuccess = new EventEmitter(); this.loadingClass = true; } /** * `aria-live` value applied to the host based on `state` (`'off'` for inactive states, `'assertive'` * otherwise). */ get hostAriaLive() { if (this.state === InlineLoadingState.Hidden) { return null; } return this.state === InlineLoadingState.Inactive ? "off" : "assertive"; } /** * set to `false` to stop the loading animation */ get isActive() { return this.state === InlineLoadingState.Active; } set isActive(active) { this.state = active ? InlineLoadingState.Active : InlineLoadingState.Inactive; } /** * Returns value `true` if the component is in the success state. */ get success() { return this.state === InlineLoadingState.Finished; } /** * Set the component's state to match the parameter and emits onSuccess if it exits. */ set success(success) { this.state = success ? InlineLoadingState.Finished : InlineLoadingState.Error; if (this.state === InlineLoadingState.Finished) { setTimeout(() => { this.onSuccess.emit(); }, this.successDelay); } } } InlineLoading.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: InlineLoading, deps: [], target: i0.ɵɵFactoryTarget.Component }); InlineLoading.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: InlineLoading, selector: "cds-inline-loading, ibm-inline-loading", inputs: { state: "state", loadingText: "loadingText", successText: "successText", successDelay: "successDelay", errorText: "errorText", iconDescription: "iconDescription", isActive: "isActive", success: "success" }, outputs: { onSuccess: "onSuccess" }, host: { properties: { "attr.aria-live": "this.hostAriaLive", "class.cds--inline-loading": "this.loadingClass" } }, ngImport: i0, template: ` <div *ngIf="state !== InlineLoadingState.Hidden" class="cds--inline-loading__animation"> <div *ngIf="state === InlineLoadingState.Inactive || state === InlineLoadingState.Active" class="cds--loading cds--loading--small" [ngClass]="{ 'cds--loading--stop': state === InlineLoadingState.Inactive }"> <svg class="cds--loading__svg" viewBox="0 0 100 100"> <title *ngIf="iconDescription">{{iconDescription}}</title> <circle class="cds--loading__background" cx="50%" cy="50%" r="44" /> <circle class="cds--loading__stroke" cx="50%" cy="50%" r="44" /> </svg> </div> <svg *ngIf="state === InlineLoadingState.Finished" cdsIcon="checkmark--filled" size="16" class="cds--inline-loading__checkmark-container" [attr.title]="iconDescription || null"> </svg> <svg *ngIf="state === InlineLoadingState.Error" cdsIcon="error--filled" size="16" class="cds--inline-loading--error" [attr.title]="iconDescription || null"> </svg> </div> <p *ngIf="state === InlineLoadingState.Inactive || state === InlineLoadingState.Active" class="cds--inline-loading__text">{{loadingText}}</p> <p *ngIf="state === InlineLoadingState.Finished" class="cds--inline-loading__text">{{successText}}</p> <p *ngIf="state === InlineLoadingState.Error" class="cds--inline-loading__text">{{errorText}}</p> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: InlineLoading, decorators: [{ type: Component, args: [{ selector: "cds-inline-loading, ibm-inline-loading", template: ` <div *ngIf="state !== InlineLoadingState.Hidden" class="cds--inline-loading__animation"> <div *ngIf="state === InlineLoadingState.Inactive || state === InlineLoadingState.Active" class="cds--loading cds--loading--small" [ngClass]="{ 'cds--loading--stop': state === InlineLoadingState.Inactive }"> <svg class="cds--loading__svg" viewBox="0 0 100 100"> <title *ngIf="iconDescription">{{iconDescription}}</title> <circle class="cds--loading__background" cx="50%" cy="50%" r="44" /> <circle class="cds--loading__stroke" cx="50%" cy="50%" r="44" /> </svg> </div> <svg *ngIf="state === InlineLoadingState.Finished" cdsIcon="checkmark--filled" size="16" class="cds--inline-loading__checkmark-container" [attr.title]="iconDescription || null"> </svg> <svg *ngIf="state === InlineLoadingState.Error" cdsIcon="error--filled" size="16" class="cds--inline-loading--error" [attr.title]="iconDescription || null"> </svg> </div> <p *ngIf="state === InlineLoadingState.Inactive || state === InlineLoadingState.Active" class="cds--inline-loading__text">{{loadingText}}</p> <p *ngIf="state === InlineLoadingState.Finished" class="cds--inline-loading__text">{{successText}}</p> <p *ngIf="state === InlineLoadingState.Error" class="cds--inline-loading__text">{{errorText}}</p> ` }] }], propDecorators: { state: [{ type: Input }], loadingText: [{ type: Input }], successText: [{ type: Input }], successDelay: [{ type: Input }], errorText: [{ type: Input }], iconDescription: [{ type: Input }], hostAriaLive: [{ type: HostBinding, args: ["attr.aria-live"] }], isActive: [{ type: Input }], success: [{ type: Input }], onSuccess: [{ type: Output }], loadingClass: [{ type: HostBinding, args: ["class.cds--inline-loading"] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-loading.component.js","sourceRoot":"","sources":["../../../src/inline-loading/inline-loading.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EACZ,WAAW,EACX,MAAM,eAAe,CAAC;;;;AAEvB,MAAM,CAAN,IAAY,kBAWX;AAXD,WAAY,kBAAkB;IAC7B,oCAAoC;IACpC,uCAAiB,CAAA;IACjB,2DAA2D;IAC3D,2CAAqB,CAAA;IACrB,yDAAyD;IACzD,uCAAiB,CAAA;IACjB,uDAAuD;IACvD,2CAAqB,CAAA;IACrB,oDAAoD;IACpD,qCAAe,CAAA;AAChB,CAAC,EAXW,kBAAkB,KAAlB,kBAAkB,QAW7B;AAED;;;;;;;;GAQG;AAwCH,MAAM,OAAO,aAAa;IAvC1B;QAwCC,uBAAkB,GAAG,kBAAkB,CAAC;QAExC;;WAEG;QACM,UAAK,GAAgC,kBAAkB,CAAC,MAAM,CAAC;QASxE;;WAEG;QACM,iBAAY,GAAG,IAAI,CAAC;QAgD7B;;WAEG;QACO,cAAS,GAAsB,IAAI,YAAY,EAAE,CAAC;QAElB,iBAAY,GAAG,IAAI,CAAC;KAC9D;IA5CA;;;OAGG;IACH,IAAmC,YAAY;QAC9C,IAAI,IAAI,CAAC,KAAK,KAAK,kBAAkB,CAAC,MAAM,EAAE;YAC7C,OAAO,IAAI,CAAC;SACZ;QACD,OAAO,IAAI,CAAC,KAAK,KAAK,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC;IACzE,CAAC;IACD;;OAEG;IACH,IAAa,QAAQ;QACpB,OAAO,IAAI,CAAC,KAAK,KAAK,kBAAkB,CAAC,MAAM,CAAC;IACjD,CAAC;IACD,IAAI,QAAQ,CAAC,MAAe;QAC3B,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,kBAAkB,CAAC,QAAQ,CAAC;IAC/E,CAAC;IAED;;OAEG;IACH,IAAa,OAAO;QACnB,OAAO,IAAI,CAAC,KAAK,KAAK,kBAAkB,CAAC,QAAQ,CAAC;IACnD,CAAC;IACD;;OAEG;IACH,IAAI,OAAO,CAAC,OAAgB;QAC3B,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAC,kBAAkB,CAAC,KAAK,CAAC;QAC9E,IAAI,IAAI,CAAC,KAAK,KAAK,kBAAkB,CAAC,QAAQ,EAAE;YAC/C,UAAU,CAAC,GAAG,EAAE;gBACf,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;YACvB,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SACtB;IACF,CAAC;;0GAhEW,aAAa;8FAAb,aAAa,8bArCf;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmCT;2FAEW,aAAa;kBAvCzB,SAAS;mBAAC;oBACV,QAAQ,EAAE,wCAAwC;oBAClD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmCT;iBACD;8BAOS,KAAK;sBAAb,KAAK;gBAIG,WAAW;sBAAnB,KAAK;gBAIG,WAAW;sBAAnB,KAAK;gBAIG,YAAY;sBAApB,KAAK;gBAIG,SAAS;sBAAjB,KAAK;gBAIG,eAAe;sBAAvB,KAAK;gBAM6B,YAAY;sBAA9C,WAAW;uBAAC,gBAAgB;gBAShB,QAAQ;sBAApB,KAAK;gBAUO,OAAO;sBAAnB,KAAK;gBAkBI,SAAS;sBAAlB,MAAM;gBAEmC,YAAY;sBAArD,WAAW;uBAAC,2BAA2B","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tOutput,\n\tEventEmitter,\n\tHostBinding\n} from \"@angular/core\";\n\nexport enum InlineLoadingState {\n\t/** It hides the whole component. */\n\tHidden = \"hidden\",\n\t/** It shows the `loadingText` but no loading animation. */\n\tInactive = \"inactive\",\n\t/** It shows the `loadingText` with loading animation. */\n\tActive = \"active\",\n\t/** It shows the `successText` with a success state. */\n\tFinished = \"finished\",\n\t/** It shows the `errorText` with an error state. */\n\tError = \"error\"\n}\n\n/**\n * Get started with importing the module:\n *\n * ```typescript\n * import { InlineLoadingModule } from 'carbon-components-angular';\n * ```\n *\n * [See demo](../../?path=/story/components-inline-loading--basic)\n */\n@Component({\n\tselector: \"cds-inline-loading, ibm-inline-loading\",\n\ttemplate: `\n\t\t<div *ngIf=\"state !== InlineLoadingState.Hidden\"\n\t\t\tclass=\"cds--inline-loading__animation\">\n\t\t\t<div\n\t\t\t\t*ngIf=\"state === InlineLoadingState.Inactive || state === InlineLoadingState.Active\"\n\t\t\t\tclass=\"cds--loading cds--loading--small\"\n\t\t\t\t[ngClass]=\"{\n\t\t\t\t\t'cds--loading--stop': state === InlineLoadingState.Inactive\n\t\t\t\t}\">\n\t\t\t\t<svg class=\"cds--loading__svg\" viewBox=\"0 0 100 100\">\n\t\t\t\t\t<title *ngIf=\"iconDescription\">{{iconDescription}}</title>\n\t\t\t\t\t<circle class=\"cds--loading__background\" cx=\"50%\" cy=\"50%\" r=\"44\" />\n\t\t\t\t\t<circle class=\"cds--loading__stroke\" cx=\"50%\" cy=\"50%\" r=\"44\" />\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t\t<svg\n\t\t\t\t*ngIf=\"state === InlineLoadingState.Finished\"\n\t\t\t\tcdsIcon=\"checkmark--filled\"\n\t\t\t\tsize=\"16\"\n\t\t\t\tclass=\"cds--inline-loading__checkmark-container\"\n\t\t\t\t[attr.title]=\"iconDescription || null\">\n\t\t\t</svg>\n\t\t\t<svg\n\t\t\t\t*ngIf=\"state === InlineLoadingState.Error\"\n\t\t\t\tcdsIcon=\"error--filled\"\n\t\t\t\tsize=\"16\"\n\t\t\t\tclass=\"cds--inline-loading--error\"\n\t\t\t\t[attr.title]=\"iconDescription || null\">\n\t\t\t</svg>\n\t\t</div>\n\t\t<p\n\t\t\t*ngIf=\"state === InlineLoadingState.Inactive || state === InlineLoadingState.Active\"\n\t\t\tclass=\"cds--inline-loading__text\">{{loadingText}}</p>\n\t\t<p *ngIf=\"state === InlineLoadingState.Finished\" class=\"cds--inline-loading__text\">{{successText}}</p>\n\t\t<p *ngIf=\"state === InlineLoadingState.Error\" class=\"cds--inline-loading__text\">{{errorText}}</p>\n\t`\n})\nexport class InlineLoading {\n\tInlineLoadingState = InlineLoadingState;\n\n\t/**\n\t * Specify the text description for the loading state.\n\t */\n\t@Input() state: InlineLoadingState | string = InlineLoadingState.Active;\n\t/**\n\t * Specify the text description for the loading state.\n\t */\n\t@Input() loadingText: string;\n\t/**\n\t * Specify the text description for the success state.\n\t */\n\t@Input() successText: string;\n\t/**\n\t * Provide a delay for the `setTimeout` for success.\n\t */\n\t@Input() successDelay = 1500;\n\t/**\n\t * Specify the text description for the error state.\n\t */\n\t@Input() errorText: string;\n\t/**\n\t * Accessible description applied to the loading/success/error SVG.\n\t */\n\t@Input() iconDescription: string;\n\n\t/**\n\t * `aria-live` value applied to the host based on `state` (`'off'` for inactive states, `'assertive'`\n\t * otherwise).\n\t */\n\t@HostBinding(\"attr.aria-live\") get hostAriaLive(): string | null {\n\t\tif (this.state === InlineLoadingState.Hidden) {\n\t\t\treturn null;\n\t\t}\n\t\treturn this.state === InlineLoadingState.Inactive ? \"off\" : \"assertive\";\n\t}\n\t/**\n\t * set to `false` to stop the loading animation\n\t */\n\t@Input() get isActive() {\n\t\treturn this.state === InlineLoadingState.Active;\n\t}\n\tset isActive(active: boolean) {\n\t\tthis.state = active ? InlineLoadingState.Active : InlineLoadingState.Inactive;\n\t}\n\n\t/**\n\t * Returns value `true` if the component is in the success state.\n\t */\n\t@Input() get success() {\n\t\treturn this.state === InlineLoadingState.Finished;\n\t}\n\t/**\n\t * Set the component's state to match the parameter and emits onSuccess if it exits.\n\t */\n\tset success(success: boolean) {\n\t\tthis.state = success ? InlineLoadingState.Finished : InlineLoadingState.Error;\n\t\tif (this.state === InlineLoadingState.Finished) {\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.onSuccess.emit();\n\t\t\t}, this.successDelay);\n\t\t}\n\t}\n\n\t/**\n\t * Emits event after the success state is active\n\t */\n\t@Output() onSuccess: EventEmitter<any> = new EventEmitter();\n\n\t@HostBinding(\"class.cds--inline-loading\") loadingClass = true;\n}\n"]}