coer-elements 0.0.128 → 0.0.130

Sign up to get free protection for your applications and to get access to all the features.
Files changed (38) hide show
  1. package/components/lib/coer-accordion/coer-accordion.component.d.ts +1 -1
  2. package/components/lib/coer-datebox/coer-datebox.component.d.ts +1 -1
  3. package/components/lib/coer-filebox/coer-filebox.component.d.ts +3 -3
  4. package/components/lib/coer-modal/coer-modal.component.d.ts +3 -3
  5. package/components/lib/coer-numberbox/coer-numberbox.component.d.ts +1 -1
  6. package/components/lib/coer-textarea/coer-textarea.component.d.ts +1 -1
  7. package/components/lib/coer-textbox/coer-textbox.component.d.ts +1 -1
  8. package/extensions/index.d.ts +5 -0
  9. package/extensions/lib/object.extension.d.ts +1 -0
  10. package/extensions/lib/string.extension.d.ts +17 -0
  11. package/extensions/public-api.d.ts +2 -0
  12. package/fesm2022/coer-elements-components.mjs +1 -1
  13. package/fesm2022/coer-elements-components.mjs.map +1 -1
  14. package/fesm2022/coer-elements-extensions.mjs +53 -0
  15. package/fesm2022/coer-elements-extensions.mjs.map +1 -0
  16. package/fesm2022/coer-elements-guards.mjs +29 -0
  17. package/fesm2022/coer-elements-guards.mjs.map +1 -0
  18. package/fesm2022/coer-elements-interceptors.mjs +64 -0
  19. package/fesm2022/coer-elements-interceptors.mjs.map +1 -0
  20. package/fesm2022/coer-elements-tools.mjs +10 -30
  21. package/fesm2022/coer-elements-tools.mjs.map +1 -1
  22. package/fesm2022/coer-elements.mjs +1 -0
  23. package/fesm2022/coer-elements.mjs.map +1 -1
  24. package/guards/index.d.ts +5 -0
  25. package/guards/lib/login.guard.d.ts +2 -0
  26. package/guards/lib/page.guard.d.ts +2 -0
  27. package/guards/public-api.d.ts +2 -0
  28. package/index.d.ts +1 -0
  29. package/interceptors/index.d.ts +5 -0
  30. package/interceptors/lib/user.interceptor.d.ts +8 -0
  31. package/interceptors/lib/utc-offset.interceptor.d.ts +8 -0
  32. package/interceptors/public-api.d.ts +1 -0
  33. package/package.json +14 -2
  34. package/pages/lib/coer-system/coer-system.component.d.ts +2 -2
  35. package/pages/lib/coer-system/login/login.component.d.ts +1 -1
  36. package/tools/lib/page.class.d.ts +4 -4
  37. package/tools/lib/section.class.d.ts +4 -4
  38. package/tools/lib/tools.d.ts +6 -6
