New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

angular-file

Package Overview
Dependencies
Maintainers
1
Versions
60
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

angular-file - npm Package Compare versions

Comparing version
4.0.1
to
4.0.2
+1
-1
package.json
{
"name": "angular-file",
"version": "4.0.1",
"version": "4.0.2",
"description": "Easy to use Angular directives for user file selections",

@@ -5,0 +5,0 @@ "main": "dist/index.js",

{"__symbolic":"module","version":4,"metadata":{"ngfModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":22,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":24,"character":4}],"declarations":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"},{"__symbolic":"reference","name":"ɵb"}],"exports":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"},{"__symbolic":"reference","name":"ɵb"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"ɵb"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":6,"character":1},"arguments":[{"selector":"[ngfDrop]","exportAs":"ngfDrop"}]}],"members":{"fileOver":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":11,"character":3}}]}],"validDrag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"validDragChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":14,"character":3}}]}],"invalidDrag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"invalidDragChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":17,"character":3}}]}],"dragFiles":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"dragFilesChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":20,"character":3}}]}],"onDrop":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":22,"character":3},"arguments":["drop",["$event"]]}]}],"handleFiles":[{"__symbolic":"method"}],"onDragOver":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":43,"character":3},"arguments":["dragover",["$event"]]}]}],"closeDrags":[{"__symbolic":"method"}],"onDragLeave":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":83,"character":3},"arguments":["dragleave",["$event"]]}]}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":15,"character":1},"arguments":[{"selector":"[ngf]","exportAs":"ngf"}]}],"members":{"multiple":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"accept":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":25,"character":3}}]}],"maxSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"ngfFixOrientation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"fileDropDisabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"selectable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"directiveInit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":31,"character":3},"arguments":["init"]}]}],"lastInvalids":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"lastInvalidsChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":34,"character":3}}]}],"lastBaseUrl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"lastBaseUrlChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":37,"character":3}}]}],"file":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"fileChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":40,"character":3}}]}],"files":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"filesChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":43,"character":3}}]}],"fileSelectStart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":45,"character":3}}]}],"capturePaste":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":51,"character":29}]}],"initFilters":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"evalCapturePaste":[{"__symbolic":"method"}],"destroyPasteListener":[{"__symbolic":"method"}],"paramFileElm":[{"__symbolic":"method"}],"createFileElm":[{"__symbolic":"method"}],"enableSelecting":[{"__symbolic":"method"}],"getValidFiles":[{"__symbolic":"method"}],"getInvalidFiles":[{"__symbolic":"method"}],"handleFiles":[{"__symbolic":"method"}],"que":[{"__symbolic":"method"}],"changeFn":[{"__symbolic":"method"}],"clickHandler":[{"__symbolic":"method"}],"beforeSelect":[{"__symbolic":"method"}],"clearFileElmValue":[{"__symbolic":"method"}],"isEmptyAfterSelection":[{"__symbolic":"method"}],"stopEvent":[{"__symbolic":"method"}],"transferHasFiles":[{"__symbolic":"method"}],"eventToFiles":[{"__symbolic":"method"}],"applyExifRotations":[{"__symbolic":"method"}],"onChange":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":354,"character":3},"arguments":["change",["$event"]]}]}],"getFileFilterFailName":[{"__symbolic":"method"}],"isFileValid":[{"__symbolic":"method"}],"isFilesValid":[{"__symbolic":"method"}],"_acceptFilter":[{"__symbolic":"method"}],"_fileSizeFilter":[{"__symbolic":"method"}]}},"ɵc":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"ɵb"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":3,"character":1},"arguments":[{"selector":"[ngfSelect]","exportAs":"ngfSelect"}]}],"members":{"selectable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":8,"character":3}}]}]}},"ɵd":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":3,"character":1},"arguments":[{"selector":"[ngfBackground]"}]}],"members":{"file":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":5,"character":3},"arguments":["ngfBackground"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":7,"character":32}]}],"ngOnChanges":[{"__symbolic":"method"}]}},"ɵe":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":3,"character":1},"arguments":[{"selector":"[ngfSrc]"}]}],"members":{"file":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":5,"character":3},"arguments":["ngfSrc"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":7,"character":33}]}],"ngOnChanges":[{"__symbolic":"method"}]}},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":2,"character":1},"arguments":[{"selector":"ngfUploadStatus"}]}],"members":{"percent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":4,"character":3}}]}],"percentChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":5,"character":3}}]}],"httpEvent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":6,"character":3}}]}],"ngOnChanges":[{"__symbolic":"method"}]}},"ɵg":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":7,"character":1},"arguments":[{"selector":"ngfFormData"}]}],"members":{"files":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"postName":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"fileName":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"FormData":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"FormDataChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":14,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"IterableDiffers","line":18,"character":31}]}],"ngDoCheck":[{"__symbolic":"method"}],"buildFormData":[{"__symbolic":"method"}]}}},"origins":{"ngfModule":"./file-upload/ngf.module","ɵa":"./file-upload/ngfDrop.directive","ɵb":"./file-upload/ngf.directive","ɵc":"./file-upload/ngfSelect.directive","ɵd":"./file-upload/ngfBackground.directive","ɵe":"./file-upload/ngfSrc.directive","ɵf":"./file-upload/ngfUploadStatus.directive","ɵg":"./file-upload/ngfFormData.directive"},"importAs":"angular-file"}
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common')) :
typeof define === 'function' && define.amd ? define('angular-file/src', ['exports', '@angular/core', '@angular/common'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-file"] = global["angular-file"] || {}, global["angular-file"].src = {}), global.ng.core, global.ng.common));
})(this, (function (exports, core, common) { 'use strict';
/******************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
/* global Reflect, Promise */
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b)
if (Object.prototype.hasOwnProperty.call(b, p))
d[p] = b[p]; };
return extendStatics(d, b);
};
function __extends(d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var __assign = function () {
__assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s)
if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
function __rest(s, e) {
var t = {};
for (var p in s)
if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
}
function __decorate(decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
r = Reflect.decorate(decorators, target, key, desc);
else
for (var i = decorators.length - 1; i >= 0; i--)
if (d = decorators[i])
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
}
function __param(paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); };
}
function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
function accept(f) { if (f !== void 0 && typeof f !== "function")
throw new TypeError("Function expected"); return f; }
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
var _, done = false;
for (var i = decorators.length - 1; i >= 0; i--) {
var context = {};
for (var p in contextIn)
context[p] = p === "access" ? {} : contextIn[p];
for (var p in contextIn.access)
context.access[p] = contextIn.access[p];
context.addInitializer = function (f) { if (done)
throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
if (kind === "accessor") {
if (result === void 0)
continue;
if (result === null || typeof result !== "object")
throw new TypeError("Object expected");
if (_ = accept(result.get))
descriptor.get = _;
if (_ = accept(result.set))
descriptor.set = _;
if (_ = accept(result.init))
initializers.push(_);
}
else if (_ = accept(result)) {
if (kind === "field")
initializers.push(_);
else
descriptor[key] = _;
}
}
if (target)
Object.defineProperty(target, contextIn.name, descriptor);
done = true;
}
;
function __runInitializers(thisArg, initializers, value) {
var useValue = arguments.length > 2;
for (var i = 0; i < initializers.length; i++) {
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
}
return useValue ? value : void 0;
}
;
function __propKey(x) {
return typeof x === "symbol" ? x : "".concat(x);
}
;
function __setFunctionName(f, name, prefix) {
if (typeof name === "symbol")
name = name.description ? "[".concat(name.description, "]") : "";
return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
}
;
function __metadata(metadataKey, metadataValue) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
return Reflect.metadata(metadataKey, metadataValue);
}
function __awaiter(thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try {
step(generator.next(value));
}
catch (e) {
reject(e);
} }
function rejected(value) { try {
step(generator["throw"](value));
}
catch (e) {
reject(e);
} }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
}
function __generator(thisArg, body) {
var _ = { label: 0, sent: function () { if (t[0] & 1)
throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function () { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f)
throw new TypeError("Generator is already executing.");
while (g && (g = 0, op[0] && (_ = 0)), _)
try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done)
return t;
if (y = 0, t)
op = [op[0] & 2, t.value];
switch (op[0]) {
case 0:
case 1:
t = op;
break;
case 4:
_.label++;
return { value: op[1], done: false };
case 5:
_.label++;
y = op[1];
op = [0];
continue;
case 7:
op = _.ops.pop();
_.trys.pop();
continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
_ = 0;
continue;
}
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) {
_.label = op[1];
break;
}
if (op[0] === 6 && _.label < t[1]) {
_.label = t[1];
t = op;
break;
}
if (t && _.label < t[2]) {
_.label = t[2];
_.ops.push(op);
break;
}
if (t[2])
_.ops.pop();
_.trys.pop();
continue;
}
op = body.call(thisArg, _);
}
catch (e) {
op = [6, e];
y = 0;
}
finally {
f = t = 0;
}
if (op[0] & 5)
throw op[1];
return { value: op[0] ? op[1] : void 0, done: true };
}
}
var __createBinding = Object.create ? (function (o, m, k, k2) {
if (k2 === undefined)
k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function () { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function (o, m, k, k2) {
if (k2 === undefined)
k2 = k;
o[k2] = m[k];
});
function __exportStar(m, o) {
for (var p in m)
if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p))
__createBinding(o, m, p);
}
function __values(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m)
return m.call(o);
if (o && typeof o.length === "number")
return {
next: function () {
if (o && i >= o.length)
o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
}
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m)
return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done)
ar.push(r.value);
}
catch (error) {
e = { error: error };
}
finally {
try {
if (r && !r.done && (m = i["return"]))
m.call(i);
}
finally {
if (e)
throw e.error;
}
}
return ar;
}
/** @deprecated */
function __spread() {
for (var ar = [], i = 0; i < arguments.length; i++)
ar = ar.concat(__read(arguments[i]));
return ar;
}
/** @deprecated */
function __spreadArrays() {
for (var s = 0, i = 0, il = arguments.length; i < il; i++)
s += arguments[i].length;
for (var r = Array(s), k = 0, i = 0; i < il; i++)
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
r[k] = a[j];
return r;
}
function __spreadArray(to, from, pack) {
if (pack || arguments.length === 2)
for (var i = 0, l = from.length, ar; i < l; i++) {
if (ar || !(i in from)) {
if (!ar)
ar = Array.prototype.slice.call(from, 0, i);
ar[i] = from[i];
}
}
return to.concat(ar || Array.prototype.slice.call(from));
}
function __await(v) {
return this instanceof __await ? (this.v = v, this) : new __await(v);
}
function __asyncGenerator(thisArg, _arguments, generator) {
if (!Symbol.asyncIterator)
throw new TypeError("Symbol.asyncIterator is not defined.");
var g = generator.apply(thisArg, _arguments || []), i, q = [];
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
function verb(n) { if (g[n])
i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
function resume(n, v) { try {
step(g[n](v));
}
catch (e) {
settle(q[0][3], e);
} }
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
function fulfill(value) { resume("next", value); }
function reject(value) { resume("throw", value); }
function settle(f, v) { if (f(v), q.shift(), q.length)
resume(q[0][0], q[0][1]); }
}
function __asyncDelegator(o) {
var i, p;
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }
}
function __asyncValues(o) {
if (!Symbol.asyncIterator)
throw new TypeError("Symbol.asyncIterator is not defined.");
var m = o[Symbol.asyncIterator], i;
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function (v) { resolve({ value: v, done: d }); }, reject); }
}
function __makeTemplateObject(cooked, raw) {
if (Object.defineProperty) {
Object.defineProperty(cooked, "raw", { value: raw });
}
else {
cooked.raw = raw;
}
return cooked;
}
;
var __setModuleDefault = Object.create ? (function (o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function (o, v) {
o["default"] = v;
};
function __importStar(mod) {
if (mod && mod.__esModule)
return mod;
var result = {};
if (mod != null)
for (var k in mod)
if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k))
__createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
}
function __importDefault(mod) {
return (mod && mod.__esModule) ? mod : { default: mod };
}
function __classPrivateFieldGet(receiver, state, kind, f) {
if (kind === "a" && !f)
throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
}
function __classPrivateFieldSet(receiver, state, value, kind, f) {
if (kind === "m")
throw new TypeError("Private method is not writable");
if (kind === "a" && !f)
throw new TypeError("Private accessor was defined without a setter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
throw new TypeError("Cannot write private member to an object whose class did not declare it");
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
}
function __classPrivateFieldIn(state, receiver) {
if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function"))
throw new TypeError("Cannot use 'in' operator on non-object");
return typeof state === "function" ? receiver === state : state.has(receiver);
}
var isFileInput = function (elm) {
var ty = elm.getAttribute('type');
return elm.tagName.toLowerCase() === 'input' && ty && ty.toLowerCase() === 'file';
};
var initialTouchStartY = 0;
var initialTouchStartX = 0;
var detectSwipe = function (evt) {
var touches = evt.changedTouches || (evt.originalEvent && evt.originalEvent.changedTouches);
if (touches) {
if (evt.type === 'touchstart') {
initialTouchStartX = touches[0].clientX;
initialTouchStartY = touches[0].clientY;
return true; // don't block event default
}
else {
// prevent scroll from triggering event
if (evt.type === 'touchend') {
var currentX = touches[0].clientX;
var currentY = touches[0].clientY;
if ((Math.abs(currentX - initialTouchStartX) > 20) ||
(Math.abs(currentY - initialTouchStartY) > 20)) {
evt.stopPropagation();
if (evt.cancelable) {
evt.preventDefault();
}
return false;
}
}
return true;
}
}
return false;
};
var createInvisibleFileInputWrap = function () {
var fileElem = createFileInput();
var label = document.createElement('label');
label.innerHTML = 'upload';
label.style.visibility = 'hidden';
label.style.position = 'absolute';
label.style.overflow = 'hidden';
label.style.width = '0px';
label.style.height = '0px';
label.style.border = 'none';
label.style.margin = '0px';
label.style.padding = '0px';
label.setAttribute('tabindex', '-1');
//bindAttrToFileInput(fileElem, label);
//generatedElems.push({el: elem, ref: label});
label.appendChild(fileElem);
//document.body.appendChild( label );
return label;
};
var createFileInput = function () {
var fileElem = document.createElement('input');
fileElem.type = "file";
return fileElem;
};
function getWindow() { return window; }
function acceptType(accept, type, name) {
if (!accept) {
return true;
}
var defs = accept.split(',');
var regx;
var acceptRegString;
for (var x = defs.length - 1; x >= 0; --x) {
//Escapes dots in mimetype
acceptRegString = defs[x];
//trim
acceptRegString = acceptRegString.replace(/(^\s+|\s+$)/g, '');
//Escapes stars in mimetype
acceptRegString = acceptRegString.replace(/\*/g, '.*');
//let acceptReg = '^((' + acceptRegString
//acceptReg = acceptReg.replace(/,/g,')|(') + '))$'
//try by mime
regx = new RegExp(acceptRegString, 'gi');
if (type.search(regx) >= 0) {
return true;
}
//try by ext
if (acceptRegString.substring(0, 1) == '.') {
acceptRegString = '\\' + acceptRegString; //.substring(1, acceptRegString.length-1)//remove dot at front
regx = new RegExp(acceptRegString + '$', 'i');
if ((name || type).search(regx) >= 0) {
return true;
}
}
}
return false;
}
function arrayBufferToBase64(buffer) {
var binary = '';
var bytes = new Uint8Array(buffer);
var len = bytes.byteLength;
for (var i = 0; i < len; i++) {
binary += String.fromCharCode(bytes[i]);
}
return window.btoa(binary);
}
function dataUrltoBlob(dataurl, name, origSize) {
var arr = dataurl.split(',');
var mimeMatch = arr[0].match(/:(.*?);/);
var mime = mimeMatch ? mimeMatch[1] : 'text/plain';
var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
var blob = new window.Blob([u8arr], { type: mime });
blob["name"] = name;
blob["$ngfOrigSize"] = origSize;
return blob;
}
function applyTransform(ctx, orientation, width, height) {
switch (orientation) {
case 2:
return ctx.transform(-1, 0, 0, 1, width, 0);
case 3:
return ctx.transform(-1, 0, 0, -1, width, height);
case 4:
return ctx.transform(1, 0, 0, -1, 0, height);
case 5:
return ctx.transform(0, 1, 1, 0, 0, 0);
case 6:
return ctx.transform(0, 1, -1, 0, height, 0);
case 7:
return ctx.transform(0, -1, -1, 0, height, width);
case 8:
return ctx.transform(0, -1, 1, 0, 0, width);
}
}
function fixFileOrientationByMeta(file, result) {
return dataUrl(file, true)
.then(function (url) {
var canvas = document.createElement('canvas');
var img = document.createElement('img');
return new Promise(function (res, rej) {
img.onload = function () {
try {
canvas.width = result.orientation > 4 ? img.height : img.width;
canvas.height = result.orientation > 4 ? img.width : img.height;
var ctx = canvas.getContext('2d');
applyTransform(ctx, result.orientation, img.width, img.height);
ctx.drawImage(img, 0, 0);
var dataUrl = canvas.toDataURL(file.type || 'image/WebP', 0.934);
var base = arrayBufferToBase64(result.fixedArrayBuffer);
dataUrl = restoreExif(base, dataUrl);
var blob = dataUrltoBlob(dataUrl, file.name);
var newFile = blobToFile(blob, file.name);
res(newFile);
}
catch (e) {
rej(e);
}
};
img.onerror = rej;
img.src = url;
});
});
}
function applyExifRotation(file) {
if (file.type.indexOf('image/jpeg') !== 0) {
return Promise.resolve(file);
}
return readOrientation(file)
.then(function (result) {
if (result.orientation < 2 || result.orientation > 8) {
return file;
}
return fixFileOrientationByMeta(file, result);
});
}
function readOrientation(file) {
return new Promise(function (res, rej) {
var reader = new FileReader();
var slicedFile = file.slice ? file.slice(0, 64 * 1024) : file;
reader.readAsArrayBuffer(slicedFile);
reader.onerror = rej;
reader.onload = function (e) {
var result = { orientation: 1 };
var view = new DataView(this.result);
if (view.getUint16(0, false) !== 0xFFD8)
return res(result);
var length = view.byteLength, offset = 2;
while (offset < length) {
var marker = view.getUint16(offset, false);
offset += 2;
if (marker === 0xFFE1) {
if (view.getUint32(offset += 2, false) !== 0x45786966)
return res(result);
var little = view.getUint16(offset += 6, false) === 0x4949;
offset += view.getUint32(offset + 4, little);
var tags = view.getUint16(offset, little);
offset += 2;
for (var i = 0; i < tags; i++)
if (view.getUint16(offset + (i * 12), little) === 0x0112) {
var orientation = view.getUint16(offset + (i * 12) + 8, little);
if (orientation >= 2 && orientation <= 8) {
view.setUint16(offset + (i * 12) + 8, 1, little);
result.fixedArrayBuffer = e.target.result;
}
result.orientation = orientation;
return res(result);
}
}
else if ((marker & 0xFF00) !== 0xFF00)
break;
else
offset += view.getUint16(offset, false);
}
return res(result);
};
});
}
/** converts file-input file into base64 dataUri */
function dataUrl(file, disallowObjectUrl) {
if (!file)
return Promise.resolve(file);
if ((disallowObjectUrl && file.$ngfDataUrl != null) || (!disallowObjectUrl && file.$ngfBlobUrl != null)) {
return Promise.resolve(disallowObjectUrl ? file.$ngfDataUrl : file.$ngfBlobUrl);
}
var p = disallowObjectUrl ? file.$$ngfDataUrlPromise : file.$$ngfBlobUrlPromise;
if (p)
return p;
var win = getWindow();
var deferred;
if (win.FileReader && file &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 8') === -1 || file.size < 20000) &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 9') === -1 || file.size < 4000000)) {
//prefer URL.createObjectURL for handling refrences to files of all sizes
//since it doesn´t build a large string in memory
var URL = win.URL || win.webkitURL;
if (FileReader) {
deferred = new Promise(function (res, rej) {
var fileReader = new FileReader();
fileReader.onload = function (event) {
file.$ngfDataUrl = event.target.result;
delete file.$ngfDataUrl;
res(event.target.result);
};
fileReader.onerror = function (e) {
file.$ngfDataUrl = '';
rej(e);
};
fileReader.readAsDataURL(file);
});
}
else {
var url;
try {
url = URL.createObjectURL(file);
}
catch (e) {
return Promise.reject(e);
}
deferred = Promise.resolve(url);
file.$ngfBlobUrl = url;
}
}
else {
file[disallowObjectUrl ? '$ngfDataUrl' : '$ngfBlobUrl'] = '';
return Promise.reject(new Error('Browser does not support window.FileReader, window.FileReader, or window.FileAPI')); //deferred.reject();
}
if (disallowObjectUrl) {
p = file.$$ngfDataUrlPromise = deferred;
}
else {
p = file.$$ngfBlobUrlPromise = deferred;
}
p = p.then(function (x) {
delete file[disallowObjectUrl ? '$$ngfDataUrlPromise' : '$$ngfBlobUrlPromise'];
return x;
});
return p;
}
function restoreExif(orig, resized) {
var ExifRestorer = {
KEY_STR: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='
};
ExifRestorer.encode64 = function (input) {
var output = '', chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0;
do {
chr1 = input[i++];
chr2 = input[i++];
chr3 = input[i++];
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
}
else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
this.KEY_STR.charAt(enc1) +
this.KEY_STR.charAt(enc2) +
this.KEY_STR.charAt(enc3) +
this.KEY_STR.charAt(enc4);
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return output;
};
ExifRestorer.restore = function (origFileBase64, resizedFileBase64) {
if (origFileBase64.match('data:image/jpeg;base64,')) {
origFileBase64 = origFileBase64.replace('data:image/jpeg;base64,', '');
}
var rawImage = this.decode64(origFileBase64);
var segments = this.slice2Segments(rawImage);
var image = this.exifManipulation(resizedFileBase64, segments);
return 'data:image/jpeg;base64,' + this.encode64(image);
};
ExifRestorer.exifManipulation = function (resizedFileBase64, segments) {
var exifArray = this.getExifArray(segments), newImageArray = this.insertExif(resizedFileBase64, exifArray);
return new Uint8Array(newImageArray);
};
ExifRestorer.getExifArray = function (segments) {
var seg;
for (var x = 0; x < segments.length; x++) {
seg = segments[x];
if (seg[0] === 255 && seg[1] === 225) //(ff e1)
{
return seg;
}
}
return [];
};
ExifRestorer.insertExif = function (resizedFileBase64, exifArray) {
var imageData = resizedFileBase64.replace('data:image/jpeg;base64,', ''), buf = this.decode64(imageData), separatePoint = buf.indexOf(255, 3), mae = buf.slice(0, separatePoint), ato = buf.slice(separatePoint), array = mae;
array = array.concat(exifArray);
array = array.concat(ato);
return array;
};
ExifRestorer.slice2Segments = function (rawImageArray) {
var head = 0, segments = [];
while (1) {
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 218) {
break;
}
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 216) {
head += 2;
}
else {
var length = rawImageArray[head + 2] * 256 + rawImageArray[head + 3];
var endPoint = head + length + 2;
var seg = rawImageArray.slice(head, endPoint);
segments.push(seg);
head = endPoint;
}
if (head > rawImageArray.length) {
break;
}
}
return segments;
};
ExifRestorer.decode64 = function (input) {
var chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0, buf = [];
// remove all characters that are not A-Z, a-z, 0-9, +, /, or =
var base64test = /[^A-Za-z0-9\+\/\=]/g;
if (base64test.exec(input)) {
console.log('There were invalid base64 characters in the input text.');
}
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, '');
do {
enc1 = this.KEY_STR.indexOf(input.charAt(i++));
enc2 = this.KEY_STR.indexOf(input.charAt(i++));
enc3 = this.KEY_STR.indexOf(input.charAt(i++));
enc4 = this.KEY_STR.indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
buf.push(chr1);
if (enc3 !== 64) {
buf.push(chr2);
}
if (enc4 !== 64) {
buf.push(chr3);
}
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return buf;
};
return ExifRestorer.restore(orig, resized); //<= EXIF
}
;
function blobToFile(theBlob, fileName) {
var b = theBlob;
//A Blob() is almost a File() - it's just missing the two properties below which we will add
b.lastModifiedDate = new Date();
b.name = fileName;
//Cast to a File() type
return theBlob;
}
/** A master base set of logic intended to support file select/drag/drop operations
NOTE: Use ngfDrop for full drag/drop. Use ngfSelect for selecting
*/
var ngf = /** @class */ (function () {
function ngf(element) {
this.element = element;
this.filters = [];
this.lastFileCount = 0;
this.ngfFixOrientation = true;
this.fileDropDisabled = false;
this.selectable = false;
this.directiveInit = new core.EventEmitter();
this.lastInvalids = [];
this.lastInvalidsChange = new core.EventEmitter();
this.lastBaseUrlChange = new core.EventEmitter();
this.fileChange = new core.EventEmitter();
this.files = [];
this.filesChange = new core.EventEmitter();
this.fileSelectStart = new core.EventEmitter();
this.initFilters();
}
ngf.prototype.initFilters = function () {
// the order is important
this.filters.push({ name: 'accept', fn: this._acceptFilter });
this.filters.push({ name: 'fileSize', fn: this._fileSizeFilter });
//this.filters.push({name: 'fileType', fn: this._fileTypeFilter})
//this.filters.push({name: 'queueLimit', fn: this._queueLimitFilter})
//this.filters.push({name: 'mimeType', fn: this._mimeTypeFilter})
};
ngf.prototype.ngOnDestroy = function () {
delete this.fileElm; //faster memory release of dom element
this.destroyPasteListener();
};
ngf.prototype.ngOnInit = function () {
var _this = this;
var selectable = (this.selectable || this.selectable === '') && !['false', 'null', '0'].includes(this.selectable);
if (selectable) {
this.enableSelecting();
}
if (this.multiple) {
this.paramFileElm().setAttribute('multiple', this.multiple);
}
this.evalCapturePaste();
// create reference to this class with one cycle delay to avoid ExpressionChangedAfterItHasBeenCheckedError
setTimeout(function () {
_this.directiveInit.emit(_this);
}, 0);
};
ngf.prototype.ngOnChanges = function (changes) {
var _a, _b;
if (changes.accept) {
this.paramFileElm().setAttribute('accept', changes.accept.currentValue || '*');
}
if (changes.capturePaste) {
this.evalCapturePaste();
}
// Did we go from having a file to not having a file? Clear file element then
if (changes.file && changes.file.previousValue && !changes.file.currentValue) {
this.clearFileElmValue();
}
// Did we go from having files to not having files? Clear file element then
if (changes.files) {
var filesWentToZero = ((_a = changes.files.previousValue) === null || _a === void 0 ? void 0 : _a.length) && !((_b = changes.files.currentValue) === null || _b === void 0 ? void 0 : _b.length);
if (filesWentToZero) {
this.clearFileElmValue();
}
}
};
ngf.prototype.evalCapturePaste = function () {
var _this = this;
var isActive = this.capturePaste || this.capturePaste === '' || ['false', '0', 'null'].includes(this.capturePaste);
if (isActive) {
if (this.pasteCapturer) {
return; // already listening
}
this.pasteCapturer = function (e) {
var clip = e.clipboardData;
if (clip && clip.files && clip.files.length) {
_this.handleFiles(clip.files);
e.preventDefault();
}
};
window.addEventListener('paste', this.pasteCapturer);
return;
}
this.destroyPasteListener();
};
ngf.prototype.destroyPasteListener = function () {
if (this.pasteCapturer) {
window.removeEventListener('paste', this.pasteCapturer);
delete this.pasteCapturer;
}
};
ngf.prototype.paramFileElm = function () {
if (this.fileElm)
return this.fileElm; // already defined
// elm already is a file input
var isFile = isFileInput(this.element.nativeElement);
if (isFile) {
return this.fileElm = this.element.nativeElement;
}
// the host elm is NOT a file input
return this.fileElm = this.createFileElm({
change: this.changeFn.bind(this)
});
};
/** Only used when host element we are attached to is NOT a fileElement */
ngf.prototype.createFileElm = function (_c) {
var change = _c.change;
// use specific technique to hide file element within
var label = createInvisibleFileInputWrap();
var fileElm = label.getElementsByTagName('input')[0];
fileElm.addEventListener('change', change);
this.element.nativeElement.appendChild(label); // put on html stage
return fileElm;
};
ngf.prototype.enableSelecting = function () {
var _this = this;
var elm = this.element.nativeElement;
if (isFileInput(elm)) {
var bindedHandler_1 = function (event) { return _this.beforeSelect(event); };
elm.addEventListener('click', bindedHandler_1);
elm.addEventListener('touchstart', bindedHandler_1);
return;
}
var bindedHandler = function (ev) { return _this.clickHandler(ev); };
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
elm.addEventListener('touchend', bindedHandler);
};
ngf.prototype.getValidFiles = function (files) {
var rtn = [];
for (var x = files.length - 1; x >= 0; --x) {
if (this.isFileValid(files[x])) {
rtn.push(files[x]);
}
}
return rtn;
};
ngf.prototype.getInvalidFiles = function (files) {
var rtn = [];
for (var x = files.length - 1; x >= 0; --x) {
var failReason = this.getFileFilterFailName(files[x]);
if (failReason) {
rtn.push({
file: files[x],
type: failReason
});
}
}
return rtn;
};
// Primary handler of files coming in
ngf.prototype.handleFiles = function (files) {
var _this = this;
var valids = this.getValidFiles(files);
if (files.length != valids.length) {
this.lastInvalids = this.getInvalidFiles(files);
}
else {
delete this.lastInvalids;
}
this.lastInvalidsChange.emit(this.lastInvalids);
if (valids.length) {
if (this.ngfFixOrientation) {
this.applyExifRotations(valids)
.then(function (fixedFiles) { return _this.que(fixedFiles); });
}
else {
this.que(valids);
}
}
if (this.isEmptyAfterSelection()) {
this.element.nativeElement.value = '';
}
};
ngf.prototype.que = function (files) {
var _this = this;
this.files = this.files || [];
Array.prototype.push.apply(this.files, files);
//below break memory ref and doesnt act like a que
//this.files = files//causes memory change which triggers bindings like <ngfFormData [files]="files"></ngfFormData>
this.filesChange.emit(this.files);
if (files.length) {
this.fileChange.emit(this.file = files[0]);
if (this.lastBaseUrlChange.observers.length) {
dataUrl(files[0])
.then(function (url) { return _this.lastBaseUrlChange.emit(url); });
}
}
//will be checked for input value clearing
this.lastFileCount = this.files.length;
};
/** called when input has files */
ngf.prototype.changeFn = function (event) {
var fileList = event.__files_ || (event.target && event.target.files);
if (!fileList)
return;
this.stopEvent(event);
this.handleFiles(fileList);
};
ngf.prototype.clickHandler = function (evt) {
var elm = this.element.nativeElement;
if (elm.getAttribute('disabled') || this.fileDropDisabled) {
return false;
}
var r = detectSwipe(evt);
// prevent the click if it is a swipe
if (r !== false)
return r;
var fileElm = this.paramFileElm();
fileElm.click();
//fileElm.dispatchEvent( new Event('click') );
this.beforeSelect(evt);
return false;
};
ngf.prototype.beforeSelect = function (event) {
this.fileSelectStart.emit(event);
if (this.files && this.lastFileCount === this.files.length)
return;
// if no files in array, be sure browser does not prevent reselect of same file (see github issue 27)
this.clearFileElmValue();
};
ngf.prototype.clearFileElmValue = function () {
if (!this.fileElm)
return;
this.fileElm.value = null;
};
ngf.prototype.isEmptyAfterSelection = function () {
return !!this.element.nativeElement.attributes.multiple;
};
ngf.prototype.stopEvent = function (event) {
event.preventDefault();
event.stopPropagation();
};
ngf.prototype.transferHasFiles = function (transfer) {
if (!transfer.types) {
return false;
}
if (transfer.types.indexOf) {
return transfer.types.indexOf('Files') !== -1;
}
else if (transfer.types.contains) {
return transfer.types.contains('Files');
}
else {
return false;
}
};
ngf.prototype.eventToFiles = function (event) {
var transfer = eventToTransfer(event);
if (transfer) {
if (transfer.files && transfer.files.length) {
return transfer.files;
}
if (transfer.items && transfer.items.length) {
return transfer.items;
}
}
return [];
};
ngf.prototype.applyExifRotations = function (files) {
var mapper = function (file, index) {
return applyExifRotation(file)
.then(function (fixedFile) { return files.splice(index, 1, fixedFile); });
};
var proms = [];
for (var x = files.length - 1; x >= 0; --x) {
proms[x] = mapper(files[x], x);
}
return Promise.all(proms).then(function () { return files; });
};
ngf.prototype.onChange = function (event) {
var files = this.element.nativeElement.files || this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
};
ngf.prototype.getFileFilterFailName = function (file) {
for (var i = 0; i < this.filters.length; i++) {
if (!this.filters[i].fn.call(this, file)) {
return this.filters[i].name;
}
}
return undefined;
};
ngf.prototype.isFileValid = function (file) {
var noFilters = !this.accept && (!this.filters || !this.filters.length);
if (noFilters) {
return true; //we have no filters so all files are valid
}
return this.getFileFilterFailName(file) ? false : true;
};
ngf.prototype.isFilesValid = function (files) {
for (var x = files.length - 1; x >= 0; --x) {
if (!this.isFileValid(files[x])) {
return false;
}
}
return true;
};
ngf.prototype._acceptFilter = function (item) {
return acceptType(this.accept, item.type, item.name);
};
ngf.prototype._fileSizeFilter = function (item) {
return !(this.maxSize && item.size > this.maxSize);
};
return ngf;
}());
ngf.decorators = [
{ type: core.Directive, args: [{
selector: "[ngf]",
exportAs: "ngf"
},] }
];
ngf.ctorParameters = function () { return [
{ type: core.ElementRef }
]; };
ngf.propDecorators = {
multiple: [{ type: core.Input }],
accept: [{ type: core.Input }],
maxSize: [{ type: core.Input }],
ngfFixOrientation: [{ type: core.Input }],
fileDropDisabled: [{ type: core.Input }],
selectable: [{ type: core.Input }],
directiveInit: [{ type: core.Output, args: ['init',] }],
lastInvalids: [{ type: core.Input }],
lastInvalidsChange: [{ type: core.Output }],
lastBaseUrl: [{ type: core.Input }],
lastBaseUrlChange: [{ type: core.Output }],
file: [{ type: core.Input }],
fileChange: [{ type: core.Output }],
files: [{ type: core.Input }],
filesChange: [{ type: core.Output }],
fileSelectStart: [{ type: core.Output }],
capturePaste: [{ type: core.Input }],
onChange: [{ type: core.HostListener, args: ['change', ['$event'],] }]
};
/** browsers try hard to conceal data about file drags, this tends to undo that */
function filesToWriteableObject(files) {
var jsonFiles = [];
for (var x = 0; x < files.length; ++x) {
jsonFiles.push({
type: files[x].type,
kind: files[x]["kind"]
});
}
return jsonFiles;
}
function eventToTransfer(event) {
if (event.dataTransfer)
return event.dataTransfer;
return event.originalEvent ? event.originalEvent.dataTransfer : null;
}
var ngfSelect = /** @class */ (function (_super) {
__extends(ngfSelect, _super);
function ngfSelect() {
var _this = _super.apply(this, __spreadArray([], __read(arguments))) || this;
_this.selectable = true;
return _this;
}
return ngfSelect;
}(ngf));
ngfSelect.decorators = [
{ type: core.Directive, args: [{
selector: "[ngfSelect]",
exportAs: "ngfSelect"
},] }
];
ngfSelect.propDecorators = {
selectable: [{ type: core.Input }]
};
var ngfDrop = /** @class */ (function (_super) {
__extends(ngfDrop, _super);
function ngfDrop() {
var _this = _super.apply(this, __spreadArray([], __read(arguments))) || this;
_this.fileOver = new core.EventEmitter();
_this.validDrag = false;
_this.validDragChange = new core.EventEmitter();
_this.invalidDrag = false;
_this.invalidDragChange = new core.EventEmitter();
_this.dragFilesChange = new core.EventEmitter();
return _this;
}
ngfDrop.prototype.onDrop = function (event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
var files = this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
};
ngfDrop.prototype.handleFiles = function (files) {
this.fileOver.emit(false); //turn-off dragover
_super.prototype.handleFiles.call(this, files);
};
ngfDrop.prototype.onDragOver = function (event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
var transfer = eventToTransfer(event);
var files = this.eventToFiles(event);
var jsonFiles = filesToWriteableObject(files);
this.dragFilesChange.emit(this.dragFiles = jsonFiles);
if (files.length) {
this.validDrag = this.isFilesValid(files);
}
else {
//Safari, IE11 & some browsers do NOT tell you about dragged files until dropped. Always consider a valid drag
this.validDrag = true;
}
this.validDragChange.emit(this.validDrag);
this.invalidDrag = !this.validDrag;
this.invalidDragChange.emit(this.invalidDrag);
transfer.dropEffect = 'copy'; // change cursor and visual display
this.stopEvent(event);
this.fileOver.emit(true);
};
ngfDrop.prototype.closeDrags = function () {
delete this.validDrag;
this.validDragChange.emit(this.validDrag);
this.invalidDrag = false;
this.invalidDragChange.emit(this.invalidDrag);
delete this.dragFiles;
this.dragFilesChange.emit(this.dragFiles);
};
ngfDrop.prototype.onDragLeave = function (event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
if (this.element) {
if (event.currentTarget === this.element[0]) {
return;
}
}
this.stopEvent(event);
this.fileOver.emit(false);
};
return ngfDrop;
}(ngf));
ngfDrop.decorators = [
{ type: core.Directive, args: [{
selector: "[ngfDrop]",
exportAs: "ngfDrop"
},] }
];
ngfDrop.propDecorators = {
fileOver: [{ type: core.Output }],
validDrag: [{ type: core.Input }],
validDragChange: [{ type: core.Output }],
invalidDrag: [{ type: core.Input }],
invalidDragChange: [{ type: core.Output }],
dragFiles: [{ type: core.Input }],
dragFilesChange: [{ type: core.Output }],
onDrop: [{ type: core.HostListener, args: ['drop', ['$event'],] }],
onDragOver: [{ type: core.HostListener, args: ['dragover', ['$event'],] }],
onDragLeave: [{ type: core.HostListener, args: ['dragleave', ['$event'],] }]
};
var ngfBackground = /** @class */ (function () {
function ngfBackground(ElementRef) {
this.ElementRef = ElementRef;
}
ngfBackground.prototype.ngOnChanges = function (_changes) {
var _this = this;
dataUrl(this.file)
.then(function (src) {
var urlString = 'url(\'' + (src || '') + '\')';
_this.ElementRef.nativeElement.style.backgroundImage = urlString;
});
};
return ngfBackground;
}());
ngfBackground.decorators = [
{ type: core.Directive, args: [{ selector: '[ngfBackground]' },] }
];
ngfBackground.ctorParameters = function () { return [
{ type: core.ElementRef }
]; };
ngfBackground.propDecorators = {
file: [{ type: core.Input, args: ['ngfBackground',] }]
};
var ngfUploadStatus = /** @class */ (function () {
function ngfUploadStatus() {
this.percent = 0;
this.percentChange = new core.EventEmitter();
}
ngfUploadStatus.prototype.ngOnChanges = function (changes) {
var _this = this;
if (changes.httpEvent && changes.httpEvent.currentValue) {
var event_1 = changes.httpEvent.currentValue;
if (event_1.loaded && event_1.total) {
setTimeout(function () {
_this.percent = Math.round(100 * event_1.loaded / event_1.total);
_this.percentChange.emit(_this.percent);
}, 0);
}
}
};
return ngfUploadStatus;
}());
ngfUploadStatus.decorators = [
{ type: core.Directive, args: [{ selector: 'ngfUploadStatus' },] }
];
ngfUploadStatus.propDecorators = {
percent: [{ type: core.Input }],
percentChange: [{ type: core.Output }],
httpEvent: [{ type: core.Input }]
};
var ngfFormData = /** @class */ (function () {
function ngfFormData(IterableDiffers) {
this.postName = "file";
this.FormData = new FormData();
this.FormDataChange = new core.EventEmitter();
this.differ = IterableDiffers.find([]).create();
}
ngfFormData.prototype.ngDoCheck = function () {
var _this = this;
var changes = this.differ.diff(this.files);
if (changes) {
setTimeout(function () { return _this.buildFormData(); }, 0);
}
};
ngfFormData.prototype.buildFormData = function () {
var _this = this;
var isArray = typeof (this.files) === 'object' && this.files.constructor === Array;
if (isArray) {
this.FormData = new FormData();
var files = this.files || [];
files.forEach(function (file) { return _this.FormData.append(_this.postName, file, _this.fileName || file.name); });
this.FormDataChange.emit(this.FormData);
}
else {
delete this.FormData;
}
};
return ngfFormData;
}());
ngfFormData.decorators = [
{ type: core.Directive, args: [{ selector: 'ngfFormData' },] }
];
ngfFormData.ctorParameters = function () { return [
{ type: core.IterableDiffers }
]; };
ngfFormData.propDecorators = {
files: [{ type: core.Input }],
postName: [{ type: core.Input }],
fileName: [{ type: core.Input }],
FormData: [{ type: core.Input }],
FormDataChange: [{ type: core.Output }]
};
var ngfSrc = /** @class */ (function () {
function ngfSrc(ElementRef) {
this.ElementRef = ElementRef;
}
ngfSrc.prototype.ngOnChanges = function (_changes) {
var _this = this;
dataUrl(this.file)
.then(function (src) { return _this.ElementRef.nativeElement.src = src; });
};
return ngfSrc;
}());
ngfSrc.decorators = [
{ type: core.Directive, args: [{ selector: '[ngfSrc]' },] }
];
ngfSrc.ctorParameters = function () { return [
{ type: core.ElementRef }
]; };
ngfSrc.propDecorators = {
file: [{ type: core.Input, args: ['ngfSrc',] }]
};
//import{ HttpModule } from '@angular/http';
var declarations = [
ngfDrop,
ngfSelect,
ngfBackground,
ngfSrc,
ngfUploadStatus,
ngfFormData,
ngf
];
var ngfModule = /** @class */ (function () {
function ngfModule() {
}
return ngfModule;
}());
ngfModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
common.CommonModule
//,HttpModule
],
declarations: declarations,
exports: declarations //[HttpModule, ...declarations]
},] }
];
/*
* Public API Surface of angular-file
*/
/**
* Generated bundle index. Do not edit.
*/
exports.eventToTransfer = eventToTransfer;
exports.filesToWriteableObject = filesToWriteableObject;
exports.ngf = ngf;
exports.ngfBackground = ngfBackground;
exports.ngfDrop = ngfDrop;
exports.ngfFormData = ngfFormData;
exports.ngfModule = ngfModule;
exports.ngfSelect = ngfSelect;
exports.ngfSrc = ngfSrc;
exports.ngfUploadStatus = ngfUploadStatus;
Object.defineProperty(exports, '__esModule', { value: true });
}));
//# sourceMappingURL=angular-file-src.umd.js.map

Sorry, the diff of this file is too big to display

(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/common'), require('@angular/core')) :
typeof define === 'function' && define.amd ? define('angular-file', ['exports', '@angular/common', '@angular/core'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["angular-file"] = {}, global.ng.common, global.ng.core));
})(this, (function (exports, common, core) { 'use strict';
function getWindow() { return window; }
function acceptType(accept, type, name) {
if (!accept) {
return true;
}
var defs = accept.split(',');
var regx;
var acceptRegString;
for (var x = defs.length - 1; x >= 0; --x) {
//Escapes dots in mimetype
acceptRegString = defs[x];
//trim
acceptRegString = acceptRegString.replace(/(^\s+|\s+$)/g, '');
//Escapes stars in mimetype
acceptRegString = acceptRegString.replace(/\*/g, '.*');
//let acceptReg = '^((' + acceptRegString
//acceptReg = acceptReg.replace(/,/g,')|(') + '))$'
//try by mime
regx = new RegExp(acceptRegString, 'gi');
if (type.search(regx) >= 0) {
return true;
}
//try by ext
if (acceptRegString.substring(0, 1) == '.') {
acceptRegString = '\\' + acceptRegString; //.substring(1, acceptRegString.length-1)//remove dot at front
regx = new RegExp(acceptRegString + '$', 'i');
if ((name || type).search(regx) >= 0) {
return true;
}
}
}
return false;
}
function arrayBufferToBase64(buffer) {
var binary = '';
var bytes = new Uint8Array(buffer);
var len = bytes.byteLength;
for (var i = 0; i < len; i++) {
binary += String.fromCharCode(bytes[i]);
}
return window.btoa(binary);
}
function dataUrltoBlob(dataurl, name, origSize) {
var arr = dataurl.split(',');
var mimeMatch = arr[0].match(/:(.*?);/);
var mime = mimeMatch ? mimeMatch[1] : 'text/plain';
var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
var blob = new window.Blob([u8arr], { type: mime });
blob["name"] = name;
blob["$ngfOrigSize"] = origSize;
return blob;
}
function applyTransform(ctx, orientation, width, height) {
switch (orientation) {
case 2:
return ctx.transform(-1, 0, 0, 1, width, 0);
case 3:
return ctx.transform(-1, 0, 0, -1, width, height);
case 4:
return ctx.transform(1, 0, 0, -1, 0, height);
case 5:
return ctx.transform(0, 1, 1, 0, 0, 0);
case 6:
return ctx.transform(0, 1, -1, 0, height, 0);
case 7:
return ctx.transform(0, -1, -1, 0, height, width);
case 8:
return ctx.transform(0, -1, 1, 0, 0, width);
}
}
function fixFileOrientationByMeta(file, result) {
return dataUrl(file, true)
.then(function (url) {
var canvas = document.createElement('canvas');
var img = document.createElement('img');
return new Promise(function (res, rej) {
img.onload = function () {
try {
canvas.width = result.orientation > 4 ? img.height : img.width;
canvas.height = result.orientation > 4 ? img.width : img.height;
var ctx = canvas.getContext('2d');
applyTransform(ctx, result.orientation, img.width, img.height);
ctx.drawImage(img, 0, 0);
var dataUrl = canvas.toDataURL(file.type || 'image/WebP', 0.934);
var base = arrayBufferToBase64(result.fixedArrayBuffer);
dataUrl = restoreExif(base, dataUrl);
var blob = dataUrltoBlob(dataUrl, file.name);
var newFile = blobToFile(blob, file.name);
res(newFile);
}
catch (e) {
rej(e);
}
};
img.onerror = rej;
img.src = url;
});
});
}
function applyExifRotation(file) {
if (file.type.indexOf('image/jpeg') !== 0) {
return Promise.resolve(file);
}
return readOrientation(file)
.then(function (result) {
if (result.orientation < 2 || result.orientation > 8) {
return file;
}
return fixFileOrientationByMeta(file, result);
});
}
function readOrientation(file) {
return new Promise(function (res, rej) {
var reader = new FileReader();
var slicedFile = file.slice ? file.slice(0, 64 * 1024) : file;
reader.readAsArrayBuffer(slicedFile);
reader.onerror = rej;
reader.onload = function (e) {
var result = { orientation: 1 };
var view = new DataView(this.result);
if (view.getUint16(0, false) !== 0xFFD8)
return res(result);
var length = view.byteLength, offset = 2;
while (offset < length) {
var marker = view.getUint16(offset, false);
offset += 2;
if (marker === 0xFFE1) {
if (view.getUint32(offset += 2, false) !== 0x45786966)
return res(result);
var little = view.getUint16(offset += 6, false) === 0x4949;
offset += view.getUint32(offset + 4, little);
var tags = view.getUint16(offset, little);
offset += 2;
for (var i = 0; i < tags; i++)
if (view.getUint16(offset + (i * 12), little) === 0x0112) {
var orientation = view.getUint16(offset + (i * 12) + 8, little);
if (orientation >= 2 && orientation <= 8) {
view.setUint16(offset + (i * 12) + 8, 1, little);
result.fixedArrayBuffer = e.target.result;
}
result.orientation = orientation;
return res(result);
}
}
else if ((marker & 0xFF00) !== 0xFF00)
break;
else
offset += view.getUint16(offset, false);
}
return res(result);
};
});
}
/** converts file-input file into base64 dataUri */
function dataUrl(file, disallowObjectUrl) {
if (!file)
return Promise.resolve(file);
if ((disallowObjectUrl && file.$ngfDataUrl != null) || (!disallowObjectUrl && file.$ngfBlobUrl != null)) {
return Promise.resolve(disallowObjectUrl ? file.$ngfDataUrl : file.$ngfBlobUrl);
}
var p = disallowObjectUrl ? file.$$ngfDataUrlPromise : file.$$ngfBlobUrlPromise;
if (p)
return p;
var win = getWindow();
var deferred;
if (win.FileReader && file &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 8') === -1 || file.size < 20000) &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 9') === -1 || file.size < 4000000)) {
//prefer URL.createObjectURL for handling refrences to files of all sizes
//since it doesn´t build a large string in memory
var URL = win.URL || win.webkitURL;
if (FileReader) {
deferred = new Promise(function (res, rej) {
var fileReader = new FileReader();
fileReader.onload = function (event) {
file.$ngfDataUrl = event.target.result;
delete file.$ngfDataUrl;
res(event.target.result);
};
fileReader.onerror = function (e) {
file.$ngfDataUrl = '';
rej(e);
};
fileReader.readAsDataURL(file);
});
}
else {
var url;
try {
url = URL.createObjectURL(file);
}
catch (e) {
return Promise.reject(e);
}
deferred = Promise.resolve(url);
file.$ngfBlobUrl = url;
}
}
else {
file[disallowObjectUrl ? '$ngfDataUrl' : '$ngfBlobUrl'] = '';
return Promise.reject(new Error('Browser does not support window.FileReader, window.FileReader, or window.FileAPI')); //deferred.reject();
}
if (disallowObjectUrl) {
p = file.$$ngfDataUrlPromise = deferred;
}
else {
p = file.$$ngfBlobUrlPromise = deferred;
}
p = p.then(function (x) {
delete file[disallowObjectUrl ? '$$ngfDataUrlPromise' : '$$ngfBlobUrlPromise'];
return x;
});
return p;
}
function restoreExif(orig, resized) {
var ExifRestorer = {
KEY_STR: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='
};
ExifRestorer.encode64 = function (input) {
var output = '', chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0;
do {
chr1 = input[i++];
chr2 = input[i++];
chr3 = input[i++];
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
}
else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
this.KEY_STR.charAt(enc1) +
this.KEY_STR.charAt(enc2) +
this.KEY_STR.charAt(enc3) +
this.KEY_STR.charAt(enc4);
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return output;
};
ExifRestorer.restore = function (origFileBase64, resizedFileBase64) {
if (origFileBase64.match('data:image/jpeg;base64,')) {
origFileBase64 = origFileBase64.replace('data:image/jpeg;base64,', '');
}
var rawImage = this.decode64(origFileBase64);
var segments = this.slice2Segments(rawImage);
var image = this.exifManipulation(resizedFileBase64, segments);
return 'data:image/jpeg;base64,' + this.encode64(image);
};
ExifRestorer.exifManipulation = function (resizedFileBase64, segments) {
var exifArray = this.getExifArray(segments), newImageArray = this.insertExif(resizedFileBase64, exifArray);
return new Uint8Array(newImageArray);
};
ExifRestorer.getExifArray = function (segments) {
var seg;
for (var x = 0; x < segments.length; x++) {
seg = segments[x];
if (seg[0] === 255 && seg[1] === 225) //(ff e1)
{
return seg;
}
}
return [];
};
ExifRestorer.insertExif = function (resizedFileBase64, exifArray) {
var imageData = resizedFileBase64.replace('data:image/jpeg;base64,', ''), buf = this.decode64(imageData), separatePoint = buf.indexOf(255, 3), mae = buf.slice(0, separatePoint), ato = buf.slice(separatePoint), array = mae;
array = array.concat(exifArray);
array = array.concat(ato);
return array;
};
ExifRestorer.slice2Segments = function (rawImageArray) {
var head = 0, segments = [];
while (1) {
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 218) {
break;
}
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 216) {
head += 2;
}
else {
var length = rawImageArray[head + 2] * 256 + rawImageArray[head + 3];
var endPoint = head + length + 2;
var seg = rawImageArray.slice(head, endPoint);
segments.push(seg);
head = endPoint;
}
if (head > rawImageArray.length) {
break;
}
}
return segments;
};
ExifRestorer.decode64 = function (input) {
var chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0, buf = [];
// remove all characters that are not A-Z, a-z, 0-9, +, /, or =
var base64test = /[^A-Za-z0-9\+\/\=]/g;
if (base64test.exec(input)) {
console.log('There were invalid base64 characters in the input text.');
}
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, '');
do {
enc1 = this.KEY_STR.indexOf(input.charAt(i++));
enc2 = this.KEY_STR.indexOf(input.charAt(i++));
enc3 = this.KEY_STR.indexOf(input.charAt(i++));
enc4 = this.KEY_STR.indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
buf.push(chr1);
if (enc3 !== 64) {
buf.push(chr2);
}
if (enc4 !== 64) {
buf.push(chr3);
}
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return buf;
};
return ExifRestorer.restore(orig, resized); //<= EXIF
}
;
function blobToFile(theBlob, fileName) {
var b = theBlob;
//A Blob() is almost a File() - it's just missing the two properties below which we will add
b.lastModifiedDate = new Date();
b.name = fileName;
//Cast to a File() type
return theBlob;
}
var ngfBackground = /** @class */ (function () {
function ngfBackground(ElementRef) {
this.ElementRef = ElementRef;
}
ngfBackground.prototype.ngOnChanges = function (_changes) {
var _this = this;
dataUrl(this.file)
.then(function (src) {
var urlString = 'url(\'' + (src || '') + '\')';
_this.ElementRef.nativeElement.style.backgroundImage = urlString;
});
};
return ngfBackground;
}());
ngfBackground.decorators = [
{ type: core.Directive, args: [{ selector: '[ngfBackground]' },] }
];
ngfBackground.ctorParameters = function () { return [
{ type: core.ElementRef }
]; };
ngfBackground.propDecorators = {
file: [{ type: core.Input, args: ['ngfBackground',] }]
};
/******************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
/* global Reflect, Promise */
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b)
if (Object.prototype.hasOwnProperty.call(b, p))
d[p] = b[p]; };
return extendStatics(d, b);
};
function __extends(d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var __assign = function () {
__assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s)
if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
function __rest(s, e) {
var t = {};
for (var p in s)
if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
}
function __decorate(decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
r = Reflect.decorate(decorators, target, key, desc);
else
for (var i = decorators.length - 1; i >= 0; i--)
if (d = decorators[i])
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
}
function __param(paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); };
}
function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
function accept(f) { if (f !== void 0 && typeof f !== "function")
throw new TypeError("Function expected"); return f; }
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
var _, done = false;
for (var i = decorators.length - 1; i >= 0; i--) {
var context = {};
for (var p in contextIn)
context[p] = p === "access" ? {} : contextIn[p];
for (var p in contextIn.access)
context.access[p] = contextIn.access[p];
context.addInitializer = function (f) { if (done)
throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
if (kind === "accessor") {
if (result === void 0)
continue;
if (result === null || typeof result !== "object")
throw new TypeError("Object expected");
if (_ = accept(result.get))
descriptor.get = _;
if (_ = accept(result.set))
descriptor.set = _;
if (_ = accept(result.init))
initializers.push(_);
}
else if (_ = accept(result)) {
if (kind === "field")
initializers.push(_);
else
descriptor[key] = _;
}
}
if (target)
Object.defineProperty(target, contextIn.name, descriptor);
done = true;
}
;
function __runInitializers(thisArg, initializers, value) {
var useValue = arguments.length > 2;
for (var i = 0; i < initializers.length; i++) {
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
}
return useValue ? value : void 0;
}
;
function __propKey(x) {
return typeof x === "symbol" ? x : "".concat(x);
}
;
function __setFunctionName(f, name, prefix) {
if (typeof name === "symbol")
name = name.description ? "[".concat(name.description, "]") : "";
return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
}
;
function __metadata(metadataKey, metadataValue) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
return Reflect.metadata(metadataKey, metadataValue);
}
function __awaiter(thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try {
step(generator.next(value));
}
catch (e) {
reject(e);
} }
function rejected(value) { try {
step(generator["throw"](value));
}
catch (e) {
reject(e);
} }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
}
function __generator(thisArg, body) {
var _ = { label: 0, sent: function () { if (t[0] & 1)
throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function () { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f)
throw new TypeError("Generator is already executing.");
while (g && (g = 0, op[0] && (_ = 0)), _)
try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done)
return t;
if (y = 0, t)
op = [op[0] & 2, t.value];
switch (op[0]) {
case 0:
case 1:
t = op;
break;
case 4:
_.label++;
return { value: op[1], done: false };
case 5:
_.label++;
y = op[1];
op = [0];
continue;
case 7:
op = _.ops.pop();
_.trys.pop();
continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
_ = 0;
continue;
}
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) {
_.label = op[1];
break;
}
if (op[0] === 6 && _.label < t[1]) {
_.label = t[1];
t = op;
break;
}
if (t && _.label < t[2]) {
_.label = t[2];
_.ops.push(op);
break;
}
if (t[2])
_.ops.pop();
_.trys.pop();
continue;
}
op = body.call(thisArg, _);
}
catch (e) {
op = [6, e];
y = 0;
}
finally {
f = t = 0;
}
if (op[0] & 5)
throw op[1];
return { value: op[0] ? op[1] : void 0, done: true };
}
}
var __createBinding = Object.create ? (function (o, m, k, k2) {
if (k2 === undefined)
k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function () { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function (o, m, k, k2) {
if (k2 === undefined)
k2 = k;
o[k2] = m[k];
});
function __exportStar(m, o) {
for (var p in m)
if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p))
__createBinding(o, m, p);
}
function __values(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m)
return m.call(o);
if (o && typeof o.length === "number")
return {
next: function () {
if (o && i >= o.length)
o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
}
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m)
return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done)
ar.push(r.value);
}
catch (error) {
e = { error: error };
}
finally {
try {
if (r && !r.done && (m = i["return"]))
m.call(i);
}
finally {
if (e)
throw e.error;
}
}
return ar;
}
/** @deprecated */
function __spread() {
for (var ar = [], i = 0; i < arguments.length; i++)
ar = ar.concat(__read(arguments[i]));
return ar;
}
/** @deprecated */
function __spreadArrays() {
for (var s = 0, i = 0, il = arguments.length; i < il; i++)
s += arguments[i].length;
for (var r = Array(s), k = 0, i = 0; i < il; i++)
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
r[k] = a[j];
return r;
}
function __spreadArray(to, from, pack) {
if (pack || arguments.length === 2)
for (var i = 0, l = from.length, ar; i < l; i++) {
if (ar || !(i in from)) {
if (!ar)
ar = Array.prototype.slice.call(from, 0, i);
ar[i] = from[i];
}
}
return to.concat(ar || Array.prototype.slice.call(from));
}
function __await(v) {
return this instanceof __await ? (this.v = v, this) : new __await(v);
}
function __asyncGenerator(thisArg, _arguments, generator) {
if (!Symbol.asyncIterator)
throw new TypeError("Symbol.asyncIterator is not defined.");
var g = generator.apply(thisArg, _arguments || []), i, q = [];
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
function verb(n) { if (g[n])
i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
function resume(n, v) { try {
step(g[n](v));
}
catch (e) {
settle(q[0][3], e);
} }
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
function fulfill(value) { resume("next", value); }
function reject(value) { resume("throw", value); }
function settle(f, v) { if (f(v), q.shift(), q.length)
resume(q[0][0], q[0][1]); }
}
function __asyncDelegator(o) {
var i, p;
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }
}
function __asyncValues(o) {
if (!Symbol.asyncIterator)
throw new TypeError("Symbol.asyncIterator is not defined.");
var m = o[Symbol.asyncIterator], i;
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function (v) { resolve({ value: v, done: d }); }, reject); }
}
function __makeTemplateObject(cooked, raw) {
if (Object.defineProperty) {
Object.defineProperty(cooked, "raw", { value: raw });
}
else {
cooked.raw = raw;
}
return cooked;
}
;
var __setModuleDefault = Object.create ? (function (o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function (o, v) {
o["default"] = v;
};
function __importStar(mod) {
if (mod && mod.__esModule)
return mod;
var result = {};
if (mod != null)
for (var k in mod)
if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k))
__createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
}
function __importDefault(mod) {
return (mod && mod.__esModule) ? mod : { default: mod };
}
function __classPrivateFieldGet(receiver, state, kind, f) {
if (kind === "a" && !f)
throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
}
function __classPrivateFieldSet(receiver, state, value, kind, f) {
if (kind === "m")
throw new TypeError("Private method is not writable");
if (kind === "a" && !f)
throw new TypeError("Private accessor was defined without a setter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
throw new TypeError("Cannot write private member to an object whose class did not declare it");
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
}
function __classPrivateFieldIn(state, receiver) {
if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function"))
throw new TypeError("Cannot use 'in' operator on non-object");
return typeof state === "function" ? receiver === state : state.has(receiver);
}
var isFileInput = function (elm) {
var ty = elm.getAttribute('type');
return elm.tagName.toLowerCase() === 'input' && ty && ty.toLowerCase() === 'file';
};
var initialTouchStartY = 0;
var initialTouchStartX = 0;
var detectSwipe = function (evt) {
var touches = evt.changedTouches || (evt.originalEvent && evt.originalEvent.changedTouches);
if (touches) {
if (evt.type === 'touchstart') {
initialTouchStartX = touches[0].clientX;
initialTouchStartY = touches[0].clientY;
return true; // don't block event default
}
else {
// prevent scroll from triggering event
if (evt.type === 'touchend') {
var currentX = touches[0].clientX;
var currentY = touches[0].clientY;
if ((Math.abs(currentX - initialTouchStartX) > 20) ||
(Math.abs(currentY - initialTouchStartY) > 20)) {
evt.stopPropagation();
if (evt.cancelable) {
evt.preventDefault();
}
return false;
}
}
return true;
}
}
return false;
};
var createInvisibleFileInputWrap = function () {
var fileElem = createFileInput();
var label = document.createElement('label');
label.innerHTML = 'upload';
label.style.visibility = 'hidden';
label.style.position = 'absolute';
label.style.overflow = 'hidden';
label.style.width = '0px';
label.style.height = '0px';
label.style.border = 'none';
label.style.margin = '0px';
label.style.padding = '0px';
label.setAttribute('tabindex', '-1');
//bindAttrToFileInput(fileElem, label);
//generatedElems.push({el: elem, ref: label});
label.appendChild(fileElem);
//document.body.appendChild( label );
return label;
};
var createFileInput = function () {
var fileElem = document.createElement('input');
fileElem.type = "file";
return fileElem;
};
/** A master base set of logic intended to support file select/drag/drop operations
NOTE: Use ngfDrop for full drag/drop. Use ngfSelect for selecting
*/
var ngf = /** @class */ (function () {
function ngf(element) {
this.element = element;
this.filters = [];
this.lastFileCount = 0;
this.ngfFixOrientation = true;
this.fileDropDisabled = false;
this.selectable = false;
this.directiveInit = new core.EventEmitter();
this.lastInvalids = [];
this.lastInvalidsChange = new core.EventEmitter();
this.lastBaseUrlChange = new core.EventEmitter();
this.fileChange = new core.EventEmitter();
this.files = [];
this.filesChange = new core.EventEmitter();
this.fileSelectStart = new core.EventEmitter();
this.initFilters();
}
ngf.prototype.initFilters = function () {
// the order is important
this.filters.push({ name: 'accept', fn: this._acceptFilter });
this.filters.push({ name: 'fileSize', fn: this._fileSizeFilter });
//this.filters.push({name: 'fileType', fn: this._fileTypeFilter})
//this.filters.push({name: 'queueLimit', fn: this._queueLimitFilter})
//this.filters.push({name: 'mimeType', fn: this._mimeTypeFilter})
};
ngf.prototype.ngOnDestroy = function () {
delete this.fileElm; //faster memory release of dom element
this.destroyPasteListener();
};
ngf.prototype.ngOnInit = function () {
var _this = this;
var selectable = (this.selectable || this.selectable === '') && !['false', 'null', '0'].includes(this.selectable);
if (selectable) {
this.enableSelecting();
}
if (this.multiple) {
this.paramFileElm().setAttribute('multiple', this.multiple);
}
this.evalCapturePaste();
// create reference to this class with one cycle delay to avoid ExpressionChangedAfterItHasBeenCheckedError
setTimeout(function () {
_this.directiveInit.emit(_this);
}, 0);
};
ngf.prototype.ngOnChanges = function (changes) {
var _a, _b;
if (changes.accept) {
this.paramFileElm().setAttribute('accept', changes.accept.currentValue || '*');
}
if (changes.capturePaste) {
this.evalCapturePaste();
}
// Did we go from having a file to not having a file? Clear file element then
if (changes.file && changes.file.previousValue && !changes.file.currentValue) {
this.clearFileElmValue();
}
// Did we go from having files to not having files? Clear file element then
if (changes.files) {
var filesWentToZero = ((_a = changes.files.previousValue) === null || _a === void 0 ? void 0 : _a.length) && !((_b = changes.files.currentValue) === null || _b === void 0 ? void 0 : _b.length);
if (filesWentToZero) {
this.clearFileElmValue();
}
}
};
ngf.prototype.evalCapturePaste = function () {
var _this = this;
var isActive = this.capturePaste || this.capturePaste === '' || ['false', '0', 'null'].includes(this.capturePaste);
if (isActive) {
if (this.pasteCapturer) {
return; // already listening
}
this.pasteCapturer = function (e) {
var clip = e.clipboardData;
if (clip && clip.files && clip.files.length) {
_this.handleFiles(clip.files);
e.preventDefault();
}
};
window.addEventListener('paste', this.pasteCapturer);
return;
}
this.destroyPasteListener();
};
ngf.prototype.destroyPasteListener = function () {
if (this.pasteCapturer) {
window.removeEventListener('paste', this.pasteCapturer);
delete this.pasteCapturer;
}
};
ngf.prototype.paramFileElm = function () {
if (this.fileElm)
return this.fileElm; // already defined
// elm already is a file input
var isFile = isFileInput(this.element.nativeElement);
if (isFile) {
return this.fileElm = this.element.nativeElement;
}
// the host elm is NOT a file input
return this.fileElm = this.createFileElm({
change: this.changeFn.bind(this)
});
};
/** Only used when host element we are attached to is NOT a fileElement */
ngf.prototype.createFileElm = function (_c) {
var change = _c.change;
// use specific technique to hide file element within
var label = createInvisibleFileInputWrap();
var fileElm = label.getElementsByTagName('input')[0];
fileElm.addEventListener('change', change);
this.element.nativeElement.appendChild(label); // put on html stage
return fileElm;
};
ngf.prototype.enableSelecting = function () {
var _this = this;
var elm = this.element.nativeElement;
if (isFileInput(elm)) {
var bindedHandler_1 = function (event) { return _this.beforeSelect(event); };
elm.addEventListener('click', bindedHandler_1);
elm.addEventListener('touchstart', bindedHandler_1);
return;
}
var bindedHandler = function (ev) { return _this.clickHandler(ev); };
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
elm.addEventListener('touchend', bindedHandler);
};
ngf.prototype.getValidFiles = function (files) {
var rtn = [];
for (var x = files.length - 1; x >= 0; --x) {
if (this.isFileValid(files[x])) {
rtn.push(files[x]);
}
}
return rtn;
};
ngf.prototype.getInvalidFiles = function (files) {
var rtn = [];
for (var x = files.length - 1; x >= 0; --x) {
var failReason = this.getFileFilterFailName(files[x]);
if (failReason) {
rtn.push({
file: files[x],
type: failReason
});
}
}
return rtn;
};
// Primary handler of files coming in
ngf.prototype.handleFiles = function (files) {
var _this = this;
var valids = this.getValidFiles(files);
if (files.length != valids.length) {
this.lastInvalids = this.getInvalidFiles(files);
}
else {
delete this.lastInvalids;
}
this.lastInvalidsChange.emit(this.lastInvalids);
if (valids.length) {
if (this.ngfFixOrientation) {
this.applyExifRotations(valids)
.then(function (fixedFiles) { return _this.que(fixedFiles); });
}
else {
this.que(valids);
}
}
if (this.isEmptyAfterSelection()) {
this.element.nativeElement.value = '';
}
};
ngf.prototype.que = function (files) {
var _this = this;
this.files = this.files || [];
Array.prototype.push.apply(this.files, files);
//below break memory ref and doesnt act like a que
//this.files = files//causes memory change which triggers bindings like <ngfFormData [files]="files"></ngfFormData>
this.filesChange.emit(this.files);
if (files.length) {
this.fileChange.emit(this.file = files[0]);
if (this.lastBaseUrlChange.observers.length) {
dataUrl(files[0])
.then(function (url) { return _this.lastBaseUrlChange.emit(url); });
}
}
//will be checked for input value clearing
this.lastFileCount = this.files.length;
};
/** called when input has files */
ngf.prototype.changeFn = function (event) {
var fileList = event.__files_ || (event.target && event.target.files);
if (!fileList)
return;
this.stopEvent(event);
this.handleFiles(fileList);
};
ngf.prototype.clickHandler = function (evt) {
var elm = this.element.nativeElement;
if (elm.getAttribute('disabled') || this.fileDropDisabled) {
return false;
}
var r = detectSwipe(evt);
// prevent the click if it is a swipe
if (r !== false)
return r;
var fileElm = this.paramFileElm();
fileElm.click();
//fileElm.dispatchEvent( new Event('click') );
this.beforeSelect(evt);
return false;
};
ngf.prototype.beforeSelect = function (event) {
this.fileSelectStart.emit(event);
if (this.files && this.lastFileCount === this.files.length)
return;
// if no files in array, be sure browser does not prevent reselect of same file (see github issue 27)
this.clearFileElmValue();
};
ngf.prototype.clearFileElmValue = function () {
if (!this.fileElm)
return;
this.fileElm.value = null;
};
ngf.prototype.isEmptyAfterSelection = function () {
return !!this.element.nativeElement.attributes.multiple;
};
ngf.prototype.stopEvent = function (event) {
event.preventDefault();
event.stopPropagation();
};
ngf.prototype.transferHasFiles = function (transfer) {
if (!transfer.types) {
return false;
}
if (transfer.types.indexOf) {
return transfer.types.indexOf('Files') !== -1;
}
else if (transfer.types.contains) {
return transfer.types.contains('Files');
}
else {
return false;
}
};
ngf.prototype.eventToFiles = function (event) {
var transfer = eventToTransfer(event);
if (transfer) {
if (transfer.files && transfer.files.length) {
return transfer.files;
}
if (transfer.items && transfer.items.length) {
return transfer.items;
}
}
return [];
};
ngf.prototype.applyExifRotations = function (files) {
var mapper = function (file, index) {
return applyExifRotation(file)
.then(function (fixedFile) { return files.splice(index, 1, fixedFile); });
};
var proms = [];
for (var x = files.length - 1; x >= 0; --x) {
proms[x] = mapper(files[x], x);
}
return Promise.all(proms).then(function () { return files; });
};
ngf.prototype.onChange = function (event) {
var files = this.element.nativeElement.files || this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
};
ngf.prototype.getFileFilterFailName = function (file) {
for (var i = 0; i < this.filters.length; i++) {
if (!this.filters[i].fn.call(this, file)) {
return this.filters[i].name;
}
}
return undefined;
};
ngf.prototype.isFileValid = function (file) {
var noFilters = !this.accept && (!this.filters || !this.filters.length);
if (noFilters) {
return true; //we have no filters so all files are valid
}
return this.getFileFilterFailName(file) ? false : true;
};
ngf.prototype.isFilesValid = function (files) {
for (var x = files.length - 1; x >= 0; --x) {
if (!this.isFileValid(files[x])) {
return false;
}
}
return true;
};
ngf.prototype._acceptFilter = function (item) {
return acceptType(this.accept, item.type, item.name);
};
ngf.prototype._fileSizeFilter = function (item) {
return !(this.maxSize && item.size > this.maxSize);
};
return ngf;
}());
ngf.decorators = [
{ type: core.Directive, args: [{
selector: "[ngf]",
exportAs: "ngf"
},] }
];
ngf.ctorParameters = function () { return [
{ type: core.ElementRef }
]; };
ngf.propDecorators = {
multiple: [{ type: core.Input }],
accept: [{ type: core.Input }],
maxSize: [{ type: core.Input }],
ngfFixOrientation: [{ type: core.Input }],
fileDropDisabled: [{ type: core.Input }],
selectable: [{ type: core.Input }],
directiveInit: [{ type: core.Output, args: ['init',] }],
lastInvalids: [{ type: core.Input }],
lastInvalidsChange: [{ type: core.Output }],
lastBaseUrl: [{ type: core.Input }],
lastBaseUrlChange: [{ type: core.Output }],
file: [{ type: core.Input }],
fileChange: [{ type: core.Output }],
files: [{ type: core.Input }],
filesChange: [{ type: core.Output }],
fileSelectStart: [{ type: core.Output }],
capturePaste: [{ type: core.Input }],
onChange: [{ type: core.HostListener, args: ['change', ['$event'],] }]
};
/** browsers try hard to conceal data about file drags, this tends to undo that */
function filesToWriteableObject(files) {
var jsonFiles = [];
for (var x = 0; x < files.length; ++x) {
jsonFiles.push({
type: files[x].type,
kind: files[x]["kind"]
});
}
return jsonFiles;
}
function eventToTransfer(event) {
if (event.dataTransfer)
return event.dataTransfer;
return event.originalEvent ? event.originalEvent.dataTransfer : null;
}
var ngfDrop = /** @class */ (function (_super) {
__extends(ngfDrop, _super);
function ngfDrop() {
var _this = _super.apply(this, __spreadArray([], __read(arguments))) || this;
_this.fileOver = new core.EventEmitter();
_this.validDrag = false;
_this.validDragChange = new core.EventEmitter();
_this.invalidDrag = false;
_this.invalidDragChange = new core.EventEmitter();
_this.dragFilesChange = new core.EventEmitter();
return _this;
}
ngfDrop.prototype.onDrop = function (event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
var files = this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
};
ngfDrop.prototype.handleFiles = function (files) {
this.fileOver.emit(false); //turn-off dragover
_super.prototype.handleFiles.call(this, files);
};
ngfDrop.prototype.onDragOver = function (event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
var transfer = eventToTransfer(event);
var files = this.eventToFiles(event);
var jsonFiles = filesToWriteableObject(files);
this.dragFilesChange.emit(this.dragFiles = jsonFiles);
if (files.length) {
this.validDrag = this.isFilesValid(files);
}
else {
//Safari, IE11 & some browsers do NOT tell you about dragged files until dropped. Always consider a valid drag
this.validDrag = true;
}
this.validDragChange.emit(this.validDrag);
this.invalidDrag = !this.validDrag;
this.invalidDragChange.emit(this.invalidDrag);
transfer.dropEffect = 'copy'; // change cursor and visual display
this.stopEvent(event);
this.fileOver.emit(true);
};
ngfDrop.prototype.closeDrags = function () {
delete this.validDrag;
this.validDragChange.emit(this.validDrag);
this.invalidDrag = false;
this.invalidDragChange.emit(this.invalidDrag);
delete this.dragFiles;
this.dragFilesChange.emit(this.dragFiles);
};
ngfDrop.prototype.onDragLeave = function (event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
if (this.element) {
if (event.currentTarget === this.element[0]) {
return;
}
}
this.stopEvent(event);
this.fileOver.emit(false);
};
return ngfDrop;
}(ngf));
ngfDrop.decorators = [
{ type: core.Directive, args: [{
selector: "[ngfDrop]",
exportAs: "ngfDrop"
},] }
];
ngfDrop.propDecorators = {
fileOver: [{ type: core.Output }],
validDrag: [{ type: core.Input }],
validDragChange: [{ type: core.Output }],
invalidDrag: [{ type: core.Input }],
invalidDragChange: [{ type: core.Output }],
dragFiles: [{ type: core.Input }],
dragFilesChange: [{ type: core.Output }],
onDrop: [{ type: core.HostListener, args: ['drop', ['$event'],] }],
onDragOver: [{ type: core.HostListener, args: ['dragover', ['$event'],] }],
onDragLeave: [{ type: core.HostListener, args: ['dragleave', ['$event'],] }]
};
var ngfSelect = /** @class */ (function (_super) {
__extends(ngfSelect, _super);
function ngfSelect() {
var _this = _super.apply(this, __spreadArray([], __read(arguments))) || this;
_this.selectable = true;
return _this;
}
return ngfSelect;
}(ngf));
ngfSelect.decorators = [
{ type: core.Directive, args: [{
selector: "[ngfSelect]",
exportAs: "ngfSelect"
},] }
];
ngfSelect.propDecorators = {
selectable: [{ type: core.Input }]
};
var ngfUploadStatus = /** @class */ (function () {
function ngfUploadStatus() {
this.percent = 0;
this.percentChange = new core.EventEmitter();
}
ngfUploadStatus.prototype.ngOnChanges = function (changes) {
var _this = this;
if (changes.httpEvent && changes.httpEvent.currentValue) {
var event_1 = changes.httpEvent.currentValue;
if (event_1.loaded && event_1.total) {
setTimeout(function () {
_this.percent = Math.round(100 * event_1.loaded / event_1.total);
_this.percentChange.emit(_this.percent);
}, 0);
}
}
};
return ngfUploadStatus;
}());
ngfUploadStatus.decorators = [
{ type: core.Directive, args: [{ selector: 'ngfUploadStatus' },] }
];
ngfUploadStatus.propDecorators = {
percent: [{ type: core.Input }],
percentChange: [{ type: core.Output }],
httpEvent: [{ type: core.Input }]
};
var ngfFormData = /** @class */ (function () {
function ngfFormData(IterableDiffers) {
this.postName = "file";
this.FormData = new FormData();
this.FormDataChange = new core.EventEmitter();
this.differ = IterableDiffers.find([]).create();
}
ngfFormData.prototype.ngDoCheck = function () {
var _this = this;
var changes = this.differ.diff(this.files);
if (changes) {
setTimeout(function () { return _this.buildFormData(); }, 0);
}
};
ngfFormData.prototype.buildFormData = function () {
var _this = this;
var isArray = typeof (this.files) === 'object' && this.files.constructor === Array;
if (isArray) {
this.FormData = new FormData();
var files = this.files || [];
files.forEach(function (file) { return _this.FormData.append(_this.postName, file, _this.fileName || file.name); });
this.FormDataChange.emit(this.FormData);
}
else {
delete this.FormData;
}
};
return ngfFormData;
}());
ngfFormData.decorators = [
{ type: core.Directive, args: [{ selector: 'ngfFormData' },] }
];
ngfFormData.ctorParameters = function () { return [
{ type: core.IterableDiffers }
]; };
ngfFormData.propDecorators = {
files: [{ type: core.Input }],
postName: [{ type: core.Input }],
fileName: [{ type: core.Input }],
FormData: [{ type: core.Input }],
FormDataChange: [{ type: core.Output }]
};
var ngfSrc = /** @class */ (function () {
function ngfSrc(ElementRef) {
this.ElementRef = ElementRef;
}
ngfSrc.prototype.ngOnChanges = function (_changes) {
var _this = this;
dataUrl(this.file)
.then(function (src) { return _this.ElementRef.nativeElement.src = src; });
};
return ngfSrc;
}());
ngfSrc.decorators = [
{ type: core.Directive, args: [{ selector: '[ngfSrc]' },] }
];
ngfSrc.ctorParameters = function () { return [
{ type: core.ElementRef }
]; };
ngfSrc.propDecorators = {
file: [{ type: core.Input, args: ['ngfSrc',] }]
};
//import{ HttpModule } from '@angular/http';
var declarations = [
ngfDrop,
ngfSelect,
ngfBackground,
ngfSrc,
ngfUploadStatus,
ngfFormData,
ngf
];
var ngfModule = /** @class */ (function () {
function ngfModule() {
}
return ngfModule;
}());
ngfModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
common.CommonModule
//,HttpModule
],
declarations: declarations,
exports: declarations //[HttpModule, ...declarations]
},] }
];
/**
* Generated bundle index. Do not edit.
*/
exports.ngfModule = ngfModule;
exports["ɵa"] = ngfDrop;
exports["ɵb"] = ngf;
exports["ɵc"] = ngfSelect;
exports["ɵd"] = ngfBackground;
exports["ɵe"] = ngfSrc;
exports["ɵf"] = ngfUploadStatus;
exports["ɵg"] = ngfFormData;
Object.defineProperty(exports, '__esModule', { value: true });
}));
//# sourceMappingURL=angular-file.umd.js.map

Sorry, the diff of this file is too big to display

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-file",["exports","@angular/core","@angular/common"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["angular-file"]={},e.ng.core,e.ng.common)}(this,(function(e,t,n){"use strict";var i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n])})(e,t)};function r(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Class extends value "+String(t)+" is not a constructor or null");function n(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}Object.create;function a(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var i,r,a=n.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(i=a.next()).done;)s.push(i.value)}catch(e){r={error:e}}finally{try{i&&!i.done&&(n=a.return)&&n.call(a)}finally{if(r)throw r.error}}return s}function s(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(a(arguments[t]));return e}Object.create;var o=function(e){var t=e.getAttribute("type");return"input"===e.tagName.toLowerCase()&&t&&"file"===t.toLowerCase()},l=0,u=0,f=function(){var e=document.createElement("input");return e.type="file",e};function p(e,t){return h(e,!0).then((function(n){var i=document.createElement("canvas"),r=document.createElement("img");return new Promise((function(a,s){r.onload=function(){try{i.width=t.orientation>4?r.height:r.width,i.height=t.orientation>4?r.width:r.height;var n=i.getContext("2d");!function(e,t,n,i){switch(t){case 2:return e.transform(-1,0,0,1,n,0);case 3:return e.transform(-1,0,0,-1,n,i);case 4:return e.transform(1,0,0,-1,0,i);case 5:return e.transform(0,1,1,0,0,0);case 6:return e.transform(0,1,-1,0,i,0);case 7:return e.transform(0,-1,-1,0,i,n);case 8:e.transform(0,-1,1,0,0,n)}}(n,t.orientation,r.width,r.height),n.drawImage(r,0,0);var o=i.toDataURL(e.type||"image/WebP",.934),l=function(e){for(var t="",n=new Uint8Array(e),i=n.byteLength,r=0;r<i;r++)t+=String.fromCharCode(n[r]);return window.btoa(t)}(t.fixedArrayBuffer),u=function(e,t,n){for(var i=e.split(","),r=i[0].match(/:(.*?);/),a=r?r[1]:"text/plain",s=atob(i[1]),o=s.length,l=new Uint8Array(o);o--;)l[o]=s.charCodeAt(o);var u=new window.Blob([l],{type:a});return u.name=t,u.$ngfOrigSize=n,u}(o={KEY_STR:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",encode64:function(e){var t,n,i,r,a,s="",o="",l="",u=0;do{i=(t=e[u++])>>2,r=(3&t)<<4|(n=e[u++])>>4,a=(15&n)<<2|(o=e[u++])>>6,l=63&o,isNaN(n)?a=l=64:isNaN(o)&&(l=64),s=s+this.KEY_STR.charAt(i)+this.KEY_STR.charAt(r)+this.KEY_STR.charAt(a)+this.KEY_STR.charAt(l),t=n=o="",i=r=a=l=""}while(u<e.length);return s},restore:function(e,t){e.match("data:image/jpeg;base64,")&&(e=e.replace("data:image/jpeg;base64,",""));var n=this.decode64(e),i=this.slice2Segments(n),r=this.exifManipulation(t,i);return"data:image/jpeg;base64,"+this.encode64(r)},exifManipulation:function(e,t){var n=this.getExifArray(t),i=this.insertExif(e,n);return new Uint8Array(i)},getExifArray:function(e){for(var t,n=0;n<e.length;n++)if(255===(t=e[n])[0]&&225===t[1])return t;return[]},insertExif:function(e,t){var n=e.replace("data:image/jpeg;base64,",""),i=this.decode64(n),r=i.indexOf(255,3),a=i.slice(0,r),s=i.slice(r),o=a;return o=(o=o.concat(t)).concat(s)},slice2Segments:function(e){for(var t=0,n=[];255!==e[t]||218!==e[t+1];){if(255===e[t]&&216===e[t+1])t+=2;else{var i=t+(256*e[t+2]+e[t+3])+2,r=e.slice(t,i);n.push(r),t=i}if(t>e.length)break}return n},decode64:function(e){var t,n,i,r,a="",s="",o=0,l=[];/[^A-Za-z0-9\+\/\=]/g.exec(e)&&console.log("There were invalid base64 characters in the input text."),e=e.replace(/[^A-Za-z0-9\+\/\=]/g,"");do{t=this.KEY_STR.indexOf(e.charAt(o++))<<2|(i=this.KEY_STR.indexOf(e.charAt(o++)))>>4,n=(15&i)<<4|(r=this.KEY_STR.indexOf(e.charAt(o++)))>>2,a=(3&r)<<6|(s=this.KEY_STR.indexOf(e.charAt(o++))),l.push(t),64!==r&&l.push(n),64!==s&&l.push(a),t=n=a="",i=r=s=""}while(o<e.length);return l}}.restore(l,o),e.name),f=(p=u,c=e.name,(h=p).lastModifiedDate=new Date,h.name=c,p);a(f)}catch(e){s(e)}var p,c,h},r.onerror=s,r.src=n}))}))}function c(e){return 0!==e.type.indexOf("image/jpeg")?Promise.resolve(e):function(e){return new Promise((function(t,n){var i=new FileReader,r=e.slice?e.slice(0,65536):e;i.readAsArrayBuffer(r),i.onerror=n,i.onload=function(e){var n={orientation:1},i=new DataView(this.result);if(65496!==i.getUint16(0,!1))return t(n);for(var r=i.byteLength,a=2;a<r;){var s=i.getUint16(a,!1);if(a+=2,65505===s){if(1165519206!==i.getUint32(a+=2,!1))return t(n);var o=18761===i.getUint16(a+=6,!1);a+=i.getUint32(a+4,o);var l=i.getUint16(a,o);a+=2;for(var u=0;u<l;u++)if(274===i.getUint16(a+12*u,o)){var f=i.getUint16(a+12*u+8,o);return f>=2&&f<=8&&(i.setUint16(a+12*u+8,1,o),n.fixedArrayBuffer=e.target.result),n.orientation=f,t(n)}}else{if(65280!=(65280&s))break;a+=i.getUint16(a,!1)}}return t(n)}}))}(e).then((function(t){return t.orientation<2||t.orientation>8?e:p(e,t)}))}function h(e,t){if(!e)return Promise.resolve(e);if(t&&null!=e.$ngfDataUrl||!t&&null!=e.$ngfBlobUrl)return Promise.resolve(t?e.$ngfDataUrl:e.$ngfBlobUrl);var n=t?e.$$ngfDataUrlPromise:e.$$ngfBlobUrlPromise;if(n)return n;var i,r=window;if(!r.FileReader||!e||r.FileAPI&&-1!==navigator.userAgent.indexOf("MSIE 8")&&!(e.size<2e4)||r.FileAPI&&-1!==navigator.userAgent.indexOf("MSIE 9")&&!(e.size<4e6))return e[t?"$ngfDataUrl":"$ngfBlobUrl"]="",Promise.reject(new Error("Browser does not support window.FileReader, window.FileReader, or window.FileAPI"));var a=r.URL||r.webkitURL;if(FileReader)i=new Promise((function(t,n){var i=new FileReader;i.onload=function(n){e.$ngfDataUrl=n.target.result,delete e.$ngfDataUrl,t(n.target.result)},i.onerror=function(t){e.$ngfDataUrl="",n(t)},i.readAsDataURL(e)}));else{var s;try{s=a.createObjectURL(e)}catch(e){return Promise.reject(e)}i=Promise.resolve(s),e.$ngfBlobUrl=s}return n=(n=t?e.$$ngfDataUrlPromise=i:e.$$ngfBlobUrlPromise=i).then((function(n){return delete e[t?"$$ngfDataUrlPromise":"$$ngfBlobUrlPromise"],n}))}var g=function(){function e(e){this.element=e,this.filters=[],this.lastFileCount=0,this.ngfFixOrientation=!0,this.fileDropDisabled=!1,this.selectable=!1,this.directiveInit=new t.EventEmitter,this.lastInvalids=[],this.lastInvalidsChange=new t.EventEmitter,this.lastBaseUrlChange=new t.EventEmitter,this.fileChange=new t.EventEmitter,this.files=[],this.filesChange=new t.EventEmitter,this.fileSelectStart=new t.EventEmitter,this.initFilters()}return e.prototype.initFilters=function(){this.filters.push({name:"accept",fn:this._acceptFilter}),this.filters.push({name:"fileSize",fn:this._fileSizeFilter})},e.prototype.ngOnDestroy=function(){delete this.fileElm,this.destroyPasteListener()},e.prototype.ngOnInit=function(){var e=this;(this.selectable||""===this.selectable)&&!["false","null","0"].includes(this.selectable)&&this.enableSelecting(),this.multiple&&this.paramFileElm().setAttribute("multiple",this.multiple),this.evalCapturePaste(),setTimeout((function(){e.directiveInit.emit(e)}),0)},e.prototype.ngOnChanges=function(e){var t,n;(e.accept&&this.paramFileElm().setAttribute("accept",e.accept.currentValue||"*"),e.capturePaste&&this.evalCapturePaste(),e.file&&e.file.previousValue&&!e.file.currentValue&&this.clearFileElmValue(),e.files)&&((null===(t=e.files.previousValue)||void 0===t?void 0:t.length)&&!(null===(n=e.files.currentValue)||void 0===n?void 0:n.length)&&this.clearFileElmValue())},e.prototype.evalCapturePaste=function(){var e=this;if(this.capturePaste||""===this.capturePaste||["false","0","null"].includes(this.capturePaste)){if(this.pasteCapturer)return;return this.pasteCapturer=function(t){var n=t.clipboardData;n&&n.files&&n.files.length&&(e.handleFiles(n.files),t.preventDefault())},void window.addEventListener("paste",this.pasteCapturer)}this.destroyPasteListener()},e.prototype.destroyPasteListener=function(){this.pasteCapturer&&(window.removeEventListener("paste",this.pasteCapturer),delete this.pasteCapturer)},e.prototype.paramFileElm=function(){if(this.fileElm)return this.fileElm;var e=o(this.element.nativeElement);return this.fileElm=e?this.element.nativeElement:this.createFileElm({change:this.changeFn.bind(this)})},e.prototype.createFileElm=function(e){var t=e.change,n=function(){var e=f(),t=document.createElement("label");return t.innerHTML="upload",t.style.visibility="hidden",t.style.position="absolute",t.style.overflow="hidden",t.style.width="0px",t.style.height="0px",t.style.border="none",t.style.margin="0px",t.style.padding="0px",t.setAttribute("tabindex","-1"),t.appendChild(e),t}(),i=n.getElementsByTagName("input")[0];return i.addEventListener("change",t),this.element.nativeElement.appendChild(n),i},e.prototype.enableSelecting=function(){var e=this,t=this.element.nativeElement;if(o(t)){var n=function(t){return e.beforeSelect(t)};return t.addEventListener("click",n),void t.addEventListener("touchstart",n)}var i=function(t){return e.clickHandler(t)};t.addEventListener("click",i),t.addEventListener("touchstart",i),t.addEventListener("touchend",i)},e.prototype.getValidFiles=function(e){for(var t=[],n=e.length-1;n>=0;--n)this.isFileValid(e[n])&&t.push(e[n]);return t},e.prototype.getInvalidFiles=function(e){for(var t=[],n=e.length-1;n>=0;--n){var i=this.getFileFilterFailName(e[n]);i&&t.push({file:e[n],type:i})}return t},e.prototype.handleFiles=function(e){var t=this,n=this.getValidFiles(e);e.length!=n.length?this.lastInvalids=this.getInvalidFiles(e):delete this.lastInvalids,this.lastInvalidsChange.emit(this.lastInvalids),n.length&&(this.ngfFixOrientation?this.applyExifRotations(n).then((function(e){return t.que(e)})):this.que(n)),this.isEmptyAfterSelection()&&(this.element.nativeElement.value="")},e.prototype.que=function(e){var t=this;this.files=this.files||[],Array.prototype.push.apply(this.files,e),this.filesChange.emit(this.files),e.length&&(this.fileChange.emit(this.file=e[0]),this.lastBaseUrlChange.observers.length&&h(e[0]).then((function(e){return t.lastBaseUrlChange.emit(e)}))),this.lastFileCount=this.files.length},e.prototype.changeFn=function(e){var t=e.__files_||e.target&&e.target.files;t&&(this.stopEvent(e),this.handleFiles(t))},e.prototype.clickHandler=function(e){if(this.element.nativeElement.getAttribute("disabled")||this.fileDropDisabled)return!1;var t=function(e){var t=e.changedTouches||e.originalEvent&&e.originalEvent.changedTouches;if(t){if("touchstart"===e.type)return u=t[0].clientX,l=t[0].clientY,!0;if("touchend"===e.type){var n=t[0].clientX,i=t[0].clientY;if(Math.abs(n-u)>20||Math.abs(i-l)>20)return e.stopPropagation(),e.cancelable&&e.preventDefault(),!1}return!0}return!1}(e);return!1!==t?t:(this.paramFileElm().click(),this.beforeSelect(e),!1)},e.prototype.beforeSelect=function(e){this.fileSelectStart.emit(e),this.files&&this.lastFileCount===this.files.length||this.clearFileElmValue()},e.prototype.clearFileElmValue=function(){this.fileElm&&(this.fileElm.value=null)},e.prototype.isEmptyAfterSelection=function(){return!!this.element.nativeElement.attributes.multiple},e.prototype.stopEvent=function(e){e.preventDefault(),e.stopPropagation()},e.prototype.transferHasFiles=function(e){return!!e.types&&(e.types.indexOf?-1!==e.types.indexOf("Files"):!!e.types.contains&&e.types.contains("Files"))},e.prototype.eventToFiles=function(e){var t=v(e);if(t){if(t.files&&t.files.length)return t.files;if(t.items&&t.items.length)return t.items}return[]},e.prototype.applyExifRotations=function(e){for(var t=function(t,n){return c(t).then((function(t){return e.splice(n,1,t)}))},n=[],i=e.length-1;i>=0;--i)n[i]=t(e[i],i);return Promise.all(n).then((function(){return e}))},e.prototype.onChange=function(e){var t=this.element.nativeElement.files||this.eventToFiles(e);t.length&&(this.stopEvent(e),this.handleFiles(t))},e.prototype.getFileFilterFailName=function(e){for(var t=0;t<this.filters.length;t++)if(!this.filters[t].fn.call(this,e))return this.filters[t].name},e.prototype.isFileValid=function(e){return!(this.accept||this.filters&&this.filters.length)||!this.getFileFilterFailName(e)},e.prototype.isFilesValid=function(e){for(var t=e.length-1;t>=0;--t)if(!this.isFileValid(e[t]))return!1;return!0},e.prototype._acceptFilter=function(e){return function(e,t,n){if(!e)return!0;for(var i,r,a=e.split(","),s=a.length-1;s>=0;--s){if(r=(r=(r=a[s]).replace(/(^\s+|\s+$)/g,"")).replace(/\*/g,".*"),i=new RegExp(r,"gi"),t.search(i)>=0)return!0;if("."==r.substring(0,1)&&(r="\\"+r,i=new RegExp(r+"$","i"),(n||t).search(i)>=0))return!0}return!1}(this.accept,e.type,e.name)},e.prototype._fileSizeFilter=function(e){return!(this.maxSize&&e.size>this.maxSize)},e}();function d(e){for(var t=[],n=0;n<e.length;++n)t.push({type:e[n].type,kind:e[n].kind});return t}function v(e){return e.dataTransfer?e.dataTransfer:e.originalEvent?e.originalEvent.dataTransfer:null}g.decorators=[{type:t.Directive,args:[{selector:"[ngf]",exportAs:"ngf"}]}],g.ctorParameters=function(){return[{type:t.ElementRef}]},g.propDecorators={multiple:[{type:t.Input}],accept:[{type:t.Input}],maxSize:[{type:t.Input}],ngfFixOrientation:[{type:t.Input}],fileDropDisabled:[{type:t.Input}],selectable:[{type:t.Input}],directiveInit:[{type:t.Output,args:["init"]}],lastInvalids:[{type:t.Input}],lastInvalidsChange:[{type:t.Output}],lastBaseUrl:[{type:t.Input}],lastBaseUrlChange:[{type:t.Output}],file:[{type:t.Input}],fileChange:[{type:t.Output}],files:[{type:t.Input}],filesChange:[{type:t.Output}],fileSelectStart:[{type:t.Output}],capturePaste:[{type:t.Input}],onChange:[{type:t.HostListener,args:["change",["$event"]]}]};var m=function(e){function t(){var t=e.apply(this,s(arguments))||this;return t.selectable=!0,t}return r(t,e),t}(g);m.decorators=[{type:t.Directive,args:[{selector:"[ngfSelect]",exportAs:"ngfSelect"}]}],m.propDecorators={selectable:[{type:t.Input}]};var y=function(e){function n(){var n=e.apply(this,s(arguments))||this;return n.fileOver=new t.EventEmitter,n.validDrag=!1,n.validDragChange=new t.EventEmitter,n.invalidDrag=!1,n.invalidDragChange=new t.EventEmitter,n.dragFilesChange=new t.EventEmitter,n}return r(n,e),n.prototype.onDrop=function(e){if(this.fileDropDisabled)this.stopEvent(e);else{this.closeDrags();var t=this.eventToFiles(e);t.length&&(this.stopEvent(e),this.handleFiles(t))}},n.prototype.handleFiles=function(t){this.fileOver.emit(!1),e.prototype.handleFiles.call(this,t)},n.prototype.onDragOver=function(e){if(this.fileDropDisabled)this.stopEvent(e);else{var t=v(e),n=this.eventToFiles(e),i=d(n);this.dragFilesChange.emit(this.dragFiles=i),n.length?this.validDrag=this.isFilesValid(n):this.validDrag=!0,this.validDragChange.emit(this.validDrag),this.invalidDrag=!this.validDrag,this.invalidDragChange.emit(this.invalidDrag),t.dropEffect="copy",this.stopEvent(e),this.fileOver.emit(!0)}},n.prototype.closeDrags=function(){delete this.validDrag,this.validDragChange.emit(this.validDrag),this.invalidDrag=!1,this.invalidDragChange.emit(this.invalidDrag),delete this.dragFiles,this.dragFilesChange.emit(this.dragFiles)},n.prototype.onDragLeave=function(e){this.fileDropDisabled?this.stopEvent(e):(this.closeDrags(),this.element&&e.currentTarget===this.element[0]||(this.stopEvent(e),this.fileOver.emit(!1)))},n}(g);y.decorators=[{type:t.Directive,args:[{selector:"[ngfDrop]",exportAs:"ngfDrop"}]}],y.propDecorators={fileOver:[{type:t.Output}],validDrag:[{type:t.Input}],validDragChange:[{type:t.Output}],invalidDrag:[{type:t.Input}],invalidDragChange:[{type:t.Output}],dragFiles:[{type:t.Input}],dragFilesChange:[{type:t.Output}],onDrop:[{type:t.HostListener,args:["drop",["$event"]]}],onDragOver:[{type:t.HostListener,args:["dragover",["$event"]]}],onDragLeave:[{type:t.HostListener,args:["dragleave",["$event"]]}]};var E=function(){function e(e){this.ElementRef=e}return e.prototype.ngOnChanges=function(e){var t=this;h(this.file).then((function(e){var n="url('"+(e||"")+"')";t.ElementRef.nativeElement.style.backgroundImage=n}))},e}();E.decorators=[{type:t.Directive,args:[{selector:"[ngfBackground]"}]}],E.ctorParameters=function(){return[{type:t.ElementRef}]},E.propDecorators={file:[{type:t.Input,args:["ngfBackground"]}]};var D=function(){function e(){this.percent=0,this.percentChange=new t.EventEmitter}return e.prototype.ngOnChanges=function(e){var t=this;if(e.httpEvent&&e.httpEvent.currentValue){var n=e.httpEvent.currentValue;n.loaded&&n.total&&setTimeout((function(){t.percent=Math.round(100*n.loaded/n.total),t.percentChange.emit(t.percent)}),0)}},e}();D.decorators=[{type:t.Directive,args:[{selector:"ngfUploadStatus"}]}],D.propDecorators={percent:[{type:t.Input}],percentChange:[{type:t.Output}],httpEvent:[{type:t.Input}]};var F=function(){function e(e){this.postName="file",this.FormData=new FormData,this.FormDataChange=new t.EventEmitter,this.differ=e.find([]).create()}return e.prototype.ngDoCheck=function(){var e=this;this.differ.diff(this.files)&&setTimeout((function(){return e.buildFormData()}),0)},e.prototype.buildFormData=function(){var e=this;"object"==typeof this.files&&this.files.constructor===Array?(this.FormData=new FormData,(this.files||[]).forEach((function(t){return e.FormData.append(e.postName,t,e.fileName||t.name)})),this.FormDataChange.emit(this.FormData)):delete this.FormData},e}();F.decorators=[{type:t.Directive,args:[{selector:"ngfFormData"}]}],F.ctorParameters=function(){return[{type:t.IterableDiffers}]},F.propDecorators={files:[{type:t.Input}],postName:[{type:t.Input}],fileName:[{type:t.Input}],FormData:[{type:t.Input}],FormDataChange:[{type:t.Output}]};var b=function(){function e(e){this.ElementRef=e}return e.prototype.ngOnChanges=function(e){var t=this;h(this.file).then((function(e){return t.ElementRef.nativeElement.src=e}))},e}();b.decorators=[{type:t.Directive,args:[{selector:"[ngfSrc]"}]}],b.ctorParameters=function(){return[{type:t.ElementRef}]},b.propDecorators={file:[{type:t.Input,args:["ngfSrc"]}]};var w=[y,m,E,b,D,F,g],C=function(){};C.decorators=[{type:t.NgModule,args:[{imports:[n.CommonModule],declarations:w,exports:w}]}],e.eventToTransfer=v,e.filesToWriteableObject=d,e.ngf=g,e.ngfBackground=E,e.ngfDrop=y,e.ngfFormData=F,e.ngfModule=C,e.ngfSelect=m,e.ngfSrc=b,e.ngfUploadStatus=D,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=angular-file.umd.min.js.map

Sorry, the diff of this file is too big to display

/**
* Generated bundle index. Do not edit.
*/
export * from './index';
export { ngf as ɵb } from './file-upload/ngf.directive';
export { ngfBackground as ɵd } from './file-upload/ngfBackground.directive';
export { ngfDrop as ɵa } from './file-upload/ngfDrop.directive';
export { ngfFormData as ɵg } from './file-upload/ngfFormData.directive';
export { ngfSelect as ɵc } from './file-upload/ngfSelect.directive';
export { ngfSrc as ɵe } from './file-upload/ngfSrc.directive';
export { ngfUploadStatus as ɵf } from './file-upload/ngfUploadStatus.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1maWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FuZ3VsYXItZmlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDO0FBRXhCLE9BQU8sRUFBQyxHQUFHLElBQUksRUFBRSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDdEQsT0FBTyxFQUFDLGFBQWEsSUFBSSxFQUFFLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsT0FBTyxJQUFJLEVBQUUsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBQzlELE9BQU8sRUFBQyxXQUFXLElBQUksRUFBRSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUFDLFNBQVMsSUFBSSxFQUFFLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUNsRSxPQUFPLEVBQUMsTUFBTSxJQUFJLEVBQUUsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQzVELE9BQU8sRUFBQyxlQUFlLElBQUksRUFBRSxFQUFDLE1BQU0seUNBQXlDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuXG5leHBvcnQge25nZiBhcyDJtWJ9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmLmRpcmVjdGl2ZSc7XG5leHBvcnQge25nZkJhY2tncm91bmQgYXMgybVkfSBmcm9tICcuL2ZpbGUtdXBsb2FkL25nZkJhY2tncm91bmQuZGlyZWN0aXZlJztcbmV4cG9ydCB7bmdmRHJvcCBhcyDJtWF9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmRHJvcC5kaXJlY3RpdmUnO1xuZXhwb3J0IHtuZ2ZGb3JtRGF0YSBhcyDJtWd9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmRm9ybURhdGEuZGlyZWN0aXZlJztcbmV4cG9ydCB7bmdmU2VsZWN0IGFzIMm1Y30gZnJvbSAnLi9maWxlLXVwbG9hZC9uZ2ZTZWxlY3QuZGlyZWN0aXZlJztcbmV4cG9ydCB7bmdmU3JjIGFzIMm1ZX0gZnJvbSAnLi9maWxlLXVwbG9hZC9uZ2ZTcmMuZGlyZWN0aXZlJztcbmV4cG9ydCB7bmdmVXBsb2FkU3RhdHVzIGFzIMm1Zn0gZnJvbSAnLi9maWxlLXVwbG9hZC9uZ2ZVcGxvYWRTdGF0dXMuZGlyZWN0aXZlJzsiXX0=
export const isFileInput = function (elm) {
const ty = elm.getAttribute('type');
return elm.tagName.toLowerCase() === 'input' && ty && ty.toLowerCase() === 'file';
};
let initialTouchStartY = 0;
let initialTouchStartX = 0;
export const detectSwipe = function (evt) {
var touches = evt.changedTouches || (evt.originalEvent && evt.originalEvent.changedTouches);
if (touches) {
if (evt.type === 'touchstart') {
initialTouchStartX = touches[0].clientX;
initialTouchStartY = touches[0].clientY;
return true; // don't block event default
}
else {
// prevent scroll from triggering event
if (evt.type === 'touchend') {
var currentX = touches[0].clientX;
var currentY = touches[0].clientY;
if ((Math.abs(currentX - initialTouchStartX) > 20) ||
(Math.abs(currentY - initialTouchStartY) > 20)) {
evt.stopPropagation();
if (evt.cancelable) {
evt.preventDefault();
}
return false;
}
}
return true;
}
}
return false;
};
export const createInvisibleFileInputWrap = function () {
var fileElem = createFileInput();
var label = document.createElement('label');
label.innerHTML = 'upload';
label.style.visibility = 'hidden';
label.style.position = 'absolute';
label.style.overflow = 'hidden';
label.style.width = '0px';
label.style.height = '0px';
label.style.border = 'none';
label.style.margin = '0px';
label.style.padding = '0px';
label.setAttribute('tabindex', '-1');
//bindAttrToFileInput(fileElem, label);
//generatedElems.push({el: elem, ref: label});
label.appendChild(fileElem);
//document.body.appendChild( label );
return label;
};
export const createFileInput = function () {
var fileElem = document.createElement('input');
fileElem.type = "file";
return fileElem;
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jLWV2ZW50LWhlbHAuZnVuY3Rpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2ZpbGUtdXBsb2FkL2RvYy1ldmVudC1oZWxwLmZ1bmN0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsVUFBUyxHQUFPO0lBQ3pDLE1BQU0sRUFBRSxHQUFHLEdBQUcsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUE7SUFDbkMsT0FBTyxHQUFHLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxLQUFLLE9BQU8sSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLFdBQVcsRUFBRSxLQUFLLE1BQU0sQ0FBQztBQUNwRixDQUFDLENBQUE7QUFFRCxJQUFJLGtCQUFrQixHQUFHLENBQUMsQ0FBQztBQUMzQixJQUFJLGtCQUFrQixHQUFHLENBQUMsQ0FBQztBQUMzQixNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsVUFBUyxHQUFPO0lBQ3pDLElBQUksT0FBTyxHQUFHLEdBQUcsQ0FBQyxjQUFjLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxJQUFJLEdBQUcsQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDNUYsSUFBSSxPQUFPLEVBQUU7UUFDWCxJQUFJLEdBQUcsQ0FBQyxJQUFJLEtBQUssWUFBWSxFQUFFO1lBQzdCLGtCQUFrQixHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7WUFDeEMsa0JBQWtCLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztZQUN4QyxPQUFPLElBQUksQ0FBQyxDQUFDLDRCQUE0QjtTQUMxQzthQUFNO1lBQ0wsdUNBQXVDO1lBQ3ZDLElBQUksR0FBRyxDQUFDLElBQUksS0FBSyxVQUFVLEVBQUU7Z0JBQzNCLElBQUksUUFBUSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7Z0JBQ2xDLElBQUksUUFBUSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7Z0JBQ2xDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsR0FBRyxrQkFBa0IsQ0FBQyxHQUFHLEVBQUUsQ0FBQztvQkFDaEQsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsR0FBRyxrQkFBa0IsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUFFO29CQUNoRCxHQUFHLENBQUMsZUFBZSxFQUFFLENBQUM7b0JBQ3RCLElBQUksR0FBRyxDQUFDLFVBQVUsRUFBRTt3QkFDbEIsR0FBRyxDQUFDLGNBQWMsRUFBRSxDQUFDO3FCQUN0QjtvQkFDRCxPQUFPLEtBQUssQ0FBQztpQkFDZDthQUNGO1lBQ0QsT0FBTyxJQUFJLENBQUM7U0FDYjtLQUNGO0lBQ0QsT0FBTyxLQUFLLENBQUE7QUFDZCxDQUFDLENBQUE7QUFFRCxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRztJQUMxQyxJQUFJLFFBQVEsR0FBRyxlQUFlLEVBQUUsQ0FBQTtJQUNoQyxJQUFJLEtBQUssR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzVDLEtBQUssQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFBO0lBQzFCLEtBQUssQ0FBQyxLQUFLLENBQUMsVUFBVSxHQUFHLFFBQVEsQ0FBQTtJQUNqQyxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQVEsR0FBRyxVQUFVLENBQUE7SUFDakMsS0FBSyxDQUFDLEtBQUssQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFBO0lBQy9CLEtBQUssQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQTtJQUN6QixLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUE7SUFDMUIsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO0lBQzNCLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQTtJQUMxQixLQUFLLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUE7SUFDM0IsS0FBSyxDQUFDLFlBQVksQ0FBQyxVQUFVLEVBQUMsSUFBSSxDQUFDLENBQUE7SUFFbkMsdUNBQXVDO0lBQ3ZDLDhDQUE4QztJQUU5QyxLQUFLLENBQUMsV0FBVyxDQUFFLFFBQVEsQ0FBRSxDQUFBO0lBQzdCLHFDQUFxQztJQUVyQyxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUMsQ0FBQTtBQUVELE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRztJQUM3QixJQUFJLFFBQVEsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQy9DLFFBQVEsQ0FBQyxJQUFJLEdBQUMsTUFBTSxDQUFBO0lBQ3BCLE9BQU8sUUFBUSxDQUFDO0FBQ2xCLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBpc0ZpbGVJbnB1dCA9IGZ1bmN0aW9uKGVsbTphbnkpe1xuICBjb25zdCB0eSA9IGVsbS5nZXRBdHRyaWJ1dGUoJ3R5cGUnKVxuICByZXR1cm4gZWxtLnRhZ05hbWUudG9Mb3dlckNhc2UoKSA9PT0gJ2lucHV0JyAmJiB0eSAmJiB0eS50b0xvd2VyQ2FzZSgpID09PSAnZmlsZSc7XG59XG5cbmxldCBpbml0aWFsVG91Y2hTdGFydFkgPSAwO1xubGV0IGluaXRpYWxUb3VjaFN0YXJ0WCA9IDA7XG5leHBvcnQgY29uc3QgZGV0ZWN0U3dpcGUgPSBmdW5jdGlvbihldnQ6YW55KTpib29sZWFuIHtcbiAgdmFyIHRvdWNoZXMgPSBldnQuY2hhbmdlZFRvdWNoZXMgfHwgKGV2dC5vcmlnaW5hbEV2ZW50ICYmIGV2dC5vcmlnaW5hbEV2ZW50LmNoYW5nZWRUb3VjaGVzKTtcbiAgaWYgKHRvdWNoZXMpIHtcbiAgICBpZiAoZXZ0LnR5cGUgPT09ICd0b3VjaHN0YXJ0Jykge1xuICAgICAgaW5pdGlhbFRvdWNoU3RhcnRYID0gdG91Y2hlc1swXS5jbGllbnRYO1xuICAgICAgaW5pdGlhbFRvdWNoU3RhcnRZID0gdG91Y2hlc1swXS5jbGllbnRZO1xuICAgICAgcmV0dXJuIHRydWU7IC8vIGRvbid0IGJsb2NrIGV2ZW50IGRlZmF1bHRcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gcHJldmVudCBzY3JvbGwgZnJvbSB0cmlnZ2VyaW5nIGV2ZW50XG4gICAgICBpZiAoZXZ0LnR5cGUgPT09ICd0b3VjaGVuZCcpIHtcbiAgICAgICAgdmFyIGN1cnJlbnRYID0gdG91Y2hlc1swXS5jbGllbnRYO1xuICAgICAgICB2YXIgY3VycmVudFkgPSB0b3VjaGVzWzBdLmNsaWVudFk7XG4gICAgICAgIGlmICgoTWF0aC5hYnMoY3VycmVudFggLSBpbml0aWFsVG91Y2hTdGFydFgpID4gMjApIHx8XG4gICAgICAgICAgKE1hdGguYWJzKGN1cnJlbnRZIC0gaW5pdGlhbFRvdWNoU3RhcnRZKSA+IDIwKSkge1xuICAgICAgICAgIGV2dC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgICBpZiAoZXZ0LmNhbmNlbGFibGUpIHtcbiAgICAgICAgICAgIGV2dC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gZmFsc2Vcbn1cblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUludmlzaWJsZUZpbGVJbnB1dFdyYXAgPSBmdW5jdGlvbigpIHtcbiAgdmFyIGZpbGVFbGVtID0gY3JlYXRlRmlsZUlucHV0KClcbiAgdmFyIGxhYmVsID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnbGFiZWwnKTtcbiAgbGFiZWwuaW5uZXJIVE1MID0gJ3VwbG9hZCdcbiAgbGFiZWwuc3R5bGUudmlzaWJpbGl0eSA9ICdoaWRkZW4nXG4gIGxhYmVsLnN0eWxlLnBvc2l0aW9uID0gJ2Fic29sdXRlJ1xuICBsYWJlbC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gIGxhYmVsLnN0eWxlLndpZHRoID0gJzBweCdcbiAgbGFiZWwuc3R5bGUuaGVpZ2h0ID0gJzBweCdcbiAgbGFiZWwuc3R5bGUuYm9yZGVyID0gJ25vbmUnXG4gIGxhYmVsLnN0eWxlLm1hcmdpbiA9ICcwcHgnXG4gIGxhYmVsLnN0eWxlLnBhZGRpbmcgPSAnMHB4J1xuICBsYWJlbC5zZXRBdHRyaWJ1dGUoJ3RhYmluZGV4JywnLTEnKVxuICBcbiAgLy9iaW5kQXR0clRvRmlsZUlucHV0KGZpbGVFbGVtLCBsYWJlbCk7XG4gIC8vZ2VuZXJhdGVkRWxlbXMucHVzaCh7ZWw6IGVsZW0sIHJlZjogbGFiZWx9KTtcblxuICBsYWJlbC5hcHBlbmRDaGlsZCggZmlsZUVsZW0gKVxuICAvL2RvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQoIGxhYmVsICk7XG5cbiAgcmV0dXJuIGxhYmVsO1xufVxuXG5leHBvcnQgY29uc3QgY3JlYXRlRmlsZUlucHV0ID0gZnVuY3Rpb24oKSB7XG4gIHZhciBmaWxlRWxlbSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2lucHV0Jyk7XG4gIGZpbGVFbGVtLnR5cGU9XCJmaWxlXCJcbiAgcmV0dXJuIGZpbGVFbGVtO1xufVxuIl19
export function getWindow() { return window; }
export function acceptType(accept, type, name) {
if (!accept) {
return true;
}
const defs = accept.split(',');
let regx;
let acceptRegString;
for (let x = defs.length - 1; x >= 0; --x) {
//Escapes dots in mimetype
acceptRegString = defs[x];
//trim
acceptRegString = acceptRegString.replace(/(^\s+|\s+$)/g, '');
//Escapes stars in mimetype
acceptRegString = acceptRegString.replace(/\*/g, '.*');
//let acceptReg = '^((' + acceptRegString
//acceptReg = acceptReg.replace(/,/g,')|(') + '))$'
//try by mime
regx = new RegExp(acceptRegString, 'gi');
if (type.search(regx) >= 0) {
return true;
}
//try by ext
if (acceptRegString.substring(0, 1) == '.') {
acceptRegString = '\\' + acceptRegString; //.substring(1, acceptRegString.length-1)//remove dot at front
regx = new RegExp(acceptRegString + '$', 'i');
if ((name || type).search(regx) >= 0) {
return true;
}
}
}
return false;
}
export function arrayBufferToBase64(buffer) {
var binary = '';
var bytes = new Uint8Array(buffer);
var len = bytes.byteLength;
for (var i = 0; i < len; i++) {
binary += String.fromCharCode(bytes[i]);
}
return window.btoa(binary);
}
export function dataUrltoBlob(dataurl, name, origSize) {
var arr = dataurl.split(',');
var mimeMatch = arr[0].match(/:(.*?);/);
var mime = mimeMatch ? mimeMatch[1] : 'text/plain';
var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
var blob = new window.Blob([u8arr], { type: mime });
blob["name"] = name;
blob["$ngfOrigSize"] = origSize;
return blob;
}
export function applyTransform(ctx, orientation, width, height) {
switch (orientation) {
case 2:
return ctx.transform(-1, 0, 0, 1, width, 0);
case 3:
return ctx.transform(-1, 0, 0, -1, width, height);
case 4:
return ctx.transform(1, 0, 0, -1, 0, height);
case 5:
return ctx.transform(0, 1, 1, 0, 0, 0);
case 6:
return ctx.transform(0, 1, -1, 0, height, 0);
case 7:
return ctx.transform(0, -1, -1, 0, height, width);
case 8:
return ctx.transform(0, -1, 1, 0, 0, width);
}
}
export function fixFileOrientationByMeta(file, result) {
return dataUrl(file, true)
.then(url => {
var canvas = document.createElement('canvas');
var img = document.createElement('img');
return new Promise(function (res, rej) {
img.onload = function () {
try {
canvas.width = result.orientation > 4 ? img.height : img.width;
canvas.height = result.orientation > 4 ? img.width : img.height;
var ctx = canvas.getContext('2d');
applyTransform(ctx, result.orientation, img.width, img.height);
ctx.drawImage(img, 0, 0);
var dataUrl = canvas.toDataURL(file.type || 'image/WebP', 0.934);
const base = arrayBufferToBase64(result.fixedArrayBuffer);
dataUrl = restoreExif(base, dataUrl);
var blob = dataUrltoBlob(dataUrl, file.name);
const newFile = blobToFile(blob, file.name);
res(newFile);
}
catch (e) {
rej(e);
}
};
img.onerror = rej;
img.src = url;
});
});
}
export function applyExifRotation(file) {
if (file.type.indexOf('image/jpeg') !== 0) {
return Promise.resolve(file);
}
return readOrientation(file)
.then((result) => {
if (result.orientation < 2 || result.orientation > 8) {
return file;
}
return fixFileOrientationByMeta(file, result);
});
}
export function readOrientation(file) {
return new Promise((res, rej) => {
var reader = new FileReader();
var slicedFile = file.slice ? file.slice(0, 64 * 1024) : file;
reader.readAsArrayBuffer(slicedFile);
reader.onerror = rej;
reader.onload = function (e) {
var result = { orientation: 1 };
var view = new DataView(this.result);
if (view.getUint16(0, false) !== 0xFFD8)
return res(result);
var length = view.byteLength, offset = 2;
while (offset < length) {
var marker = view.getUint16(offset, false);
offset += 2;
if (marker === 0xFFE1) {
if (view.getUint32(offset += 2, false) !== 0x45786966)
return res(result);
var little = view.getUint16(offset += 6, false) === 0x4949;
offset += view.getUint32(offset + 4, little);
var tags = view.getUint16(offset, little);
offset += 2;
for (var i = 0; i < tags; i++)
if (view.getUint16(offset + (i * 12), little) === 0x0112) {
var orientation = view.getUint16(offset + (i * 12) + 8, little);
if (orientation >= 2 && orientation <= 8) {
view.setUint16(offset + (i * 12) + 8, 1, little);
result.fixedArrayBuffer = e.target.result;
}
result.orientation = orientation;
return res(result);
}
}
else if ((marker & 0xFF00) !== 0xFF00)
break;
else
offset += view.getUint16(offset, false);
}
return res(result);
};
});
}
/** converts file-input file into base64 dataUri */
export function dataUrl(file, disallowObjectUrl) {
if (!file)
return Promise.resolve(file);
if ((disallowObjectUrl && file.$ngfDataUrl != null) || (!disallowObjectUrl && file.$ngfBlobUrl != null)) {
return Promise.resolve(disallowObjectUrl ? file.$ngfDataUrl : file.$ngfBlobUrl);
}
var p = disallowObjectUrl ? file.$$ngfDataUrlPromise : file.$$ngfBlobUrlPromise;
if (p)
return p;
const win = getWindow();
let deferred;
if (win.FileReader && file &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 8') === -1 || file.size < 20000) &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 9') === -1 || file.size < 4000000)) {
//prefer URL.createObjectURL for handling refrences to files of all sizes
//since it doesn´t build a large string in memory
var URL = win.URL || win.webkitURL;
if (FileReader) {
deferred = new Promise((res, rej) => {
var fileReader = new FileReader();
fileReader.onload = function (event) {
file.$ngfDataUrl = event.target.result;
delete file.$ngfDataUrl;
res(event.target.result);
};
fileReader.onerror = function (e) {
file.$ngfDataUrl = '';
rej(e);
};
fileReader.readAsDataURL(file);
});
}
else {
var url;
try {
url = URL.createObjectURL(file);
}
catch (e) {
return Promise.reject(e);
}
deferred = Promise.resolve(url);
file.$ngfBlobUrl = url;
}
}
else {
file[disallowObjectUrl ? '$ngfDataUrl' : '$ngfBlobUrl'] = '';
return Promise.reject(new Error('Browser does not support window.FileReader, window.FileReader, or window.FileAPI')); //deferred.reject();
}
if (disallowObjectUrl) {
p = file.$$ngfDataUrlPromise = deferred;
}
else {
p = file.$$ngfBlobUrlPromise = deferred;
}
p = p.then((x) => {
delete file[disallowObjectUrl ? '$$ngfDataUrlPromise' : '$$ngfBlobUrlPromise'];
return x;
});
return p;
}
export function restoreExif(orig, resized) {
var ExifRestorer = {
KEY_STR: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='
};
ExifRestorer.encode64 = function (input) {
var output = '', chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0;
do {
chr1 = input[i++];
chr2 = input[i++];
chr3 = input[i++];
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
}
else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
this.KEY_STR.charAt(enc1) +
this.KEY_STR.charAt(enc2) +
this.KEY_STR.charAt(enc3) +
this.KEY_STR.charAt(enc4);
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return output;
};
ExifRestorer.restore = function (origFileBase64, resizedFileBase64) {
if (origFileBase64.match('data:image/jpeg;base64,')) {
origFileBase64 = origFileBase64.replace('data:image/jpeg;base64,', '');
}
var rawImage = this.decode64(origFileBase64);
var segments = this.slice2Segments(rawImage);
var image = this.exifManipulation(resizedFileBase64, segments);
return 'data:image/jpeg;base64,' + this.encode64(image);
};
ExifRestorer.exifManipulation = function (resizedFileBase64, segments) {
var exifArray = this.getExifArray(segments), newImageArray = this.insertExif(resizedFileBase64, exifArray);
return new Uint8Array(newImageArray);
};
ExifRestorer.getExifArray = function (segments) {
var seg;
for (var x = 0; x < segments.length; x++) {
seg = segments[x];
if (seg[0] === 255 && seg[1] === 225) //(ff e1)
{
return seg;
}
}
return [];
};
ExifRestorer.insertExif = function (resizedFileBase64, exifArray) {
var imageData = resizedFileBase64.replace('data:image/jpeg;base64,', ''), buf = this.decode64(imageData), separatePoint = buf.indexOf(255, 3), mae = buf.slice(0, separatePoint), ato = buf.slice(separatePoint), array = mae;
array = array.concat(exifArray);
array = array.concat(ato);
return array;
};
ExifRestorer.slice2Segments = function (rawImageArray) {
var head = 0, segments = [];
while (1) {
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 218) {
break;
}
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 216) {
head += 2;
}
else {
var length = rawImageArray[head + 2] * 256 + rawImageArray[head + 3];
var endPoint = head + length + 2;
var seg = rawImageArray.slice(head, endPoint);
segments.push(seg);
head = endPoint;
}
if (head > rawImageArray.length) {
break;
}
}
return segments;
};
ExifRestorer.decode64 = function (input) {
var chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0, buf = [];
// remove all characters that are not A-Z, a-z, 0-9, +, /, or =
var base64test = /[^A-Za-z0-9\+\/\=]/g;
if (base64test.exec(input)) {
console.log('There were invalid base64 characters in the input text.');
}
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, '');
do {
enc1 = this.KEY_STR.indexOf(input.charAt(i++));
enc2 = this.KEY_STR.indexOf(input.charAt(i++));
enc3 = this.KEY_STR.indexOf(input.charAt(i++));
enc4 = this.KEY_STR.indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
buf.push(chr1);
if (enc3 !== 64) {
buf.push(chr2);
}
if (enc4 !== 64) {
buf.push(chr3);
}
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return buf;
};
return ExifRestorer.restore(orig, resized); //<= EXIF
}
;
function blobToFile(theBlob, fileName) {
var b = theBlob;
//A Blob() is almost a File() - it's just missing the two properties below which we will add
b.lastModifiedDate = new Date();
b.name = fileName;
//Cast to a File() type
return theBlob;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fileTools.js","sourceRoot":"","sources":["../../../src/file-upload/fileTools.ts"],"names":[],"mappings":"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","sourcesContent":["export function getWindow():any{return window}\n\nexport function acceptType(accept:string, type:string, name?:string):boolean {   \n  if( !accept ){\n    return true\n  }\n\n  const defs = accept.split(',')\n  let regx:RegExp\n  let acceptRegString:string\n\n  for(let x=defs.length-1; x >= 0; --x){\n    //Escapes dots in mimetype \n    acceptRegString = defs[x]\n    //trim\n    acceptRegString = acceptRegString.replace(/(^\\s+|\\s+$)/g,'')\n    //Escapes stars in mimetype \n    acceptRegString = acceptRegString.replace(/\\*/g,'.*')\n    //let acceptReg = '^((' + acceptRegString\n    //acceptReg = acceptReg.replace(/,/g,')|(') + '))$'\n    \n    //try by mime\n    regx = new RegExp(acceptRegString, 'gi')\n    if( type.search(regx)>=0 ){\n      return true\n    }\n\n    //try by ext\n    if( acceptRegString.substring(0, 1)=='.' ){      \n      acceptRegString = '\\\\'+ acceptRegString//.substring(1, acceptRegString.length-1)//remove dot at front\n      regx = new RegExp(acceptRegString+'$', 'i')\n      if( (name||type).search(regx)>=0 ){\n        return true\n      }\n    }\n  }\n  return false\n}\n\nexport interface InvalidFileItem{\n  file:File\n  type:string\n}\n\nexport function arrayBufferToBase64(buffer:any) {\n  var binary = '';\n  var bytes = new Uint8Array(buffer);\n  var len = bytes.byteLength;\n  for (var i = 0; i < len; i++) {\n    binary += String.fromCharCode(bytes[i]);\n  }\n  return window.btoa(binary);\n}\n\nexport function dataUrltoBlob(\n  dataurl:string,\n  name:string,\n  origSize?:any\n):Blob{\n  var arr = dataurl.split(',');\n  var mimeMatch = arr[0].match(/:(.*?);/)\n  var mime:string = mimeMatch ? mimeMatch[1] : 'text/plain'\n  var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);\n  while (n--) {\n    u8arr[n] = bstr.charCodeAt(n);\n  }\n  \n  var blob: any = new window.Blob([u8arr], {type: mime});\n  blob[\"name\"] = name;\n  blob[\"$ngfOrigSize\"] = origSize;\n  return blob;\n}\n\nexport interface orientationMeta{\n  orientation: number\n  fixedArrayBuffer?:any[]\n}\n\nexport function applyTransform(\n  ctx:CanvasRenderingContext2D,\n  orientation:number,\n  width:number,\n  height:number\n) {\n  switch (orientation) {\n    case 2:\n      return ctx.transform(-1, 0, 0, 1, width, 0);\n    case 3:\n      return ctx.transform(-1, 0, 0, -1, width, height);\n    case 4:\n      return ctx.transform(1, 0, 0, -1, 0, height);\n    case 5:\n      return ctx.transform(0, 1, 1, 0, 0, 0);\n    case 6:\n      return ctx.transform(0, 1, -1, 0, height, 0);\n    case 7:\n      return ctx.transform(0, -1, -1, 0, height, width);\n    case 8:\n      return ctx.transform(0, -1, 1, 0, 0, width);\n  }\n}\n\nexport function fixFileOrientationByMeta(\n  file:File, result:orientationMeta\n):Promise<File>{\n  return dataUrl(file, true)\n  .then(url=>{\n    var canvas = document.createElement('canvas');\n    var img = document.createElement('img');\n\n    return <Promise<File>>new Promise(function(res,rej){\n      img.onload = function () {\n        try {\n          canvas.width = result.orientation > 4 ? img.height : img.width\n          canvas.height = result.orientation > 4 ? img.width : img.height\n          var ctx = <CanvasRenderingContext2D>canvas.getContext('2d')\n          applyTransform(ctx, result.orientation, img.width, img.height)\n          ctx.drawImage(img, 0, 0);\n          var dataUrl = canvas.toDataURL(file.type || 'image/WebP', 0.934)\n          const base = arrayBufferToBase64(result.fixedArrayBuffer)\n          dataUrl = restoreExif(base, dataUrl)\n          var blob = dataUrltoBlob(dataUrl, file.name)\n          const newFile = blobToFile(blob, file.name);\n          res(newFile);\n        } catch (e) {\n          rej(e)\n        }\n      };\n      img.onerror = rej;\n      img.src = url;    \n    })\n  })\n}\n\nexport function applyExifRotation(\n  file:File\n):Promise<File>{\n  if (file.type.indexOf('image/jpeg') !== 0) {\n    return Promise.resolve(file);\n  }\n\n  return readOrientation(file)\n  .then((result:orientationMeta)=>{\n    if (result.orientation < 2 || result.orientation > 8) {\n      return file\n    }\n    \n    return fixFileOrientationByMeta(file,result)\n  })\n}\n\nexport function readOrientation(\n  file:File\n):Promise<orientationMeta>{\n  return new Promise((res,rej)=>{\n    var reader = new FileReader();\n    var slicedFile = file.slice ? file.slice(0, 64 * 1024) : file;\n    reader.readAsArrayBuffer(slicedFile);\n    reader.onerror = rej\n    reader.onload = function (e:any) {\n      var result:orientationMeta = {orientation: 1};\n      var view = new DataView( <ArrayBuffer>this.result );\n      if (view.getUint16(0, false) !== 0xFFD8) return res(result);\n\n      var length = view.byteLength,\n        offset = 2;\n      while (offset < length) {\n        var marker = view.getUint16(offset, false);\n        offset += 2;\n        if (marker === 0xFFE1) {\n          if (view.getUint32(offset += 2, false) !== 0x45786966) return res(result);\n\n          var little = view.getUint16(offset += 6, false) === 0x4949;\n          offset += view.getUint32(offset + 4, little);\n          var tags = view.getUint16(offset, little);\n          offset += 2;\n          for (var i = 0; i < tags; i++)\n            if (view.getUint16(offset + (i * 12), little) === 0x0112) {\n              var orientation = view.getUint16(offset + (i * 12) + 8, little);\n              if (orientation >= 2 && orientation <= 8) {\n                view.setUint16(offset + (i * 12) + 8, 1, little);\n                result.fixedArrayBuffer = e.target.result;\n              }\n              result.orientation = orientation;\n              return res(result);\n            }\n        } else if ((marker & 0xFF00) !== 0xFF00) break;\n        else offset += view.getUint16(offset, false);\n      }\n      return res(result);\n    };\n  })\n}\n\n/** converts file-input file into base64 dataUri */\nexport function dataUrl(\n  file:any,\n  disallowObjectUrl?:any\n):Promise<string>{\n  if (!file) return Promise.resolve(file)\n  \n  if ((disallowObjectUrl && file.$ngfDataUrl != null) || (!disallowObjectUrl && file.$ngfBlobUrl != null)) {\n    return Promise.resolve( disallowObjectUrl ? file.$ngfDataUrl : file.$ngfBlobUrl )\n  }\n\n  var p = disallowObjectUrl ? file.$$ngfDataUrlPromise : file.$$ngfBlobUrlPromise;\n  if (p) return p;\n\n  const win = getWindow()\n  let deferred:Promise<string>\n  if (win.FileReader && file &&\n    (!win.FileAPI || navigator.userAgent.indexOf('MSIE 8') === -1 || file.size < 20000) &&\n    (!win.FileAPI || navigator.userAgent.indexOf('MSIE 9') === -1 || file.size < 4000000)) {\n    //prefer URL.createObjectURL for handling refrences to files of all sizes\n    //since it doesn´t build a large string in memory\n    var URL = win.URL || win.webkitURL;\n    if (FileReader) {\n      deferred = new Promise((res,rej)=>{\n        var fileReader = new FileReader();\n        fileReader.onload = function (event:any) {\n          file.$ngfDataUrl = event.target.result;\n          delete file.$ngfDataUrl;\n          res( event.target.result )\n        };\n        fileReader.onerror = function (e) {\n          file.$ngfDataUrl = '';\n          rej(e)\n        };\n        fileReader.readAsDataURL(file);\n      })\n    } else {\n      var url:any;\n      try {\n        url = URL.createObjectURL(file);\n      } catch (e) {\n        return Promise.reject(e);\n      }\n      \n      deferred = Promise.resolve( url )\n      file.$ngfBlobUrl = url;\n    }\n  } else {\n    file[disallowObjectUrl ? '$ngfDataUrl' : '$ngfBlobUrl'] = '';\n    return Promise.reject( new Error('Browser does not support window.FileReader, window.FileReader, or window.FileAPI') )//deferred.reject();\n  }\n\n  if (disallowObjectUrl) {\n    p = file.$$ngfDataUrlPromise = deferred;\n  } else {\n    p = file.$$ngfBlobUrlPromise = deferred;\n  }\n\n  p = p.then((x:any)=>{\n    delete file[disallowObjectUrl ? '$$ngfDataUrlPromise' : '$$ngfBlobUrlPromise'];\n    return x\n  })\n\n  return p;\n}\n\nexport function restoreExif(orig:any, resized:any) {\n  var ExifRestorer:any = {\n    KEY_STR:'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='\n  }\n\n  ExifRestorer.encode64 = function (input:any) {\n    var output = '',\n      chr1, chr2, chr3:any = '',\n      enc1, enc2, enc3, enc4:any = '',\n      i = 0;\n\n    do {\n      chr1 = input[i++];\n      chr2 = input[i++];\n      chr3 = input[i++];\n\n      enc1 = chr1 >> 2;\n      enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);\n      enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);\n      enc4 = chr3 & 63;\n\n      if (isNaN(chr2)) {\n        enc3 = enc4 = 64;\n      } else if (isNaN(chr3)) {\n        enc4 = 64;\n      }\n\n      output = output +\n        this.KEY_STR.charAt(enc1) +\n        this.KEY_STR.charAt(enc2) +\n        this.KEY_STR.charAt(enc3) +\n        this.KEY_STR.charAt(enc4);\n      chr1 = chr2 = chr3 = '';\n      enc1 = enc2 = enc3 = enc4 = '';\n    } while (i < input.length);\n\n    return output;\n  };\n\n  ExifRestorer.restore = function (origFileBase64:any, resizedFileBase64:any) {\n    if (origFileBase64.match('data:image/jpeg;base64,')) {\n      origFileBase64 = origFileBase64.replace('data:image/jpeg;base64,', '');\n    }\n\n    var rawImage:number[] = this.decode64(origFileBase64);\n    var segments = this.slice2Segments(rawImage);\n\n    var image = this.exifManipulation(resizedFileBase64, segments);\n\n    return 'data:image/jpeg;base64,' + this.encode64(image);\n  };\n\n\n  ExifRestorer.exifManipulation = function (resizedFileBase64:any, segments:any) {\n    var exifArray = this.getExifArray(segments),\n      newImageArray = this.insertExif(resizedFileBase64, exifArray);\n    return new Uint8Array(newImageArray);\n  };\n\n  ExifRestorer.getExifArray = function (segments:number[][]) {\n    var seg;\n    for (var x = 0; x < segments.length; x++) {\n      seg = segments[x];\n      if (seg[0] === 255 && seg[1] === 225) //(ff e1)\n      {\n        return seg;\n      }\n    }\n    return [];\n  };\n\n\n  ExifRestorer.insertExif = function (resizedFileBase64:any, exifArray:any) {\n    var imageData = resizedFileBase64.replace('data:image/jpeg;base64,', ''),\n      buf = this.decode64(imageData),\n      separatePoint = buf.indexOf(255, 3),\n      mae = buf.slice(0, separatePoint),\n      ato = buf.slice(separatePoint),\n      array = mae;\n\n    array = array.concat(exifArray);\n    array = array.concat(ato);\n    return array;\n  };\n\n\n  ExifRestorer.slice2Segments = function(\n    rawImageArray:number[]\n  ) {\n    var head:number = 0,\n      segments:number[][] = [];\n\n    while (1) {\n      if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 218) {\n        break;\n      }\n      if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 216) {\n        head += 2;\n      }\n      else {\n        var length = rawImageArray[head + 2] * 256 + rawImageArray[head + 3]\n        var endPoint = head + length + 2\n        var seg:number[] = rawImageArray.slice(head, endPoint)\n        segments.push(seg);\n        head = endPoint;\n      }\n      if (head > rawImageArray.length) {\n        break;\n      }\n    }\n\n    return segments;\n  };\n\n\n  ExifRestorer.decode64 = function (\n    input:any\n  ):number[]{\n    var chr1, chr2, chr3:any = '',\n      enc1, enc2, enc3, enc4:any = '',\n      i = 0,\n      buf:number[] = [];\n\n    // remove all characters that are not A-Z, a-z, 0-9, +, /, or =\n    var base64test = /[^A-Za-z0-9\\+\\/\\=]/g;\n    if (base64test.exec(input)) {\n      console.log('There were invalid base64 characters in the input text.');\n    }\n    input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, '');\n\n    do {\n      enc1 = this.KEY_STR.indexOf(input.charAt(i++));\n      enc2 = this.KEY_STR.indexOf(input.charAt(i++));\n      enc3 = this.KEY_STR.indexOf(input.charAt(i++));\n      enc4 = this.KEY_STR.indexOf(input.charAt(i++));\n\n      chr1 = (enc1 << 2) | (enc2 >> 4);\n      chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);\n      chr3 = ((enc3 & 3) << 6) | enc4;\n\n      buf.push(chr1);\n\n      if (enc3 !== 64) {\n        buf.push(chr2);\n      }\n      if (enc4 !== 64) {\n        buf.push(chr3);\n      }\n\n      chr1 = chr2 = chr3 = '';\n      enc1 = enc2 = enc3 = enc4 = '';\n\n    } while (i < input.length);\n\n    return buf;\n  };\n\n  return ExifRestorer.restore(orig, resized);  //<= EXIF\n};\n\nfunction blobToFile(theBlob: Blob, fileName:string): File {\n  var b: any = theBlob;\n  //A Blob() is almost a File() - it's just missing the two properties below which we will add\n  b.lastModifiedDate = new Date();\n  b.name = fileName;\n\n  //Cast to a File() type\n  return <File>theBlob;\n}\n"]}
import { Directive, EventEmitter, ElementRef, Input, Output, HostListener } from '@angular/core';
import { createInvisibleFileInputWrap, isFileInput, detectSwipe } from "./doc-event-help.functions";
import { acceptType, applyExifRotation, dataUrl } from "./fileTools";
/** A master base set of logic intended to support file select/drag/drop operations
NOTE: Use ngfDrop for full drag/drop. Use ngfSelect for selecting
*/
export class ngf {
constructor(element) {
this.element = element;
this.filters = [];
this.lastFileCount = 0;
this.ngfFixOrientation = true;
this.fileDropDisabled = false;
this.selectable = false;
this.directiveInit = new EventEmitter();
this.lastInvalids = [];
this.lastInvalidsChange = new EventEmitter();
this.lastBaseUrlChange = new EventEmitter();
this.fileChange = new EventEmitter();
this.files = [];
this.filesChange = new EventEmitter();
this.fileSelectStart = new EventEmitter();
this.initFilters();
}
initFilters() {
// the order is important
this.filters.push({ name: 'accept', fn: this._acceptFilter });
this.filters.push({ name: 'fileSize', fn: this._fileSizeFilter });
//this.filters.push({name: 'fileType', fn: this._fileTypeFilter})
//this.filters.push({name: 'queueLimit', fn: this._queueLimitFilter})
//this.filters.push({name: 'mimeType', fn: this._mimeTypeFilter})
}
ngOnDestroy() {
delete this.fileElm; //faster memory release of dom element
this.destroyPasteListener();
}
ngOnInit() {
const selectable = (this.selectable || this.selectable === '') && !['false', 'null', '0'].includes(this.selectable);
if (selectable) {
this.enableSelecting();
}
if (this.multiple) {
this.paramFileElm().setAttribute('multiple', this.multiple);
}
this.evalCapturePaste();
// create reference to this class with one cycle delay to avoid ExpressionChangedAfterItHasBeenCheckedError
setTimeout(() => {
this.directiveInit.emit(this);
}, 0);
}
ngOnChanges(changes) {
var _a, _b;
if (changes.accept) {
this.paramFileElm().setAttribute('accept', changes.accept.currentValue || '*');
}
if (changes.capturePaste) {
this.evalCapturePaste();
}
// Did we go from having a file to not having a file? Clear file element then
if (changes.file && changes.file.previousValue && !changes.file.currentValue) {
this.clearFileElmValue();
}
// Did we go from having files to not having files? Clear file element then
if (changes.files) {
const filesWentToZero = ((_a = changes.files.previousValue) === null || _a === void 0 ? void 0 : _a.length) && !((_b = changes.files.currentValue) === null || _b === void 0 ? void 0 : _b.length);
if (filesWentToZero) {
this.clearFileElmValue();
}
}
}
evalCapturePaste() {
const isActive = this.capturePaste || this.capturePaste === '' || ['false', '0', 'null'].includes(this.capturePaste);
if (isActive) {
if (this.pasteCapturer) {
return; // already listening
}
this.pasteCapturer = (e) => {
const clip = e.clipboardData;
if (clip && clip.files && clip.files.length) {
this.handleFiles(clip.files);
e.preventDefault();
}
};
window.addEventListener('paste', this.pasteCapturer);
return;
}
this.destroyPasteListener();
}
destroyPasteListener() {
if (this.pasteCapturer) {
window.removeEventListener('paste', this.pasteCapturer);
delete this.pasteCapturer;
}
}
paramFileElm() {
if (this.fileElm)
return this.fileElm; // already defined
// elm already is a file input
const isFile = isFileInput(this.element.nativeElement);
if (isFile) {
return this.fileElm = this.element.nativeElement;
}
// the host elm is NOT a file input
return this.fileElm = this.createFileElm({
change: this.changeFn.bind(this)
});
}
/** Only used when host element we are attached to is NOT a fileElement */
createFileElm({ change }) {
// use specific technique to hide file element within
const label = createInvisibleFileInputWrap();
const fileElm = label.getElementsByTagName('input')[0];
fileElm.addEventListener('change', change);
this.element.nativeElement.appendChild(label); // put on html stage
return fileElm;
}
enableSelecting() {
let elm = this.element.nativeElement;
if (isFileInput(elm)) {
const bindedHandler = event => this.beforeSelect(event);
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
return;
}
const bindedHandler = ev => this.clickHandler(ev);
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
elm.addEventListener('touchend', bindedHandler);
}
getValidFiles(files) {
const rtn = [];
for (let x = files.length - 1; x >= 0; --x) {
if (this.isFileValid(files[x])) {
rtn.push(files[x]);
}
}
return rtn;
}
getInvalidFiles(files) {
const rtn = [];
for (let x = files.length - 1; x >= 0; --x) {
let failReason = this.getFileFilterFailName(files[x]);
if (failReason) {
rtn.push({
file: files[x],
type: failReason
});
}
}
return rtn;
}
// Primary handler of files coming in
handleFiles(files) {
const valids = this.getValidFiles(files);
if (files.length != valids.length) {
this.lastInvalids = this.getInvalidFiles(files);
}
else {
delete this.lastInvalids;
}
this.lastInvalidsChange.emit(this.lastInvalids);
if (valids.length) {
if (this.ngfFixOrientation) {
this.applyExifRotations(valids)
.then(fixedFiles => this.que(fixedFiles));
}
else {
this.que(valids);
}
}
if (this.isEmptyAfterSelection()) {
this.element.nativeElement.value = '';
}
}
que(files) {
this.files = this.files || [];
Array.prototype.push.apply(this.files, files);
//below break memory ref and doesnt act like a que
//this.files = files//causes memory change which triggers bindings like <ngfFormData [files]="files"></ngfFormData>
this.filesChange.emit(this.files);
if (files.length) {
this.fileChange.emit(this.file = files[0]);
if (this.lastBaseUrlChange.observers.length) {
dataUrl(files[0])
.then(url => this.lastBaseUrlChange.emit(url));
}
}
//will be checked for input value clearing
this.lastFileCount = this.files.length;
}
/** called when input has files */
changeFn(event) {
var fileList = event.__files_ || (event.target && event.target.files);
if (!fileList)
return;
this.stopEvent(event);
this.handleFiles(fileList);
}
clickHandler(evt) {
const elm = this.element.nativeElement;
if (elm.getAttribute('disabled') || this.fileDropDisabled) {
return false;
}
var r = detectSwipe(evt);
// prevent the click if it is a swipe
if (r !== false)
return r;
const fileElm = this.paramFileElm();
fileElm.click();
//fileElm.dispatchEvent( new Event('click') );
this.beforeSelect(evt);
return false;
}
beforeSelect(event) {
this.fileSelectStart.emit(event);
if (this.files && this.lastFileCount === this.files.length)
return;
// if no files in array, be sure browser does not prevent reselect of same file (see github issue 27)
this.clearFileElmValue();
}
clearFileElmValue() {
if (!this.fileElm)
return;
this.fileElm.value = null;
}
isEmptyAfterSelection() {
return !!this.element.nativeElement.attributes.multiple;
}
stopEvent(event) {
event.preventDefault();
event.stopPropagation();
}
transferHasFiles(transfer) {
if (!transfer.types) {
return false;
}
if (transfer.types.indexOf) {
return transfer.types.indexOf('Files') !== -1;
}
else if (transfer.types.contains) {
return transfer.types.contains('Files');
}
else {
return false;
}
}
eventToFiles(event) {
const transfer = eventToTransfer(event);
if (transfer) {
if (transfer.files && transfer.files.length) {
return transfer.files;
}
if (transfer.items && transfer.items.length) {
return transfer.items;
}
}
return [];
}
applyExifRotations(files) {
const mapper = (file, index) => {
return applyExifRotation(file)
.then(fixedFile => files.splice(index, 1, fixedFile));
};
const proms = [];
for (let x = files.length - 1; x >= 0; --x) {
proms[x] = mapper(files[x], x);
}
return Promise.all(proms).then(() => files);
}
onChange(event) {
let files = this.element.nativeElement.files || this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
}
getFileFilterFailName(file) {
for (let i = 0; i < this.filters.length; i++) {
if (!this.filters[i].fn.call(this, file)) {
return this.filters[i].name;
}
}
return undefined;
}
isFileValid(file) {
const noFilters = !this.accept && (!this.filters || !this.filters.length);
if (noFilters) {
return true; //we have no filters so all files are valid
}
return this.getFileFilterFailName(file) ? false : true;
}
isFilesValid(files) {
for (let x = files.length - 1; x >= 0; --x) {
if (!this.isFileValid(files[x])) {
return false;
}
}
return true;
}
_acceptFilter(item) {
return acceptType(this.accept, item.type, item.name);
}
_fileSizeFilter(item) {
return !(this.maxSize && item.size > this.maxSize);
}
}
ngf.decorators = [
{ type: Directive, args: [{
selector: "[ngf]",
exportAs: "ngf"
},] }
];
ngf.ctorParameters = () => [
{ type: ElementRef }
];
ngf.propDecorators = {
multiple: [{ type: Input }],
accept: [{ type: Input }],
maxSize: [{ type: Input }],
ngfFixOrientation: [{ type: Input }],
fileDropDisabled: [{ type: Input }],
selectable: [{ type: Input }],
directiveInit: [{ type: Output, args: ['init',] }],
lastInvalids: [{ type: Input }],
lastInvalidsChange: [{ type: Output }],
lastBaseUrl: [{ type: Input }],
lastBaseUrlChange: [{ type: Output }],
file: [{ type: Input }],
fileChange: [{ type: Output }],
files: [{ type: Input }],
filesChange: [{ type: Output }],
fileSelectStart: [{ type: Output }],
capturePaste: [{ type: Input }],
onChange: [{ type: HostListener, args: ['change', ['$event'],] }]
};
/** browsers try hard to conceal data about file drags, this tends to undo that */
export function filesToWriteableObject(files) {
const jsonFiles = [];
for (let x = 0; x < files.length; ++x) {
jsonFiles.push({
type: files[x].type,
kind: files[x]["kind"]
});
}
return jsonFiles;
}
export function eventToTransfer(event) {
if (event.dataTransfer)
return event.dataTransfer;
return event.originalEvent ? event.originalEvent.dataTransfer : null;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngf.directive.js","sourceRoot":"","sources":["../../../src/file-upload/ngf.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, ElementRef, Input, Output, HostListener, SimpleChanges } from '@angular/core';\nimport { createInvisibleFileInputWrap, isFileInput, detectSwipe } from \"./doc-event-help.functions\"\nimport {\n  acceptType, InvalidFileItem,\n  applyExifRotation, dataUrl\n} from \"./fileTools\"\n\nexport interface dragMeta{\n  type:string\n  kind:string\n}\n\n/** A master base set of logic intended to support file select/drag/drop operations\n NOTE: Use ngfDrop for full drag/drop. Use ngfSelect for selecting\n*/\n@Directive({\n  selector: \"[ngf]\",\n  exportAs:\"ngf\"\n})\nexport class ngf {\n  fileElm: any\n  filters: {name: string, fn: (file:File)=>boolean}[] = []\n  lastFileCount: number = 0\n\n  @Input() multiple !:string\n  @Input() accept   !:string\n  @Input() maxSize  !:number\n  @Input() ngfFixOrientation: boolean = true\n\n  @Input() fileDropDisabled: boolean = false\n  @Input() selectable: boolean | string = false\n  @Output('init') directiveInit:EventEmitter<ngf> = new EventEmitter()\n\n  @Input() lastInvalids:InvalidFileItem[] = []\n  @Output() lastInvalidsChange:EventEmitter<{file:File,type:string}[]> = new EventEmitter()\n\n  @Input() lastBaseUrl!: string//base64 last file uploaded url\n  @Output() lastBaseUrlChange:EventEmitter<string> = new EventEmitter()\n\n  @Input() file?: File//last file uploaded\n  @Output() fileChange: EventEmitter<File> = new EventEmitter()\n\n  @Input() files:File[] = []\n  @Output() filesChange:EventEmitter<File[]> = new EventEmitter<File[]>();\n\n  @Output() fileSelectStart:EventEmitter<Event> = new EventEmitter()\n\n  @Input() capturePaste: boolean // window paste file watching (empty string turns on)\n\n  pasteCapturer!: (e: Event) => void // goes with capturePaste\n\n  constructor(public element:ElementRef){\n    this.initFilters()\n  }\n\n  initFilters(){\n    // the order is important\n    this.filters.push({name: 'accept', fn: this._acceptFilter})\n    this.filters.push({name: 'fileSize', fn: this._fileSizeFilter})\n\n    //this.filters.push({name: 'fileType', fn: this._fileTypeFilter})\n    //this.filters.push({name: 'queueLimit', fn: this._queueLimitFilter})\n    //this.filters.push({name: 'mimeType', fn: this._mimeTypeFilter})\n  }\n\n  ngOnDestroy(){\n    delete this.fileElm//faster memory release of dom element\n    this.destroyPasteListener();\n  }\n\n  ngOnInit(){\n    const selectable = (this.selectable || this.selectable==='') && !['false', 'null', '0'].includes(this.selectable as string);\n    if( selectable ){\n      this.enableSelecting()\n    }\n\n    if( this.multiple ){\n      this.paramFileElm().setAttribute('multiple', this.multiple)\n    }\n\n    this.evalCapturePaste();\n\n    // create reference to this class with one cycle delay to avoid ExpressionChangedAfterItHasBeenCheckedError\n    setTimeout(()=>{\n      this.directiveInit.emit(this)\n    }, 0)\n  }\n\n  ngOnChanges( changes: SimpleChanges ){\n    if( changes.accept ){\n      this.paramFileElm().setAttribute('accept', changes.accept.currentValue || '*')\n    }\n\n    if (changes.capturePaste) {\n      this.evalCapturePaste();\n    }\n\n    // Did we go from having a file to not having a file? Clear file element then\n    if (changes.file && changes.file.previousValue && !changes.file.currentValue) {\n      this.clearFileElmValue()\n    }\n\n    // Did we go from having files to not having files? Clear file element then\n    if (changes.files) {\n      const filesWentToZero = changes.files.previousValue?.length && !changes.files.currentValue?.length\n\n      if (filesWentToZero) {\n        this.clearFileElmValue()\n      }\n    }\n  }\n\n  evalCapturePaste() {\n    const isActive = this.capturePaste || (this.capturePaste as any)==='' || ['false', '0', 'null'].includes(this.capturePaste as any);\n\n    if (isActive) {\n      if (this.pasteCapturer) {\n        return; // already listening\n      }\n\n      this.pasteCapturer = (e: Event) => {\n        const clip = (e as any).clipboardData;\n        if (clip && clip.files && clip.files.length) {\n          this.handleFiles(clip.files);\n          e.preventDefault();\n        }\n      }\n\n      window.addEventListener('paste', this.pasteCapturer);\n\n      return;\n    }\n\n    this.destroyPasteListener();\n  }\n\n  destroyPasteListener() {\n    if (this.pasteCapturer) {\n      window.removeEventListener('paste', this.pasteCapturer);\n      delete this.pasteCapturer;\n    }\n  }\n\n  paramFileElm(){\n    if( this.fileElm )return this.fileElm // already defined\n\n    // elm already is a file input\n    const isFile = isFileInput( this.element.nativeElement )\n    if(isFile){\n      return this.fileElm = this.element.nativeElement\n    }\n\n    // the host elm is NOT a file input\n    return this.fileElm = this.createFileElm({\n      change: this.changeFn.bind(this)\n    })\n  }\n\n  /** Only used when host element we are attached to is NOT a fileElement */\n  createFileElm({change}: {change:() => any}) {\n    // use specific technique to hide file element within\n    const label = createInvisibleFileInputWrap()\n    const fileElm = label.getElementsByTagName('input')[0]\n\n    fileElm.addEventListener('change', change);\n    this.element.nativeElement.appendChild( label ) // put on html stage\n\n    return fileElm\n  }\n\n  enableSelecting(){\n    let elm = this.element.nativeElement\n\n    if( isFileInput(elm) ){\n      const bindedHandler = event => this.beforeSelect(event)\n      elm.addEventListener('click', bindedHandler)\n      elm.addEventListener('touchstart', bindedHandler)\n      return\n    }\n\n    const bindedHandler = ev => this.clickHandler(ev)\n    elm.addEventListener('click', bindedHandler)\n    elm.addEventListener('touchstart', bindedHandler)\n    elm.addEventListener('touchend', bindedHandler)\n  }\n\n  getValidFiles( files:File[] ):File[]{\n    const rtn:File[] = []\n    for(let x=files.length-1; x >= 0; --x){\n      if( this.isFileValid(files[x]) ){\n        rtn.push( files[x] )\n      }\n    }\n    return rtn\n  }\n\n  getInvalidFiles(files:File[]):InvalidFileItem[]{\n    const rtn:InvalidFileItem[] = []\n    for(let x=files.length-1; x >= 0; --x){\n      let failReason = this.getFileFilterFailName(files[x])\n      if( failReason ){\n        rtn.push({\n          file : files[x],\n          type : failReason\n        })\n      }\n    }\n    return rtn\n  }\n\n  // Primary handler of files coming in\n  handleFiles(files:File[]){\n    const valids = this.getValidFiles(files)\n\n    if(files.length!=valids.length){\n      this.lastInvalids = this.getInvalidFiles(files)\n    }else{\n      delete this.lastInvalids\n    }\n\n    this.lastInvalidsChange.emit(this.lastInvalids)\n\n    if( valids.length ){\n      if( this.ngfFixOrientation ){\n        this.applyExifRotations(valids)\n        .then( fixedFiles=>this.que(fixedFiles) )\n      }else{\n        this.que(valids)\n      }\n    }\n\n    if (this.isEmptyAfterSelection()) {\n      this.element.nativeElement.value = ''\n    }\n  }\n\n  que( files:File[] ){\n    this.files = this.files || []\n    Array.prototype.push.apply(this.files, files)\n\n    //below break memory ref and doesnt act like a que\n    //this.files = files//causes memory change which triggers bindings like <ngfFormData [files]=\"files\"></ngfFormData>\n\n    this.filesChange.emit( this.files )\n\n    if(files.length){\n      this.fileChange.emit( this.file=files[0] )\n\n      if(this.lastBaseUrlChange.observers.length){\n        dataUrl( files[0] )\n        .then( url=>this.lastBaseUrlChange.emit(url) )\n      }\n    }\n\n    //will be checked for input value clearing\n    this.lastFileCount = this.files.length\n  }\n\n  /** called when input has files */\n  changeFn(event:any) {\n    var fileList = event.__files_ || (event.target && event.target.files)\n\n    if (!fileList) return;\n\n    this.stopEvent(event);\n    this.handleFiles(fileList)\n  }\n\n  clickHandler(evt: Event){\n    const elm = this.element.nativeElement\n    if (elm.getAttribute('disabled') || this.fileDropDisabled){\n      return false;\n    }\n\n    var r = detectSwipe(evt);\n    // prevent the click if it is a swipe\n    if ( r!==false ) return r;\n\n    const fileElm = this.paramFileElm()\n    fileElm.click()\n    //fileElm.dispatchEvent( new Event('click') );\n    this.beforeSelect(evt)\n\n    return false;\n  }\n\n  beforeSelect(event: Event){\n    this.fileSelectStart.emit(event)\n\n    if( this.files && this.lastFileCount===this.files.length )return\n\n    // if no files in array, be sure browser does not prevent reselect of same file (see github issue 27)\n    this.clearFileElmValue()\n  }\n\n  clearFileElmValue() {\n    if (!this.fileElm) return\n\n    this.fileElm.value = null\n  }\n\n  isEmptyAfterSelection():boolean {\n    return !!this.element.nativeElement.attributes.multiple;\n  }\n\n  stopEvent(event:any):any {\n    event.preventDefault();\n    event.stopPropagation();\n  }\n\n  transferHasFiles(transfer:any):any {\n    if (!transfer.types) {\n      return false;\n    }\n\n    if (transfer.types.indexOf) {\n      return transfer.types.indexOf('Files') !== -1;\n    } else if (transfer.types.contains) {\n      return transfer.types.contains('Files');\n    } else {\n      return false;\n    }\n  }\n\n  eventToFiles(event:Event){\n    const transfer = eventToTransfer(event);\n    if( transfer ){\n      if(transfer.files && transfer.files.length){\n        return transfer.files\n      }\n      if(transfer.items && transfer.items.length){\n        return transfer.items\n      }\n    }\n    return []\n  }\n\n  applyExifRotations(\n    files:File[]\n  ):Promise<File[]>{\n    const mapper = (\n      file:File,index:number\n    ):Promise<any>=>{\n      return applyExifRotation(file)\n      .then( fixedFile=>files.splice(index, 1, fixedFile) )\n    }\n\n    const proms:Promise<any>[] = []\n    for(let x=files.length-1; x >= 0; --x){\n      proms[x] = mapper( files[x], x )\n    }\n    return Promise.all( proms ).then( ()=>files )\n  }\n\n  @HostListener('change', ['$event'])\n  onChange(event:Event):void {\n    let files = this.element.nativeElement.files || this.eventToFiles(event)\n\n    if(!files.length)return\n\n    this.stopEvent(event);\n    this.handleFiles(files)\n  }\n\n  getFileFilterFailName(\n    file:File\n  ):string | undefined{\n    for(let i = 0; i < this.filters.length; i++){\n      if( !this.filters[i].fn.call(this, file) ){\n        return this.filters[i].name\n      }\n    }\n    return undefined\n  }\n\n  isFileValid(file:File):boolean{\n    const noFilters = !this.accept && (!this.filters || !this.filters.length)\n    if( noFilters ){\n      return true//we have no filters so all files are valid\n    }\n\n    return this.getFileFilterFailName(file) ? false : true\n  }\n\n  isFilesValid(files:File[]){\n    for(let x=files.length-1; x >= 0; --x){\n      if( !this.isFileValid(files[x]) ){\n        return false\n      }\n    }\n    return true\n  }\n\n  protected _acceptFilter(item:File):boolean {\n    return acceptType(this.accept, item.type, item.name)\n  }\n\n  protected _fileSizeFilter(item:File):boolean {\n    return !(this.maxSize && item.size > this.maxSize);\n  }\n}\n\n\n/** browsers try hard to conceal data about file drags, this tends to undo that */\nexport function filesToWriteableObject( files:File[] ):dragMeta[]{\n  const jsonFiles:dragMeta[] = []\n  for(let x=0; x < files.length; ++x){\n    jsonFiles.push({\n      type:files[x].type,\n      kind:files[x][\"kind\"]\n    })\n  }\n  return jsonFiles\n}\n\nexport function eventToTransfer(event: any): TransferObject {\n  if(event.dataTransfer)return event.dataTransfer\n  return  event.originalEvent ? event.originalEvent.dataTransfer : null\n}\n\n\ninterface TransferObject {\n  items?: any[]\n  files?: any[]\n  dropEffect?: 'copy' // https://developer.mozilla.org/en-US/docs/Web/API/DataTransfer/dropEffect\n}\n"]}
import { CommonModule } from '@angular/common';
import { NgModule } from '@angular/core';
import { ngfBackground } from './ngfBackground.directive';
import { ngfDrop } from './ngfDrop.directive';
import { ngf } from './ngf.directive';
import { ngfSelect } from './ngfSelect.directive';
import { ngfUploadStatus } from './ngfUploadStatus.directive';
import { ngfFormData } from './ngfFormData.directive';
import { ngfSrc } from './ngfSrc.directive';
//import{ HttpModule } from '@angular/http';
const declarations = [
ngfDrop,
ngfSelect,
ngfBackground,
ngfSrc,
ngfUploadStatus,
ngfFormData,
ngf
];
export class ngfModule {
}
ngfModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule
//,HttpModule
],
declarations: declarations,
exports: declarations //[HttpModule, ...declarations]
},] }
];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9maWxlLXVwbG9hZC9uZ2YubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDOUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3RDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM1Qyw0Q0FBNEM7QUFFNUMsTUFBTSxZQUFZLEdBQUc7SUFDbkIsT0FBTztJQUNQLFNBQVM7SUFDVCxhQUFhO0lBQ2IsTUFBTTtJQUNOLGVBQWU7SUFDZixXQUFXO0lBQ1gsR0FBRztDQUNKLENBQUE7QUFTRSxNQUFNLE9BQU8sU0FBUzs7O1lBUHhCLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWixhQUFhO2lCQUNkO2dCQUNELFlBQVksRUFBRSxZQUFZO2dCQUMxQixPQUFPLEVBQUUsWUFBWSxDQUFBLCtCQUErQjthQUNyRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBuZ2ZCYWNrZ3JvdW5kIH0gZnJvbSAnLi9uZ2ZCYWNrZ3JvdW5kLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBuZ2ZEcm9wIH0gZnJvbSAnLi9uZ2ZEcm9wLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBuZ2YgfSBmcm9tICcuL25nZi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgbmdmU2VsZWN0IH0gZnJvbSAnLi9uZ2ZTZWxlY3QuZGlyZWN0aXZlJztcbmltcG9ydCB7IG5nZlVwbG9hZFN0YXR1cyB9IGZyb20gJy4vbmdmVXBsb2FkU3RhdHVzLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBuZ2ZGb3JtRGF0YSB9IGZyb20gJy4vbmdmRm9ybURhdGEuZGlyZWN0aXZlJztcbmltcG9ydCB7IG5nZlNyYyB9IGZyb20gJy4vbmdmU3JjLmRpcmVjdGl2ZSc7XG4vL2ltcG9ydHsgSHR0cE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2h0dHAnO1xuXG5jb25zdCBkZWNsYXJhdGlvbnMgPSBbXG4gIG5nZkRyb3AsXG4gIG5nZlNlbGVjdCxcbiAgbmdmQmFja2dyb3VuZCxcbiAgbmdmU3JjLFxuICBuZ2ZVcGxvYWRTdGF0dXMsXG4gIG5nZkZvcm1EYXRhLFxuICBuZ2Zcbl1cblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICAgIC8vLEh0dHBNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBkZWNsYXJhdGlvbnMsXG4gIGV4cG9ydHM6IGRlY2xhcmF0aW9ucy8vW0h0dHBNb2R1bGUsIC4uLmRlY2xhcmF0aW9uc11cbn0pIGV4cG9ydCBjbGFzcyBuZ2ZNb2R1bGUge30iXX0=
import { Directive, ElementRef, Input } from '@angular/core';
import { dataUrl } from './fileTools';
export class ngfBackground {
constructor(ElementRef) {
this.ElementRef = ElementRef;
}
ngOnChanges(_changes) {
dataUrl(this.file)
.then(src => {
const urlString = 'url(\'' + (src || '') + '\')';
this.ElementRef.nativeElement.style.backgroundImage = urlString;
});
}
}
ngfBackground.decorators = [
{ type: Directive, args: [{ selector: '[ngfBackground]' },] }
];
ngfBackground.ctorParameters = () => [
{ type: ElementRef }
];
ngfBackground.propDecorators = {
file: [{ type: Input, args: ['ngfBackground',] }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmQmFja2dyb3VuZC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZmlsZS11cGxvYWQvbmdmQmFja2dyb3VuZC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFHdEMsTUFBTSxPQUFPLGFBQWE7SUFHeEIsWUFBbUIsVUFBcUI7UUFBckIsZUFBVSxHQUFWLFVBQVUsQ0FBVztJQUFFLENBQUM7SUFFM0MsV0FBVyxDQUFFLFFBQVk7UUFDdkIsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7YUFDakIsSUFBSSxDQUFDLEdBQUcsQ0FBQSxFQUFFO1lBQ1QsTUFBTSxTQUFTLEdBQUcsUUFBUSxHQUFHLENBQUMsR0FBRyxJQUFJLEVBQUUsQ0FBQyxHQUFHLEtBQUssQ0FBQTtZQUNoRCxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsZUFBZSxHQUFHLFNBQVMsQ0FBQTtRQUNqRSxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7OztZQVpGLFNBQVMsU0FBQyxFQUFDLFFBQVEsRUFBRSxpQkFBaUIsRUFBQzs7O1lBSHBCLFVBQVU7OzttQkFLM0IsS0FBSyxTQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBkYXRhVXJsIH0gZnJvbSAnLi9maWxlVG9vbHMnO1xuXG5ARGlyZWN0aXZlKHtzZWxlY3RvcjogJ1tuZ2ZCYWNrZ3JvdW5kXSd9KVxuZXhwb3J0IGNsYXNzIG5nZkJhY2tncm91bmQge1xuICBASW5wdXQoJ25nZkJhY2tncm91bmQnKSBmaWxlOmFueVxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBFbGVtZW50UmVmOkVsZW1lbnRSZWYpe31cblxuICBuZ09uQ2hhbmdlcyggX2NoYW5nZXM6YW55ICl7XG4gICAgZGF0YVVybCh0aGlzLmZpbGUpXG4gICAgLnRoZW4oc3JjPT57XG4gICAgICBjb25zdCB1cmxTdHJpbmcgPSAndXJsKFxcJycgKyAoc3JjIHx8ICcnKSArICdcXCcpJ1xuICAgICAgdGhpcy5FbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuc3R5bGUuYmFja2dyb3VuZEltYWdlID0gdXJsU3RyaW5nXG4gICAgfSlcbiAgfVxufVxuIl19
import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
import { ngf, eventToTransfer, filesToWriteableObject } from "./ngf.directive";
export class ngfDrop extends ngf {
constructor() {
super(...arguments);
this.fileOver = new EventEmitter();
this.validDrag = false;
this.validDragChange = new EventEmitter();
this.invalidDrag = false;
this.invalidDragChange = new EventEmitter();
this.dragFilesChange = new EventEmitter();
}
onDrop(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
let files = this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
}
handleFiles(files) {
this.fileOver.emit(false); //turn-off dragover
super.handleFiles(files);
}
onDragOver(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
const transfer = eventToTransfer(event);
let files = this.eventToFiles(event);
let jsonFiles = filesToWriteableObject(files);
this.dragFilesChange.emit(this.dragFiles = jsonFiles);
if (files.length) {
this.validDrag = this.isFilesValid(files);
}
else {
//Safari, IE11 & some browsers do NOT tell you about dragged files until dropped. Always consider a valid drag
this.validDrag = true;
}
this.validDragChange.emit(this.validDrag);
this.invalidDrag = !this.validDrag;
this.invalidDragChange.emit(this.invalidDrag);
transfer.dropEffect = 'copy'; // change cursor and visual display
this.stopEvent(event);
this.fileOver.emit(true);
}
closeDrags() {
delete this.validDrag;
this.validDragChange.emit(this.validDrag);
this.invalidDrag = false;
this.invalidDragChange.emit(this.invalidDrag);
delete this.dragFiles;
this.dragFilesChange.emit(this.dragFiles);
}
onDragLeave(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
if (this.element) {
if (event.currentTarget === this.element[0]) {
return;
}
}
this.stopEvent(event);
this.fileOver.emit(false);
}
}
ngfDrop.decorators = [
{ type: Directive, args: [{
selector: "[ngfDrop]",
exportAs: "ngfDrop"
},] }
];
ngfDrop.propDecorators = {
fileOver: [{ type: Output }],
validDrag: [{ type: Input }],
validDragChange: [{ type: Output }],
invalidDrag: [{ type: Input }],
invalidDragChange: [{ type: Output }],
dragFiles: [{ type: Input }],
dragFilesChange: [{ type: Output }],
onDrop: [{ type: HostListener, args: ['drop', ['$event'],] }],
onDragOver: [{ type: HostListener, args: ['dragover', ['$event'],] }],
onDragLeave: [{ type: HostListener, args: ['dragleave', ['$event'],] }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmRHJvcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZmlsZS11cGxvYWQvbmdmRHJvcC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFBRSxZQUFZLEVBQ3ZCLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUM1QixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsR0FBRyxFQUFZLGVBQWUsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBTXhGLE1BQU0sT0FBTyxPQUFRLFNBQVEsR0FBRztJQUpoQzs7UUFLWSxhQUFRLEdBQXFCLElBQUksWUFBWSxFQUFFLENBQUM7UUFFakQsY0FBUyxHQUFXLEtBQUssQ0FBQTtRQUN4QixvQkFBZSxHQUF5QixJQUFJLFlBQVksRUFBRSxDQUFBO1FBRTNELGdCQUFXLEdBQUcsS0FBSyxDQUFBO1FBQ2xCLHNCQUFpQixHQUF5QixJQUFJLFlBQVksRUFBRSxDQUFBO1FBRzVELG9CQUFlLEdBQTRCLElBQUksWUFBWSxFQUFFLENBQUE7SUFpRnpFLENBQUM7SUE5RUMsTUFBTSxDQUFDLEtBQVc7UUFDaEIsSUFBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUM7WUFDdkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUN0QixPQUFNO1NBQ1A7UUFFRCxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7UUFDakIsSUFBSSxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUVwQyxJQUFHLENBQUMsS0FBSyxDQUFDLE1BQU07WUFBQyxPQUFNO1FBRXZCLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUN6QixDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQVk7UUFDdEIs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Q0FBQyxRQUFRLENBQUM7MEJBd0NuQyxZQUFZLFNBQUMsV0FBVyxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsXG4gIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE91dHB1dFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IG5nZiwgZHJhZ01ldGEsIGV2ZW50VG9UcmFuc2ZlciwgZmlsZXNUb1dyaXRlYWJsZU9iamVjdCB9IGZyb20gXCIuL25nZi5kaXJlY3RpdmVcIlxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6IFwiW25nZkRyb3BdXCIsXG4gIGV4cG9ydEFzOiBcIm5nZkRyb3BcIlxufSlcbmV4cG9ydCBjbGFzcyBuZ2ZEcm9wIGV4dGVuZHMgbmdmIHtcbiAgQE91dHB1dCgpIGZpbGVPdmVyOkV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIEBJbnB1dCgpIHZhbGlkRHJhZzpib29sZWFuID0gZmFsc2VcbiAgQE91dHB1dCgpIHZhbGlkRHJhZ0NoYW5nZTpFdmVudEVtaXR0ZXI8Ym9vbGVhbj4gPSBuZXcgRXZlbnRFbWl0dGVyKClcblxuICBASW5wdXQoKSBpbnZhbGlkRHJhZyA9IGZhbHNlXG4gIEBPdXRwdXQoKSBpbnZhbGlkRHJhZ0NoYW5nZTpFdmVudEVtaXR0ZXI8Ym9vbGVhbj4gPSBuZXcgRXZlbnRFbWl0dGVyKClcblxuICBASW5wdXQoKSBkcmFnRmlsZXMgITogZHJhZ01ldGFbXVxuICBAT3V0cHV0KCkgZHJhZ0ZpbGVzQ2hhbmdlOkV2ZW50RW1pdHRlcjxkcmFnTWV0YVtdPiA9IG5ldyBFdmVudEVtaXR0ZXIoKVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2Ryb3AnLCBbJyRldmVudCddKVxuICBvbkRyb3AoZXZlbnQ6RXZlbnQpOnZvaWQge1xuICAgIGlmKHRoaXMuZmlsZURyb3BEaXNhYmxlZCl7XG4gICAgICB0aGlzLnN0b3BFdmVudChldmVudCk7XG4gICAgICByZXR1cm5cbiAgICB9XG5cbiAgICB0aGlzLmNsb3NlRHJhZ3MoKVxuICAgIGxldCBmaWxlcyA9IHRoaXMuZXZlbnRUb0ZpbGVzKGV2ZW50KVxuXG4gICAgaWYoIWZpbGVzLmxlbmd0aClyZXR1cm5cblxuICAgIHRoaXMuc3RvcEV2ZW50KGV2ZW50KTtcbiAgICB0aGlzLmhhbmRsZUZpbGVzKGZpbGVzKVxuICB9XG5cbiAgaGFuZGxlRmlsZXMoZmlsZXM6RmlsZVtdKXtcbiAgICB0aGlzLmZpbGVPdmVyLmVtaXQoZmFsc2UpLy90dXJuLW9mZiBkcmFnb3ZlclxuICAgIHN1cGVyLmhhbmRsZUZpbGVzKGZpbGVzKVxuICB9XG5cbiAgQEhvc3RMaXN0ZW5lcignZHJhZ292ZXInLCBbJyRldmVudCddKVxuICBvbkRyYWdPdmVyKGV2ZW50OkV2ZW50KTp2b2lkIHtcbiAgICBpZih0aGlzLmZpbGVEcm9wRGlzYWJsZWQpe1xuICAgICAgdGhpcy5zdG9wRXZlbnQoZXZlbnQpO1xuICAgICAgcmV0dXJuXG4gICAgfVxuXG4gICAgY29uc3QgdHJhbnNmZXIgPSBldmVudFRvVHJhbnNmZXIoZXZlbnQpXG5cbiAgICBsZXQgZmlsZXMgPSB0aGlzLmV2ZW50VG9GaWxlcyhldmVudClcblxuICAgIGxldCBqc29uRmlsZXMgPSBmaWxlc1RvV3JpdGVhYmxlT2JqZWN0KGZpbGVzKVxuICAgIHRoaXMuZHJhZ0ZpbGVzQ2hhbmdlLmVtaXQoIHRoaXMuZHJhZ0ZpbGVzPWpzb25GaWxlcyApXG5cbiAgICBpZiggZmlsZXMubGVuZ3RoICl7XG4gICAgICB0aGlzLnZhbGlkRHJhZyA9IHRoaXMuaXNGaWxlc1ZhbGlkKGZpbGVzKVxuICAgIH1lbHNle1xuICAgICAgLy9TYWZhcmksIElFMTEgJiBzb21lIGJyb3dzZXJzIGRvIE5PVCB0ZWxsIHlvdSBhYm91dCBkcmFnZ2VkIGZpbGVzIHVudGlsIGRyb3BwZWQuIEFsd2F5cyBjb25zaWRlciBhIHZhbGlkIGRyYWdcbiAgICAgIHRoaXMudmFsaWREcmFnID0gdHJ1ZVxuICAgIH1cblxuICAgIHRoaXMudmFsaWREcmFnQ2hhbmdlLmVtaXQodGhpcy52YWxpZERyYWcpXG5cbiAgICB0aGlzLmludmFsaWREcmFnID0gIXRoaXMudmFsaWREcmFnXG4gICAgdGhpcy5pbnZhbGlkRHJhZ0NoYW5nZS5lbWl0KHRoaXMuaW52YWxpZERyYWcpXG5cbiAgICB0cmFuc2Zlci5kcm9wRWZmZWN0ID0gJ2NvcHknIC8vIGNoYW5nZSBjdXJzb3IgYW5kIHZpc3VhbCBkaXNwbGF5XG4gICAgdGhpcy5zdG9wRXZlbnQoZXZlbnQpXG4gICAgdGhpcy5maWxlT3Zlci5lbWl0KHRydWUpXG4gIH1cblxuICBjbG9zZURyYWdzKCl7XG4gICAgZGVsZXRlIHRoaXMudmFsaWREcmFnXG4gICAgdGhpcy52YWxpZERyYWdDaGFuZ2UuZW1pdCh0aGlzLnZhbGlkRHJhZylcbiAgICB0aGlzLmludmFsaWREcmFnID0gZmFsc2VcbiAgICB0aGlzLmludmFsaWREcmFnQ2hhbmdlLmVtaXQodGhpcy5pbnZhbGlkRHJhZylcbiAgICBkZWxldGUgdGhpcy5kcmFnRmlsZXNcbiAgICB0aGlzLmRyYWdGaWxlc0NoYW5nZS5lbWl0KCB0aGlzLmRyYWdGaWxlcyApXG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdkcmFnbGVhdmUnLCBbJyRldmVudCddKVxuICBvbkRyYWdMZWF2ZShldmVudDpFdmVudCk6YW55IHtcbiAgICBpZih0aGlzLmZpbGVEcm9wRGlzYWJsZWQpe1xuICAgICAgdGhpcy5zdG9wRXZlbnQoZXZlbnQpO1xuICAgICAgcmV0dXJuXG4gICAgfVxuXG4gICAgdGhpcy5jbG9zZURyYWdzKClcblxuICAgIGlmICgodGhpcyBhcyBhbnkpLmVsZW1lbnQpIHtcbiAgICAgIGlmIChldmVudC5jdXJyZW50VGFyZ2V0ID09PSAodGhpcyBhcyBhbnkpLmVsZW1lbnRbMF0pIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgIH1cblxuICAgIHRoaXMuc3RvcEV2ZW50KGV2ZW50KTtcbiAgICB0aGlzLmZpbGVPdmVyLmVtaXQoZmFsc2UpO1xuICB9XG59Il19
import { IterableDiffers, Directive, EventEmitter, Output, Input } from '@angular/core';
export class ngfFormData {
constructor(IterableDiffers) {
this.postName = "file";
this.FormData = new FormData();
this.FormDataChange = new EventEmitter();
this.differ = IterableDiffers.find([]).create();
}
ngDoCheck() {
var changes = this.differ.diff(this.files);
if (changes) {
setTimeout(() => this.buildFormData(), 0);
}
}
buildFormData() {
const isArray = typeof (this.files) === 'object' && this.files.constructor === Array;
if (isArray) {
this.FormData = new FormData();
const files = this.files || [];
files.forEach(file => this.FormData.append(this.postName, file, this.fileName || file.name));
this.FormDataChange.emit(this.FormData);
}
else {
delete this.FormData;
}
}
}
ngfFormData.decorators = [
{ type: Directive, args: [{ selector: 'ngfFormData' },] }
];
ngfFormData.ctorParameters = () => [
{ type: IterableDiffers }
];
ngfFormData.propDecorators = {
files: [{ type: Input }],
postName: [{ type: Input }],
fileName: [{ type: Input }],
FormData: [{ type: Input }],
FormDataChange: [{ type: Output }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmRm9ybURhdGEuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2ZpbGUtdXBsb2FkL25nZkZvcm1EYXRhLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsZUFBZSxFQUNmLFNBQVMsRUFBRSxZQUFZLEVBQ3ZCLE1BQU0sRUFBRSxLQUFLLEVBQ2QsTUFBTSxlQUFlLENBQUM7QUFHdkIsTUFBTSxPQUFPLFdBQVc7SUFVdEIsWUFBWSxlQUFnQztRQVJuQyxhQUFRLEdBQVUsTUFBTSxDQUFBO1FBR3hCLGFBQVEsR0FBWSxJQUFJLFFBQVEsRUFBRSxDQUFBO1FBQ2pDLG1CQUFjLEdBQTBCLElBQUksWUFBWSxFQUFFLENBQUE7UUFLbEUsSUFBSSxDQUFDLE1BQU0sR0FBRyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFBO0lBQ2pELENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxPQUFPLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUUsSUFBSSxDQUFDLEtBQUssQ0FBRSxDQUFDO1FBRTdDLElBQUksT0FBTyxFQUFFO1lBQ1gsVUFBVSxDQUFDLEdBQUUsRUFBRSxDQUFBLElBQUksQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQTtTQUN4QztJQUNILENBQUM7SUFFRCxhQUFhO1FBQ1gsTUFBTSxPQUFPLEdBQUcsT0FBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBRyxRQUFRLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEtBQUcsS0FBSyxDQUFBO1FBRS9FLElBQUksT0FBTyxFQUFFO1lBQ1gsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRSxDQUFBO1lBQzlCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFBO1lBQzlCLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFBLEVBQUUsQ0FDbEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLFFBQVEsSUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQ3BFLENBQUE7WUFDRCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBRSxJQUFJLENBQUMsUUFBUSxDQUFFLENBQUE7U0FDMUM7YUFBSTtZQUNILE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQTtTQUNyQjtJQUNILENBQUM7OztZQXBDRixTQUFTLFNBQUMsRUFBQyxRQUFRLEVBQUUsYUFBYSxFQUFDOzs7WUFMbEMsZUFBZTs7O29CQU9kLEtBQUs7dUJBQ0wsS0FBSzt1QkFDTCxLQUFLO3VCQUVMLEtBQUs7NkJBQ0wsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEl0ZXJhYmxlRGlmZmVyLFxuICBJdGVyYWJsZURpZmZlcnMsXG4gIERpcmVjdGl2ZSwgRXZlbnRFbWl0dGVyLFxuICBPdXRwdXQsIElucHV0XG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtzZWxlY3RvcjogJ25nZkZvcm1EYXRhJ30pXG5leHBvcnQgY2xhc3MgbmdmRm9ybURhdGEge1xuICBASW5wdXQoKSBmaWxlcyAhOiBGaWxlW11cbiAgQElucHV0KCkgcG9zdE5hbWU6c3RyaW5nID0gXCJmaWxlXCJcbiAgQElucHV0KCkgZmlsZU5hbWUgITogc3RyaW5nLy9mb3JjZSBmaWxlIG5hbWVcblxuICBASW5wdXQoKSBGb3JtRGF0YTpGb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpXG4gIEBPdXRwdXQoKSBGb3JtRGF0YUNoYW5nZTpFdmVudEVtaXR0ZXI8Rm9ybURhdGE+ID0gbmV3IEV2ZW50RW1pdHRlcigpXG5cbiAgZGlmZmVyOkl0ZXJhYmxlRGlmZmVyPHt9PlxuXG4gIGNvbnN0cnVjdG9yKEl0ZXJhYmxlRGlmZmVyczogSXRlcmFibGVEaWZmZXJzKXtcbiAgICB0aGlzLmRpZmZlciA9IEl0ZXJhYmxlRGlmZmVycy5maW5kKFtdKS5jcmVhdGUoKVxuICB9XG5cbiAgbmdEb0NoZWNrKCl7XG4gICAgdmFyIGNoYW5nZXMgPSB0aGlzLmRpZmZlci5kaWZmKCB0aGlzLmZpbGVzICk7XG5cbiAgICBpZiAoY2hhbmdlcykge1xuICAgICAgc2V0VGltZW91dCgoKT0+dGhpcy5idWlsZEZvcm1EYXRhKCksIDApXG4gICAgfVxuICB9XG5cbiAgYnVpbGRGb3JtRGF0YSgpe1xuICAgIGNvbnN0IGlzQXJyYXkgPSB0eXBlb2YodGhpcy5maWxlcyk9PT0nb2JqZWN0JyAmJiB0aGlzLmZpbGVzLmNvbnN0cnVjdG9yPT09QXJyYXlcblxuICAgIGlmKCBpc0FycmF5ICl7XG4gICAgICB0aGlzLkZvcm1EYXRhID0gbmV3IEZvcm1EYXRhKClcbiAgICAgIGNvbnN0IGZpbGVzID0gdGhpcy5maWxlcyB8fCBbXVxuICAgICAgZmlsZXMuZm9yRWFjaChmaWxlPT5cbiAgICAgICAgdGhpcy5Gb3JtRGF0YS5hcHBlbmQodGhpcy5wb3N0TmFtZSwgZmlsZSwgdGhpcy5maWxlTmFtZXx8ZmlsZS5uYW1lKVxuICAgICAgKVxuICAgICAgdGhpcy5Gb3JtRGF0YUNoYW5nZS5lbWl0KCB0aGlzLkZvcm1EYXRhIClcbiAgICB9ZWxzZXtcbiAgICAgIGRlbGV0ZSB0aGlzLkZvcm1EYXRhXG4gICAgfVxuICB9XG59Il19
import { Directive, Input } from "@angular/core";
import { ngf } from "./ngf.directive";
export class ngfSelect extends ngf {
constructor() {
super(...arguments);
this.selectable = true;
}
}
ngfSelect.decorators = [
{ type: Directive, args: [{
selector: "[ngfSelect]",
exportAs: "ngfSelect"
},] }
];
ngfSelect.propDecorators = {
selectable: [{ type: Input }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmU2VsZWN0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9maWxlLXVwbG9hZC9uZ2ZTZWxlY3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ2hELE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQU1yQyxNQUFNLE9BQU8sU0FBVSxTQUFRLEdBQUc7SUFKbEM7O1FBS1csZUFBVSxHQUFPLElBQUksQ0FBQTtJQUNoQyxDQUFDOzs7WUFOQSxTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGFBQWE7Z0JBQ3ZCLFFBQVEsRUFBRSxXQUFXO2FBQ3RCOzs7eUJBRUUsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5pbXBvcnQgeyBuZ2YgfSBmcm9tIFwiLi9uZ2YuZGlyZWN0aXZlXCJcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiBcIltuZ2ZTZWxlY3RdXCIsXG4gIGV4cG9ydEFzOiBcIm5nZlNlbGVjdFwiXG59KVxuZXhwb3J0IGNsYXNzIG5nZlNlbGVjdCBleHRlbmRzIG5nZiB7XG4gIEBJbnB1dCgpIHNlbGVjdGFibGU6YW55ID0gdHJ1ZVxufSJdfQ==
import { Directive, ElementRef, Input } from '@angular/core';
import { dataUrl } from './fileTools';
export class ngfSrc {
constructor(ElementRef) {
this.ElementRef = ElementRef;
}
ngOnChanges(_changes) {
dataUrl(this.file)
.then(src => this.ElementRef.nativeElement.src = src);
}
}
ngfSrc.decorators = [
{ type: Directive, args: [{ selector: '[ngfSrc]' },] }
];
ngfSrc.ctorParameters = () => [
{ type: ElementRef }
];
ngfSrc.propDecorators = {
file: [{ type: Input, args: ['ngfSrc',] }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmU3JjLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9maWxlLXVwbG9hZC9uZ2ZTcmMuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBR3RDLE1BQU0sT0FBTyxNQUFNO0lBR2pCLFlBQW1CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7SUFBSSxDQUFDO0lBRTlDLFdBQVcsQ0FBQyxRQUFhO1FBQ3ZCLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO2FBQ2pCLElBQUksQ0FBQyxHQUFHLENBQUEsRUFBRSxDQUNULElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQ3hDLENBQUE7SUFDSCxDQUFDOzs7WUFYRixTQUFTLFNBQUMsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFOzs7WUFIZixVQUFVOzs7bUJBSzNCLEtBQUssU0FBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZGF0YVVybCB9IGZyb20gJy4vZmlsZVRvb2xzJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnW25nZlNyY10nIH0pXG5leHBvcnQgY2xhc3MgbmdmU3JjIHtcbiAgQElucHV0KCduZ2ZTcmMnKSBmaWxlOiBhbnlcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgRWxlbWVudFJlZjogRWxlbWVudFJlZikgeyB9XG5cbiAgbmdPbkNoYW5nZXMoX2NoYW5nZXM6IGFueSkge1xuICAgIGRhdGFVcmwodGhpcy5maWxlKVxuICAgIC50aGVuKHNyYz0+XG4gICAgICB0aGlzLkVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5zcmMgPSBzcmNcbiAgICApXG4gIH1cbn1cbiJdfQ==
import { Directive, EventEmitter, Output, Input } from '@angular/core';
export class ngfUploadStatus {
constructor() {
this.percent = 0;
this.percentChange = new EventEmitter();
}
ngOnChanges(changes) {
if (changes.httpEvent && changes.httpEvent.currentValue) {
const event = changes.httpEvent.currentValue;
if (event.loaded && event.total) {
setTimeout(() => {
this.percent = Math.round(100 * event.loaded / event.total);
this.percentChange.emit(this.percent);
}, 0);
}
}
}
}
ngfUploadStatus.decorators = [
{ type: Directive, args: [{ selector: 'ngfUploadStatus' },] }
];
ngfUploadStatus.propDecorators = {
percent: [{ type: Input }],
percentChange: [{ type: Output }],
httpEvent: [{ type: Input }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmVXBsb2FkU3RhdHVzLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9maWxlLXVwbG9hZC9uZ2ZVcGxvYWRTdGF0dXMuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdkUsTUFBTSxPQUFPLGVBQWU7SUFENUI7UUFFVyxZQUFPLEdBQVUsQ0FBQyxDQUFBO1FBQ2pCLGtCQUFhLEdBQXdCLElBQUksWUFBWSxFQUFFLENBQUE7SUFjbkUsQ0FBQztJQVhDLFdBQVcsQ0FBRSxPQUFPO1FBQ2xCLElBQUksT0FBTyxDQUFDLFNBQVMsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLFlBQVksRUFBRTtZQUN2RCxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQTtZQUM1QyxJQUFJLEtBQUssQ0FBQyxNQUFNLElBQUksS0FBSyxDQUFDLEtBQUssRUFBRTtnQkFDL0IsVUFBVSxDQUFDLEdBQUUsRUFBRTtvQkFDYixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxHQUFHLEtBQUssQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUM1RCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBRSxJQUFJLENBQUMsT0FBTyxDQUFFLENBQUE7Z0JBQ3pDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQTthQUNOO1NBQ0Y7SUFDSCxDQUFDOzs7WUFoQkYsU0FBUyxTQUFDLEVBQUMsUUFBUSxFQUFFLGlCQUFpQixFQUFDOzs7c0JBRXJDLEtBQUs7NEJBQ0wsTUFBTTt3QkFDTixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIE91dHB1dCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7c2VsZWN0b3I6ICduZ2ZVcGxvYWRTdGF0dXMnfSlcbmV4cG9ydCBjbGFzcyBuZ2ZVcGxvYWRTdGF0dXMge1xuICBASW5wdXQoKSBwZXJjZW50Om51bWJlciA9IDBcbiAgQE91dHB1dCgpIHBlcmNlbnRDaGFuZ2U6RXZlbnRFbWl0dGVyPG51bWJlcj4gPSBuZXcgRXZlbnRFbWl0dGVyKClcbiAgQElucHV0KCkgaHR0cEV2ZW50ICE6IEV2ZW50XG5cbiAgbmdPbkNoYW5nZXMoIGNoYW5nZXMgKXtcbiAgICBpZiggY2hhbmdlcy5odHRwRXZlbnQgJiYgY2hhbmdlcy5odHRwRXZlbnQuY3VycmVudFZhbHVlICl7XG4gICAgICBjb25zdCBldmVudCA9IGNoYW5nZXMuaHR0cEV2ZW50LmN1cnJlbnRWYWx1ZVxuICAgICAgaWYgKGV2ZW50LmxvYWRlZCAmJiBldmVudC50b3RhbCkge1xuICAgICAgICBzZXRUaW1lb3V0KCgpPT57XG4gICAgICAgICAgdGhpcy5wZXJjZW50ID0gTWF0aC5yb3VuZCgxMDAgKiBldmVudC5sb2FkZWQgLyBldmVudC50b3RhbCk7XG4gICAgICAgICAgdGhpcy5wZXJjZW50Q2hhbmdlLmVtaXQoIHRoaXMucGVyY2VudCApXG4gICAgICAgIH0sIDApXG4gICAgICB9XG4gICAgfVxuICB9XG59Il19
export * from './file-upload/ngf.module';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywwQkFBMEIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZmlsZS11cGxvYWQvbmdmLm1vZHVsZSciXX0=
/*
* Public API Surface of angular-file
*/
export * from './file-upload/ngfSelect.directive';
export * from './file-upload/ngfDrop.directive';
export * from './file-upload/ngf.directive';
export * from './file-upload/ngf.module';
export { ngfBackground } from './file-upload/ngfBackground.directive';
export { ngfSrc } from './file-upload/ngfSrc.directive';
export { ngfUploadStatus } from './file-upload/ngfUploadStatus.directive';
export { ngfFormData } from './file-upload/ngfFormData.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDdEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3hELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0scUNBQXFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGFuZ3VsYXItZmlsZVxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vZmlsZS11cGxvYWQvbmdmU2VsZWN0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtdXBsb2FkL25nZkRyb3AuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS11cGxvYWQvbmdmLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtdXBsb2FkL25nZi5tb2R1bGUnO1xuZXhwb3J0IHsgbmdmQmFja2dyb3VuZCB9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmQmFja2dyb3VuZC5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgbmdmU3JjIH0gZnJvbSAnLi9maWxlLXVwbG9hZC9uZ2ZTcmMuZGlyZWN0aXZlJztcbmV4cG9ydCB7IG5nZlVwbG9hZFN0YXR1cyB9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmVXBsb2FkU3RhdHVzLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBuZ2ZGb3JtRGF0YSB9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmRm9ybURhdGEuZGlyZWN0aXZlJzsiXX0=
/**
* Generated bundle index. Do not edit.
*/
export * from './public-api';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1maWxlLXNyYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hbmd1bGFyLWZpbGUtc3JjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
export const isFileInput = function (elm) {
const ty = elm.getAttribute('type');
return elm.tagName.toLowerCase() === 'input' && ty && ty.toLowerCase() === 'file';
};
let initialTouchStartY = 0;
let initialTouchStartX = 0;
export const detectSwipe = function (evt) {
var touches = evt.changedTouches || (evt.originalEvent && evt.originalEvent.changedTouches);
if (touches) {
if (evt.type === 'touchstart') {
initialTouchStartX = touches[0].clientX;
initialTouchStartY = touches[0].clientY;
return true; // don't block event default
}
else {
// prevent scroll from triggering event
if (evt.type === 'touchend') {
var currentX = touches[0].clientX;
var currentY = touches[0].clientY;
if ((Math.abs(currentX - initialTouchStartX) > 20) ||
(Math.abs(currentY - initialTouchStartY) > 20)) {
evt.stopPropagation();
if (evt.cancelable) {
evt.preventDefault();
}
return false;
}
}
return true;
}
}
return false;
};
export const createInvisibleFileInputWrap = function () {
var fileElem = createFileInput();
var label = document.createElement('label');
label.innerHTML = 'upload';
label.style.visibility = 'hidden';
label.style.position = 'absolute';
label.style.overflow = 'hidden';
label.style.width = '0px';
label.style.height = '0px';
label.style.border = 'none';
label.style.margin = '0px';
label.style.padding = '0px';
label.setAttribute('tabindex', '-1');
//bindAttrToFileInput(fileElem, label);
//generatedElems.push({el: elem, ref: label});
label.appendChild(fileElem);
//document.body.appendChild( label );
return label;
};
export const createFileInput = function () {
var fileElem = document.createElement('input');
fileElem.type = "file";
return fileElem;
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jLWV2ZW50LWhlbHAuZnVuY3Rpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2ZpbGUtdXBsb2FkL2RvYy1ldmVudC1oZWxwLmZ1bmN0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsVUFBUyxHQUFPO0lBQ3pDLE1BQU0sRUFBRSxHQUFHLEdBQUcsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUE7SUFDbkMsT0FBTyxHQUFHLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxLQUFLLE9BQU8sSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLFdBQVcsRUFBRSxLQUFLLE1BQU0sQ0FBQztBQUNwRixDQUFDLENBQUE7QUFFRCxJQUFJLGtCQUFrQixHQUFHLENBQUMsQ0FBQztBQUMzQixJQUFJLGtCQUFrQixHQUFHLENBQUMsQ0FBQztBQUMzQixNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsVUFBUyxHQUFPO0lBQ3pDLElBQUksT0FBTyxHQUFHLEdBQUcsQ0FBQyxjQUFjLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxJQUFJLEdBQUcsQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDNUYsSUFBSSxPQUFPLEVBQUU7UUFDWCxJQUFJLEdBQUcsQ0FBQyxJQUFJLEtBQUssWUFBWSxFQUFFO1lBQzdCLGtCQUFrQixHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7WUFDeEMsa0JBQWtCLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztZQUN4QyxPQUFPLElBQUksQ0FBQyxDQUFDLDRCQUE0QjtTQUMxQzthQUFNO1lBQ0wsdUNBQXVDO1lBQ3ZDLElBQUksR0FBRyxDQUFDLElBQUksS0FBSyxVQUFVLEVBQUU7Z0JBQzNCLElBQUksUUFBUSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7Z0JBQ2xDLElBQUksUUFBUSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7Z0JBQ2xDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsR0FBRyxrQkFBa0IsQ0FBQyxHQUFHLEVBQUUsQ0FBQztvQkFDaEQsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsR0FBRyxrQkFBa0IsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUFFO29CQUNoRCxHQUFHLENBQUMsZUFBZSxFQUFFLENBQUM7b0JBQ3RCLElBQUksR0FBRyxDQUFDLFVBQVUsRUFBRTt3QkFDbEIsR0FBRyxDQUFDLGNBQWMsRUFBRSxDQUFDO3FCQUN0QjtvQkFDRCxPQUFPLEtBQUssQ0FBQztpQkFDZDthQUNGO1lBQ0QsT0FBTyxJQUFJLENBQUM7U0FDYjtLQUNGO0lBQ0QsT0FBTyxLQUFLLENBQUE7QUFDZCxDQUFDLENBQUE7QUFFRCxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRztJQUMxQyxJQUFJLFFBQVEsR0FBRyxlQUFlLEVBQUUsQ0FBQTtJQUNoQyxJQUFJLEtBQUssR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzVDLEtBQUssQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFBO0lBQzFCLEtBQUssQ0FBQyxLQUFLLENBQUMsVUFBVSxHQUFHLFFBQVEsQ0FBQTtJQUNqQyxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQVEsR0FBRyxVQUFVLENBQUE7SUFDakMsS0FBSyxDQUFDLEtBQUssQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFBO0lBQy9CLEtBQUssQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQTtJQUN6QixLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUE7SUFDMUIsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO0lBQzNCLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQTtJQUMxQixLQUFLLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUE7SUFDM0IsS0FBSyxDQUFDLFlBQVksQ0FBQyxVQUFVLEVBQUMsSUFBSSxDQUFDLENBQUE7SUFFbkMsdUNBQXVDO0lBQ3ZDLDhDQUE4QztJQUU5QyxLQUFLLENBQUMsV0FBVyxDQUFFLFFBQVEsQ0FBRSxDQUFBO0lBQzdCLHFDQUFxQztJQUVyQyxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUMsQ0FBQTtBQUVELE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRztJQUM3QixJQUFJLFFBQVEsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQy9DLFFBQVEsQ0FBQyxJQUFJLEdBQUMsTUFBTSxDQUFBO0lBQ3BCLE9BQU8sUUFBUSxDQUFDO0FBQ2xCLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBpc0ZpbGVJbnB1dCA9IGZ1bmN0aW9uKGVsbTphbnkpe1xuICBjb25zdCB0eSA9IGVsbS5nZXRBdHRyaWJ1dGUoJ3R5cGUnKVxuICByZXR1cm4gZWxtLnRhZ05hbWUudG9Mb3dlckNhc2UoKSA9PT0gJ2lucHV0JyAmJiB0eSAmJiB0eS50b0xvd2VyQ2FzZSgpID09PSAnZmlsZSc7XG59XG5cbmxldCBpbml0aWFsVG91Y2hTdGFydFkgPSAwO1xubGV0IGluaXRpYWxUb3VjaFN0YXJ0WCA9IDA7XG5leHBvcnQgY29uc3QgZGV0ZWN0U3dpcGUgPSBmdW5jdGlvbihldnQ6YW55KTpib29sZWFuIHtcbiAgdmFyIHRvdWNoZXMgPSBldnQuY2hhbmdlZFRvdWNoZXMgfHwgKGV2dC5vcmlnaW5hbEV2ZW50ICYmIGV2dC5vcmlnaW5hbEV2ZW50LmNoYW5nZWRUb3VjaGVzKTtcbiAgaWYgKHRvdWNoZXMpIHtcbiAgICBpZiAoZXZ0LnR5cGUgPT09ICd0b3VjaHN0YXJ0Jykge1xuICAgICAgaW5pdGlhbFRvdWNoU3RhcnRYID0gdG91Y2hlc1swXS5jbGllbnRYO1xuICAgICAgaW5pdGlhbFRvdWNoU3RhcnRZID0gdG91Y2hlc1swXS5jbGllbnRZO1xuICAgICAgcmV0dXJuIHRydWU7IC8vIGRvbid0IGJsb2NrIGV2ZW50IGRlZmF1bHRcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gcHJldmVudCBzY3JvbGwgZnJvbSB0cmlnZ2VyaW5nIGV2ZW50XG4gICAgICBpZiAoZXZ0LnR5cGUgPT09ICd0b3VjaGVuZCcpIHtcbiAgICAgICAgdmFyIGN1cnJlbnRYID0gdG91Y2hlc1swXS5jbGllbnRYO1xuICAgICAgICB2YXIgY3VycmVudFkgPSB0b3VjaGVzWzBdLmNsaWVudFk7XG4gICAgICAgIGlmICgoTWF0aC5hYnMoY3VycmVudFggLSBpbml0aWFsVG91Y2hTdGFydFgpID4gMjApIHx8XG4gICAgICAgICAgKE1hdGguYWJzKGN1cnJlbnRZIC0gaW5pdGlhbFRvdWNoU3RhcnRZKSA+IDIwKSkge1xuICAgICAgICAgIGV2dC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgICBpZiAoZXZ0LmNhbmNlbGFibGUpIHtcbiAgICAgICAgICAgIGV2dC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gZmFsc2Vcbn1cblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUludmlzaWJsZUZpbGVJbnB1dFdyYXAgPSBmdW5jdGlvbigpIHtcbiAgdmFyIGZpbGVFbGVtID0gY3JlYXRlRmlsZUlucHV0KClcbiAgdmFyIGxhYmVsID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnbGFiZWwnKTtcbiAgbGFiZWwuaW5uZXJIVE1MID0gJ3VwbG9hZCdcbiAgbGFiZWwuc3R5bGUudmlzaWJpbGl0eSA9ICdoaWRkZW4nXG4gIGxhYmVsLnN0eWxlLnBvc2l0aW9uID0gJ2Fic29sdXRlJ1xuICBsYWJlbC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gIGxhYmVsLnN0eWxlLndpZHRoID0gJzBweCdcbiAgbGFiZWwuc3R5bGUuaGVpZ2h0ID0gJzBweCdcbiAgbGFiZWwuc3R5bGUuYm9yZGVyID0gJ25vbmUnXG4gIGxhYmVsLnN0eWxlLm1hcmdpbiA9ICcwcHgnXG4gIGxhYmVsLnN0eWxlLnBhZGRpbmcgPSAnMHB4J1xuICBsYWJlbC5zZXRBdHRyaWJ1dGUoJ3RhYmluZGV4JywnLTEnKVxuICBcbiAgLy9iaW5kQXR0clRvRmlsZUlucHV0KGZpbGVFbGVtLCBsYWJlbCk7XG4gIC8vZ2VuZXJhdGVkRWxlbXMucHVzaCh7ZWw6IGVsZW0sIHJlZjogbGFiZWx9KTtcblxuICBsYWJlbC5hcHBlbmRDaGlsZCggZmlsZUVsZW0gKVxuICAvL2RvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQoIGxhYmVsICk7XG5cbiAgcmV0dXJuIGxhYmVsO1xufVxuXG5leHBvcnQgY29uc3QgY3JlYXRlRmlsZUlucHV0ID0gZnVuY3Rpb24oKSB7XG4gIHZhciBmaWxlRWxlbSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2lucHV0Jyk7XG4gIGZpbGVFbGVtLnR5cGU9XCJmaWxlXCJcbiAgcmV0dXJuIGZpbGVFbGVtO1xufVxuIl19
export function getWindow() { return window; }
export function acceptType(accept, type, name) {
if (!accept) {
return true;
}
const defs = accept.split(',');
let regx;
let acceptRegString;
for (let x = defs.length - 1; x >= 0; --x) {
//Escapes dots in mimetype
acceptRegString = defs[x];
//trim
acceptRegString = acceptRegString.replace(/(^\s+|\s+$)/g, '');
//Escapes stars in mimetype
acceptRegString = acceptRegString.replace(/\*/g, '.*');
//let acceptReg = '^((' + acceptRegString
//acceptReg = acceptReg.replace(/,/g,')|(') + '))$'
//try by mime
regx = new RegExp(acceptRegString, 'gi');
if (type.search(regx) >= 0) {
return true;
}
//try by ext
if (acceptRegString.substring(0, 1) == '.') {
acceptRegString = '\\' + acceptRegString; //.substring(1, acceptRegString.length-1)//remove dot at front
regx = new RegExp(acceptRegString + '$', 'i');
if ((name || type).search(regx) >= 0) {
return true;
}
}
}
return false;
}
export function arrayBufferToBase64(buffer) {
var binary = '';
var bytes = new Uint8Array(buffer);
var len = bytes.byteLength;
for (var i = 0; i < len; i++) {
binary += String.fromCharCode(bytes[i]);
}
return window.btoa(binary);
}
export function dataUrltoBlob(dataurl, name, origSize) {
var arr = dataurl.split(',');
var mimeMatch = arr[0].match(/:(.*?);/);
var mime = mimeMatch ? mimeMatch[1] : 'text/plain';
var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
var blob = new window.Blob([u8arr], { type: mime });
blob["name"] = name;
blob["$ngfOrigSize"] = origSize;
return blob;
}
export function applyTransform(ctx, orientation, width, height) {
switch (orientation) {
case 2:
return ctx.transform(-1, 0, 0, 1, width, 0);
case 3:
return ctx.transform(-1, 0, 0, -1, width, height);
case 4:
return ctx.transform(1, 0, 0, -1, 0, height);
case 5:
return ctx.transform(0, 1, 1, 0, 0, 0);
case 6:
return ctx.transform(0, 1, -1, 0, height, 0);
case 7:
return ctx.transform(0, -1, -1, 0, height, width);
case 8:
return ctx.transform(0, -1, 1, 0, 0, width);
}
}
export function fixFileOrientationByMeta(file, result) {
return dataUrl(file, true)
.then(url => {
var canvas = document.createElement('canvas');
var img = document.createElement('img');
return new Promise(function (res, rej) {
img.onload = function () {
try {
canvas.width = result.orientation > 4 ? img.height : img.width;
canvas.height = result.orientation > 4 ? img.width : img.height;
var ctx = canvas.getContext('2d');
applyTransform(ctx, result.orientation, img.width, img.height);
ctx.drawImage(img, 0, 0);
var dataUrl = canvas.toDataURL(file.type || 'image/WebP', 0.934);
const base = arrayBufferToBase64(result.fixedArrayBuffer);
dataUrl = restoreExif(base, dataUrl);
var blob = dataUrltoBlob(dataUrl, file.name);
const newFile = blobToFile(blob, file.name);
res(newFile);
}
catch (e) {
rej(e);
}
};
img.onerror = rej;
img.src = url;
});
});
}
export function applyExifRotation(file) {
if (file.type.indexOf('image/jpeg') !== 0) {
return Promise.resolve(file);
}
return readOrientation(file)
.then((result) => {
if (result.orientation < 2 || result.orientation > 8) {
return file;
}
return fixFileOrientationByMeta(file, result);
});
}
export function readOrientation(file) {
return new Promise((res, rej) => {
var reader = new FileReader();
var slicedFile = file.slice ? file.slice(0, 64 * 1024) : file;
reader.readAsArrayBuffer(slicedFile);
reader.onerror = rej;
reader.onload = function (e) {
var result = { orientation: 1 };
var view = new DataView(this.result);
if (view.getUint16(0, false) !== 0xFFD8)
return res(result);
var length = view.byteLength, offset = 2;
while (offset < length) {
var marker = view.getUint16(offset, false);
offset += 2;
if (marker === 0xFFE1) {
if (view.getUint32(offset += 2, false) !== 0x45786966)
return res(result);
var little = view.getUint16(offset += 6, false) === 0x4949;
offset += view.getUint32(offset + 4, little);
var tags = view.getUint16(offset, little);
offset += 2;
for (var i = 0; i < tags; i++)
if (view.getUint16(offset + (i * 12), little) === 0x0112) {
var orientation = view.getUint16(offset + (i * 12) + 8, little);
if (orientation >= 2 && orientation <= 8) {
view.setUint16(offset + (i * 12) + 8, 1, little);
result.fixedArrayBuffer = e.target.result;
}
result.orientation = orientation;
return res(result);
}
}
else if ((marker & 0xFF00) !== 0xFF00)
break;
else
offset += view.getUint16(offset, false);
}
return res(result);
};
});
}
/** converts file-input file into base64 dataUri */
export function dataUrl(file, disallowObjectUrl) {
if (!file)
return Promise.resolve(file);
if ((disallowObjectUrl && file.$ngfDataUrl != null) || (!disallowObjectUrl && file.$ngfBlobUrl != null)) {
return Promise.resolve(disallowObjectUrl ? file.$ngfDataUrl : file.$ngfBlobUrl);
}
var p = disallowObjectUrl ? file.$$ngfDataUrlPromise : file.$$ngfBlobUrlPromise;
if (p)
return p;
const win = getWindow();
let deferred;
if (win.FileReader && file &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 8') === -1 || file.size < 20000) &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 9') === -1 || file.size < 4000000)) {
//prefer URL.createObjectURL for handling refrences to files of all sizes
//since it doesn´t build a large string in memory
var URL = win.URL || win.webkitURL;
if (FileReader) {
deferred = new Promise((res, rej) => {
var fileReader = new FileReader();
fileReader.onload = function (event) {
file.$ngfDataUrl = event.target.result;
delete file.$ngfDataUrl;
res(event.target.result);
};
fileReader.onerror = function (e) {
file.$ngfDataUrl = '';
rej(e);
};
fileReader.readAsDataURL(file);
});
}
else {
var url;
try {
url = URL.createObjectURL(file);
}
catch (e) {
return Promise.reject(e);
}
deferred = Promise.resolve(url);
file.$ngfBlobUrl = url;
}
}
else {
file[disallowObjectUrl ? '$ngfDataUrl' : '$ngfBlobUrl'] = '';
return Promise.reject(new Error('Browser does not support window.FileReader, window.FileReader, or window.FileAPI')); //deferred.reject();
}
if (disallowObjectUrl) {
p = file.$$ngfDataUrlPromise = deferred;
}
else {
p = file.$$ngfBlobUrlPromise = deferred;
}
p = p.then((x) => {
delete file[disallowObjectUrl ? '$$ngfDataUrlPromise' : '$$ngfBlobUrlPromise'];
return x;
});
return p;
}
export function restoreExif(orig, resized) {
var ExifRestorer = {
KEY_STR: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='
};
ExifRestorer.encode64 = function (input) {
var output = '', chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0;
do {
chr1 = input[i++];
chr2 = input[i++];
chr3 = input[i++];
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
}
else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
this.KEY_STR.charAt(enc1) +
this.KEY_STR.charAt(enc2) +
this.KEY_STR.charAt(enc3) +
this.KEY_STR.charAt(enc4);
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return output;
};
ExifRestorer.restore = function (origFileBase64, resizedFileBase64) {
if (origFileBase64.match('data:image/jpeg;base64,')) {
origFileBase64 = origFileBase64.replace('data:image/jpeg;base64,', '');
}
var rawImage = this.decode64(origFileBase64);
var segments = this.slice2Segments(rawImage);
var image = this.exifManipulation(resizedFileBase64, segments);
return 'data:image/jpeg;base64,' + this.encode64(image);
};
ExifRestorer.exifManipulation = function (resizedFileBase64, segments) {
var exifArray = this.getExifArray(segments), newImageArray = this.insertExif(resizedFileBase64, exifArray);
return new Uint8Array(newImageArray);
};
ExifRestorer.getExifArray = function (segments) {
var seg;
for (var x = 0; x < segments.length; x++) {
seg = segments[x];
if (seg[0] === 255 && seg[1] === 225) //(ff e1)
{
return seg;
}
}
return [];
};
ExifRestorer.insertExif = function (resizedFileBase64, exifArray) {
var imageData = resizedFileBase64.replace('data:image/jpeg;base64,', ''), buf = this.decode64(imageData), separatePoint = buf.indexOf(255, 3), mae = buf.slice(0, separatePoint), ato = buf.slice(separatePoint), array = mae;
array = array.concat(exifArray);
array = array.concat(ato);
return array;
};
ExifRestorer.slice2Segments = function (rawImageArray) {
var head = 0, segments = [];
while (1) {
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 218) {
break;
}
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 216) {
head += 2;
}
else {
var length = rawImageArray[head + 2] * 256 + rawImageArray[head + 3];
var endPoint = head + length + 2;
var seg = rawImageArray.slice(head, endPoint);
segments.push(seg);
head = endPoint;
}
if (head > rawImageArray.length) {
break;
}
}
return segments;
};
ExifRestorer.decode64 = function (input) {
var chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0, buf = [];
// remove all characters that are not A-Z, a-z, 0-9, +, /, or =
var base64test = /[^A-Za-z0-9\+\/\=]/g;
if (base64test.exec(input)) {
console.log('There were invalid base64 characters in the input text.');
}
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, '');
do {
enc1 = this.KEY_STR.indexOf(input.charAt(i++));
enc2 = this.KEY_STR.indexOf(input.charAt(i++));
enc3 = this.KEY_STR.indexOf(input.charAt(i++));
enc4 = this.KEY_STR.indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
buf.push(chr1);
if (enc3 !== 64) {
buf.push(chr2);
}
if (enc4 !== 64) {
buf.push(chr3);
}
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return buf;
};
return ExifRestorer.restore(orig, resized); //<= EXIF
}
;
function blobToFile(theBlob, fileName) {
var b = theBlob;
//A Blob() is almost a File() - it's just missing the two properties below which we will add
b.lastModifiedDate = new Date();
b.name = fileName;
//Cast to a File() type
return theBlob;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fileTools.js","sourceRoot":"","sources":["../../../../src/file-upload/fileTools.ts"],"names":[],"mappings":"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","sourcesContent":["export function getWindow():any{return window}\n\nexport function acceptType(accept:string, type:string, name?:string):boolean {   \n  if( !accept ){\n    return true\n  }\n\n  const defs = accept.split(',')\n  let regx:RegExp\n  let acceptRegString:string\n\n  for(let x=defs.length-1; x >= 0; --x){\n    //Escapes dots in mimetype \n    acceptRegString = defs[x]\n    //trim\n    acceptRegString = acceptRegString.replace(/(^\\s+|\\s+$)/g,'')\n    //Escapes stars in mimetype \n    acceptRegString = acceptRegString.replace(/\\*/g,'.*')\n    //let acceptReg = '^((' + acceptRegString\n    //acceptReg = acceptReg.replace(/,/g,')|(') + '))$'\n    \n    //try by mime\n    regx = new RegExp(acceptRegString, 'gi')\n    if( type.search(regx)>=0 ){\n      return true\n    }\n\n    //try by ext\n    if( acceptRegString.substring(0, 1)=='.' ){      \n      acceptRegString = '\\\\'+ acceptRegString//.substring(1, acceptRegString.length-1)//remove dot at front\n      regx = new RegExp(acceptRegString+'$', 'i')\n      if( (name||type).search(regx)>=0 ){\n        return true\n      }\n    }\n  }\n  return false\n}\n\nexport interface InvalidFileItem{\n  file:File\n  type:string\n}\n\nexport function arrayBufferToBase64(buffer:any) {\n  var binary = '';\n  var bytes = new Uint8Array(buffer);\n  var len = bytes.byteLength;\n  for (var i = 0; i < len; i++) {\n    binary += String.fromCharCode(bytes[i]);\n  }\n  return window.btoa(binary);\n}\n\nexport function dataUrltoBlob(\n  dataurl:string,\n  name:string,\n  origSize?:any\n):Blob{\n  var arr = dataurl.split(',');\n  var mimeMatch = arr[0].match(/:(.*?);/)\n  var mime:string = mimeMatch ? mimeMatch[1] : 'text/plain'\n  var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);\n  while (n--) {\n    u8arr[n] = bstr.charCodeAt(n);\n  }\n  \n  var blob: any = new window.Blob([u8arr], {type: mime});\n  blob[\"name\"] = name;\n  blob[\"$ngfOrigSize\"] = origSize;\n  return blob;\n}\n\nexport interface orientationMeta{\n  orientation: number\n  fixedArrayBuffer?:any[]\n}\n\nexport function applyTransform(\n  ctx:CanvasRenderingContext2D,\n  orientation:number,\n  width:number,\n  height:number\n) {\n  switch (orientation) {\n    case 2:\n      return ctx.transform(-1, 0, 0, 1, width, 0);\n    case 3:\n      return ctx.transform(-1, 0, 0, -1, width, height);\n    case 4:\n      return ctx.transform(1, 0, 0, -1, 0, height);\n    case 5:\n      return ctx.transform(0, 1, 1, 0, 0, 0);\n    case 6:\n      return ctx.transform(0, 1, -1, 0, height, 0);\n    case 7:\n      return ctx.transform(0, -1, -1, 0, height, width);\n    case 8:\n      return ctx.transform(0, -1, 1, 0, 0, width);\n  }\n}\n\nexport function fixFileOrientationByMeta(\n  file:File, result:orientationMeta\n):Promise<File>{\n  return dataUrl(file, true)\n  .then(url=>{\n    var canvas = document.createElement('canvas');\n    var img = document.createElement('img');\n\n    return <Promise<File>>new Promise(function(res,rej){\n      img.onload = function () {\n        try {\n          canvas.width = result.orientation > 4 ? img.height : img.width\n          canvas.height = result.orientation > 4 ? img.width : img.height\n          var ctx = <CanvasRenderingContext2D>canvas.getContext('2d')\n          applyTransform(ctx, result.orientation, img.width, img.height)\n          ctx.drawImage(img, 0, 0);\n          var dataUrl = canvas.toDataURL(file.type || 'image/WebP', 0.934)\n          const base = arrayBufferToBase64(result.fixedArrayBuffer)\n          dataUrl = restoreExif(base, dataUrl)\n          var blob = dataUrltoBlob(dataUrl, file.name)\n          const newFile = blobToFile(blob, file.name);\n          res(newFile);\n        } catch (e) {\n          rej(e)\n        }\n      };\n      img.onerror = rej;\n      img.src = url;    \n    })\n  })\n}\n\nexport function applyExifRotation(\n  file:File\n):Promise<File>{\n  if (file.type.indexOf('image/jpeg') !== 0) {\n    return Promise.resolve(file);\n  }\n\n  return readOrientation(file)\n  .then((result:orientationMeta)=>{\n    if (result.orientation < 2 || result.orientation > 8) {\n      return file\n    }\n    \n    return fixFileOrientationByMeta(file,result)\n  })\n}\n\nexport function readOrientation(\n  file:File\n):Promise<orientationMeta>{\n  return new Promise((res,rej)=>{\n    var reader = new FileReader();\n    var slicedFile = file.slice ? file.slice(0, 64 * 1024) : file;\n    reader.readAsArrayBuffer(slicedFile);\n    reader.onerror = rej\n    reader.onload = function (e:any) {\n      var result:orientationMeta = {orientation: 1};\n      var view = new DataView( <ArrayBuffer>this.result );\n      if (view.getUint16(0, false) !== 0xFFD8) return res(result);\n\n      var length = view.byteLength,\n        offset = 2;\n      while (offset < length) {\n        var marker = view.getUint16(offset, false);\n        offset += 2;\n        if (marker === 0xFFE1) {\n          if (view.getUint32(offset += 2, false) !== 0x45786966) return res(result);\n\n          var little = view.getUint16(offset += 6, false) === 0x4949;\n          offset += view.getUint32(offset + 4, little);\n          var tags = view.getUint16(offset, little);\n          offset += 2;\n          for (var i = 0; i < tags; i++)\n            if (view.getUint16(offset + (i * 12), little) === 0x0112) {\n              var orientation = view.getUint16(offset + (i * 12) + 8, little);\n              if (orientation >= 2 && orientation <= 8) {\n                view.setUint16(offset + (i * 12) + 8, 1, little);\n                result.fixedArrayBuffer = e.target.result;\n              }\n              result.orientation = orientation;\n              return res(result);\n            }\n        } else if ((marker & 0xFF00) !== 0xFF00) break;\n        else offset += view.getUint16(offset, false);\n      }\n      return res(result);\n    };\n  })\n}\n\n/** converts file-input file into base64 dataUri */\nexport function dataUrl(\n  file:any,\n  disallowObjectUrl?:any\n):Promise<string>{\n  if (!file) return Promise.resolve(file)\n  \n  if ((disallowObjectUrl && file.$ngfDataUrl != null) || (!disallowObjectUrl && file.$ngfBlobUrl != null)) {\n    return Promise.resolve( disallowObjectUrl ? file.$ngfDataUrl : file.$ngfBlobUrl )\n  }\n\n  var p = disallowObjectUrl ? file.$$ngfDataUrlPromise : file.$$ngfBlobUrlPromise;\n  if (p) return p;\n\n  const win = getWindow()\n  let deferred:Promise<string>\n  if (win.FileReader && file &&\n    (!win.FileAPI || navigator.userAgent.indexOf('MSIE 8') === -1 || file.size < 20000) &&\n    (!win.FileAPI || navigator.userAgent.indexOf('MSIE 9') === -1 || file.size < 4000000)) {\n    //prefer URL.createObjectURL for handling refrences to files of all sizes\n    //since it doesn´t build a large string in memory\n    var URL = win.URL || win.webkitURL;\n    if (FileReader) {\n      deferred = new Promise((res,rej)=>{\n        var fileReader = new FileReader();\n        fileReader.onload = function (event:any) {\n          file.$ngfDataUrl = event.target.result;\n          delete file.$ngfDataUrl;\n          res( event.target.result )\n        };\n        fileReader.onerror = function (e) {\n          file.$ngfDataUrl = '';\n          rej(e)\n        };\n        fileReader.readAsDataURL(file);\n      })\n    } else {\n      var url:any;\n      try {\n        url = URL.createObjectURL(file);\n      } catch (e) {\n        return Promise.reject(e);\n      }\n      \n      deferred = Promise.resolve( url )\n      file.$ngfBlobUrl = url;\n    }\n  } else {\n    file[disallowObjectUrl ? '$ngfDataUrl' : '$ngfBlobUrl'] = '';\n    return Promise.reject( new Error('Browser does not support window.FileReader, window.FileReader, or window.FileAPI') )//deferred.reject();\n  }\n\n  if (disallowObjectUrl) {\n    p = file.$$ngfDataUrlPromise = deferred;\n  } else {\n    p = file.$$ngfBlobUrlPromise = deferred;\n  }\n\n  p = p.then((x:any)=>{\n    delete file[disallowObjectUrl ? '$$ngfDataUrlPromise' : '$$ngfBlobUrlPromise'];\n    return x\n  })\n\n  return p;\n}\n\nexport function restoreExif(orig:any, resized:any) {\n  var ExifRestorer:any = {\n    KEY_STR:'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='\n  }\n\n  ExifRestorer.encode64 = function (input:any) {\n    var output = '',\n      chr1, chr2, chr3:any = '',\n      enc1, enc2, enc3, enc4:any = '',\n      i = 0;\n\n    do {\n      chr1 = input[i++];\n      chr2 = input[i++];\n      chr3 = input[i++];\n\n      enc1 = chr1 >> 2;\n      enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);\n      enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);\n      enc4 = chr3 & 63;\n\n      if (isNaN(chr2)) {\n        enc3 = enc4 = 64;\n      } else if (isNaN(chr3)) {\n        enc4 = 64;\n      }\n\n      output = output +\n        this.KEY_STR.charAt(enc1) +\n        this.KEY_STR.charAt(enc2) +\n        this.KEY_STR.charAt(enc3) +\n        this.KEY_STR.charAt(enc4);\n      chr1 = chr2 = chr3 = '';\n      enc1 = enc2 = enc3 = enc4 = '';\n    } while (i < input.length);\n\n    return output;\n  };\n\n  ExifRestorer.restore = function (origFileBase64:any, resizedFileBase64:any) {\n    if (origFileBase64.match('data:image/jpeg;base64,')) {\n      origFileBase64 = origFileBase64.replace('data:image/jpeg;base64,', '');\n    }\n\n    var rawImage:number[] = this.decode64(origFileBase64);\n    var segments = this.slice2Segments(rawImage);\n\n    var image = this.exifManipulation(resizedFileBase64, segments);\n\n    return 'data:image/jpeg;base64,' + this.encode64(image);\n  };\n\n\n  ExifRestorer.exifManipulation = function (resizedFileBase64:any, segments:any) {\n    var exifArray = this.getExifArray(segments),\n      newImageArray = this.insertExif(resizedFileBase64, exifArray);\n    return new Uint8Array(newImageArray);\n  };\n\n  ExifRestorer.getExifArray = function (segments:number[][]) {\n    var seg;\n    for (var x = 0; x < segments.length; x++) {\n      seg = segments[x];\n      if (seg[0] === 255 && seg[1] === 225) //(ff e1)\n      {\n        return seg;\n      }\n    }\n    return [];\n  };\n\n\n  ExifRestorer.insertExif = function (resizedFileBase64:any, exifArray:any) {\n    var imageData = resizedFileBase64.replace('data:image/jpeg;base64,', ''),\n      buf = this.decode64(imageData),\n      separatePoint = buf.indexOf(255, 3),\n      mae = buf.slice(0, separatePoint),\n      ato = buf.slice(separatePoint),\n      array = mae;\n\n    array = array.concat(exifArray);\n    array = array.concat(ato);\n    return array;\n  };\n\n\n  ExifRestorer.slice2Segments = function(\n    rawImageArray:number[]\n  ) {\n    var head:number = 0,\n      segments:number[][] = [];\n\n    while (1) {\n      if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 218) {\n        break;\n      }\n      if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 216) {\n        head += 2;\n      }\n      else {\n        var length = rawImageArray[head + 2] * 256 + rawImageArray[head + 3]\n        var endPoint = head + length + 2\n        var seg:number[] = rawImageArray.slice(head, endPoint)\n        segments.push(seg);\n        head = endPoint;\n      }\n      if (head > rawImageArray.length) {\n        break;\n      }\n    }\n\n    return segments;\n  };\n\n\n  ExifRestorer.decode64 = function (\n    input:any\n  ):number[]{\n    var chr1, chr2, chr3:any = '',\n      enc1, enc2, enc3, enc4:any = '',\n      i = 0,\n      buf:number[] = [];\n\n    // remove all characters that are not A-Z, a-z, 0-9, +, /, or =\n    var base64test = /[^A-Za-z0-9\\+\\/\\=]/g;\n    if (base64test.exec(input)) {\n      console.log('There were invalid base64 characters in the input text.');\n    }\n    input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, '');\n\n    do {\n      enc1 = this.KEY_STR.indexOf(input.charAt(i++));\n      enc2 = this.KEY_STR.indexOf(input.charAt(i++));\n      enc3 = this.KEY_STR.indexOf(input.charAt(i++));\n      enc4 = this.KEY_STR.indexOf(input.charAt(i++));\n\n      chr1 = (enc1 << 2) | (enc2 >> 4);\n      chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);\n      chr3 = ((enc3 & 3) << 6) | enc4;\n\n      buf.push(chr1);\n\n      if (enc3 !== 64) {\n        buf.push(chr2);\n      }\n      if (enc4 !== 64) {\n        buf.push(chr3);\n      }\n\n      chr1 = chr2 = chr3 = '';\n      enc1 = enc2 = enc3 = enc4 = '';\n\n    } while (i < input.length);\n\n    return buf;\n  };\n\n  return ExifRestorer.restore(orig, resized);  //<= EXIF\n};\n\nfunction blobToFile(theBlob: Blob, fileName:string): File {\n  var b: any = theBlob;\n  //A Blob() is almost a File() - it's just missing the two properties below which we will add\n  b.lastModifiedDate = new Date();\n  b.name = fileName;\n\n  //Cast to a File() type\n  return <File>theBlob;\n}\n"]}
import { Directive, EventEmitter, ElementRef, Input, Output, HostListener } from '@angular/core';
import { createInvisibleFileInputWrap, isFileInput, detectSwipe } from "./doc-event-help.functions";
import { acceptType, applyExifRotation, dataUrl } from "./fileTools";
/** A master base set of logic intended to support file select/drag/drop operations
NOTE: Use ngfDrop for full drag/drop. Use ngfSelect for selecting
*/
export class ngf {
constructor(element) {
this.element = element;
this.filters = [];
this.lastFileCount = 0;
this.ngfFixOrientation = true;
this.fileDropDisabled = false;
this.selectable = false;
this.directiveInit = new EventEmitter();
this.lastInvalids = [];
this.lastInvalidsChange = new EventEmitter();
this.lastBaseUrlChange = new EventEmitter();
this.fileChange = new EventEmitter();
this.files = [];
this.filesChange = new EventEmitter();
this.fileSelectStart = new EventEmitter();
this.initFilters();
}
initFilters() {
// the order is important
this.filters.push({ name: 'accept', fn: this._acceptFilter });
this.filters.push({ name: 'fileSize', fn: this._fileSizeFilter });
//this.filters.push({name: 'fileType', fn: this._fileTypeFilter})
//this.filters.push({name: 'queueLimit', fn: this._queueLimitFilter})
//this.filters.push({name: 'mimeType', fn: this._mimeTypeFilter})
}
ngOnDestroy() {
delete this.fileElm; //faster memory release of dom element
this.destroyPasteListener();
}
ngOnInit() {
const selectable = (this.selectable || this.selectable === '') && !['false', 'null', '0'].includes(this.selectable);
if (selectable) {
this.enableSelecting();
}
if (this.multiple) {
this.paramFileElm().setAttribute('multiple', this.multiple);
}
this.evalCapturePaste();
// create reference to this class with one cycle delay to avoid ExpressionChangedAfterItHasBeenCheckedError
setTimeout(() => {
this.directiveInit.emit(this);
}, 0);
}
ngOnChanges(changes) {
var _a, _b;
if (changes.accept) {
this.paramFileElm().setAttribute('accept', changes.accept.currentValue || '*');
}
if (changes.capturePaste) {
this.evalCapturePaste();
}
// Did we go from having a file to not having a file? Clear file element then
if (changes.file && changes.file.previousValue && !changes.file.currentValue) {
this.clearFileElmValue();
}
// Did we go from having files to not having files? Clear file element then
if (changes.files) {
const filesWentToZero = ((_a = changes.files.previousValue) === null || _a === void 0 ? void 0 : _a.length) && !((_b = changes.files.currentValue) === null || _b === void 0 ? void 0 : _b.length);
if (filesWentToZero) {
this.clearFileElmValue();
}
}
}
evalCapturePaste() {
const isActive = this.capturePaste || this.capturePaste === '' || ['false', '0', 'null'].includes(this.capturePaste);
if (isActive) {
if (this.pasteCapturer) {
return; // already listening
}
this.pasteCapturer = (e) => {
const clip = e.clipboardData;
if (clip && clip.files && clip.files.length) {
this.handleFiles(clip.files);
e.preventDefault();
}
};
window.addEventListener('paste', this.pasteCapturer);
return;
}
this.destroyPasteListener();
}
destroyPasteListener() {
if (this.pasteCapturer) {
window.removeEventListener('paste', this.pasteCapturer);
delete this.pasteCapturer;
}
}
paramFileElm() {
if (this.fileElm)
return this.fileElm; // already defined
// elm already is a file input
const isFile = isFileInput(this.element.nativeElement);
if (isFile) {
return this.fileElm = this.element.nativeElement;
}
// the host elm is NOT a file input
return this.fileElm = this.createFileElm({
change: this.changeFn.bind(this)
});
}
/** Only used when host element we are attached to is NOT a fileElement */
createFileElm({ change }) {
// use specific technique to hide file element within
const label = createInvisibleFileInputWrap();
const fileElm = label.getElementsByTagName('input')[0];
fileElm.addEventListener('change', change);
this.element.nativeElement.appendChild(label); // put on html stage
return fileElm;
}
enableSelecting() {
let elm = this.element.nativeElement;
if (isFileInput(elm)) {
const bindedHandler = event => this.beforeSelect(event);
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
return;
}
const bindedHandler = ev => this.clickHandler(ev);
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
elm.addEventListener('touchend', bindedHandler);
}
getValidFiles(files) {
const rtn = [];
for (let x = files.length - 1; x >= 0; --x) {
if (this.isFileValid(files[x])) {
rtn.push(files[x]);
}
}
return rtn;
}
getInvalidFiles(files) {
const rtn = [];
for (let x = files.length - 1; x >= 0; --x) {
let failReason = this.getFileFilterFailName(files[x]);
if (failReason) {
rtn.push({
file: files[x],
type: failReason
});
}
}
return rtn;
}
// Primary handler of files coming in
handleFiles(files) {
const valids = this.getValidFiles(files);
if (files.length != valids.length) {
this.lastInvalids = this.getInvalidFiles(files);
}
else {
delete this.lastInvalids;
}
this.lastInvalidsChange.emit(this.lastInvalids);
if (valids.length) {
if (this.ngfFixOrientation) {
this.applyExifRotations(valids)
.then(fixedFiles => this.que(fixedFiles));
}
else {
this.que(valids);
}
}
if (this.isEmptyAfterSelection()) {
this.element.nativeElement.value = '';
}
}
que(files) {
this.files = this.files || [];
Array.prototype.push.apply(this.files, files);
//below break memory ref and doesnt act like a que
//this.files = files//causes memory change which triggers bindings like <ngfFormData [files]="files"></ngfFormData>
this.filesChange.emit(this.files);
if (files.length) {
this.fileChange.emit(this.file = files[0]);
if (this.lastBaseUrlChange.observers.length) {
dataUrl(files[0])
.then(url => this.lastBaseUrlChange.emit(url));
}
}
//will be checked for input value clearing
this.lastFileCount = this.files.length;
}
/** called when input has files */
changeFn(event) {
var fileList = event.__files_ || (event.target && event.target.files);
if (!fileList)
return;
this.stopEvent(event);
this.handleFiles(fileList);
}
clickHandler(evt) {
const elm = this.element.nativeElement;
if (elm.getAttribute('disabled') || this.fileDropDisabled) {
return false;
}
var r = detectSwipe(evt);
// prevent the click if it is a swipe
if (r !== false)
return r;
const fileElm = this.paramFileElm();
fileElm.click();
//fileElm.dispatchEvent( new Event('click') );
this.beforeSelect(evt);
return false;
}
beforeSelect(event) {
this.fileSelectStart.emit(event);
if (this.files && this.lastFileCount === this.files.length)
return;
// if no files in array, be sure browser does not prevent reselect of same file (see github issue 27)
this.clearFileElmValue();
}
clearFileElmValue() {
if (!this.fileElm)
return;
this.fileElm.value = null;
}
isEmptyAfterSelection() {
return !!this.element.nativeElement.attributes.multiple;
}
stopEvent(event) {
event.preventDefault();
event.stopPropagation();
}
transferHasFiles(transfer) {
if (!transfer.types) {
return false;
}
if (transfer.types.indexOf) {
return transfer.types.indexOf('Files') !== -1;
}
else if (transfer.types.contains) {
return transfer.types.contains('Files');
}
else {
return false;
}
}
eventToFiles(event) {
const transfer = eventToTransfer(event);
if (transfer) {
if (transfer.files && transfer.files.length) {
return transfer.files;
}
if (transfer.items && transfer.items.length) {
return transfer.items;
}
}
return [];
}
applyExifRotations(files) {
const mapper = (file, index) => {
return applyExifRotation(file)
.then(fixedFile => files.splice(index, 1, fixedFile));
};
const proms = [];
for (let x = files.length - 1; x >= 0; --x) {
proms[x] = mapper(files[x], x);
}
return Promise.all(proms).then(() => files);
}
onChange(event) {
let files = this.element.nativeElement.files || this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
}
getFileFilterFailName(file) {
for (let i = 0; i < this.filters.length; i++) {
if (!this.filters[i].fn.call(this, file)) {
return this.filters[i].name;
}
}
return undefined;
}
isFileValid(file) {
const noFilters = !this.accept && (!this.filters || !this.filters.length);
if (noFilters) {
return true; //we have no filters so all files are valid
}
return this.getFileFilterFailName(file) ? false : true;
}
isFilesValid(files) {
for (let x = files.length - 1; x >= 0; --x) {
if (!this.isFileValid(files[x])) {
return false;
}
}
return true;
}
_acceptFilter(item) {
return acceptType(this.accept, item.type, item.name);
}
_fileSizeFilter(item) {
return !(this.maxSize && item.size > this.maxSize);
}
}
ngf.decorators = [
{ type: Directive, args: [{
selector: "[ngf]",
exportAs: "ngf"
},] }
];
ngf.ctorParameters = () => [
{ type: ElementRef }
];
ngf.propDecorators = {
multiple: [{ type: Input }],
accept: [{ type: Input }],
maxSize: [{ type: Input }],
ngfFixOrientation: [{ type: Input }],
fileDropDisabled: [{ type: Input }],
selectable: [{ type: Input }],
directiveInit: [{ type: Output, args: ['init',] }],
lastInvalids: [{ type: Input }],
lastInvalidsChange: [{ type: Output }],
lastBaseUrl: [{ type: Input }],
lastBaseUrlChange: [{ type: Output }],
file: [{ type: Input }],
fileChange: [{ type: Output }],
files: [{ type: Input }],
filesChange: [{ type: Output }],
fileSelectStart: [{ type: Output }],
capturePaste: [{ type: Input }],
onChange: [{ type: HostListener, args: ['change', ['$event'],] }]
};
/** browsers try hard to conceal data about file drags, this tends to undo that */
export function filesToWriteableObject(files) {
const jsonFiles = [];
for (let x = 0; x < files.length; ++x) {
jsonFiles.push({
type: files[x].type,
kind: files[x]["kind"]
});
}
return jsonFiles;
}
export function eventToTransfer(event) {
if (event.dataTransfer)
return event.dataTransfer;
return event.originalEvent ? event.originalEvent.dataTransfer : null;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngf.directive.js","sourceRoot":"","sources":["../../../../src/file-upload/ngf.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, ElementRef, Input, Output, HostListener, SimpleChanges } from '@angular/core';\nimport { createInvisibleFileInputWrap, isFileInput, detectSwipe } from \"./doc-event-help.functions\"\nimport {\n  acceptType, InvalidFileItem,\n  applyExifRotation, dataUrl\n} from \"./fileTools\"\n\nexport interface dragMeta{\n  type:string\n  kind:string\n}\n\n/** A master base set of logic intended to support file select/drag/drop operations\n NOTE: Use ngfDrop for full drag/drop. Use ngfSelect for selecting\n*/\n@Directive({\n  selector: \"[ngf]\",\n  exportAs:\"ngf\"\n})\nexport class ngf {\n  fileElm: any\n  filters: {name: string, fn: (file:File)=>boolean}[] = []\n  lastFileCount: number = 0\n\n  @Input() multiple !:string\n  @Input() accept   !:string\n  @Input() maxSize  !:number\n  @Input() ngfFixOrientation: boolean = true\n\n  @Input() fileDropDisabled: boolean = false\n  @Input() selectable: boolean | string = false\n  @Output('init') directiveInit:EventEmitter<ngf> = new EventEmitter()\n\n  @Input() lastInvalids:InvalidFileItem[] = []\n  @Output() lastInvalidsChange:EventEmitter<{file:File,type:string}[]> = new EventEmitter()\n\n  @Input() lastBaseUrl!: string//base64 last file uploaded url\n  @Output() lastBaseUrlChange:EventEmitter<string> = new EventEmitter()\n\n  @Input() file?: File//last file uploaded\n  @Output() fileChange: EventEmitter<File> = new EventEmitter()\n\n  @Input() files:File[] = []\n  @Output() filesChange:EventEmitter<File[]> = new EventEmitter<File[]>();\n\n  @Output() fileSelectStart:EventEmitter<Event> = new EventEmitter()\n\n  @Input() capturePaste: boolean // window paste file watching (empty string turns on)\n\n  pasteCapturer!: (e: Event) => void // goes with capturePaste\n\n  constructor(public element:ElementRef){\n    this.initFilters()\n  }\n\n  initFilters(){\n    // the order is important\n    this.filters.push({name: 'accept', fn: this._acceptFilter})\n    this.filters.push({name: 'fileSize', fn: this._fileSizeFilter})\n\n    //this.filters.push({name: 'fileType', fn: this._fileTypeFilter})\n    //this.filters.push({name: 'queueLimit', fn: this._queueLimitFilter})\n    //this.filters.push({name: 'mimeType', fn: this._mimeTypeFilter})\n  }\n\n  ngOnDestroy(){\n    delete this.fileElm//faster memory release of dom element\n    this.destroyPasteListener();\n  }\n\n  ngOnInit(){\n    const selectable = (this.selectable || this.selectable==='') && !['false', 'null', '0'].includes(this.selectable as string);\n    if( selectable ){\n      this.enableSelecting()\n    }\n\n    if( this.multiple ){\n      this.paramFileElm().setAttribute('multiple', this.multiple)\n    }\n\n    this.evalCapturePaste();\n\n    // create reference to this class with one cycle delay to avoid ExpressionChangedAfterItHasBeenCheckedError\n    setTimeout(()=>{\n      this.directiveInit.emit(this)\n    }, 0)\n  }\n\n  ngOnChanges( changes: SimpleChanges ){\n    if( changes.accept ){\n      this.paramFileElm().setAttribute('accept', changes.accept.currentValue || '*')\n    }\n\n    if (changes.capturePaste) {\n      this.evalCapturePaste();\n    }\n\n    // Did we go from having a file to not having a file? Clear file element then\n    if (changes.file && changes.file.previousValue && !changes.file.currentValue) {\n      this.clearFileElmValue()\n    }\n\n    // Did we go from having files to not having files? Clear file element then\n    if (changes.files) {\n      const filesWentToZero = changes.files.previousValue?.length && !changes.files.currentValue?.length\n\n      if (filesWentToZero) {\n        this.clearFileElmValue()\n      }\n    }\n  }\n\n  evalCapturePaste() {\n    const isActive = this.capturePaste || (this.capturePaste as any)==='' || ['false', '0', 'null'].includes(this.capturePaste as any);\n\n    if (isActive) {\n      if (this.pasteCapturer) {\n        return; // already listening\n      }\n\n      this.pasteCapturer = (e: Event) => {\n        const clip = (e as any).clipboardData;\n        if (clip && clip.files && clip.files.length) {\n          this.handleFiles(clip.files);\n          e.preventDefault();\n        }\n      }\n\n      window.addEventListener('paste', this.pasteCapturer);\n\n      return;\n    }\n\n    this.destroyPasteListener();\n  }\n\n  destroyPasteListener() {\n    if (this.pasteCapturer) {\n      window.removeEventListener('paste', this.pasteCapturer);\n      delete this.pasteCapturer;\n    }\n  }\n\n  paramFileElm(){\n    if( this.fileElm )return this.fileElm // already defined\n\n    // elm already is a file input\n    const isFile = isFileInput( this.element.nativeElement )\n    if(isFile){\n      return this.fileElm = this.element.nativeElement\n    }\n\n    // the host elm is NOT a file input\n    return this.fileElm = this.createFileElm({\n      change: this.changeFn.bind(this)\n    })\n  }\n\n  /** Only used when host element we are attached to is NOT a fileElement */\n  createFileElm({change}: {change:() => any}) {\n    // use specific technique to hide file element within\n    const label = createInvisibleFileInputWrap()\n    const fileElm = label.getElementsByTagName('input')[0]\n\n    fileElm.addEventListener('change', change);\n    this.element.nativeElement.appendChild( label ) // put on html stage\n\n    return fileElm\n  }\n\n  enableSelecting(){\n    let elm = this.element.nativeElement\n\n    if( isFileInput(elm) ){\n      const bindedHandler = event => this.beforeSelect(event)\n      elm.addEventListener('click', bindedHandler)\n      elm.addEventListener('touchstart', bindedHandler)\n      return\n    }\n\n    const bindedHandler = ev => this.clickHandler(ev)\n    elm.addEventListener('click', bindedHandler)\n    elm.addEventListener('touchstart', bindedHandler)\n    elm.addEventListener('touchend', bindedHandler)\n  }\n\n  getValidFiles( files:File[] ):File[]{\n    const rtn:File[] = []\n    for(let x=files.length-1; x >= 0; --x){\n      if( this.isFileValid(files[x]) ){\n        rtn.push( files[x] )\n      }\n    }\n    return rtn\n  }\n\n  getInvalidFiles(files:File[]):InvalidFileItem[]{\n    const rtn:InvalidFileItem[] = []\n    for(let x=files.length-1; x >= 0; --x){\n      let failReason = this.getFileFilterFailName(files[x])\n      if( failReason ){\n        rtn.push({\n          file : files[x],\n          type : failReason\n        })\n      }\n    }\n    return rtn\n  }\n\n  // Primary handler of files coming in\n  handleFiles(files:File[]){\n    const valids = this.getValidFiles(files)\n\n    if(files.length!=valids.length){\n      this.lastInvalids = this.getInvalidFiles(files)\n    }else{\n      delete this.lastInvalids\n    }\n\n    this.lastInvalidsChange.emit(this.lastInvalids)\n\n    if( valids.length ){\n      if( this.ngfFixOrientation ){\n        this.applyExifRotations(valids)\n        .then( fixedFiles=>this.que(fixedFiles) )\n      }else{\n        this.que(valids)\n      }\n    }\n\n    if (this.isEmptyAfterSelection()) {\n      this.element.nativeElement.value = ''\n    }\n  }\n\n  que( files:File[] ){\n    this.files = this.files || []\n    Array.prototype.push.apply(this.files, files)\n\n    //below break memory ref and doesnt act like a que\n    //this.files = files//causes memory change which triggers bindings like <ngfFormData [files]=\"files\"></ngfFormData>\n\n    this.filesChange.emit( this.files )\n\n    if(files.length){\n      this.fileChange.emit( this.file=files[0] )\n\n      if(this.lastBaseUrlChange.observers.length){\n        dataUrl( files[0] )\n        .then( url=>this.lastBaseUrlChange.emit(url) )\n      }\n    }\n\n    //will be checked for input value clearing\n    this.lastFileCount = this.files.length\n  }\n\n  /** called when input has files */\n  changeFn(event:any) {\n    var fileList = event.__files_ || (event.target && event.target.files)\n\n    if (!fileList) return;\n\n    this.stopEvent(event);\n    this.handleFiles(fileList)\n  }\n\n  clickHandler(evt: Event){\n    const elm = this.element.nativeElement\n    if (elm.getAttribute('disabled') || this.fileDropDisabled){\n      return false;\n    }\n\n    var r = detectSwipe(evt);\n    // prevent the click if it is a swipe\n    if ( r!==false ) return r;\n\n    const fileElm = this.paramFileElm()\n    fileElm.click()\n    //fileElm.dispatchEvent( new Event('click') );\n    this.beforeSelect(evt)\n\n    return false;\n  }\n\n  beforeSelect(event: Event){\n    this.fileSelectStart.emit(event)\n\n    if( this.files && this.lastFileCount===this.files.length )return\n\n    // if no files in array, be sure browser does not prevent reselect of same file (see github issue 27)\n    this.clearFileElmValue()\n  }\n\n  clearFileElmValue() {\n    if (!this.fileElm) return\n\n    this.fileElm.value = null\n  }\n\n  isEmptyAfterSelection():boolean {\n    return !!this.element.nativeElement.attributes.multiple;\n  }\n\n  stopEvent(event:any):any {\n    event.preventDefault();\n    event.stopPropagation();\n  }\n\n  transferHasFiles(transfer:any):any {\n    if (!transfer.types) {\n      return false;\n    }\n\n    if (transfer.types.indexOf) {\n      return transfer.types.indexOf('Files') !== -1;\n    } else if (transfer.types.contains) {\n      return transfer.types.contains('Files');\n    } else {\n      return false;\n    }\n  }\n\n  eventToFiles(event:Event){\n    const transfer = eventToTransfer(event);\n    if( transfer ){\n      if(transfer.files && transfer.files.length){\n        return transfer.files\n      }\n      if(transfer.items && transfer.items.length){\n        return transfer.items\n      }\n    }\n    return []\n  }\n\n  applyExifRotations(\n    files:File[]\n  ):Promise<File[]>{\n    const mapper = (\n      file:File,index:number\n    ):Promise<any>=>{\n      return applyExifRotation(file)\n      .then( fixedFile=>files.splice(index, 1, fixedFile) )\n    }\n\n    const proms:Promise<any>[] = []\n    for(let x=files.length-1; x >= 0; --x){\n      proms[x] = mapper( files[x], x )\n    }\n    return Promise.all( proms ).then( ()=>files )\n  }\n\n  @HostListener('change', ['$event'])\n  onChange(event:Event):void {\n    let files = this.element.nativeElement.files || this.eventToFiles(event)\n\n    if(!files.length)return\n\n    this.stopEvent(event);\n    this.handleFiles(files)\n  }\n\n  getFileFilterFailName(\n    file:File\n  ):string | undefined{\n    for(let i = 0; i < this.filters.length; i++){\n      if( !this.filters[i].fn.call(this, file) ){\n        return this.filters[i].name\n      }\n    }\n    return undefined\n  }\n\n  isFileValid(file:File):boolean{\n    const noFilters = !this.accept && (!this.filters || !this.filters.length)\n    if( noFilters ){\n      return true//we have no filters so all files are valid\n    }\n\n    return this.getFileFilterFailName(file) ? false : true\n  }\n\n  isFilesValid(files:File[]){\n    for(let x=files.length-1; x >= 0; --x){\n      if( !this.isFileValid(files[x]) ){\n        return false\n      }\n    }\n    return true\n  }\n\n  protected _acceptFilter(item:File):boolean {\n    return acceptType(this.accept, item.type, item.name)\n  }\n\n  protected _fileSizeFilter(item:File):boolean {\n    return !(this.maxSize && item.size > this.maxSize);\n  }\n}\n\n\n/** browsers try hard to conceal data about file drags, this tends to undo that */\nexport function filesToWriteableObject( files:File[] ):dragMeta[]{\n  const jsonFiles:dragMeta[] = []\n  for(let x=0; x < files.length; ++x){\n    jsonFiles.push({\n      type:files[x].type,\n      kind:files[x][\"kind\"]\n    })\n  }\n  return jsonFiles\n}\n\nexport function eventToTransfer(event: any): TransferObject {\n  if(event.dataTransfer)return event.dataTransfer\n  return  event.originalEvent ? event.originalEvent.dataTransfer : null\n}\n\n\ninterface TransferObject {\n  items?: any[]\n  files?: any[]\n  dropEffect?: 'copy' // https://developer.mozilla.org/en-US/docs/Web/API/DataTransfer/dropEffect\n}\n"]}
import { CommonModule } from '@angular/common';
import { NgModule } from '@angular/core';
import { ngfBackground } from './ngfBackground.directive';
import { ngfDrop } from './ngfDrop.directive';
import { ngf } from './ngf.directive';
import { ngfSelect } from './ngfSelect.directive';
import { ngfUploadStatus } from './ngfUploadStatus.directive';
import { ngfFormData } from './ngfFormData.directive';
import { ngfSrc } from './ngfSrc.directive';
//import{ HttpModule } from '@angular/http';
const declarations = [
ngfDrop,
ngfSelect,
ngfBackground,
ngfSrc,
ngfUploadStatus,
ngfFormData,
ngf
];
export class ngfModule {
}
ngfModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule
//,HttpModule
],
declarations: declarations,
exports: declarations //[HttpModule, ...declarations]
},] }
];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9maWxlLXVwbG9hZC9uZ2YubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDOUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3RDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM1Qyw0Q0FBNEM7QUFFNUMsTUFBTSxZQUFZLEdBQUc7SUFDbkIsT0FBTztJQUNQLFNBQVM7SUFDVCxhQUFhO0lBQ2IsTUFBTTtJQUNOLGVBQWU7SUFDZixXQUFXO0lBQ1gsR0FBRztDQUNKLENBQUE7QUFTRSxNQUFNLE9BQU8sU0FBUzs7O1lBUHhCLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWixhQUFhO2lCQUNkO2dCQUNELFlBQVksRUFBRSxZQUFZO2dCQUMxQixPQUFPLEVBQUUsWUFBWSxDQUFBLCtCQUErQjthQUNyRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBuZ2ZCYWNrZ3JvdW5kIH0gZnJvbSAnLi9uZ2ZCYWNrZ3JvdW5kLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBuZ2ZEcm9wIH0gZnJvbSAnLi9uZ2ZEcm9wLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBuZ2YgfSBmcm9tICcuL25nZi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgbmdmU2VsZWN0IH0gZnJvbSAnLi9uZ2ZTZWxlY3QuZGlyZWN0aXZlJztcbmltcG9ydCB7IG5nZlVwbG9hZFN0YXR1cyB9IGZyb20gJy4vbmdmVXBsb2FkU3RhdHVzLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBuZ2ZGb3JtRGF0YSB9IGZyb20gJy4vbmdmRm9ybURhdGEuZGlyZWN0aXZlJztcbmltcG9ydCB7IG5nZlNyYyB9IGZyb20gJy4vbmdmU3JjLmRpcmVjdGl2ZSc7XG4vL2ltcG9ydHsgSHR0cE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2h0dHAnO1xuXG5jb25zdCBkZWNsYXJhdGlvbnMgPSBbXG4gIG5nZkRyb3AsXG4gIG5nZlNlbGVjdCxcbiAgbmdmQmFja2dyb3VuZCxcbiAgbmdmU3JjLFxuICBuZ2ZVcGxvYWRTdGF0dXMsXG4gIG5nZkZvcm1EYXRhLFxuICBuZ2Zcbl1cblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICAgIC8vLEh0dHBNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBkZWNsYXJhdGlvbnMsXG4gIGV4cG9ydHM6IGRlY2xhcmF0aW9ucy8vW0h0dHBNb2R1bGUsIC4uLmRlY2xhcmF0aW9uc11cbn0pIGV4cG9ydCBjbGFzcyBuZ2ZNb2R1bGUge30iXX0=
import { Directive, ElementRef, Input } from '@angular/core';
import { dataUrl } from './fileTools';
export class ngfBackground {
constructor(ElementRef) {
this.ElementRef = ElementRef;
}
ngOnChanges(_changes) {
dataUrl(this.file)
.then(src => {
const urlString = 'url(\'' + (src || '') + '\')';
this.ElementRef.nativeElement.style.backgroundImage = urlString;
});
}
}
ngfBackground.decorators = [
{ type: Directive, args: [{ selector: '[ngfBackground]' },] }
];
ngfBackground.ctorParameters = () => [
{ type: ElementRef }
];
ngfBackground.propDecorators = {
file: [{ type: Input, args: ['ngfBackground',] }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmQmFja2dyb3VuZC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZmlsZS11cGxvYWQvbmdmQmFja2dyb3VuZC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFHdEMsTUFBTSxPQUFPLGFBQWE7SUFHeEIsWUFBbUIsVUFBcUI7UUFBckIsZUFBVSxHQUFWLFVBQVUsQ0FBVztJQUFFLENBQUM7SUFFM0MsV0FBVyxDQUFFLFFBQVk7UUFDdkIsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7YUFDakIsSUFBSSxDQUFDLEdBQUcsQ0FBQSxFQUFFO1lBQ1QsTUFBTSxTQUFTLEdBQUcsUUFBUSxHQUFHLENBQUMsR0FBRyxJQUFJLEVBQUUsQ0FBQyxHQUFHLEtBQUssQ0FBQTtZQUNoRCxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsZUFBZSxHQUFHLFNBQVMsQ0FBQTtRQUNqRSxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7OztZQVpGLFNBQVMsU0FBQyxFQUFDLFFBQVEsRUFBRSxpQkFBaUIsRUFBQzs7O1lBSHBCLFVBQVU7OzttQkFLM0IsS0FBSyxTQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBkYXRhVXJsIH0gZnJvbSAnLi9maWxlVG9vbHMnO1xuXG5ARGlyZWN0aXZlKHtzZWxlY3RvcjogJ1tuZ2ZCYWNrZ3JvdW5kXSd9KVxuZXhwb3J0IGNsYXNzIG5nZkJhY2tncm91bmQge1xuICBASW5wdXQoJ25nZkJhY2tncm91bmQnKSBmaWxlOmFueVxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBFbGVtZW50UmVmOkVsZW1lbnRSZWYpe31cblxuICBuZ09uQ2hhbmdlcyggX2NoYW5nZXM6YW55ICl7XG4gICAgZGF0YVVybCh0aGlzLmZpbGUpXG4gICAgLnRoZW4oc3JjPT57XG4gICAgICBjb25zdCB1cmxTdHJpbmcgPSAndXJsKFxcJycgKyAoc3JjIHx8ICcnKSArICdcXCcpJ1xuICAgICAgdGhpcy5FbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuc3R5bGUuYmFja2dyb3VuZEltYWdlID0gdXJsU3RyaW5nXG4gICAgfSlcbiAgfVxufVxuIl19
import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
import { ngf, eventToTransfer, filesToWriteableObject } from "./ngf.directive";
export class ngfDrop extends ngf {
constructor() {
super(...arguments);
this.fileOver = new EventEmitter();
this.validDrag = false;
this.validDragChange = new EventEmitter();
this.invalidDrag = false;
this.invalidDragChange = new EventEmitter();
this.dragFilesChange = new EventEmitter();
}
onDrop(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
let files = this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
}
handleFiles(files) {
this.fileOver.emit(false); //turn-off dragover
super.handleFiles(files);
}
onDragOver(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
const transfer = eventToTransfer(event);
let files = this.eventToFiles(event);
let jsonFiles = filesToWriteableObject(files);
this.dragFilesChange.emit(this.dragFiles = jsonFiles);
if (files.length) {
this.validDrag = this.isFilesValid(files);
}
else {
//Safari, IE11 & some browsers do NOT tell you about dragged files until dropped. Always consider a valid drag
this.validDrag = true;
}
this.validDragChange.emit(this.validDrag);
this.invalidDrag = !this.validDrag;
this.invalidDragChange.emit(this.invalidDrag);
transfer.dropEffect = 'copy'; // change cursor and visual display
this.stopEvent(event);
this.fileOver.emit(true);
}
closeDrags() {
delete this.validDrag;
this.validDragChange.emit(this.validDrag);
this.invalidDrag = false;
this.invalidDragChange.emit(this.invalidDrag);
delete this.dragFiles;
this.dragFilesChange.emit(this.dragFiles);
}
onDragLeave(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
if (this.element) {
if (event.currentTarget === this.element[0]) {
return;
}
}
this.stopEvent(event);
this.fileOver.emit(false);
}
}
ngfDrop.decorators = [
{ type: Directive, args: [{
selector: "[ngfDrop]",
exportAs: "ngfDrop"
},] }
];
ngfDrop.propDecorators = {
fileOver: [{ type: Output }],
validDrag: [{ type: Input }],
validDragChange: [{ type: Output }],
invalidDrag: [{ type: Input }],
invalidDragChange: [{ type: Output }],
dragFiles: [{ type: Input }],
dragFilesChange: [{ type: Output }],
onDrop: [{ type: HostListener, args: ['drop', ['$event'],] }],
onDragOver: [{ type: HostListener, args: ['dragover', ['$event'],] }],
onDragLeave: [{ type: HostListener, args: ['dragleave', ['$event'],] }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmRHJvcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZmlsZS11cGxvYWQvbmdmRHJvcC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFBRSxZQUFZLEVBQ3ZCLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUM1QixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsR0FBRyxFQUFZLGVBQWUsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBTXhGLE1BQU0sT0FBTyxPQUFRLFNBQVEsR0FBRztJQUpoQzs7UUFLWSxhQUFRLEdBQXFCLElBQUksWUFBWSxFQUFFLENBQUM7UUFFakQsY0FBUyxHQUFXLEtBQUssQ0FBQTtRQUN4QixvQkFBZSxHQUF5QixJQUFJLFlBQVksRUFBRSxDQUFBO1FBRTNELGdCQUFXLEdBQUcsS0FBSyxDQUFBO1FBQ2xCLHNCQUFpQixHQUF5QixJQUFJLFlBQVksRUFBRSxDQUFBO1FBRzVELG9CQUFlLEdBQTRCLElBQUksWUFBWSxFQUFFLENBQUE7SUFpRnpFLENBQUM7SUE5RUMsTUFBTSxDQUFDLEtBQVc7UUFDaEIsSUFBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUM7WUFDdkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUN0QixPQUFNO1NBQ1A7UUFFRCxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7UUFDakIsSUFBSSxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUVwQyxJQUFHLENBQUMsS0FBSyxDQUFDLE1BQU07WUFBQyxPQUFNO1FBRXZCLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUN6QixDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQVk7UUFD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QUUsQ0FBQyxRQUFRLENBQUM7MEJBd0NuQyxZQUFZLFNBQUMsV0FBVyxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsXG4gIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE91dHB1dFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IG5nZiwgZHJhZ01ldGEsIGV2ZW50VG9UcmFuc2ZlciwgZmlsZXNUb1dyaXRlYWJsZU9iamVjdCB9IGZyb20gXCIuL25nZi5kaXJlY3RpdmVcIlxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6IFwiW25nZkRyb3BdXCIsXG4gIGV4cG9ydEFzOiBcIm5nZkRyb3BcIlxufSlcbmV4cG9ydCBjbGFzcyBuZ2ZEcm9wIGV4dGVuZHMgbmdmIHtcbiAgQE91dHB1dCgpIGZpbGVPdmVyOkV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIEBJbnB1dCgpIHZhbGlkRHJhZzpib29sZWFuID0gZmFsc2VcbiAgQE91dHB1dCgpIHZhbGlkRHJhZ0NoYW5nZTpFdmVudEVtaXR0ZXI8Ym9vbGVhbj4gPSBuZXcgRXZlbnRFbWl0dGVyKClcblxuICBASW5wdXQoKSBpbnZhbGlkRHJhZyA9IGZhbHNlXG4gIEBPdXRwdXQoKSBpbnZhbGlkRHJhZ0NoYW5nZTpFdmVudEVtaXR0ZXI8Ym9vbGVhbj4gPSBuZXcgRXZlbnRFbWl0dGVyKClcblxuICBASW5wdXQoKSBkcmFnRmlsZXMgITogZHJhZ01ldGFbXVxuICBAT3V0cHV0KCkgZHJhZ0ZpbGVzQ2hhbmdlOkV2ZW50RW1pdHRlcjxkcmFnTWV0YVtdPiA9IG5ldyBFdmVudEVtaXR0ZXIoKVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2Ryb3AnLCBbJyRldmVudCddKVxuICBvbkRyb3AoZXZlbnQ6RXZlbnQpOnZvaWQge1xuICAgIGlmKHRoaXMuZmlsZURyb3BEaXNhYmxlZCl7XG4gICAgICB0aGlzLnN0b3BFdmVudChldmVudCk7XG4gICAgICByZXR1cm5cbiAgICB9XG5cbiAgICB0aGlzLmNsb3NlRHJhZ3MoKVxuICAgIGxldCBmaWxlcyA9IHRoaXMuZXZlbnRUb0ZpbGVzKGV2ZW50KVxuXG4gICAgaWYoIWZpbGVzLmxlbmd0aClyZXR1cm5cblxuICAgIHRoaXMuc3RvcEV2ZW50KGV2ZW50KTtcbiAgICB0aGlzLmhhbmRsZUZpbGVzKGZpbGVzKVxuICB9XG5cbiAgaGFuZGxlRmlsZXMoZmlsZXM6RmlsZVtdKXtcbiAgICB0aGlzLmZpbGVPdmVyLmVtaXQoZmFsc2UpLy90dXJuLW9mZiBkcmFnb3ZlclxuICAgIHN1cGVyLmhhbmRsZUZpbGVzKGZpbGVzKVxuICB9XG5cbiAgQEhvc3RMaXN0ZW5lcignZHJhZ292ZXInLCBbJyRldmVudCddKVxuICBvbkRyYWdPdmVyKGV2ZW50OkV2ZW50KTp2b2lkIHtcbiAgICBpZih0aGlzLmZpbGVEcm9wRGlzYWJsZWQpe1xuICAgICAgdGhpcy5zdG9wRXZlbnQoZXZlbnQpO1xuICAgICAgcmV0dXJuXG4gICAgfVxuXG4gICAgY29uc3QgdHJhbnNmZXIgPSBldmVudFRvVHJhbnNmZXIoZXZlbnQpXG5cbiAgICBsZXQgZmlsZXMgPSB0aGlzLmV2ZW50VG9GaWxlcyhldmVudClcblxuICAgIGxldCBqc29uRmlsZXMgPSBmaWxlc1RvV3JpdGVhYmxlT2JqZWN0KGZpbGVzKVxuICAgIHRoaXMuZHJhZ0ZpbGVzQ2hhbmdlLmVtaXQoIHRoaXMuZHJhZ0ZpbGVzPWpzb25GaWxlcyApXG5cbiAgICBpZiggZmlsZXMubGVuZ3RoICl7XG4gICAgICB0aGlzLnZhbGlkRHJhZyA9IHRoaXMuaXNGaWxlc1ZhbGlkKGZpbGVzKVxuICAgIH1lbHNle1xuICAgICAgLy9TYWZhcmksIElFMTEgJiBzb21lIGJyb3dzZXJzIGRvIE5PVCB0ZWxsIHlvdSBhYm91dCBkcmFnZ2VkIGZpbGVzIHVudGlsIGRyb3BwZWQuIEFsd2F5cyBjb25zaWRlciBhIHZhbGlkIGRyYWdcbiAgICAgIHRoaXMudmFsaWREcmFnID0gdHJ1ZVxuICAgIH1cblxuICAgIHRoaXMudmFsaWREcmFnQ2hhbmdlLmVtaXQodGhpcy52YWxpZERyYWcpXG5cbiAgICB0aGlzLmludmFsaWREcmFnID0gIXRoaXMudmFsaWREcmFnXG4gICAgdGhpcy5pbnZhbGlkRHJhZ0NoYW5nZS5lbWl0KHRoaXMuaW52YWxpZERyYWcpXG5cbiAgICB0cmFuc2Zlci5kcm9wRWZmZWN0ID0gJ2NvcHknIC8vIGNoYW5nZSBjdXJzb3IgYW5kIHZpc3VhbCBkaXNwbGF5XG4gICAgdGhpcy5zdG9wRXZlbnQoZXZlbnQpXG4gICAgdGhpcy5maWxlT3Zlci5lbWl0KHRydWUpXG4gIH1cblxuICBjbG9zZURyYWdzKCl7XG4gICAgZGVsZXRlIHRoaXMudmFsaWREcmFnXG4gICAgdGhpcy52YWxpZERyYWdDaGFuZ2UuZW1pdCh0aGlzLnZhbGlkRHJhZylcbiAgICB0aGlzLmludmFsaWREcmFnID0gZmFsc2VcbiAgICB0aGlzLmludmFsaWREcmFnQ2hhbmdlLmVtaXQodGhpcy5pbnZhbGlkRHJhZylcbiAgICBkZWxldGUgdGhpcy5kcmFnRmlsZXNcbiAgICB0aGlzLmRyYWdGaWxlc0NoYW5nZS5lbWl0KCB0aGlzLmRyYWdGaWxlcyApXG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdkcmFnbGVhdmUnLCBbJyRldmVudCddKVxuICBvbkRyYWdMZWF2ZShldmVudDpFdmVudCk6YW55IHtcbiAgICBpZih0aGlzLmZpbGVEcm9wRGlzYWJsZWQpe1xuICAgICAgdGhpcy5zdG9wRXZlbnQoZXZlbnQpO1xuICAgICAgcmV0dXJuXG4gICAgfVxuXG4gICAgdGhpcy5jbG9zZURyYWdzKClcblxuICAgIGlmICgodGhpcyBhcyBhbnkpLmVsZW1lbnQpIHtcbiAgICAgIGlmIChldmVudC5jdXJyZW50VGFyZ2V0ID09PSAodGhpcyBhcyBhbnkpLmVsZW1lbnRbMF0pIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgIH1cblxuICAgIHRoaXMuc3RvcEV2ZW50KGV2ZW50KTtcbiAgICB0aGlzLmZpbGVPdmVyLmVtaXQoZmFsc2UpO1xuICB9XG59Il19
import { IterableDiffers, Directive, EventEmitter, Output, Input } from '@angular/core';
export class ngfFormData {
constructor(IterableDiffers) {
this.postName = "file";
this.FormData = new FormData();
this.FormDataChange = new EventEmitter();
this.differ = IterableDiffers.find([]).create();
}
ngDoCheck() {
var changes = this.differ.diff(this.files);
if (changes) {
setTimeout(() => this.buildFormData(), 0);
}
}
buildFormData() {
const isArray = typeof (this.files) === 'object' && this.files.constructor === Array;
if (isArray) {
this.FormData = new FormData();
const files = this.files || [];
files.forEach(file => this.FormData.append(this.postName, file, this.fileName || file.name));
this.FormDataChange.emit(this.FormData);
}
else {
delete this.FormData;
}
}
}
ngfFormData.decorators = [
{ type: Directive, args: [{ selector: 'ngfFormData' },] }
];
ngfFormData.ctorParameters = () => [
{ type: IterableDiffers }
];
ngfFormData.propDecorators = {
files: [{ type: Input }],
postName: [{ type: Input }],
fileName: [{ type: Input }],
FormData: [{ type: Input }],
FormDataChange: [{ type: Output }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmRm9ybURhdGEuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2ZpbGUtdXBsb2FkL25nZkZvcm1EYXRhLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsZUFBZSxFQUNmLFNBQVMsRUFBRSxZQUFZLEVBQ3ZCLE1BQU0sRUFBRSxLQUFLLEVBQ2QsTUFBTSxlQUFlLENBQUM7QUFHdkIsTUFBTSxPQUFPLFdBQVc7SUFVdEIsWUFBWSxlQUFnQztRQVJuQyxhQUFRLEdBQVUsTUFBTSxDQUFBO1FBR3hCLGFBQVEsR0FBWSxJQUFJLFFBQVEsRUFBRSxDQUFBO1FBQ2pDLG1CQUFjLEdBQTBCLElBQUksWUFBWSxFQUFFLENBQUE7UUFLbEUsSUFBSSxDQUFDLE1BQU0sR0FBRyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFBO0lBQ2pELENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxPQUFPLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUUsSUFBSSxDQUFDLEtBQUssQ0FBRSxDQUFDO1FBRTdDLElBQUksT0FBTyxFQUFFO1lBQ1gsVUFBVSxDQUFDLEdBQUUsRUFBRSxDQUFBLElBQUksQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQTtTQUN4QztJQUNILENBQUM7SUFFRCxhQUFhO1FBQ1gsTUFBTSxPQUFPLEdBQUcsT0FBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBRyxRQUFRLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEtBQUcsS0FBSyxDQUFBO1FBRS9FLElBQUksT0FBTyxFQUFFO1lBQ1gsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRSxDQUFBO1lBQzlCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFBO1lBQzlCLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFBLEVBQUUsQ0FDbEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLFFBQVEsSUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQ3BFLENBQUE7WUFDRCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBRSxJQUFJLENBQUMsUUFBUSxDQUFFLENBQUE7U0FDMUM7YUFBSTtZQUNILE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQTtTQUNyQjtJQUNILENBQUM7OztZQXBDRixTQUFTLFNBQUMsRUFBQyxRQUFRLEVBQUUsYUFBYSxFQUFDOzs7WUFMbEMsZUFBZTs7O29CQU9kLEtBQUs7dUJBQ0wsS0FBSzt1QkFDTCxLQUFLO3VCQUVMLEtBQUs7NkJBQ0wsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEl0ZXJhYmxlRGlmZmVyLFxuICBJdGVyYWJsZURpZmZlcnMsXG4gIERpcmVjdGl2ZSwgRXZlbnRFbWl0dGVyLFxuICBPdXRwdXQsIElucHV0XG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtzZWxlY3RvcjogJ25nZkZvcm1EYXRhJ30pXG5leHBvcnQgY2xhc3MgbmdmRm9ybURhdGEge1xuICBASW5wdXQoKSBmaWxlcyAhOiBGaWxlW11cbiAgQElucHV0KCkgcG9zdE5hbWU6c3RyaW5nID0gXCJmaWxlXCJcbiAgQElucHV0KCkgZmlsZU5hbWUgITogc3RyaW5nLy9mb3JjZSBmaWxlIG5hbWVcblxuICBASW5wdXQoKSBGb3JtRGF0YTpGb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpXG4gIEBPdXRwdXQoKSBGb3JtRGF0YUNoYW5nZTpFdmVudEVtaXR0ZXI8Rm9ybURhdGE+ID0gbmV3IEV2ZW50RW1pdHRlcigpXG5cbiAgZGlmZmVyOkl0ZXJhYmxlRGlmZmVyPHt9PlxuXG4gIGNvbnN0cnVjdG9yKEl0ZXJhYmxlRGlmZmVyczogSXRlcmFibGVEaWZmZXJzKXtcbiAgICB0aGlzLmRpZmZlciA9IEl0ZXJhYmxlRGlmZmVycy5maW5kKFtdKS5jcmVhdGUoKVxuICB9XG5cbiAgbmdEb0NoZWNrKCl7XG4gICAgdmFyIGNoYW5nZXMgPSB0aGlzLmRpZmZlci5kaWZmKCB0aGlzLmZpbGVzICk7XG5cbiAgICBpZiAoY2hhbmdlcykge1xuICAgICAgc2V0VGltZW91dCgoKT0+dGhpcy5idWlsZEZvcm1EYXRhKCksIDApXG4gICAgfVxuICB9XG5cbiAgYnVpbGRGb3JtRGF0YSgpe1xuICAgIGNvbnN0IGlzQXJyYXkgPSB0eXBlb2YodGhpcy5maWxlcyk9PT0nb2JqZWN0JyAmJiB0aGlzLmZpbGVzLmNvbnN0cnVjdG9yPT09QXJyYXlcblxuICAgIGlmKCBpc0FycmF5ICl7XG4gICAgICB0aGlzLkZvcm1EYXRhID0gbmV3IEZvcm1EYXRhKClcbiAgICAgIGNvbnN0IGZpbGVzID0gdGhpcy5maWxlcyB8fCBbXVxuICAgICAgZmlsZXMuZm9yRWFjaChmaWxlPT5cbiAgICAgICAgdGhpcy5Gb3JtRGF0YS5hcHBlbmQodGhpcy5wb3N0TmFtZSwgZmlsZSwgdGhpcy5maWxlTmFtZXx8ZmlsZS5uYW1lKVxuICAgICAgKVxuICAgICAgdGhpcy5Gb3JtRGF0YUNoYW5nZS5lbWl0KCB0aGlzLkZvcm1EYXRhIClcbiAgICB9ZWxzZXtcbiAgICAgIGRlbGV0ZSB0aGlzLkZvcm1EYXRhXG4gICAgfVxuICB9XG59Il19
import { Directive, Input } from "@angular/core";
import { ngf } from "./ngf.directive";
export class ngfSelect extends ngf {
constructor() {
super(...arguments);
this.selectable = true;
}
}
ngfSelect.decorators = [
{ type: Directive, args: [{
selector: "[ngfSelect]",
exportAs: "ngfSelect"
},] }
];
ngfSelect.propDecorators = {
selectable: [{ type: Input }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmU2VsZWN0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9maWxlLXVwbG9hZC9uZ2ZTZWxlY3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ2hELE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQU1yQyxNQUFNLE9BQU8sU0FBVSxTQUFRLEdBQUc7SUFKbEM7O1FBS1csZUFBVSxHQUFPLElBQUksQ0FBQTtJQUNoQyxDQUFDOzs7WUFOQSxTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGFBQWE7Z0JBQ3ZCLFFBQVEsRUFBRSxXQUFXO2FBQ3RCOzs7eUJBRUUsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5pbXBvcnQgeyBuZ2YgfSBmcm9tIFwiLi9uZ2YuZGlyZWN0aXZlXCJcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiBcIltuZ2ZTZWxlY3RdXCIsXG4gIGV4cG9ydEFzOiBcIm5nZlNlbGVjdFwiXG59KVxuZXhwb3J0IGNsYXNzIG5nZlNlbGVjdCBleHRlbmRzIG5nZiB7XG4gIEBJbnB1dCgpIHNlbGVjdGFibGU6YW55ID0gdHJ1ZVxufSJdfQ==
import { Directive, ElementRef, Input } from '@angular/core';
import { dataUrl } from './fileTools';
export class ngfSrc {
constructor(ElementRef) {
this.ElementRef = ElementRef;
}
ngOnChanges(_changes) {
dataUrl(this.file)
.then(src => this.ElementRef.nativeElement.src = src);
}
}
ngfSrc.decorators = [
{ type: Directive, args: [{ selector: '[ngfSrc]' },] }
];
ngfSrc.ctorParameters = () => [
{ type: ElementRef }
];
ngfSrc.propDecorators = {
file: [{ type: Input, args: ['ngfSrc',] }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmU3JjLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9maWxlLXVwbG9hZC9uZ2ZTcmMuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBR3RDLE1BQU0sT0FBTyxNQUFNO0lBR2pCLFlBQW1CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7SUFBSSxDQUFDO0lBRTlDLFdBQVcsQ0FBQyxRQUFhO1FBQ3ZCLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO2FBQ2pCLElBQUksQ0FBQyxHQUFHLENBQUEsRUFBRSxDQUNULElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQ3hDLENBQUE7SUFDSCxDQUFDOzs7WUFYRixTQUFTLFNBQUMsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFOzs7WUFIZixVQUFVOzs7bUJBSzNCLEtBQUssU0FBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZGF0YVVybCB9IGZyb20gJy4vZmlsZVRvb2xzJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnW25nZlNyY10nIH0pXG5leHBvcnQgY2xhc3MgbmdmU3JjIHtcbiAgQElucHV0KCduZ2ZTcmMnKSBmaWxlOiBhbnlcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgRWxlbWVudFJlZjogRWxlbWVudFJlZikgeyB9XG5cbiAgbmdPbkNoYW5nZXMoX2NoYW5nZXM6IGFueSkge1xuICAgIGRhdGFVcmwodGhpcy5maWxlKVxuICAgIC50aGVuKHNyYz0+XG4gICAgICB0aGlzLkVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5zcmMgPSBzcmNcbiAgICApXG4gIH1cbn1cbiJdfQ==
import { Directive, EventEmitter, Output, Input } from '@angular/core';
export class ngfUploadStatus {
constructor() {
this.percent = 0;
this.percentChange = new EventEmitter();
}
ngOnChanges(changes) {
if (changes.httpEvent && changes.httpEvent.currentValue) {
const event = changes.httpEvent.currentValue;
if (event.loaded && event.total) {
setTimeout(() => {
this.percent = Math.round(100 * event.loaded / event.total);
this.percentChange.emit(this.percent);
}, 0);
}
}
}
}
ngfUploadStatus.decorators = [
{ type: Directive, args: [{ selector: 'ngfUploadStatus' },] }
];
ngfUploadStatus.propDecorators = {
percent: [{ type: Input }],
percentChange: [{ type: Output }],
httpEvent: [{ type: Input }]
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdmVXBsb2FkU3RhdHVzLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9maWxlLXVwbG9hZC9uZ2ZVcGxvYWRTdGF0dXMuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdkUsTUFBTSxPQUFPLGVBQWU7SUFENUI7UUFFVyxZQUFPLEdBQVUsQ0FBQyxDQUFBO1FBQ2pCLGtCQUFhLEdBQXdCLElBQUksWUFBWSxFQUFFLENBQUE7SUFjbkUsQ0FBQztJQVhDLFdBQVcsQ0FBRSxPQUFPO1FBQ2xCLElBQUksT0FBTyxDQUFDLFNBQVMsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLFlBQVksRUFBRTtZQUN2RCxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQTtZQUM1QyxJQUFJLEtBQUssQ0FBQyxNQUFNLElBQUksS0FBSyxDQUFDLEtBQUssRUFBRTtnQkFDL0IsVUFBVSxDQUFDLEdBQUUsRUFBRTtvQkFDYixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxHQUFHLEtBQUssQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUM1RCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBRSxJQUFJLENBQUMsT0FBTyxDQUFFLENBQUE7Z0JBQ3pDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQTthQUNOO1NBQ0Y7SUFDSCxDQUFDOzs7WUFoQkYsU0FBUyxTQUFDLEVBQUMsUUFBUSxFQUFFLGlCQUFpQixFQUFDOzs7c0JBRXJDLEtBQUs7NEJBQ0wsTUFBTTt3QkFDTixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIE91dHB1dCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7c2VsZWN0b3I6ICduZ2ZVcGxvYWRTdGF0dXMnfSlcbmV4cG9ydCBjbGFzcyBuZ2ZVcGxvYWRTdGF0dXMge1xuICBASW5wdXQoKSBwZXJjZW50Om51bWJlciA9IDBcbiAgQE91dHB1dCgpIHBlcmNlbnRDaGFuZ2U6RXZlbnRFbWl0dGVyPG51bWJlcj4gPSBuZXcgRXZlbnRFbWl0dGVyKClcbiAgQElucHV0KCkgaHR0cEV2ZW50ICE6IEV2ZW50XG5cbiAgbmdPbkNoYW5nZXMoIGNoYW5nZXMgKXtcbiAgICBpZiggY2hhbmdlcy5odHRwRXZlbnQgJiYgY2hhbmdlcy5odHRwRXZlbnQuY3VycmVudFZhbHVlICl7XG4gICAgICBjb25zdCBldmVudCA9IGNoYW5nZXMuaHR0cEV2ZW50LmN1cnJlbnRWYWx1ZVxuICAgICAgaWYgKGV2ZW50LmxvYWRlZCAmJiBldmVudC50b3RhbCkge1xuICAgICAgICBzZXRUaW1lb3V0KCgpPT57XG4gICAgICAgICAgdGhpcy5wZXJjZW50ID0gTWF0aC5yb3VuZCgxMDAgKiBldmVudC5sb2FkZWQgLyBldmVudC50b3RhbCk7XG4gICAgICAgICAgdGhpcy5wZXJjZW50Q2hhbmdlLmVtaXQoIHRoaXMucGVyY2VudCApXG4gICAgICAgIH0sIDApXG4gICAgICB9XG4gICAgfVxuICB9XG59Il19
/*
* Public API Surface of angular-file
*/
export * from './file-upload/ngfSelect.directive';
export * from './file-upload/ngfDrop.directive';
export * from './file-upload/ngf.directive';
export * from './file-upload/ngf.module';
export { ngfBackground } from './file-upload/ngfBackground.directive';
export { ngfSrc } from './file-upload/ngfSrc.directive';
export { ngfUploadStatus } from './file-upload/ngfUploadStatus.directive';
export { ngfFormData } from './file-upload/ngfFormData.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDdEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3hELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0scUNBQXFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGFuZ3VsYXItZmlsZVxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vZmlsZS11cGxvYWQvbmdmU2VsZWN0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtdXBsb2FkL25nZkRyb3AuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS11cGxvYWQvbmdmLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtdXBsb2FkL25nZi5tb2R1bGUnO1xuZXhwb3J0IHsgbmdmQmFja2dyb3VuZCB9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmQmFja2dyb3VuZC5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgbmdmU3JjIH0gZnJvbSAnLi9maWxlLXVwbG9hZC9uZ2ZTcmMuZGlyZWN0aXZlJztcbmV4cG9ydCB7IG5nZlVwbG9hZFN0YXR1cyB9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmVXBsb2FkU3RhdHVzLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBuZ2ZGb3JtRGF0YSB9IGZyb20gJy4vZmlsZS11cGxvYWQvbmdmRm9ybURhdGEuZGlyZWN0aXZlJzsiXX0=
import { EventEmitter, Directive, ElementRef, Input, Output, HostListener, IterableDiffers, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
const isFileInput = function (elm) {
const ty = elm.getAttribute('type');
return elm.tagName.toLowerCase() === 'input' && ty && ty.toLowerCase() === 'file';
};
let initialTouchStartY = 0;
let initialTouchStartX = 0;
const detectSwipe = function (evt) {
var touches = evt.changedTouches || (evt.originalEvent && evt.originalEvent.changedTouches);
if (touches) {
if (evt.type === 'touchstart') {
initialTouchStartX = touches[0].clientX;
initialTouchStartY = touches[0].clientY;
return true; // don't block event default
}
else {
// prevent scroll from triggering event
if (evt.type === 'touchend') {
var currentX = touches[0].clientX;
var currentY = touches[0].clientY;
if ((Math.abs(currentX - initialTouchStartX) > 20) ||
(Math.abs(currentY - initialTouchStartY) > 20)) {
evt.stopPropagation();
if (evt.cancelable) {
evt.preventDefault();
}
return false;
}
}
return true;
}
}
return false;
};
const createInvisibleFileInputWrap = function () {
var fileElem = createFileInput();
var label = document.createElement('label');
label.innerHTML = 'upload';
label.style.visibility = 'hidden';
label.style.position = 'absolute';
label.style.overflow = 'hidden';
label.style.width = '0px';
label.style.height = '0px';
label.style.border = 'none';
label.style.margin = '0px';
label.style.padding = '0px';
label.setAttribute('tabindex', '-1');
//bindAttrToFileInput(fileElem, label);
//generatedElems.push({el: elem, ref: label});
label.appendChild(fileElem);
//document.body.appendChild( label );
return label;
};
const createFileInput = function () {
var fileElem = document.createElement('input');
fileElem.type = "file";
return fileElem;
};
function getWindow() { return window; }
function acceptType(accept, type, name) {
if (!accept) {
return true;
}
const defs = accept.split(',');
let regx;
let acceptRegString;
for (let x = defs.length - 1; x >= 0; --x) {
//Escapes dots in mimetype
acceptRegString = defs[x];
//trim
acceptRegString = acceptRegString.replace(/(^\s+|\s+$)/g, '');
//Escapes stars in mimetype
acceptRegString = acceptRegString.replace(/\*/g, '.*');
//let acceptReg = '^((' + acceptRegString
//acceptReg = acceptReg.replace(/,/g,')|(') + '))$'
//try by mime
regx = new RegExp(acceptRegString, 'gi');
if (type.search(regx) >= 0) {
return true;
}
//try by ext
if (acceptRegString.substring(0, 1) == '.') {
acceptRegString = '\\' + acceptRegString; //.substring(1, acceptRegString.length-1)//remove dot at front
regx = new RegExp(acceptRegString + '$', 'i');
if ((name || type).search(regx) >= 0) {
return true;
}
}
}
return false;
}
function arrayBufferToBase64(buffer) {
var binary = '';
var bytes = new Uint8Array(buffer);
var len = bytes.byteLength;
for (var i = 0; i < len; i++) {
binary += String.fromCharCode(bytes[i]);
}
return window.btoa(binary);
}
function dataUrltoBlob(dataurl, name, origSize) {
var arr = dataurl.split(',');
var mimeMatch = arr[0].match(/:(.*?);/);
var mime = mimeMatch ? mimeMatch[1] : 'text/plain';
var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
var blob = new window.Blob([u8arr], { type: mime });
blob["name"] = name;
blob["$ngfOrigSize"] = origSize;
return blob;
}
function applyTransform(ctx, orientation, width, height) {
switch (orientation) {
case 2:
return ctx.transform(-1, 0, 0, 1, width, 0);
case 3:
return ctx.transform(-1, 0, 0, -1, width, height);
case 4:
return ctx.transform(1, 0, 0, -1, 0, height);
case 5:
return ctx.transform(0, 1, 1, 0, 0, 0);
case 6:
return ctx.transform(0, 1, -1, 0, height, 0);
case 7:
return ctx.transform(0, -1, -1, 0, height, width);
case 8:
return ctx.transform(0, -1, 1, 0, 0, width);
}
}
function fixFileOrientationByMeta(file, result) {
return dataUrl(file, true)
.then(url => {
var canvas = document.createElement('canvas');
var img = document.createElement('img');
return new Promise(function (res, rej) {
img.onload = function () {
try {
canvas.width = result.orientation > 4 ? img.height : img.width;
canvas.height = result.orientation > 4 ? img.width : img.height;
var ctx = canvas.getContext('2d');
applyTransform(ctx, result.orientation, img.width, img.height);
ctx.drawImage(img, 0, 0);
var dataUrl = canvas.toDataURL(file.type || 'image/WebP', 0.934);
const base = arrayBufferToBase64(result.fixedArrayBuffer);
dataUrl = restoreExif(base, dataUrl);
var blob = dataUrltoBlob(dataUrl, file.name);
const newFile = blobToFile(blob, file.name);
res(newFile);
}
catch (e) {
rej(e);
}
};
img.onerror = rej;
img.src = url;
});
});
}
function applyExifRotation(file) {
if (file.type.indexOf('image/jpeg') !== 0) {
return Promise.resolve(file);
}
return readOrientation(file)
.then((result) => {
if (result.orientation < 2 || result.orientation > 8) {
return file;
}
return fixFileOrientationByMeta(file, result);
});
}
function readOrientation(file) {
return new Promise((res, rej) => {
var reader = new FileReader();
var slicedFile = file.slice ? file.slice(0, 64 * 1024) : file;
reader.readAsArrayBuffer(slicedFile);
reader.onerror = rej;
reader.onload = function (e) {
var result = { orientation: 1 };
var view = new DataView(this.result);
if (view.getUint16(0, false) !== 0xFFD8)
return res(result);
var length = view.byteLength, offset = 2;
while (offset < length) {
var marker = view.getUint16(offset, false);
offset += 2;
if (marker === 0xFFE1) {
if (view.getUint32(offset += 2, false) !== 0x45786966)
return res(result);
var little = view.getUint16(offset += 6, false) === 0x4949;
offset += view.getUint32(offset + 4, little);
var tags = view.getUint16(offset, little);
offset += 2;
for (var i = 0; i < tags; i++)
if (view.getUint16(offset + (i * 12), little) === 0x0112) {
var orientation = view.getUint16(offset + (i * 12) + 8, little);
if (orientation >= 2 && orientation <= 8) {
view.setUint16(offset + (i * 12) + 8, 1, little);
result.fixedArrayBuffer = e.target.result;
}
result.orientation = orientation;
return res(result);
}
}
else if ((marker & 0xFF00) !== 0xFF00)
break;
else
offset += view.getUint16(offset, false);
}
return res(result);
};
});
}
/** converts file-input file into base64 dataUri */
function dataUrl(file, disallowObjectUrl) {
if (!file)
return Promise.resolve(file);
if ((disallowObjectUrl && file.$ngfDataUrl != null) || (!disallowObjectUrl && file.$ngfBlobUrl != null)) {
return Promise.resolve(disallowObjectUrl ? file.$ngfDataUrl : file.$ngfBlobUrl);
}
var p = disallowObjectUrl ? file.$$ngfDataUrlPromise : file.$$ngfBlobUrlPromise;
if (p)
return p;
const win = getWindow();
let deferred;
if (win.FileReader && file &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 8') === -1 || file.size < 20000) &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 9') === -1 || file.size < 4000000)) {
//prefer URL.createObjectURL for handling refrences to files of all sizes
//since it doesn´t build a large string in memory
var URL = win.URL || win.webkitURL;
if (FileReader) {
deferred = new Promise((res, rej) => {
var fileReader = new FileReader();
fileReader.onload = function (event) {
file.$ngfDataUrl = event.target.result;
delete file.$ngfDataUrl;
res(event.target.result);
};
fileReader.onerror = function (e) {
file.$ngfDataUrl = '';
rej(e);
};
fileReader.readAsDataURL(file);
});
}
else {
var url;
try {
url = URL.createObjectURL(file);
}
catch (e) {
return Promise.reject(e);
}
deferred = Promise.resolve(url);
file.$ngfBlobUrl = url;
}
}
else {
file[disallowObjectUrl ? '$ngfDataUrl' : '$ngfBlobUrl'] = '';
return Promise.reject(new Error('Browser does not support window.FileReader, window.FileReader, or window.FileAPI')); //deferred.reject();
}
if (disallowObjectUrl) {
p = file.$$ngfDataUrlPromise = deferred;
}
else {
p = file.$$ngfBlobUrlPromise = deferred;
}
p = p.then((x) => {
delete file[disallowObjectUrl ? '$$ngfDataUrlPromise' : '$$ngfBlobUrlPromise'];
return x;
});
return p;
}
function restoreExif(orig, resized) {
var ExifRestorer = {
KEY_STR: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='
};
ExifRestorer.encode64 = function (input) {
var output = '', chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0;
do {
chr1 = input[i++];
chr2 = input[i++];
chr3 = input[i++];
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
}
else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
this.KEY_STR.charAt(enc1) +
this.KEY_STR.charAt(enc2) +
this.KEY_STR.charAt(enc3) +
this.KEY_STR.charAt(enc4);
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return output;
};
ExifRestorer.restore = function (origFileBase64, resizedFileBase64) {
if (origFileBase64.match('data:image/jpeg;base64,')) {
origFileBase64 = origFileBase64.replace('data:image/jpeg;base64,', '');
}
var rawImage = this.decode64(origFileBase64);
var segments = this.slice2Segments(rawImage);
var image = this.exifManipulation(resizedFileBase64, segments);
return 'data:image/jpeg;base64,' + this.encode64(image);
};
ExifRestorer.exifManipulation = function (resizedFileBase64, segments) {
var exifArray = this.getExifArray(segments), newImageArray = this.insertExif(resizedFileBase64, exifArray);
return new Uint8Array(newImageArray);
};
ExifRestorer.getExifArray = function (segments) {
var seg;
for (var x = 0; x < segments.length; x++) {
seg = segments[x];
if (seg[0] === 255 && seg[1] === 225) //(ff e1)
{
return seg;
}
}
return [];
};
ExifRestorer.insertExif = function (resizedFileBase64, exifArray) {
var imageData = resizedFileBase64.replace('data:image/jpeg;base64,', ''), buf = this.decode64(imageData), separatePoint = buf.indexOf(255, 3), mae = buf.slice(0, separatePoint), ato = buf.slice(separatePoint), array = mae;
array = array.concat(exifArray);
array = array.concat(ato);
return array;
};
ExifRestorer.slice2Segments = function (rawImageArray) {
var head = 0, segments = [];
while (1) {
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 218) {
break;
}
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 216) {
head += 2;
}
else {
var length = rawImageArray[head + 2] * 256 + rawImageArray[head + 3];
var endPoint = head + length + 2;
var seg = rawImageArray.slice(head, endPoint);
segments.push(seg);
head = endPoint;
}
if (head > rawImageArray.length) {
break;
}
}
return segments;
};
ExifRestorer.decode64 = function (input) {
var chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0, buf = [];
// remove all characters that are not A-Z, a-z, 0-9, +, /, or =
var base64test = /[^A-Za-z0-9\+\/\=]/g;
if (base64test.exec(input)) {
console.log('There were invalid base64 characters in the input text.');
}
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, '');
do {
enc1 = this.KEY_STR.indexOf(input.charAt(i++));
enc2 = this.KEY_STR.indexOf(input.charAt(i++));
enc3 = this.KEY_STR.indexOf(input.charAt(i++));
enc4 = this.KEY_STR.indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
buf.push(chr1);
if (enc3 !== 64) {
buf.push(chr2);
}
if (enc4 !== 64) {
buf.push(chr3);
}
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return buf;
};
return ExifRestorer.restore(orig, resized); //<= EXIF
}
;
function blobToFile(theBlob, fileName) {
var b = theBlob;
//A Blob() is almost a File() - it's just missing the two properties below which we will add
b.lastModifiedDate = new Date();
b.name = fileName;
//Cast to a File() type
return theBlob;
}
/** A master base set of logic intended to support file select/drag/drop operations
NOTE: Use ngfDrop for full drag/drop. Use ngfSelect for selecting
*/
class ngf {
constructor(element) {
this.element = element;
this.filters = [];
this.lastFileCount = 0;
this.ngfFixOrientation = true;
this.fileDropDisabled = false;
this.selectable = false;
this.directiveInit = new EventEmitter();
this.lastInvalids = [];
this.lastInvalidsChange = new EventEmitter();
this.lastBaseUrlChange = new EventEmitter();
this.fileChange = new EventEmitter();
this.files = [];
this.filesChange = new EventEmitter();
this.fileSelectStart = new EventEmitter();
this.initFilters();
}
initFilters() {
// the order is important
this.filters.push({ name: 'accept', fn: this._acceptFilter });
this.filters.push({ name: 'fileSize', fn: this._fileSizeFilter });
//this.filters.push({name: 'fileType', fn: this._fileTypeFilter})
//this.filters.push({name: 'queueLimit', fn: this._queueLimitFilter})
//this.filters.push({name: 'mimeType', fn: this._mimeTypeFilter})
}
ngOnDestroy() {
delete this.fileElm; //faster memory release of dom element
this.destroyPasteListener();
}
ngOnInit() {
const selectable = (this.selectable || this.selectable === '') && !['false', 'null', '0'].includes(this.selectable);
if (selectable) {
this.enableSelecting();
}
if (this.multiple) {
this.paramFileElm().setAttribute('multiple', this.multiple);
}
this.evalCapturePaste();
// create reference to this class with one cycle delay to avoid ExpressionChangedAfterItHasBeenCheckedError
setTimeout(() => {
this.directiveInit.emit(this);
}, 0);
}
ngOnChanges(changes) {
var _a, _b;
if (changes.accept) {
this.paramFileElm().setAttribute('accept', changes.accept.currentValue || '*');
}
if (changes.capturePaste) {
this.evalCapturePaste();
}
// Did we go from having a file to not having a file? Clear file element then
if (changes.file && changes.file.previousValue && !changes.file.currentValue) {
this.clearFileElmValue();
}
// Did we go from having files to not having files? Clear file element then
if (changes.files) {
const filesWentToZero = ((_a = changes.files.previousValue) === null || _a === void 0 ? void 0 : _a.length) && !((_b = changes.files.currentValue) === null || _b === void 0 ? void 0 : _b.length);
if (filesWentToZero) {
this.clearFileElmValue();
}
}
}
evalCapturePaste() {
const isActive = this.capturePaste || this.capturePaste === '' || ['false', '0', 'null'].includes(this.capturePaste);
if (isActive) {
if (this.pasteCapturer) {
return; // already listening
}
this.pasteCapturer = (e) => {
const clip = e.clipboardData;
if (clip && clip.files && clip.files.length) {
this.handleFiles(clip.files);
e.preventDefault();
}
};
window.addEventListener('paste', this.pasteCapturer);
return;
}
this.destroyPasteListener();
}
destroyPasteListener() {
if (this.pasteCapturer) {
window.removeEventListener('paste', this.pasteCapturer);
delete this.pasteCapturer;
}
}
paramFileElm() {
if (this.fileElm)
return this.fileElm; // already defined
// elm already is a file input
const isFile = isFileInput(this.element.nativeElement);
if (isFile) {
return this.fileElm = this.element.nativeElement;
}
// the host elm is NOT a file input
return this.fileElm = this.createFileElm({
change: this.changeFn.bind(this)
});
}
/** Only used when host element we are attached to is NOT a fileElement */
createFileElm({ change }) {
// use specific technique to hide file element within
const label = createInvisibleFileInputWrap();
const fileElm = label.getElementsByTagName('input')[0];
fileElm.addEventListener('change', change);
this.element.nativeElement.appendChild(label); // put on html stage
return fileElm;
}
enableSelecting() {
let elm = this.element.nativeElement;
if (isFileInput(elm)) {
const bindedHandler = event => this.beforeSelect(event);
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
return;
}
const bindedHandler = ev => this.clickHandler(ev);
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
elm.addEventListener('touchend', bindedHandler);
}
getValidFiles(files) {
const rtn = [];
for (let x = files.length - 1; x >= 0; --x) {
if (this.isFileValid(files[x])) {
rtn.push(files[x]);
}
}
return rtn;
}
getInvalidFiles(files) {
const rtn = [];
for (let x = files.length - 1; x >= 0; --x) {
let failReason = this.getFileFilterFailName(files[x]);
if (failReason) {
rtn.push({
file: files[x],
type: failReason
});
}
}
return rtn;
}
// Primary handler of files coming in
handleFiles(files) {
const valids = this.getValidFiles(files);
if (files.length != valids.length) {
this.lastInvalids = this.getInvalidFiles(files);
}
else {
delete this.lastInvalids;
}
this.lastInvalidsChange.emit(this.lastInvalids);
if (valids.length) {
if (this.ngfFixOrientation) {
this.applyExifRotations(valids)
.then(fixedFiles => this.que(fixedFiles));
}
else {
this.que(valids);
}
}
if (this.isEmptyAfterSelection()) {
this.element.nativeElement.value = '';
}
}
que(files) {
this.files = this.files || [];
Array.prototype.push.apply(this.files, files);
//below break memory ref and doesnt act like a que
//this.files = files//causes memory change which triggers bindings like <ngfFormData [files]="files"></ngfFormData>
this.filesChange.emit(this.files);
if (files.length) {
this.fileChange.emit(this.file = files[0]);
if (this.lastBaseUrlChange.observers.length) {
dataUrl(files[0])
.then(url => this.lastBaseUrlChange.emit(url));
}
}
//will be checked for input value clearing
this.lastFileCount = this.files.length;
}
/** called when input has files */
changeFn(event) {
var fileList = event.__files_ || (event.target && event.target.files);
if (!fileList)
return;
this.stopEvent(event);
this.handleFiles(fileList);
}
clickHandler(evt) {
const elm = this.element.nativeElement;
if (elm.getAttribute('disabled') || this.fileDropDisabled) {
return false;
}
var r = detectSwipe(evt);
// prevent the click if it is a swipe
if (r !== false)
return r;
const fileElm = this.paramFileElm();
fileElm.click();
//fileElm.dispatchEvent( new Event('click') );
this.beforeSelect(evt);
return false;
}
beforeSelect(event) {
this.fileSelectStart.emit(event);
if (this.files && this.lastFileCount === this.files.length)
return;
// if no files in array, be sure browser does not prevent reselect of same file (see github issue 27)
this.clearFileElmValue();
}
clearFileElmValue() {
if (!this.fileElm)
return;
this.fileElm.value = null;
}
isEmptyAfterSelection() {
return !!this.element.nativeElement.attributes.multiple;
}
stopEvent(event) {
event.preventDefault();
event.stopPropagation();
}
transferHasFiles(transfer) {
if (!transfer.types) {
return false;
}
if (transfer.types.indexOf) {
return transfer.types.indexOf('Files') !== -1;
}
else if (transfer.types.contains) {
return transfer.types.contains('Files');
}
else {
return false;
}
}
eventToFiles(event) {
const transfer = eventToTransfer(event);
if (transfer) {
if (transfer.files && transfer.files.length) {
return transfer.files;
}
if (transfer.items && transfer.items.length) {
return transfer.items;
}
}
return [];
}
applyExifRotations(files) {
const mapper = (file, index) => {
return applyExifRotation(file)
.then(fixedFile => files.splice(index, 1, fixedFile));
};
const proms = [];
for (let x = files.length - 1; x >= 0; --x) {
proms[x] = mapper(files[x], x);
}
return Promise.all(proms).then(() => files);
}
onChange(event) {
let files = this.element.nativeElement.files || this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
}
getFileFilterFailName(file) {
for (let i = 0; i < this.filters.length; i++) {
if (!this.filters[i].fn.call(this, file)) {
return this.filters[i].name;
}
}
return undefined;
}
isFileValid(file) {
const noFilters = !this.accept && (!this.filters || !this.filters.length);
if (noFilters) {
return true; //we have no filters so all files are valid
}
return this.getFileFilterFailName(file) ? false : true;
}
isFilesValid(files) {
for (let x = files.length - 1; x >= 0; --x) {
if (!this.isFileValid(files[x])) {
return false;
}
}
return true;
}
_acceptFilter(item) {
return acceptType(this.accept, item.type, item.name);
}
_fileSizeFilter(item) {
return !(this.maxSize && item.size > this.maxSize);
}
}
ngf.decorators = [
{ type: Directive, args: [{
selector: "[ngf]",
exportAs: "ngf"
},] }
];
ngf.ctorParameters = () => [
{ type: ElementRef }
];
ngf.propDecorators = {
multiple: [{ type: Input }],
accept: [{ type: Input }],
maxSize: [{ type: Input }],
ngfFixOrientation: [{ type: Input }],
fileDropDisabled: [{ type: Input }],
selectable: [{ type: Input }],
directiveInit: [{ type: Output, args: ['init',] }],
lastInvalids: [{ type: Input }],
lastInvalidsChange: [{ type: Output }],
lastBaseUrl: [{ type: Input }],
lastBaseUrlChange: [{ type: Output }],
file: [{ type: Input }],
fileChange: [{ type: Output }],
files: [{ type: Input }],
filesChange: [{ type: Output }],
fileSelectStart: [{ type: Output }],
capturePaste: [{ type: Input }],
onChange: [{ type: HostListener, args: ['change', ['$event'],] }]
};
/** browsers try hard to conceal data about file drags, this tends to undo that */
function filesToWriteableObject(files) {
const jsonFiles = [];
for (let x = 0; x < files.length; ++x) {
jsonFiles.push({
type: files[x].type,
kind: files[x]["kind"]
});
}
return jsonFiles;
}
function eventToTransfer(event) {
if (event.dataTransfer)
return event.dataTransfer;
return event.originalEvent ? event.originalEvent.dataTransfer : null;
}
class ngfSelect extends ngf {
constructor() {
super(...arguments);
this.selectable = true;
}
}
ngfSelect.decorators = [
{ type: Directive, args: [{
selector: "[ngfSelect]",
exportAs: "ngfSelect"
},] }
];
ngfSelect.propDecorators = {
selectable: [{ type: Input }]
};
class ngfDrop extends ngf {
constructor() {
super(...arguments);
this.fileOver = new EventEmitter();
this.validDrag = false;
this.validDragChange = new EventEmitter();
this.invalidDrag = false;
this.invalidDragChange = new EventEmitter();
this.dragFilesChange = new EventEmitter();
}
onDrop(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
let files = this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
}
handleFiles(files) {
this.fileOver.emit(false); //turn-off dragover
super.handleFiles(files);
}
onDragOver(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
const transfer = eventToTransfer(event);
let files = this.eventToFiles(event);
let jsonFiles = filesToWriteableObject(files);
this.dragFilesChange.emit(this.dragFiles = jsonFiles);
if (files.length) {
this.validDrag = this.isFilesValid(files);
}
else {
//Safari, IE11 & some browsers do NOT tell you about dragged files until dropped. Always consider a valid drag
this.validDrag = true;
}
this.validDragChange.emit(this.validDrag);
this.invalidDrag = !this.validDrag;
this.invalidDragChange.emit(this.invalidDrag);
transfer.dropEffect = 'copy'; // change cursor and visual display
this.stopEvent(event);
this.fileOver.emit(true);
}
closeDrags() {
delete this.validDrag;
this.validDragChange.emit(this.validDrag);
this.invalidDrag = false;
this.invalidDragChange.emit(this.invalidDrag);
delete this.dragFiles;
this.dragFilesChange.emit(this.dragFiles);
}
onDragLeave(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
if (this.element) {
if (event.currentTarget === this.element[0]) {
return;
}
}
this.stopEvent(event);
this.fileOver.emit(false);
}
}
ngfDrop.decorators = [
{ type: Directive, args: [{
selector: "[ngfDrop]",
exportAs: "ngfDrop"
},] }
];
ngfDrop.propDecorators = {
fileOver: [{ type: Output }],
validDrag: [{ type: Input }],
validDragChange: [{ type: Output }],
invalidDrag: [{ type: Input }],
invalidDragChange: [{ type: Output }],
dragFiles: [{ type: Input }],
dragFilesChange: [{ type: Output }],
onDrop: [{ type: HostListener, args: ['drop', ['$event'],] }],
onDragOver: [{ type: HostListener, args: ['dragover', ['$event'],] }],
onDragLeave: [{ type: HostListener, args: ['dragleave', ['$event'],] }]
};
class ngfBackground {
constructor(ElementRef) {
this.ElementRef = ElementRef;
}
ngOnChanges(_changes) {
dataUrl(this.file)
.then(src => {
const urlString = 'url(\'' + (src || '') + '\')';
this.ElementRef.nativeElement.style.backgroundImage = urlString;
});
}
}
ngfBackground.decorators = [
{ type: Directive, args: [{ selector: '[ngfBackground]' },] }
];
ngfBackground.ctorParameters = () => [
{ type: ElementRef }
];
ngfBackground.propDecorators = {
file: [{ type: Input, args: ['ngfBackground',] }]
};
class ngfUploadStatus {
constructor() {
this.percent = 0;
this.percentChange = new EventEmitter();
}
ngOnChanges(changes) {
if (changes.httpEvent && changes.httpEvent.currentValue) {
const event = changes.httpEvent.currentValue;
if (event.loaded && event.total) {
setTimeout(() => {
this.percent = Math.round(100 * event.loaded / event.total);
this.percentChange.emit(this.percent);
}, 0);
}
}
}
}
ngfUploadStatus.decorators = [
{ type: Directive, args: [{ selector: 'ngfUploadStatus' },] }
];
ngfUploadStatus.propDecorators = {
percent: [{ type: Input }],
percentChange: [{ type: Output }],
httpEvent: [{ type: Input }]
};
class ngfFormData {
constructor(IterableDiffers) {
this.postName = "file";
this.FormData = new FormData();
this.FormDataChange = new EventEmitter();
this.differ = IterableDiffers.find([]).create();
}
ngDoCheck() {
var changes = this.differ.diff(this.files);
if (changes) {
setTimeout(() => this.buildFormData(), 0);
}
}
buildFormData() {
const isArray = typeof (this.files) === 'object' && this.files.constructor === Array;
if (isArray) {
this.FormData = new FormData();
const files = this.files || [];
files.forEach(file => this.FormData.append(this.postName, file, this.fileName || file.name));
this.FormDataChange.emit(this.FormData);
}
else {
delete this.FormData;
}
}
}
ngfFormData.decorators = [
{ type: Directive, args: [{ selector: 'ngfFormData' },] }
];
ngfFormData.ctorParameters = () => [
{ type: IterableDiffers }
];
ngfFormData.propDecorators = {
files: [{ type: Input }],
postName: [{ type: Input }],
fileName: [{ type: Input }],
FormData: [{ type: Input }],
FormDataChange: [{ type: Output }]
};
class ngfSrc {
constructor(ElementRef) {
this.ElementRef = ElementRef;
}
ngOnChanges(_changes) {
dataUrl(this.file)
.then(src => this.ElementRef.nativeElement.src = src);
}
}
ngfSrc.decorators = [
{ type: Directive, args: [{ selector: '[ngfSrc]' },] }
];
ngfSrc.ctorParameters = () => [
{ type: ElementRef }
];
ngfSrc.propDecorators = {
file: [{ type: Input, args: ['ngfSrc',] }]
};
//import{ HttpModule } from '@angular/http';
const declarations = [
ngfDrop,
ngfSelect,
ngfBackground,
ngfSrc,
ngfUploadStatus,
ngfFormData,
ngf
];
class ngfModule {
}
ngfModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule
//,HttpModule
],
declarations: declarations,
exports: declarations //[HttpModule, ...declarations]
},] }
];
/*
* Public API Surface of angular-file
*/
/**
* Generated bundle index. Do not edit.
*/
export { eventToTransfer, filesToWriteableObject, ngf, ngfBackground, ngfDrop, ngfFormData, ngfModule, ngfSelect, ngfSrc, ngfUploadStatus };
//# sourceMappingURL=angular-file-src.js.map

Sorry, the diff of this file is too big to display

import { CommonModule } from '@angular/common';
import { Directive, ElementRef, Input, EventEmitter, Output, HostListener, IterableDiffers, NgModule } from '@angular/core';
function getWindow() { return window; }
function acceptType(accept, type, name) {
if (!accept) {
return true;
}
const defs = accept.split(',');
let regx;
let acceptRegString;
for (let x = defs.length - 1; x >= 0; --x) {
//Escapes dots in mimetype
acceptRegString = defs[x];
//trim
acceptRegString = acceptRegString.replace(/(^\s+|\s+$)/g, '');
//Escapes stars in mimetype
acceptRegString = acceptRegString.replace(/\*/g, '.*');
//let acceptReg = '^((' + acceptRegString
//acceptReg = acceptReg.replace(/,/g,')|(') + '))$'
//try by mime
regx = new RegExp(acceptRegString, 'gi');
if (type.search(regx) >= 0) {
return true;
}
//try by ext
if (acceptRegString.substring(0, 1) == '.') {
acceptRegString = '\\' + acceptRegString; //.substring(1, acceptRegString.length-1)//remove dot at front
regx = new RegExp(acceptRegString + '$', 'i');
if ((name || type).search(regx) >= 0) {
return true;
}
}
}
return false;
}
function arrayBufferToBase64(buffer) {
var binary = '';
var bytes = new Uint8Array(buffer);
var len = bytes.byteLength;
for (var i = 0; i < len; i++) {
binary += String.fromCharCode(bytes[i]);
}
return window.btoa(binary);
}
function dataUrltoBlob(dataurl, name, origSize) {
var arr = dataurl.split(',');
var mimeMatch = arr[0].match(/:(.*?);/);
var mime = mimeMatch ? mimeMatch[1] : 'text/plain';
var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
var blob = new window.Blob([u8arr], { type: mime });
blob["name"] = name;
blob["$ngfOrigSize"] = origSize;
return blob;
}
function applyTransform(ctx, orientation, width, height) {
switch (orientation) {
case 2:
return ctx.transform(-1, 0, 0, 1, width, 0);
case 3:
return ctx.transform(-1, 0, 0, -1, width, height);
case 4:
return ctx.transform(1, 0, 0, -1, 0, height);
case 5:
return ctx.transform(0, 1, 1, 0, 0, 0);
case 6:
return ctx.transform(0, 1, -1, 0, height, 0);
case 7:
return ctx.transform(0, -1, -1, 0, height, width);
case 8:
return ctx.transform(0, -1, 1, 0, 0, width);
}
}
function fixFileOrientationByMeta(file, result) {
return dataUrl(file, true)
.then(url => {
var canvas = document.createElement('canvas');
var img = document.createElement('img');
return new Promise(function (res, rej) {
img.onload = function () {
try {
canvas.width = result.orientation > 4 ? img.height : img.width;
canvas.height = result.orientation > 4 ? img.width : img.height;
var ctx = canvas.getContext('2d');
applyTransform(ctx, result.orientation, img.width, img.height);
ctx.drawImage(img, 0, 0);
var dataUrl = canvas.toDataURL(file.type || 'image/WebP', 0.934);
const base = arrayBufferToBase64(result.fixedArrayBuffer);
dataUrl = restoreExif(base, dataUrl);
var blob = dataUrltoBlob(dataUrl, file.name);
const newFile = blobToFile(blob, file.name);
res(newFile);
}
catch (e) {
rej(e);
}
};
img.onerror = rej;
img.src = url;
});
});
}
function applyExifRotation(file) {
if (file.type.indexOf('image/jpeg') !== 0) {
return Promise.resolve(file);
}
return readOrientation(file)
.then((result) => {
if (result.orientation < 2 || result.orientation > 8) {
return file;
}
return fixFileOrientationByMeta(file, result);
});
}
function readOrientation(file) {
return new Promise((res, rej) => {
var reader = new FileReader();
var slicedFile = file.slice ? file.slice(0, 64 * 1024) : file;
reader.readAsArrayBuffer(slicedFile);
reader.onerror = rej;
reader.onload = function (e) {
var result = { orientation: 1 };
var view = new DataView(this.result);
if (view.getUint16(0, false) !== 0xFFD8)
return res(result);
var length = view.byteLength, offset = 2;
while (offset < length) {
var marker = view.getUint16(offset, false);
offset += 2;
if (marker === 0xFFE1) {
if (view.getUint32(offset += 2, false) !== 0x45786966)
return res(result);
var little = view.getUint16(offset += 6, false) === 0x4949;
offset += view.getUint32(offset + 4, little);
var tags = view.getUint16(offset, little);
offset += 2;
for (var i = 0; i < tags; i++)
if (view.getUint16(offset + (i * 12), little) === 0x0112) {
var orientation = view.getUint16(offset + (i * 12) + 8, little);
if (orientation >= 2 && orientation <= 8) {
view.setUint16(offset + (i * 12) + 8, 1, little);
result.fixedArrayBuffer = e.target.result;
}
result.orientation = orientation;
return res(result);
}
}
else if ((marker & 0xFF00) !== 0xFF00)
break;
else
offset += view.getUint16(offset, false);
}
return res(result);
};
});
}
/** converts file-input file into base64 dataUri */
function dataUrl(file, disallowObjectUrl) {
if (!file)
return Promise.resolve(file);
if ((disallowObjectUrl && file.$ngfDataUrl != null) || (!disallowObjectUrl && file.$ngfBlobUrl != null)) {
return Promise.resolve(disallowObjectUrl ? file.$ngfDataUrl : file.$ngfBlobUrl);
}
var p = disallowObjectUrl ? file.$$ngfDataUrlPromise : file.$$ngfBlobUrlPromise;
if (p)
return p;
const win = getWindow();
let deferred;
if (win.FileReader && file &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 8') === -1 || file.size < 20000) &&
(!win.FileAPI || navigator.userAgent.indexOf('MSIE 9') === -1 || file.size < 4000000)) {
//prefer URL.createObjectURL for handling refrences to files of all sizes
//since it doesn´t build a large string in memory
var URL = win.URL || win.webkitURL;
if (FileReader) {
deferred = new Promise((res, rej) => {
var fileReader = new FileReader();
fileReader.onload = function (event) {
file.$ngfDataUrl = event.target.result;
delete file.$ngfDataUrl;
res(event.target.result);
};
fileReader.onerror = function (e) {
file.$ngfDataUrl = '';
rej(e);
};
fileReader.readAsDataURL(file);
});
}
else {
var url;
try {
url = URL.createObjectURL(file);
}
catch (e) {
return Promise.reject(e);
}
deferred = Promise.resolve(url);
file.$ngfBlobUrl = url;
}
}
else {
file[disallowObjectUrl ? '$ngfDataUrl' : '$ngfBlobUrl'] = '';
return Promise.reject(new Error('Browser does not support window.FileReader, window.FileReader, or window.FileAPI')); //deferred.reject();
}
if (disallowObjectUrl) {
p = file.$$ngfDataUrlPromise = deferred;
}
else {
p = file.$$ngfBlobUrlPromise = deferred;
}
p = p.then((x) => {
delete file[disallowObjectUrl ? '$$ngfDataUrlPromise' : '$$ngfBlobUrlPromise'];
return x;
});
return p;
}
function restoreExif(orig, resized) {
var ExifRestorer = {
KEY_STR: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='
};
ExifRestorer.encode64 = function (input) {
var output = '', chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0;
do {
chr1 = input[i++];
chr2 = input[i++];
chr3 = input[i++];
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
}
else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
this.KEY_STR.charAt(enc1) +
this.KEY_STR.charAt(enc2) +
this.KEY_STR.charAt(enc3) +
this.KEY_STR.charAt(enc4);
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return output;
};
ExifRestorer.restore = function (origFileBase64, resizedFileBase64) {
if (origFileBase64.match('data:image/jpeg;base64,')) {
origFileBase64 = origFileBase64.replace('data:image/jpeg;base64,', '');
}
var rawImage = this.decode64(origFileBase64);
var segments = this.slice2Segments(rawImage);
var image = this.exifManipulation(resizedFileBase64, segments);
return 'data:image/jpeg;base64,' + this.encode64(image);
};
ExifRestorer.exifManipulation = function (resizedFileBase64, segments) {
var exifArray = this.getExifArray(segments), newImageArray = this.insertExif(resizedFileBase64, exifArray);
return new Uint8Array(newImageArray);
};
ExifRestorer.getExifArray = function (segments) {
var seg;
for (var x = 0; x < segments.length; x++) {
seg = segments[x];
if (seg[0] === 255 && seg[1] === 225) //(ff e1)
{
return seg;
}
}
return [];
};
ExifRestorer.insertExif = function (resizedFileBase64, exifArray) {
var imageData = resizedFileBase64.replace('data:image/jpeg;base64,', ''), buf = this.decode64(imageData), separatePoint = buf.indexOf(255, 3), mae = buf.slice(0, separatePoint), ato = buf.slice(separatePoint), array = mae;
array = array.concat(exifArray);
array = array.concat(ato);
return array;
};
ExifRestorer.slice2Segments = function (rawImageArray) {
var head = 0, segments = [];
while (1) {
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 218) {
break;
}
if (rawImageArray[head] === 255 && rawImageArray[head + 1] === 216) {
head += 2;
}
else {
var length = rawImageArray[head + 2] * 256 + rawImageArray[head + 3];
var endPoint = head + length + 2;
var seg = rawImageArray.slice(head, endPoint);
segments.push(seg);
head = endPoint;
}
if (head > rawImageArray.length) {
break;
}
}
return segments;
};
ExifRestorer.decode64 = function (input) {
var chr1, chr2, chr3 = '', enc1, enc2, enc3, enc4 = '', i = 0, buf = [];
// remove all characters that are not A-Z, a-z, 0-9, +, /, or =
var base64test = /[^A-Za-z0-9\+\/\=]/g;
if (base64test.exec(input)) {
console.log('There were invalid base64 characters in the input text.');
}
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, '');
do {
enc1 = this.KEY_STR.indexOf(input.charAt(i++));
enc2 = this.KEY_STR.indexOf(input.charAt(i++));
enc3 = this.KEY_STR.indexOf(input.charAt(i++));
enc4 = this.KEY_STR.indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
buf.push(chr1);
if (enc3 !== 64) {
buf.push(chr2);
}
if (enc4 !== 64) {
buf.push(chr3);
}
chr1 = chr2 = chr3 = '';
enc1 = enc2 = enc3 = enc4 = '';
} while (i < input.length);
return buf;
};
return ExifRestorer.restore(orig, resized); //<= EXIF
}
;
function blobToFile(theBlob, fileName) {
var b = theBlob;
//A Blob() is almost a File() - it's just missing the two properties below which we will add
b.lastModifiedDate = new Date();
b.name = fileName;
//Cast to a File() type
return theBlob;
}
class ngfBackground {
constructor(ElementRef) {
this.ElementRef = ElementRef;
}
ngOnChanges(_changes) {
dataUrl(this.file)
.then(src => {
const urlString = 'url(\'' + (src || '') + '\')';
this.ElementRef.nativeElement.style.backgroundImage = urlString;
});
}
}
ngfBackground.decorators = [
{ type: Directive, args: [{ selector: '[ngfBackground]' },] }
];
ngfBackground.ctorParameters = () => [
{ type: ElementRef }
];
ngfBackground.propDecorators = {
file: [{ type: Input, args: ['ngfBackground',] }]
};
const isFileInput = function (elm) {
const ty = elm.getAttribute('type');
return elm.tagName.toLowerCase() === 'input' && ty && ty.toLowerCase() === 'file';
};
let initialTouchStartY = 0;
let initialTouchStartX = 0;
const detectSwipe = function (evt) {
var touches = evt.changedTouches || (evt.originalEvent && evt.originalEvent.changedTouches);
if (touches) {
if (evt.type === 'touchstart') {
initialTouchStartX = touches[0].clientX;
initialTouchStartY = touches[0].clientY;
return true; // don't block event default
}
else {
// prevent scroll from triggering event
if (evt.type === 'touchend') {
var currentX = touches[0].clientX;
var currentY = touches[0].clientY;
if ((Math.abs(currentX - initialTouchStartX) > 20) ||
(Math.abs(currentY - initialTouchStartY) > 20)) {
evt.stopPropagation();
if (evt.cancelable) {
evt.preventDefault();
}
return false;
}
}
return true;
}
}
return false;
};
const createInvisibleFileInputWrap = function () {
var fileElem = createFileInput();
var label = document.createElement('label');
label.innerHTML = 'upload';
label.style.visibility = 'hidden';
label.style.position = 'absolute';
label.style.overflow = 'hidden';
label.style.width = '0px';
label.style.height = '0px';
label.style.border = 'none';
label.style.margin = '0px';
label.style.padding = '0px';
label.setAttribute('tabindex', '-1');
//bindAttrToFileInput(fileElem, label);
//generatedElems.push({el: elem, ref: label});
label.appendChild(fileElem);
//document.body.appendChild( label );
return label;
};
const createFileInput = function () {
var fileElem = document.createElement('input');
fileElem.type = "file";
return fileElem;
};
/** A master base set of logic intended to support file select/drag/drop operations
NOTE: Use ngfDrop for full drag/drop. Use ngfSelect for selecting
*/
class ngf {
constructor(element) {
this.element = element;
this.filters = [];
this.lastFileCount = 0;
this.ngfFixOrientation = true;
this.fileDropDisabled = false;
this.selectable = false;
this.directiveInit = new EventEmitter();
this.lastInvalids = [];
this.lastInvalidsChange = new EventEmitter();
this.lastBaseUrlChange = new EventEmitter();
this.fileChange = new EventEmitter();
this.files = [];
this.filesChange = new EventEmitter();
this.fileSelectStart = new EventEmitter();
this.initFilters();
}
initFilters() {
// the order is important
this.filters.push({ name: 'accept', fn: this._acceptFilter });
this.filters.push({ name: 'fileSize', fn: this._fileSizeFilter });
//this.filters.push({name: 'fileType', fn: this._fileTypeFilter})
//this.filters.push({name: 'queueLimit', fn: this._queueLimitFilter})
//this.filters.push({name: 'mimeType', fn: this._mimeTypeFilter})
}
ngOnDestroy() {
delete this.fileElm; //faster memory release of dom element
this.destroyPasteListener();
}
ngOnInit() {
const selectable = (this.selectable || this.selectable === '') && !['false', 'null', '0'].includes(this.selectable);
if (selectable) {
this.enableSelecting();
}
if (this.multiple) {
this.paramFileElm().setAttribute('multiple', this.multiple);
}
this.evalCapturePaste();
// create reference to this class with one cycle delay to avoid ExpressionChangedAfterItHasBeenCheckedError
setTimeout(() => {
this.directiveInit.emit(this);
}, 0);
}
ngOnChanges(changes) {
var _a, _b;
if (changes.accept) {
this.paramFileElm().setAttribute('accept', changes.accept.currentValue || '*');
}
if (changes.capturePaste) {
this.evalCapturePaste();
}
// Did we go from having a file to not having a file? Clear file element then
if (changes.file && changes.file.previousValue && !changes.file.currentValue) {
this.clearFileElmValue();
}
// Did we go from having files to not having files? Clear file element then
if (changes.files) {
const filesWentToZero = ((_a = changes.files.previousValue) === null || _a === void 0 ? void 0 : _a.length) && !((_b = changes.files.currentValue) === null || _b === void 0 ? void 0 : _b.length);
if (filesWentToZero) {
this.clearFileElmValue();
}
}
}
evalCapturePaste() {
const isActive = this.capturePaste || this.capturePaste === '' || ['false', '0', 'null'].includes(this.capturePaste);
if (isActive) {
if (this.pasteCapturer) {
return; // already listening
}
this.pasteCapturer = (e) => {
const clip = e.clipboardData;
if (clip && clip.files && clip.files.length) {
this.handleFiles(clip.files);
e.preventDefault();
}
};
window.addEventListener('paste', this.pasteCapturer);
return;
}
this.destroyPasteListener();
}
destroyPasteListener() {
if (this.pasteCapturer) {
window.removeEventListener('paste', this.pasteCapturer);
delete this.pasteCapturer;
}
}
paramFileElm() {
if (this.fileElm)
return this.fileElm; // already defined
// elm already is a file input
const isFile = isFileInput(this.element.nativeElement);
if (isFile) {
return this.fileElm = this.element.nativeElement;
}
// the host elm is NOT a file input
return this.fileElm = this.createFileElm({
change: this.changeFn.bind(this)
});
}
/** Only used when host element we are attached to is NOT a fileElement */
createFileElm({ change }) {
// use specific technique to hide file element within
const label = createInvisibleFileInputWrap();
const fileElm = label.getElementsByTagName('input')[0];
fileElm.addEventListener('change', change);
this.element.nativeElement.appendChild(label); // put on html stage
return fileElm;
}
enableSelecting() {
let elm = this.element.nativeElement;
if (isFileInput(elm)) {
const bindedHandler = event => this.beforeSelect(event);
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
return;
}
const bindedHandler = ev => this.clickHandler(ev);
elm.addEventListener('click', bindedHandler);
elm.addEventListener('touchstart', bindedHandler);
elm.addEventListener('touchend', bindedHandler);
}
getValidFiles(files) {
const rtn = [];
for (let x = files.length - 1; x >= 0; --x) {
if (this.isFileValid(files[x])) {
rtn.push(files[x]);
}
}
return rtn;
}
getInvalidFiles(files) {
const rtn = [];
for (let x = files.length - 1; x >= 0; --x) {
let failReason = this.getFileFilterFailName(files[x]);
if (failReason) {
rtn.push({
file: files[x],
type: failReason
});
}
}
return rtn;
}
// Primary handler of files coming in
handleFiles(files) {
const valids = this.getValidFiles(files);
if (files.length != valids.length) {
this.lastInvalids = this.getInvalidFiles(files);
}
else {
delete this.lastInvalids;
}
this.lastInvalidsChange.emit(this.lastInvalids);
if (valids.length) {
if (this.ngfFixOrientation) {
this.applyExifRotations(valids)
.then(fixedFiles => this.que(fixedFiles));
}
else {
this.que(valids);
}
}
if (this.isEmptyAfterSelection()) {
this.element.nativeElement.value = '';
}
}
que(files) {
this.files = this.files || [];
Array.prototype.push.apply(this.files, files);
//below break memory ref and doesnt act like a que
//this.files = files//causes memory change which triggers bindings like <ngfFormData [files]="files"></ngfFormData>
this.filesChange.emit(this.files);
if (files.length) {
this.fileChange.emit(this.file = files[0]);
if (this.lastBaseUrlChange.observers.length) {
dataUrl(files[0])
.then(url => this.lastBaseUrlChange.emit(url));
}
}
//will be checked for input value clearing
this.lastFileCount = this.files.length;
}
/** called when input has files */
changeFn(event) {
var fileList = event.__files_ || (event.target && event.target.files);
if (!fileList)
return;
this.stopEvent(event);
this.handleFiles(fileList);
}
clickHandler(evt) {
const elm = this.element.nativeElement;
if (elm.getAttribute('disabled') || this.fileDropDisabled) {
return false;
}
var r = detectSwipe(evt);
// prevent the click if it is a swipe
if (r !== false)
return r;
const fileElm = this.paramFileElm();
fileElm.click();
//fileElm.dispatchEvent( new Event('click') );
this.beforeSelect(evt);
return false;
}
beforeSelect(event) {
this.fileSelectStart.emit(event);
if (this.files && this.lastFileCount === this.files.length)
return;
// if no files in array, be sure browser does not prevent reselect of same file (see github issue 27)
this.clearFileElmValue();
}
clearFileElmValue() {
if (!this.fileElm)
return;
this.fileElm.value = null;
}
isEmptyAfterSelection() {
return !!this.element.nativeElement.attributes.multiple;
}
stopEvent(event) {
event.preventDefault();
event.stopPropagation();
}
transferHasFiles(transfer) {
if (!transfer.types) {
return false;
}
if (transfer.types.indexOf) {
return transfer.types.indexOf('Files') !== -1;
}
else if (transfer.types.contains) {
return transfer.types.contains('Files');
}
else {
return false;
}
}
eventToFiles(event) {
const transfer = eventToTransfer(event);
if (transfer) {
if (transfer.files && transfer.files.length) {
return transfer.files;
}
if (transfer.items && transfer.items.length) {
return transfer.items;
}
}
return [];
}
applyExifRotations(files) {
const mapper = (file, index) => {
return applyExifRotation(file)
.then(fixedFile => files.splice(index, 1, fixedFile));
};
const proms = [];
for (let x = files.length - 1; x >= 0; --x) {
proms[x] = mapper(files[x], x);
}
return Promise.all(proms).then(() => files);
}
onChange(event) {
let files = this.element.nativeElement.files || this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
}
getFileFilterFailName(file) {
for (let i = 0; i < this.filters.length; i++) {
if (!this.filters[i].fn.call(this, file)) {
return this.filters[i].name;
}
}
return undefined;
}
isFileValid(file) {
const noFilters = !this.accept && (!this.filters || !this.filters.length);
if (noFilters) {
return true; //we have no filters so all files are valid
}
return this.getFileFilterFailName(file) ? false : true;
}
isFilesValid(files) {
for (let x = files.length - 1; x >= 0; --x) {
if (!this.isFileValid(files[x])) {
return false;
}
}
return true;
}
_acceptFilter(item) {
return acceptType(this.accept, item.type, item.name);
}
_fileSizeFilter(item) {
return !(this.maxSize && item.size > this.maxSize);
}
}
ngf.decorators = [
{ type: Directive, args: [{
selector: "[ngf]",
exportAs: "ngf"
},] }
];
ngf.ctorParameters = () => [
{ type: ElementRef }
];
ngf.propDecorators = {
multiple: [{ type: Input }],
accept: [{ type: Input }],
maxSize: [{ type: Input }],
ngfFixOrientation: [{ type: Input }],
fileDropDisabled: [{ type: Input }],
selectable: [{ type: Input }],
directiveInit: [{ type: Output, args: ['init',] }],
lastInvalids: [{ type: Input }],
lastInvalidsChange: [{ type: Output }],
lastBaseUrl: [{ type: Input }],
lastBaseUrlChange: [{ type: Output }],
file: [{ type: Input }],
fileChange: [{ type: Output }],
files: [{ type: Input }],
filesChange: [{ type: Output }],
fileSelectStart: [{ type: Output }],
capturePaste: [{ type: Input }],
onChange: [{ type: HostListener, args: ['change', ['$event'],] }]
};
/** browsers try hard to conceal data about file drags, this tends to undo that */
function filesToWriteableObject(files) {
const jsonFiles = [];
for (let x = 0; x < files.length; ++x) {
jsonFiles.push({
type: files[x].type,
kind: files[x]["kind"]
});
}
return jsonFiles;
}
function eventToTransfer(event) {
if (event.dataTransfer)
return event.dataTransfer;
return event.originalEvent ? event.originalEvent.dataTransfer : null;
}
class ngfDrop extends ngf {
constructor() {
super(...arguments);
this.fileOver = new EventEmitter();
this.validDrag = false;
this.validDragChange = new EventEmitter();
this.invalidDrag = false;
this.invalidDragChange = new EventEmitter();
this.dragFilesChange = new EventEmitter();
}
onDrop(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
let files = this.eventToFiles(event);
if (!files.length)
return;
this.stopEvent(event);
this.handleFiles(files);
}
handleFiles(files) {
this.fileOver.emit(false); //turn-off dragover
super.handleFiles(files);
}
onDragOver(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
const transfer = eventToTransfer(event);
let files = this.eventToFiles(event);
let jsonFiles = filesToWriteableObject(files);
this.dragFilesChange.emit(this.dragFiles = jsonFiles);
if (files.length) {
this.validDrag = this.isFilesValid(files);
}
else {
//Safari, IE11 & some browsers do NOT tell you about dragged files until dropped. Always consider a valid drag
this.validDrag = true;
}
this.validDragChange.emit(this.validDrag);
this.invalidDrag = !this.validDrag;
this.invalidDragChange.emit(this.invalidDrag);
transfer.dropEffect = 'copy'; // change cursor and visual display
this.stopEvent(event);
this.fileOver.emit(true);
}
closeDrags() {
delete this.validDrag;
this.validDragChange.emit(this.validDrag);
this.invalidDrag = false;
this.invalidDragChange.emit(this.invalidDrag);
delete this.dragFiles;
this.dragFilesChange.emit(this.dragFiles);
}
onDragLeave(event) {
if (this.fileDropDisabled) {
this.stopEvent(event);
return;
}
this.closeDrags();
if (this.element) {
if (event.currentTarget === this.element[0]) {
return;
}
}
this.stopEvent(event);
this.fileOver.emit(false);
}
}
ngfDrop.decorators = [
{ type: Directive, args: [{
selector: "[ngfDrop]",
exportAs: "ngfDrop"
},] }
];
ngfDrop.propDecorators = {
fileOver: [{ type: Output }],
validDrag: [{ type: Input }],
validDragChange: [{ type: Output }],
invalidDrag: [{ type: Input }],
invalidDragChange: [{ type: Output }],
dragFiles: [{ type: Input }],
dragFilesChange: [{ type: Output }],
onDrop: [{ type: HostListener, args: ['drop', ['$event'],] }],
onDragOver: [{ type: HostListener, args: ['dragover', ['$event'],] }],
onDragLeave: [{ type: HostListener, args: ['dragleave', ['$event'],] }]
};
class ngfSelect extends ngf {
constructor() {
super(...arguments);
this.selectable = true;
}
}
ngfSelect.decorators = [
{ type: Directive, args: [{
selector: "[ngfSelect]",
exportAs: "ngfSelect"
},] }
];
ngfSelect.propDecorators = {
selectable: [{ type: Input }]
};
class ngfUploadStatus {
constructor() {
this.percent = 0;
this.percentChange = new EventEmitter();
}
ngOnChanges(changes) {
if (changes.httpEvent && changes.httpEvent.currentValue) {
const event = changes.httpEvent.currentValue;
if (event.loaded && event.total) {
setTimeout(() => {
this.percent = Math.round(100 * event.loaded / event.total);
this.percentChange.emit(this.percent);
}, 0);
}
}
}
}
ngfUploadStatus.decorators = [
{ type: Directive, args: [{ selector: 'ngfUploadStatus' },] }
];
ngfUploadStatus.propDecorators = {
percent: [{ type: Input }],
percentChange: [{ type: Output }],
httpEvent: [{ type: Input }]
};
class ngfFormData {
constructor(IterableDiffers) {
this.postName = "file";
this.FormData = new FormData();
this.FormDataChange = new EventEmitter();
this.differ = IterableDiffers.find([]).create();
}
ngDoCheck() {
var changes = this.differ.diff(this.files);
if (changes) {
setTimeout(() => this.buildFormData(), 0);
}
}
buildFormData() {
const isArray = typeof (this.files) === 'object' && this.files.constructor === Array;
if (isArray) {
this.FormData = new FormData();
const files = this.files || [];
files.forEach(file => this.FormData.append(this.postName, file, this.fileName || file.name));
this.FormDataChange.emit(this.FormData);
}
else {
delete this.FormData;
}
}
}
ngfFormData.decorators = [
{ type: Directive, args: [{ selector: 'ngfFormData' },] }
];
ngfFormData.ctorParameters = () => [
{ type: IterableDiffers }
];
ngfFormData.propDecorators = {
files: [{ type: Input }],
postName: [{ type: Input }],
fileName: [{ type: Input }],
FormData: [{ type: Input }],
FormDataChange: [{ type: Output }]
};
class ngfSrc {
constructor(ElementRef) {
this.ElementRef = ElementRef;
}
ngOnChanges(_changes) {
dataUrl(this.file)
.then(src => this.ElementRef.nativeElement.src = src);
}
}
ngfSrc.decorators = [
{ type: Directive, args: [{ selector: '[ngfSrc]' },] }
];
ngfSrc.ctorParameters = () => [
{ type: ElementRef }
];
ngfSrc.propDecorators = {
file: [{ type: Input, args: ['ngfSrc',] }]
};
//import{ HttpModule } from '@angular/http';
const declarations = [
ngfDrop,
ngfSelect,
ngfBackground,
ngfSrc,
ngfUploadStatus,
ngfFormData,
ngf
];
class ngfModule {
}
ngfModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule
//,HttpModule
],
declarations: declarations,
exports: declarations //[HttpModule, ...declarations]
},] }
];
/**
* Generated bundle index. Do not edit.
*/
export { ngfModule, ngfDrop as ɵa, ngf as ɵb, ngfSelect as ɵc, ngfBackground as ɵd, ngfSrc as ɵe, ngfUploadStatus as ɵf, ngfFormData as ɵg };
//# sourceMappingURL=angular-file.js.map

Sorry, the diff of this file is too big to display

export * from './file-upload/ngfSelect.directive';
export * from './file-upload/ngfDrop.directive';
export * from './file-upload/ngf.directive';
export * from './file-upload/ngf.module';
export { ngfBackground } from './file-upload/ngfBackground.directive';
export { ngfSrc } from './file-upload/ngfSrc.directive';
export { ngfUploadStatus } from './file-upload/ngfUploadStatus.directive';
export { ngfFormData } from './file-upload/ngfFormData.directive';