@morozeckiy/dd-lib 0.2.70 → 0.3.0

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.
Files changed (54) hide show
  1. package/assets/images/svg/file.svg +12 -0
  2. package/assets/images/svg/reload.svg +11 -0
  3. package/assets/scss/common.scss +21 -0
  4. package/assets/scss/grid.scss +158 -0
  5. package/assets/scss/keyframes.scss +9 -0
  6. package/assets/scss/reset.scss +6 -1
  7. package/assets/scss/titles.scss +28 -10
  8. package/assets/scss/vars-dark.scss +1 -0
  9. package/assets/scss/vars-light.scss +1 -0
  10. package/assets/styles.scss +2 -0
  11. package/esm2022/lib/common/lib-common-input-text.mjs +30 -25
  12. package/esm2022/lib/components/data-empty/data-empty.component.mjs +8 -3
  13. package/esm2022/lib/core/dialog/modal-base/modal-base.component.mjs +5 -5
  14. package/esm2022/lib/core/directives/click-outside.directive.mjs +2 -2
  15. package/esm2022/lib/core/services/destroy.service.mjs +1 -1
  16. package/esm2022/lib/core/services/fetcher.service.mjs +1 -1
  17. package/esm2022/lib/core/services/validators.service.mjs +33 -1
  18. package/esm2022/lib/core/toast/toast-config.mjs +11 -2
  19. package/esm2022/lib/core/toast/toast.service.mjs +18 -1
  20. package/esm2022/lib/core/tooltip/tooltip.component.mjs +3 -3
  21. package/esm2022/lib/lib-button/lib-button.component.mjs +3 -3
  22. package/esm2022/lib/lib-card/lib-card.component.mjs +3 -3
  23. package/esm2022/lib/lib-checkbox/lib-checkbox.component.mjs +11 -6
  24. package/esm2022/lib/lib-date-range/lib-date-range.component.mjs +3 -3
  25. package/esm2022/lib/lib-file-loader/lib-file-loader.component.mjs +6 -4
  26. package/esm2022/lib/lib-file-upload/lib-file-upload.component.mjs +8 -20
  27. package/esm2022/lib/lib-filter-button/lib-filter-button.component.mjs +3 -3
  28. package/esm2022/lib/lib-image-loader/lib-image-loader.component.mjs +3 -3
  29. package/esm2022/lib/lib-input/lib-input.component.mjs +42 -11
  30. package/esm2022/lib/lib-search-input/lib-search-input.component.mjs +3 -3
  31. package/esm2022/lib/lib-select/lib-select.component.mjs +52 -14
  32. package/esm2022/lib/lib-sort/lib-sort.component.mjs +3 -3
  33. package/esm2022/lib/lib-tabs-fragment/lib-tabs-fragment.component.mjs +5 -2
  34. package/esm2022/lib/lib-textarea/lib-textarea.component.mjs +3 -3
  35. package/esm2022/lib/svg-icons/svg-icon.model.mjs +11 -1
  36. package/fesm2022/morozeckiy-dd-lib.mjs +243 -104
  37. package/fesm2022/morozeckiy-dd-lib.mjs.map +1 -1
  38. package/lib/common/lib-common-input-text.d.ts +11 -4
  39. package/lib/components/data-empty/data-empty.component.d.ts +2 -1
  40. package/lib/core/dialog/modal-base/modal-base.component.d.ts +2 -2
  41. package/lib/core/services/fetcher.service.d.ts +4 -1
  42. package/lib/core/services/validators.service.d.ts +3 -2
  43. package/lib/core/toast/toast-config.d.ts +5 -2
  44. package/lib/core/toast/toast.service.d.ts +5 -1
  45. package/lib/lib-checkbox/lib-checkbox.component.d.ts +3 -1
  46. package/lib/lib-file-loader/lib-file-loader.component.d.ts +3 -2
  47. package/lib/lib-file-upload/lib-file-upload.component.d.ts +5 -8
  48. package/lib/lib-input/lib-input.component.d.ts +12 -4
  49. package/lib/lib-select/lib-select.component.d.ts +13 -4
  50. package/lib/lib-tabs-fragment/lib-tabs-fragment.component.d.ts +3 -2
  51. package/lib/svg-icons/svg-icon.model.d.ts +15 -1
  52. package/morozeckiy-dd-lib-0.3.0.tgz +0 -0
  53. package/package.json +1 -1
  54. package/morozeckiy-dd-lib-0.2.70.tgz +0 -0