@@ -0,0 +1,53 @@
1
+ import { Tools } from 'coer-elements/tools';
2
+
3
+ //import { Tools } from "coer-elements/tools";
4
+ //
5
+ //declare global {
6
+ // interface Object {
7
+ //
8
+ // /** Avoid Null value */
9
+ // AvoidNull<T>(type: 'string' | 'number' | 'boolean' | null): T;
10
+ //
11
+ // /** Get properties of an object */
12
+ // GetPropertyList(): string[];
13
+ //
14
+ // /** Break reference of a object or array */
15
+ // BreakReference<T>(object: T): T;
16
+ // }
17
+ //}
18
+ //
19
+ //Object.prototype.AvoidNull = function<T>(type: 'string' | 'number' | 'boolean' | null = null): T {
20
+ // return Tools.AvoidNull<T>(this as T, type);
21
+ //}
22
+ //
23
+ //Object.prototype.GetPropertyList = function(): string[] {
24
+ // return Tools.GetPropertyList(this);
25
+ //}
26
+ //
27
+ //Object.prototype.BreakReference = function<T>(): T {
28
+ // return Tools.BreakReference<T>(this as T);
29
+ //}
30
+
31
+ String.prototype.removeAccents = function () {
32
+ return Tools.RemoveAccents(this.toString());
33
+ };
34
+ String.prototype.cleanUpBlanks = function () {
35
+ return Tools.CleanUpBlanks(this.toString());
36
+ };
37
+ String.prototype.firstCharToLower = function () {
38
+ return Tools.FirstCharToLower(this.toString());
39
+ };
40
+ String.prototype.firstCharToUpper = function () {
41
+ return Tools.FirstCharToUpper(this.toString());
42
+ };
43
+ String.prototype.isOnlyWhiteSpace = function () {
44
+ return Tools.IsOnlyWhiteSpace(this);
45
+ };
46
+ String.prototype.isNotOnlyWhiteSpace = function () {
47
+ return Tools.IsNotOnlyWhiteSpace(this);
48
+ };
49
+
50
+ /**
51
+ * Generated bundle index. Do not edit.
52
+ */
53
+ //# sourceMappingURL=coer-elements-extensions.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coer-elements-extensions.mjs","sources":["../../../projects/coer-elements/extensions/lib/object.extension.ts","../../../projects/coer-elements/extensions/lib/string.extension.ts","../../../projects/coer-elements/extensions/coer-elements-extensions.ts"],"sourcesContent":["//import { Tools } from \"coer-elements/tools\";\r\n//\r\n//declare global {\r\n// interface Object {\r\n// \r\n// /** Avoid Null value */\r\n// AvoidNull<T>(type: 'string' | 'number' | 'boolean' | null): T; \r\n//\r\n// /** Get properties of an object */\r\n// GetPropertyList(): string[];\r\n//\r\n// /** Break reference of a object or array */\r\n// BreakReference<T>(object: T): T;\r\n// }\r\n//}\r\n//\r\n//Object.prototype.AvoidNull = function<T>(type: 'string' | 'number' | 'boolean' | null = null): T {\r\n// return Tools.AvoidNull<T>(this as T, type);\r\n//}\r\n//\r\n//Object.prototype.GetPropertyList = function(): string[] {\r\n// return Tools.GetPropertyList(this);\r\n//}\r\n//\r\n//Object.prototype.BreakReference = function<T>(): T {\r\n// return Tools.BreakReference<T>(this as T);\r\n//}\r\n\r\nexport {};","import { Tools } from \"coer-elements/tools\";\r\n\r\ndeclare global {\r\n interface String {\r\n\r\n /** */\r\n removeAccents(): string;\r\n\r\n /** Clean extra whitespaces */\r\n cleanUpBlanks(): string;\r\n\r\n /** Set First Char To Lower */\r\n firstCharToLower(): string;\r\n\r\n /** Set First Char To Upper */\r\n firstCharToUpper(): string;\r\n\r\n /** Returns true if the value is null or undefined or contains only whitespace, false otherwise */\r\n isOnlyWhiteSpace(): boolean;\r\n\r\n /** Returns true if has string value and is not only whitespace, false otherwise */\r\n isNotOnlyWhiteSpace(): boolean;\r\n }\r\n}\r\n\r\n\r\nString.prototype.removeAccents = function(): string {\r\n return Tools.RemoveAccents(this.toString());\r\n};\r\n\r\n \r\nString.prototype.cleanUpBlanks = function(): string {\r\n return Tools.CleanUpBlanks(this.toString());\r\n}; \r\n\r\n\r\nString.prototype.firstCharToLower = function(): string {\r\n return Tools.FirstCharToLower(this.toString());\r\n}; \r\n\r\n\r\nString.prototype.firstCharToUpper = function(): string {\r\n return Tools.FirstCharToUpper(this.toString());\r\n}; \r\n\r\n\r\nString.prototype.isOnlyWhiteSpace = function(): boolean {\r\n return Tools.IsOnlyWhiteSpace(this);\r\n}\r\n\r\nString.prototype.isNotOnlyWhiteSpace = function(): boolean {\r\n return Tools.IsNotOnlyWhiteSpace(this);\r\n}\r\n\r\n\r\nexport {};","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":";;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACAA,MAAM,CAAC,SAAS,CAAC,aAAa,GAAG,YAAA;IAC7B,OAAO,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;AAC/C,CAAC;AAGD,MAAM,CAAC,SAAS,CAAC,aAAa,GAAG,YAAA;IAC7B,OAAO,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;AAC/C,CAAC;AAGD,MAAM,CAAC,SAAS,CAAC,gBAAgB,GAAG,YAAA;IAChC,OAAO,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;AAClD,CAAC;AAGD,MAAM,CAAC,SAAS,CAAC,gBAAgB,GAAG,YAAA;IAChC,OAAO,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;AAClD,CAAC;AAGD,MAAM,CAAC,SAAS,CAAC,gBAAgB,GAAG,YAAA;AAChC,IAAA,OAAO,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC;AACvC,CAAC;AAED,MAAM,CAAC,SAAS,CAAC,mBAAmB,GAAG,YAAA;AACnC,IAAA,OAAO,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC;AAC1C,CAAC;;ACpDD;;AAEG"}
@@ -0,0 +1,29 @@
1
+ import { User, Tools, CoerAlert, Menu } from 'coer-elements/tools';
2
+ import { inject } from '@angular/core';
3
+ import { navigationSIGNAL } from 'coer-elements/signals';
4
+
5
+ const loginGuard = () => {
6
+ return User.LogIn();
7
+ };
8
+
9
+ const pageGuard = (route, state) => {
10
+ const module = Tools.AvoidNull(route.data.module);
11
+ const submodule = Tools.AvoidNull(route.data.submodule);
12
+ const page = Tools.AvoidNull(route.data.page);
13
+ if (Tools.IsOnlyWhiteSpace(page)) {
14
+ console.log(`[Page] Metadata for route ${state.url} is missing`);
15
+ inject(CoerAlert).Warning('Metadata is missing', 'Guard', 'fa-solid fa-file-shield');
16
+ return false;
17
+ }
18
+ //Has access?
19
+ return Menu.GetMenuAccess(navigationSIGNAL()).some(access => Tools.RemoveAccents(Tools.AvoidNull(access?.module, 'string').toUpperCase()) === Tools.RemoveAccents(module.toUpperCase())
20
+ && Tools.RemoveAccents(Tools.AvoidNull(access?.submodule, 'string').toUpperCase()) === Tools.RemoveAccents(submodule.toUpperCase())
21
+ && Tools.RemoveAccents(Tools.AvoidNull(access?.page, 'string').toUpperCase()) === Tools.RemoveAccents(page.toUpperCase()));
22
+ };
23
+
24
+ /**
25
+ * Generated bundle index. Do not edit.
26
+ */
27
+
28
+ export { loginGuard, pageGuard };
29
+ //# sourceMappingURL=coer-elements-guards.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coer-elements-guards.mjs","sources":["../../../projects/coer-elements/guards/lib/login.guard.ts","../../../projects/coer-elements/guards/lib/page.guard.ts","../../../projects/coer-elements/guards/coer-elements-guards.ts"],"sourcesContent":["import { CanActivateFn } from '@angular/router';\r\nimport { User } from 'coer-elements/tools';\r\n\r\nexport const loginGuard: CanActivateFn = () => { \r\n return User.LogIn();\r\n};","import { inject } from '@angular/core';\r\nimport { CanActivateFn } from '@angular/router';\r\nimport { navigationSIGNAL } from 'coer-elements/signals';\r\nimport { CoerAlert, Menu, Tools } from 'coer-elements/tools'; \r\n\r\nexport const pageGuard: CanActivateFn = (route: any, state: any) => { \r\n \r\n const module = Tools.AvoidNull<string>(route.data.module);\r\n const submodule = Tools.AvoidNull<string>(route.data.submodule);\r\n const page = Tools.AvoidNull<string>(route.data.page); \r\n \r\n if (Tools.IsOnlyWhiteSpace(page)) { \r\n console.log(`[Page] Metadata for route ${state.url} is missing`);\r\n inject(CoerAlert).Warning('Metadata is missing', 'Guard', 'fa-solid fa-file-shield');\r\n return false;\r\n }\r\n\r\n //Has access? \r\n return Menu.GetMenuAccess(navigationSIGNAL()).some(access => \r\n Tools.RemoveAccents(Tools.AvoidNull<string>(access?.module, 'string').toUpperCase()) === Tools.RemoveAccents(module.toUpperCase())\r\n && Tools.RemoveAccents(Tools.AvoidNull<string>(access?.submodule, 'string').toUpperCase()) === Tools.RemoveAccents(submodule.toUpperCase())\r\n && Tools.RemoveAccents(Tools.AvoidNull<string>(access?.page, 'string').toUpperCase()) === Tools.RemoveAccents(page.toUpperCase())\r\n );\r\n}; ","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":";;;;AAGO,MAAM,UAAU,GAAkB,MAAK;AAC5C,IAAA,OAAO,IAAI,CAAC,KAAK,EAAE;AACrB;;MCAa,SAAS,GAAkB,CAAC,KAAU,EAAE,KAAU,KAAI;AAEjE,IAAA,MAAM,MAAM,GAAM,KAAK,CAAC,SAAS,CAAS,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC;AAC5D,IAAA,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,CAAS,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC;AAC/D,IAAA,MAAM,IAAI,GAAQ,KAAK,CAAC,SAAS,CAAS,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC;AAE1D,IAAA,IAAI,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE;QAChC,OAAO,CAAC,GAAG,CAAC,CAAA,0BAAA,EAA6B,KAAK,CAAC,GAAG,CAAa,WAAA,CAAA,CAAC;AAChE,QAAA,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,qBAAqB,EAAE,OAAO,EAAE,yBAAyB,CAAC;AACpF,QAAA,OAAO,KAAK;;;AAId,IAAA,OAAO,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,IACvD,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,CAAS,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,WAAW,EAAE;WAC9H,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,CAAS,MAAM,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,WAAW,EAAE;AACvI,WAAA,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,CAAS,MAAM,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAClI;AACH;;ACvBA;;AAEG;;;;"}
@@ -0,0 +1,64 @@
1
+ import { provideHttpClient, withInterceptorsFromDi, HTTP_INTERCEPTORS } from '@angular/common/http';
2
+ import * as i0 from '@angular/core';
3
+ import { Injectable } from '@angular/core';
4
+ import { DateTime, User, Tools } from 'coer-elements/tools';
5
+ import { throwError } from 'rxjs';
6
+ import { catchError } from 'rxjs/operators';
7
+
8
+ class UTC_OFFSET_INTERCEPTOR {
9
+ intercept(request, next) {
10
+ const headers = request.headers.set('utc-offset', `${DateTime.GetOffset() / 60}`);
11
+ return next.handle(request.clone({ headers })).pipe(catchError((httpError) => {
12
+ console.error(httpError);
13
+ return throwError(() => httpError);
14
+ }));
15
+ }
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: UTC_OFFSET_INTERCEPTOR, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
17
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: UTC_OFFSET_INTERCEPTOR, providedIn: 'root' }); }
18
+ }
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: UTC_OFFSET_INTERCEPTOR, decorators: [{
20
+ type: Injectable,
21
+ args: [{
22
+ providedIn: 'root'
23
+ }]
24
+ }] });
25
+
26
+ class USER_INTERCEPTOR {
27
+ intercept(request, next) {
28
+ const user = User.Get();
29
+ let headers = request.headers;
30
+ if (Tools.IsNotNull(user)) {
31
+ if (Tools.IsNotNull(user?.user)) {
32
+ headers = headers.set('clien-user', user.user);
33
+ }
34
+ if (Tools.IsNotNull(user?.jwt)) {
35
+ headers = headers.set('Authorization', `Bearer ${user.jwt}`);
36
+ }
37
+ }
38
+ return next.handle(request.clone({ headers })).pipe(catchError((httpError) => {
39
+ console.error(httpError);
40
+ return throwError(() => httpError);
41
+ }));
42
+ }
43
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: USER_INTERCEPTOR, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
44
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: USER_INTERCEPTOR, providedIn: 'root' }); }
45
+ }
46
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: USER_INTERCEPTOR, decorators: [{
47
+ type: Injectable,
48
+ args: [{
49
+ providedIn: 'root'
50
+ }]
51
+ }] });
52
+
53
+ const INTERCEPTORS = [
54
+ provideHttpClient(withInterceptorsFromDi()),
55
+ { provide: HTTP_INTERCEPTORS, useClass: UTC_OFFSET_INTERCEPTOR, multi: true },
56
+ { provide: HTTP_INTERCEPTORS, useClass: USER_INTERCEPTOR, multi: true }
57
+ ];
58
+
59
+ /**
60
+ * Generated bundle index. Do not edit.
61
+ */
62
+
63
+ export { INTERCEPTORS };
64
+ //# sourceMappingURL=coer-elements-interceptors.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coer-elements-interceptors.mjs","sources":["../../../projects/coer-elements/interceptors/lib/utc-offset.interceptor.ts","../../../projects/coer-elements/interceptors/lib/user.interceptor.ts","../../../projects/coer-elements/interceptors/public-api.ts","../../../projects/coer-elements/interceptors/coer-elements-interceptors.ts"],"sourcesContent":["import { HttpErrorResponse, HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { DateTime } from 'coer-elements/tools';\r\nimport { Observable, throwError } from 'rxjs';\r\nimport { catchError } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class UTC_OFFSET_INTERCEPTOR implements HttpInterceptor {\r\n\r\n intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n\r\n const headers = request.headers.set('utc-offset', `${DateTime.GetOffset() / 60}`); \r\n\r\n return next.handle(request.clone({ headers })).pipe(\r\n catchError((httpError: HttpErrorResponse) => {\r\n console.error(httpError);\r\n return throwError(() => httpError);\r\n })\r\n );\r\n }\r\n}","import { HttpErrorResponse, HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { Tools, User } from 'coer-elements/tools';\r\nimport { Observable, throwError } from 'rxjs';\r\nimport { catchError } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class USER_INTERCEPTOR implements HttpInterceptor {\r\n\r\n intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n\r\n const user = User.Get<any>();\r\n let headers = request.headers;\r\n\r\n if (Tools.IsNotNull(user)) {\r\n if (Tools.IsNotNull(user?.user)) {\r\n headers = headers.set('clien-user', user.user); \r\n\r\n }\r\n\r\n if (Tools.IsNotNull(user?.jwt)) {\r\n headers = headers.set('Authorization', `Bearer ${user.jwt}`);\r\n }\r\n }\r\n\r\n return next.handle(request.clone({ headers })).pipe(\r\n catchError((httpError: HttpErrorResponse) => {\r\n console.error(httpError);\r\n return throwError(() => httpError);\r\n })\r\n );\r\n }\r\n}","import { HTTP_INTERCEPTORS, provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';\r\nimport { UTC_OFFSET_INTERCEPTOR } from './lib/utc-offset.interceptor';\r\nimport { USER_INTERCEPTOR } from './lib/user.interceptor';\r\n\r\nexport const INTERCEPTORS: any[] = [\r\n provideHttpClient(withInterceptorsFromDi()),\r\n { provide: HTTP_INTERCEPTORS, useClass: UTC_OFFSET_INTERCEPTOR, multi: true },\r\n { provide: HTTP_INTERCEPTORS, useClass: USER_INTERCEPTOR, multi: true }\r\n];","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
@@ -23,39 +23,19 @@ const Tools = {
23
23
  },
