Socket
Socket
Sign inDemoInstall

adias-file-uploader

Package Overview
Dependencies
Maintainers
1
Versions
21
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

adias-file-uploader - npm Package Compare versions

Comparing version 2.0.4 to 2.0.7

2

adias-file-uploader.metadata.json

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"FilePickerRespnse":{"__symbolic":"interface"},"FileUploaderModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵa"}],"imports":[],"exports":[{"__symbolic":"reference","name":"ɵa"}],"providers":[{"__symbolic":"reference","name":"FileUploaderService"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["endPoint"],"value":{"ngModule":{"__symbolic":"reference","name":"FileUploaderModule"},"providers":[{"provide":{"__symbolic":"reference","name":"ɵb"},"useValue":{"__symbolic":"reference","name":"endPoint"}}]}}}},"FileUploaderService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":10,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":13,"character":5},"arguments":[{"__symbolic":"reference","name":"ɵb"}]}],null],"parameters":[{"__symbolic":"reference","name":"string"},{"__symbolic":"reference","module":"@angular/common/http","name":"HttpClient","line":14,"character":18}]}],"upload":[{"__symbolic":"method"}]}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":14,"character":1},"arguments":[{"selector":"[ngxFilePicker]"}]}],"members":{"uploadSuccess":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":18,"character":3}}]}],"fileUrl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":33,"character":19},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":34,"character":22},{"__symbolic":"reference","name":"FileUploaderService"}]}],"ngOnInit":[{"__symbolic":"method"}],"createSpinnerDiv":[{"__symbolic":"method"}],"createHoveredDiv":[{"__symbolic":"method"}],"createUploadButton":[{"__symbolic":"method"}],"createUploaderElement":[{"__symbolic":"method"}],"bindEvents":[{"__symbolic":"method"}],"upload":[{"__symbolic":"method"}],"previewImage":[{"__symbolic":"method"}],"onMouseOver":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":182,"character":3},"arguments":["mouseover"]}]}],"onMouseOut":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":190,"character":3},"arguments":["mouseout"]}]}],"addHoverEffect":[{"__symbolic":"method"}],"removeHoverEffect":[{"__symbolic":"method"}],"showButton":[{"__symbolic":"method"}],"hideButton":[{"__symbolic":"method"}],"showSpinner":[{"__symbolic":"method"}],"hideSpinner":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":2,"character":29},"arguments":["END_POINT"]}},"origins":{"FilePickerRespnse":"./lib/file-picker.response","FileUploaderModule":"./lib/file-uploader.module","FileUploaderService":"./lib/file-uploader.service","ɵa":"./lib/file-picker.directive","ɵb":"./lib/endpoint"},"importAs":"adias-file-uploader"}
{"__symbolic":"module","version":4,"metadata":{"FilePickerRespnse":{"__symbolic":"interface"},"FileUploaderModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵa"}],"imports":[],"exports":[{"__symbolic":"reference","name":"ɵa"}],"providers":[{"__symbolic":"reference","name":"FileUploaderService"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["endPoint"],"value":{"ngModule":{"__symbolic":"reference","name":"FileUploaderModule"},"providers":[{"provide":{"__symbolic":"reference","name":"ɵb"},"useValue":{"__symbolic":"reference","name":"endPoint"}}]}}}},"FileUploaderService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":10,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":13,"character":5},"arguments":[{"__symbolic":"reference","name":"ɵb"}]}],null],"parameters":[{"__symbolic":"reference","name":"string"},{"__symbolic":"reference","module":"@angular/common/http","name":"HttpClient","line":14,"character":18}]}],"upload":[{"__symbolic":"method"}],"uploadMultiple":[{"__symbolic":"method"}]}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":14,"character":1},"arguments":[{"selector":"[ngxFilePicker]"}]}],"members":{"uploadSuccess":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":18,"character":3}}]}],"uploadMultiSuccess":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":19,"character":3}}]}],"fileUrl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"transparent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"multiple":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":22,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":36,"character":19},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":37,"character":22},{"__symbolic":"reference","name":"FileUploaderService"}]}],"ngOnInit":[{"__symbolic":"method"}],"createSpinnerDiv":[{"__symbolic":"method"}],"createHoveredDiv":[{"__symbolic":"method"}],"createUploadButton":[{"__symbolic":"method"}],"createUploaderElement":[{"__symbolic":"method"}],"bindEvents":[{"__symbolic":"method"}],"upload":[{"__symbolic":"method"}],"uploadMultiple":[{"__symbolic":"method"}],"previewImage":[{"__symbolic":"method"}],"onMouseOver":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":227,"character":3},"arguments":["mouseover"]}]}],"onMouseOut":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":235,"character":3},"arguments":["mouseout"]}]}],"addHoverEffect":[{"__symbolic":"method"}],"removeHoverEffect":[{"__symbolic":"method"}],"showButton":[{"__symbolic":"method"}],"hideButton":[{"__symbolic":"method"}],"showSpinner":[{"__symbolic":"method"}],"hideSpinner":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":2,"character":29},"arguments":["END_POINT"]}},"origins":{"FilePickerRespnse":"./lib/file-picker.response","FileUploaderModule":"./lib/file-uploader.module","FileUploaderService":"./lib/file-uploader.service","ɵa":"./lib/file-picker.directive","ɵb":"./lib/endpoint"},"importAs":"adias-file-uploader"}

@@ -77,2 +77,36 @@ (function (global, factory) {

};
/**
* @param {?} files
* @return {?}
*/
FileUploaderService.prototype.uploadMultiple = /**
* @param {?} files
* @return {?}
*/
function (files) {
/** @type {?} */
var formData = new FormData();
for (var index = 0; index < files.length; index++) {
formData.append("files", files[index], files[index].name);
}
/** @type {?} */
var req = new http.HttpRequest("POST", this.endPoint, formData, {
reportProgress: true
});
return this.http.request(req).pipe(operators.map((/**
* @param {?} res
* @return {?}
*/
function (res) {
if (res.type === http.HttpEventType.Response) {
return res.body;
}
else if (res.type === http.HttpEventType.UploadProgress) {
// Compute and show the % done:
/** @type {?} */
var UploadProgress = +Math.round((100 * res.loaded) / res.total);
return UploadProgress;
}
})));
};
FileUploaderService.decorators = [

@@ -109,3 +143,6 @@ { type: core.Injectable }

this.uploadSuccess = new core.EventEmitter();
this.uploadMultiSuccess = new core.EventEmitter();
this.fileUrl = null;
this.transparent = false;
this.multiple = false;
/**

@@ -123,2 +160,3 @@ * disabled till upload

function () {
this.multiple = this.multiple === "" || this.multiple ? true : false;
this.element = this.elRef.nativeElement;

@@ -223,2 +261,6 @@ this.element.style.position = "relative";

this.input = this.renderer.createElement("input");
this.input.style.cursor = "pointer";
if (this.multiple) {
this.renderer.setProperty(this.input, "multiple", "multiple");
}
this.renderer.setProperty(this.input, "type", "file");

@@ -245,4 +287,9 @@ this.renderer.setStyle(this.input, "opacity", "0");

/** @type {?} */
var file = ((/** @type {?} */ (ev))).target.files[0];
_this.upload(file);
var files = ((/** @type {?} */ (ev))).target.files;
if (_this.multiple) {
_this.uploadMultiple(files);
}
else {
_this.upload(files[0]);
}
}));

@@ -305,2 +352,55 @@ };

/**
* @param {?} files
* @return {?}
*/
FilePickerDirective.prototype.uploadMultiple = /**
* @param {?} files
* @return {?}
*/
function (files) {
var _this = this;
this.showSpinner();
this.mouseoverDisabled = true;
this.uploaderService
.uploadMultiple(files)
.pipe(operators.map((/**
* @param {?} response
* @return {?}
*/
function (response) {
if (response && typeof response === "object") {
if (response.hasOwnProperty("result")) {
return response["result"];
}
else if (response.hasOwnProperty("data")) {
return response["data"];
}
}
return response;
})))
.subscribe({
next: (/**
* @param {?} response
* @return {?}
*/
function (response) {
if (response && typeof response === "object") {
_this.uploadMultiSuccess.emit(response);
}
}),
complete: (/**
* @return {?}
*/
function () {
setTimeout((/**
* @return {?}
*/
function () {
_this.hideSpinner();
_this.mouseoverDisabled = false;
}), 2000);
})
});
};
/**
* @param {?} fileUrl

@@ -324,3 +424,3 @@ * @return {?}

function () {
if (this.mouseoverDisabled) {
if (this.mouseoverDisabled || this.transparent === "" || this.transparent) {
return;

@@ -420,3 +520,6 @@ }

uploadSuccess: [{ type: core.Output }],
uploadMultiSuccess: [{ type: core.Output }],
fileUrl: [{ type: core.Input }],
transparent: [{ type: core.Input }],
multiple: [{ type: core.Input }],
onMouseOver: [{ type: core.HostListener, args: ["mouseover",] }],

@@ -431,4 +534,10 @@ onMouseOut: [{ type: core.HostListener, args: ["mouseout",] }]

/** @type {?} */
FilePickerDirective.prototype.uploadMultiSuccess;
/** @type {?} */
FilePickerDirective.prototype.fileUrl;
/** @type {?} */
FilePickerDirective.prototype.transparent;
/** @type {?} */
FilePickerDirective.prototype.multiple;
/** @type {?} */
FilePickerDirective.prototype.element;