@@ -0,0 +1,12 @@
1
+ <svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <g clip-path="url(#clip0_3584_65805)">
3
+ <path d="M12 2L12.117 2.007C12.3402 2.03332 12.5481 2.13408 12.707 2.29301C12.8659 2.45194 12.9667 2.65978 12.993 2.883L13 3V7L13.005 7.15C13.0408 7.62617 13.2458 8.07383 13.5829 8.41203C13.92 8.75023 14.3669 8.95666 14.843 8.994L15 9H19L19.117 9.007C19.3402 9.03332 19.5481 9.13408 19.707 9.29301C19.8659 9.45194 19.9667 9.65978 19.993 9.883L20 10V19C20 19.7652 19.7077 20.5015 19.1827 21.0583C18.6578 21.615 17.9399 21.9501 17.176 21.995L17 22H7C6.23479 22 5.49849 21.7077 4.94174 21.1827C4.38499 20.6578 4.04989 19.9399 4.005 19.176L4 19V5C3.99996 4.23479 4.29233 3.49849 4.81728 2.94174C5.34224 2.38499 6.06011 2.04989 6.824 2.005L7 2H12Z" fill="#BDBDBD"/>
4
+ <path d="M19 7.00002H15L14.999 2.99902L19 7.00002Z" fill="#BDBDBD"/>
5
+ </g>
6
+ <defs>
7
+ <clipPath id="clip0_3584_65805">
8
+ <rect width="24" height="24" fill="white"/>
9
+ </clipPath>
10
+ </defs>
11
+ </svg>
12
+
@@ -0,0 +1,11 @@
1
+ <svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <g clip-path="url(#clip0_3584_73648)">
3
+ <path d="M19.9329 13.041C19.7441 14.481 19.1669 15.8424 18.2631 16.9792C17.3594 18.116 16.1632 18.9854 14.8029 19.4941C13.4426 20.0027 11.9695 20.1315 10.5416 19.8666C9.11368 19.6017 7.7848 18.9531 6.69749 17.9904C5.61018 17.0276 4.80545 15.787 4.36961 14.4017C3.93377 13.0164 3.88326 11.5385 4.22349 10.1266C4.56373 8.71476 5.28188 7.42214 6.30091 6.3874C7.31995 5.35266 8.60144 4.61483 10.0079 4.25304C13.9069 3.25304 17.9429 5.26004 19.4329 9.00004" stroke="#069700" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
4
+ <path d="M20 4V9H15" stroke="#069700" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
5
+ </g>
6
+ <defs>
7
+ <clipPath id="clip0_3584_73648">
8
+ <rect width="24" height="24" fill="white"/>
9
+ </clipPath>
10
+ </defs>
11
+ </svg>
@@ -1,6 +1,7 @@
1
1
  @import '../scss/mixins';
2
2
  @import '../scss/fonts';
3
3
  @import '../scss/vars';
4
+ @import '../scss/grid';
4
5
 
5
6
  html {
6
7
  font-family: 'ALS_Sirius', Roboto, Helvetica, Arial, san-serif, serif; /* 1 */
@@ -168,6 +169,10 @@ html {
168
169
  align-items: center;
169
170
  }
170
171
 
172
+ .align-start {
173
+ align-items: flex-start;
174
+ }
175
+
171
176
  .align-end {
172
177
  align-items: flex-end;
173
178
  }
@@ -176,6 +181,14 @@ html {
176
181
  justify-content: space-between;
177
182
  }
178
183
 
184
+ .justify-end {
185
+ justify-content: flex-end;
186
+ }
187
+
188
+ .justify-start {
189
+ justify-content: flex-start;
190
+ }
191
+
179
192
  .justify-around {
180
193
  justify-content: space-around;
181
194
  }
@@ -282,6 +295,13 @@ html {
282
295
  }
283
296
  }
284
297
 
298
+ .column-mobile {
299
+ @include below($mobile) {
300
+ flex-direction: column;
301
+ align-items: baseline;
302
+ }
303
+ }
304
+
285
305
  .show-mobile {
286
306
  display: none !important;
287
307
 
@@ -359,6 +379,7 @@ html {
359
379
  }
360
380
 
361
381
  @include offsets('');
382
+ @include grid('', $col-count);
362
383
 
363
384
  @include below($tablet) {
364
385
  @include offsets('t-');
@@ -0,0 +1,158 @@
1
+
2
+ /* autoprefixer grid: autoplace */
3
+ $col-count: 3;
4
+ $col-md-count: 6;
5
+ $col-lg-count: 12;
6
+
7
+ @mixin grid($prefix, $col-count) {
8
+ @for $i from 1 through $col-count {
9
+ .col#{$prefix}-#{$i} {
10
+ /* autoprefixer grid: ignore next */
11
+ grid-column-end: span $i;
12
+ -ms-grid-column-span: $i * 2 - 1 ;
13
+ min-width: 0; // fix for overflow hidden in ff
14
+ }
15
+ }
16
+
17
+ @for $i from 1 through $col-count - 1 {
18
+ .push#{$prefix}-#{$i} {
19
+ /* autoprefixer grid: ignore next */
20
+ grid-column-start: $i + 1;
21
+ -ms-grid-column: $i * 2;
22
+ }
23
+ }
24
+ }
25
+
26
+
27
+ .container {
28
+ box-sizing: border-box;
29
+ padding: 0 16px;
30
+ margin: 0 auto;
31
+ }
32
+
33
+ .grid-row {
34
+ display: grid;
35
+ grid-template-columns: repeat($col-count, 1fr);
36
+ grid-template-rows: auto;
37
+ grid-gap: 32px;
38
+
39
+ @include grid('', $col-count);
40
+ }
41
+
42
+ .grid-none {
43
+ display: block;
44
+ }
45
+
46
+ .masonry {
47
+ display: grid;
48
+ @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
49
+ display: -ms-grid;
50
+ }
51
+ column-gap: 32px;
52
+ row-gap: 16px;
53
+ }
54
+
55
+
56
+ @media all and (min-width: 768px) {
57
+ .container {
58
+ padding: 0 64px;
59
+ }
60
+
61
+ .grid-row,
62
+ .grid-row-md {
63
+ display: grid;
64
+ grid-template-columns: repeat($col-md-count, 1fr);
65
+ grid-template-rows: auto;
66
+ grid-gap: 32px;
67
+
68
+ @include grid('-md', $col-md-count);
69
+ }
70
+
71
+ .grid-none-md {
72
+ display: block;
73
+ }
74
+
75
+ .masonry {
76
+ grid-template-columns: repeat(1, minmax(566px,1fr));
77
+ -ms-grid-columns: minmax(400px, 1fr) minmax(400px, 1fr);
78
+
79
+ &.masonry-ie {
80
+ content: '';
81
+ display: table;
82
+ clear: both;
83
+ .masonry-brick {
84
+ float: left;
85
+ width: 46%;
86
+ margin: 0 2% 32px 2%;
87
+ }
88
+ }
89
+ }
90
+ }
91
+
92
+ @media all and (min-width: 1140px) {
93
+ .container, .container-lg {
94
+ max-width: 1366px;
95
+ padding: 0 72px;
96
+ margin: 0 auto;
97
+ }
98
+
99
+ .grid-row,
100
+ .grid-row-lg {
101
+ display: grid;
102
+ grid-template-columns: repeat($col-lg-count, 1fr);
103
+ grid-template-rows: auto;
104
+ grid-gap: 32px;
105
+
106
+ &.base-9 {
107
+ display: grid;
108
+ grid-template-columns: repeat(9, 1fr);
109
+ grid-template-rows: auto;
110
+ }
111
+
112
+ @include grid('-lg', $col-lg-count);
113
+ }
114
+
115
+ .grid-none-lg {
116
+ display: block;
117
+ }
118
+
119
+ .masonry {
120
+ grid-template-columns: repeat(2, minmax(300px,1fr));
121
+ }
122
+ }
123
+
124
+ @media print {
125
+ @mixin grid($prefix, $col-count) {
126
+ @for $i from 1 through $col-count {
127
+ .col#{$prefix}-#{$i} {
128
+ /* autoprefixer grid: ignore next */
129
+ grid-column-end: span $i;
130
+ -ms-grid-column-span: $i * 2 - 1 ;
131
+ }
132
+ }
133
+
134
+ @for $i from 1 through $col-count - 1 {
135
+ .push#{$prefix}-#{$i} {
136
+ /* autoprefixer grid: ignore next */
137
+ grid-column-start: $i + 1;
138
+ -ms-grid-column: $i * 2;
139
+ }
140
+ }
141
+ }
142
+
143
+
144
+ .container {
145
+ box-sizing: border-box;
146
+ padding: 0 16px;
147
+ margin: 0;
148
+ }
149
+
150
+ .grid-row {
151
+ display: grid;
152
+ grid-template-columns: repeat($col-count, 1fr);
153
+ grid-template-rows: auto;
154
+ grid-gap: 32px;
155
+
156
+ @include grid('', $col-count);
157
+ }
158
+ }
@@ -15,3 +15,12 @@
15
15
  transform: translateY(0);
