@byuhbll/components 4.3.2 → 4.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/snackbar/snackbar.component.mjs +151 -0
- package/esm2022/lib/snackbar/snackbar.service.mjs +90 -0
- package/esm2022/lib/status-button/status-button.component.mjs +13 -3
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/byuhbll-components.mjs +249 -5
- package/fesm2022/byuhbll-components.mjs.map +1 -1
- package/lib/snackbar/snackbar.component.d.ts +67 -0
- package/lib/snackbar/snackbar.service.d.ts +20 -0
- package/lib/status-button/status-button.component.d.ts +15 -1
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/styles/scss/_vars.scss +10 -0
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, booleanAttribute, } from '@angular/core';
|
|
2
|
+
import { NgClass } from '@angular/common';
|
|
3
|
+
import { StatusButtonComponent, } from '../status-button/status-button.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
const purposeToStatusMap = {
|
|
6
|
+
default: 'info',
|
|
7
|
+
info: 'info',
|
|
8
|
+
success: 'success',
|
|
9
|
+
error: 'error',
|
|
10
|
+
warning: 'warning',
|
|
11
|
+
};
|
|
12
|
+
export class SnackbarComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.purpose = 'default';
|
|
15
|
+
this.title = 'Snackbar Title';
|
|
16
|
+
this.description = 'Lorem ipsum';
|
|
17
|
+
this.fieldPlaceholder = 'Placeholder';
|
|
18
|
+
this.titleIcon = 'info';
|
|
19
|
+
this.showTitle = true;
|
|
20
|
+
this.showTitleIcon = true;
|
|
21
|
+
this.titleIconFilled = false;
|
|
22
|
+
this.showClose = true;
|
|
23
|
+
this.showProgressBar = true;
|
|
24
|
+
this.showField = true;
|
|
25
|
+
this.showButton = true;
|
|
26
|
+
this.autoDismiss = true;
|
|
27
|
+
this.visible = true;
|
|
28
|
+
this.progressMs = 5000;
|
|
29
|
+
this.y = 24;
|
|
30
|
+
this.closed = new EventEmitter();
|
|
31
|
+
this.visibleChange = new EventEmitter();
|
|
32
|
+
this.buttonClicked = new EventEmitter();
|
|
33
|
+
this.isOpen = false;
|
|
34
|
+
this.EXIT_MS = 300;
|
|
35
|
+
}
|
|
36
|
+
ngOnInit() {
|
|
37
|
+
if (this.visible) {
|
|
38
|
+
// enter on next tick
|
|
39
|
+
setTimeout(() => (this.isOpen = true), 0);
|
|
40
|
+
this.startDismissTimer();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
ngOnChanges(changes) {
|
|
44
|
+
if ('visible' in changes) {
|
|
45
|
+
// when parent toggles visible
|
|
46
|
+
if (this.visible) {
|
|
47
|
+
// becoming visible -> open + (re)start timer
|
|
48
|
+
this.isOpen = false;
|
|
49
|
+
setTimeout(() => (this.isOpen = true), 0);
|
|
50
|
+
this.startDismissTimer();
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
// becoming hidden -> stop timers and ensure closed state
|
|
54
|
+
this.clearDismissTimer();
|
|
55
|
+
this.isOpen = false;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
ngOnDestroy() {
|
|
60
|
+
this.clearDismissTimer();
|
|
61
|
+
}
|
|
62
|
+
// used by the × button, done button, and auto-dismiss
|
|
63
|
+
close(emitButtonClicked = false) {
|
|
64
|
+
if (!this.isOpen && !this.visible)
|
|
65
|
+
return;
|
|
66
|
+
this.clearDismissTimer();
|
|
67
|
+
this.isOpen = false; // triggers exit transition
|
|
68
|
+
// after exit animation, hide + notify
|
|
69
|
+
window.setTimeout(() => {
|
|
70
|
+
if (this.visible) {
|
|
71
|
+
this.visible = false;
|
|
72
|
+
this.visibleChange.emit(false);
|
|
73
|
+
}
|
|
74
|
+
if (emitButtonClicked) {
|
|
75
|
+
this.buttonClicked.emit();
|
|
76
|
+
}
|
|
77
|
+
this.closed.emit();
|
|
78
|
+
}, this.EXIT_MS);
|
|
79
|
+
}
|
|
80
|
+
get status() {
|
|
81
|
+
return purposeToStatusMap[this.purpose];
|
|
82
|
+
}
|
|
83
|
+
startDismissTimer() {
|
|
84
|
+
if (!this.autoDismiss)
|
|
85
|
+
return;
|
|
86
|
+
this.clearDismissTimer();
|
|
87
|
+
this.dismissTimer = window.setTimeout(() => this.close(), this.progressMs);
|
|
88
|
+
}
|
|
89
|
+
clearDismissTimer() {
|
|
90
|
+
if (this.dismissTimer) {
|
|
91
|
+
clearTimeout(this.dismissTimer);
|
|
92
|
+
this.dismissTimer = undefined;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: SnackbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
96
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: SnackbarComponent, isStandalone: true, selector: "lib-snackbar", inputs: { purpose: "purpose", title: "title", description: "description", fieldPlaceholder: "fieldPlaceholder", titleIcon: "titleIcon", showTitle: ["showTitle", "showTitle", booleanAttribute], showTitleIcon: ["showTitleIcon", "showTitleIcon", booleanAttribute], titleIconFilled: ["titleIconFilled", "titleIconFilled", booleanAttribute], showClose: ["showClose", "showClose", booleanAttribute], showProgressBar: ["showProgressBar", "showProgressBar", booleanAttribute], showField: ["showField", "showField", booleanAttribute], showButton: ["showButton", "showButton", booleanAttribute], autoDismiss: ["autoDismiss", "autoDismiss", booleanAttribute], visible: ["visible", "visible", booleanAttribute], progressMs: "progressMs", y: "y", statusButtonInputs: "statusButtonInputs" }, outputs: { closed: "closed", visibleChange: "visibleChange", buttonClicked: "buttonClicked" }, usesOnChanges: true, ngImport: i0, template: "@if (visible) {\n <section\n class=\"snackbar\"\n [ngClass]=\"{\n 'is-default': purpose === 'default',\n 'is-info': purpose === 'info',\n 'is-success': purpose === 'success',\n 'is-error': purpose === 'error',\n 'is-warning': purpose === 'warning',\n 'is-open': isOpen,\n }\"\n role=\"status\"\n aria-live=\"polite\"\n [style.--snackbar-progress-duration]=\"progressMs + 'ms'\"\n [style.top.px]=\"y\"\n >\n <div class=\"snackbar__left\">\n @if(showTitle) {\n <div class=\"snackbar__title-row\">\n <span \n [ngClass]=\"{\n 'snackbar__title-icon': true,\n 'has-icon': showTitle && showTitleIcon\n }\"\n aria-hidden=\"true\"\n >\n @if (showTitle && showTitleIcon) {\n <i [ngClass]=\"titleIconFilled ? 'material-icons' : 'material-icons-outlined'\"\n id=\"snackbar-title-icon\"\n aria-hidden=\"true\"\n >\n {{ titleIcon }}\n </i>\n }\n </span>\n @if (showTitle) {\n <h3 class=\"snackbar__title\">{{ title }}</h3>\n }\n </div>\n }\n <p class=\"snackbar__desc\">\n {{ description }}\n </p>\n @if (showField) {\n <input class=\"snackbar__input\" type=\"text\" [placeholder]=\"fieldPlaceholder\" />\n }\n @if (showButton) {\n <lib-status-button\n label={{statusButtonInputs?.label}}\n [status]=\"status\"\n leftIcon={{statusButtonInputs?.leftIcon}}\n rightIcon={{statusButtonInputs?.rightIcon}}\n [hideLeftIcon]=\"statusButtonInputs?.hideLeftIcon\"\n [hideRightIcon]=\"statusButtonInputs?.hideRightIcon\"\n [clearVariant]=\"statusButtonInputs?.clearVariant\"\n (click)=\"close(true)\"\n ></lib-status-button>\n\n }\n </div>\n <button \n type=\"button\"\n (click)=\"close()\"\n class=\"snackbar__close\"\n aria-label=\"Dismiss\"\n [style.visibility]=\"showClose ? 'visible' : 'hidden'\"\n >\n \u00D7\n </button>\n @if (showProgressBar) {\n <div class=\"snackbar__progress\">\n <div class=\"snackbar__progress-fill\"></div>\n </div>\n }\n </section>\n}\n", styles: [":root{--border-radius-md: 4px;--colors-border-primary: #d0d0d0;--colors-surface-primary: white;--colors-border-information: #457fa6;--colors-surface-information: #ecf2f6;--colors-border-success: #3ba35a;--colors-surface-success: #ebf6ee;--colors-border-warning: #d1c844;--colors-surface-warning: #faf9ec;--colors-border-error: #c73e3d;--colors-surface-error: #f9ecec}.snackbar{--snackbar-border-color: var(--colors-border-primary);--snackbar-bg: var(--colors-surface-primary);--snackbar-text: #141414;--snackbar-title-color: var(--snackbar-text);--snackbar-icon-bg: #e5edf8;--snackbar-accent: #0047ba;--snackbar-input-border: var(--snackbar-border-color);--snackbar-progress: var(--snackbar-accent);display:flex;width:26.25rem;padding:1.25rem 1rem;justify-content:space-between;align-items:flex-start;gap:.25rem;position:relative;border-radius:var(--border-radius-md, 4px);border:1px solid var(--snackbar-border-color);background:var(--snackbar-bg);box-shadow:1px 1px 4px #00000040;color:var(--snackbar-text)}.snackbar__left{display:grid;gap:.5rem;flex:1 1 auto}.snackbar__left>.snackbar__title-row~*{margin-left:var(--snackbar-right-gutter, 1.85rem)}.snackbar__title-row{display:flex;align-items:center;gap:.25rem}.snackbar__title{margin:0;font-weight:400;font-size:1.2rem;line-height:1.2;color:var(--snackbar-title-color)}.snackbar__title-icon{display:inline-flex;align-items:center;justify-content:center;width:1.5em;height:1.5em}.snackbar__title-icon.has-icon{border-radius:50%;color:var(--snackbar-accent)}.snackbar__icon{font-weight:700;font-size:1rem;line-height:1}.snackbar__desc{margin:0;opacity:.9}.snackbar__input{width:100%;max-width:100%;box-sizing:border-box;padding:.5em;border-radius:4px;border:1px solid var(--snackbar-input-border);background:#fff;color:inherit}.snackbar__close{margin-left:.5em;border:0;background:transparent;color:inherit;opacity:.7;font-size:1.5rem;padding:.25rem;line-height:1;cursor:pointer}.snackbar__progress{position:absolute;left:0;right:0;bottom:-1px;height:4px;overflow:hidden;border-bottom-left-radius:inherit;border-bottom-right-radius:inherit}.snackbar__progress-fill{height:100%;width:0%;background:var(--snackbar-progress);animation:fill var(--snackbar-progress-duration, 4s) linear forwards}@keyframes fill{to{width:100%}}.snackbar.is-default{--snackbar-border-color: var(--colors-border-primary, #d0d0d0);--snackbar-bg: var(--colors-surface-primary, white);--snackbar-text: #141414;--snackbar-title-color: #003995;--snackbar-icon-bg: #e5edf8;--snackbar-accent: #003995;--snackbar-input-border: #d0d0d0;--snackbar-progress: #003995}.snackbar.is-info{--snackbar-border-color: var(--colors-border-information, #457fa6);--snackbar-bg: var(--colors-surface-information, #ecf2f6);--snackbar-text: #24495c;--snackbar-title-color: #24495c;--snackbar-icon-bg: #a2bfd3;--snackbar-accent: #306a88;--snackbar-input-border: #a2bfd3;--snackbar-progress: #306a88}.snackbar.is-success{--snackbar-border-color: var(--colors-border-success, #3ba35a);--snackbar-bg: var(--colors-surface-success, #ebf6ee);--snackbar-text: #20522e;--snackbar-title-color: #20522e;--snackbar-icon-bg: #9dd1ac;--snackbar-accent: #2e7d3f;--snackbar-input-border: #9dd1ac;--snackbar-progress: #2e7d3f}.snackbar.is-warning{--snackbar-border-color: var(--colors-border-warning, #d1c844);--snackbar-bg: var(--colors-surface-warning, #faf9ec);--snackbar-text: #514a18;--snackbar-title-color: #514a18;--snackbar-icon-bg: #e8e3a1;--snackbar-accent: #7a6f13;--snackbar-input-border: #d1c844;--snackbar-progress: #7a6f13}.snackbar.is-error{--snackbar-border-color: var(--colors-border-error, #c73e3d);--snackbar-bg: var(--colors-surface-error, #f9ecec);--snackbar-text: #611a1a;--snackbar-title-color: #611a1a;--snackbar-icon-bg: #e39e9e;--snackbar-accent: #912525;--snackbar-input-border: #c73e3d;--snackbar-progress: #912525}.snackbar{position:fixed;top:24px;right:24px;z-index:1000;transform:translate(120%);transition:transform .6s ease}.snackbar.is-open{transform:translate(0)}lib-status-button{--status-button-padding: .25em .5em .25em 0}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: StatusButtonComponent, selector: "lib-status-button", inputs: ["label", "status", "leftIcon", "rightIcon", "hideLeftIcon", "hideRightIcon", "clearVariant"] }] }); }
|
|
97
|
+
}
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: SnackbarComponent, decorators: [{
|
|
99
|
+
type: Component,
|
|
100
|
+
args: [{ selector: 'lib-snackbar', standalone: true, imports: [NgClass, StatusButtonComponent], template: "@if (visible) {\n <section\n class=\"snackbar\"\n [ngClass]=\"{\n 'is-default': purpose === 'default',\n 'is-info': purpose === 'info',\n 'is-success': purpose === 'success',\n 'is-error': purpose === 'error',\n 'is-warning': purpose === 'warning',\n 'is-open': isOpen,\n }\"\n role=\"status\"\n aria-live=\"polite\"\n [style.--snackbar-progress-duration]=\"progressMs + 'ms'\"\n [style.top.px]=\"y\"\n >\n <div class=\"snackbar__left\">\n @if(showTitle) {\n <div class=\"snackbar__title-row\">\n <span \n [ngClass]=\"{\n 'snackbar__title-icon': true,\n 'has-icon': showTitle && showTitleIcon\n }\"\n aria-hidden=\"true\"\n >\n @if (showTitle && showTitleIcon) {\n <i [ngClass]=\"titleIconFilled ? 'material-icons' : 'material-icons-outlined'\"\n id=\"snackbar-title-icon\"\n aria-hidden=\"true\"\n >\n {{ titleIcon }}\n </i>\n }\n </span>\n @if (showTitle) {\n <h3 class=\"snackbar__title\">{{ title }}</h3>\n }\n </div>\n }\n <p class=\"snackbar__desc\">\n {{ description }}\n </p>\n @if (showField) {\n <input class=\"snackbar__input\" type=\"text\" [placeholder]=\"fieldPlaceholder\" />\n }\n @if (showButton) {\n <lib-status-button\n label={{statusButtonInputs?.label}}\n [status]=\"status\"\n leftIcon={{statusButtonInputs?.leftIcon}}\n rightIcon={{statusButtonInputs?.rightIcon}}\n [hideLeftIcon]=\"statusButtonInputs?.hideLeftIcon\"\n [hideRightIcon]=\"statusButtonInputs?.hideRightIcon\"\n [clearVariant]=\"statusButtonInputs?.clearVariant\"\n (click)=\"close(true)\"\n ></lib-status-button>\n\n }\n </div>\n <button \n type=\"button\"\n (click)=\"close()\"\n class=\"snackbar__close\"\n aria-label=\"Dismiss\"\n [style.visibility]=\"showClose ? 'visible' : 'hidden'\"\n >\n \u00D7\n </button>\n @if (showProgressBar) {\n <div class=\"snackbar__progress\">\n <div class=\"snackbar__progress-fill\"></div>\n </div>\n }\n </section>\n}\n", styles: [":root{--border-radius-md: 4px;--colors-border-primary: #d0d0d0;--colors-surface-primary: white;--colors-border-information: #457fa6;--colors-surface-information: #ecf2f6;--colors-border-success: #3ba35a;--colors-surface-success: #ebf6ee;--colors-border-warning: #d1c844;--colors-surface-warning: #faf9ec;--colors-border-error: #c73e3d;--colors-surface-error: #f9ecec}.snackbar{--snackbar-border-color: var(--colors-border-primary);--snackbar-bg: var(--colors-surface-primary);--snackbar-text: #141414;--snackbar-title-color: var(--snackbar-text);--snackbar-icon-bg: #e5edf8;--snackbar-accent: #0047ba;--snackbar-input-border: var(--snackbar-border-color);--snackbar-progress: var(--snackbar-accent);display:flex;width:26.25rem;padding:1.25rem 1rem;justify-content:space-between;align-items:flex-start;gap:.25rem;position:relative;border-radius:var(--border-radius-md, 4px);border:1px solid var(--snackbar-border-color);background:var(--snackbar-bg);box-shadow:1px 1px 4px #00000040;color:var(--snackbar-text)}.snackbar__left{display:grid;gap:.5rem;flex:1 1 auto}.snackbar__left>.snackbar__title-row~*{margin-left:var(--snackbar-right-gutter, 1.85rem)}.snackbar__title-row{display:flex;align-items:center;gap:.25rem}.snackbar__title{margin:0;font-weight:400;font-size:1.2rem;line-height:1.2;color:var(--snackbar-title-color)}.snackbar__title-icon{display:inline-flex;align-items:center;justify-content:center;width:1.5em;height:1.5em}.snackbar__title-icon.has-icon{border-radius:50%;color:var(--snackbar-accent)}.snackbar__icon{font-weight:700;font-size:1rem;line-height:1}.snackbar__desc{margin:0;opacity:.9}.snackbar__input{width:100%;max-width:100%;box-sizing:border-box;padding:.5em;border-radius:4px;border:1px solid var(--snackbar-input-border);background:#fff;color:inherit}.snackbar__close{margin-left:.5em;border:0;background:transparent;color:inherit;opacity:.7;font-size:1.5rem;padding:.25rem;line-height:1;cursor:pointer}.snackbar__progress{position:absolute;left:0;right:0;bottom:-1px;height:4px;overflow:hidden;border-bottom-left-radius:inherit;border-bottom-right-radius:inherit}.snackbar__progress-fill{height:100%;width:0%;background:var(--snackbar-progress);animation:fill var(--snackbar-progress-duration, 4s) linear forwards}@keyframes fill{to{width:100%}}.snackbar.is-default{--snackbar-border-color: var(--colors-border-primary, #d0d0d0);--snackbar-bg: var(--colors-surface-primary, white);--snackbar-text: #141414;--snackbar-title-color: #003995;--snackbar-icon-bg: #e5edf8;--snackbar-accent: #003995;--snackbar-input-border: #d0d0d0;--snackbar-progress: #003995}.snackbar.is-info{--snackbar-border-color: var(--colors-border-information, #457fa6);--snackbar-bg: var(--colors-surface-information, #ecf2f6);--snackbar-text: #24495c;--snackbar-title-color: #24495c;--snackbar-icon-bg: #a2bfd3;--snackbar-accent: #306a88;--snackbar-input-border: #a2bfd3;--snackbar-progress: #306a88}.snackbar.is-success{--snackbar-border-color: var(--colors-border-success, #3ba35a);--snackbar-bg: var(--colors-surface-success, #ebf6ee);--snackbar-text: #20522e;--snackbar-title-color: #20522e;--snackbar-icon-bg: #9dd1ac;--snackbar-accent: #2e7d3f;--snackbar-input-border: #9dd1ac;--snackbar-progress: #2e7d3f}.snackbar.is-warning{--snackbar-border-color: var(--colors-border-warning, #d1c844);--snackbar-bg: var(--colors-surface-warning, #faf9ec);--snackbar-text: #514a18;--snackbar-title-color: #514a18;--snackbar-icon-bg: #e8e3a1;--snackbar-accent: #7a6f13;--snackbar-input-border: #d1c844;--snackbar-progress: #7a6f13}.snackbar.is-error{--snackbar-border-color: var(--colors-border-error, #c73e3d);--snackbar-bg: var(--colors-surface-error, #f9ecec);--snackbar-text: #611a1a;--snackbar-title-color: #611a1a;--snackbar-icon-bg: #e39e9e;--snackbar-accent: #912525;--snackbar-input-border: #c73e3d;--snackbar-progress: #912525}.snackbar{position:fixed;top:24px;right:24px;z-index:1000;transform:translate(120%);transition:transform .6s ease}.snackbar.is-open{transform:translate(0)}lib-status-button{--status-button-padding: .25em .5em .25em 0}\n"] }]
|
|
101
|
+
}], propDecorators: { purpose: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}], title: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], description: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], fieldPlaceholder: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], titleIcon: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], showTitle: [{
|
|
112
|
+
type: Input,
|
|
113
|
+
args: [{ transform: booleanAttribute }]
|
|
114
|
+
}], showTitleIcon: [{
|
|
115
|
+
type: Input,
|
|
116
|
+
args: [{ transform: booleanAttribute }]
|
|
117
|
+
}], titleIconFilled: [{
|
|
118
|
+
type: Input,
|
|
119
|
+
args: [{ transform: booleanAttribute }]
|
|
120
|
+
}], showClose: [{
|
|
121
|
+
type: Input,
|
|
122
|
+
args: [{ transform: booleanAttribute }]
|
|
123
|
+
}], showProgressBar: [{
|
|
124
|
+
type: Input,
|
|
125
|
+
args: [{ transform: booleanAttribute }]
|
|
126
|
+
}], showField: [{
|
|
127
|
+
type: Input,
|
|
128
|
+
args: [{ transform: booleanAttribute }]
|
|
129
|
+
}], showButton: [{
|
|
130
|
+
type: Input,
|
|
131
|
+
args: [{ transform: booleanAttribute }]
|
|
132
|
+
}], autoDismiss: [{
|
|
133
|
+
type: Input,
|
|
134
|
+
args: [{ transform: booleanAttribute }]
|
|
135
|
+
}], visible: [{
|
|
136
|
+
type: Input,
|
|
137
|
+
args: [{ transform: booleanAttribute }]
|
|
138
|
+
}], progressMs: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], y: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], statusButtonInputs: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], closed: [{
|
|
145
|
+
type: Output
|
|
146
|
+
}], visibleChange: [{
|
|
147
|
+
type: Output
|
|
148
|
+
}], buttonClicked: [{
|
|
149
|
+
type: Output
|
|
150
|
+
}] } });
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"","sources":["../../../../../projects/components/src/lib/snackbar/snackbar.component.ts","../../../../../projects/components/src/lib/snackbar/snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    Input,\n    Output,\n    SimpleChanges,\n    OnInit,\n    OnChanges,\n    OnDestroy,\n    booleanAttribute,\n} from '@angular/core';\nimport { NgClass } from '@angular/common';\nimport {\n    StatusButtonComponent,\n    Status,\n    StatusButtonInputs,\n} from '../status-button/status-button.component';\n\nexport type SnackbarPurpose = 'default' | 'info' | 'success' | 'error' | 'warning';\n\nexport interface SnackbarInputs {\n    purpose?: SnackbarPurpose;\n    title?: string;\n    description?: string;\n    titleIcon?: string;\n    fieldPlaceholder?: string;\n    showTitle?: boolean;\n    showTitleIcon?: boolean;\n    titleIconFilled?: boolean;\n    showClose?: boolean;\n    showProgressBar?: boolean;\n    showField?: boolean;\n    showButton?: boolean;\n    progressMs?: number;\n    autoDismiss?: boolean;\n    y?: number;\n    right?: number;\n    zIndex?: number;\n    statusButtonInputs?: StatusButtonInputs;\n}\n\nconst purposeToStatusMap: Record<SnackbarPurpose, Status> = {\n    default: 'info',\n    info: 'info',\n    success: 'success',\n    error: 'error',\n    warning: 'warning',\n};\n\n@Component({\n    selector: 'lib-snackbar',\n    standalone: true,\n    imports: [NgClass, StatusButtonComponent],\n    templateUrl: './snackbar.component.html',\n    styleUrl: './snackbar.component.scss',\n})\nexport class SnackbarComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() purpose: SnackbarPurpose = 'default';\n    @Input() title = 'Snackbar Title';\n    @Input() description = 'Lorem ipsum';\n    @Input() fieldPlaceholder = 'Placeholder';\n    @Input() titleIcon: string = 'info';\n    @Input({ transform: booleanAttribute }) showTitle = true;\n    @Input({ transform: booleanAttribute }) showTitleIcon = true;\n    @Input({ transform: booleanAttribute }) titleIconFilled = false;\n    @Input({ transform: booleanAttribute }) showClose = true;\n    @Input({ transform: booleanAttribute }) showProgressBar = true;\n    @Input({ transform: booleanAttribute }) showField = true;\n    @Input({ transform: booleanAttribute }) showButton = true;\n    @Input({ transform: booleanAttribute }) autoDismiss = true;\n    @Input({ transform: booleanAttribute }) visible = true;\n    @Input() progressMs = 5000;\n    @Input() y = 24;\n    @Input() statusButtonInputs?: StatusButtonInputs;\n\n    @Output() closed = new EventEmitter<void>();\n    @Output() visibleChange = new EventEmitter<boolean>();\n    @Output() buttonClicked = new EventEmitter<void>();\n\n    isOpen = false;\n\n    private dismissTimer?: number;\n    private readonly EXIT_MS = 300;\n\n    ngOnInit(): void {\n        if (this.visible) {\n            // enter on next tick\n            setTimeout(() => (this.isOpen = true), 0);\n            this.startDismissTimer();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if ('visible' in changes) {\n            // when parent toggles visible\n            if (this.visible) {\n                // becoming visible -> open + (re)start timer\n                this.isOpen = false;\n                setTimeout(() => (this.isOpen = true), 0);\n                this.startDismissTimer();\n            } else {\n                // becoming hidden -> stop timers and ensure closed state\n                this.clearDismissTimer();\n                this.isOpen = false;\n            }\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.clearDismissTimer();\n    }\n\n    // used by the × button, done button, and auto-dismiss\n    close(emitButtonClicked: boolean = false): void {\n        if (!this.isOpen && !this.visible) return;\n        this.clearDismissTimer();\n        this.isOpen = false; // triggers exit transition\n\n        // after exit animation, hide + notify\n        window.setTimeout(() => {\n            if (this.visible) {\n                this.visible = false;\n                this.visibleChange.emit(false);\n            }\n            if (emitButtonClicked) {\n                this.buttonClicked.emit();\n            }\n            this.closed.emit();\n        }, this.EXIT_MS);\n    }\n\n    get status(): Status {\n        return purposeToStatusMap[this.purpose];\n    }\n\n    private startDismissTimer(): void {\n        if (!this.autoDismiss) return;\n        this.clearDismissTimer();\n        this.dismissTimer = window.setTimeout(() => this.close(), this.progressMs);\n    }\n\n    private clearDismissTimer(): void {\n        if (this.dismissTimer) {\n            clearTimeout(this.dismissTimer);\n            this.dismissTimer = undefined;\n        }\n    }\n}\n","@if (visible) {\n    <section\n        class=\"snackbar\"\n        [ngClass]=\"{\n            'is-default': purpose === 'default',\n            'is-info': purpose === 'info',\n            'is-success': purpose === 'success',\n            'is-error': purpose === 'error',\n            'is-warning': purpose === 'warning',\n            'is-open': isOpen,\n        }\"\n        role=\"status\"\n        aria-live=\"polite\"\n        [style.--snackbar-progress-duration]=\"progressMs + 'ms'\"\n        [style.top.px]=\"y\"\n    >\n        <div class=\"snackbar__left\">\n            @if(showTitle) {\n                <div class=\"snackbar__title-row\">\n                    <span \n                        [ngClass]=\"{\n                            'snackbar__title-icon': true,\n                            'has-icon': showTitle && showTitleIcon\n                        }\"\n                        aria-hidden=\"true\"\n                    >\n                        @if (showTitle && showTitleIcon) {\n                            <i [ngClass]=\"titleIconFilled ? 'material-icons' : 'material-icons-outlined'\"\n                                id=\"snackbar-title-icon\"\n                                aria-hidden=\"true\"\n                            >\n                                {{ titleIcon }}\n                            </i>\n                        }\n                    </span>\n                    @if (showTitle) {\n                        <h3 class=\"snackbar__title\">{{ title }}</h3>\n                    }\n                </div>\n            }\n            <p class=\"snackbar__desc\">\n                {{ description }}\n            </p>\n            @if (showField) {\n                <input class=\"snackbar__input\" type=\"text\" [placeholder]=\"fieldPlaceholder\" />\n            }\n            @if (showButton) {\n                <lib-status-button\n                    label={{statusButtonInputs?.label}}\n                    [status]=\"status\"\n                    leftIcon={{statusButtonInputs?.leftIcon}}\n                    rightIcon={{statusButtonInputs?.rightIcon}}\n                    [hideLeftIcon]=\"statusButtonInputs?.hideLeftIcon\"\n                    [hideRightIcon]=\"statusButtonInputs?.hideRightIcon\"\n                    [clearVariant]=\"statusButtonInputs?.clearVariant\"\n                    (click)=\"close(true)\"\n                ></lib-status-button>\n\n            }\n        </div>\n        <button \n            type=\"button\"\n            (click)=\"close()\"\n            class=\"snackbar__close\"\n            aria-label=\"Dismiss\"\n            [style.visibility]=\"showClose ? 'visible' : 'hidden'\"\n        >\n            ×\n        </button>\n        @if (showProgressBar) {\n            <div class=\"snackbar__progress\">\n                <div class=\"snackbar__progress-fill\"></div>\n            </div>\n        }\n    </section>\n}\n"]}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { Injectable, createComponent } from '@angular/core';
|
|
2
|
+
import { SnackbarComponent } from './snackbar.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class SnackbarService {
|
|
5
|
+
constructor(appRef, env) {
|
|
6
|
+
this.appRef = appRef;
|
|
7
|
+
this.env = env;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* This open method is what consuming code will use to create a snackbar
|
|
11
|
+
* @param snackbarOptions interface
|
|
12
|
+
* @param anchor HTML Element, optional. The snackbar's entrance and exit animations will happen on this element's Y axis (px)
|
|
13
|
+
* @returns void.
|
|
14
|
+
*/
|
|
15
|
+
open(snackbarOptions = {}, anchor) {
|
|
16
|
+
const statusButtonInputs = {
|
|
17
|
+
label: 'Done',
|
|
18
|
+
hideLeftIcon: true,
|
|
19
|
+
clearVariant: true,
|
|
20
|
+
};
|
|
21
|
+
const compRef = createComponent(SnackbarComponent, {
|
|
22
|
+
environmentInjector: this.env,
|
|
23
|
+
});
|
|
24
|
+
const desiredY = anchor // could be clamped if above or below viewport
|
|
25
|
+
? anchor.getBoundingClientRect().top
|
|
26
|
+
: snackbarOptions.y ?? 24;
|
|
27
|
+
Object.assign(compRef.instance, {
|
|
28
|
+
purpose: 'warning',
|
|
29
|
+
title: 'Snackbar Title',
|
|
30
|
+
description: 'Lorem ipsum is the standard dummy text in the design industry',
|
|
31
|
+
titleIcon: 'info',
|
|
32
|
+
fieldPlaceholder: 'Placeholder',
|
|
33
|
+
showTitle: true,
|
|
34
|
+
showTitleIcon: true,
|
|
35
|
+
titleIconFilled: false,
|
|
36
|
+
showClose: true,
|
|
37
|
+
showProgressBar: true,
|
|
38
|
+
showField: true,
|
|
39
|
+
showButton: true,
|
|
40
|
+
progressMs: 5000,
|
|
41
|
+
autoDismiss: true,
|
|
42
|
+
y: desiredY,
|
|
43
|
+
right: 24,
|
|
44
|
+
zIndex: 10000,
|
|
45
|
+
visible: true,
|
|
46
|
+
statusButtonInputs,
|
|
47
|
+
...snackbarOptions,
|
|
48
|
+
});
|
|
49
|
+
this.appRef.attachView(compRef.hostView);
|
|
50
|
+
document.body.appendChild(compRef.location.nativeElement);
|
|
51
|
+
compRef.changeDetectorRef.detectChanges();
|
|
52
|
+
// Clamp Y after it’s in the DOM
|
|
53
|
+
const margin = 8;
|
|
54
|
+
const adjustY = () => {
|
|
55
|
+
const host = compRef.location.nativeElement.querySelector('section.snackbar') ??
|
|
56
|
+
compRef.location.nativeElement;
|
|
57
|
+
const h = host.offsetHeight || 0;
|
|
58
|
+
const maxTop = Math.max(margin, window.innerHeight - h - margin);
|
|
59
|
+
const clamped = Math.min(Math.max(desiredY, margin), maxTop);
|
|
60
|
+
if (compRef.instance.y !== clamped) {
|
|
61
|
+
compRef.instance.y = clamped;
|
|
62
|
+
compRef.changeDetectorRef.detectChanges();
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
// Measure on next frame (styles applied)
|
|
66
|
+
const rafId = requestAnimationFrame(adjustY);
|
|
67
|
+
// re-clamp on resize (in case viewport changes while visible)
|
|
68
|
+
const onResize = () => adjustY();
|
|
69
|
+
window.addEventListener('resize', onResize);
|
|
70
|
+
// Cleanup when closed
|
|
71
|
+
const sub = compRef.instance.closed.subscribe(() => {
|
|
72
|
+
sub.unsubscribe();
|
|
73
|
+
cancelAnimationFrame(rafId);
|
|
74
|
+
window.removeEventListener('resize', onResize);
|
|
75
|
+
this.appRef.detachView(compRef.hostView);
|
|
76
|
+
compRef.destroy();
|
|
77
|
+
});
|
|
78
|
+
return {
|
|
79
|
+
close: () => compRef.instance.close(),
|
|
80
|
+
buttonClicked: compRef.instance.buttonClicked,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: SnackbarService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
84
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: SnackbarService, providedIn: 'root' }); }
|
|
85
|
+
}
|
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: SnackbarService, decorators: [{
|
|
87
|
+
type: Injectable,
|
|
88
|
+
args: [{ providedIn: 'root' }]
|
|
89
|
+
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }] });
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.service.js","sourceRoot":"","sources":["../../../../../projects/components/src/lib/snackbar/snackbar.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ApplicationRef, EnvironmentInjector, createComponent } from '@angular/core';\nimport { SnackbarComponent, SnackbarInputs } from './snackbar.component';\nimport { StatusButtonInputs } from '../status-button/status-button.component';\n\n@Injectable({ providedIn: 'root' })\nexport class SnackbarService {\n    constructor(\n        private appRef: ApplicationRef,\n        private env: EnvironmentInjector,\n    ) {}\n\n    /**\n     * This open method is what consuming code will use to create a snackbar\n     * @param snackbarOptions interface\n     * @param anchor HTML Element, optional. The snackbar's entrance and exit animations will happen on this element's Y axis (px)\n     * @returns void.\n     */\n    open(snackbarOptions: SnackbarInputs = {}, anchor?: HTMLElement) {\n        const statusButtonInputs: StatusButtonInputs = {\n            label: 'Done',\n            hideLeftIcon: true,\n            clearVariant: true,\n        };\n        const compRef = createComponent(SnackbarComponent, {\n            environmentInjector: this.env,\n        });\n\n        const desiredY = anchor // could be clamped if above or below viewport\n            ? anchor.getBoundingClientRect().top\n            : snackbarOptions.y ?? 24;\n\n        Object.assign(compRef.instance, {\n            purpose: 'warning',\n            title: 'Snackbar Title',\n            description: 'Lorem ipsum is the standard dummy text in the design industry',\n            titleIcon: 'info',\n            fieldPlaceholder: 'Placeholder',\n            showTitle: true,\n            showTitleIcon: true,\n            titleIconFilled: false,\n            showClose: true,\n            showProgressBar: true,\n            showField: true,\n            showButton: true,\n            progressMs: 5000,\n            autoDismiss: true,\n            y: desiredY,\n            right: 24,\n            zIndex: 10000,\n            visible: true,\n            statusButtonInputs,\n            ...snackbarOptions,\n        });\n\n        this.appRef.attachView(compRef.hostView);\n        document.body.appendChild(compRef.location.nativeElement);\n        compRef.changeDetectorRef.detectChanges();\n\n        // Clamp Y after it’s in the DOM\n        const margin = 8;\n        const adjustY = () => {\n            const host: HTMLElement =\n                (compRef.location.nativeElement as HTMLElement).querySelector('section.snackbar') ??\n                (compRef.location.nativeElement as HTMLElement);\n\n            const h = host.offsetHeight || 0;\n            const maxTop = Math.max(margin, window.innerHeight - h - margin);\n            const clamped = Math.min(Math.max(desiredY, margin), maxTop);\n\n            if (compRef.instance.y !== clamped) {\n                compRef.instance.y = clamped;\n                compRef.changeDetectorRef.detectChanges();\n            }\n        };\n\n        // Measure on next frame (styles applied)\n        const rafId = requestAnimationFrame(adjustY);\n\n        // re-clamp on resize (in case viewport changes while visible)\n        const onResize = () => adjustY();\n        window.addEventListener('resize', onResize);\n\n        // Cleanup when closed\n        const sub = compRef.instance.closed.subscribe(() => {\n            sub.unsubscribe();\n            cancelAnimationFrame(rafId);\n            window.removeEventListener('resize', onResize);\n            this.appRef.detachView(compRef.hostView);\n            compRef.destroy();\n        });\n\n        return {\n            close: () => compRef.instance.close(),\n            buttonClicked: compRef.instance.buttonClicked,\n        };\n    }\n}\n"]}
|
|
@@ -17,6 +17,7 @@ export class StatusButtonComponent {
|
|
|
17
17
|
this._rightIcon = '';
|
|
18
18
|
this._hideLeftIcon = false;
|
|
19
19
|
this._hideRightIcon = false;
|
|
20
|
+
this._clearVariant = false;
|
|
20
21
|
}
|
|
21
22
|
set status(value) {
|
|
22
23
|
this._status = value || 'info';
|
|
@@ -52,6 +53,12 @@ export class StatusButtonComponent {
|
|
|
52
53
|
get hideRightIcon() {
|
|
53
54
|
return this._hideRightIcon;
|
|
54
55
|
}
|
|
56
|
+
set clearVariant(value) {
|
|
57
|
+
this._clearVariant = value;
|
|
58
|
+
}
|
|
59
|
+
get clearVariant() {
|
|
60
|
+
return this._clearVariant;
|
|
61
|
+
}
|
|
55
62
|
/** helper for default left icons */
|
|
56
63
|
getDefaultLeftIcon(status) {
|
|
57
64
|
switch (status) {
|
|
@@ -70,11 +77,11 @@ export class StatusButtonComponent {
|
|
|
70
77
|
}
|
|
71
78
|
}
|
|
72
79
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: StatusButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
73
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.1.0", type: StatusButtonComponent, isStandalone: true, selector: "lib-status-button", inputs: { label: "label", status: "status", leftIcon: "leftIcon", rightIcon: "rightIcon", hideLeftIcon: ["hideLeftIcon", "hideLeftIcon", booleanAttribute], hideRightIcon: ["hideRightIcon", "hideRightIcon", booleanAttribute] }, ngImport: i0, template: "<button\n type=\"button\"\n [
|
|
80
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.1.0", type: StatusButtonComponent, isStandalone: true, selector: "lib-status-button", inputs: { label: "label", status: "status", leftIcon: "leftIcon", rightIcon: "rightIcon", hideLeftIcon: ["hideLeftIcon", "hideLeftIcon", booleanAttribute], hideRightIcon: ["hideRightIcon", "hideRightIcon", booleanAttribute], clearVariant: ["clearVariant", "clearVariant", booleanAttribute] }, ngImport: i0, template: "<button\n type=\"button\"\n [ngClass]=\"[\n status,\n clearVariant ? 'strokeless transparent-bg' : ''\n ]\"\n>\n <span *ngIf=\"leftIcon\" class=\"icon material-symbols-outlined\">{{ leftIcon }}</span>\n {{ label }}\n <span *ngIf=\"rightIcon\" class=\"icon material-symbols-outlined\">{{ rightIcon }}</span>\n</button>\n", styles: ["button{align-items:center;background-color:#ecf2f6;border:1px solid #457fa6;border-radius:4px;color:#3e7295;display:inline-flex;flex-shrink:0;font-size:1em;font-weight:400;gap:.5em;height:2.25em;justify-content:center;padding:var(--status-button-padding, .25em .5em)}button .icon{font-size:1.25em}button:focus{outline:2px solid #b967c7;outline-offset:2px}button:hover{background-color:#a2bfd3;color:#26485f;cursor:pointer}button.success{background-color:#ebf6ee;border:1px solid #3ba35a;color:#1d562e}button.success:hover{background-color:#9dd1ac;color:#1d562e}button.info{background-color:#ecf2f6;border:1px solid #457fa6;color:#3e7295}button.info:hover{background-color:#a2bfd3;color:#26485f}button.warning{background-color:#faf9ec;border:1px solid #d1c844;color:#635f04}button.warning:hover{background-color:#e8e3a1;color:#635f04}button.error{background-color:#f9ecec;border:1px solid #c73e3d;color:#702121}button.error:hover{background-color:#e39e9e;color:#702121}button.disabled{background-color:#e7e7e7;border:1px solid #8f8f8f;color:#767676}button.disabled:hover{background-color:#d0d0d0;color:#141414}button.strokeless{border:0px}button.transparent-bg{background:transparent}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
74
81
|
}
|
|
75
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: StatusButtonComponent, decorators: [{
|
|
76
83
|
type: Component,
|
|
77
|
-
args: [{ selector: 'lib-status-button', standalone: true, imports: [CommonModule, NgIf], template: "<button\n type=\"button\"\n [
|
|
84
|
+
args: [{ selector: 'lib-status-button', standalone: true, imports: [CommonModule, NgIf], template: "<button\n type=\"button\"\n [ngClass]=\"[\n status,\n clearVariant ? 'strokeless transparent-bg' : ''\n ]\"\n>\n <span *ngIf=\"leftIcon\" class=\"icon material-symbols-outlined\">{{ leftIcon }}</span>\n {{ label }}\n <span *ngIf=\"rightIcon\" class=\"icon material-symbols-outlined\">{{ rightIcon }}</span>\n</button>\n", styles: ["button{align-items:center;background-color:#ecf2f6;border:1px solid #457fa6;border-radius:4px;color:#3e7295;display:inline-flex;flex-shrink:0;font-size:1em;font-weight:400;gap:.5em;height:2.25em;justify-content:center;padding:var(--status-button-padding, .25em .5em)}button .icon{font-size:1.25em}button:focus{outline:2px solid #b967c7;outline-offset:2px}button:hover{background-color:#a2bfd3;color:#26485f;cursor:pointer}button.success{background-color:#ebf6ee;border:1px solid #3ba35a;color:#1d562e}button.success:hover{background-color:#9dd1ac;color:#1d562e}button.info{background-color:#ecf2f6;border:1px solid #457fa6;color:#3e7295}button.info:hover{background-color:#a2bfd3;color:#26485f}button.warning{background-color:#faf9ec;border:1px solid #d1c844;color:#635f04}button.warning:hover{background-color:#e8e3a1;color:#635f04}button.error{background-color:#f9ecec;border:1px solid #c73e3d;color:#702121}button.error:hover{background-color:#e39e9e;color:#702121}button.disabled{background-color:#e7e7e7;border:1px solid #8f8f8f;color:#767676}button.disabled:hover{background-color:#d0d0d0;color:#141414}button.strokeless{border:0px}button.transparent-bg{background:transparent}\n"] }]
|
|
78
85
|
}], propDecorators: { label: [{
|
|
79
86
|
type: Input,
|
|
80
87
|
args: [{ required: true }]
|
|
@@ -90,5 +97,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
90
97
|
}], hideRightIcon: [{
|
|
91
98
|
type: Input,
|
|
92
99
|
args: [{ transform: booleanAttribute }]
|
|
100
|
+
}], clearVariant: [{
|
|
101
|
+
type: Input,
|
|
102
|
+
args: [{ transform: booleanAttribute }]
|
|
93
103
|
}] } });
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9saWIvc3RhdHVzLWJ1dHRvbi9zdGF0dXMtYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9zdGF0dXMtYnV0dG9uL3N0YXR1cy1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkUsT0FBTyxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7O0FBYXJEOzs7Ozs7O0dBT0c7QUFRSCxNQUFNLE9BQU8scUJBQXFCO0lBUGxDO1FBUVksWUFBTyxHQUFXLE1BQU0sQ0FBQztRQUN6QixjQUFTLEdBQUcsRUFBRSxDQUFDO1FBQ2YsZUFBVSxHQUFHLEVBQUUsQ0FBQztRQUNoQixrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUN0QixtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUN2QixrQkFBYSxHQUFHLEtBQUssQ0FBQztLQXVFakM7SUFuRUcsSUFDSSxNQUFNLENBQUMsS0FBNEQ7UUFDbkUsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLElBQUksTUFBTSxDQUFDO0lBQ25DLENBQUM7SUFDRCxJQUFJLE1BQU07UUFDTixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQ0ksUUFBUSxDQUFDLEtBQWE7UUFDdEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7SUFDM0IsQ0FBQztJQUNELElBQUksUUFBUTtRQUNSLElBQUksSUFBSSxDQUFDLGFBQWE7WUFBRSxPQUFPLEVBQUUsQ0FBQztRQUNsQyxPQUFPLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRUQsSUFDSSxTQUFTLENBQUMsS0FBYTtRQUN2QixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztJQUM1QixDQUFDO0lBQ0QsSUFBSSxTQUFTO1FBQ1QsSUFBSSxJQUFJLENBQUMsY0FBYztZQUFFLE9BQU8sRUFBRSxDQUFDO1FBQ25DLE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxlQUFlLENBQUM7SUFDOUMsQ0FBQztJQUVELElBQ0ksWUFBWSxDQUFDLEtBQWM7UUFDM0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7SUFDL0IsQ0FBQztJQUNELElBQUksWUFBWTtRQUNaLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFDSSxhQUFhLENBQUMsS0FBYztRQUM1QixJQUFJLENBQUMsY0FBYyxHQUFHLEtBQUssQ0FBQztJQUNoQyxDQUFDO0lBQ0QsSUFBSSxhQUFhO1FBQ2IsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUNJLFlBQVksQ0FBQyxLQUFjO1FBQzNCLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDO0lBQy9CLENBQUM7SUFDRCxJQUFJLFlBQVk7UUFDWixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDOUIsQ0FBQztJQUVELG9DQUFvQztJQUM1QixrQkFBa0IsQ0FBQyxNQUEyQjtRQUNsRCxRQUFRLE1BQU0sRUFBRSxDQUFDO1lBQ2IsS0FBSyxTQUFTO2dCQUNWLE9BQU8sT0FBTyxDQUFDO1lBQ25CLEtBQUssTUFBTTtnQkFDUCxPQUFPLE1BQU0sQ0FBQztZQUNsQixLQUFLLFNBQVM7Z0JBQ1YsT0FBTyxTQUFTLENBQUM7WUFDckIsS0FBSyxPQUFPO2dCQUNSLE9BQU8sT0FBTyxDQUFDO1lBQ25CLEtBQUssVUFBVTtnQkFDWCxPQUFPLE9BQU8sQ0FBQztZQUNuQjtnQkFDSSxPQUFPLEVBQUUsQ0FBQztRQUNsQixDQUFDO0lBQ0wsQ0FBQzs4R0E1RVEscUJBQXFCO2tHQUFyQixxQkFBcUIsOExBb0NWLGdCQUFnQixxREFRaEIsZ0JBQWdCLGtEQVFoQixnQkFBZ0IsNkJDakZ4QyxpV0FXQSwwdENEY2MsWUFBWTs7MkZBSWIscUJBQXFCO2tCQVBqQyxTQUFTOytCQUNJLG1CQUFtQixjQUNqQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDOzhCQVlGLEtBQUs7c0JBQS9CLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUdyQixNQUFNO3NCQURULEtBQUs7Z0JBU0YsUUFBUTtzQkFEWCxLQUFLO2dCQVVGLFNBQVM7c0JBRFosS0FBSztnQkFVRixZQUFZO3NCQURmLEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBU2xDLGFBQWE7c0JBRGhCLEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBU2xDLFlBQVk7c0JBRGYsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJvb2xlYW5BdHRyaWJ1dGUsIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSwgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5leHBvcnQgdHlwZSBTdGF0dXMgPSAnc3VjY2VzcycgfCAnaW5mbycgfCAnd2FybmluZycgfCAnZXJyb3InIHwgJ2Rpc2FibGVkJztcblxuZXhwb3J0IGludGVyZmFjZSBTdGF0dXNCdXR0b25JbnB1dHMge1xuICAgIGxhYmVsOiBzdHJpbmc7XG4gICAgc3RhdHVzPzogU3RhdHVzO1xuICAgIGxlZnRJY29uPzogc3RyaW5nO1xuICAgIHJpZ2h0SWNvbj86IHN0cmluZztcbiAgICBoaWRlTGVmdEljb24/OiBib29sZWFuO1xuICAgIGhpZGVSaWdodEljb24/OiBib29sZWFuO1xuICAgIGNsZWFyVmFyaWFudD86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQSBidXR0b24gdGhhdCBpbmRpY2F0ZXMgc3RhdHVzIHdpdGggY29sb3IgYW5kIGljb24uXG4gKiBTdGF0dXMgY2FuIGJlIG9uZSBvZjogJ3N1Y2Nlc3MnLCAnaW5mbycsICd3YXJuaW5nJywgJ2Vycm9yJywgb3IgJ2Rpc2FibGVkJy5cbiAqIEVhY2ggc3RhdHVzIGhhcyBhIGRlZmF1bHQgbGVmdCBpY29uLCBidXQgYSBjdXN0b20gbGVmdCBpY29uIGNhbiBiZSBwcm92aWRlZC5cbiAqIEEgcmlnaHQgaWNvbiBjYW4gYWxzbyBiZSBwcm92aWRlZCwgZGVmYXVsdGluZyB0byAnY2hldnJvbl9yaWdodCcuXG4gKiBUaGUgbGVmdCBhbmQgcmlnaHQgaWNvbnMgY2FuIGJlIGhpZGRlbiB3aXRoIHRoZSBgaGlkZUxlZnRJY29uYCBhbmQgYGhpZGVSaWdodEljb25gIGJvb2xlYW4gaW5wdXRzLlxuICogQSBsYWJlbCBpbnB1dCBpcyByZXF1aXJlZC5cbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdsaWItc3RhdHVzLWJ1dHRvbicsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBOZ0lmXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vc3RhdHVzLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL3N0YXR1cy1idXR0b24uY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBTdGF0dXNCdXR0b25Db21wb25lbnQge1xuICAgIHByaXZhdGUgX3N0YXR1czogU3RhdHVzID0gJ2luZm8nO1xuICAgIHByaXZhdGUgX2xlZnRJY29uID0gJyc7XG4gICAgcHJpdmF0ZSBfcmlnaHRJY29uID0gJyc7XG4gICAgcHJpdmF0ZSBfaGlkZUxlZnRJY29uID0gZmFsc2U7XG4gICAgcHJpdmF0ZSBfaGlkZVJpZ2h0SWNvbiA9IGZhbHNlO1xuICAgIHByaXZhdGUgX2NsZWFyVmFyaWFudCA9IGZhbHNlO1xuXG4gICAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgbGFiZWwhOiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBzdGF0dXModmFsdWU6ICdzdWNjZXNzJyB8ICdpbmZvJyB8ICd3YXJuaW5nJyB8ICdlcnJvcicgfCAnZGlzYWJsZWQnKSB7XG4gICAgICAgIHRoaXMuX3N0YXR1cyA9IHZhbHVlIHx8ICdpbmZvJztcbiAgICB9XG4gICAgZ2V0IHN0YXR1cygpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX3N0YXR1cztcbiAgICB9XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBsZWZ0SWNvbih2YWx1ZTogc3RyaW5nKSB7XG4gICAgICAgIHRoaXMuX2xlZnRJY29uID0gdmFsdWU7XG4gICAgfVxuICAgIGdldCBsZWZ0SWNvbigpIHtcbiAgICAgICAgaWYgKHRoaXMuX2hpZGVMZWZ0SWNvbikgcmV0dXJuICcnO1xuICAgICAgICByZXR1cm4gdGhpcy5fbGVmdEljb24gfHwgdGhpcy5nZXREZWZhdWx0TGVmdEljb24odGhpcy5fc3RhdHVzKTtcbiAgICB9XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCByaWdodEljb24odmFsdWU6IHN0cmluZykge1xuICAgICAgICB0aGlzLl9yaWdodEljb24gPSB2YWx1ZTtcbiAgICB9XG4gICAgZ2V0IHJpZ2h0SWNvbigpIHtcbiAgICAgICAgaWYgKHRoaXMuX2hpZGVSaWdodEljb24pIHJldHVybiAnJztcbiAgICAgICAgcmV0dXJuIHRoaXMuX3JpZ2h0SWNvbiB8fCAnY2hldnJvbl9yaWdodCc7XG4gICAgfVxuXG4gICAgQElucHV0KHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pXG4gICAgc2V0IGhpZGVMZWZ0SWNvbih2YWx1ZTogYm9vbGVhbikge1xuICAgICAgICB0aGlzLl9oaWRlTGVmdEljb24gPSB2YWx1ZTtcbiAgICB9XG4gICAgZ2V0IGhpZGVMZWZ0SWNvbigpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2hpZGVMZWZ0SWNvbjtcbiAgICB9XG5cbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgICBzZXQgaGlkZVJpZ2h0SWNvbih2YWx1ZTogYm9vbGVhbikge1xuICAgICAgICB0aGlzLl9oaWRlUmlnaHRJY29uID0gdmFsdWU7XG4gICAgfVxuICAgIGdldCBoaWRlUmlnaHRJY29uKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5faGlkZVJpZ2h0SWNvbjtcbiAgICB9XG5cbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgICBzZXQgY2xlYXJWYXJpYW50KHZhbHVlOiBib29sZWFuKSB7XG4gICAgICAgIHRoaXMuX2NsZWFyVmFyaWFudCA9IHZhbHVlO1xuICAgIH1cbiAgICBnZXQgY2xlYXJWYXJpYW50KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5fY2xlYXJWYXJpYW50O1xuICAgIH1cblxuICAgIC8qKiBoZWxwZXIgZm9yIGRlZmF1bHQgbGVmdCBpY29ucyAqL1xuICAgIHByaXZhdGUgZ2V0RGVmYXVsdExlZnRJY29uKHN0YXR1czogdHlwZW9mIHRoaXMuX3N0YXR1cyk6IHN0cmluZyB7XG4gICAgICAgIHN3aXRjaCAoc3RhdHVzKSB7XG4gICAgICAgICAgICBjYXNlICdzdWNjZXNzJzpcbiAgICAgICAgICAgICAgICByZXR1cm4gJ2NoZWNrJztcbiAgICAgICAgICAgIGNhc2UgJ2luZm8nOlxuICAgICAgICAgICAgICAgIHJldHVybiAnaW5mbyc7XG4gICAgICAgICAgICBjYXNlICd3YXJuaW5nJzpcbiAgICAgICAgICAgICAgICByZXR1cm4gJ3dhcm5pbmcnO1xuICAgICAgICAgICAgY2FzZSAnZXJyb3InOlxuICAgICAgICAgICAgICAgIHJldHVybiAnZXJyb3InO1xuICAgICAgICAgICAgY2FzZSAnZGlzYWJsZWQnOlxuICAgICAgICAgICAgICAgIHJldHVybiAnYmxvY2snO1xuICAgICAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgICAgICByZXR1cm4gJyc7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgW25nQ2xhc3NdPVwiW1xuICAgICAgICBzdGF0dXMsXG4gICAgICAgIGNsZWFyVmFyaWFudCA/ICdzdHJva2VsZXNzIHRyYW5zcGFyZW50LWJnJyA6ICcnXG4gICAgXVwiXG4+XG4gICAgPHNwYW4gKm5nSWY9XCJsZWZ0SWNvblwiIGNsYXNzPVwiaWNvbiBtYXRlcmlhbC1zeW1ib2xzLW91dGxpbmVkXCI+e3sgbGVmdEljb24gfX08L3NwYW4+XG4gICAge3sgbGFiZWwgfX1cbiAgICA8c3BhbiAqbmdJZj1cInJpZ2h0SWNvblwiIGNsYXNzPVwiaWNvbiBtYXRlcmlhbC1zeW1ib2xzLW91dGxpbmVkXCI+e3sgcmlnaHRJY29uIH19PC9zcGFuPlxuPC9idXR0b24+XG4iXX0=
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -11,7 +11,9 @@ export * from './lib/ss-search-bar/ss-search-bar.component';
|
|
|
11
11
|
export * from './lib/ss-search-bar/models/advanced-search.model';
|
|
12
12
|
export * from './lib/ss-search-bar/models/search-scope.model';
|
|
13
13
|
export * from './lib/ss-search-bar/models/search-config.model';
|
|
14
|
+
export * from './lib/snackbar/snackbar.service';
|
|
15
|
+
export * from './lib/snackbar/snackbar.component';
|
|
14
16
|
export { getUserStatusFromRoles } from './lib/contact-utils';
|
|
15
17
|
export { ADVANCED_SEARCH_QUALIFIER_MAP, ADVANCED_SEARCH_FIELD_MAP, ADVANCED_SEARCH_OPTIONS, } from './lib/ss-search-bar/constants';
|
|
16
18
|
export * from './lib/status-button/status-button.component';
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHFFQUFxRSxDQUFDO0FBQ3BGLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM3RCxPQUFPLEVBQ0gsNkJBQTZCLEVBQzdCLHlCQUF5QixFQUN6Qix1QkFBdUIsR0FDMUIsTUFBTSwrQkFBK0IsQ0FBQztBQUN2QyxjQUFjLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBjb21wb25lbnRzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvaGJsbC1oZWFkZXIvaGJsbC1oZWFkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL2hibGwtaXRlbS10eXBlLWljb24ucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9oYmxsLWZvb3Rlci9oYmxsLWZvb3Rlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaGVhZGVyLXdpdGgtaW1wZXJzb25hdGlvbi9oZWFkZXItd2l0aC1pbXBlcnNvbmF0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbXBlcnNvbmF0ZS1tb2RhbC9pbXBlcnNvbmF0ZS1tb2RhbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW1wZXJzb25hdGlvbi1iYW5uZXIvaW1wZXJzb25hdGlvbi1iYW5uZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NzLXNlYXJjaC1iYXIvc3Mtc2VhcmNoLWJhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3Mtc2VhcmNoLWJhci9tb2RlbHMvYWR2YW5jZWQtc2VhcmNoLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NzLXNlYXJjaC1iYXIvbW9kZWxzL3NlYXJjaC1zY29wZS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zcy1zZWFyY2gtYmFyL21vZGVscy9zZWFyY2gtY29uZmlnLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NuYWNrYmFyL3NuYWNrYmFyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc25hY2tiYXIvc25hY2tiYXIuY29tcG9uZW50JztcbmV4cG9ydCB7IGdldFVzZXJTdGF0dXNGcm9tUm9sZXMgfSBmcm9tICcuL2xpYi9jb250YWN0LXV0aWxzJztcbmV4cG9ydCB7XG4gICAgQURWQU5DRURfU0VBUkNIX1FVQUxJRklFUl9NQVAsXG4gICAgQURWQU5DRURfU0VBUkNIX0ZJRUxEX01BUCxcbiAgICBBRFZBTkNFRF9TRUFSQ0hfT1BUSU9OUyxcbn0gZnJvbSAnLi9saWIvc3Mtc2VhcmNoLWJhci9jb25zdGFudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RhdHVzLWJ1dHRvbi9zdGF0dXMtYnV0dG9uLmNvbXBvbmVudCc7XG4iXX0=
|