@@ -435,0 +544,0 @@ /** @type {?} */

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs/operators"),require("@angular/common/http")):"function"==typeof define&&define.amd?define("adias-file-uploader",["exports","@angular/core","rxjs/operators","@angular/common/http"],t):t((e=e||self)["adias-file-uploader"]={},e.ng.core,e.rxjs.operators,e.ng.common.http)}(this,(function(e,t,r,i){"use strict";var n=new t.InjectionToken("END_POINT"),s=function(){function e(e,t){this.endPoint=e,this.http=t}return e.prototype.upload=function(e){var t=new FormData;t.append("file",e,e.name);var n=new i.HttpRequest("POST",this.endPoint,t,{reportProgress:!0});return this.http.request(n).pipe(r.map((function(e){return e.type===i.HttpEventType.Response?e.body:e.type===i.HttpEventType.UploadProgress?+Math.round(100*e.loaded/e.total):void 0})))},e.decorators=[{type:t.Injectable}],e.ctorParameters=function(){return[{type:String,decorators:[{type:t.Inject,args:[n]}]},{type:i.HttpClient}]},e}();var o=function(){function e(e,r,i){this.elRef=e,this.renderer=r,this.uploaderService=i,this.uploadSuccess=new t.EventEmitter,this.fileUrl=null,this.mouseoverDisabled=!1}return e.prototype.ngOnInit=function(){this.element=this.elRef.nativeElement,this.element.style.position="relative",this.createUploaderElement(),this.createUploadButton(),this.createHoveredDiv(),this.createSpinnerDiv(),this.fileUrl&&this.previewImage(this.fileUrl)},e.prototype.createSpinnerDiv=function(){this.spinnerDiv=this.renderer.createElement("div"),this.renderer.setStyle(this.spinnerDiv,"background-color","rgba(0,0,0,0.4)"),this.renderer.setStyle(this.spinnerDiv,"top","0"),this.renderer.setStyle(this.spinnerDiv,"left","0"),this.renderer.setStyle(this.spinnerDiv,"height","100%"),this.renderer.setStyle(this.spinnerDiv,"width","100%"),this.renderer.setStyle(this.spinnerDiv,"position","absolute"),this.renderer.setStyle(this.spinnerDiv,"overflow","auto"),this.renderer.setStyle(this.spinnerDiv,"display","none"),this.renderer.setStyle(this.spinnerDiv,"z-index","8");var e=this.renderer.createElement("img");this.renderer.setProperty(e,"src","https://flevix.com/wp-content/uploads/2019/07/Spinner-Preloader.gif"),this.renderer.setStyle(e,"height","100%"),this.renderer.setStyle(e,"width","100%"),this.renderer.setStyle(e,"object-fit","contain"),this.renderer.appendChild(this.spinnerDiv,e),this.renderer.appendChild(this.element,this.spinnerDiv)},e.prototype.createHoveredDiv=function(){this.hoverdDiv=this.renderer.createElement("div"),this.renderer.setStyle(this.hoverdDiv,"background-color","rgba(0,0,0,0.4)"),this.renderer.setStyle(this.hoverdDiv,"top","0"),this.renderer.setStyle(this.hoverdDiv,"left","0"),this.renderer.setStyle(this.hoverdDiv,"height","100%"),this.renderer.setStyle(this.hoverdDiv,"width","100%"),this.renderer.setStyle(this.hoverdDiv,"position","absolute"),this.renderer.setStyle(this.hoverdDiv,"overflow","auto"),this.renderer.setStyle(this.hoverdDiv,"display","none"),this.renderer.setStyle(this.hoverdDiv,"z-index","8"),this.renderer.appendChild(this.element,this.hoverdDiv)},e.prototype.createUploadButton=function(){var e=this;this.button=this.renderer.createElement("button"),this.renderer.setStyle(this.button,"background-color","#337ab7"),this.renderer.setStyle(this.button,"border-color","#2e6da4"),this.renderer.setStyle(this.button,"color","#ffff"),this.renderer.setStyle(this.button,"position","absolute"),this.renderer.setStyle(this.button,"top","0"),this.renderer.setStyle(this.button,"right","0"),this.renderer.setStyle(this.button,"bottom","0"),this.renderer.setStyle(this.button,"left","0"),this.renderer.setStyle(this.button,"margin","auto"),this.renderer.setStyle(this.button,"height","50px"),this.renderer.setStyle(this.button,"z-index","9"),this.renderer.setStyle(this.button,"width","120px"),this.renderer.setStyle(this.button,"font-weight","600"),this.renderer.setStyle(this.button,"font-size","16px"),this.renderer.setStyle(this.button,"display","none"),this.renderer.setProperty(this.button,"type","button");var t=this.renderer.createText("Select File");this.renderer.appendChild(this.button,t),this.renderer.appendChild(this.element,this.button),this.button.addEventListener("click",(function(){e.input.click()}))},e.prototype.createUploaderElement=function(){this.input=this.renderer.createElement("input"),this.renderer.setProperty(this.input,"type","file"),this.renderer.setStyle(this.input,"opacity","0"),this.renderer.setStyle(this.input,"height","100%"),this.renderer.setStyle(this.input,"width","100%"),this.renderer.appendChild(this.element,this.input),this.bindEvents()},e.prototype.bindEvents=function(){var e=this;this.input.addEventListener("change",(function(t){var r=t.target.files[0];e.upload(r)}))},e.prototype.upload=function(e){var t=this;this.showSpinner(),this.mouseoverDisabled=!0,this.uploaderService.upload(e).pipe(r.map((function(e){if(e&&"object"==typeof e){if(e.hasOwnProperty("result"))return e.result;if(e.hasOwnProperty("data"))return e.data}return e}))).subscribe({next:function(e){e&&"object"==typeof e&&(t.uploadSuccess.emit(e),t.previewImage(e.fileUrl))},complete:function(){setTimeout((function(){t.hideSpinner(),t.mouseoverDisabled=!1}),2e3)}})},e.prototype.previewImage=function(e){this.renderer.setStyle(this.element,"background-image","url("+e+")"),this.renderer.setStyle(this.element,"background-size","cover")},e.prototype.onMouseOver=function(){this.mouseoverDisabled||(this.addHoverEffect(),this.showButton())},e.prototype.onMouseOut=function(){this.removeHoverEffect(),this.hideButton()},e.prototype.addHoverEffect=function(){this.renderer.setStyle(this.hoverdDiv,"display","block")},e.prototype.removeHoverEffect=function(){this.renderer.setStyle(this.hoverdDiv,"display","none")},e.prototype.showButton=function(){this.renderer.setStyle(this.button,"display","block")},e.prototype.hideButton=function(){this.renderer.setStyle(this.button,"display","none")},e.prototype.showSpinner=function(){this.renderer.setStyle(this.spinnerDiv,"display","block")},e.prototype.hideSpinner=function(){this.renderer.setStyle(this.spinnerDiv,"display","none")},e.decorators=[{type:t.Directive,args:[{selector:"[ngxFilePicker]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2},{type:s}]},e.propDecorators={uploadSuccess:[{type:t.Output}],fileUrl:[{type:t.Input}],onMouseOver:[{type:t.HostListener,args:["mouseover"]}],onMouseOut:[{type:t.HostListener,args:["mouseout"]}]},e}();var h=function(){function e(){}return e.forRoot=function(t){var r=t.endPoint;return{ngModule:e,providers:[{provide:n,useValue:r}]}},e.decorators=[{type:t.NgModule,args:[{declarations:[o],imports:[],exports:[o],providers:[s]}]}],e}();e.FileUploaderModule=h,e.FileUploaderService=s,e.ɵa=o,e.ɵb=n,Object.defineProperty(e,"__esModule",{value:!0})}));
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs/operators"),require("@angular/common/http")):"function"==typeof define&&define.amd?define("adias-file-uploader",["exports","@angular/core","rxjs/operators","@angular/common/http"],t):t((e=e||self)["adias-file-uploader"]={},e.ng.core,e.rxjs.operators,e.ng.common.http)}(this,(function(e,t,r,i){"use strict";var n=new t.InjectionToken("END_POINT"),s=function(){function e(e,t){this.endPoint=e,this.http=t}return e.prototype.upload=function(e){var t=new FormData;t.append("file",e,e.name);var n=new i.HttpRequest("POST",this.endPoint,t,{reportProgress:!0});return this.http.request(n).pipe(r.map((function(e){return e.type===i.HttpEventType.Response?e.body:e.type===i.HttpEventType.UploadProgress?+Math.round(100*e.loaded/e.total):void 0})))},e.prototype.uploadMultiple=function(e){for(var t=new FormData,n=0;n<e.length;n++)t.append("files",e[n],e[n].name);var s=new i.HttpRequest("POST",this.endPoint,t,{reportProgress:!0});return this.http.request(s).pipe(r.map((function(e){return e.type===i.HttpEventType.Response?e.body:e.type===i.HttpEventType.UploadProgress?+Math.round(100*e.loaded/e.total):void 0})))},e.decorators=[{type:t.Injectable}],e.ctorParameters=function(){return[{type:String,decorators:[{type:t.Inject,args:[n]}]},{type:i.HttpClient}]},e}();var o=function(){function e(e,r,i){this.elRef=e,this.renderer=r,this.uploaderService=i,this.uploadSuccess=new t.EventEmitter,this.uploadMultiSuccess=new t.EventEmitter,this.fileUrl=null,this.transparent=!1,this.multiple=!1,this.mouseoverDisabled=!1}return e.prototype.ngOnInit=function(){this.multiple=!(""!==this.multiple&&!this.multiple),this.element=this.elRef.nativeElement,this.element.style.position="relative",this.createUploaderElement(),this.createUploadButton(),this.createHoveredDiv(),this.createSpinnerDiv(),this.fileUrl&&this.previewImage(this.fileUrl)},e.prototype.createSpinnerDiv=function(){this.spinnerDiv=this.renderer.createElement("div"),this.renderer.setStyle(this.spinnerDiv,"background-color","rgba(0,0,0,0.4)"),this.renderer.setStyle(this.spinnerDiv,"top","0"),this.renderer.setStyle(this.spinnerDiv,"left","0"),this.renderer.setStyle(this.spinnerDiv,"height","100%"),this.renderer.setStyle(this.spinnerDiv,"width","100%"),this.renderer.setStyle(this.spinnerDiv,"position","absolute"),this.renderer.setStyle(this.spinnerDiv,"overflow","auto"),this.renderer.setStyle(this.spinnerDiv,"display","none"),this.renderer.setStyle(this.spinnerDiv,"z-index","8");var e=this.renderer.createElement("img");this.renderer.setProperty(e,"src","https://flevix.com/wp-content/uploads/2019/07/Spinner-Preloader.gif"),this.renderer.setStyle(e,"height","100%"),this.renderer.setStyle(e,"width","100%"),this.renderer.setStyle(e,"object-fit","contain"),this.renderer.appendChild(this.spinnerDiv,e),this.renderer.appendChild(this.element,this.spinnerDiv)},e.prototype.createHoveredDiv=function(){this.hoverdDiv=this.renderer.createElement("div"),this.renderer.setStyle(this.hoverdDiv,"background-color","rgba(0,0,0,0.4)"),this.renderer.setStyle(this.hoverdDiv,"top","0"),this.renderer.setStyle(this.hoverdDiv,"left","0"),this.renderer.setStyle(this.hoverdDiv,"height","100%"),this.renderer.setStyle(this.hoverdDiv,"width","100%"),this.renderer.setStyle(this.hoverdDiv,"position","absolute"),this.renderer.setStyle(this.hoverdDiv,"overflow","auto"),this.renderer.setStyle(this.hoverdDiv,"display","none"),this.renderer.setStyle(this.hoverdDiv,"z-index","8"),this.renderer.appendChild(this.element,this.hoverdDiv)},e.prototype.createUploadButton=function(){var e=this;this.button=this.renderer.createElement("button"),this.renderer.setStyle(this.button,"background-color","#337ab7"),this.renderer.setStyle(this.button,"border-color","#2e6da4"),this.renderer.setStyle(this.button,"color","#ffff"),this.renderer.setStyle(this.button,"position","absolute"),this.renderer.setStyle(this.button,"top","0"),this.renderer.setStyle(this.button,"right","0"),this.renderer.setStyle(this.button,"bottom","0"),this.renderer.setStyle(this.button,"left","0"),this.renderer.setStyle(this.button,"margin","auto"),this.renderer.setStyle(this.button,"height","50px"),this.renderer.setStyle(this.button,"z-index","9"),this.renderer.setStyle(this.button,"width","120px"),this.renderer.setStyle(this.button,"font-weight","600"),this.renderer.setStyle(this.button,"font-size","16px"),this.renderer.setStyle(this.button,"display","none"),this.renderer.setProperty(this.button,"type","button");var t=this.renderer.createText("Select File");this.renderer.appendChild(this.button,t),this.renderer.appendChild(this.element,this.button),this.button.addEventListener("click",(function(){e.input.click()}))},e.prototype.createUploaderElement=function(){this.input=this.renderer.createElement("input"),this.input.style.cursor="pointer",this.multiple&&this.renderer.setProperty(this.input,"multiple","multiple"),this.renderer.setProperty(this.input,"type","file"),this.renderer.setStyle(this.input,"opacity","0"),this.renderer.setStyle(this.input,"height","100%"),this.renderer.setStyle(this.input,"width","100%"),this.renderer.appendChild(this.element,this.input),this.bindEvents()},e.prototype.bindEvents=function(){var e=this;this.input.addEventListener("change",(function(t){var r=t.target.files;e.multiple?e.uploadMultiple(r):e.upload(r[0])}))},e.prototype.upload=function(e){var t=this;this.showSpinner(),this.mouseoverDisabled=!0,this.uploaderService.upload(e).pipe(r.map((function(e){if(e&&"object"==typeof e){if(e.hasOwnProperty("result"))return e.result;if(e.hasOwnProperty("data"))return e.data}return e}))).subscribe({next:function(e){e&&"object"==typeof e&&(t.uploadSuccess.emit(e),t.previewImage(e.fileUrl))},complete:function(){setTimeout((function(){t.hideSpinner(),t.mouseoverDisabled=!1}),2e3)}})},e.prototype.uploadMultiple=function(e){var t=this;this.showSpinner(),this.mouseoverDisabled=!0,this.uploaderService.uploadMultiple(e).pipe(r.map((function(e){if(e&&"object"==typeof e){if(e.hasOwnProperty("result"))return e.result;if(e.hasOwnProperty("data"))return e.data}return e}))).subscribe({next:function(e){e&&"object"==typeof e&&t.uploadMultiSuccess.emit(e)},complete:function(){setTimeout((function(){t.hideSpinner(),t.mouseoverDisabled=!1}),2e3)}})},e.prototype.previewImage=function(e){this.renderer.setStyle(this.element,"background-image","url("+e+")"),this.renderer.setStyle(this.element,"background-size","cover")},e.prototype.onMouseOver=function(){this.mouseoverDisabled||""===this.transparent||this.transparent||(this.addHoverEffect(),this.showButton())},e.prototype.onMouseOut=function(){this.removeHoverEffect(),this.hideButton()},e.prototype.addHoverEffect=function(){this.renderer.setStyle(this.hoverdDiv,"display","block")},e.prototype.removeHoverEffect=function(){this.renderer.setStyle(this.hoverdDiv,"display","none")},e.prototype.showButton=function(){this.renderer.setStyle(this.button,"display","block")},e.prototype.hideButton=function(){this.renderer.setStyle(this.button,"display","none")},e.prototype.showSpinner=function(){this.renderer.setStyle(this.spinnerDiv,"display","block")},e.prototype.hideSpinner=function(){this.renderer.setStyle(this.spinnerDiv,"display","none")},e.decorators=[{type:t.Directive,args:[{selector:"[ngxFilePicker]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2},{type:s}]},e.propDecorators={uploadSuccess:[{type:t.Output}],uploadMultiSuccess:[{type:t.Output}],fileUrl:[{type:t.Input}],transparent:[{type:t.Input}],multiple:[{type:t.Input}],onMouseOver:[{type:t.HostListener,args:["mouseover"]}],onMouseOut:[{type:t.HostListener,args:["mouseout"]}]},e}();var p=function(){function e(){}return e.forRoot=function(t){var r=t.endPoint;return{ngModule:e,providers:[{provide:n,useValue:r}]}},e.decorators=[{type:t.NgModule,args:[{declarations:[o],imports:[],exports:[o],providers:[s]}]}],e}();e.FileUploaderModule=p,e.FileUploaderService=s,e.ɵa=o,e.ɵb=n,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=adias-file-uploader.umd.min.js.map