16
16
  }
17
17
  }
18
+
19
+ @keyframes rotation {
20
+ 0% {
21
+ transform: rotate(0deg);
22
+ }
23
+ 100% {
24
+ transform: rotate(360deg);
25
+ }
26
+ }
@@ -144,6 +144,11 @@ input:focus-visible {
144
144
  outline: none;
145
145
  }
146
146
 
147
- button {
147
+ button,
148
+ textarea {
148
149
  font-family: inherit;
149
150
  }
151
+
152
+ textarea {
153
+ outline: none;
154
+ }
@@ -31,6 +31,12 @@
31
31
  font-size: 24px;
32
32
  line-height: 32px;
33
33
  color: var(--light-black-color);
34
+
35
+ @include below($mobile) {
36
+ font-weight: 500;
37
+ font-size: 18px;
38
+ line-height: 28px;
39
+ }
34
40
  }
35
41
 
36
42
  .g-h4-title {
@@ -133,6 +139,15 @@
133
139
  color: var(--light-black-color);
134
140
  }
135
141
 
142
+ .b2-title {
143
+ font-size: 16px;
144
+ font-weight: 500;
145
+ line-height: 24px;
146
+ letter-spacing: 0;
147
+ cursor: default;
148
+ color: var(--font-light-black-color);
149
+ }
150
+
136
151
  .b3-title {
137
152
  font-size: 16px;
138
153
  font-weight: 400;
@@ -191,6 +206,14 @@
191
206
  font-weight: 500;
192
207
  }
193
208
 
209
+ .font-bold {
210
+ font-weight: 700;
211
+ }
212
+
213
+ .uppercase {
214
+ text-transform: uppercase;
215
+ }
216
+
194
217
  .no-wrap-text {
195
218
  white-space: nowrap;
196
219
  }
@@ -235,24 +258,19 @@
235
258
  color: var(--red-error-color);
236
259
  }
237
260
 
261
+ .blue {
262
+ color: var(--blue-color);
263
+ }
264
+
238
265
  .green-hover {
239
266
  &:hover {
240
267
  color: var(--primary-green-color);
241
268
  }
242
269
  }
243
270
 