24
24
  /** Returns true if the value is null or undefined, false otherwise */
25
25
  IsNull: (value) => {
26
- if (value === undefined)
27
- return true;
28
- if (value === null)
29
- return true;
30
- return false;
26
+ return (value === undefined || value === null);
31
27
  },
32
28
  /** Returns true if the value is not null or undefined, false otherwise */
33
29
  IsNotNull: (value) => {
34
- if (value === undefined)
35
- return false;
36
- if (value === null)
37
- return false;
38
- return true;
30
+ return !Tools.IsNull(value);
39
31
  },
40
32
  /** Returns true if the value is null or undefined or contains only whitespace, false otherwise */
41
33
  IsOnlyWhiteSpace: (value) => {
42
- if (value === undefined)
43
- return true;
44
- if (value === null)
45
- return true;
46
- if (typeof value === 'string' && value.trim() === '')
47
- return true;
48
- return false;
34
+ return Tools.IsNull(value) || (typeof value === 'string' && value.trim() === '');
49
35
  },
50
36
  /** Returns true if has string value and is not only whitespace, false otherwise */
51
37
  IsNotOnlyWhiteSpace: (value) => {
52
- if (value === undefined)
53
- return false;
54
- if (value === null)
55
- return false;
56
- if (typeof value === 'string' && value.trim() === '')
57
- return false;
58
- return true;
38
+ return Tools.IsNotNull(value) && !Tools.IsOnlyWhiteSpace(value);
59
39
  },