@@ -20,3 +20,6 @@ /**

this.uploadSuccess = new EventEmitter();
this.uploadMultiSuccess = new EventEmitter();
this.fileUrl = null;
this.transparent = false;
this.multiple = false;
/**

@@ -31,2 +34,3 @@ * disabled till upload

ngOnInit() {
this.multiple = this.multiple === "" || this.multiple ? true : false;
this.element = this.elRef.nativeElement;

@@ -118,2 +122,6 @@ this.element.style.position = "relative";

this.input = this.renderer.createElement("input");
this.input.style.cursor = "pointer";
if (this.multiple) {
this.renderer.setProperty(this.input, "multiple", "multiple");
}
this.renderer.setProperty(this.input, "type", "file");

@@ -136,4 +144,9 @@ this.renderer.setStyle(this.input, "opacity", "0");

/** @type {?} */
const file = ((/** @type {?} */ (ev))).target.files[0];
this.upload(file);
const files = ((/** @type {?} */ (ev))).target.files;
if (this.multiple) {
this.uploadMultiple(files);
}
else {
this.upload(files[0]);
}
}));

@@ -191,2 +204,50 @@ }

/**
* @param {?} files
* @return {?}
*/
uploadMultiple(files) {
this.showSpinner();
this.mouseoverDisabled = true;
this.uploaderService
.uploadMultiple(files)
.pipe(map((/**
* @param {?} response
* @return {?}
*/
(response) => {
if (response && typeof response === "object") {
if (response.hasOwnProperty("result")) {
return response["result"];
}
else if (response.hasOwnProperty("data")) {
return response["data"];
}
}
return response;
})))
.subscribe({
next: (/**
* @param {?} response
* @return {?}
*/
(response) => {
if (response && typeof response === "object") {
this.uploadMultiSuccess.emit(response);
}
}),
complete: (/**
* @return {?}
*/
() => {
setTimeout((/**
* @return {?}
*/
() => {
this.hideSpinner();
this.mouseoverDisabled = false;
}), 2000);
})
});
}
/**
* @param {?} fileUrl

@@ -203,3 +264,3 @@ * @return {?}

onMouseOver() {
if (this.mouseoverDisabled) {
if (this.mouseoverDisabled || this.transparent === "" || this.transparent) {
return;

@@ -273,3 +334,6 @@ }

uploadSuccess: [{ type: Output }],
uploadMultiSuccess: [{ type: Output }],
fileUrl: [{ type: Input }],
transparent: [{ type: Input }],
multiple: [{ type: Input }],
onMouseOver: [{ type: HostListener, args: ["mouseover",] }],

@@ -282,4 +346,10 @@ onMouseOut: [{ type: HostListener, args: ["mouseout",] }]

/** @type {?} */
FilePickerDirective.prototype.uploadMultiSuccess;
/** @type {?} */
FilePickerDirective.prototype.fileUrl;
/** @type {?} */
FilePickerDirective.prototype.transparent;
/** @type {?} */
FilePickerDirective.prototype.multiple;
/** @type {?} */
FilePickerDirective.prototype.element;

@@ -319,2 +389,2 @@ /** @type {?} */

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker.directive.js","sourceRoot":"ng://adias-file-uploader/","sources":["lib/file-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  Renderer2\n} from \"@angular/core\";\nimport { map } from \"rxjs/operators\";\nimport { FilePickerRespnse } from \"./file-picker.response\";\nimport { FileUploaderService } from \"./file-uploader.service\";\n\n@Directive({\n  selector: \"[ngxFilePicker]\"\n})\nexport class FilePickerDirective implements OnInit {\n  @Output() uploadSuccess = new EventEmitter<FilePickerRespnse>();\n  @Input() fileUrl: string = null;\n\n  element: HTMLElement;\n  hoverdDiv: HTMLElement;\n  spinnerDiv: HTMLElement;\n  input: HTMLElement;\n  button: HTMLElement;\n  image: HTMLElement;\n  uploadedFiles: Array<File>;\n\n  /** disabled till upload */\n  mouseoverDisabled = false;\n\n  constructor(\n    private elRef: ElementRef,\n    private renderer: Renderer2,\n    private uploaderService: FileUploaderService\n  ) {}\n\n  ngOnInit() {\n    this.element = this.elRef.nativeElement;\n    this.element.style.position = \"relative\";\n    this.createUploaderElement();\n    this.createUploadButton();\n    this.createHoveredDiv();\n    this.createSpinnerDiv();\n\n    if (this.fileUrl) {\n      this.previewImage(this.fileUrl);\n    }\n  }\n\n  createSpinnerDiv() {\n    this.spinnerDiv = this.renderer.createElement(\"div\");\n    this.renderer.setStyle(\n      this.spinnerDiv,\n      \"background-color\",\n      \"rgba(0,0,0,0.4)\"\n    );\n    this.renderer.setStyle(this.spinnerDiv, \"top\", \"0\");\n    this.renderer.setStyle(this.spinnerDiv, \"left\", \"0\");\n    this.renderer.setStyle(this.spinnerDiv, \"height\", \"100%\");\n    this.renderer.setStyle(this.spinnerDiv, \"width\", \"100%\");\n    this.renderer.setStyle(this.spinnerDiv, \"position\", \"absolute\");\n    this.renderer.setStyle(this.spinnerDiv, \"overflow\", \"auto\");\n    this.renderer.setStyle(this.spinnerDiv, \"display\", \"none\");\n    this.renderer.setStyle(this.spinnerDiv, \"z-index\", \"8\");\n\n    const image = this.renderer.createElement(\"img\");\n\n    this.renderer.setProperty(\n      image,\n      \"src\",\n      `https://flevix.com/wp-content/uploads/2019/07/Spinner-Preloader.gif`\n    );\n\n    this.renderer.setStyle(image, \"height\", `100%`);\n    this.renderer.setStyle(image, \"width\", `100%`);\n    this.renderer.setStyle(image, \"object-fit\", `contain`);\n    this.renderer.appendChild(this.spinnerDiv, image);\n    this.renderer.appendChild(this.element, this.spinnerDiv);\n  }\n\n  createHoveredDiv() {\n    this.hoverdDiv = this.renderer.createElement(\"div\");\n    this.renderer.setStyle(\n      this.hoverdDiv,\n      \"background-color\",\n      \"rgba(0,0,0,0.4)\"\n    );\n    this.renderer.setStyle(this.hoverdDiv, \"top\", \"0\");\n    this.renderer.setStyle(this.hoverdDiv, \"left\", \"0\");\n    this.renderer.setStyle(this.hoverdDiv, \"height\", \"100%\");\n    this.renderer.setStyle(this.hoverdDiv, \"width\", \"100%\");\n    this.renderer.setStyle(this.hoverdDiv, \"position\", \"absolute\");\n    this.renderer.setStyle(this.hoverdDiv, \"overflow\", \"auto\");\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"none\");\n    this.renderer.setStyle(this.hoverdDiv, \"z-index\", \"8\");\n    this.renderer.appendChild(this.element, this.hoverdDiv);\n  }\n\n  createUploadButton() {\n    this.button = this.renderer.createElement(\"button\");\n    this.renderer.setStyle(this.button, \"background-color\", \"#337ab7\");\n    this.renderer.setStyle(this.button, \"border-color\", \"#2e6da4\");\n    this.renderer.setStyle(this.button, \"color\", \"#ffff\");\n    this.renderer.setStyle(this.button, \"position\", \"absolute\");\n    this.renderer.setStyle(this.button, \"top\", \"0\");\n    this.renderer.setStyle(this.button, \"right\", \"0\");\n    this.renderer.setStyle(this.button, \"bottom\", \"0\");\n    this.renderer.setStyle(this.button, \"left\", \"0\");\n    this.renderer.setStyle(this.button, \"margin\", \"auto\");\n    this.renderer.setStyle(this.button, \"height\", \"50px\");\n    this.renderer.setStyle(this.button, \"z-index\", \"9\");\n    this.renderer.setStyle(this.button, \"width\", \"120px\");\n    this.renderer.setStyle(this.button, \"font-weight\", \"600\");\n    this.renderer.setStyle(this.button, \"font-size\", \"16px\");\n    this.renderer.setStyle(this.button, \"display\", \"none\");\n    this.renderer.setProperty(this.button, \"type\", \"button\");\n    const buttontext = this.renderer.createText(\"Select File\");\n    this.renderer.appendChild(this.button, buttontext);\n    this.renderer.appendChild(this.element, this.button);\n    this.button.addEventListener(\"click\", () => {\n      this.input.click();\n    });\n  }\n\n  createUploaderElement() {\n    this.input = this.renderer.createElement(\"input\");\n    this.renderer.setProperty(this.input, \"type\", \"file\");\n    this.renderer.setStyle(this.input, \"opacity\", \"0\");\n    this.renderer.setStyle(this.input, \"height\", \"100%\");\n    this.renderer.setStyle(this.input, \"width\", \"100%\");\n    this.renderer.appendChild(this.element, this.input);\n    this.bindEvents();\n  }\n\n  bindEvents() {\n    this.input.addEventListener(\"change\", ev => {\n      const file = (ev as any).target.files[0];\n      this.upload(file);\n    });\n  }\n\n  upload(file: File) {\n    this.showSpinner();\n    this.mouseoverDisabled = true;\n    this.uploaderService\n      .upload(file)\n      .pipe(\n        map((response: any) => {\n          if (response && typeof response === \"object\") {\n            if (response.hasOwnProperty(\"result\")) {\n              return response[\"result\"];\n            } else if (response.hasOwnProperty(\"data\")) {\n              return response[\"data\"];\n            }\n          }\n\n          return response;\n        })\n      )\n      .subscribe({\n        next: (response: FilePickerRespnse) => {\n          if (response && typeof response === \"object\") {\n            this.uploadSuccess.emit(response);\n            this.previewImage(response.fileUrl);\n          }\n        },\n        complete: () => {\n          setTimeout(() => {\n            this.hideSpinner();\n            this.mouseoverDisabled = false;\n          }, 2000);\n        }\n      });\n  }\n\n  previewImage(fileUrl: string) {\n    this.renderer.setStyle(this.element, \"background-image\", `url(${fileUrl})`);\n    this.renderer.setStyle(this.element, \"background-size\", `cover`);\n  }\n\n  @HostListener(\"mouseover\") onMouseOver() {\n    if (this.mouseoverDisabled) {\n      return;\n    }\n    this.addHoverEffect();\n    this.showButton();\n  }\n\n  @HostListener(\"mouseout\") onMouseOut() {\n    this.removeHoverEffect();\n    this.hideButton();\n  }\n\n  private addHoverEffect() {\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"block\");\n  }\n\n  private removeHoverEffect() {\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"none\");\n  }\n\n  private showButton() {\n    this.renderer.setStyle(this.button, \"display\", `block`);\n  }\n\n  private hideButton() {\n    this.renderer.setStyle(this.button, \"display\", `none`);\n  }\n\n  private showSpinner() {\n    this.renderer.setStyle(this.spinnerDiv, \"display\", `block`);\n  }\n\n  private hideSpinner() {\n    this.renderer.setStyle(this.spinnerDiv, \"display\", `none`);\n  }\n}\n// TODO hover karne p upload button ayega uslp click krne p uploa dnput khileha\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker.directive.js","sourceRoot":"ng://adias-file-uploader/","sources":["lib/file-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  Renderer2\n} from \"@angular/core\";\nimport { map } from \"rxjs/operators\";\nimport { FilePickerRespnse } from \"./file-picker.response\";\nimport { FileUploaderService } from \"./file-uploader.service\";\n\n@Directive({\n  selector: \"[ngxFilePicker]\"\n})\nexport class FilePickerDirective implements OnInit {\n  @Output() uploadSuccess = new EventEmitter<FilePickerRespnse>();\n  @Output() uploadMultiSuccess = new EventEmitter<FilePickerRespnse[]>();\n  @Input() fileUrl: string = null;\n  @Input() transparent: boolean | string = false;\n  @Input() multiple: boolean | string = false;\n\n  element: HTMLElement;\n  hoverdDiv: HTMLElement;\n  spinnerDiv: HTMLElement;\n  input: HTMLElement;\n  button: HTMLElement;\n  image: HTMLElement;\n  uploadedFiles: Array<File>;\n\n  /** disabled till upload */\n  mouseoverDisabled = false;\n\n  constructor(\n    private elRef: ElementRef,\n    private renderer: Renderer2,\n    private uploaderService: FileUploaderService\n  ) {}\n\n  ngOnInit() {\n    this.multiple = this.multiple === \"\" || this.multiple ? true : false;\n    this.element = this.elRef.nativeElement;\n    this.element.style.position = \"relative\";\n    this.createUploaderElement();\n    this.createUploadButton();\n    this.createHoveredDiv();\n    this.createSpinnerDiv();\n\n    if (this.fileUrl) {\n      this.previewImage(this.fileUrl);\n    }\n  }\n\n  createSpinnerDiv() {\n    this.spinnerDiv = this.renderer.createElement(\"div\");\n    this.renderer.setStyle(\n      this.spinnerDiv,\n      \"background-color\",\n      \"rgba(0,0,0,0.4)\"\n    );\n    this.renderer.setStyle(this.spinnerDiv, \"top\", \"0\");\n    this.renderer.setStyle(this.spinnerDiv, \"left\", \"0\");\n    this.renderer.setStyle(this.spinnerDiv, \"height\", \"100%\");\n    this.renderer.setStyle(this.spinnerDiv, \"width\", \"100%\");\n    this.renderer.setStyle(this.spinnerDiv, \"position\", \"absolute\");\n    this.renderer.setStyle(this.spinnerDiv, \"overflow\", \"auto\");\n    this.renderer.setStyle(this.spinnerDiv, \"display\", \"none\");\n    this.renderer.setStyle(this.spinnerDiv, \"z-index\", \"8\");\n\n    const image = this.renderer.createElement(\"img\");\n\n    this.renderer.setProperty(\n      image,\n      \"src\",\n      `https://flevix.com/wp-content/uploads/2019/07/Spinner-Preloader.gif`\n    );\n\n    this.renderer.setStyle(image, \"height\", `100%`);\n    this.renderer.setStyle(image, \"width\", `100%`);\n    this.renderer.setStyle(image, \"object-fit\", `contain`);\n    this.renderer.appendChild(this.spinnerDiv, image);\n    this.renderer.appendChild(this.element, this.spinnerDiv);\n  }\n\n  createHoveredDiv() {\n    this.hoverdDiv = this.renderer.createElement(\"div\");\n    this.renderer.setStyle(\n      this.hoverdDiv,\n      \"background-color\",\n      \"rgba(0,0,0,0.4)\"\n    );\n    this.renderer.setStyle(this.hoverdDiv, \"top\", \"0\");\n    this.renderer.setStyle(this.hoverdDiv, \"left\", \"0\");\n    this.renderer.setStyle(this.hoverdDiv, \"height\", \"100%\");\n    this.renderer.setStyle(this.hoverdDiv, \"width\", \"100%\");\n    this.renderer.setStyle(this.hoverdDiv, \"position\", \"absolute\");\n    this.renderer.setStyle(this.hoverdDiv, \"overflow\", \"auto\");\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"none\");\n    this.renderer.setStyle(this.hoverdDiv, \"z-index\", \"8\");\n    this.renderer.appendChild(this.element, this.hoverdDiv);\n  }\n\n  createUploadButton() {\n    this.button = this.renderer.createElement(\"button\");\n    this.renderer.setStyle(this.button, \"background-color\", \"#337ab7\");\n    this.renderer.setStyle(this.button, \"border-color\", \"#2e6da4\");\n    this.renderer.setStyle(this.button, \"color\", \"#ffff\");\n    this.renderer.setStyle(this.button, \"position\", \"absolute\");\n    this.renderer.setStyle(this.button, \"top\", \"0\");\n    this.renderer.setStyle(this.button, \"right\", \"0\");\n    this.renderer.setStyle(this.button, \"bottom\", \"0\");\n    this.renderer.setStyle(this.button, \"left\", \"0\");\n    this.renderer.setStyle(this.button, \"margin\", \"auto\");\n    this.renderer.setStyle(this.button, \"height\", \"50px\");\n    this.renderer.setStyle(this.button, \"z-index\", \"9\");\n    this.renderer.setStyle(this.button, \"width\", \"120px\");\n    this.renderer.setStyle(this.button, \"font-weight\", \"600\");\n    this.renderer.setStyle(this.button, \"font-size\", \"16px\");\n    this.renderer.setStyle(this.button, \"display\", \"none\");\n    this.renderer.setProperty(this.button, \"type\", \"button\");\n    const buttontext = this.renderer.createText(\"Select File\");\n    this.renderer.appendChild(this.button, buttontext);\n    this.renderer.appendChild(this.element, this.button);\n    this.button.addEventListener(\"click\", () => {\n      this.input.click();\n    });\n  }\n\n  createUploaderElement() {\n    this.input = this.renderer.createElement(\"input\");\n    this.input.style.cursor = \"pointer\";\n    if (this.multiple) {\n      this.renderer.setProperty(this.input, \"multiple\", \"multiple\");\n    }\n    this.renderer.setProperty(this.input, \"type\", \"file\");\n    this.renderer.setStyle(this.input, \"opacity\", \"0\");\n    this.renderer.setStyle(this.input, \"height\", \"100%\");\n    this.renderer.setStyle(this.input, \"width\", \"100%\");\n    this.renderer.appendChild(this.element, this.input);\n    this.bindEvents();\n  }\n\n  bindEvents() {\n    this.input.addEventListener(\"change\", ev => {\n      const files = (ev as any).target.files;\n      if (this.multiple) {\n        this.uploadMultiple(files);\n      } else {\n        this.upload(files[0]);\n      }\n    });\n  }\n\n  upload(file: File) {\n    this.showSpinner();\n    this.mouseoverDisabled = true;\n    this.uploaderService\n      .upload(file)\n      .pipe(\n        map((response: any) => {\n          if (response && typeof response === \"object\") {\n            if (response.hasOwnProperty(\"result\")) {\n              return response[\"result\"];\n            } else if (response.hasOwnProperty(\"data\")) {\n              return response[\"data\"];\n            }\n          }\n\n          return response;\n        })\n      )\n      .subscribe({\n        next: (response: FilePickerRespnse) => {\n          if (response && typeof response === \"object\") {\n            this.uploadSuccess.emit(response);\n            this.previewImage(response.fileUrl);\n          }\n        },\n        complete: () => {\n          setTimeout(() => {\n            this.hideSpinner();\n            this.mouseoverDisabled = false;\n          }, 2000);\n        }\n      });\n  }\n\n  uploadMultiple(files: File[]) {\n    this.showSpinner();\n    this.mouseoverDisabled = true;\n    this.uploaderService\n      .uploadMultiple(files)\n      .pipe(\n        map((response: any) => {\n          if (response && typeof response === \"object\") {\n            if (response.hasOwnProperty(\"result\")) {\n              return response[\"result\"];\n            } else if (response.hasOwnProperty(\"data\")) {\n              return response[\"data\"];\n            }\n          }\n\n          return response;\n        })\n      )\n      .subscribe({\n        next: (response: FilePickerRespnse[]) => {\n          if (response && typeof response === \"object\") {\n            this.uploadMultiSuccess.emit(response);\n          }\n        },\n        complete: () => {\n          setTimeout(() => {\n            this.hideSpinner();\n            this.mouseoverDisabled = false;\n          }, 2000);\n        }\n      });\n  }\n\n  previewImage(fileUrl: string) {\n    this.renderer.setStyle(this.element, \"background-image\", `url(${fileUrl})`);\n    this.renderer.setStyle(this.element, \"background-size\", `cover`);\n  }\n\n  @HostListener(\"mouseover\") onMouseOver() {\n    if (this.mouseoverDisabled || this.transparent === \"\" || this.transparent) {\n      return;\n    }\n    this.addHoverEffect();\n    this.showButton();\n  }\n\n  @HostListener(\"mouseout\") onMouseOut() {\n    this.removeHoverEffect();\n    this.hideButton();\n  }\n\n  private addHoverEffect() {\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"block\");\n  }\n\n  private removeHoverEffect() {\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"none\");\n  }\n\n  private showButton() {\n    this.renderer.setStyle(this.button, \"display\", `block`);\n  }\n\n  private hideButton() {\n    this.renderer.setStyle(this.button, \"display\", `none`);\n  }\n\n  private showSpinner() {\n    this.renderer.setStyle(this.spinnerDiv, \"display\", `block`);\n  }\n\n  private hideSpinner() {\n    this.renderer.setStyle(this.spinnerDiv, \"display\", `none`);\n  }\n}\n// TODO hover karne p upload button ayega uslp click krne p uploa dnput khileha\n"]}