244
- .plain-link {
245
- cursor: pointer;
246
- font-size: 14px;
247
- font-weight: 400;
248
- line-height: 24px;
249
- color: var(--primary-green-color);
271
+ .underline-link {
250
272
  text-decoration: underline;
251
273
 
252
- &.blue {
253
- color: var(--blue-color);
254
- }
255
-
256
274
  &:hover {
257
275
  text-decoration: none;
258
276
  }
@@ -35,6 +35,7 @@
35
35
  --shared-bgc: #182442;
36
36
  --select-act-hov-bgc: #182442;
37
37
  --filter-color: #1A1A1A;
38
+ --tooltip-bgc: #3E3E3E;
38
39
 
39
40
  //button
40
41
  --btn-green-bgc: var(--primary-green-color);
@@ -35,6 +35,7 @@
35
35
  --shared-bgc: #f7f9fe;
36
36
  --select-act-hov-bgc: #f7f9fe;
37
37
  --filter-color: #F9FBFA;
38
+ --tooltip-bgc: #ffffff;
38
39
 
39
40
  //button
40
41
  --btn-green-bgc: var(--primary-green-color);
@@ -7,5 +7,7 @@
7
7
  @import './scss/keyframes';
8
8
  @import './scss/titles';
9
9
  @import './scss/theme';
10
+ @import './scss/grid';
11
+
10
12
  @import '@angular/cdk/overlay-prebuilt.css';
11
13
  @import './scss/common';
@@ -6,18 +6,20 @@ export class LibCommonInputTextComponent {
6
6
  return this._ID;
7
7
  }
8
8
  constructor(changeDetection) {
9
- this.maxlength = 700;
10
9
  this.required = false;
11
10
  this.disabled = false;
12
11
  this.commitOnInput = true; // коммитить по input или по change
13
12
  this.clearable = false;
13
+ this.showSelfError = true;
14
14
  this.uppercase = false;
15
15
  this.invalid = false;
16
+ this.errorTexts = [];
16
17
  this.side = 'bottom';
17
18
  this.cleared = new EventEmitter();
18
19
  this.fetchEvent = new EventEmitter();
19
20
  this.focus = new EventEmitter();
20
21
  this.blur = new EventEmitter();
22
+ this.fullBlur = new EventEmitter();
21
23
  this.focused = false;
22
24
  this.touched = false;
23
25
  this.value = '';
@@ -25,6 +27,16 @@ export class LibCommonInputTextComponent {
25
27
  this._ID = '';
26
28
  this.changeDetection = changeDetection;
27
29
  }
30
+ get invalidState() {
31
+ return this.invalid || this.control ? this.control.invalid : false;
32
+ }
33
+ get showError() {
34
+ if (!this.control) {
35
+ return this.invalid;
36
+ }
37
+ const { dirty, touched } = this.control;
38
+ return this.invalidState ? ((dirty || touched) && !this.focused) : false;
39
+ }
28
40
  handleInput(_e) {
29
41
  if (this.commitOnInput) {
30
42
  this.commit(this.value);
@@ -33,21 +45,6 @@ export class LibCommonInputTextComponent {
33
45
  notifyFocusEvent(e) {
34
46
  // this.focusManager.notifyFocusMayChanged(this, e.type === 'focus');
35
47
  }
36
- // public writeValue(value: string | number | null): void {
37
- // this.value = value === null || value === undefined ? '' : '' + value;
38
- // if (!this.destroyed) {
39
- // this.changeDetection.detectChanges();
40
- // }
41
- // }
42
- // public clearValue(e: Event): void {
43
- // if (!this.disabled) {
44
- // this.writeValue(null);
45
- // this.commit(null);
46
- // this.cleared.emit();
47
- // this.returnFocus(e);
48
- // }
49
- // e.stopPropagation();
50
- // }
51
48
  handleBlur() {
52
49
  this.focused = false;
53
50
  if (this.onTouchedCallback) {
@@ -85,12 +82,10 @@ export class LibCommonInputTextComponent {
85
82
  registerOnTouched(fn) {
86
83
  this.onTouchedCallback = fn;
87
84
  }
88
- setDisabledState(isDisabled) {
89
- this.disabled = isDisabled;
90
- if (!this.destroyed) {
91
- this.changeDetection.detectChanges();
92
- }
93
- }
85
+ // public setDisabledState(isDisabled: boolean): void {
86
+ // console.log(isDisabled)
87
+ // this.disabled = isDisabled;
88
+ // }
94
89
  handleChange() {
95
90
  if (!this.commitOnInput) {
96
91
  this.commit(this.value);
@@ -98,7 +93,7 @@ export class LibCommonInputTextComponent {
98
93
  }
99
94
  commit(_value) { }
100
95
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: LibCommonInputTextComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
101
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.2", type: LibCommonInputTextComponent, selector: "dd-lib-common-input", inputs: { name: "name", label: "label", formControlName: "formControlName", type: "type", contextClass: "contextClass", minlength: "minlength", maxlength: "maxlength", placeholder: "placeholder", autocomplete: "autocomplete", tabIndex: "tabIndex", readOnly: "readOnly", fetchMode: "fetchMode", required: "required", disabled: "disabled", commitOnInput: "commitOnInput", clearable: "clearable", uppercase: "uppercase", invalid: "invalid", errorText: "errorText", side: "side" }, outputs: { cleared: "cleared", fetchEvent: "fetchEvent", focus: "focus", blur: "blur" }, providers: [
96
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.2", type: LibCommonInputTextComponent, selector: "dd-lib-common-input", inputs: { name: "name", label: "label", formControlName: "formControlName", type: "type", contextClass: "contextClass", minlength: "minlength", min: "min", maxlength: "maxlength", max: "max", placeholder: "placeholder", autocomplete: "autocomplete", tabIndex: "tabIndex", readOnly: "readOnly", autofocus: "autofocus", fetchMode: "fetchMode", required: "required", disabled: "disabled", commitOnInput: "commitOnInput", clearable: "clearable", showSelfError: "showSelfError", uppercase: "uppercase", invalid: "invalid", errorTexts: "errorTexts", side: "side" }, outputs: { cleared: "cleared", fetchEvent: "fetchEvent", focus: "focus", blur: "blur", fullBlur: "fullBlur" }, providers: [
102
97
  {
103
98
  provide: NG_VALUE_ACCESSOR,
104
99
  useExisting: forwardRef(() => LibCommonInputTextComponent),
@@ -140,8 +135,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
140
135
  type: Input
141
136
  }], minlength: [{
142
137
  type: Input
138
+ }], min: [{
139
+ type: Input
143
140
  }], maxlength: [{
144
141
  type: Input
142
+ }], max: [{
143
+ type: Input
145
144
  }], placeholder: [{
146
145
  type: Input
147
146
  }], autocomplete: [{
@@ -150,6 +149,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
150
149
  type: Input
151
150
  }], readOnly: [{
152
151
  type: Input
152
+ }], autofocus: [{
153
+ type: Input
153
154
  }], fetchMode: [{
154
155
  type: Input
155
156
  }], required: [{
@@ -160,11 +161,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
160
161
  type: Input
161
162
  }], clearable: [{
162
163
  type: Input
164
+ }], showSelfError: [{
165
+ type: Input
163
166
  }], uppercase: [{
164
167
  type: Input
165
168
  }], invalid: [{
166
169
  type: Input
167
- }], errorText: [{
170
+ }], errorTexts: [{
168
171
  type: Input
169
172
  }], side: [{
170
173
  type: Input
@@ -176,5 +179,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
176
179
  type: Output
177
180
  }], blur: [{
178
181
  type: Output
182
+ }], fullBlur: [{
183
+ type: Output
179
184
  }] } });
180
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-common-input-text.js","sourceRoot":"","sources":["../../../../../projects/dd-lib/src/lib/common/lib-common-input-text.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { AbstractControl, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'dd-lib-common-input',\r\n  template: '',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => LibCommonInputTextComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport abstract class LibCommonInputTextComponent {\r\n  @ViewChild('searchInput') protected inputSearchElement: ElementRef<HTMLInputElement> | undefined;\r\n  @ViewChild('input') protected inputElement: ElementRef<HTMLInputElement> | undefined;\r\n  @ViewChild('textarea') protected textAreaElement: ElementRef<HTMLTextAreaElement> | undefined;\r\n  @Input() public name: string | undefined;\r\n  @Input() public label: string | undefined;\r\n  @Input() public formControlName: string | undefined;\r\n  @Input() public type: 'password' | 'email' | 'number' | 'text' | undefined;\r\n  @Input() public contextClass: string | undefined; // класс разметки для deep стилей\r\n  @Input() public minlength: string | number | undefined;\r\n  @Input() public maxlength = 700;\r\n  @Input() public placeholder?: string;\r\n  @Input() public autocomplete?: string;\r\n  @Input() public tabIndex?: string | number;\r\n  @Input() public readOnly?: boolean;\r\n  @Input() public fetchMode?: boolean; // работает fetchEvent при клике\r\n  @Input() public required = false;\r\n  @Input() public disabled = false;\r\n  @Input() public commitOnInput = true; // коммитить по input или по change\r\n  @Input() public clearable = false;\r\n  @Input() public uppercase = false;\r\n  @Input() public invalid = false;\r\n  @Input() public errorText: string | undefined;\r\n  @Input()public side: 'top' | 'bottom' = 'bottom';\r\n  @Output() public cleared = new EventEmitter<void>();\r\n  @Output() public fetchEvent = new EventEmitter<any>();\r\n  @Output() public focus = new EventEmitter<any>();\r\n  @Output() public blur = new EventEmitter<any>();\r\n  public get id() {\r\n    return this._ID;\r\n  }\r\n  public focused = false;\r\n  public touched = false;\r\n  public control: AbstractControl | undefined | null;\r\n  public value: string | undefined = '';\r\n  public changeDetection: ChangeDetectorRef;\r\n\r\n  protected destroyed = false;\r\n  protected onTouchedCallback: (() => void) | undefined;\r\n  private _ID = '';\r\n\r\n  protected constructor(changeDetection: ChangeDetectorRef) {\r\n    this.changeDetection = changeDetection;\r\n  }\r\n\r\n  public handleInput(_e: Event): void {\r\n    if (this.commitOnInput) {\r\n      this.commit(this.value);\r\n    }\r\n  }\r\n\r\n  public notifyFocusEvent(e: Event): void {\r\n    // this.focusManager.notifyFocusMayChanged(this, e.type === 'focus');\r\n  }\r\n\r\n  // public writeValue(value: string | number | null): void {\r\n  //   this.value = value === null || value === undefined ? '' : '' + value;\r\n  //   if (!this.destroyed) {\r\n  //     this.changeDetection.detectChanges();\r\n  //   }\r\n  // }\r\n\r\n  // public clearValue(e: Event): void {\r\n  //   if (!this.disabled) {\r\n  //     this.writeValue(null);\r\n  //     this.commit(null);\r\n  //     this.cleared.emit();\r\n  //     this.returnFocus(e);\r\n  //   }\r\n  //   e.stopPropagation();\r\n  // }\r\n\r\n  public handleBlur(): void {\r\n    this.focused = false;\r\n    if (this.onTouchedCallback) {\r\n      this.onTouchedCallback();\r\n    }\r\n\r\n    this.blur.emit();\r\n    this.changeDetection.detectChanges();\r\n  }\r\n\r\n  public handleFocus(): void {\r\n    this.focused = this.touched = true;\r\n    if (this.onTouchedCallback) {\r\n      this.onTouchedCallback();\r\n    }\r\n    this.focus.emit();\r\n  }\r\n\r\n  public returnFocus(e?: Event): void {\r\n    if (\r\n      this.inputElement &&\r\n      this.inputElement.nativeElement &&\r\n      (!e || e.target !== this.inputElement.nativeElement)\r\n    ) {\r\n      this.inputElement.nativeElement.focus();\r\n      // HelperService.resetSelection(this.inputElement.nativeElement);\r\n    }\r\n  }\r\n\r\n  public loseFocus(): void {\r\n    this.inputElement?.nativeElement.blur();\r\n  }\r\n\r\n  public forceChange(): void {\r\n    if (this.inputElement) {\r\n      // this.inputElement.nativeElement.dispatchEvent(HelperService.createEvent('change', true, false));\r\n    }\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.commit = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    if (!this.destroyed) {\r\n      this.changeDetection.detectChanges();\r\n    }\r\n  }\r\n\r\n  public handleChange(): void {\r\n    if (!this.commitOnInput) {\r\n      this.commit(this.value);\r\n    }\r\n  }\r\n\r\n  public commit(_value: string | null | undefined): void {}\r\n}\r\n"]}
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-common-input-text.js","sourceRoot":"","sources":["../../../../../projects/dd-lib/src/lib/common/lib-common-input-text.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,UAAU,EACV,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;;AAalE,MAAM,OAAgB,2BAA2B;IAiC/C,IAAW,EAAE;QACX,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAYD,YAAsB,eAAkC;QA5BxC,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,kBAAa,GAAG,IAAI,CAAC,CAAC,mCAAmC;QACzD,cAAS,GAAG,KAAK,CAAC;QAClB,kBAAa,GAAG,IAAI,CAAC;QACrB,cAAS,GAAG,KAAK,CAAC;QAClB,YAAO,GAAG,KAAK,CAAC;QAChB,eAAU,GAAa,EAAE,CAAC;QAC3B,SAAI,GAAqB,QAAQ,CAAC;QAChC,YAAO,GAAG,IAAI,YAAY,EAAQ,CAAC;QACnC,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,UAAK,GAAG,IAAI,YAAY,EAAO,CAAC;QAChC,SAAI,GAAG,IAAI,YAAY,EAAO,CAAC;QAC/B,aAAQ,GAAG,IAAI,YAAY,EAAS,CAAC;QAM/C,YAAO,GAAG,KAAK,CAAC;QAChB,YAAO,GAAG,KAAK,CAAC;QAEhB,UAAK,GAAuB,EAAE,CAAC;QAE5B,cAAS,GAAG,KAAK,CAAC;QAEpB,QAAG,GAAG,EAAE,CAAC;QAGf,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;IACzC,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;IACtE,CAAC;IAED,IAAW,SAAS;QAClB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC,OAAO,CAAC;QACtB,CAAC;QAED,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QACxC,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAC3E,CAAC;IACM,WAAW,CAAC,EAAS;QAC1B,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;IACH,CAAC;IAGM,gBAAgB,CAAC,CAAQ;QAC9B,qEAAqE;IACvE,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QACjB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACnC,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC;IAEM,WAAW,CAAC,CAAS;QAC1B,IACE,IAAI,CAAC,YAAY;YACjB,IAAI,CAAC,YAAY,CAAC,aAAa;YAC/B,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,EACpD,CAAC;YACD,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACxC,iEAAiE;QACnE,CAAC;IACH,CAAC;IAEM,SAAS;QACd,IAAI,CAAC,YAAY,EAAE,aAAa,CAAC,IAAI,EAAE,CAAC;IAC1C,CAAC;IAEM,WAAW;QAChB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,mGAAmG;QACrG,CAAC;IACH,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;IACnB,CAAC;IAEM,iBAAiB,CAAC,EAAO;QAC9B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,uDAAuD;IACvD,4BAA4B;IAC5B,gCAAgC;IAChC,IAAI;IAEG,YAAY;QACjB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;IACH,CAAC;IAEM,MAAM,CAAC,MAAiC,IAAS,CAAC;8GApIrC,2BAA2B;kGAA3B,2BAA2B,6sBARpC;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,2BAA2B,CAAC;gBAC1D,KAAK,EAAE,IAAI;aACZ;SACF,mUAPS,EAAE;;2FASQ,2BAA2B;kBAXhD,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,QAAQ,EAAE,EAAE;oBACZ,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,4BAA4B,CAAC;4BAC1D,KAAK,EAAE,IAAI;yBACZ;qBACF;iBACF;sFAEqC,kBAAkB;sBAArD,SAAS;uBAAC,aAAa;gBACM,YAAY;sBAAzC,SAAS;uBAAC,OAAO;gBACe,eAAe;sBAA/C,SAAS;uBAAC,UAAU;gBACL,IAAI;sBAAnB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,eAAe;sBAA9B,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,GAAG;sBAAlB,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,GAAG;sBAAlB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACS,IAAI;sBAAlB,KAAK;gBACW,OAAO;sBAAvB,MAAM;gBACU,UAAU;sBAA1B,MAAM;gBACU,KAAK;sBAArB,MAAM;gBACU,IAAI;sBAApB,MAAM;gBACU,QAAQ;sBAAxB,MAAM","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {AbstractControl, NG_VALUE_ACCESSOR} from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'dd-lib-common-input',\r\n  template: '',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => LibCommonInputTextComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport abstract class LibCommonInputTextComponent {\r\n  @ViewChild('searchInput') protected inputSearchElement: ElementRef<HTMLInputElement> | undefined;\r\n  @ViewChild('input') protected inputElement: ElementRef<HTMLInputElement> | undefined;\r\n  @ViewChild('textarea') protected textAreaElement: ElementRef<HTMLTextAreaElement> | undefined;\r\n  @Input() public name: string | undefined;\r\n  @Input() public label: string | undefined;\r\n  @Input() public formControlName: string | undefined;\r\n  @Input() public type: 'password' | 'email' | 'number' | 'text' | undefined;\r\n  @Input() public contextClass: string | undefined;\r\n  @Input() public minlength: string | number | undefined;\r\n  @Input() public min: string | number | undefined;\r\n  @Input() public maxlength: string | number | undefined;\r\n  @Input() public max: string | number | undefined;\r\n  @Input() public placeholder?: string;\r\n  @Input() public autocomplete?: string;\r\n  @Input() public tabIndex?: string | number;\r\n  @Input() public readOnly?: boolean;\r\n  @Input() public autofocus?: boolean;\r\n  @Input() public fetchMode?: boolean; // работает fetchEvent при клике\r\n  @Input() public required = false;\r\n  @Input() public disabled = false;\r\n  @Input() public commitOnInput = true; // коммитить по input или по change\r\n  @Input() public clearable = false;\r\n  @Input() public showSelfError = true;\r\n  @Input() public uppercase = false;\r\n  @Input() public invalid = false;\r\n  @Input() public errorTexts: string[] = [];\r\n  @Input()public side: 'top' | 'bottom' = 'bottom';\r\n  @Output() public cleared = new EventEmitter<void>();\r\n  @Output() public fetchEvent = new EventEmitter<any>();\r\n  @Output() public focus = new EventEmitter<any>();\r\n  @Output() public blur = new EventEmitter<any>();\r\n  @Output() public fullBlur = new EventEmitter<Event>();\r\n  public get id() {\r\n    return this._ID;\r\n  }\r\n\r\n  public errorText: string | undefined;\r\n  public focused = false;\r\n  public touched = false;\r\n  public control: AbstractControl | undefined | null;\r\n  public value: string | undefined = '';\r\n  public changeDetection: ChangeDetectorRef;\r\n  protected destroyed = false;\r\n  protected onTouchedCallback: (() => void) | undefined;\r\n  private _ID = '';\r\n\r\n  protected constructor(changeDetection: ChangeDetectorRef) {\r\n    this.changeDetection = changeDetection;\r\n  }\r\n\r\n  public get invalidState(): boolean {\r\n    return this.invalid || this.control ? this.control!.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return this.invalid;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n    return this.invalidState ? ((dirty || touched) && !this.focused) : false;\r\n  }\r\n  public handleInput(_e: Event): void {\r\n    if (this.commitOnInput) {\r\n      this.commit(this.value);\r\n    }\r\n  }\r\n\r\n\r\n  public notifyFocusEvent(e: Event): void {\r\n    // this.focusManager.notifyFocusMayChanged(this, e.type === 'focus');\r\n  }\r\n\r\n  public handleBlur(): void {\r\n    this.focused = false;\r\n    if (this.onTouchedCallback) {\r\n      this.onTouchedCallback();\r\n    }\r\n\r\n    this.blur.emit();\r\n    this.changeDetection.detectChanges();\r\n  }\r\n\r\n  public handleFocus(): void {\r\n    this.focused = this.touched = true;\r\n    if (this.onTouchedCallback) {\r\n      this.onTouchedCallback();\r\n    }\r\n    this.focus.emit();\r\n  }\r\n\r\n  public returnFocus(e?: Event): void {\r\n    if (\r\n      this.inputElement &&\r\n      this.inputElement.nativeElement &&\r\n      (!e || e.target !== this.inputElement.nativeElement)\r\n    ) {\r\n      this.inputElement.nativeElement.focus();\r\n      // HelperService.resetSelection(this.inputElement.nativeElement);\r\n    }\r\n  }\r\n\r\n  public loseFocus(): void {\r\n    this.inputElement?.nativeElement.blur();\r\n  }\r\n\r\n  public forceChange(): void {\r\n    if (this.inputElement) {\r\n      // this.inputElement.nativeElement.dispatchEvent(HelperService.createEvent('change', true, false));\r\n    }\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.commit = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  // public setDisabledState(isDisabled: boolean): void {\r\n  //   console.log(isDisabled)\r\n  //   this.disabled = isDisabled;\r\n  // }\r\n\r\n  public handleChange(): void {\r\n    if (!this.commitOnInput) {\r\n      this.commit(this.value);\r\n    }\r\n  }\r\n\r\n  public commit(_value: string | null | undefined): void {}\r\n}\r\n"]}
@@ -3,13 +3,18 @@ import { NgOptimizedImage } from '@angular/common';
3
3
  import { LibSvgIconComponent } from "../../lib-svg-icon/lib-svg-icon.component";
4
4
  import * as i0 from "@angular/core";
5
5
  export class DataEmptyComponent {
6
+ constructor() {
7
+ this.text = 'По Вашему запросу ничего не найдено';
8
+ }
6
9
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DataEmptyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
7
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.2", type: DataEmptyComponent, isStandalone: true, selector: "dd-data-empty", inputs: { abs: "abs" }, ngImport: i0, template: "<div [class.abs]=\"abs\" class=\"data-empty\">\r\n <div class=\"data-empty__img not-found-bg\"></div>\r\n <div class=\"g-h5-title font-regular mt-12\">\u041F\u043E \u0412\u0430\u0448\u0435\u043C\u0443 \u0437\u0430\u043F\u0440\u043E\u0441\u0443 \u043D\u0438\u0447\u0435\u0433\u043E \u043D\u0435 \u043D\u0430\u0439\u0434\u0435\u043D\u043E</div>\r\n</div>\r\n", styles: [".data-empty{background:var(--main-bgc);display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:calc(60vh - var(--header-height));width:100%;text-align:center}.data-empty.abs{width:100vw;position:absolute}.data-empty__img{width:150px;height:150px;background-size:cover}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
10
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.2", type: DataEmptyComponent, isStandalone: true, selector: "dd-data-empty", inputs: { abs: "abs", text: "text" }, ngImport: i0, template: "<div [class.abs]=\"abs\" class=\"data-empty\">\r\n <div class=\"data-empty__img not-found-bg\"></div>\r\n <div class=\"g-h5-title font-regular mt-12\" [innerHTML]=\"text\"></div>\r\n</div>\r\n", styles: [".data-empty{background:var(--main-bgc);display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:calc(60vh - var(--header-height));width:100%;text-align:center}.data-empty.abs{width:100vw;position:absolute}.data-empty__img{width:150px;height:150px;background-size:cover}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
8
11
  }
9
12
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DataEmptyComponent, decorators: [{
10
13
  type: Component,
11
- args: [{ selector: 'dd-data-empty', standalone: true, imports: [NgOptimizedImage, LibSvgIconComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class.abs]=\"abs\" class=\"data-empty\">\r\n <div class=\"data-empty__img not-found-bg\"></div>\r\n <div class=\"g-h5-title font-regular mt-12\">\u041F\u043E \u0412\u0430\u0448\u0435\u043C\u0443 \u0437\u0430\u043F\u0440\u043E\u0441\u0443 \u043D\u0438\u0447\u0435\u0433\u043E \u043D\u0435 \u043D\u0430\u0439\u0434\u0435\u043D\u043E</div>\r\n</div>\r\n", styles: [".data-empty{background:var(--main-bgc);display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:calc(60vh - var(--header-height));width:100%;text-align:center}.data-empty.abs{width:100vw;position:absolute}.data-empty__img{width:150px;height:150px;background-size:cover}\n"] }]
14
+ args: [{ selector: 'dd-data-empty', standalone: true, imports: [NgOptimizedImage, LibSvgIconComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class.abs]=\"abs\" class=\"data-empty\">\r\n <div class=\"data-empty__img not-found-bg\"></div>\r\n <div class=\"g-h5-title font-regular mt-12\" [innerHTML]=\"text\"></div>\r\n</div>\r\n", styles: [".data-empty{background:var(--main-bgc);display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:calc(60vh - var(--header-height));width:100%;text-align:center}.data-empty.abs{width:100vw;position:absolute}.data-empty__img{width:150px;height:150px;background-size:cover}\n"] }]
12
15
  }], propDecorators: { abs: [{
13
16
  type: Input
17
+ }], text: [{
18
+ type: Input
14
19
  }] } });
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1lbXB0eS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZC1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtZW1wdHkvZGF0YS1lbXB0eS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZC1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtZW1wdHkvZGF0YS1lbXB0eS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQzs7QUFVOUUsTUFBTSxPQUFPLGtCQUFrQjs4R0FBbEIsa0JBQWtCO2tHQUFsQixrQkFBa0IsaUdDWi9CLHdXQUlBOzsyRkRRYSxrQkFBa0I7a0JBUjlCLFNBQVM7K0JBQ0UsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLGdCQUFnQixFQUFFLG1CQUFtQixDQUFDLG1CQUcvQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUcvQixHQUFHO3NCQUFsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nT3B0aW1pemVkSW1hZ2UgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtMaWJTdmdJY29uQ29tcG9uZW50fSBmcm9tIFwiLi4vLi4vbGliLXN2Zy1pY29uL2xpYi1zdmctaWNvbi5jb21wb25lbnRcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGQtZGF0YS1lbXB0eScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ09wdGltaXplZEltYWdlLCBMaWJTdmdJY29uQ29tcG9uZW50XSxcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGEtZW1wdHkuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vZGF0YS1lbXB0eS5jb21wb25lbnQuc2NzcycsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBEYXRhRW1wdHlDb21wb25lbnQge1xuICBASW5wdXQoKSBwdWJsaWMgYWJzOiBib29sZWFuIHwgdW5kZWZpbmVkO1xufVxuIiwiPGRpdiBbY2xhc3MuYWJzXT1cImFic1wiIGNsYXNzPVwiZGF0YS1lbXB0eVwiPlxyXG4gIDxkaXYgY2xhc3M9XCJkYXRhLWVtcHR5X19pbWcgbm90LWZvdW5kLWJnXCI+PC9kaXY+XHJcbiAgPGRpdiBjbGFzcz1cImctaDUtdGl0bGUgZm9udC1yZWd1bGFyIG10LTEyXCI+0J/QviDQktCw0YjQtdC80YMg0LfQsNC/0YDQvtGB0YMg0L3QuNGH0LXQs9C+INC90LUg0L3QsNC50LTQtdC90L48L2Rpdj5cclxuPC9kaXY+XHJcbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1lbXB0eS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZC1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtZW1wdHkvZGF0YS1lbXB0eS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZC1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtZW1wdHkvZGF0YS1lbXB0eS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQzs7QUFVOUUsTUFBTSxPQUFPLGtCQUFrQjtJQVIvQjtRQVVrQixTQUFJLEdBQUcscUNBQXFDLENBQUM7S0FDOUQ7OEdBSFksa0JBQWtCO2tHQUFsQixrQkFBa0IsK0dDWi9CLG9NQUlBOzsyRkRRYSxrQkFBa0I7a0JBUjlCLFNBQVM7K0JBQ0UsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLGdCQUFnQixFQUFFLG1CQUFtQixDQUFDLG1CQUcvQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUcvQixHQUFHO3NCQUFsQixLQUFLO2dCQUNVLElBQUk7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdPcHRpbWl6ZWRJbWFnZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0xpYlN2Z0ljb25Db21wb25lbnR9IGZyb20gXCIuLi8uLi9saWItc3ZnLWljb24vbGliLXN2Zy1pY29uLmNvbXBvbmVudFwiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkZC1kYXRhLWVtcHR5JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW05nT3B0aW1pemVkSW1hZ2UsIExpYlN2Z0ljb25Db21wb25lbnRdLFxuICB0ZW1wbGF0ZVVybDogJy4vZGF0YS1lbXB0eS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9kYXRhLWVtcHR5LmNvbXBvbmVudC5zY3NzJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIERhdGFFbXB0eUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHB1YmxpYyBhYnM6IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG4gIEBJbnB1dCgpIHB1YmxpYyB0ZXh0ID0gJ9Cf0L4g0JLQsNGI0LXQvNGDINC30LDQv9GA0L7RgdGDINC90LjRh9C10LPQviDQvdC1INC90LDQudC00LXQvdC+Jztcbn1cbiIsIjxkaXYgW2NsYXNzLmFic109XCJhYnNcIiBjbGFzcz1cImRhdGEtZW1wdHlcIj5cclxuICA8ZGl2IGNsYXNzPVwiZGF0YS1lbXB0eV9faW1nIG5vdC1mb3VuZC1iZ1wiPjwvZGl2PlxyXG4gIDxkaXYgY2xhc3M9XCJnLWg1LXRpdGxlIGZvbnQtcmVndWxhciBtdC0xMlwiIFtpbm5lckhUTUxdPVwidGV4dFwiPjwvZGl2PlxyXG48L2Rpdj5cclxuIl19