60
40
  /** Avoid Null value */
61
41
  AvoidNull: (value, type = null) => {
@@ -99,7 +79,7 @@ const Tools = {
99
79
  default: return '';
100
80
  }
101
81
  },
102
- /** Avoid Null value */
82
+ /** */
103
83
  RemoveAccents: (value) => {
104
84
  if (Tools.IsOnlyWhiteSpace(value))
105
85
  return '';
@@ -124,12 +104,12 @@ const Tools = {
124
104
  CleanUpBlanks: (text) => {
125
105
  if (Tools.IsOnlyWhiteSpace(text))
126
106
  return '';
127
- let worlds = String(text).split(' ');
128
- worlds = worlds.filter(x => x.length > 0);
129
- return worlds.join(' ');
107
+ let words = String(text).split(' ');
108
+ words = words.filter(x => x.length > 0);
109
+ return words.join(' ');
130
110
  },
131
111
  /** Get properties of an object */
132
- GetObjectProperties: (obj) => {
112
+ GetPropertyList: (obj) => {
133
113
  const properties = [];
134
114
  if (obj === null)
135
115
  return properties;
@@ -822,7 +802,7 @@ const ElementsHTML = {
822
802
  let isInvalid = true;
823
803
  if (Tools.IsNotNull(element)) {
824
804
  if (typeof element == 'object') {
825
- const properties = Tools.GetObjectProperties(element);
805
+ const properties = Tools.GetPropertyList(element);
826
806
  if (properties.includes('_isTouched') && properties.includes('_value')) {
827
807
  isInvalid = element.isTouched && Tools.IsOnlyWhiteSpace(element.value);
828
808
  }