@@ -47,2 +47,32 @@ /**

}
/**
* @param {?} files
* @return {?}
*/
uploadMultiple(files) {
/** @type {?} */
let formData = new FormData();
for (let index = 0; index < files.length; index++) {
formData.append("files", files[index], files[index].name);
}
/** @type {?} */
const req = new HttpRequest("POST", this.endPoint, formData, {
reportProgress: true
});
return this.http.request(req).pipe(map((/**
* @param {?} res
* @return {?}
*/
(res) => {
if (res.type === HttpEventType.Response) {
return res.body;
}
else if (res.type === HttpEventType.UploadProgress) {
// Compute and show the % done:
/** @type {?} */
const UploadProgress = +Math.round((100 * res.loaded) / res.total);
return UploadProgress;
}
})));
}
}

@@ -66,2 +96,2 @@ FileUploaderService.decorators = [

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYWRpYXMtZmlsZS11cGxvYWRlci8iLCJzb3VyY2VzIjpbImxpYi9maWxlLXVwbG9hZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxPQUFPLEVBQ0wsVUFBVSxFQUVWLGFBQWEsRUFDYixXQUFXLEVBQ1osTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUd2QyxNQUFNLE9BQU8sbUJBQW1COzs7OztJQUM5QixZQUM0QixRQUFnQixFQUNsQyxJQUFnQjtRQURFLGFBQVEsR0FBUixRQUFRLENBQVE7UUFDbEMsU0FBSSxHQUFKLElBQUksQ0FBWTtJQUN2QixDQUFDOzs7OztJQUVKLE1BQU0sQ0FBQyxRQUFjOztZQUNmLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRTtRQUM3QixRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDOztjQUUzQyxHQUFHLEdBQUcsSUFBSSxXQUFXLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFO1lBQzNELGNBQWMsRUFBRSxJQUFJO1NBQ3JCLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FDaEMsR0FBRzs7OztRQUFDLENBQUMsR0FBbUIsRUFBRSxFQUFFO1lBQzFCLElBQUksR0FBRyxDQUFDLElBQUksS0FBSyxhQUFhLENBQUMsUUFBUSxFQUFFO2dCQUN2QyxPQUFPLEdBQUcsQ0FBQyxJQUFJLENBQUM7YUFDakI7aUJBQU0sSUFBSSxHQUFHLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxjQUFjLEVBQUU7OztzQkFFOUMsY0FBYyxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQztnQkFDbEUsT0FBTyxjQUFjLENBQUM7YUFDdkI7UUFDSCxDQUFDLEVBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQzs7O1lBekJGLFVBQVU7Ozs7eUNBR04sTUFBTSxTQUFDLFNBQVM7WUFabkIsVUFBVTs7OztJQVlSLHVDQUEwQzs7Ozs7SUFDMUMsbUNBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgSHR0cENsaWVudCxcbiAgSHR0cEV2ZW50LFxuICBIdHRwRXZlbnRUeXBlLFxuICBIdHRwUmVxdWVzdFxufSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uL2h0dHBcIjtcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBtYXAgfSBmcm9tIFwicnhqcy9vcGVyYXRvcnNcIjtcbmltcG9ydCB7IEVORF9QT0lOVCB9IGZyb20gXCIuL2VuZHBvaW50XCI7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBGaWxlVXBsb2FkZXJTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChFTkRfUE9JTlQpIHB1YmxpYyBlbmRQb2ludDogc3RyaW5nLFxuICAgIHByaXZhdGUgaHR0cDogSHR0cENsaWVudFxuICApIHt9XG5cbiAgdXBsb2FkKGZpbGVJdGVtOiBGaWxlKSB7XG4gICAgbGV0IGZvcm1EYXRhID0gbmV3IEZvcm1EYXRhKCk7XG4gICAgZm9ybURhdGEuYXBwZW5kKFwiZmlsZVwiLCBmaWxlSXRlbSwgZmlsZUl0ZW0ubmFtZSk7XG5cbiAgICBjb25zdCByZXEgPSBuZXcgSHR0cFJlcXVlc3QoXCJQT1NUXCIsIHRoaXMuZW5kUG9pbnQsIGZvcm1EYXRhLCB7XG4gICAgICByZXBvcnRQcm9ncmVzczogdHJ1ZVxuICAgIH0pO1xuICAgIHJldHVybiB0aGlzLmh0dHAucmVxdWVzdChyZXEpLnBpcGUoXG4gICAgICBtYXAoKHJlczogSHR0cEV2ZW50PGFueT4pID0+IHtcbiAgICAgICAgaWYgKHJlcy50eXBlID09PSBIdHRwRXZlbnRUeXBlLlJlc3BvbnNlKSB7XG4gICAgICAgICAgcmV0dXJuIHJlcy5ib2R5O1xuICAgICAgICB9IGVsc2UgaWYgKHJlcy50eXBlID09PSBIdHRwRXZlbnRUeXBlLlVwbG9hZFByb2dyZXNzKSB7XG4gICAgICAgICAgLy8gQ29tcHV0ZSBhbmQgc2hvdyB0aGUgJSBkb25lOlxuICAgICAgICAgIGNvbnN0IFVwbG9hZFByb2dyZXNzID0gK01hdGgucm91bmQoKDEwMCAqIHJlcy5sb2FkZWQpIC8gcmVzLnRvdGFsKTtcbiAgICAgICAgICByZXR1cm4gVXBsb2FkUHJvZ3Jlc3M7XG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgKTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYWRpYXMtZmlsZS11cGxvYWRlci8iLCJzb3VyY2VzIjpbImxpYi9maWxlLXVwbG9hZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxPQUFPLEVBQ0wsVUFBVSxFQUVWLGFBQWEsRUFDYixXQUFXLEVBQ1osTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUd2QyxNQUFNLE9BQU8sbUJBQW1COzs7OztJQUM5QixZQUM0QixRQUFnQixFQUNsQyxJQUFnQjtRQURFLGFBQVEsR0FBUixRQUFRLENBQVE7UUFDbEMsU0FBSSxHQUFKLElBQUksQ0FBWTtJQUN2QixDQUFDOzs7OztJQUVKLE1BQU0sQ0FBQyxRQUFjOztZQUNmLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRTtRQUU3QixRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDOztjQUUzQyxHQUFHLEdBQUcsSUFBSSxXQUFXLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFO1lBQzNELGNBQWMsRUFBRSxJQUFJO1NBQ3JCLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FDaEMsR0FBRzs7OztRQUFDLENBQUMsR0FBbUIsRUFBRSxFQUFFO1lBQzFCLElBQUksR0FBRyxDQUFDLElBQUksS0FBSyxhQUFhLENBQUMsUUFBUSxFQUFFO2dCQUN2QyxPQUFPLEdBQUcsQ0FBQyxJQUFJLENBQUM7YUFDakI7aUJBQU0sSUFBSSxHQUFHLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxjQUFjLEVBQUU7OztzQkFFOUMsY0FBYyxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQztnQkFDbEUsT0FBTyxjQUFjLENBQUM7YUFDdkI7UUFDSCxDQUFDLEVBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQzs7Ozs7SUFFRCxjQUFjLENBQUMsS0FBYTs7WUFDdEIsUUFBUSxHQUFHLElBQUksUUFBUSxFQUFFO1FBRTdCLEtBQUssSUFBSSxLQUFLLEdBQUcsQ0FBQyxFQUFFLEtBQUssR0FBRyxLQUFLLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxFQUFFO1lBQ2pELFFBQVEsQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDM0Q7O2NBRUssR0FBRyxHQUFHLElBQUksV0FBVyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLFFBQVEsRUFBRTtZQUMzRCxjQUFjLEVBQUUsSUFBSTtTQUNyQixDQUFDO1FBQ0YsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQ2hDLEdBQUc7Ozs7UUFBQyxDQUFDLEdBQW1CLEVBQUUsRUFBRTtZQUMxQixJQUFJLEdBQUcsQ0FBQyxJQUFJLEtBQUssYUFBYSxDQUFDLFFBQVEsRUFBRTtnQkFDdkMsT0FBTyxHQUFHLENBQUMsSUFBSSxDQUFDO2FBQ2pCO2lCQUFNLElBQUksR0FBRyxDQUFDLElBQUksS0FBSyxhQUFhLENBQUMsY0FBYyxFQUFFOzs7c0JBRTlDLGNBQWMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUM7Z0JBQ2xFLE9BQU8sY0FBYyxDQUFDO2FBQ3ZCO1FBQ0gsQ0FBQyxFQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7OztZQWpERixVQUFVOzs7O3lDQUdOLE1BQU0sU0FBQyxTQUFTO1lBWm5CLFVBQVU7Ozs7SUFZUix1Q0FBMEM7Ozs7O0lBQzFDLG1DQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEh0dHBDbGllbnQsXG4gIEh0dHBFdmVudCxcbiAgSHR0cEV2ZW50VHlwZSxcbiAgSHR0cFJlcXVlc3Rcbn0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XG5pbXBvcnQgeyBFTkRfUE9JTlQgfSBmcm9tIFwiLi9lbmRwb2ludFwiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZGVyU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoRU5EX1BPSU5UKSBwdWJsaWMgZW5kUG9pbnQ6IHN0cmluZyxcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnRcbiAgKSB7fVxuXG4gIHVwbG9hZChmaWxlSXRlbTogRmlsZSkge1xuICAgIGxldCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xuXG4gICAgZm9ybURhdGEuYXBwZW5kKFwiZmlsZVwiLCBmaWxlSXRlbSwgZmlsZUl0ZW0ubmFtZSk7XG5cbiAgICBjb25zdCByZXEgPSBuZXcgSHR0cFJlcXVlc3QoXCJQT1NUXCIsIHRoaXMuZW5kUG9pbnQsIGZvcm1EYXRhLCB7XG4gICAgICByZXBvcnRQcm9ncmVzczogdHJ1ZVxuICAgIH0pO1xuICAgIHJldHVybiB0aGlzLmh0dHAucmVxdWVzdChyZXEpLnBpcGUoXG4gICAgICBtYXAoKHJlczogSHR0cEV2ZW50PGFueT4pID0+IHtcbiAgICAgICAgaWYgKHJlcy50eXBlID09PSBIdHRwRXZlbnRUeXBlLlJlc3BvbnNlKSB7XG4gICAgICAgICAgcmV0dXJuIHJlcy5ib2R5O1xuICAgICAgICB9IGVsc2UgaWYgKHJlcy50eXBlID09PSBIdHRwRXZlbnRUeXBlLlVwbG9hZFByb2dyZXNzKSB7XG4gICAgICAgICAgLy8gQ29tcHV0ZSBhbmQgc2hvdyB0aGUgJSBkb25lOlxuICAgICAgICAgIGNvbnN0IFVwbG9hZFByb2dyZXNzID0gK01hdGgucm91bmQoKDEwMCAqIHJlcy5sb2FkZWQpIC8gcmVzLnRvdGFsKTtcbiAgICAgICAgICByZXR1cm4gVXBsb2FkUHJvZ3Jlc3M7XG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIHVwbG9hZE11bHRpcGxlKGZpbGVzOiBGaWxlW10pIHtcbiAgICBsZXQgZm9ybURhdGEgPSBuZXcgRm9ybURhdGEoKTtcblxuICAgIGZvciAobGV0IGluZGV4ID0gMDsgaW5kZXggPCBmaWxlcy5sZW5ndGg7IGluZGV4KyspIHtcbiAgICAgIGZvcm1EYXRhLmFwcGVuZChcImZpbGVzXCIsIGZpbGVzW2luZGV4XSwgZmlsZXNbaW5kZXhdLm5hbWUpO1xuICAgIH1cblxuICAgIGNvbnN0IHJlcSA9IG5ldyBIdHRwUmVxdWVzdChcIlBPU1RcIiwgdGhpcy5lbmRQb2ludCwgZm9ybURhdGEsIHtcbiAgICAgIHJlcG9ydFByb2dyZXNzOiB0cnVlXG4gICAgfSk7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5yZXF1ZXN0KHJlcSkucGlwZShcbiAgICAgIG1hcCgocmVzOiBIdHRwRXZlbnQ8YW55PikgPT4ge1xuICAgICAgICBpZiAocmVzLnR5cGUgPT09IEh0dHBFdmVudFR5cGUuUmVzcG9uc2UpIHtcbiAgICAgICAgICByZXR1cm4gcmVzLmJvZHk7XG4gICAgICAgIH0gZWxzZSBpZiAocmVzLnR5cGUgPT09IEh0dHBFdmVudFR5cGUuVXBsb2FkUHJvZ3Jlc3MpIHtcbiAgICAgICAgICAvLyBDb21wdXRlIGFuZCBzaG93IHRoZSAlIGRvbmU6XG4gICAgICAgICAgY29uc3QgVXBsb2FkUHJvZ3Jlc3MgPSArTWF0aC5yb3VuZCgoMTAwICogcmVzLmxvYWRlZCkgLyByZXMudG90YWwpO1xuICAgICAgICAgIHJldHVybiBVcGxvYWRQcm9ncmVzcztcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICApO1xuICB9XG59XG4iXX0=

@@ -15,3 +15,6 @@ /**

this.uploadSuccess = new EventEmitter();
this.uploadMultiSuccess = new EventEmitter();
this.fileUrl = null;
this.transparent = false;
this.multiple = false;
/**

@@ -29,2 +32,3 @@ * disabled till upload

function () {
this.multiple = this.multiple === "" || this.multiple ? true : false;
this.element = this.elRef.nativeElement;

@@ -129,2 +133,6 @@ this.element.style.position = "relative";

this.input = this.renderer.createElement("input");
this.input.style.cursor = "pointer";
if (this.multiple) {
this.renderer.setProperty(this.input, "multiple", "multiple");
}
this.renderer.setProperty(this.input, "type", "file");

@@ -151,4 +159,9 @@ this.renderer.setStyle(this.input, "opacity", "0");

/** @type {?} */
var file = ((/** @type {?} */ (ev))).target.files[0];
_this.upload(file);
var files = ((/** @type {?} */ (ev))).target.files;
if (_this.multiple) {
_this.uploadMultiple(files);
}
else {
_this.upload(files[0]);
}
}));

