UNPKG

sl-questionnaire

Version:
182 lines 22.9 kB
import { __awaiter, __decorate, __generator, __values } from "tslib"; import { Component, Input } from '@angular/core'; import { SlTranslateService } from '../services/translate.service'; import { SlUtilsService } from '../services/utils.service'; var AttachmentComponent = /** @class */ (function () { function AttachmentComponent(translate, utils) { this.translate = translate; this.utils = utils; } AttachmentComponent.prototype.ngOnInit = function () { }; AttachmentComponent.prototype.basicUpload = function (files) { var _this = this; var sizeMB = +(files[0].size / 1000 / 1000).toFixed(4); if (sizeMB > 20) { this.fileLimitCross(); return; } this.formData = new FormData(); Array.from(files).forEach(function (f) { return _this.formData.append('file', f); }); this.preSignedUrl(this.getFileNames(this.formData)); }; AttachmentComponent.prototype.fileLimitCross = function () { var alertMeta = { size: 'tiny', bodyType: 'text', data: this.translate['frmelmnts'].alert.fileLimitCross20, buttonClass: 'single-btn', acceptText: this.translate['frmelmnts'].btn.ok, cancelText: null, }; this.utils.alert(alertMeta); }; AttachmentComponent.prototype.getFileNames = function (formData) { var files = []; formData.forEach(function (element) { files.push(element.name); }); return files; }; AttachmentComponent.prototype.preSignedUrl = function (files) { var _this = this; var payload = {}; payload['ref'] = 'survey'; payload['request'] = {}; payload['request'][this.data.submissionId] = { files: files, }; this.utils.getPreSingedUrls(payload).subscribe(function (imageData) { var presignedUrlData = imageData['result'][_this.data.submissionId].files[0]; _this.formData.append('url', presignedUrlData.url); _this.utils.cloudStorageUpload(_this.formData).subscribe(function (success) { var e_1, _a; if (success.status === 200) { var obj = { name: _this.getFileNames(_this.formData)[0], url: presignedUrlData.url.split('?')[0], }; try { for (var _b = __values(Object.keys(presignedUrlData.payload)), _c = _b.next(); !_c.done; _c = _b.next()) { var key = _c.value; obj[key] = presignedUrlData['payload'][key]; } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_1) throw e_1.error; } } _this.data.files.push(obj); var alertMeta = { size: 'tiny', bodyType: 'text', data: _this.translate['frmelmnts'].alert.evidenceUploaded, buttonClass: 'single-btn', acceptText: _this.translate['frmelmnts'].btn.ok, cancelText: null, type: 'uploaded', }; _this.utils.alert(alertMeta); } else { _this.utils.error(_this.translate['frmelmnts'].message.unableToUpload); } }, function (error) { _this.utils.error(_this.translate['frmelmnts'].message.unableToUpload); }); }, function (error) { console.log(error); }); }; AttachmentComponent.prototype.extension = function (name) { return name.split('.').pop(); }; AttachmentComponent.prototype.openFile = function (file) { window.open(file.url, '_blank'); }; AttachmentComponent.prototype.deleteAttachment = function (fileIndex) { return __awaiter(this, void 0, void 0, function () { var alertMeta, accepted; return __generator(this, function (_a) { switch (_a.label) { case 0: alertMeta = { size: 'mini', bodyType: 'text', data: this.translate['frmelmnts'].alert.confirmEvidenceDelete, buttonClass: 'double-btn', acceptText: this.translate['frmelmnts'].btn.ok, cancelText: this.translate['frmelmnts'].btn.no, }; return [4 /*yield*/, this.utils.alert(alertMeta)]; case 1: accepted = _a.sent(); if (!accepted) { return [2 /*return*/]; } this.data.files.splice(fileIndex, 1); return [2 /*return*/]; } }); }); }; AttachmentComponent.prototype.onAddApproval = function (file) { return __awaiter(this, void 0, void 0, function () { var html, alertMeta, returnData; return __generator(this, function (_a) { switch (_a.label) { case 0: html = "\n " + this.translate['frmelmnts'].alert.evidence_content_policy + "<a href='/term-of-use.html' target=\"_blank\">" + this.translate['frmelmnts'].alert.evidence_content_policy_label + "</a> ." + this.translate['frmelmnts'].alert.uploadevidencecontent + "\n "; alertMeta = { size: 'tiny', bodyType: 'checkbox', data: html, buttonClass: 'double-btn', acceptText: this.translate['frmelmnts'].btn.upload, cancelText: this.translate['frmelmnts'].btn.donotupload, }; return [4 /*yield*/, this.utils.alert(alertMeta)]; case 1: returnData = _a.sent(); if (!returnData) { this.notAccepted(); return [2 /*return*/]; } file.click(); return [2 /*return*/]; } }); }); }; AttachmentComponent.prototype.notAccepted = function () { var alertMeta = { size: 'tiny', bodyType: 'text', data: this.translate['frmelmnts'].alert.uploadTermsRejected, buttonClass: 'single-btn', acceptText: this.translate['frmelmnts'].btn.ok, cancelText: null, type: 'notAccepted', }; this.utils.alert(alertMeta); }; AttachmentComponent.ctorParameters = function () { return [ { type: SlTranslateService }, { type: SlUtilsService } ]; }; __decorate([ Input() ], AttachmentComponent.prototype, "data", void 0); AttachmentComponent = __decorate([ Component({ selector: 'sl-attachment', template: "<label for=\"file-upload\" class=\"custom-file-upload\"></label>\n<input\n id=\"file-upload\"\n type=\"file\"\n #file\n (change)=\"basicUpload($event.target.files)\"\n/>\n<div class=\"d-flex\">\n <div class=\"bs-1 p-20\" (click)=\"onAddApproval(file)\">\n <i class=\"plus icon\"></i>\n </div>\n <div\n *ngFor=\"let item of data.files; let i = index\"\n (click)=\"openFile(item)\"\n class=\"area\"\n >\n <a\n class=\"remove-image\"\n (click)=\"$event.stopPropagation(); deleteAttachment(i)\"\n >&#215;</a\n >\n <div *ngIf=\"extension(item.name) == 'png'\" class=\"mx-10\">\n <i class=\"file image outline icon\"></i>\n </div>\n <div *ngIf=\"extension(item.name) == 'jpg'\" class=\"mx-10\">\n <i class=\"file image outline icon\"></i>\n </div>\n <div *ngIf=\"extension(item.name) == 'jpeg'\" class=\"mx-10\">\n <i class=\"file image outline icon\"></i>\n </div>\n <div *ngIf=\"extension(item.name) == 'pdf'\" class=\"mx-10\">\n <i class=\"file pdf outline icon\"></i>\n </div>\n </div>\n</div>\n", styles: ["input[type=file]{display:none}.area{position:relative}.area a{display:inline}.area i{font-size:40px}.remove-image{display:none;position:absolute;top:-10px;right:2px;border-radius:10em;padding:2px 6px 3px;text-decoration:none;background:#555;border:3px solid #fff;color:#fff!important;box-shadow:0 2px 6px rgba(0,0,0,.5),inset 0 2px 4px rgba(0,0,0,.3);text-shadow:0 1px 2px rgba(0,0,0,.5);transition:background .5s}.remove-image:hover{background:#e54e4e;padding:3px 7px 5px;top:-11px;right:2px}.remove-image:active{background:#e54e4e;top:-10px;right:2px}.bs-1{background-color:grey}"] }) ], AttachmentComponent); return AttachmentComponent; }()); export { AttachmentComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment.component.js","sourceRoot":"ng://sl-questionnaire/","sources":["lib/attachment/attachment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { AlertMeta } from '../interfaces/alert.type';\nimport { SlTranslateService } from '../services/translate.service';\nimport { SlUtilsService } from '../services/utils.service';\n\n@Component({\n  selector: 'sl-attachment',\n  templateUrl: './attachment.component.html',\n  styleUrls: ['./attachment.component.scss'],\n})\nexport class AttachmentComponent implements OnInit {\n  @Input() data;\n  formData;\n  constructor(\n    private translate: SlTranslateService,\n    private utils: SlUtilsService\n  ) {}\n\n  ngOnInit(): void {}\n\n  basicUpload(files: File[]) {\n    let sizeMB = +(files[0].size / 1000 / 1000).toFixed(4);\n    if (sizeMB > 20) {\n      this.fileLimitCross();\n      return;\n    }\n    this.formData = new FormData();\n    Array.from(files).forEach((f) => this.formData.append('file', f));\n    this.preSignedUrl(this.getFileNames(this.formData));\n  }\n\n  fileLimitCross() {\n    const alertMeta: AlertMeta = {\n      size: 'tiny',\n      bodyType: 'text',\n      data: this.translate['frmelmnts'].alert.fileLimitCross20,\n      buttonClass: 'single-btn',\n      acceptText: this.translate['frmelmnts'].btn.ok,\n      cancelText: null,\n    };\n    this.utils.alert(alertMeta);\n  }\n\n  getFileNames(formData) {\n    let files = [];\n    formData.forEach((element) => {\n      files.push(element.name);\n    });\n    return files;\n  }\n\n  preSignedUrl(files) {\n    let payload = {};\n    payload['ref'] = 'survey';\n    payload['request'] = {};\n    payload['request'][this.data.submissionId] = {\n      files: files,\n    };\n    this.utils.getPreSingedUrls(payload).subscribe(\n      (imageData) => {\n        const presignedUrlData =\n          imageData['result'][this.data.submissionId].files[0];\n        this.formData.append('url', presignedUrlData.url);\n        this.utils.cloudStorageUpload(this.formData).subscribe(\n          (success: any) => {\n            if (success.status === 200) {\n              const obj = {\n                name: this.getFileNames(this.formData)[0],\n                url: presignedUrlData.url.split('?')[0],\n              };\n              for (const key of Object.keys(presignedUrlData.payload)) {\n                obj[key] = presignedUrlData['payload'][key];\n              }\n              this.data.files.push(obj);\n              const alertMeta: AlertMeta = {\n                size: 'tiny',\n                bodyType: 'text',\n                data: this.translate['frmelmnts'].alert.evidenceUploaded,\n                buttonClass: 'single-btn',\n                acceptText: this.translate['frmelmnts'].btn.ok,\n                cancelText: null,\n                type: 'uploaded',\n              };\n              this.utils.alert(alertMeta);\n            } else {\n              this.utils.error(\n                this.translate['frmelmnts'].message.unableToUpload\n              );\n            }\n          },\n          (error) => {\n            this.utils.error(\n              this.translate['frmelmnts'].message.unableToUpload\n            );\n          }\n        );\n      },\n      (error) => {\n        console.log(error);\n      }\n    );\n  }\n\n  extension(name) {\n    return name.split('.').pop();\n  }\n  openFile(file) {\n    window.open(file.url, '_blank');\n  }\n\n  async deleteAttachment(fileIndex) {\n    const alertMeta: AlertMeta = {\n      size: 'mini',\n      bodyType: 'text',\n      data: this.translate['frmelmnts'].alert.confirmEvidenceDelete,\n      buttonClass: 'double-btn',\n      acceptText: this.translate['frmelmnts'].btn.ok,\n      cancelText: this.translate['frmelmnts'].btn.no,\n    };\n    const accepted = await this.utils.alert(alertMeta);\n\n    if (!accepted) {\n      return;\n    }\n    this.data.files.splice(fileIndex, 1);\n  }\n\n  async onAddApproval(file) {\n    let html = `\n    ${this.translate['frmelmnts'].alert.evidence_content_policy}<a href='/term-of-use.html' target=\"_blank\">${this.translate['frmelmnts'].alert.evidence_content_policy_label}</a> .${this.translate['frmelmnts'].alert.uploadevidencecontent}\n    `;\n    const alertMeta: AlertMeta = {\n      size: 'tiny',\n      bodyType: 'checkbox',\n      data: html,\n      buttonClass: 'double-btn',\n      acceptText: this.translate['frmelmnts'].btn.upload,\n      cancelText: this.translate['frmelmnts'].btn.donotupload,\n    };\n    let returnData = await this.utils.alert(alertMeta);\n    if (!returnData) {\n      this.notAccepted();\n      return;\n    }\n    file.click();\n  }\n\n  notAccepted(): void {\n    const alertMeta: AlertMeta = {\n      size: 'tiny',\n      bodyType: 'text',\n      data: this.translate['frmelmnts'].alert.uploadTermsRejected,\n      buttonClass: 'single-btn',\n      acceptText: this.translate['frmelmnts'].btn.ok,\n      cancelText: null,\n      type: 'notAccepted',\n    };\n    this.utils.alert(alertMeta);\n  }\n}\n"]}