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.
- package/esm2022/lib/account-service.mjs +21 -0
- package/esm2022/lib/auth-service.mjs +155 -0
- package/esm2022/lib/calendar/date-time/datetime-processor.service.mjs +448 -0
- package/esm2022/lib/common.service.mjs +38 -0
- package/esm2022/lib/error-message.service.mjs +22 -0
- package/esm2022/lib/file-service.mjs +229 -0
- package/esm2022/lib/group-storage.service.mjs +66 -0
- package/esm2022/lib/i8n.module.mjs +43 -0
- package/esm2022/lib/local-storage.service.mjs +77 -0
- package/esm2022/lib/phone-input/phone-input.component.mjs +127 -0
- package/esm2022/lib/phone-input/phone-input.module.mjs +24 -0
- package/esm2022/lib/pipes/autolink/autolink.pipe.mjs +22 -0
- package/esm2022/lib/pipes/capitalize/capitalize.module.mjs +20 -0
- package/esm2022/lib/pipes/capitalize/capitalize.pipe.mjs +18 -0
- package/esm2022/lib/pipes/filter/filter.pipe.mjs +24 -0
- package/esm2022/lib/pipes/limit-to/limitTo.pipe.mjs +18 -0
- package/esm2022/lib/pipes/safe-html/safehtml.module.mjs +20 -0
- package/esm2022/lib/pipes/safe-html/safehtml.pipe.mjs +19 -0
- package/esm2022/lib/project-messages.mjs +146 -0
- package/esm2022/lib/questionaire/edit/questionnaire.component.mjs +1422 -0
- package/esm2022/lib/questionaire/edit/questionnaire.module.mjs +77 -0
- package/esm2022/lib/questionaire/questionaire-service.mjs +92 -0
- package/esm2022/lib/session-storage.service.mjs +57 -0
- package/esm2022/lib/shared.service.mjs +24 -2
- package/esm2022/lib/showuploadfile/showuploadfile.component.mjs +61 -0
- package/esm2022/lib/showuploadfile/showuploadfile.module.mjs +28 -0
- package/esm2022/lib/spinner/loading-spinner.component.mjs +22 -0
- package/esm2022/lib/spinner/loading-spinner.module.mjs +28 -0
- package/esm2022/lib/storage.service.mjs +75 -0
- package/esm2022/lib/word-processor.service.mjs +181 -0
- package/esm2022/public-api.mjs +27 -1
- package/fesm2022/jconsumer-shared.mjs +3522 -26
- package/fesm2022/jconsumer-shared.mjs.map +1 -1
- package/jconsumer-shared-0.0.3.tgz +0 -0
- package/lib/account-service.d.ts +9 -0
- package/lib/auth-service.d.ts +43 -0
- package/lib/calendar/date-time/datetime-processor.service.d.ts +120 -0
- package/lib/common.service.d.ts +9 -0
- package/lib/error-message.service.d.ts +5 -0
- package/lib/file-service.d.ts +26 -0
- package/lib/group-storage.service.d.ts +14 -0
- package/lib/i8n.module.d.ts +12 -0
- package/lib/local-storage.service.d.ts +34 -0
- package/lib/phone-input/phone-input.component.d.ts +25 -0
- package/lib/phone-input/phone-input.module.d.ts +9 -0
- package/lib/pipes/autolink/autolink.pipe.d.ts +7 -0
- package/lib/pipes/capitalize/capitalize.module.d.ts +8 -0
- package/lib/pipes/capitalize/capitalize.pipe.d.ts +7 -0
- package/lib/pipes/filter/filter.pipe.d.ts +7 -0
- package/lib/pipes/limit-to/limitTo.pipe.d.ts +7 -0
- package/lib/pipes/safe-html/safehtml.module.d.ts +8 -0
- package/lib/pipes/safe-html/safehtml.pipe.d.ts +10 -0
- package/lib/project-messages.d.ts +1 -0
- package/lib/questionaire/edit/questionnaire.component.d.ts +151 -0
- package/lib/questionaire/edit/questionnaire.module.d.ts +19 -0
- package/lib/questionaire/questionaire-service.d.ts +28 -0
- package/lib/session-storage.service.d.ts +26 -0
- package/lib/shared.service.d.ts +12 -3
- package/lib/showuploadfile/showuploadfile.component.d.ts +21 -0
- package/lib/showuploadfile/showuploadfile.module.d.ts +9 -0
- package/lib/spinner/loading-spinner.component.d.ts +11 -0
- package/lib/spinner/loading-spinner.module.d.ts +9 -0
- package/lib/storage.service.d.ts +16 -0
- package/lib/word-processor.service.d.ts +80 -0
- package/package.json +1 -1
- package/public-api.d.ts +26 -0
- 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>"]}
|