@@ -211,2 +224,55 @@ };

/**
* @param {?} files
* @return {?}
*/
FilePickerDirective.prototype.uploadMultiple = /**
* @param {?} files
* @return {?}
*/
function (files) {
var _this = this;
this.showSpinner();
this.mouseoverDisabled = true;
this.uploaderService
.uploadMultiple(files)
.pipe(map((/**
* @param {?} response
* @return {?}
*/
function (response) {
if (response && typeof response === "object") {
if (response.hasOwnProperty("result")) {
return response["result"];
}
else if (response.hasOwnProperty("data")) {
return response["data"];
}
}
return response;
})))
.subscribe({
next: (/**
* @param {?} response
* @return {?}
*/
function (response) {
if (response && typeof response === "object") {
_this.uploadMultiSuccess.emit(response);
}
}),
complete: (/**
* @return {?}
*/
function () {
setTimeout((/**
* @return {?}
*/
function () {
_this.hideSpinner();
_this.mouseoverDisabled = false;
}), 2000);
})
});
};
/**
* @param {?} fileUrl

@@ -230,3 +296,3 @@ * @return {?}

function () {
if (this.mouseoverDisabled) {
if (this.mouseoverDisabled || this.transparent === "" || this.transparent) {
return;

@@ -326,3 +392,6 @@ }

uploadSuccess: [{ type: Output }],
uploadMultiSuccess: [{ type: Output }],
fileUrl: [{ type: Input }],
transparent: [{ type: Input }],
multiple: [{ type: Input }],
onMouseOver: [{ type: HostListener, args: ["mouseover",] }],

@@ -338,4 +407,10 @@ onMouseOut: [{ type: HostListener, args: ["mouseout",] }]

/** @type {?} */
FilePickerDirective.prototype.uploadMultiSuccess;
/** @type {?} */
FilePickerDirective.prototype.fileUrl;
/** @type {?} */
FilePickerDirective.prototype.transparent;
/** @type {?} */
FilePickerDirective.prototype.multiple;
/** @type {?} */
FilePickerDirective.prototype.element;

