@libs-ui/services-config-project 0.2.28 → 0.2.30-6.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.
@@ -1,7 +1,7 @@
1
1
  /* eslint-disable @typescript-eslint/no-explicit-any */
2
2
  import { Injectable, computed, effect, signal } from "@angular/core";
3
3
  import { colorStepContrastFromOrigin, get } from "@libs-ui/utils";
4
- import { configButtonColor, configButtonStatus, configButtonTab, configHeading, configLinkButton, fontConfig, styleButtonTab, weights } from "./config-project-data";
4
+ import { configButtonColor, configButtonStatus, configButtonTab, configHeading, configLinkButton, fontConfig, sizeButtonConfig, styleButtonTab, weights } from "./config-project-data";
5
5
  import * as i0 from "@angular/core";
6
6
  export class LibsUiConfigProjectService {
7
7
  themeColor = signal('#226ff5');
@@ -13,11 +13,19 @@ export class LibsUiConfigProjectService {
13
13
  textReadonlyColor = signal('#071631');
14
14
  textDisableColor = signal('#9ca2ad');
15
15
  backgroundReadonlyColor = signal('#f8f9fa');
16
+ backgroundUserSelection = signal('#00000040');
17
+ backgroundList = signal('#f8f9fa');
18
+ backgroundListHover = signal('#f8f9fa');
19
+ backgroundListHoverDanger = signal('#fef5f6');
16
20
  configFont = signal(fontConfig);
17
21
  configHead = signal(configHeading);
22
+ functionGetConfigButtonIncludes = signal(() => {
23
+ return {};
24
+ });
18
25
  configButton = computed(() => {
19
- return { ...configButtonColor(this.themeColor()), ...configLinkButton(this.themeColor()) };
26
+ return { ...configButtonColor(this.themeColor()), ...configLinkButton(this.themeColor()), ...this.functionGetConfigButtonIncludes()(this.themeColor()) };
20
27
  });
28
+ configButtonSize = signal(sizeButtonConfig());
21
29
  configButtonStatus = signal(configButtonStatus());
22
30
  configButtonTab = signal(configButtonTab());
23
31
  styleClassGlobalEl = document.createElement('style');
@@ -36,6 +44,9 @@ export class LibsUiConfigProjectService {
36
44
  effect(() => {
37
45
  this.setupButtonTab();
38
46
  });
47
+ effect(() => {
48
+ this.setupButtonSize();
49
+ });
39
50
  this.configString();
40
51
  this.setClassGlobal();
41
52
  }
@@ -60,6 +71,18 @@ export class LibsUiConfigProjectService {
60
71
  set TextReadonlyColor(color) {
61
72
  this.textReadonlyColor.set(color || '#071631');
62
73
  }
74
+ set BackgroundUserSelection(color) {
75
+ this.backgroundUserSelection.set(color || '#00000040');
76
+ }
77
+ set BackgroundList(color) {
78
+ this.backgroundList.set(color || '#f8f9fa');
79
+ }
80
+ set BackgroundListHover(color) {
81
+ this.backgroundListHover.set(color || '#f8f9fa');
82
+ }
83
+ set BackgroundListHoverDanger(color) {
84
+ this.backgroundListHover.set(color || '#fef5f6');
85
+ }
63
86
  set BackgroundDisableColor(color) {
64
87
  this.backgroundDisableColor.set(color || '#f8f9fa');
65
88
  }
@@ -75,6 +98,9 @@ export class LibsUiConfigProjectService {
75
98
  get ConfigButton() {
76
99
  return this.configButton;
77
100
  }
101
+ set FunctionGetConfigButtonIncludes(functionGetConfigButtonIncludes) {
102
+ this.functionGetConfigButtonIncludes.set(functionGetConfigButtonIncludes);
103
+ }
78
104
  get ConfigButtonStatus() {
79
105
  return this.configButtonStatus();
80
106
  }
@@ -86,24 +112,32 @@ export class LibsUiConfigProjectService {
86
112
  }
87
113
  // public hàm để sử dụng cho component input sử dụng tagInput = frameArea;
88
114
  setupFontFamily(currentDoc) {
89
- currentDoc = currentDoc || document;
90
- const doc = currentDoc.documentElement;
91
- doc.style.setProperty('--libs-ui-font-family-name', `${this.configFont().name},Arial, Helvetica, sans-serif`);
92
- Object.keys(weights).forEach(key => {
93
- const fontFace = new FontFace(this.configFont().name, `url(${get(this.configFont(), key)})`, { weight: get(weights, key) });
94
- fontFace.load().then(loadedFont => {
95
- if ('add' in currentDoc.fonts) {
96
- currentDoc.fonts.add(loadedFont);
115
+ try {
116
+ currentDoc = currentDoc || document;
117
+ const doc = currentDoc.documentElement;
118
+ doc.style.setProperty('--libs-ui-font-family-name', `${this.configFont().name},Arial, Helvetica, sans-serif`);
119
+ Object.keys(weights).forEach(key => {
120
+ if (!get(this.configFont(), key)) {
121
+ return;
97
122
  }
123
+ const fontFace = new FontFace(this.configFont().name, `url(${get(this.configFont(), key)})`, { weight: get(weights, key) });
124
+ fontFace.load().then(loadedFont => {
125
+ if (currentDoc && 'add' in currentDoc.fonts) {
126
+ currentDoc.fonts.add(loadedFont);
127
+ }
128
+ });
98
129
  });
99
- });
130
+ }
131
+ catch (error) {
132
+ console.log(error);
133
+ }
100
134
  }
101
135
  setupFontHead() {
102
- const configHeads = this.configHead();
136
+ const configHeadsData = this.configHead();
103
137
  let styles = '';
104
- Object.keys(configHeads).forEach(keyConfig => {
138
+ Object.keys(configHeadsData).forEach(keyConfig => {
105
139
  let style = `font-family:var(--libs-ui-font-family-name,'Arial');`;
106
- const config = get(configHeading, keyConfig);
140
+ const config = get(configHeadsData, keyConfig);
107
141
  Object.keys(config).forEach(key => {
108
142
  style = `${style}${key}:${get(config, key)};`;
109
143
  });
@@ -113,6 +147,17 @@ export class LibsUiConfigProjectService {
113
147
  this.styleClassHeadEl.innerHTML = styles;
114
148
  document.head.append(this.styleClassHeadEl);
115
149
  }
150
+ setupButtonSize() {
151
+ const configButtonSize = this.configButtonSize();
152
+ const doc = document.documentElement;
153
+ Object.keys(configButtonSize).forEach(keySize => {
154
+ const config = get(configButtonSize, keySize);
155
+ Object.keys(config).forEach(keyType => {
156
+ const name = `--libs-ui-button-size-${keySize}-${keyType.replace(/[_]/g, '-')}`;
157
+ doc.style.setProperty(name, get(config, keyType));
158
+ });
159
+ });
160
+ }
116
161
  setupButtonTab() {
117
162
  const configButtonTab = this.configButtonTab();
118
163
  let styles = '';
@@ -138,6 +183,10 @@ export class LibsUiConfigProjectService {
138
183
  light_5: colorStepContrastFromOrigin(this.themeColor(), 70)?.light,
139
184
  light_6: colorStepContrastFromOrigin(this.themeColor(), 80)?.light,
140
185
  dark: colorStepContrastFromOrigin(this.themeColor(), 20)?.dark,
186
+ background_list: this.backgroundList(),
187
+ background_list_hover: this.backgroundListHover(),
188
+ background_list_hover_danger: this.backgroundListHoverDanger(),
189
+ background_selection: this.backgroundUserSelection(),
141
190
  border: this.borderColor(),
142
191
  border_error: this.borderErrorColor(),
143
192
  text_error: this.textErrorColor(),
@@ -159,38 +208,61 @@ export class LibsUiConfigProjectService {
159
208
  }
160
209
  setClassGlobal() {
161
210
  this.styleClassGlobalEl.innerHTML = `
162
- .libs-ui-border-primary-general{border: 1px solid var(--libs-ui-color-default, #226FF5) !important;}
163
- .libs-ui-border-primary-focus-general{border: 1px solid var(--libs-ui-color-light-1, #4e8cf7) !important;}
164
- .libs-ui-border-primary-hover-general{border: 1px solid var(--libs-ui-color-light-3, #f4f8ff) !important;}
165
- .libs-ui-border-general{ border: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
166
- .libs-ui-border-top-general{border-top: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
167
- .libs-ui-border-right-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
168
- .libs-ui-border-bottom-general{border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
169
- .libs-ui-border-dashed-bottom-general{border-bottom: dashed 1px var(--libs-ui-color-border, #e6e7ea) !important;}
170
- .libs-ui-border-left-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
171
- .libs-ui-border-x-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea) !important; border-right: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
172
- .libs-ui-border-y-general{border-top: 1px solid var(--libs-ui-color-border, #e6e7ea) !important; border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
173
- .libs-ui-border-left-top-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea) !important; border-top: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
174
- .libs-ui-border-left-bottom-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea) !important; border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
175
- .libs-ui-border-right-top-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea) !important; border-top: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
176
- .libs-ui-border-right-bottom-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea) !important; border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}
211
+ .libs-ui-border-primary-general{border: 1px solid var(--libs-ui-color-default, #226FF5);}
212
+ .libs-ui-border-primary-focus-general{border: 1px solid var(--libs-ui-color-light-1, #4e8cf7);}
213
+ .libs-ui-border-primary-hover-general{border: 1px solid var(--libs-ui-color-light-3, #f4f8ff);}
214
+ .libs-ui-border-general{ border: 1px solid var(--libs-ui-color-border, #e6e7ea);}
215
+ .libs-ui-border-top-general{border-top: 1px solid var(--libs-ui-color-border, #e6e7ea);}
216
+ .libs-ui-border-right-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea);}
217
+ .libs-ui-border-bottom-general{border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea);}
218
+ .libs-ui-border-dashed-general{border: dashed 1px var(--libs-ui-color-border, #e6e7ea);}
219
+ .libs-ui-border-top-dashed-general{border-top: dashed 1px var(--libs-ui-color-border, #e6e7ea);}
220
+ .libs-ui-border-left-dashed-general{border-left: dashed 1px var(--libs-ui-color-border, #e6e7ea);}
221
+ .libs-ui-border-right-dashed-general{border-right: dashed 1px var(--libs-ui-color-border, #e6e7ea);}
222
+ .libs-ui-border-bottom-dashed-general{border-bottom: dashed 1px var(--libs-ui-color-border, #e6e7ea);}
223
+ .libs-ui-border-left-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea);}
224
+ .libs-ui-border-x-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea); border-right: 1px solid var(--libs-ui-color-border, #e6e7ea);}
225
+ .libs-ui-border-y-general{border-top: 1px solid var(--libs-ui-color-border, #e6e7ea); border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea);}
226
+ .libs-ui-border-left-top-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea); border-top: 1px solid var(--libs-ui-color-border, #e6e7ea);}
227
+ .libs-ui-border-left-bottom-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea); border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea);}
228
+ .libs-ui-border-right-top-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea); border-top: 1px solid var(--libs-ui-color-border, #e6e7ea);}
229
+ .libs-ui-border-right-bottom-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea); border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea);}
177
230
  .libs-ui-border-error-general{border: 1px solid var(--libs-ui-color-border-error, #ee2d41) !important;}
178
- .libs-ui-bg-list {background-color: #f8f9fa !important;}
179
- .libs-ui-bg-list-hover:hover {background-color: #f8f9fa !important;}
180
- .libs-ui-bg-list-active {background-color: var(--libs-ui-color-light-3, #f4f8ff) !important;}
181
- .libs-ui-bg-list-hover-active:hover {background-color: #f8f9fa !important;}
182
- .libs-ui-bg-list-hover-active:active {background-color: var(--libs-ui-color-light-3, #f4f8ff) !important;}
183
- .libs-ui-text-error {color: var(--libs-ui-color-text-error, #ff5454); !important}
231
+ .libs-ui-bg-list {background-color: var(--libs-ui-background-list, #f8f9fa);}
232
+ .libs-ui-bg-list-hover:hover {background-color: var(--libs-ui-background-list-hover, #f8f9fa);}
233
+ .libs-ui-bg-list-active {background-color: var(--libs-ui-color-light-3, #f4f8ff);}
234
+ .libs-ui-bg-list-hover-active:hover {background-color: #f8f9fa;}
235
+ .libs-ui-bg-list-hover-active:active {background-color: var(--libs-ui-color-light-3, #f4f8ff);}
236
+ .libs-ui-bg-list-hover-danger:hover {background-color: var(--libs-ui-background-list-hover-danger, #fef5f6); color: var(--libs-ui-color-icon-hover-danger, #f15767) !important; [class*="libs-ui-icon-"],[class*="icon-font-3rd"]{&:before,&:after{color: var(--libs-ui-color-icon-hover-danger, #f15767) !important;}}}
237
+ .libs-ui-text-error {color: var(--libs-ui-color-text-error, #ff5454) !important;}
184
238
  .libs-ui-text-error::before {color: var(--libs-ui-color-text-error, #ff5454) !important;}
185
- .libs-ui-disable {cursor: default !important;text-decoration: none;color:var(--libs-ui-color-text-disable, #cdd0d6) !important}
186
- .libs-ui-disable::before {color:var(--libs-ui-color-text-disable, #9ca2ad) !important}
239
+ .libs-ui-disable {cursor: not-allowed !important;text-decoration: none;color:var(--libs-ui-color-text-disable, #cdd0d6) !important;}
240
+ .libs-ui-disable::before {color:var(--libs-ui-color-text-disable, #9ca2ad) !important;}
187
241
  .libs-ui-disable-background{background: var(--libs-ui-color-background-disable, #f8f9fa) !important;}
188
- .libs-ui-disable-active {color:var(--libs-ui-color-light-4,#91b7fa) !important}
189
- .libs-ui-disable-active::before {color:var(--libs-ui-color-light-4,#91b7fa) !important}
190
- .libs-ui-readonly {cursor: default !important;color:var(--libs-ui-color-text-readonly, #071631) !important;}
242
+ .libs-ui-disable-active {color:var(--libs-ui-color-light-4,#91b7fa) !important;}
243
+ .libs-ui-disable-active::before {color:var(--libs-ui-color-light-4,#91b7fa) !important;}
244
+ .libs-ui-disable-active-background{background: var(--libs-ui-color-light-4,#91b7fa) !important;}
245
+ .libs-ui-readonly {cursor: not-allowed !important;color:var(--libs-ui-color-text-readonly, #071631) !important;}
191
246
  .libs-ui-readonly::before {color:var(--libs-ui-color-text-readonly, #071631) !important;}
192
247
  .libs-ui-readonly-background{background: var(--libs-ui-color-background-readonly, #f8f9fa) !important;}
193
- .libs-ui-icon-hover-danger:hover {color: var(--libs-ui-color-icon-hover-danger, #f15767) !important; [class*="libs-ui-icon-"]{&:before,&:after{color: var(--libs-ui-color-icon-hover-danger, #f15767) !important;}}}
248
+ .libs-ui-icon-hover-danger:hover {color: var(--libs-ui-color-icon-hover-danger, #f15767) !important; [class*="libs-ui-icon-"],[class*="icon-font-3rd"]{&:before,&:after{color: var(--libs-ui-color-icon-hover-danger, #f15767) !important;}}}
249
+ .break-word{word-break: break-word !important;}
250
+ .libs-ui-shadow {box-shadow: 0 2px 10px 1px rgba(51, 51, 51, 0.1);}
251
+ .libs-ui-shadow-md {box-shadow: 0 4px 8px 0 rgba(51, 51, 51, 0.1);}
252
+ .libs-ui-shadow-lg {box-shadow: 0 15px 30px 0 rgba(51, 51, 51, 0.1);}
253
+ .libs-ui-shadow-top {box-shadow: 0 -5px 5px -5px rgba(51, 51, 51, 0.1);}
254
+ .libs-ui-shadow-right {box-shadow: -5px 0 5px -5px rgba(51, 51, 51, 0.1);}
255
+ .libs-ui-shadow-bottom {box-shadow: 0 5px 5px -5px rgba(51, 51, 51, 0.1);}
256
+ .libs-ui-shadow-left {box-shadow: 5px 0 5px -5px rgba(51, 51, 51, 0.1);}
257
+ .libs-ui-shadow-sm {box-shadow: 0 1px 2px 0 rgba(51, 51, 51, 0.1);}
258
+ .libs-ui-shadow-popup {box-shadow: -2px 0 4px 0 rgba(51, 51, 51, 0.1);}
259
+ .libs-ui-shadow-none {box-shadow: none !important;}
260
+ .libs-ui-shadow-small {box-shadow: 0px 1px 2px 0px rgba(0,20,51,.04), 0px 1px 1px 0px rgba(0,20,51,.02);}
261
+ .libs-ui-shadow-medium {box-shadow: 0px 4px 8px 0px rgba(0, 20, 51, 0.04), 0px 1px 1px 0px rgba(0, 20, 51, 0.02);}
262
+ .libs-ui-shadow-large {box-shadow: 0px 4px 16px 0px rgba(0,20,51,.1), 0px 1px 1px 0px rgba(0,20,51,.02);}
263
+ .libs-ui-shadow-extra-large {box-shadow: 0px 8px 56px 0px rgba(0,20,51,.05), 0px 1px 1px 0px rgba(0,20,51,.02);}
264
+ ::-moz-selection {background: var(--libs-ui-color-background-selection, #00000040) !important;}
265
+ ::selection {background: var(--libs-ui-color-background-selection, #00000040) !important;}
194
266
  `.replace(/\n+/g, '');
195
267
  document.head.append(this.styleClassGlobalEl);
196
268
  }
@@ -254,4 +326,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
254
326
  providedIn: 'root'
255
327
  }]
256
328
  }], ctorParameters: () => [] });
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config-project.service.js","sourceRoot":"","sources":["../../../../../libs-ui/services/config-project/src/config-project.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable, computed, effect, signal } from \"@angular/core\";\nimport { colorStepContrastFromOrigin, get } from \"@libs-ui/utils\";\nimport { configButtonColor, configButtonStatus, configButtonTab, configHeading, configLinkButton, fontConfig, styleButtonTab, weights } from \"./config-project-data\";\nimport { ILibsUiConfigButtonStatus, ILibsUiConfigButtonTab, ILibsUiConfigFontFamily, ILibsUiConfigFontHeading } from \"./config-project.interface\";\n@Injectable({\n  providedIn: 'root'\n})\n\nexport class LibsUiConfigProjectService {\n  private readonly themeColor = signal<string>('#226ff5');\n  private readonly borderColor = signal<string>('#e6e7ea');\n  private readonly textErrorColor = signal<string>('#ff5454');\n  private readonly iconHoverDangerColor = signal<string>('#f15767');\n  private readonly borderErrorColor = signal<string>('#ee2d41');\n  private readonly backgroundDisableColor = signal<string>('#f8f9fa');\n  private readonly textReadonlyColor = signal<string>('#071631');\n  private readonly textDisableColor = signal<string>('#9ca2ad');\n  private readonly backgroundReadonlyColor = signal<string>('#f8f9fa');\n  private readonly configFont = signal<ILibsUiConfigFontFamily>(fontConfig);\n  private readonly configHead = signal<ILibsUiConfigFontHeading>(configHeading);\n  private readonly configButton = computed(() => {\n    return { ...configButtonColor(this.themeColor()), ...configLinkButton(this.themeColor()) };\n  });\n  private readonly configButtonStatus = signal<ILibsUiConfigButtonStatus>(configButtonStatus());\n  private readonly configButtonTab = signal<ILibsUiConfigButtonTab>(configButtonTab());\n  private readonly styleClassGlobalEl = document.createElement('style');\n  private readonly styleClassHeadEl = document.createElement('style');\n  private readonly styleClassButtonTabEl = document.createElement('style');\n\n  constructor() {\n    effect(() => {\n      this.setThemeColor();\n    });\n\n    effect(() => {\n      this.setupFontFamily();\n    });\n\n    effect(() => {\n      this.setupFontHead();\n    });\n\n    effect(() => {\n      this.setupButtonTab();\n    });\n\n    this.configString();\n    this.setClassGlobal();\n  }\n\n  public set ThemeColor(color: string) {\n    this.themeColor.set(color || '#226ff5');\n  }\n\n  public set BorderColor(color: string) {\n    this.borderColor.set(color || '#e6e7ea');\n  }\n\n  public set BorderErrorColor(color: string) {\n    this.borderErrorColor.set(color || '#ee2d41');\n  }\n\n  public set TextErrorColor(color: string) {\n    this.textErrorColor.set(color || '#ff5454');\n  }\n\n  public set IconHoverDangerColor(color: string) {\n    this.iconHoverDangerColor.set(color || '#ff5454');\n  }\n\n  public set BackgroundReadonlyColor(color: string) {\n    this.backgroundReadonlyColor.set(color || '#f15767');\n  }\n\n  public set TextReadonlyColor(color: string) {\n    this.textReadonlyColor.set(color || '#071631');\n  }\n\n  public set BackgroundDisableColor(color: string) {\n    this.backgroundDisableColor.set(color || '#f8f9fa');\n  }\n\n  public set TextDisableColor(color: string) {\n    this.textDisableColor.set(color || '#9ca2ad');\n  }\n\n  public set ConfigFont(configFont: ILibsUiConfigFontFamily) {\n    this.configFont.set({ ...configFont });\n  }\n\n  public set ConfigFontHead(configHead: ILibsUiConfigFontHeading) {\n    this.configHead.set({ ...configHead });\n  }\n\n  public get ConfigButton() {\n    return this.configButton;\n  }\n\n  public get ConfigButtonStatus() {\n    return this.configButtonStatus();\n  }\n\n  public set ConfigButtonStatus(config: ILibsUiConfigButtonStatus) {\n    this.configButtonStatus.set(config);\n  }\n\n  public set ConfigButtonTab(config: ILibsUiConfigButtonTab) {\n    this.configButtonTab.set(config);\n  }\n\n  // public hàm để sử dụng cho component input sử dụng tagInput = frameArea;\n  public setupFontFamily(currentDoc?: Document) {\n    currentDoc = currentDoc || document;\n    const doc = currentDoc.documentElement;\n\n    doc.style.setProperty('--libs-ui-font-family-name', `${this.configFont().name},Arial, Helvetica, sans-serif`);\n    Object.keys(weights).forEach(key => {\n      const fontFace = new FontFace(this.configFont().name, `url(${get(this.configFont(), key)})`, { weight: get(weights, key) });\n      fontFace.load().then(loadedFont => {\n        if ('add' in currentDoc.fonts) {\n          (currentDoc.fonts as any).add(loadedFont);\n        }\n      });\n    });\n  }\n\n  private setupFontHead() {\n    const configHeads = this.configHead();\n    let styles = '';\n    Object.keys(configHeads).forEach(keyConfig => {\n      let style = `font-family:var(--libs-ui-font-family-name,'Arial');`;\n      const config = get(configHeading, keyConfig);\n      Object.keys(config).forEach(key => {\n        style = `${style}${key}:${get(config, key)};`;\n      });\n      styles = `${styles} .libs-ui-font-${keyConfig}{${style}}.libs-ui-font-${keyConfig}i{${style.replace(/;/g,' !important;')}}`;\n    });\n\n    styles = `*{box-sizing: border-box !important;}${styles}`;\n\n    this.styleClassHeadEl.innerHTML = styles;\n    document.head.append(this.styleClassHeadEl);\n  }\n\n  private setupButtonTab() {\n    const configButtonTab = this.configButtonTab();\n    let styles = '';\n\n    Object.keys(configButtonTab).forEach(key => {\n      const config = get(configButtonTab, key);\n      const style = config ? styleButtonTab(key, config) : '';\n\n      styles = `${styles}${style}`;\n    });\n    this.styleClassButtonTabEl.innerHTML = styles;\n    document.head.append(this.styleClassButtonTabEl);\n  }\n\n  private setThemeColor() {\n    const doc = document.documentElement;\n    [{\n      group: 'libs-ui',\n      type: 'color',\n      property: {\n        default: colorStepContrastFromOrigin(this.themeColor(), 0)?.light,\n        light_1: colorStepContrastFromOrigin(this.themeColor(), 20)?.light,\n        light_2: colorStepContrastFromOrigin(this.themeColor(), 90)?.light,\n        light_3: colorStepContrastFromOrigin(this.themeColor(), 95)?.light,\n        light_4: colorStepContrastFromOrigin(this.themeColor(), 50)?.light,\n        light_5: colorStepContrastFromOrigin(this.themeColor(), 70)?.light,\n        light_6: colorStepContrastFromOrigin(this.themeColor(), 80)?.light,\n        dark: colorStepContrastFromOrigin(this.themeColor(), 20)?.dark,\n        border: this.borderColor(),\n        border_error: this.borderErrorColor(),\n        text_error: this.textErrorColor(),\n        icon_hover_danger: this.iconHoverDangerColor(),\n        background_readonly: this.backgroundReadonlyColor(),\n        text_readonly: this.textReadonlyColor(),\n        background_disable: this.backgroundDisableColor(),\n        text_disable: this.textDisableColor(),\n        gradient_from: this.themeColor().toLocaleUpperCase() === '#226FF5' ? colorStepContrastFromOrigin(this.themeColor(), 10)?.light : colorStepContrastFromOrigin(this.themeColor(), 0)?.light,\n        gradient_to: this.themeColor().toLocaleUpperCase() === '#226FF5' ? colorStepContrastFromOrigin('#5B2EBB', 10)?.light : colorStepContrastFromOrigin(this.themeColor(), 20)?.dark,\n      }\n    }].forEach(item => {\n      const name = `--${item.group.replace(/[_]/g, '-')}-${item.type.replace(/[_]/g, '-')}`;\n      Object.keys(item.property).forEach(key => doc.style.setProperty(`${name}-${key.replace(/[_]/g, '-')}`, (item.property as any)[key]));\n    });\n  }\n\n  public colorStepContrastFromOrigin(step: number, color?: string) {\n    return colorStepContrastFromOrigin(color || this.themeColor(), step || 0);\n  }\n\n  private setClassGlobal() {\n    this.styleClassGlobalEl.innerHTML = `\n    .libs-ui-border-primary-general{border: 1px solid var(--libs-ui-color-default, #226FF5) !important;}\n    .libs-ui-border-primary-focus-general{border: 1px solid var(--libs-ui-color-light-1, #4e8cf7) !important;}\n    .libs-ui-border-primary-hover-general{border: 1px solid var(--libs-ui-color-light-3, #f4f8ff) !important;}\n    .libs-ui-border-general{ border: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-top-general{border-top: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-right-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-bottom-general{border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-dashed-bottom-general{border-bottom: dashed 1px var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-left-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-x-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;  border-right: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-y-general{border-top: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;  border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-left-top-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;  border-top: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-left-bottom-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;  border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-right-top-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;  border-top: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-right-bottom-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;  border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea) !important;}\n    .libs-ui-border-error-general{border: 1px solid var(--libs-ui-color-border-error, #ee2d41) !important;}\n    .libs-ui-bg-list {background-color: #f8f9fa !important;}\n    .libs-ui-bg-list-hover:hover {background-color: #f8f9fa !important;}\n    .libs-ui-bg-list-active {background-color:  var(--libs-ui-color-light-3, #f4f8ff) !important;}\n    .libs-ui-bg-list-hover-active:hover {background-color: #f8f9fa !important;}\n    .libs-ui-bg-list-hover-active:active {background-color: var(--libs-ui-color-light-3, #f4f8ff) !important;}\n    .libs-ui-text-error {color: var(--libs-ui-color-text-error, #ff5454); !important}\n    .libs-ui-text-error::before {color: var(--libs-ui-color-text-error, #ff5454) !important;}\n    .libs-ui-disable {cursor: default !important;text-decoration: none;color:var(--libs-ui-color-text-disable, #cdd0d6) !important}\n    .libs-ui-disable::before {color:var(--libs-ui-color-text-disable, #9ca2ad) !important}\n    .libs-ui-disable-background{background: var(--libs-ui-color-background-disable, #f8f9fa) !important;}\n    .libs-ui-disable-active {color:var(--libs-ui-color-light-4,#91b7fa) !important}\n    .libs-ui-disable-active::before {color:var(--libs-ui-color-light-4,#91b7fa) !important}\n    .libs-ui-readonly {cursor: default !important;color:var(--libs-ui-color-text-readonly, #071631) !important;}\n    .libs-ui-readonly::before {color:var(--libs-ui-color-text-readonly, #071631) !important;}\n    .libs-ui-readonly-background{background: var(--libs-ui-color-background-readonly, #f8f9fa) !important;}\n    .libs-ui-icon-hover-danger:hover {color: var(--libs-ui-color-icon-hover-danger, #f15767) !important; [class*=\"libs-ui-icon-\"]{&:before,&:after{color: var(--libs-ui-color-icon-hover-danger, #f15767) !important;}}}\n    `.replace(/\\n+/g, '');\n\n    document.head.append(this.styleClassGlobalEl);\n  }\n\n  private configString() {\n    const prototype = String.prototype as any;\n    prototype.replaceAt = function (index: number, replacement: string) {\n      const values = this.split('');\n\n      values[index] = replacement;\n\n      return values.join('');\n    }\n\n    prototype.replaceAll = function (index: number, separator: string, replacement: string) {\n      const regex = new RegExp(separator, 'g');\n\n      return `${this.substr(0, index)}${this.substr(index + 1 + (replacement?.length || 0)).replace(regex, replacement)}`;\n    }\n\n    prototype.occurrencesByCharacter = function (character: string): number {\n      const values = this.split('');\n\n      if (!values || !values.length) {\n        return 0;\n      }\n\n      return values.filter((char: string) => char === character).length;\n    }\n\n    prototype.indexesOfCharacter = function (character: string): Array<number> {\n      const values: Array<string> = this.split('');\n      const indexes: Array<number> = [];\n\n      if (!values || !values.length) {\n        return indexes;\n      }\n      for (const indexValue in values) {\n        if (values[indexValue] === character) {\n          indexes.push(+indexValue);\n        }\n      }\n\n      return indexes;\n    }\n\n\n    prototype.indexesByString = function (str: string): Array<number> {\n      const values: Array<string> = this as any;\n      const indexes: Array<number> = [];\n\n      if (!values || !values.length || !str || !str.length || values.length < str.length) {\n\n        return indexes;\n      }\n      for (const indexValue in values) {\n        if (values[indexValue] !== str[0] || ((+indexValue) + str.length) > values.length) {\n          continue;\n        }\n\n        for (const index in str.split('')) {\n\n          if (values[(+indexValue) + (+index)] !== str[index]) {\n            break;\n          }\n        }\n        indexes.push(+indexValue);\n      }\n\n      return indexes;\n    }\n  }\n\n}\n"]}
329
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config-project.service.js","sourceRoot":"","sources":["../../../../../libs-ui/services/config-project/src/config-project.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable, computed, effect, signal } from \"@angular/core\";\nimport { PathsToStringProps } from \"@libs-ui/interfaces-types\";\nimport { colorStepContrastFromOrigin, get } from \"@libs-ui/utils\";\nimport { configButtonColor, configButtonStatus, configButtonTab, configHeading, configLinkButton, fontConfig, sizeButtonConfig, styleButtonTab, weights } from \"./config-project-data\";\nimport { IColorButton, ILibsUiConfigButtonSize, ILibsUiConfigButtonStatus, ILibsUiConfigButtonTab, ILibsUiConfigFontFamily, ILibsUiConfigFontHeading, ILibsUiConfigFontWeight } from \"./config-project.interface\";\n@Injectable({\n  providedIn: 'root'\n})\n\nexport class LibsUiConfigProjectService {\n  private readonly themeColor = signal<string>('#226ff5');\n  private readonly borderColor = signal<string>('#e6e7ea');\n  private readonly textErrorColor = signal<string>('#ff5454');\n  private readonly iconHoverDangerColor = signal<string>('#f15767');\n  private readonly borderErrorColor = signal<string>('#ee2d41');\n  private readonly backgroundDisableColor = signal<string>('#f8f9fa');\n  private readonly textReadonlyColor = signal<string>('#071631');\n  private readonly textDisableColor = signal<string>('#9ca2ad');\n  private readonly backgroundReadonlyColor = signal<string>('#f8f9fa');\n  private readonly backgroundUserSelection = signal<string>('#00000040');\n  private readonly backgroundList = signal<string>('#f8f9fa');\n  private readonly backgroundListHover = signal<string>('#f8f9fa');\n  private readonly backgroundListHoverDanger = signal<string>('#fef5f6');\n  private readonly configFont = signal<ILibsUiConfigFontFamily>(fontConfig);\n  private readonly configHead = signal<ILibsUiConfigFontHeading>(configHeading);\n  private readonly functionGetConfigButtonIncludes = signal<(rootColor: string) => { [key: string]: IColorButton }>(() => {\n    return {};\n  });\n  private readonly configButton = computed<{ [key: string]: IColorButton }>(() => {\n    return { ...configButtonColor(this.themeColor()), ...configLinkButton(this.themeColor()), ...this.functionGetConfigButtonIncludes()(this.themeColor()) };\n  });\n  private readonly configButtonSize = signal<ILibsUiConfigButtonSize>(sizeButtonConfig());\n  private readonly configButtonStatus = signal<ILibsUiConfigButtonStatus>(configButtonStatus());\n  private readonly configButtonTab = signal<ILibsUiConfigButtonTab>(configButtonTab());\n  private readonly styleClassGlobalEl = document.createElement('style');\n  private readonly styleClassHeadEl = document.createElement('style');\n  private readonly styleClassButtonTabEl = document.createElement('style');\n  constructor() {\n    effect(() => {\n      this.setThemeColor();\n    });\n\n    effect(() => {\n      this.setupFontFamily();\n    });\n\n    effect(() => {\n      this.setupFontHead();\n    });\n\n    effect(() => {\n      this.setupButtonTab();\n    });\n\n    effect(() => {\n      this.setupButtonSize();\n    });\n\n    this.configString();\n    this.setClassGlobal();\n  }\n\n  public set ThemeColor(color: string) {\n    this.themeColor.set(color || '#226ff5');\n  }\n\n  public set BorderColor(color: string) {\n    this.borderColor.set(color || '#e6e7ea');\n  }\n\n  public set BorderErrorColor(color: string) {\n    this.borderErrorColor.set(color || '#ee2d41');\n  }\n\n  public set TextErrorColor(color: string) {\n    this.textErrorColor.set(color || '#ff5454');\n  }\n\n  public set IconHoverDangerColor(color: string) {\n    this.iconHoverDangerColor.set(color || '#ff5454');\n  }\n\n  public set BackgroundReadonlyColor(color: string) {\n    this.backgroundReadonlyColor.set(color || '#f15767');\n  }\n\n  public set TextReadonlyColor(color: string) {\n    this.textReadonlyColor.set(color || '#071631');\n  }\n\n  public set BackgroundUserSelection(color: string) {\n    this.backgroundUserSelection.set(color || '#00000040');\n  }\n\n  public set BackgroundList(color: string) {\n    this.backgroundList.set(color || '#f8f9fa');\n  }\n\n  public set BackgroundListHover(color: string) {\n    this.backgroundListHover.set(color || '#f8f9fa');\n  }\n\n  public set BackgroundListHoverDanger(color: string) {\n    this.backgroundListHover.set(color || '#fef5f6');\n  }\n\n  public set BackgroundDisableColor(color: string) {\n    this.backgroundDisableColor.set(color || '#f8f9fa');\n  }\n\n  public set TextDisableColor(color: string) {\n    this.textDisableColor.set(color || '#9ca2ad');\n  }\n\n  public set ConfigFont(configFont: ILibsUiConfigFontFamily) {\n    this.configFont.set({ ...configFont });\n  }\n\n  public set ConfigFontHead(configHead: ILibsUiConfigFontHeading) {\n    this.configHead.set({ ...configHead });\n  }\n\n  public get ConfigButton() {\n    return this.configButton;\n  }\n\n  public set FunctionGetConfigButtonIncludes(functionGetConfigButtonIncludes: (rootColor: string) => { [key: string]: IColorButton }) {\n    this.functionGetConfigButtonIncludes.set(functionGetConfigButtonIncludes);\n  }\n\n  public get ConfigButtonStatus() {\n    return this.configButtonStatus();\n  }\n\n  public set ConfigButtonStatus(config: ILibsUiConfigButtonStatus) {\n    this.configButtonStatus.set(config);\n  }\n\n  public set ConfigButtonTab(config: ILibsUiConfigButtonTab) {\n    this.configButtonTab.set(config);\n  }\n\n  // public hàm để sử dụng cho component input sử dụng tagInput = frameArea;\n  public setupFontFamily(currentDoc?: Document) {\n    try {\n      currentDoc = currentDoc || document;\n      const doc = currentDoc.documentElement;\n\n      doc.style.setProperty('--libs-ui-font-family-name', `${this.configFont().name},Arial, Helvetica, sans-serif`);\n      Object.keys(weights).forEach(key => {\n        if (!get(this.configFont(), key as PathsToStringProps<ILibsUiConfigFontFamily>)) {\n          return;\n        }\n        const fontFace = new FontFace(this.configFont().name, `url(${get(this.configFont(), key as PathsToStringProps<ILibsUiConfigFontFamily>)})`, { weight: get(weights, key as PathsToStringProps<ILibsUiConfigFontWeight>) });\n        fontFace.load().then(loadedFont => {\n          if (currentDoc && 'add' in currentDoc.fonts) {\n            (currentDoc.fonts as any).add(loadedFont);\n          }\n        });\n      });\n    } catch (error) {\n      console.log(error);\n    }\n  }\n\n  private setupFontHead() {\n    const configHeadsData = this.configHead();\n    let styles = '';\n    Object.keys(configHeadsData).forEach(keyConfig => {\n      let style = `font-family:var(--libs-ui-font-family-name,'Arial');`;\n      const config = get(configHeadsData, keyConfig as PathsToStringProps<ILibsUiConfigFontHeading>);\n      Object.keys(config).forEach(key => {\n        style = `${style}${key}:${get(config, key)};`;\n      });\n      styles = `${styles} .libs-ui-font-${keyConfig}{${style}}.libs-ui-font-${keyConfig}i{${style.replace(/;/g, ' !important;')}}`;\n    });\n\n    styles = `*{box-sizing: border-box !important;}${styles}`;\n\n    this.styleClassHeadEl.innerHTML = styles;\n    document.head.append(this.styleClassHeadEl);\n  }\n\n  private setupButtonSize() {\n    const configButtonSize = this.configButtonSize();\n    const doc = document.documentElement;\n    Object.keys(configButtonSize).forEach(keySize => {\n      const config = get(configButtonSize, keySize as PathsToStringProps<ILibsUiConfigButtonSize>);\n      Object.keys(config).forEach(keyType => {\n        const name = `--libs-ui-button-size-${keySize}-${keyType.replace(/[_]/g, '-')}`;\n        doc.style.setProperty(name, get(config, keyType));\n      });\n    });\n  }\n\n  private setupButtonTab() {\n    const configButtonTab = this.configButtonTab();\n    let styles = '';\n\n    Object.keys(configButtonTab).forEach(key => {\n      const config = get(configButtonTab, key);\n      const style = config ? styleButtonTab(key, config) : '';\n\n      styles = `${styles}${style}`;\n    });\n    this.styleClassButtonTabEl.innerHTML = styles;\n    document.head.append(this.styleClassButtonTabEl);\n  }\n\n  private setThemeColor() {\n    const doc = document.documentElement;\n    [{\n      group: 'libs-ui',\n      type: 'color',\n      property: {\n        default: colorStepContrastFromOrigin(this.themeColor(), 0)?.light,\n        light_1: colorStepContrastFromOrigin(this.themeColor(), 20)?.light,\n        light_2: colorStepContrastFromOrigin(this.themeColor(), 90)?.light,\n        light_3: colorStepContrastFromOrigin(this.themeColor(), 95)?.light,\n        light_4: colorStepContrastFromOrigin(this.themeColor(), 50)?.light,\n        light_5: colorStepContrastFromOrigin(this.themeColor(), 70)?.light,\n        light_6: colorStepContrastFromOrigin(this.themeColor(), 80)?.light,\n        dark: colorStepContrastFromOrigin(this.themeColor(), 20)?.dark,\n        background_list: this.backgroundList(),\n        background_list_hover: this.backgroundListHover(),\n        background_list_hover_danger: this.backgroundListHoverDanger(),\n        background_selection: this.backgroundUserSelection(),\n        border: this.borderColor(),\n        border_error: this.borderErrorColor(),\n        text_error: this.textErrorColor(),\n        icon_hover_danger: this.iconHoverDangerColor(),\n        background_readonly: this.backgroundReadonlyColor(),\n        text_readonly: this.textReadonlyColor(),\n        background_disable: this.backgroundDisableColor(),\n        text_disable: this.textDisableColor(),\n        gradient_from: this.themeColor().toLocaleUpperCase() === '#226FF5' ? colorStepContrastFromOrigin(this.themeColor(), 10)?.light : colorStepContrastFromOrigin(this.themeColor(), 0)?.light,\n        gradient_to: this.themeColor().toLocaleUpperCase() === '#226FF5' ? colorStepContrastFromOrigin('#5B2EBB', 10)?.light : colorStepContrastFromOrigin(this.themeColor(), 20)?.dark,\n      }\n    }].forEach(item => {\n      const name = `--${item.group.replace(/[_]/g, '-')}-${item.type.replace(/[_]/g, '-')}`;\n      Object.keys(item.property).forEach(key => doc.style.setProperty(`${name}-${key.replace(/[_]/g, '-')}`, (item.property as any)[key]));\n    });\n  }\n\n  public colorStepContrastFromOrigin(step: number, color?: string) {\n    return colorStepContrastFromOrigin(color || this.themeColor(), step || 0);\n  }\n\n  private setClassGlobal() {\n    this.styleClassGlobalEl.innerHTML = `\n    .libs-ui-border-primary-general{border: 1px solid var(--libs-ui-color-default, #226FF5);}\n    .libs-ui-border-primary-focus-general{border: 1px solid var(--libs-ui-color-light-1, #4e8cf7);}\n    .libs-ui-border-primary-hover-general{border: 1px solid var(--libs-ui-color-light-3, #f4f8ff);}\n    .libs-ui-border-general{ border: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-top-general{border-top: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-right-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-bottom-general{border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-dashed-general{border: dashed 1px var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-top-dashed-general{border-top: dashed 1px var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-left-dashed-general{border-left: dashed 1px var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-right-dashed-general{border-right: dashed 1px var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-bottom-dashed-general{border-bottom: dashed 1px var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-left-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-x-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea);  border-right: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-y-general{border-top: 1px solid var(--libs-ui-color-border, #e6e7ea);  border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-left-top-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea);  border-top: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-left-bottom-general{border-left: 1px solid var(--libs-ui-color-border, #e6e7ea);  border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-right-top-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea);  border-top: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-right-bottom-general{border-right: 1px solid var(--libs-ui-color-border, #e6e7ea);  border-bottom: 1px solid var(--libs-ui-color-border, #e6e7ea);}\n    .libs-ui-border-error-general{border: 1px solid var(--libs-ui-color-border-error, #ee2d41) !important;}\n    .libs-ui-bg-list {background-color: var(--libs-ui-background-list, #f8f9fa);}\n    .libs-ui-bg-list-hover:hover {background-color: var(--libs-ui-background-list-hover, #f8f9fa);}\n    .libs-ui-bg-list-active {background-color:  var(--libs-ui-color-light-3, #f4f8ff);}\n    .libs-ui-bg-list-hover-active:hover {background-color: #f8f9fa;}\n    .libs-ui-bg-list-hover-active:active {background-color: var(--libs-ui-color-light-3, #f4f8ff);}\n    .libs-ui-bg-list-hover-danger:hover {background-color: var(--libs-ui-background-list-hover-danger, #fef5f6); color: var(--libs-ui-color-icon-hover-danger, #f15767) !important; [class*=\"libs-ui-icon-\"],[class*=\"icon-font-3rd\"]{&:before,&:after{color: var(--libs-ui-color-icon-hover-danger, #f15767) !important;}}}\n    .libs-ui-text-error {color: var(--libs-ui-color-text-error, #ff5454) !important;}\n    .libs-ui-text-error::before {color: var(--libs-ui-color-text-error, #ff5454) !important;}\n    .libs-ui-disable {cursor: not-allowed !important;text-decoration: none;color:var(--libs-ui-color-text-disable, #cdd0d6) !important;}\n    .libs-ui-disable::before {color:var(--libs-ui-color-text-disable, #9ca2ad) !important;}\n    .libs-ui-disable-background{background: var(--libs-ui-color-background-disable, #f8f9fa) !important;}\n    .libs-ui-disable-active {color:var(--libs-ui-color-light-4,#91b7fa) !important;}\n    .libs-ui-disable-active::before {color:var(--libs-ui-color-light-4,#91b7fa) !important;}\n    .libs-ui-disable-active-background{background: var(--libs-ui-color-light-4,#91b7fa) !important;}\n    .libs-ui-readonly {cursor: not-allowed !important;color:var(--libs-ui-color-text-readonly, #071631) !important;}\n    .libs-ui-readonly::before {color:var(--libs-ui-color-text-readonly, #071631) !important;}\n    .libs-ui-readonly-background{background: var(--libs-ui-color-background-readonly, #f8f9fa) !important;}\n    .libs-ui-icon-hover-danger:hover {color: var(--libs-ui-color-icon-hover-danger, #f15767) !important; [class*=\"libs-ui-icon-\"],[class*=\"icon-font-3rd\"]{&:before,&:after{color: var(--libs-ui-color-icon-hover-danger, #f15767) !important;}}}\n    .break-word{word-break: break-word !important;}\n    .libs-ui-shadow {box-shadow: 0 2px 10px 1px rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-md {box-shadow: 0 4px 8px 0 rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-lg {box-shadow: 0 15px 30px 0 rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-top {box-shadow: 0 -5px 5px -5px rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-right {box-shadow: -5px 0 5px -5px rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-bottom {box-shadow: 0 5px 5px -5px rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-left {box-shadow: 5px 0 5px -5px rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-sm {box-shadow: 0 1px 2px 0 rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-popup {box-shadow: -2px 0 4px 0 rgba(51, 51, 51, 0.1);}\n    .libs-ui-shadow-none {box-shadow: none !important;}\n    .libs-ui-shadow-small {box-shadow: 0px 1px 2px 0px rgba(0,20,51,.04), 0px 1px 1px 0px rgba(0,20,51,.02);}\n    .libs-ui-shadow-medium {box-shadow: 0px 4px 8px 0px rgba(0, 20, 51, 0.04), 0px 1px 1px 0px rgba(0, 20, 51, 0.02);}\n    .libs-ui-shadow-large {box-shadow: 0px 4px 16px 0px rgba(0,20,51,.1), 0px 1px 1px 0px rgba(0,20,51,.02);}\n    .libs-ui-shadow-extra-large {box-shadow: 0px 8px 56px 0px rgba(0,20,51,.05), 0px 1px 1px 0px rgba(0,20,51,.02);}\n    ::-moz-selection {background: var(--libs-ui-color-background-selection, #00000040) !important;}\n    ::selection {background: var(--libs-ui-color-background-selection, #00000040) !important;}\n    `.replace(/\\n+/g, '');\n\n    document.head.append(this.styleClassGlobalEl);\n  }\n\n  private configString() {\n    const prototype = String.prototype as any;\n    prototype.replaceAt = function (index: number, replacement: string) {\n      const values = this.split('');\n\n      values[index] = replacement;\n\n      return values.join('');\n    }\n\n    prototype.replaceAll = function (index: number, separator: string, replacement: string) {\n      const regex = new RegExp(separator, 'g');\n\n      return `${this.substr(0, index)}${this.substr(index + 1 + (replacement?.length || 0)).replace(regex, replacement)}`;\n    }\n\n    prototype.occurrencesByCharacter = function (character: string): number {\n      const values = this.split('');\n\n      if (!values || !values.length) {\n        return 0;\n      }\n\n      return values.filter((char: string) => char === character).length;\n    }\n\n    prototype.indexesOfCharacter = function (character: string): Array<number> {\n      const values: Array<string> = this.split('');\n      const indexes: Array<number> = [];\n\n      if (!values || !values.length) {\n        return indexes;\n      }\n      for (const indexValue in values) {\n        if (values[indexValue] === character) {\n          indexes.push(+indexValue);\n        }\n      }\n\n      return indexes;\n    }\n\n\n    prototype.indexesByString = function (str: string): Array<number> {\n      const values: Array<string> = this as any;\n      const indexes: Array<number> = [];\n\n      if (!values || !values.length || !str || !str.length || values.length < str.length) {\n\n        return indexes;\n      }\n      for (const indexValue in values) {\n        if (values[indexValue] !== str[0] || ((+indexValue) + str.length) > values.length) {\n          continue;\n        }\n\n        for (const index in str.split('')) {\n\n          if (values[(+indexValue) + (+index)] !== str[index]) {\n            break;\n          }\n        }\n        indexes.push(+indexValue);\n      }\n\n      return indexes;\n    }\n  }\n\n}\n"]}
package/esm2022/index.mjs CHANGED
@@ -1,3 +1,4 @@
1
1
  export * from './config-project.service';
2
2
  export * from './config-project.interface';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL3NlcnZpY2VzL2NvbmZpZy1wcm9qZWN0L3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbmZpZy1wcm9qZWN0LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jb25maWctcHJvamVjdC5pbnRlcmZhY2UnO1xuIl19
3
+ export * from './config-project-data';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL3NlcnZpY2VzL2NvbmZpZy1wcm9qZWN0L3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29uZmlnLXByb2plY3Quc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbmZpZy1wcm9qZWN0LmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbmZpZy1wcm9qZWN0LWRhdGEnOyJdfQ==