jconsumer-shared 0.0.2 → 0.0.3

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 (67) hide show
  1. package/esm2022/lib/account-service.mjs +21 -0
  2. package/esm2022/lib/auth-service.mjs +155 -0
  3. package/esm2022/lib/calendar/date-time/datetime-processor.service.mjs +448 -0
  4. package/esm2022/lib/common.service.mjs +38 -0
  5. package/esm2022/lib/error-message.service.mjs +22 -0
  6. package/esm2022/lib/file-service.mjs +229 -0
  7. package/esm2022/lib/group-storage.service.mjs +66 -0
  8. package/esm2022/lib/i8n.module.mjs +43 -0
  9. package/esm2022/lib/local-storage.service.mjs +77 -0
  10. package/esm2022/lib/phone-input/phone-input.component.mjs +127 -0
  11. package/esm2022/lib/phone-input/phone-input.module.mjs +24 -0
  12. package/esm2022/lib/pipes/autolink/autolink.pipe.mjs +22 -0
  13. package/esm2022/lib/pipes/capitalize/capitalize.module.mjs +20 -0
  14. package/esm2022/lib/pipes/capitalize/capitalize.pipe.mjs +18 -0
  15. package/esm2022/lib/pipes/filter/filter.pipe.mjs +24 -0
  16. package/esm2022/lib/pipes/limit-to/limitTo.pipe.mjs +18 -0
  17. package/esm2022/lib/pipes/safe-html/safehtml.module.mjs +20 -0
  18. package/esm2022/lib/pipes/safe-html/safehtml.pipe.mjs +19 -0
  19. package/esm2022/lib/project-messages.mjs +146 -0
  20. package/esm2022/lib/questionaire/edit/questionnaire.component.mjs +1422 -0
  21. package/esm2022/lib/questionaire/edit/questionnaire.module.mjs +77 -0
  22. package/esm2022/lib/questionaire/questionaire-service.mjs +92 -0
  23. package/esm2022/lib/session-storage.service.mjs +57 -0
  24. package/esm2022/lib/shared.service.mjs +24 -2
  25. package/esm2022/lib/showuploadfile/showuploadfile.component.mjs +61 -0
  26. package/esm2022/lib/showuploadfile/showuploadfile.module.mjs +28 -0
  27. package/esm2022/lib/spinner/loading-spinner.component.mjs +22 -0
  28. package/esm2022/lib/spinner/loading-spinner.module.mjs +28 -0
  29. package/esm2022/lib/storage.service.mjs +75 -0
  30. package/esm2022/lib/word-processor.service.mjs +181 -0
  31. package/esm2022/public-api.mjs +27 -1
  32. package/fesm2022/jconsumer-shared.mjs +3522 -26
  33. package/fesm2022/jconsumer-shared.mjs.map +1 -1
  34. package/jconsumer-shared-0.0.3.tgz +0 -0
  35. package/lib/account-service.d.ts +9 -0
  36. package/lib/auth-service.d.ts +43 -0
  37. package/lib/calendar/date-time/datetime-processor.service.d.ts +120 -0
  38. package/lib/common.service.d.ts +9 -0
  39. package/lib/error-message.service.d.ts +5 -0
  40. package/lib/file-service.d.ts +26 -0
  41. package/lib/group-storage.service.d.ts +14 -0
  42. package/lib/i8n.module.d.ts +12 -0
  43. package/lib/local-storage.service.d.ts +34 -0
  44. package/lib/phone-input/phone-input.component.d.ts +25 -0
  45. package/lib/phone-input/phone-input.module.d.ts +9 -0
  46. package/lib/pipes/autolink/autolink.pipe.d.ts +7 -0
  47. package/lib/pipes/capitalize/capitalize.module.d.ts +8 -0
  48. package/lib/pipes/capitalize/capitalize.pipe.d.ts +7 -0
  49. package/lib/pipes/filter/filter.pipe.d.ts +7 -0
  50. package/lib/pipes/limit-to/limitTo.pipe.d.ts +7 -0
  51. package/lib/pipes/safe-html/safehtml.module.d.ts +8 -0
  52. package/lib/pipes/safe-html/safehtml.pipe.d.ts +10 -0
  53. package/lib/project-messages.d.ts +1 -0
  54. package/lib/questionaire/edit/questionnaire.component.d.ts +151 -0
  55. package/lib/questionaire/edit/questionnaire.module.d.ts +19 -0
  56. package/lib/questionaire/questionaire-service.d.ts +28 -0
  57. package/lib/session-storage.service.d.ts +26 -0
  58. package/lib/shared.service.d.ts +12 -3
  59. package/lib/showuploadfile/showuploadfile.component.d.ts +21 -0
  60. package/lib/showuploadfile/showuploadfile.module.d.ts +9 -0
  61. package/lib/spinner/loading-spinner.component.d.ts +11 -0
  62. package/lib/spinner/loading-spinner.module.d.ts +9 -0
  63. package/lib/storage.service.d.ts +16 -0
  64. package/lib/word-processor.service.d.ts +80 -0
  65. package/package.json +1 -1
  66. package/public-api.d.ts +26 -0
  67. package/jconsumer-shared-0.0.2.tgz +0 -0