@@ -375,2 +450,2 @@ /** @type {?} */

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker.directive.js","sourceRoot":"ng://adias-file-uploader/","sources":["lib/file-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  Renderer2\n} from \"@angular/core\";\nimport { map } from \"rxjs/operators\";\nimport { FilePickerRespnse } from \"./file-picker.response\";\nimport { FileUploaderService } from \"./file-uploader.service\";\n\n@Directive({\n  selector: \"[ngxFilePicker]\"\n})\nexport class FilePickerDirective implements OnInit {\n  @Output() uploadSuccess = new EventEmitter<FilePickerRespnse>();\n  @Input() fileUrl: string = null;\n\n  element: HTMLElement;\n  hoverdDiv: HTMLElement;\n  spinnerDiv: HTMLElement;\n  input: HTMLElement;\n  button: HTMLElement;\n  image: HTMLElement;\n  uploadedFiles: Array<File>;\n\n  /** disabled till upload */\n  mouseoverDisabled = false;\n\n  constructor(\n    private elRef: ElementRef,\n    private renderer: Renderer2,\n    private uploaderService: FileUploaderService\n  ) {}\n\n  ngOnInit() {\n    this.element = this.elRef.nativeElement;\n    this.element.style.position = \"relative\";\n    this.createUploaderElement();\n    this.createUploadButton();\n    this.createHoveredDiv();\n    this.createSpinnerDiv();\n\n    if (this.fileUrl) {\n      this.previewImage(this.fileUrl);\n    }\n  }\n\n  createSpinnerDiv() {\n    this.spinnerDiv = this.renderer.createElement(\"div\");\n    this.renderer.setStyle(\n      this.spinnerDiv,\n      \"background-color\",\n      \"rgba(0,0,0,0.4)\"\n    );\n    this.renderer.setStyle(this.spinnerDiv, \"top\", \"0\");\n    this.renderer.setStyle(this.spinnerDiv, \"left\", \"0\");\n    this.renderer.setStyle(this.spinnerDiv, \"height\", \"100%\");\n    this.renderer.setStyle(this.spinnerDiv, \"width\", \"100%\");\n    this.renderer.setStyle(this.spinnerDiv, \"position\", \"absolute\");\n    this.renderer.setStyle(this.spinnerDiv, \"overflow\", \"auto\");\n    this.renderer.setStyle(this.spinnerDiv, \"display\", \"none\");\n    this.renderer.setStyle(this.spinnerDiv, \"z-index\", \"8\");\n\n    const image = this.renderer.createElement(\"img\");\n\n    this.renderer.setProperty(\n      image,\n      \"src\",\n      `https://flevix.com/wp-content/uploads/2019/07/Spinner-Preloader.gif`\n    );\n\n    this.renderer.setStyle(image, \"height\", `100%`);\n    this.renderer.setStyle(image, \"width\", `100%`);\n    this.renderer.setStyle(image, \"object-fit\", `contain`);\n    this.renderer.appendChild(this.spinnerDiv, image);\n    this.renderer.appendChild(this.element, this.spinnerDiv);\n  }\n\n  createHoveredDiv() {\n    this.hoverdDiv = this.renderer.createElement(\"div\");\n    this.renderer.setStyle(\n      this.hoverdDiv,\n      \"background-color\",\n      \"rgba(0,0,0,0.4)\"\n    );\n    this.renderer.setStyle(this.hoverdDiv, \"top\", \"0\");\n    this.renderer.setStyle(this.hoverdDiv, \"left\", \"0\");\n    this.renderer.setStyle(this.hoverdDiv, \"height\", \"100%\");\n    this.renderer.setStyle(this.hoverdDiv, \"width\", \"100%\");\n    this.renderer.setStyle(this.hoverdDiv, \"position\", \"absolute\");\n    this.renderer.setStyle(this.hoverdDiv, \"overflow\", \"auto\");\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"none\");\n    this.renderer.setStyle(this.hoverdDiv, \"z-index\", \"8\");\n    this.renderer.appendChild(this.element, this.hoverdDiv);\n  }\n\n  createUploadButton() {\n    this.button = this.renderer.createElement(\"button\");\n    this.renderer.setStyle(this.button, \"background-color\", \"#337ab7\");\n    this.renderer.setStyle(this.button, \"border-color\", \"#2e6da4\");\n    this.renderer.setStyle(this.button, \"color\", \"#ffff\");\n    this.renderer.setStyle(this.button, \"position\", \"absolute\");\n    this.renderer.setStyle(this.button, \"top\", \"0\");\n    this.renderer.setStyle(this.button, \"right\", \"0\");\n    this.renderer.setStyle(this.button, \"bottom\", \"0\");\n    this.renderer.setStyle(this.button, \"left\", \"0\");\n    this.renderer.setStyle(this.button, \"margin\", \"auto\");\n    this.renderer.setStyle(this.button, \"height\", \"50px\");\n    this.renderer.setStyle(this.button, \"z-index\", \"9\");\n    this.renderer.setStyle(this.button, \"width\", \"120px\");\n    this.renderer.setStyle(this.button, \"font-weight\", \"600\");\n    this.renderer.setStyle(this.button, \"font-size\", \"16px\");\n    this.renderer.setStyle(this.button, \"display\", \"none\");\n    this.renderer.setProperty(this.button, \"type\", \"button\");\n    const buttontext = this.renderer.createText(\"Select File\");\n    this.renderer.appendChild(this.button, buttontext);\n    this.renderer.appendChild(this.element, this.button);\n    this.button.addEventListener(\"click\", () => {\n      this.input.click();\n    });\n  }\n\n  createUploaderElement() {\n    this.input = this.renderer.createElement(\"input\");\n    this.renderer.setProperty(this.input, \"type\", \"file\");\n    this.renderer.setStyle(this.input, \"opacity\", \"0\");\n    this.renderer.setStyle(this.input, \"height\", \"100%\");\n    this.renderer.setStyle(this.input, \"width\", \"100%\");\n    this.renderer.appendChild(this.element, this.input);\n    this.bindEvents();\n  }\n\n  bindEvents() {\n    this.input.addEventListener(\"change\", ev => {\n      const file = (ev as any).target.files[0];\n      this.upload(file);\n    });\n  }\n\n  upload(file: File) {\n    this.showSpinner();\n    this.mouseoverDisabled = true;\n    this.uploaderService\n      .upload(file)\n      .pipe(\n        map((response: any) => {\n          if (response && typeof response === \"object\") {\n            if (response.hasOwnProperty(\"result\")) {\n              return response[\"result\"];\n            } else if (response.hasOwnProperty(\"data\")) {\n              return response[\"data\"];\n            }\n          }\n\n          return response;\n        })\n      )\n      .subscribe({\n        next: (response: FilePickerRespnse) => {\n          if (response && typeof response === \"object\") {\n            this.uploadSuccess.emit(response);\n            this.previewImage(response.fileUrl);\n          }\n        },\n        complete: () => {\n          setTimeout(() => {\n            this.hideSpinner();\n            this.mouseoverDisabled = false;\n          }, 2000);\n        }\n      });\n  }\n\n  previewImage(fileUrl: string) {\n    this.renderer.setStyle(this.element, \"background-image\", `url(${fileUrl})`);\n    this.renderer.setStyle(this.element, \"background-size\", `cover`);\n  }\n\n  @HostListener(\"mouseover\") onMouseOver() {\n    if (this.mouseoverDisabled) {\n      return;\n    }\n    this.addHoverEffect();\n    this.showButton();\n  }\n\n  @HostListener(\"mouseout\") onMouseOut() {\n    this.removeHoverEffect();\n    this.hideButton();\n  }\n\n  private addHoverEffect() {\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"block\");\n  }\n\n  private removeHoverEffect() {\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"none\");\n  }\n\n  private showButton() {\n    this.renderer.setStyle(this.button, \"display\", `block`);\n  }\n\n  private hideButton() {\n    this.renderer.setStyle(this.button, \"display\", `none`);\n  }\n\n  private showSpinner() {\n    this.renderer.setStyle(this.spinnerDiv, \"display\", `block`);\n  }\n\n  private hideSpinner() {\n    this.renderer.setStyle(this.spinnerDiv, \"display\", `none`);\n  }\n}\n// TODO hover karne p upload button ayega uslp click krne p uploa dnput khileha\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker.directive.js","sourceRoot":"ng://adias-file-uploader/","sources":["lib/file-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  Renderer2\n} from \"@angular/core\";\nimport { map } from \"rxjs/operators\";\nimport { FilePickerRespnse } from \"./file-picker.response\";\nimport { FileUploaderService } from \"./file-uploader.service\";\n\n@Directive({\n  selector: \"[ngxFilePicker]\"\n})\nexport class FilePickerDirective implements OnInit {\n  @Output() uploadSuccess = new EventEmitter<FilePickerRespnse>();\n  @Output() uploadMultiSuccess = new EventEmitter<FilePickerRespnse[]>();\n  @Input() fileUrl: string = null;\n  @Input() transparent: boolean | string = false;\n  @Input() multiple: boolean | string = false;\n\n  element: HTMLElement;\n  hoverdDiv: HTMLElement;\n  spinnerDiv: HTMLElement;\n  input: HTMLElement;\n  button: HTMLElement;\n  image: HTMLElement;\n  uploadedFiles: Array<File>;\n\n  /** disabled till upload */\n  mouseoverDisabled = false;\n\n  constructor(\n    private elRef: ElementRef,\n    private renderer: Renderer2,\n    private uploaderService: FileUploaderService\n  ) {}\n\n  ngOnInit() {\n    this.multiple = this.multiple === \"\" || this.multiple ? true : false;\n    this.element = this.elRef.nativeElement;\n    this.element.style.position = \"relative\";\n    this.createUploaderElement();\n    this.createUploadButton();\n    this.createHoveredDiv();\n    this.createSpinnerDiv();\n\n    if (this.fileUrl) {\n      this.previewImage(this.fileUrl);\n    }\n  }\n\n  createSpinnerDiv() {\n    this.spinnerDiv = this.renderer.createElement(\"div\");\n    this.renderer.setStyle(\n      this.spinnerDiv,\n      \"background-color\",\n      \"rgba(0,0,0,0.4)\"\n    );\n    this.renderer.setStyle(this.spinnerDiv, \"top\", \"0\");\n    this.renderer.setStyle(this.spinnerDiv, \"left\", \"0\");\n    this.renderer.setStyle(this.spinnerDiv, \"height\", \"100%\");\n    this.renderer.setStyle(this.spinnerDiv, \"width\", \"100%\");\n    this.renderer.setStyle(this.spinnerDiv, \"position\", \"absolute\");\n    this.renderer.setStyle(this.spinnerDiv, \"overflow\", \"auto\");\n    this.renderer.setStyle(this.spinnerDiv, \"display\", \"none\");\n    this.renderer.setStyle(this.spinnerDiv, \"z-index\", \"8\");\n\n    const image = this.renderer.createElement(\"img\");\n\n    this.renderer.setProperty(\n      image,\n      \"src\",\n      `https://flevix.com/wp-content/uploads/2019/07/Spinner-Preloader.gif`\n    );\n\n    this.renderer.setStyle(image, \"height\", `100%`);\n    this.renderer.setStyle(image, \"width\", `100%`);\n    this.renderer.setStyle(image, \"object-fit\", `contain`);\n    this.renderer.appendChild(this.spinnerDiv, image);\n    this.renderer.appendChild(this.element, this.spinnerDiv);\n  }\n\n  createHoveredDiv() {\n    this.hoverdDiv = this.renderer.createElement(\"div\");\n    this.renderer.setStyle(\n      this.hoverdDiv,\n      \"background-color\",\n      \"rgba(0,0,0,0.4)\"\n    );\n    this.renderer.setStyle(this.hoverdDiv, \"top\", \"0\");\n    this.renderer.setStyle(this.hoverdDiv, \"left\", \"0\");\n    this.renderer.setStyle(this.hoverdDiv, \"height\", \"100%\");\n    this.renderer.setStyle(this.hoverdDiv, \"width\", \"100%\");\n    this.renderer.setStyle(this.hoverdDiv, \"position\", \"absolute\");\n    this.renderer.setStyle(this.hoverdDiv, \"overflow\", \"auto\");\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"none\");\n    this.renderer.setStyle(this.hoverdDiv, \"z-index\", \"8\");\n    this.renderer.appendChild(this.element, this.hoverdDiv);\n  }\n\n  createUploadButton() {\n    this.button = this.renderer.createElement(\"button\");\n    this.renderer.setStyle(this.button, \"background-color\", \"#337ab7\");\n    this.renderer.setStyle(this.button, \"border-color\", \"#2e6da4\");\n    this.renderer.setStyle(this.button, \"color\", \"#ffff\");\n    this.renderer.setStyle(this.button, \"position\", \"absolute\");\n    this.renderer.setStyle(this.button, \"top\", \"0\");\n    this.renderer.setStyle(this.button, \"right\", \"0\");\n    this.renderer.setStyle(this.button, \"bottom\", \"0\");\n    this.renderer.setStyle(this.button, \"left\", \"0\");\n    this.renderer.setStyle(this.button, \"margin\", \"auto\");\n    this.renderer.setStyle(this.button, \"height\", \"50px\");\n    this.renderer.setStyle(this.button, \"z-index\", \"9\");\n    this.renderer.setStyle(this.button, \"width\", \"120px\");\n    this.renderer.setStyle(this.button, \"font-weight\", \"600\");\n    this.renderer.setStyle(this.button, \"font-size\", \"16px\");\n    this.renderer.setStyle(this.button, \"display\", \"none\");\n    this.renderer.setProperty(this.button, \"type\", \"button\");\n    const buttontext = this.renderer.createText(\"Select File\");\n    this.renderer.appendChild(this.button, buttontext);\n    this.renderer.appendChild(this.element, this.button);\n    this.button.addEventListener(\"click\", () => {\n      this.input.click();\n    });\n  }\n\n  createUploaderElement() {\n    this.input = this.renderer.createElement(\"input\");\n    this.input.style.cursor = \"pointer\";\n    if (this.multiple) {\n      this.renderer.setProperty(this.input, \"multiple\", \"multiple\");\n    }\n    this.renderer.setProperty(this.input, \"type\", \"file\");\n    this.renderer.setStyle(this.input, \"opacity\", \"0\");\n    this.renderer.setStyle(this.input, \"height\", \"100%\");\n    this.renderer.setStyle(this.input, \"width\", \"100%\");\n    this.renderer.appendChild(this.element, this.input);\n    this.bindEvents();\n  }\n\n  bindEvents() {\n    this.input.addEventListener(\"change\", ev => {\n      const files = (ev as any).target.files;\n      if (this.multiple) {\n        this.uploadMultiple(files);\n      } else {\n        this.upload(files[0]);\n      }\n    });\n  }\n\n  upload(file: File) {\n    this.showSpinner();\n    this.mouseoverDisabled = true;\n    this.uploaderService\n      .upload(file)\n      .pipe(\n        map((response: any) => {\n          if (response && typeof response === \"object\") {\n            if (response.hasOwnProperty(\"result\")) {\n              return response[\"result\"];\n            } else if (response.hasOwnProperty(\"data\")) {\n              return response[\"data\"];\n            }\n          }\n\n          return response;\n        })\n      )\n      .subscribe({\n        next: (response: FilePickerRespnse) => {\n          if (response && typeof response === \"object\") {\n            this.uploadSuccess.emit(response);\n            this.previewImage(response.fileUrl);\n          }\n        },\n        complete: () => {\n          setTimeout(() => {\n            this.hideSpinner();\n            this.mouseoverDisabled = false;\n          }, 2000);\n        }\n      });\n  }\n\n  uploadMultiple(files: File[]) {\n    this.showSpinner();\n    this.mouseoverDisabled = true;\n    this.uploaderService\n      .uploadMultiple(files)\n      .pipe(\n        map((response: any) => {\n          if (response && typeof response === \"object\") {\n            if (response.hasOwnProperty(\"result\")) {\n              return response[\"result\"];\n            } else if (response.hasOwnProperty(\"data\")) {\n              return response[\"data\"];\n            }\n          }\n\n          return response;\n        })\n      )\n      .subscribe({\n        next: (response: FilePickerRespnse[]) => {\n          if (response && typeof response === \"object\") {\n            this.uploadMultiSuccess.emit(response);\n          }\n        },\n        complete: () => {\n          setTimeout(() => {\n            this.hideSpinner();\n            this.mouseoverDisabled = false;\n          }, 2000);\n        }\n      });\n  }\n\n  previewImage(fileUrl: string) {\n    this.renderer.setStyle(this.element, \"background-image\", `url(${fileUrl})`);\n    this.renderer.setStyle(this.element, \"background-size\", `cover`);\n  }\n\n  @HostListener(\"mouseover\") onMouseOver() {\n    if (this.mouseoverDisabled || this.transparent === \"\" || this.transparent) {\n      return;\n    }\n    this.addHoverEffect();\n    this.showButton();\n  }\n\n  @HostListener(\"mouseout\") onMouseOut() {\n    this.removeHoverEffect();\n    this.hideButton();\n  }\n\n  private addHoverEffect() {\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"block\");\n  }\n\n  private removeHoverEffect() {\n    this.renderer.setStyle(this.hoverdDiv, \"display\", \"none\");\n  }\n\n  private showButton() {\n    this.renderer.setStyle(this.button, \"display\", `block`);\n  }\n\n  private hideButton() {\n    this.renderer.setStyle(this.button, \"display\", `none`);\n  }\n\n  private showSpinner() {\n    this.renderer.setStyle(this.spinnerDiv, \"display\", `block`);\n  }\n\n  private hideSpinner() {\n    this.renderer.setStyle(this.spinnerDiv, \"display\", `none`);\n  }\n}\n// TODO hover karne p upload button ayega uslp click krne p uploa dnput khileha\n"]}