@@ -0,0 +1,229 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ *
5
+ */
6
+ export class FileService {
7
+ // Supported images types
8
+ IMAGE_FORMATS = [
9
+ 'image/gif',
10
+ 'image/png',
11
+ 'image/jpeg',
12
+ 'image/bmp',
13
+ 'image/webp'
14
+ ];
15
+ FILETYPES_UPLOAD = [
16
+ 'image/jpg',
17
+ 'image/png',
18
+ 'image/jpeg',
19
+ 'image/bmp',
20
+ 'application/pdf',
21
+ 'application/jfif',
22
+ 'video/mp4',
23
+ 'video/mpeg',
24
+ 'audio/mpeg',
25
+ 'audio/mp3',
26
+ 'audio/ogg',
27
+ 'application/vnd.ms-excel',
28
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
29
+ 'application/doc',
30
+ 'application/ms-doc',
31
+ 'application/msword',
32
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
33
+ 'docx',
34
+ 'doc'
35
+ ];
36
+ imageSize = 15000000;
37
+ FILE_MAX_SIZE = 10000000;
38
+ constructor() { }
39
+ /**
40
+ * Method returns supported formats of files which has to be uploaded
41
+ * @param source image/file
42
+ * @returns available formats
43
+ */
44
+ getSupportedFormats(source) {
45
+ console.log(source);
46
+ let formats = [];
47
+ if (source == 'image') {
48
+ formats = this.IMAGE_FORMATS;
49
+ //return this.IMAGE_FORMATS;
50
+ }
51
+ else {
52
+ formats = this.FILETYPES_UPLOAD;
53
+ //return this.FILETYPES_UPLOAD;
54
+ }
55
+ console.log(formats);
56
+ return formats;
57
+ }
58
+ /**
59
+ * Method will return the maximum uploadable size of a file/image
60
+ * @returns Maximum size of the image to upload
61
+ */
62
+ getMaximumImageSize() {
63
+ return this.imageSize;
64
+ }
65
+ imageValidation(file, source) {
66
+ console.log("In Image Validation:", source);
67
+ let file_types = [];
68
+ if (source === 'attachment' || source === 'consumerimages') {
69
+ file_types = this.getSupportedFormats('file');
70
+ }
71
+ else {
72
+ file_types = this.getSupportedFormats('image');
73
+ }
74
+ const image_max_size = this.getMaximumImageSize();
75
+ const error = [];
76
+ console.log(file_types);
77
+ console.log(file.type);
78
+ let is_error = false;
79
+ if (!file.type || (file.type && file_types.indexOf(file.type) === -1)) {
80
+ error['type'] = true;
81
+ is_error = true;
82
+ }
83
+ if (file.size && file.size > image_max_size) {
84
+ error['size'] = true;
85
+ is_error = true;
86
+ }
87
+ if (is_error === false) {
88
+ return true;
89
+ }
90
+ else {
91
+ return error;
92
+ }
93
+ }
94
+ getImage(url, fileObj) {
95
+ let file = fileObj;
96
+ if (fileObj && fileObj['mimeType']) {
97
+ file['type'] = fileObj['mimeType'];
98
+ }
99
+ // console.log("File :", file);
100
+ // console.log("File Type :", file.type)
101
+ // console.log("File Name :", file.name.includes('docx'))
102
+ if (file.type) {
103
+ if (file.type == 'application/pdf') {
104
+ return './assets/images/pdf.png';
105
+ }
106
+ else if (file.type == 'application/vnd.ms-excel' || file.type == 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet') {
107
+ return './assets/images/xls.png';
108
+ }
109
+ else if (file.type == 'audio/mp3' || file.type == 'audio/mpeg' || file.type == 'audio/ogg') {
110
+ return './assets/images/audio.png';
111
+ }
112
+ else if (file.type == 'video/mp4' || file.type == 'video/mpeg') {
113
+ return './assets/images/video.png';
114
+ }
115
+ else if (file.type == 'application/msword' || file.type == 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' || file.type.includes('docx') || file.type.includes('doc')) {
116
+ return './assets/images/ImgeFileIcon/wordDocsBgWhite.jpg';
117
+ }
118
+ else if (file.type.includes('txt')) {
119
+ return './assets/images/ImgeFileIcon/docTxt.png';
120
+ }
121
+ else {
122
+ return url;
123
+ }
124
+ }
125
+ return url;
126
+ }
127
+ getImageByType(type) {
128
+ if (type == 'pdf') {
129
+ return './assets/images/pdf.png';
130
+ }
131
+ else if (type == 'vnd.ms-excel' || type == 'vnd.openxmlformats-officedocument.spreadsheetml.sheet' || type == 'xls' || type == 'xlsx') {
132
+ return './assets/images/xls.png';
133
+ }
134
+ else if (type == 'mp3' || type == 'mpeg' || type == 'ogg') {
135
+ return './assets/images/audio.png';
136
+ }
137
+ else if (type == 'mp4' || type == 'mpeg') {
138
+ return './assets/images/video.png';
139
+ }
140
+ else if (type == 'application/msword' || type == 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' || type == 'docx' || type == 'doc' || type == 'msword') {
141
+ return './assets/images/ImgeFileIcon/wordDocsBgWhite.jpg';
142
+ }
143
+ else if (type == 'txt') {
144
+ return './assets/images/ImgeFileIcon/docTxt.png';
145
+ }
146
+ else {
147
+ return './assets/images/img_uplod.png';
148
+ }
149
+ }
150
+ filesSelected(event, selectedMessage) {
151
+ const _this = this;
152
+ return new Promise(function (resolve, reject) {
153
+ // const input = event.target.files;
154
+ let input = event.files;
155
+ if (event.target && event.target.files) {
156
+ input = event.target.files;
157
+ }
158
+ console.log("File Selected :", input);
159
+ if (input) {
160
+ let count = 0;
161
+ let filesCount = input.length;
162
+ for (const file of input) {
163
+ if (_this.FILETYPES_UPLOAD.indexOf(file.type) === -1) {
164
+ reject("Selected file type not supported");
165
+ }
166
+ else if (file.size > _this.FILE_MAX_SIZE) {
167
+ reject("Please upload files with size < 10mb");
168
+ }
169
+ else {
170
+ selectedMessage.files.push(file);
171
+ const reader = new FileReader();
172
+ reader.onload = (e) => {
173
+ selectedMessage.base64.push(e.target["result"]);
174
+ count++;
175
+ if (count === filesCount) {
176
+ resolve(true);
177
+ }
178
+ };
179
+ reader.readAsDataURL(file);
180
+ }
181
+ }
182
+ }
183
+ });
184
+ }
185
+ filessSelected(event, selectedMessage) {
186
+ const _this = this;
187
+ return new Promise(function (resolve, reject) {
188
+ // const input = event.target.files;
189
+ let input = event.files;
190
+ if (event.target && event.target.files) {
191
+ input = event.target.files;
192
+ }
193
+ console.log("File Selected :", input);
194
+ if (input) {
195
+ let count = 0;
196
+ let filesCount = input.length;
197
+ for (const file of input) {
198
+ if (_this.IMAGE_FORMATS.indexOf(file.type) === -1) {
199
+ reject("Selected file type not supported");
200
+ }
201
+ else if (file.size > _this.FILE_MAX_SIZE) {
202
+ reject("Please upload files with size < 10mb");
203
+ }
204
+ else {
205
+ selectedMessage.files.push(file);
206
+ const reader = new FileReader();
207
+ reader.onload = (e) => {
208
+ selectedMessage.base64.push(e.target["result"]);
209
+ count++;
210
+ if (count === filesCount) {
211
+ resolve(true);
212
+ }
213
+ };
214
+ reader.readAsDataURL(file);
215
+ }
216
+ }
217
+ }
218
+ });
219
+ }
220
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: FileService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
221
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: FileService, providedIn: 'root' });
222
+ }
223
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: FileService, decorators: [{
224
+ type: Injectable,
225
+ args: [{
226
+ providedIn: 'root'
227
+ }]
228
+ }], ctorParameters: () => [] });
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-service.js","sourceRoot":"","sources":["../../../../projects/jconsumer-shared/src/lib/file-service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\n\r\n/**\r\n * \r\n */\r\nexport class FileService {\r\n  // Supported images types\r\n  IMAGE_FORMATS = [\r\n    'image/gif',\r\n    'image/png',\r\n    'image/jpeg',\r\n    'image/bmp',\r\n    'image/webp'\r\n  ];\r\n\r\n  FILETYPES_UPLOAD = [\r\n    'image/jpg',\r\n    'image/png',\r\n    'image/jpeg',\r\n    'image/bmp',\r\n    'application/pdf',\r\n    'application/jfif',\r\n    'video/mp4',\r\n    'video/mpeg',\r\n    'audio/mpeg',\r\n    'audio/mp3',\r\n    'audio/ogg',\r\n    'application/vnd.ms-excel',\r\n    'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\r\n    'application/doc',\r\n    'application/ms-doc',\r\n    'application/msword',\r\n    'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\r\n    'docx',\r\n    'doc'\r\n  ];\r\n\r\n  imageSize = 15000000;\r\n  FILE_MAX_SIZE = 10000000;\r\n  constructor() { }\r\n\r\n  /**\r\n   * Method returns supported formats of files which has to be uploaded\r\n   * @param source image/file\r\n   * @returns available formats\r\n   */\r\n  getSupportedFormats(source: any) {\r\n    console.log(source);\r\n    let formats = [];\r\n    if (source == 'image') {\r\n      formats = this.IMAGE_FORMATS;\r\n      //return this.IMAGE_FORMATS;\r\n    } else {\r\n      formats = this.FILETYPES_UPLOAD;\r\n      //return this.FILETYPES_UPLOAD;\r\n    }\r\n    console.log(formats);\r\n    return formats;\r\n  }\r\n\r\n  /**\r\n   * Method will return the maximum uploadable size of a file/image\r\n   * @returns Maximum size of the image to upload\r\n   */\r\n  getMaximumImageSize() {\r\n    return this.imageSize;\r\n  }\r\n\r\n  imageValidation(file: any, source?: any) {\r\n    console.log(\"In Image Validation:\", source);\r\n    let file_types = [];\r\n    if (source === 'attachment' || source === 'consumerimages') {\r\n      file_types = this.getSupportedFormats('file');\r\n    } else {\r\n      file_types = this.getSupportedFormats('image');\r\n    }\r\n    const image_max_size = this.getMaximumImageSize();\r\n    const error: any = [];\r\n    console.log(file_types);\r\n    console.log(file.type);\r\n    let is_error = false;\r\n    if (!file.type || (file.type && file_types.indexOf(file.type) === -1)) {\r\n      error['type'] = true;\r\n      is_error = true;\r\n    }\r\n    if (file.size && file.size > image_max_size) {\r\n      error['size'] = true;\r\n      is_error = true;\r\n    }\r\n    if (is_error === false) {\r\n      return true;\r\n    } else {\r\n      return error;\r\n    }\r\n  }\r\n  getImage(url: any, fileObj: any) {\r\n    let file = fileObj;\r\n    if (fileObj && fileObj['mimeType']) {\r\n      file['type'] = fileObj['mimeType'];\r\n    }\r\n    // console.log(\"File :\", file);\r\n    // console.log(\"File Type :\", file.type)\r\n    // console.log(\"File Name :\", file.name.includes('docx'))\r\n    if (file.type) {\r\n      if (file.type == 'application/pdf') {\r\n        return './assets/images/pdf.png';\r\n      } else if (file.type == 'application/vnd.ms-excel' || file.type == 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet') {\r\n        return './assets/images/xls.png';\r\n      } else if (file.type == 'audio/mp3' || file.type == 'audio/mpeg' || file.type == 'audio/ogg') {\r\n        return './assets/images/audio.png';\r\n      } else if (file.type == 'video/mp4' || file.type == 'video/mpeg') {\r\n        return './assets/images/video.png';\r\n      } else if (file.type == 'application/msword' || file.type == 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' || file.type.includes('docx') || file.type.includes('doc')) {\r\n        return './assets/images/ImgeFileIcon/wordDocsBgWhite.jpg';\r\n      } else if (file.type.includes('txt')) {\r\n        return './assets/images/ImgeFileIcon/docTxt.png';\r\n      } else {\r\n        return url;\r\n      }\r\n    }\r\n    return url;\r\n  }\r\n  getImageByType(type: any) {\r\n    if (type == 'pdf') {\r\n      return './assets/images/pdf.png';\r\n    } else if (type == 'vnd.ms-excel' || type == 'vnd.openxmlformats-officedocument.spreadsheetml.sheet' || type == 'xls' || type == 'xlsx') {\r\n      return './assets/images/xls.png';\r\n    } else if (type == 'mp3' || type == 'mpeg' || type == 'ogg') {\r\n      return './assets/images/audio.png';\r\n    } else if (type == 'mp4' || type == 'mpeg') {\r\n      return './assets/images/video.png';\r\n    } else if (type == 'application/msword' || type == 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' || type == 'docx' || type == 'doc' || type == 'msword') {\r\n      return './assets/images/ImgeFileIcon/wordDocsBgWhite.jpg';\r\n    } else if (type == 'txt') {\r\n      return './assets/images/ImgeFileIcon/docTxt.png';\r\n    } else {\r\n      return './assets/images/img_uplod.png';\r\n    }\r\n  }\r\n\r\n  filesSelected(event: any, selectedMessage: any) {\r\n    const _this = this;\r\n    return new Promise(function (resolve, reject) {\r\n      // const input = event.target.files;\r\n      let input = event.files;\r\n      if (event.target && event.target.files) {\r\n        input = event.target.files;\r\n      }\r\n      console.log(\"File Selected :\", input);\r\n      if (input) {\r\n        let count = 0;\r\n        let filesCount = input.length;\r\n        for (const file of input) {\r\n          if (_this.FILETYPES_UPLOAD.indexOf(file.type) === -1) {\r\n            reject(\"Selected file type not supported\");\r\n          } else if (file.size > _this.FILE_MAX_SIZE) {\r\n            reject(\"Please upload files with size < 10mb\");\r\n          } else {\r\n            selectedMessage.files.push(file);\r\n            const reader = new FileReader();\r\n            reader.onload = (e: any) => {\r\n              selectedMessage.base64.push(e.target[\"result\"]);\r\n              count++;\r\n              if (count === filesCount) {\r\n                resolve(true);\r\n              }\r\n            };\r\n            reader.readAsDataURL(file);\r\n          }\r\n        }\r\n      }\r\n    })\r\n  }\r\n  filessSelected(event: any, selectedMessage: any) {\r\n    const _this = this;\r\n    return new Promise(function (resolve, reject) {\r\n      // const input = event.target.files;\r\n      let input = event.files;\r\n      if (event.target && event.target.files) {\r\n        input = event.target.files;\r\n      }\r\n      console.log(\"File Selected :\", input);\r\n      if (input) {\r\n        let count = 0;\r\n        let filesCount = input.length;\r\n        for (const file of input) {\r\n          if (_this.IMAGE_FORMATS.indexOf(file.type) === -1) {\r\n            reject(\"Selected file type not supported\");\r\n          } else if (file.size > _this.FILE_MAX_SIZE) {\r\n            reject(\"Please upload files with size < 10mb\");\r\n          } else {\r\n            selectedMessage.files.push(file);\r\n            const reader = new FileReader();\r\n            reader.onload = (e: any) => {\r\n              selectedMessage.base64.push(e.target[\"result\"]);\r\n              count++;\r\n              if (count === filesCount) {\r\n                resolve(true);\r\n              }\r\n            };\r\n            reader.readAsDataURL(file);\r\n          }\r\n        }\r\n      }\r\n    })\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,66 @@
1
+ import { Injectable } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "./session-storage.service";
4
+ import * as i2 from "./local-storage.service";
5
+ export class GroupStorageService {
6
+ sessionStorageService;
7
+ lStorageService;
8
+ constructor(sessionStorageService, lStorageService) {
9
+ this.sessionStorageService = sessionStorageService;
10
+ this.lStorageService = lStorageService;
11
+ }
12
+ getGroup() {
13
+ if (this.sessionStorageService.getitemfromSessionStorage('tabId')) {
14
+ return this.sessionStorageService.getitemfromSessionStorage('accountid');
15
+ }
16
+ else {
17
+ return 0;
18
+ }
19
+ }
20
+ setitemToGroupStorage(itemname, itemvalue) {
21
+ const group = this.getGroup();
22
+ let groupObj = {};
23
+ if (this.lStorageService.getitemfromLocalStorage(group)) {
24
+ groupObj = JSON.parse(this.lStorageService.getitemfromLocalStorage(group)) ? JSON.parse(this.lStorageService.getitemfromLocalStorage(group)) : {};
25
+ if (groupObj) {
26
+ groupObj[itemname] = itemvalue;
27
+ }
28
+ }
29
+ else {
30
+ groupObj[itemname] = itemvalue;
31
+ }
32
+ this.lStorageService.setitemonLocalStorage(group, JSON.stringify(groupObj));
33
+ }
34
+ getitemFromGroupStorage(itemname, type) {
35
+ let group;
36
+ if (type) {
37
+ group = 0;
38
+ }
39
+ else {
40
+ group = this.getGroup();
41
+ }
42
+ if (this.lStorageService.getitemfromLocalStorage(group)) {
43
+ const groupObj = JSON.parse(this.lStorageService.getitemfromLocalStorage(group));
44
+ if (groupObj[itemname] || (itemname === 'isCheckin' && groupObj[itemname] !== undefined)) {
45
+ return groupObj[itemname];
46
+ }
47
+ }
48
+ }
49
+ removeitemFromGroupStorage(itemname) {
50
+ const group = this.getGroup();
51
+ const groupObj = JSON.parse(this.lStorageService.getitemfromLocalStorage(group));
52
+ if (groupObj[itemname]) {
53
+ delete groupObj[itemname];
54
+ this.lStorageService.setitemonLocalStorage(group, JSON.stringify(groupObj));
55
+ }
56
+ }
57
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: GroupStorageService, deps: [{ token: i1.SessionStorageService }, { token: i2.LocalStorageService }], target: i0.ɵɵFactoryTarget.Injectable });
58
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: GroupStorageService, providedIn: 'root' });
59
+ }
60
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: GroupStorageService, decorators: [{
61
+ type: Injectable,
62
+ args: [{
63
+ providedIn: 'root'
64
+ }]
65
+ }], ctorParameters: () => [{ type: i1.SessionStorageService }, { type: i2.LocalStorageService }] });
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAtc3RvcmFnZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvamNvbnN1bWVyLXNoYXJlZC9zcmMvbGliL2dyb3VwLXN0b3JhZ2Uuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBUzNDLE1BQU0sT0FBTyxtQkFBbUI7SUFDUjtJQUFzRDtJQUExRSxZQUFvQixxQkFBNEMsRUFBVSxlQUFvQztRQUExRiwwQkFBcUIsR0FBckIscUJBQXFCLENBQXVCO1FBQVUsb0JBQWUsR0FBZixlQUFlLENBQXFCO0lBQUcsQ0FBQztJQUUzRyxRQUFRO1FBQ1gsSUFBSSxJQUFJLENBQUMscUJBQXFCLENBQUMseUJBQXlCLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNsRSxPQUFPLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyx5QkFBeUIsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzRSxDQUFDO2FBQU0sQ0FBQztZQUNOLE9BQU8sQ0FBQyxDQUFDO1FBQ1gsQ0FBQztJQUNILENBQUM7SUFFTSxxQkFBcUIsQ0FBQyxRQUFhLEVBQUUsU0FBYztRQUN4RCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDOUIsSUFBSSxRQUFRLEdBQVEsRUFBRSxDQUFDO1FBQ3ZCLElBQUksSUFBSSxDQUFDLGVBQWUsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQ3hELFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQSxDQUFDLENBQUEsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUEsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUMvSSxJQUFJLFFBQVEsRUFBRSxDQUFDO2dCQUNiLFFBQVEsQ0FBQyxRQUFRLENBQUMsR0FBRyxTQUFTLENBQUM7WUFDakMsQ0FBQztRQUNILENBQUM7YUFBTSxDQUFDO1lBQ04sUUFBUSxDQUFDLFFBQVEsQ0FBQyxHQUFHLFNBQVMsQ0FBQztRQUNqQyxDQUFDO1FBQ0QsSUFBSSxDQUFDLGVBQWUsQ0FBQyxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0lBQzlFLENBQUM7SUFDTSx1QkFBdUIsQ0FBQyxRQUFnQixFQUFFLElBQVU7UUFDekQsSUFBSSxLQUFLLENBQUM7UUFDVixJQUFJLElBQUksRUFBRSxDQUFDO1lBQ1QsS0FBSyxHQUFHLENBQUMsQ0FBQztRQUNaLENBQUM7YUFBTSxDQUFDO1lBQ04sS0FBSyxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUMxQixDQUFDO1FBQ0QsSUFBSSxJQUFJLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDeEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDakYsSUFBSSxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxRQUFRLEtBQUssV0FBVyxJQUFJLFFBQVEsQ0FBQyxRQUFRLENBQUMsS0FBSyxTQUFTLENBQUMsRUFBRSxDQUFDO2dCQUN6RixPQUFPLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM1QixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFDTSwwQkFBMEIsQ0FBQyxRQUF5QjtRQUN6RCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDOUIsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDakYsSUFBSSxRQUFRLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQztZQUN2QixPQUFPLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUMxQixJQUFJLENBQUMsZUFBZSxDQUFDLHFCQUFxQixDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDOUUsQ0FBQztJQUNILENBQUM7dUdBN0NNLG1CQUFtQjsyR0FBbkIsbUJBQW1CLGNBSGhCLE1BQU07OzJGQUdULG1CQUFtQjtrQkFKL0IsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgU2Vzc2lvblN0b3JhZ2VTZXJ2aWNlIH0gZnJvbSBcIi4vc2Vzc2lvbi1zdG9yYWdlLnNlcnZpY2VcIjtcclxuaW1wb3J0IHsgTG9jYWxTdG9yYWdlU2VydmljZSB9IGZyb20gXCIuL2xvY2FsLXN0b3JhZ2Uuc2VydmljZVwiO1xyXG5cclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICAgIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5cclxuZXhwb3J0IGNsYXNzIEdyb3VwU3RvcmFnZVNlcnZpY2Uge1xyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBzZXNzaW9uU3RvcmFnZVNlcnZpY2U6IFNlc3Npb25TdG9yYWdlU2VydmljZSwgcHJpdmF0ZSBsU3RvcmFnZVNlcnZpY2U6IExvY2FsU3RvcmFnZVNlcnZpY2UpIHt9XHJcblxyXG4gICAgcHVibGljIGdldEdyb3VwKCkge1xyXG4gICAgICAgIGlmICh0aGlzLnNlc3Npb25TdG9yYWdlU2VydmljZS5nZXRpdGVtZnJvbVNlc3Npb25TdG9yYWdlKCd0YWJJZCcpKSB7XHJcbiAgICAgICAgICByZXR1cm4gdGhpcy5zZXNzaW9uU3RvcmFnZVNlcnZpY2UuZ2V0aXRlbWZyb21TZXNzaW9uU3RvcmFnZSgnYWNjb3VudGlkJyk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIHJldHVybiAwO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgXHJcbiAgICAgIHB1YmxpYyBzZXRpdGVtVG9Hcm91cFN0b3JhZ2UoaXRlbW5hbWU6IGFueSwgaXRlbXZhbHVlOiBhbnkpIHtcclxuICAgICAgICBjb25zdCBncm91cCA9IHRoaXMuZ2V0R3JvdXAoKTtcclxuICAgICAgICBsZXQgZ3JvdXBPYmo6IGFueSA9IHt9O1xyXG4gICAgICAgIGlmICh0aGlzLmxTdG9yYWdlU2VydmljZS5nZXRpdGVtZnJvbUxvY2FsU3RvcmFnZShncm91cCkpIHtcclxuICAgICAgICAgIGdyb3VwT2JqID0gSlNPTi5wYXJzZSh0aGlzLmxTdG9yYWdlU2VydmljZS5nZXRpdGVtZnJvbUxvY2FsU3RvcmFnZShncm91cCkpP0pTT04ucGFyc2UodGhpcy5sU3RvcmFnZVNlcnZpY2UuZ2V0aXRlbWZyb21Mb2NhbFN0b3JhZ2UoZ3JvdXApKToge307XHJcbiAgICAgICAgICBpZiAoZ3JvdXBPYmopIHtcclxuICAgICAgICAgICAgZ3JvdXBPYmpbaXRlbW5hbWVdID0gaXRlbXZhbHVlO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICBncm91cE9ialtpdGVtbmFtZV0gPSBpdGVtdmFsdWU7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHRoaXMubFN0b3JhZ2VTZXJ2aWNlLnNldGl0ZW1vbkxvY2FsU3RvcmFnZShncm91cCwgSlNPTi5zdHJpbmdpZnkoZ3JvdXBPYmopKTtcclxuICAgICAgfVxyXG4gICAgICBwdWJsaWMgZ2V0aXRlbUZyb21Hcm91cFN0b3JhZ2UoaXRlbW5hbWU6IHN0cmluZywgdHlwZT86IGFueSkge1xyXG4gICAgICAgIGxldCBncm91cDtcclxuICAgICAgICBpZiAodHlwZSkge1xyXG4gICAgICAgICAgZ3JvdXAgPSAwO1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICBncm91cCA9IHRoaXMuZ2V0R3JvdXAoKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKHRoaXMubFN0b3JhZ2VTZXJ2aWNlLmdldGl0ZW1mcm9tTG9jYWxTdG9yYWdlKGdyb3VwKSkge1xyXG4gICAgICAgICAgY29uc3QgZ3JvdXBPYmogPSBKU09OLnBhcnNlKHRoaXMubFN0b3JhZ2VTZXJ2aWNlLmdldGl0ZW1mcm9tTG9jYWxTdG9yYWdlKGdyb3VwKSk7XHJcbiAgICAgICAgICBpZiAoZ3JvdXBPYmpbaXRlbW5hbWVdIHx8IChpdGVtbmFtZSA9PT0gJ2lzQ2hlY2tpbicgJiYgZ3JvdXBPYmpbaXRlbW5hbWVdICE9PSB1bmRlZmluZWQpKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBncm91cE9ialtpdGVtbmFtZV07XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICAgIHB1YmxpYyByZW1vdmVpdGVtRnJvbUdyb3VwU3RvcmFnZShpdGVtbmFtZTogc3RyaW5nIHwgbnVtYmVyKSB7XHJcbiAgICAgICAgY29uc3QgZ3JvdXAgPSB0aGlzLmdldEdyb3VwKCk7XHJcbiAgICAgICAgY29uc3QgZ3JvdXBPYmogPSBKU09OLnBhcnNlKHRoaXMubFN0b3JhZ2VTZXJ2aWNlLmdldGl0ZW1mcm9tTG9jYWxTdG9yYWdlKGdyb3VwKSk7XHJcbiAgICAgICAgaWYgKGdyb3VwT2JqW2l0ZW1uYW1lXSkge1xyXG4gICAgICAgICAgZGVsZXRlIGdyb3VwT2JqW2l0ZW1uYW1lXTtcclxuICAgICAgICAgIHRoaXMubFN0b3JhZ2VTZXJ2aWNlLnNldGl0ZW1vbkxvY2FsU3RvcmFnZShncm91cCwgSlNPTi5zdHJpbmdpZnkoZ3JvdXBPYmopKTtcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,43 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { HttpClient } from '@angular/common/http';
4
+ import { TranslateHttpLoader } from '@ngx-translate/http-loader';
5
+ import { TranslateLoader, TranslateModule } from '@ngx-translate/core';
6
+ import { SharedService } from './shared.service';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@ngx-translate/core";
9
+ export function HttpLoaderFactory(http, sharedService) {
10
+ return new TranslateHttpLoader(http, sharedService.getI8nPath() + 'assets/i18n/', '.json');
11
+ }
12
+ export class I8nModule {
13
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: I8nModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
14
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: I8nModule, imports: [CommonModule, i1.TranslateModule], exports: [TranslateModule] });
15
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: I8nModule, imports: [CommonModule,
16
+ TranslateModule.forRoot({
17
+ loader: {
18
+ provide: TranslateLoader,
19
+ useFactory: HttpLoaderFactory,
20
+ deps: [HttpClient, SharedService]
21
+ }
22
+ }), TranslateModule] });
23
+ }
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: I8nModule, decorators: [{
25
+ type: NgModule,
26
+ args: [{
27
+ declarations: [],
28
+ imports: [
29
+ CommonModule,
30
+ TranslateModule.forRoot({
31
+ loader: {
32
+ provide: TranslateLoader,
33
+ useFactory: HttpLoaderFactory,
34
+ deps: [HttpClient, SharedService]
35
+ }
36
+ })
37
+ ],
38
+ exports: [
39
+ TranslateModule
40
+ ]
41
+ }]
42
+ }] });
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaThuLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2pjb25zdW1lci1zaGFyZWQvc3JjL2xpYi9pOG4ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNsRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7O0FBRWpELE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxJQUFnQixFQUFFLGFBQTRCO0lBQzlFLE9BQU8sSUFBSSxtQkFBbUIsQ0FBQyxJQUFJLEVBQUUsYUFBYSxDQUFDLFVBQVUsRUFBRSxHQUFHLGNBQWMsRUFBRSxPQUFPLENBQUMsQ0FBQztBQUM3RixDQUFDO0FBa0JELE1BQU0sT0FBTyxTQUFTO3VHQUFULFNBQVM7d0dBQVQsU0FBUyxZQWJsQixZQUFZLGlDQVVaLGVBQWU7d0dBR04sU0FBUyxZQWJsQixZQUFZO1lBQ1osZUFBZSxDQUFDLE9BQU8sQ0FBQztnQkFDdEIsTUFBTSxFQUFFO29CQUNOLE9BQU8sRUFBRSxlQUFlO29CQUN0QixVQUFVLEVBQUUsaUJBQWlCO29CQUM3QixJQUFJLEVBQUUsQ0FBQyxVQUFVLEVBQUUsYUFBYSxDQUFDO2lCQUNwQzthQUNGLENBQUMsRUFHRixlQUFlOzsyRkFHTixTQUFTO2tCQWhCckIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osZUFBZSxDQUFDLE9BQU8sQ0FBQzs0QkFDdEIsTUFBTSxFQUFFO2dDQUNOLE9BQU8sRUFBRSxlQUFlO2dDQUN0QixVQUFVLEVBQUUsaUJBQWlCO2dDQUM3QixJQUFJLEVBQUUsQ0FBQyxVQUFVLEVBQUUsYUFBYSxDQUFDOzZCQUNwQzt5QkFDRixDQUFDO3FCQUNIO29CQUNELE9BQU8sRUFBRzt3QkFDUixlQUFlO3FCQUNoQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZUh0dHBMb2FkZXIgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9odHRwLWxvYWRlcic7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZUxvYWRlciwgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IFNoYXJlZFNlcnZpY2UgfSBmcm9tICcuL3NoYXJlZC5zZXJ2aWNlJztcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBIdHRwTG9hZGVyRmFjdG9yeShodHRwOiBIdHRwQ2xpZW50LCBzaGFyZWRTZXJ2aWNlOiBTaGFyZWRTZXJ2aWNlKSB7XHJcbiAgcmV0dXJuIG5ldyBUcmFuc2xhdGVIdHRwTG9hZGVyKGh0dHAsIHNoYXJlZFNlcnZpY2UuZ2V0SThuUGF0aCgpICsgJ2Fzc2V0cy9pMThuLycsICcuanNvbicpO1xyXG59XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW10sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgVHJhbnNsYXRlTW9kdWxlLmZvclJvb3Qoe1xyXG4gICAgICBsb2FkZXI6IHtcclxuICAgICAgICBwcm92aWRlOiBUcmFuc2xhdGVMb2FkZXIsXHJcbiAgICAgICAgICB1c2VGYWN0b3J5OiBIdHRwTG9hZGVyRmFjdG9yeSxcclxuICAgICAgICAgIGRlcHM6IFtIdHRwQ2xpZW50LCBTaGFyZWRTZXJ2aWNlXVxyXG4gICAgICB9XHJcbiAgICB9KVxyXG4gIF0sXHJcbiAgZXhwb3J0cyA6IFtcclxuICAgIFRyYW5zbGF0ZU1vZHVsZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEk4bk1vZHVsZSB7IH1cclxuIl19
@@ -0,0 +1,77 @@
1
+ import { Injectable } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ * Handle Local Storage related actions
5
+ */
6
+ export class LocalStorageService {
7
+ /* holds the variables which not removed by clearLocalstorage() method */
8
+ dont_delete_localstorage = ['refreshToken', 'userType', 'version', 'qrp', 'mUniqueId', 'authToken', 'reqFrom', 'source', 'translatevariable', 'appId', 'installId', 'appUniqueId', 'cleared', 'googleToken', 'sysdate', 'pt_pwd', 'target', 'activeLocation', 'busId'];
9
+ /**
10
+ * Default constructor
11
+ */
12
+ constructor() {
13
+ }
14
+ /**
15
+ * function to get local storage item value
16
+ * @param itemname name of variable
17
+ */
18
+ getitemfromLocalStorage(itemname) {
19
+ // if (isPlatformBrowser(this.platformId)) {
20
+ if (localStorage.getItem(itemname) !== 'undefined') {
21
+ return JSON.parse(localStorage.getItem(itemname));
22
+ }
23
+ // }
24
+ // return null;
25
+ }
26
+ /**
27
+ * // function to set local storage item value
28
+ * @param itemname name of variable
29
+ * @param itemvalue value to set
30
+ */
31
+ setitemonLocalStorage(itemname, itemvalue) {
32
+ // if (isPlatformBrowser(this.platformId)) {
33
+ localStorage.setItem(itemname, JSON.stringify(itemvalue));
34
+ // }
35
+ }
36
+ /**
37
+ * Method to remove an item from local storage
38
+ * @param itemname item to be removed
39
+ */
40
+ removeitemfromLocalStorage(itemname) {
41
+ // if (isPlatformBrowser(this.platformId)) {
42
+ localStorage.removeItem(itemname);
43
+ // }
44
+ }
45
+ /**
46
+ * Method to clear the local storage items except the ones contained in 'dont_delete_localstorage'
47
+ */
48
+ clearLocalstorage() {
49
+ // if (isPlatformBrowser(this.platformId)) {
50
+ this.removeitemfromLocalStorage('ynw-credentials');
51
+ for (let index = 0; index < localStorage.length; index++) {
52
+ if (this.dont_delete_localstorage.indexOf(localStorage.key(index)) === -1) {
53
+ localStorage.removeItem(localStorage.key(index));
54
+ index = index - 1; // manage index after remove
55
+ }
56
+ }
57
+ // }
58
+ }
59
+ /**
60
+ * Method to clear the local storage items
61
+ */
62
+ clearAll() {
63
+ for (let index = 0; index < localStorage.length; index++) {
64
+ localStorage.removeItem(localStorage.key(index));
65
+ index = index - 1; // manage index after remove
66
+ }
67
+ }
68
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: LocalStorageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
69
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: LocalStorageService, providedIn: 'root' });
70
+ }
71
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: LocalStorageService, decorators: [{
72
+ type: Injectable,
73
+ args: [{
74
+ providedIn: 'root'
75
+ }]
76
+ }], ctorParameters: () => [] });
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWwtc3RvcmFnZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvamNvbnN1bWVyLXNoYXJlZC9zcmMvbGliL2xvY2FsLXN0b3JhZ2Uuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQzs7R0FFRztBQUNILE1BQU0sT0FBTyxtQkFBbUI7SUFFNUIseUVBQXlFO0lBQ3pFLHdCQUF3QixHQUFHLENBQUMsY0FBYyxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxtQkFBbUIsRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBRXZROztPQUVHO0lBQ0g7SUFHQSxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksdUJBQXVCLENBQUMsUUFBZ0I7UUFDM0MsNENBQTRDO1FBQzVDLElBQUksWUFBWSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsS0FBSyxXQUFXLEVBQUUsQ0FBQztZQUNqRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1FBQ3RELENBQUM7UUFDRCxJQUFJO1FBQ0osZUFBZTtJQUNuQixDQUFDO0lBQ0Q7Ozs7T0FJRztJQUNJLHFCQUFxQixDQUFDLFFBQWdCLEVBQUUsU0FBYztRQUN6RCw0Q0FBNEM7UUFDNUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO1FBQzFELElBQUk7SUFDUixDQUFDO0lBQ0Q7OztPQUdHO0lBQ0ksMEJBQTBCLENBQUMsUUFBZ0I7UUFDOUMsNENBQTRDO1FBQzVDLFlBQVksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDbEMsSUFBSTtJQUNSLENBQUM7SUFDRDs7T0FFRztJQUNJLGlCQUFpQjtRQUNwQiw0Q0FBNEM7UUFDNUMsSUFBSSxDQUFDLDBCQUEwQixDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDbkQsS0FBSyxJQUFJLEtBQUssR0FBRyxDQUFDLEVBQUUsS0FBSyxHQUFHLFlBQVksQ0FBQyxNQUFNLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUN2RCxJQUFJLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQ3hFLFlBQVksQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO2dCQUNqRCxLQUFLLEdBQUcsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDLDRCQUE0QjtZQUNuRCxDQUFDO1FBQ0wsQ0FBQztRQUNELElBQUk7SUFDUixDQUFDO0lBQ0Q7O09BRUc7SUFDSSxRQUFRO1FBQ1gsS0FBSyxJQUFJLEtBQUssR0FBRyxDQUFDLEVBQUUsS0FBSyxHQUFHLFlBQVksQ0FBQyxNQUFNLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUN2RCxZQUFZLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUNqRCxLQUFLLEdBQUcsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDLDRCQUE0QjtRQUNuRCxDQUFDO0lBQ0wsQ0FBQzt1R0FsRVEsbUJBQW1COzJHQUFuQixtQkFBbUIsY0FMaEIsTUFBTTs7MkZBS1QsbUJBQW1CO2tCQU4vQixVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbi8qKlxyXG4gKiBIYW5kbGUgTG9jYWwgU3RvcmFnZSByZWxhdGVkIGFjdGlvbnNcclxuICovXHJcbmV4cG9ydCBjbGFzcyBMb2NhbFN0b3JhZ2VTZXJ2aWNlIHtcclxuXHJcbiAgICAvKiBob2xkcyB0aGUgdmFyaWFibGVzIHdoaWNoIG5vdCByZW1vdmVkIGJ5IGNsZWFyTG9jYWxzdG9yYWdlKCkgbWV0aG9kICovXHJcbiAgICBkb250X2RlbGV0ZV9sb2NhbHN0b3JhZ2UgPSBbJ3JlZnJlc2hUb2tlbicsICd1c2VyVHlwZScsICd2ZXJzaW9uJywgJ3FycCcsICdtVW5pcXVlSWQnLCAnYXV0aFRva2VuJywgJ3JlcUZyb20nLCAnc291cmNlJywgJ3RyYW5zbGF0ZXZhcmlhYmxlJywgJ2FwcElkJywgJ2luc3RhbGxJZCcsICdhcHBVbmlxdWVJZCcsICdjbGVhcmVkJywgJ2dvb2dsZVRva2VuJywgJ3N5c2RhdGUnLCAncHRfcHdkJywgJ3RhcmdldCcsICdhY3RpdmVMb2NhdGlvbicsICdidXNJZCddO1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogRGVmYXVsdCBjb25zdHJ1Y3RvclxyXG4gICAgICovXHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICAvLyBASW5qZWN0KFBMQVRGT1JNX0lEKSBwcml2YXRlIHBsYXRmb3JtSWQ6IG9iamVjdFxyXG4gICAgKSB7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBmdW5jdGlvbiB0byBnZXQgbG9jYWwgc3RvcmFnZSBpdGVtIHZhbHVlXHJcbiAgICAgKiBAcGFyYW0gaXRlbW5hbWUgbmFtZSBvZiB2YXJpYWJsZVxyXG4gICAgICovXHJcbiAgICBwdWJsaWMgZ2V0aXRlbWZyb21Mb2NhbFN0b3JhZ2UoaXRlbW5hbWU6IHN0cmluZykge1xyXG4gICAgICAgIC8vIGlmIChpc1BsYXRmb3JtQnJvd3Nlcih0aGlzLnBsYXRmb3JtSWQpKSB7XHJcbiAgICAgICAgaWYgKGxvY2FsU3RvcmFnZS5nZXRJdGVtKGl0ZW1uYW1lKSAhPT0gJ3VuZGVmaW5lZCcpIHtcclxuICAgICAgICAgICAgcmV0dXJuIEpTT04ucGFyc2UobG9jYWxTdG9yYWdlLmdldEl0ZW0oaXRlbW5hbWUpKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgLy8gfVxyXG4gICAgICAgIC8vIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgLyoqXHJcbiAgICAgKiAvLyBmdW5jdGlvbiB0byBzZXQgbG9jYWwgc3RvcmFnZSBpdGVtIHZhbHVlXHJcbiAgICAgKiBAcGFyYW0gaXRlbW5hbWUgbmFtZSBvZiB2YXJpYWJsZSBcclxuICAgICAqIEBwYXJhbSBpdGVtdmFsdWUgdmFsdWUgdG8gc2V0XHJcbiAgICAgKi9cclxuICAgIHB1YmxpYyBzZXRpdGVtb25Mb2NhbFN0b3JhZ2UoaXRlbW5hbWU6IHN0cmluZywgaXRlbXZhbHVlOiBhbnkpIHtcclxuICAgICAgICAvLyBpZiAoaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xyXG4gICAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGl0ZW1uYW1lLCBKU09OLnN0cmluZ2lmeShpdGVtdmFsdWUpKTtcclxuICAgICAgICAvLyB9XHJcbiAgICB9XHJcbiAgICAvKipcclxuICAgICAqIE1ldGhvZCB0byByZW1vdmUgYW4gaXRlbSBmcm9tIGxvY2FsIHN0b3JhZ2VcclxuICAgICAqIEBwYXJhbSBpdGVtbmFtZSBpdGVtIHRvIGJlIHJlbW92ZWRcclxuICAgICAqL1xyXG4gICAgcHVibGljIHJlbW92ZWl0ZW1mcm9tTG9jYWxTdG9yYWdlKGl0ZW1uYW1lOiBzdHJpbmcpIHtcclxuICAgICAgICAvLyBpZiAoaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xyXG4gICAgICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKGl0ZW1uYW1lKTtcclxuICAgICAgICAvLyB9XHJcbiAgICB9XHJcbiAgICAvKipcclxuICAgICAqIE1ldGhvZCB0byBjbGVhciB0aGUgbG9jYWwgc3RvcmFnZSBpdGVtcyBleGNlcHQgdGhlIG9uZXMgY29udGFpbmVkIGluICdkb250X2RlbGV0ZV9sb2NhbHN0b3JhZ2UnXHJcbiAgICAgKi9cclxuICAgIHB1YmxpYyBjbGVhckxvY2Fsc3RvcmFnZSgpIHtcclxuICAgICAgICAvLyBpZiAoaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xyXG4gICAgICAgIHRoaXMucmVtb3ZlaXRlbWZyb21Mb2NhbFN0b3JhZ2UoJ3ludy1jcmVkZW50aWFscycpO1xyXG4gICAgICAgIGZvciAobGV0IGluZGV4ID0gMDsgaW5kZXggPCBsb2NhbFN0b3JhZ2UubGVuZ3RoOyBpbmRleCsrKSB7XHJcbiAgICAgICAgICAgIGlmICh0aGlzLmRvbnRfZGVsZXRlX2xvY2Fsc3RvcmFnZS5pbmRleE9mKGxvY2FsU3RvcmFnZS5rZXkoaW5kZXgpKSA9PT0gLTEpIHtcclxuICAgICAgICAgICAgICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKGxvY2FsU3RvcmFnZS5rZXkoaW5kZXgpKTtcclxuICAgICAgICAgICAgICAgIGluZGV4ID0gaW5kZXggLSAxOyAvLyBtYW5hZ2UgaW5kZXggYWZ0ZXIgcmVtb3ZlXHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICAgICAgLy8gfVxyXG4gICAgfVxyXG4gICAgLyoqXHJcbiAgICAgKiBNZXRob2QgdG8gY2xlYXIgdGhlIGxvY2FsIHN0b3JhZ2UgaXRlbXNcclxuICAgICAqL1xyXG4gICAgcHVibGljIGNsZWFyQWxsKCkge1xyXG4gICAgICAgIGZvciAobGV0IGluZGV4ID0gMDsgaW5kZXggPCBsb2NhbFN0b3JhZ2UubGVuZ3RoOyBpbmRleCsrKSB7XHJcbiAgICAgICAgICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKGxvY2FsU3RvcmFnZS5rZXkoaW5kZXgpKTtcclxuICAgICAgICAgICAgaW5kZXggPSBpbmRleCAtIDE7IC8vIG1hbmFnZSBpbmRleCBhZnRlciByZW1vdmVcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIl19
@@ -0,0 +1,127 @@
1
+ import { Component, forwardRef, Input, ViewChild, Output, EventEmitter } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import intlTelInput from 'intl-tel-input';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "@angular/forms";
7
+ export class PhoneInputComponent {
8
+ initialCountry = 'us'; // Default to 'us'
9
+ preferredCountries = []; // List of preferred countries
10
+ nationalMode = true; // Use national mode so dial code is hidden in input box
11
+ separateDialCode = true; // Whether to separate dial code (controls formatting)
12
+ otherOptions = {}; // Any other options for intl-tel-input
13
+ phoneInput;
14
+ phoneNumber = { dialCode: '', countryCode: '', e164Number: '', number: '' }; // Structured phone number object
15
+ phoneInputInstance;
16
+ // Output Event to send the phone number value to the parent component
17
+ phoneNumberChange = new EventEmitter();
18
+ // Function to handle form control value changes
19
+ onChange = (value) => { };
20
+ onTouched = () => { };
21
+ ngAfterViewInit() {
22
+ if (this.phoneInput && this.phoneInput.nativeElement) {
23
+ this.initializePhoneInput();
24
+ }
25
+ }
26
+ // Initialize intl-tel-input for the phone input field
27
+ initializePhoneInput() {
28
+ const options = {
29
+ initialCountry: this.initialCountry,
30
+ preferredCountries: this.preferredCountries,
31
+ nationalMode: this.nationalMode, // Use national mode to hide dial code
32
+ separateDialCode: this.separateDialCode, // Keep separate dial code for processing
33
+ utilsScript: 'https://cdnjs.cloudflare.com/ajax/libs/intl-tel-input/17.0.8/js/utils.js',
34
+ ...this.otherOptions // Merge any additional options provided
35
+ };
36
+ // Initialize intl-tel-input
37
+ this.phoneInputInstance = intlTelInput(this.phoneInput.nativeElement, options);
38
+ // Capture the country change event to track the selected country code and dial code
39
+ this.phoneInput.nativeElement.addEventListener('countrychange', () => {
40
+ this.updatePhoneNumber();
41
+ });
42
+ // Capture input event to update phone number in E.164 format
43
+ this.phoneInput.nativeElement.addEventListener('input', () => {
44
+ this.updatePhoneNumber();
45
+ });
46
+ // Set the initial value if available (without showing the dial code)
47
+ if (this.phoneNumber.e164Number) {
48
+ this.phoneInputInstance.setNumber(this.phoneNumber.e164Number); // Set the E.164 formatted number
49
+ }
50
+ }
51
+ // Method to update the phone number object
52
+ updatePhoneNumber() {
53
+ const dialCode = '+' + this.phoneInputInstance.getSelectedCountryData().dialCode;
54
+ const countryCode = this.phoneInputInstance.getSelectedCountryData().iso2;
55
+ const e164Number = this.phoneInputInstance.getNumber(); // Full number in E.164 format
56
+ const number = e164Number.split(dialCode)[1];
57
+ // Update the phoneNumber object with the full details
58
+ this.phoneNumber = {
59
+ dialCode,
60
+ countryCode,
61
+ e164Number,
62
+ number
63
+ };
64
+ // Emit the updated value to the parent component
65
+ this.phoneNumberChange.emit(this.phoneNumber); // Sending the value to parent
66
+ }
67
+ // Implement the writeValue method for ControlValueAccessor
68
+ writeValue(value) {
69
+ if (value && value.e164Number) {
70
+ this.phoneNumber = value;
71
+ if (this.phoneInput && this.phoneInput.nativeElement) {
72
+ this.phoneInputInstance.setNumber(value.e164Number); // Set the E.164 formatted number
73
+ }
74
+ }
75
+ }
76
+ // Implement the registerOnChange method for ControlValueAccessor
77
+ registerOnChange(fn) {
78
+ this.onChange = fn;
79
+ }
80
+ // Implement the registerOnTouched method for ControlValueAccessor
81
+ registerOnTouched(fn) {
82
+ this.onTouched = fn;
83
+ }
84
+ // Custom Validation Method: Validate the phone number
85
+ validatePhoneNumber() {
86
+ if (this.phoneInputInstance) {
87
+ // Check if the current phone number is valid according to the selected country
88
+ const isValid = this.phoneInputInstance.isValidNumber() || this.phoneNumber.number.startsWith('555');
89
+ return isValid;
90
+ }
91
+ return false;
92
+ }
93
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PhoneInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
94
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: PhoneInputComponent, selector: "app-phone-input", inputs: { initialCountry: "initialCountry", preferredCountries: "preferredCountries", nationalMode: "nationalMode", separateDialCode: "separateDialCode", otherOptions: "otherOptions" }, outputs: { phoneNumberChange: "phoneNumberChange" }, providers: [
95
+ {
96
+ provide: NG_VALUE_ACCESSOR,
97
+ useExisting: forwardRef(() => PhoneInputComponent),
98
+ multi: true
99
+ }
100
+ ], viewQueries: [{ propertyName: "phoneInput", first: true, predicate: ["phoneInput"], descendants: true }], ngImport: i0, template: "<div class=\"phone-input-wrapper\">\r\n <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.phoneNumber\"\r\n name=\"phoneNumber\" [required]=\"true\" #phone=\"ngModel\"\r\n [ngClass]=\"{'is-invalid': !validatePhoneNumber() && phone.touched}\">\r\n\r\n <!-- Validation feedback -->\r\n <!-- <div *ngIf=\"!validatePhoneNumber() && phone.touched\" class=\"text-danger\">\r\n Invalid phone number.\r\n </div> -->\r\n <!-- <input #phoneInput [(ngModel)]=\"phoneNumber.number\" /> -->\r\n</div>", styles: ["::ng-deep .tel-input-container .iti{width:100%!important}::ng-deep .tel-input-container .iti--separate-dial-code .iti__selected-flag{background-color:transparent}::ng-deep .tel-input-container input::-webkit-input-placeholder{color:#ddd!important}::ng-deep .tel-input-container input:focus{outline:none!important;border-color:#e1e2e3!important}::ng-deep .tel-input-container input{height:50px!important;width:100%!important;background:#fff!important;border:1.39032px solid #E1E2E3!important;border-radius:11.1225px!important;padding:15px;font-size:15px}::ng-deep .tel-input-container input.is-invalid{border:1.39032px solid #ff0000!important}::ng-deep .tel-input-container input::placeholder{color:#ddd}::ng-deep .tel-input-container input.custom:focus{color:#495057!important;background-color:#fff!important;border-color:#3c8dbc!important;outline:0!important;box-shadow:0 0 #fff!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
101
+ }
102
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PhoneInputComponent, decorators: [{
103
+ type: Component,
104
+ args: [{ selector: 'app-phone-input', providers: [
105
+ {
106
+ provide: NG_VALUE_ACCESSOR,
107
+ useExisting: forwardRef(() => PhoneInputComponent),
108
+ multi: true
109
+ }
110
+ ], template: "<div class=\"phone-input-wrapper\">\r\n <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.phoneNumber\"\r\n name=\"phoneNumber\" [required]=\"true\" #phone=\"ngModel\"\r\n [ngClass]=\"{'is-invalid': !validatePhoneNumber() && phone.touched}\">\r\n\r\n <!-- Validation feedback -->\r\n <!-- <div *ngIf=\"!validatePhoneNumber() && phone.touched\" class=\"text-danger\">\r\n Invalid phone number.\r\n </div> -->\r\n <!-- <input #phoneInput [(ngModel)]=\"phoneNumber.number\" /> -->\r\n</div>", styles: ["::ng-deep .tel-input-container .iti{width:100%!important}::ng-deep .tel-input-container .iti--separate-dial-code .iti__selected-flag{background-color:transparent}::ng-deep .tel-input-container input::-webkit-input-placeholder{color:#ddd!important}::ng-deep .tel-input-container input:focus{outline:none!important;border-color:#e1e2e3!important}::ng-deep .tel-input-container input{height:50px!important;width:100%!important;background:#fff!important;border:1.39032px solid #E1E2E3!important;border-radius:11.1225px!important;padding:15px;font-size:15px}::ng-deep .tel-input-container input.is-invalid{border:1.39032px solid #ff0000!important}::ng-deep .tel-input-container input::placeholder{color:#ddd}::ng-deep .tel-input-container input.custom:focus{color:#495057!important;background-color:#fff!important;border-color:#3c8dbc!important;outline:0!important;box-shadow:0 0 #fff!important}\n"] }]
111
+ }], propDecorators: { initialCountry: [{
112
+ type: Input
113
+ }], preferredCountries: [{
114
+ type: Input
115
+ }], nationalMode: [{
116
+ type: Input
117
+ }], separateDialCode: [{
118
+ type: Input
119
+ }], otherOptions: [{
120
+ type: Input
121
+ }], phoneInput: [{
122
+ type: ViewChild,
123
+ args: ['phoneInput', { static: false }]
124
+ }], phoneNumberChange: [{
125
+ type: Output
126
+ }] } });
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-input.component.js","sourceRoot":"","sources":["../../../../../projects/jconsumer-shared/src/lib/phone-input/phone-input.component.ts","../../../../../projects/jconsumer-shared/src/lib/phone-input/phone-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, forwardRef, Input, ViewChild, Output, EventEmitter } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\nimport intlTelInput from 'intl-tel-input';\r\n\r\n@Component({\r\n  selector: 'app-phone-input',\r\n  templateUrl: './phone-input.component.html',\r\n  styleUrls: ['./phone-input.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => PhoneInputComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class PhoneInputComponent implements AfterViewInit, ControlValueAccessor {\r\n  @Input() initialCountry: string = 'us'; // Default to 'us'\r\n  @Input() preferredCountries: string[] = []; // List of preferred countries\r\n  @Input() nationalMode: boolean = true; // Use national mode so dial code is hidden in input box\r\n  @Input() separateDialCode: boolean = true; // Whether to separate dial code (controls formatting)\r\n  @Input() otherOptions: any = {}; // Any other options for intl-tel-input\r\n\r\n  @ViewChild('phoneInput', { static: false }) phoneInput: ElementRef;\r\n  phoneNumber: any = { dialCode: '', countryCode: '', e164Number: '', number: '' }; // Structured phone number object\r\n  phoneInputInstance: any;\r\n\r\n  // Output Event to send the phone number value to the parent component\r\n  @Output() phoneNumberChange = new EventEmitter<any>();\r\n\r\n  // Function to handle form control value changes\r\n  onChange = (value: any) => {};\r\n  onTouched = () => {};\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.phoneInput && this.phoneInput.nativeElement) {\r\n      this.initializePhoneInput();\r\n    }\r\n  }\r\n\r\n  // Initialize intl-tel-input for the phone input field\r\n  initializePhoneInput(): void {\r\n    const options = {\r\n      initialCountry: this.initialCountry,\r\n      preferredCountries: this.preferredCountries,\r\n      nationalMode: this.nationalMode, // Use national mode to hide dial code\r\n      separateDialCode: this.separateDialCode, // Keep separate dial code for processing\r\n      utilsScript: 'https://cdnjs.cloudflare.com/ajax/libs/intl-tel-input/17.0.8/js/utils.js',\r\n      ...this.otherOptions // Merge any additional options provided\r\n    };\r\n\r\n    // Initialize intl-tel-input\r\n    this.phoneInputInstance = intlTelInput(this.phoneInput.nativeElement, options);\r\n\r\n    // Capture the country change event to track the selected country code and dial code\r\n    this.phoneInput.nativeElement.addEventListener('countrychange', () => {\r\n      this.updatePhoneNumber();\r\n    });\r\n\r\n    // Capture input event to update phone number in E.164 format\r\n    this.phoneInput.nativeElement.addEventListener('input', () => {\r\n      this.updatePhoneNumber();\r\n    });\r\n\r\n    // Set the initial value if available (without showing the dial code)\r\n    if (this.phoneNumber.e164Number) {\r\n      this.phoneInputInstance.setNumber(this.phoneNumber.e164Number); // Set the E.164 formatted number\r\n    }\r\n  }\r\n\r\n  // Method to update the phone number object\r\n  updatePhoneNumber(): void {\r\n    const dialCode = '+' + this.phoneInputInstance.getSelectedCountryData().dialCode;\r\n    const countryCode = this.phoneInputInstance.getSelectedCountryData().iso2;\r\n    const e164Number = this.phoneInputInstance.getNumber(); // Full number in E.164 format\r\n    const number = e164Number.split(dialCode)[1];\r\n\r\n    // Update the phoneNumber object with the full details\r\n    this.phoneNumber = {\r\n      dialCode,\r\n      countryCode,\r\n      e164Number,\r\n      number\r\n    };\r\n\r\n    // Emit the updated value to the parent component\r\n    this.phoneNumberChange.emit(this.phoneNumber);  // Sending the value to parent\r\n  }\r\n\r\n  // Implement the writeValue method for ControlValueAccessor\r\n  writeValue(value: any): void {\r\n    if (value && value.e164Number) {\r\n      this.phoneNumber = value;\r\n      if (this.phoneInput && this.phoneInput.nativeElement) {\r\n        this.phoneInputInstance.setNumber(value.e164Number); // Set the E.164 formatted number\r\n      }\r\n    }\r\n  }\r\n\r\n  // Implement the registerOnChange method for ControlValueAccessor\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  // Implement the registerOnTouched method for ControlValueAccessor\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  // Custom Validation Method: Validate the phone number\r\n  validatePhoneNumber(): boolean {\r\n    if (this.phoneInputInstance) {\r\n      // Check if the current phone number is valid according to the selected country\r\n      const isValid = this.phoneInputInstance.isValidNumber() || this.phoneNumber.number.startsWith('555');\r\n      return isValid;\r\n    }\r\n    return false;\r\n  }\r\n}","<div class=\"phone-input-wrapper\">\r\n    <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.phoneNumber\"\r\n        name=\"phoneNumber\" [required]=\"true\" #phone=\"ngModel\"\r\n        [ngClass]=\"{'is-invalid': !validatePhoneNumber() && phone.touched}\">\r\n\r\n    <!-- Validation feedback -->\r\n    <!-- <div *ngIf=\"!validatePhoneNumber() && phone.touched\" class=\"text-danger\">\r\n        Invalid phone number.\r\n    </div> -->\r\n    <!-- <input #phoneInput [(ngModel)]=\"phoneNumber.number\" /> -->\r\n</div>"]}