@@ -47,2 +47,36 @@ /**

};
/**
* @param {?} files
* @return {?}
*/
FileUploaderService.prototype.uploadMultiple = /**
* @param {?} files
* @return {?}
*/
function (files) {
/** @type {?} */
var formData = new FormData();
for (var index = 0; index < files.length; index++) {
formData.append("files", files[index], files[index].name);
}
/** @type {?} */
var req = new HttpRequest("POST", this.endPoint, formData, {
reportProgress: true
});
return this.http.request(req).pipe(map((/**
* @param {?} res
* @return {?}
*/
function (res) {
if (res.type === HttpEventType.Response) {
return res.body;
}
else if (res.type === HttpEventType.UploadProgress) {
// Compute and show the % done:
/** @type {?} */
var UploadProgress = +Math.round((100 * res.loaded) / res.total);
return UploadProgress;
}
})));
};
FileUploaderService.decorators = [

@@ -68,2 +102,2 @@ { type: Injectable }

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYWRpYXMtZmlsZS11cGxvYWRlci8iLCJzb3VyY2VzIjpbImxpYi9maWxlLXVwbG9hZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxPQUFPLEVBQ0wsVUFBVSxFQUVWLGFBQWEsRUFDYixXQUFXLEVBQ1osTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUV2QztJQUVFLDZCQUM0QixRQUFnQixFQUNsQyxJQUFnQjtRQURFLGFBQVEsR0FBUixRQUFRLENBQVE7UUFDbEMsU0FBSSxHQUFKLElBQUksQ0FBWTtJQUN2QixDQUFDOzs7OztJQUVKLG9DQUFNOzs7O0lBQU4sVUFBTyxRQUFjOztZQUNmLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRTtRQUM3QixRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDOztZQUUzQyxHQUFHLEdBQUcsSUFBSSxXQUFXLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFO1lBQzNELGNBQWMsRUFBRSxJQUFJO1NBQ3JCLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FDaEMsR0FBRzs7OztRQUFDLFVBQUMsR0FBbUI7WUFDdEIsSUFBSSxHQUFHLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxRQUFRLEVBQUU7Z0JBQ3ZDLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQzthQUNqQjtpQkFBTSxJQUFJLEdBQUcsQ0FBQyxJQUFJLEtBQUssYUFBYSxDQUFDLGNBQWMsRUFBRTs7O29CQUU5QyxjQUFjLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO2dCQUNsRSxPQUFPLGNBQWMsQ0FBQzthQUN2QjtRQUNILENBQUMsRUFBQyxDQUNILENBQUM7SUFDSixDQUFDOztnQkF6QkYsVUFBVTs7Ozs2Q0FHTixNQUFNLFNBQUMsU0FBUztnQkFabkIsVUFBVTs7SUFtQ1osMEJBQUM7Q0FBQSxBQTFCRCxJQTBCQztTQXpCWSxtQkFBbUI7OztJQUU1Qix1Q0FBMEM7Ozs7O0lBQzFDLG1DQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEh0dHBDbGllbnQsXG4gIEh0dHBFdmVudCxcbiAgSHR0cEV2ZW50VHlwZSxcbiAgSHR0cFJlcXVlc3Rcbn0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XG5pbXBvcnQgeyBFTkRfUE9JTlQgfSBmcm9tIFwiLi9lbmRwb2ludFwiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZGVyU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoRU5EX1BPSU5UKSBwdWJsaWMgZW5kUG9pbnQ6IHN0cmluZyxcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnRcbiAgKSB7fVxuXG4gIHVwbG9hZChmaWxlSXRlbTogRmlsZSkge1xuICAgIGxldCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xuICAgIGZvcm1EYXRhLmFwcGVuZChcImZpbGVcIiwgZmlsZUl0ZW0sIGZpbGVJdGVtLm5hbWUpO1xuXG4gICAgY29uc3QgcmVxID0gbmV3IEh0dHBSZXF1ZXN0KFwiUE9TVFwiLCB0aGlzLmVuZFBvaW50LCBmb3JtRGF0YSwge1xuICAgICAgcmVwb3J0UHJvZ3Jlc3M6IHRydWVcbiAgICB9KTtcbiAgICByZXR1cm4gdGhpcy5odHRwLnJlcXVlc3QocmVxKS5waXBlKFxuICAgICAgbWFwKChyZXM6IEh0dHBFdmVudDxhbnk+KSA9PiB7XG4gICAgICAgIGlmIChyZXMudHlwZSA9PT0gSHR0cEV2ZW50VHlwZS5SZXNwb25zZSkge1xuICAgICAgICAgIHJldHVybiByZXMuYm9keTtcbiAgICAgICAgfSBlbHNlIGlmIChyZXMudHlwZSA9PT0gSHR0cEV2ZW50VHlwZS5VcGxvYWRQcm9ncmVzcykge1xuICAgICAgICAgIC8vIENvbXB1dGUgYW5kIHNob3cgdGhlICUgZG9uZTpcbiAgICAgICAgICBjb25zdCBVcGxvYWRQcm9ncmVzcyA9ICtNYXRoLnJvdW5kKCgxMDAgKiByZXMubG9hZGVkKSAvIHJlcy50b3RhbCk7XG4gICAgICAgICAgcmV0dXJuIFVwbG9hZFByb2dyZXNzO1xuICAgICAgICB9XG4gICAgICB9KVxuICAgICk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYWRpYXMtZmlsZS11cGxvYWRlci8iLCJzb3VyY2VzIjpbImxpYi9maWxlLXVwbG9hZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxPQUFPLEVBQ0wsVUFBVSxFQUVWLGFBQWEsRUFDYixXQUFXLEVBQ1osTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUV2QztJQUVFLDZCQUM0QixRQUFnQixFQUNsQyxJQUFnQjtRQURFLGFBQVEsR0FBUixRQUFRLENBQVE7UUFDbEMsU0FBSSxHQUFKLElBQUksQ0FBWTtJQUN2QixDQUFDOzs7OztJQUVKLG9DQUFNOzs7O0lBQU4sVUFBTyxRQUFjOztZQUNmLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRTtRQUU3QixRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDOztZQUUzQyxHQUFHLEdBQUcsSUFBSSxXQUFXLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFO1lBQzNELGNBQWMsRUFBRSxJQUFJO1NBQ3JCLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FDaEMsR0FBRzs7OztRQUFDLFVBQUMsR0FBbUI7WUFDdEIsSUFBSSxHQUFHLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxRQUFRLEVBQUU7Z0JBQ3ZDLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQzthQUNqQjtpQkFBTSxJQUFJLEdBQUcsQ0FBQyxJQUFJLEtBQUssYUFBYSxDQUFDLGNBQWMsRUFBRTs7O29CQUU5QyxjQUFjLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO2dCQUNsRSxPQUFPLGNBQWMsQ0FBQzthQUN2QjtRQUNILENBQUMsRUFBQyxDQUNILENBQUM7SUFDSixDQUFDOzs7OztJQUVELDRDQUFjOzs7O0lBQWQsVUFBZSxLQUFhOztZQUN0QixRQUFRLEdBQUcsSUFBSSxRQUFRLEVBQUU7UUFFN0IsS0FBSyxJQUFJLEtBQUssR0FBRyxDQUFDLEVBQUUsS0FBSyxHQUFHLEtBQUssQ0FBQyxNQUFNLEVBQUUsS0FBSyxFQUFFLEVBQUU7WUFDakQsUUFBUSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUMzRDs7WUFFSyxHQUFHLEdBQUcsSUFBSSxXQUFXLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFO1lBQzNELGNBQWMsRUFBRSxJQUFJO1NBQ3JCLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FDaEMsR0FBRzs7OztRQUFDLFVBQUMsR0FBbUI7WUFDdEIsSUFBSSxHQUFHLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxRQUFRLEVBQUU7Z0JBQ3ZDLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQzthQUNqQjtpQkFBTSxJQUFJLEdBQUcsQ0FBQyxJQUFJLEtBQUssYUFBYSxDQUFDLGNBQWMsRUFBRTs7O29CQUU5QyxjQUFjLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO2dCQUNsRSxPQUFPLGNBQWMsQ0FBQzthQUN2QjtRQUNILENBQUMsRUFBQyxDQUNILENBQUM7SUFDSixDQUFDOztnQkFqREYsVUFBVTs7Ozs2Q0FHTixNQUFNLFNBQUMsU0FBUztnQkFabkIsVUFBVTs7SUEyRFosMEJBQUM7Q0FBQSxBQWxERCxJQWtEQztTQWpEWSxtQkFBbUI7OztJQUU1Qix1Q0FBMEM7Ozs7O0lBQzFDLG1DQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEh0dHBDbGllbnQsXG4gIEh0dHBFdmVudCxcbiAgSHR0cEV2ZW50VHlwZSxcbiAgSHR0cFJlcXVlc3Rcbn0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XG5pbXBvcnQgeyBFTkRfUE9JTlQgfSBmcm9tIFwiLi9lbmRwb2ludFwiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZGVyU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoRU5EX1BPSU5UKSBwdWJsaWMgZW5kUG9pbnQ6IHN0cmluZyxcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnRcbiAgKSB7fVxuXG4gIHVwbG9hZChmaWxlSXRlbTogRmlsZSkge1xuICAgIGxldCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xuXG4gICAgZm9ybURhdGEuYXBwZW5kKFwiZmlsZVwiLCBmaWxlSXRlbSwgZmlsZUl0ZW0ubmFtZSk7XG5cbiAgICBjb25zdCByZXEgPSBuZXcgSHR0cFJlcXVlc3QoXCJQT1NUXCIsIHRoaXMuZW5kUG9pbnQsIGZvcm1EYXRhLCB7XG4gICAgICByZXBvcnRQcm9ncmVzczogdHJ1ZVxuICAgIH0pO1xuICAgIHJldHVybiB0aGlzLmh0dHAucmVxdWVzdChyZXEpLnBpcGUoXG4gICAgICBtYXAoKHJlczogSHR0cEV2ZW50PGFueT4pID0+IHtcbiAgICAgICAgaWYgKHJlcy50eXBlID09PSBIdHRwRXZlbnRUeXBlLlJlc3BvbnNlKSB7XG4gICAgICAgICAgcmV0dXJuIHJlcy5ib2R5O1xuICAgICAgICB9IGVsc2UgaWYgKHJlcy50eXBlID09PSBIdHRwRXZlbnRUeXBlLlVwbG9hZFByb2dyZXNzKSB7XG4gICAgICAgICAgLy8gQ29tcHV0ZSBhbmQgc2hvdyB0aGUgJSBkb25lOlxuICAgICAgICAgIGNvbnN0IFVwbG9hZFByb2dyZXNzID0gK01hdGgucm91bmQoKDEwMCAqIHJlcy5sb2FkZWQpIC8gcmVzLnRvdGFsKTtcbiAgICAgICAgICByZXR1cm4gVXBsb2FkUHJvZ3Jlc3M7XG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIHVwbG9hZE11bHRpcGxlKGZpbGVzOiBGaWxlW10pIHtcbiAgICBsZXQgZm9ybURhdGEgPSBuZXcgRm9ybURhdGEoKTtcblxuICAgIGZvciAobGV0IGluZGV4ID0gMDsgaW5kZXggPCBmaWxlcy5sZW5ndGg7IGluZGV4KyspIHtcbiAgICAgIGZvcm1EYXRhLmFwcGVuZChcImZpbGVzXCIsIGZpbGVzW2luZGV4XSwgZmlsZXNbaW5kZXhdLm5hbWUpO1xuICAgIH1cblxuICAgIGNvbnN0IHJlcSA9IG5ldyBIdHRwUmVxdWVzdChcIlBPU1RcIiwgdGhpcy5lbmRQb2ludCwgZm9ybURhdGEsIHtcbiAgICAgIHJlcG9ydFByb2dyZXNzOiB0cnVlXG4gICAgfSk7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5yZXF1ZXN0KHJlcSkucGlwZShcbiAgICAgIG1hcCgocmVzOiBIdHRwRXZlbnQ8YW55PikgPT4ge1xuICAgICAgICBpZiAocmVzLnR5cGUgPT09IEh0dHBFdmVudFR5cGUuUmVzcG9uc2UpIHtcbiAgICAgICAgICByZXR1cm4gcmVzLmJvZHk7XG4gICAgICAgIH0gZWxzZSBpZiAocmVzLnR5cGUgPT09IEh0dHBFdmVudFR5cGUuVXBsb2FkUHJvZ3Jlc3MpIHtcbiAgICAgICAgICAvLyBDb21wdXRlIGFuZCBzaG93IHRoZSAlIGRvbmU6XG4gICAgICAgICAgY29uc3QgVXBsb2FkUHJvZ3Jlc3MgPSArTWF0aC5yb3VuZCgoMTAwICogcmVzLmxvYWRlZCkgLyByZXMudG90YWwpO1xuICAgICAgICAgIHJldHVybiBVcGxvYWRQcm9ncmVzcztcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICApO1xuICB9XG59XG4iXX0=

@@ -75,2 +75,32 @@ import { InjectionToken, Injectable, Inject, EventEmitter, Directive, ElementRef, Renderer2, Output, Input, HostListener, NgModule } from '@angular/core';

}
/**
* @param {?} files
* @return {?}
*/
uploadMultiple(files) {
/** @type {?} */
let formData = new FormData();
for (let index = 0; index < files.length; index++) {
formData.append("files", files[index], files[index].name);
}
/** @type {?} */
const req = new HttpRequest("POST", this.endPoint, formData, {
reportProgress: true
});
return this.http.request(req).pipe(map((/**
* @param {?} res
* @return {?}
*/
(res) => {
if (res.type === HttpEventType.Response) {
return res.body;
}
else if (res.type === HttpEventType.UploadProgress) {
// Compute and show the % done:
/** @type {?} */
const UploadProgress = +Math.round((100 * res.loaded) / res.total);
return UploadProgress;
}
})));
}
}

@@ -111,3 +141,6 @@ FileUploaderService.decorators = [

this.uploadSuccess = new EventEmitter();
this.uploadMultiSuccess = new EventEmitter();
this.fileUrl = null;
this.transparent = false;
this.multiple = false;
/**

@@ -122,2 +155,3 @@ * disabled till upload

ngOnInit() {
this.multiple = this.multiple === "" || this.multiple ? true : false;
this.element = this.elRef.nativeElement;

@@ -209,2 +243,6 @@ this.element.style.position = "relative";

this.input = this.renderer.createElement("input");
this.input.style.cursor = "pointer";
if (this.multiple) {
this.renderer.setProperty(this.input, "multiple", "multiple");
}
this.renderer.setProperty(this.input, "type", "file");

@@ -227,4 +265,9 @@ this.renderer.setStyle(this.input, "opacity", "0");

/** @type {?} */
const file = ((/** @type {?} */ (ev))).target.files[0];
this.upload(file);
const files = ((/** @type {?} */ (ev))).target.files;
if (this.multiple) {
this.uploadMultiple(files);
}
else {
this.upload(files[0]);
}
}));

@@ -282,2 +325,50 @@ }

/**
* @param {?} files
* @return {?}
*/
uploadMultiple(files) {
this.showSpinner();
this.mouseoverDisabled = true;
this.uploaderService
.uploadMultiple(files)
.pipe(map((/**
* @param {?} response
* @return {?}
*/
(response) => {
if (response && typeof response === "object") {
if (response.hasOwnProperty("result")) {
return response["result"];
}
else if (response.hasOwnProperty("data")) {
return response["data"];
}
}
return response;
})))
.subscribe({
next: (/**
* @param {?} response
* @return {?}
*/
(response) => {
if (response && typeof response === "object") {
this.uploadMultiSuccess.emit(response);
}
}),
complete: (/**
* @return {?}
*/
() => {
setTimeout((/**
* @return {?}
*/
() => {
this.hideSpinner();
this.mouseoverDisabled = false;
}), 2000);
})
});
}
/**
* @param {?} fileUrl

@@ -294,3 +385,3 @@ * @return {?}

onMouseOver() {
if (this.mouseoverDisabled) {
if (this.mouseoverDisabled || this.transparent === "" || this.transparent) {
return;

@@ -364,3 +455,6 @@ }

uploadSuccess: [{ type: Output }],
uploadMultiSuccess: [{ type: Output }],
fileUrl: [{ type: Input }],
transparent: [{ type: Input }],
multiple: [{ type: Input }],
onMouseOver: [{ type: HostListener, args: ["mouseover",] }],

@@ -373,4 +467,10 @@ onMouseOut: [{ type: HostListener, args: ["mouseout",] }]

/** @type {?} */
FilePickerDirective.prototype.uploadMultiSuccess;
/** @type {?} */
FilePickerDirective.prototype.fileUrl;
/** @type {?} */
FilePickerDirective.prototype.transparent;
/** @type {?} */
FilePickerDirective.prototype.multiple;
/** @type {?} */
FilePickerDirective.prototype.element;

@@ -377,0 +477,0 @@ /** @type {?} */

@@ -75,2 +75,36 @@ import { InjectionToken, Injectable, Inject, EventEmitter, Directive, ElementRef, Renderer2, Output, Input, HostListener, NgModule } from '@angular/core';

};
/**
* @param {?} files
* @return {?}
*/
FileUploaderService.prototype.uploadMultiple = /**
* @param {?} files
* @return {?}
*/
function (files) {
/** @type {?} */
var formData = new FormData();
for (var index = 0; index < files.length; index++) {
formData.append("files", files[index], files[index].name);
}
/** @type {?} */
var req = new HttpRequest("POST", this.endPoint, formData, {
reportProgress: true
});
return this.http.request(req).pipe(map((/**
* @param {?} res
* @return {?}
*/
function (res) {
if (res.type === HttpEventType.Response) {
return res.body;
}
else if (res.type === HttpEventType.UploadProgress) {
// Compute and show the % done:
/** @type {?} */
var UploadProgress = +Math.round((100 * res.loaded) / res.total);
return UploadProgress;
}
})));
};
FileUploaderService.decorators = [

@@ -107,3 +141,6 @@ { type: Injectable }

this.uploadSuccess = new EventEmitter();
this.uploadMultiSuccess = new EventEmitter();
this.fileUrl = null;
this.transparent = false;
this.multiple = false;
/**

@@ -121,2 +158,3 @@ * disabled till upload

function () {
this.multiple = this.multiple === "" || this.multiple ? true : false;
this.element = this.elRef.nativeElement;

@@ -221,2 +259,6 @@ this.element.style.position = "relative";

this.input = this.renderer.createElement("input");
this.input.style.cursor = "pointer";
if (this.multiple) {
this.renderer.setProperty(this.input, "multiple", "multiple");
}
this.renderer.setProperty(this.input, "type", "file");

@@ -243,4 +285,9 @@ this.renderer.setStyle(this.input, "opacity", "0");

/** @type {?} */
var file = ((/** @type {?} */ (ev))).target.files[0];
_this.upload(file);
var files = ((/** @type {?} */ (ev))).target.files;
if (_this.multiple) {
_this.uploadMultiple(files);
}
else {
_this.upload(files[0]);
}
}));

@@ -303,2 +350,55 @@ };

/**
* @param {?} files
* @return {?}
*/
FilePickerDirective.prototype.uploadMultiple = /**
* @param {?} files
* @return {?}
*/
function (files) {
var _this = this;
this.showSpinner();
this.mouseoverDisabled = true;
this.uploaderService
.uploadMultiple(files)
.pipe(map((/**
* @param {?} response
* @return {?}
*/
function (response) {
if (response && typeof response === "object") {
if (response.hasOwnProperty("result")) {
return response["result"];
}
else if (response.hasOwnProperty("data")) {
return response["data"];
}
}
return response;
})))
.subscribe({
next: (/**
* @param {?} response
* @return {?}
*/
function (response) {
if (response && typeof response === "object") {
_this.uploadMultiSuccess.emit(response);
}
}),
complete: (/**
* @return {?}
*/
function () {
setTimeout((/**
* @return {?}
*/
function () {
_this.hideSpinner();
_this.mouseoverDisabled = false;
}), 2000);
})
});
};
/**
* @param {?} fileUrl

@@ -322,3 +422,3 @@ * @return {?}

function () {
if (this.mouseoverDisabled) {
if (this.mouseoverDisabled || this.transparent === "" || this.transparent) {
return;

@@ -418,3 +518,6 @@ }

uploadSuccess: [{ type: Output }],
uploadMultiSuccess: [{ type: Output }],
fileUrl: [{ type: Input }],
transparent: [{ type: Input }],
multiple: [{ type: Input }],
onMouseOver: [{ type: HostListener, args: ["mouseover",] }],

@@ -429,4 +532,10 @@ onMouseOut: [{ type: HostListener, args: ["mouseout",] }]

/** @type {?} */
FilePickerDirective.prototype.uploadMultiSuccess;
/** @type {?} */
FilePickerDirective.prototype.fileUrl;
/** @type {?} */
FilePickerDirective.prototype.transparent;
/** @type {?} */
FilePickerDirective.prototype.multiple;
/** @type {?} */
FilePickerDirective.prototype.element;

@@ -433,0 +542,0 @@ /** @type {?} */

@@ -9,3 +9,6 @@ import { ElementRef, EventEmitter, OnInit, Renderer2 } from "@angular/core";

uploadSuccess: EventEmitter<FilePickerRespnse>;
uploadMultiSuccess: EventEmitter<FilePickerRespnse[]>;
fileUrl: string;
transparent: boolean | string;
multiple: boolean | string;
element: HTMLElement;

@@ -28,2 +31,3 @@ hoverdDiv: HTMLElement;

upload(file: File): void;
uploadMultiple(files: File[]): void;
previewImage(fileUrl: string): void;

@@ -30,0 +34,0 @@ onMouseOver(): void;

@@ -7,2 +7,3 @@ import { HttpClient } from "@angular/common/http";

upload(fileItem: File): import("rxjs").Observable<any>;
uploadMultiple(files: File[]): import("rxjs").Observable<any>;
}
{
"name": "adias-file-uploader",
"version": "2.0.4",
"version": "2.0.7",
"description": "Angular Library for uploading files",

@@ -5,0 +5,0 @@ "peerDependencies": {

@@ -11,2 +11,4 @@ # adias-file-uploader

- [x] Set Custom File Url After Upload
- [x] Transparent Uploader
- [x] Multiple File Uploader

@@ -52,2 +54,18 @@ ---

OR
For Transparent File uploader
```HTML
<div ngxFilePicker transparent (uploadSuccess)="onUploadSuccess($event)"></div>
```
OR
For Multiple File upload
```HTML
<div ngxFilePicker transparent multiple (uploadMultiSuccess)="onUploadSuccess($event)"></div>
```
## Events

@@ -70,1 +88,104 @@

```
Nestjs
controller.ts
```ts
@Post()
@AllowWithoutToken()
@UseInterceptors(FilesInterceptor('files'))
async uploadAvatar(@UploadedFiles() files: S3Response[]) {
return files.map(file => {
return {
fileUrl: buildFileUrl(file.key),
fileName: file.key,
fileSize: file.size,
fileType: file.mimetype,
};
});
}
```
s3.service.ts
```ts
import { Injectable, Logger } from "@nestjs/common";
import {
MulterModuleOptions,
MulterOptionsFactory
} from "@nestjs/platform-express";
import * as AWS from "aws-sdk";
import * as Express from "express";
import * as Multer from "multer";
import * as MulterS3 from "multer-s3";
import { Random } from "random-js";
const random = new Random();
@Injectable()
export class S3Service implements MulterOptionsFactory {
private s3: any;
private readonly FILE_LIMIT_SIZE = 3145728; // 사용자 프로필 이미지는 3MB 제한
config = {
acesssKeyId: acesssKeyId,
bucket: bucket,
secretAccessKey: secretAccessKey
};
constructor() {
this.s3 = new AWS.S3();
AWS.config.update({
accessKeyId: acesssKeyId,
secretAccessKey: secretAccessKey
});
}
// CallBack 함수로, NestJS의 MulterModule에 사용될 MulterModuleOption을 리턴한다.
createMulterOptions(): MulterModuleOptions | Promise<MulterModuleOptions> {
const bucket: string = this.config.bucket;
const acl: string = "public-read";
const multerS3Storage = MulterS3({
s3: this.s3,
bucket,
// acl,
metadata: (req, file, cb) => {
cb(null, { fieldName: file.fieldname });
},
key: (req, file, cb) => {
cb(
null,
`${Date.now().toString()}-${String(file.originalname).replace(
/[&\/\\#, +()$~%'":*?<>{}]/g,
"_"
)}`
);
}
});
return {
storage: multerS3Storage,
fileFilter: this.fileFilter,
limits: {
fileSize: this.FILE_LIMIT_SIZE
}
};
}
public fileFilter(
req: Express.Request,
file: Multer.File,
cb: (error: Error | null, acceptFile: boolean) => void
) {
if (file.mimetype.match(/\/(jpg|jpeg|png|gif)$/)) {
cb(null, true);
} else {
Logger.log(`No! ${JSON.stringify(file)}`);
cb(new Error("unsupported file"), false);
}
}
}
```

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc