@sd-angular/core 1.1.94 → 1.1.97
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/sd-angular-core-grid-material.umd.js +52 -37
- package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
- package/bundles/sd-angular-core-grid-material.umd.min.js +2 -2
- package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-upload-file.umd.js +24 -2
- package/bundles/sd-angular-core-upload-file.umd.js.map +1 -1
- package/bundles/sd-angular-core-upload-file.umd.min.js +1 -1
- package/bundles/sd-angular-core-upload-file.umd.min.js.map +1 -1
- package/esm2015/grid-material/src/lib/grid-material.component.js +8 -2
- package/esm2015/grid-material/src/lib/pipes/column-values.pipe.js +11 -5
- package/esm2015/upload-file/src/lib/upload-file.component.js +24 -3
- package/fesm2015/sd-angular-core-grid-material.js +34 -23
- package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
- package/fesm2015/sd-angular-core-upload-file.js +23 -2
- package/fesm2015/sd-angular-core-upload-file.js.map +1 -1
- package/package.json +1 -1
- package/{sd-angular-core-1.1.94.tgz → sd-angular-core-1.1.97.tgz} +0 -0
- package/upload-file/sd-angular-core-upload-file.metadata.json +1 -1
- package/upload-file/src/lib/upload-file.component.d.ts +1 -1
|
@@ -272,8 +272,29 @@ export class SdUploadFile {
|
|
|
272
272
|
}
|
|
273
273
|
}
|
|
274
274
|
set model(model) {
|
|
275
|
-
if (Array.isArray(model)) {
|
|
276
|
-
|
|
275
|
+
if (Array.isArray(model) && __classPrivateFieldGet(this, _model) !== model) {
|
|
276
|
+
let flag = false;
|
|
277
|
+
__classPrivateFieldSet(this, _model, model.map(src => {
|
|
278
|
+
if (typeof (src) === 'string') {
|
|
279
|
+
let extension = null;
|
|
280
|
+
const lastDot = src.lastIndexOf('.');
|
|
281
|
+
if (lastDot > 0) {
|
|
282
|
+
extension = src.substring(lastDot + 1);
|
|
283
|
+
}
|
|
284
|
+
flag = true;
|
|
285
|
+
return {
|
|
286
|
+
file: null,
|
|
287
|
+
previewSrc: null,
|
|
288
|
+
src,
|
|
289
|
+
isPreviewImage: this.type === 'image',
|
|
290
|
+
extension
|
|
291
|
+
};
|
|
292
|
+
}
|
|
293
|
+
return src;
|
|
294
|
+
}));
|
|
295
|
+
if (flag) {
|
|
296
|
+
this.modelChange.emit(__classPrivateFieldGet(this, _model));
|
|
297
|
+
}
|
|
277
298
|
__classPrivateFieldGet(this, _modelChanges).next(__classPrivateFieldGet(this, _model));
|
|
278
299
|
}
|
|
279
300
|
}
|
|
@@ -394,4 +415,4 @@ SdUploadFile.propDecorators = {
|
|
|
394
415
|
dropElements: [{ type: ViewChildren, args: ['dropElement',] }],
|
|
395
416
|
canvas: [{ type: ViewChild, args: ['canvas',] }]
|
|
396
417
|
};
|
|
397
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-file.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/upload-file/","sources":["src/lib/upload-file.component.ts"],"names":[],"mappings":";;AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EACZ,iBAAiB,EAIjB,YAAY,EAGZ,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAe,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,CAAC,MAAM,QAAQ,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,qFAAqF;AAMrF,MAAM,OAAO,YAAY;IAyCvB,YACE,aAAoC,EAC5B,GAAsB,EACtB,aAA8B,EAC9B,gBAAoC;QAFpC,QAAG,GAAH,GAAG,CAAmB;QACtB,kBAAa,GAAb,aAAa,CAAiB;QAC9B,qBAAgB,GAAhB,gBAAgB,CAAoB;QA5C9C,OAAE,GAAG,IAAI,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC;QACrB,4BAAoB,KAAK,EAAC;QAC1B,mBAAW,IAAI,IAAI,CAAC,EAAE,EAAE,EAAE,EAAC;QAC3B,mBAAW,IAAI,IAAI,CAAC,EAAE,EAAE,EAAE,EAAC;QAC3B,iBAAY,GAAkB,EAAE,CAAC;QAGxB,SAAI,GAAqB,MAAM,CAAC;QAChC,aAAQ,GAAG,KAAK,CAAC;QACjB,eAAU,GAAa,EAAE,CAAC;QAC1B,QAAG,GAAG,CAAC,CAAC;QAKjB,wBAAgB;QAOP,iBAAY,GAAW,OAAO,CAAC;QAC/B,kBAAa,GAAW,OAAO,CAAC;QAChC,UAAK,GAAsB,QAAQ,CAAC;QAC7C,yBAAsB;QAOZ,gBAAW,GAAG,IAAI,YAAY,EAAiB,CAAC;QAChD,aAAQ,GAAG,IAAI,YAAY,EAAiB,CAAC;QAGvD,wBAAgB,IAAI,YAAY,EAAE,EAAC;QACnC,wCAA2B;QAC3B,sBAAc,IAAI,OAAO,EAAE,EAAC;QAC5B,wBAAgB,IAAI,OAAO,EAAE,EAAC;QA+F9B,WAAM,GAAG,CAAC,YAA2B,EAAE,EAAE;YACvC,IAAI,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE;gBAC/B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;gBACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACpC,oCAAoC;aACrC;QACH,CAAC,CAAA;QAED,oBAAY,CAAO,IAAU,EAAmB,EAAE;;YAChD,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE;gBACzB,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,OAAO,EAAE;oBACvC,OAAO,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,+BAA+B,CAAC,EAAE,CAAC;iBAC7F;aACF;YACD,UAAI,IAAI,CAAC,UAAU,0CAAE,MAAM,EAAE;gBAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;gBACnD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,KAAK,SAAS,CAAC,WAAW,EAAE,CAAC,EAAE;oBAC3E,OAAO,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,sCAAsC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;iBAClI;aACF;YACD,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChB,IAAI,IAAI,CAAC,OAAO,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE;oBAC1C,OAAO,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,eAAe,CAAC,IAAI,IAAI,CAAC,OAAO,MAAM,CAAC;iBACjG;aACF;YACD,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,EAAE;gBAC9D,MAAM,OAAO,GAAW,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;oBAClD,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,IAAI,MAAM,CAAC,SAAS,CAAC;oBAC3C,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;oBACxB,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;wBAChB,IAAI,IAAI,CAAC,QAAQ,IAAI,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE;4BAC9C,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,iBAAiB,CAAC,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC;yBACpG;wBACD,IAAI,IAAI,CAAC,SAAS,IAAI,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE;4BACjD,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,kBAAkB,CAAC,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC;yBACtG;wBACD,OAAO,CAAC,IAAI,CAAC,CAAC;oBAChB,CAAC,CAAC;oBACF,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBACtC,CAAC,CAAC,CAAC;gBACH,IAAI,OAAO,EAAE;oBACX,OAAO,OAAO,CAAC;iBAChB;aACF;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAA,EAAA;QAED,mBAAW,GAAG,EAAE;YACd,KAAK,MAAM,WAAW,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE;gBAC/D,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;gBAChC,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,EAAE,EAAE;;oBACtB,WAAW,CAAC,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC;oBAC3C,WAAW,CAAC,cAAc,GAAG,OAAA,WAAW,CAAC,IAAI,0CAAE,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,OAAM,OAAO,CAAC;oBAC9E,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;gBAC3B,CAAC,CAAC;gBACF,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;aACxC;QACH,CAAC,EAAA;QAED,aAAQ,GAAG,CAAC,WAAyB,EAAE,EAAE;YACvC,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;gBAC3B,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;aAC5C;YACD,IAAI,WAAW,IAAI,IAAI,CAAC,GAAG,KAAK,CAAC,EAAE;gBACjC,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,EAAE,wCAAwC,CAAC,CAAC;aACjF;iBAAM;gBACL,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,EAAE,iDAAiD,CAAC,CAAC;aAC1F;YACD,CAAC,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAO,GAAQ,EAAE,EAAE;gBAC/C,MAAM,+CAAA,IAAI,EAAa,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;gBAChD,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;YAC7C,CAAC,CAAA,CAAC,CAAC;YACH,CAAC,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACpC,CAAC,CAAA;QAED,sBAAc,CAAO,MAAoB,EAAE,WAAyB,EAAE,EAAE;YACtE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE;gBACxB,OAAO;aACR;YACD,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC;YACjC,MAAM,KAAK,GAAW,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,EAAE;gBAChB,IAAI,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE;oBAC5D,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,qBAAqB,CAAC,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;oBAC3G,OAAO;iBACR;gBACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAC3C,IAAI,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBAC/B,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE;wBAClD,IAAI,GAAG,MAAM,2CAAA,IAAI,EAAS,IAAI,CAAC,CAAC;qBACjC;oBACD,MAAM,OAAO,GAAG,MAAM,6CAAA,IAAI,EAAW,IAAI,CAAC,CAAC;oBAC3C,IAAI,OAAO,EAAE;wBACX,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;wBAC3C,OAAO;qBACR;oBACD,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBAClB;gBACD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;oBACxB,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;oBAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;oBACnD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;wBACrB,IAAI;wBACJ,cAAc,EAAE,KAAK;wBACrB,UAAU,EAAE,IAAI;wBAChB,GAAG,EAAE,IAAI;wBACT,QAAQ,EAAE,IAAI,CAAC,IAAI;wBACnB,SAAS;qBACV,CAAC,CAAC;iBACJ;aACF;iBAAM;gBACL,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;gBACnD,IAAI,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC/B,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE;oBAClD,IAAI,GAAG,MAAM,2CAAA,IAAI,EAAS,IAAI,CAAC,CAAC;iBACjC;gBACD,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;gBACnD,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG;oBACvB,IAAI;oBACJ,cAAc,EAAE,KAAK;oBACrB,UAAU,EAAE,IAAI;oBAChB,GAAG,EAAE,IAAI;oBACT,QAAQ,EAAE,IAAI,CAAC,IAAI;oBACnB,SAAS;iBACV,CAAC;aACH;YACD,4CAAA,IAAI,CAAW,CAAC;YAChB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACzC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACtC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAA,EAAA;QAED,aAAQ,GAAG,CAAC,WAAwB,EAAE,EAAE;YACtC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;gBAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;gBACnD,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;gBACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACzC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACxC,CAAC,CAAC,CAAC;QACL,CAAC,CAAA;QAED,WAAM,GAAG,CAAC,KAA4B,EAAE,EAAE;YACxC,eAAe,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;YAC5E,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACzC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACxC,CAAC,CAAA;QAED,kBAAU,CAAO,IAAU,EAAiB,EAAE;YAC5C,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;gBACtB,OAAO,IAAI,CAAC;aACb;YACD,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;YAC3C,IAAI,OAAO,KAAK,CAAC,CAAC,EAAE;gBAClB,OAAO,IAAI,CAAC;aACb;YACD,OAAO,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC3C,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,IAAI,MAAM,CAAC,SAAS,CAAC;gBAC3C,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;gBACxB,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;oBAChB,IAAI;wBACF,IAAI,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,EAAE;4BAC/C,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC;yBACtB;wBACD,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;wBACjD,OAAO,CAAC,YAAY,CAAC,IAAI,yCAAgB,CAAC;wBAC1C,MAAM,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;wBACtC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,0CAAA,IAAI,EAAQ,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;wBAChF,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC;wBACtB,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC;wBAExB,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;wBACjD,OAAO,CAAC,YAAY,CAAC,IAAI,yCAAgB,CAAC;wBAC1C,MAAM,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;wBACtC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC;wBACtB,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC;wBACxB,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;wBACzD,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,KAAK,GAAG,GAAG,EAAE,OAAO,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC;wBACzE,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,KAAK,GAAG,GAAG,EAAE,OAAO,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;wBAC9G,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;4BACpB,OAAO,CAAC,+CAAA,IAAI,EAAa,IAAI,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;wBAC5E,CAAC,CAAC,CAAC;qBACJ;oBAAC,OAAO,GAAG,EAAE;wBACZ,MAAM,CAAC,GAAG,CAAC,CAAC;qBACb;4BAAS;wBACR,CAAC,CAAC,IAAI,sCAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;wBAChC,CAAC,CAAC,IAAI,sCAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;qBACjC;gBACH,CAAC,CAAC;gBACF,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YACtC,CAAC,CAAC,CAAC;QACL,CAAC,CAAA,EAAA;QAED,iBAAS,CAAC,KAAa,EAAE,MAAc,EAAE,aAAqB,EAAE,EAAE;YAChE,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,IAAI,CAAC,aAAa,EAAE;gBACvC,OAAO;oBACL,KAAK;oBACL,MAAM;iBACP,CAAC;aACH;YACD,MAAM,KAAK,GAAG,KAAK,GAAG,MAAM,CAAC;YAC7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;gBAC9B,KAAK,IAAI,CAAC,CAAC;gBACX,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC;gBACnC,IAAI,KAAK,GAAG,MAAM,IAAI,aAAa,EAAE;oBACnC,MAAM;iBACP;aACF;YACD,OAAO;gBACL,KAAK;gBACL,MAAM;aACP,CAAC;QACJ,CAAC,EAAA;QAED,aAAQ,GAAG,CAAC,IAAiB,EAAE,EAAE;YAC/B,IAAI,gDAAuB,EAAE;gBAC3B,OAAO;aACR;YACD,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;gBAC9B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;aAC1B;iBAAM;gBACL,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;aAC1B;QACH,CAAC,CAAA;QAED,sBAAc,CAAC,IAAU,EAAE,QAAgB,EAAQ,EAAE;YACnD,MAAM,IAAI,GAAQ,IAAI,CAAC;YACvB,IAAI,CAAC,gBAAgB,GAAG,IAAI,IAAI,EAAE,CAAC;YACnC,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;YACrB,OAAO,IAAY,CAAC;QACtB,CAAC,EAAA;QAhUC,uBAAA,IAAI,qBAAqB,CAAC,aAAa,CAAC,SAAS,EAAE,EAAC;IACtD,CAAC;IA9BD,IAAa,IAAI,CAAC,IAAc;QAC9B,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACvB,uBAAA,IAAI,SAAS,IAAI,EAAC;YAClB,0CAAiB,IAAI,qCAAY,CAAC;SACnC;IACH,CAAC;IAKD,IAAa,KAAK,CAAC,KAAoB;QACrC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACxB,uBAAA,IAAI,UAAU,KAAK,EAAC;YACpB,4CAAmB,IAAI,sCAAa,CAAC;SACtC;IACH,CAAC;IAiBD,QAAQ;IAER,CAAC;IAED,eAAe;QACb,4CAAmB,GAAG,CAAC,0CAAiB,IAAI,CAAC,SAAS,qCAAY,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACjF,IAAI,CAAC,KAAK,CAAC,OAAO,qCAAY,EAAE;gBAC9B,OAAO;aACR;YACD,MAAM,YAAY,GAAG,oCAAW,GAAG,CAAC,GAAG,CAAC,EAAE;gBACxC,IAAI,SAAS,GAAG,IAAI,CAAC;gBACrB,MAAM,OAAO,GAAG,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBACrC,IAAI,OAAO,GAAG,CAAC,EAAE;oBACf,SAAS,GAAG,GAAG,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;iBACxC;gBACD,OAAO;oBACL,IAAI,EAAE,IAAI;oBACV,UAAU,EAAE,IAAI;oBAChB,GAAG;oBACH,cAAc,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO;oBACrC,SAAS;iBACV,CAAA;YACH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;YACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACpC,oCAAoC;QACtC,CAAC,CAAC,CAAC,CAAC;QACJ,4CAAmB,GAAG,CAAC,4CAAmB,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC3E,IAAI,KAAK,CAAC,OAAO,sCAAa,EAAE;gBAC9B,IAAI,CAAC,YAAY,uCAAc,CAAC;aACjC;QACH,CAAC,CAAC,CAAC,CAAC;QACJ,IAAI,gDAAuB,EAAE;YAC3B,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE;gBAChC,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,aAAa,CAAC;gBAC5D,uBAAA,IAAI,yBAAyB,aAAa,EAAC;gBAC3C,aAAa,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,GAAU,EAAE,EAAE;oBACxD,GAAG,CAAC,cAAc,EAAE,CAAC;oBACrB,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;oBAClC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,gBAAgB,CAAC;gBAChD,CAAC,CAAC,CAAC;gBACH,aAAa,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,GAAU,EAAE,EAAE;oBACzD,GAAG,CAAC,cAAc,EAAE,CAAC;gBACvB,CAAC,CAAC,CAAC;gBACH,aAAa,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,GAAU,EAAE,EAAE;oBACzD,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;oBAClC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC;gBACjD,CAAC,CAAC,CAAC;gBACH,aAAa,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAO,GAAc,EAAE,EAAE;oBAC9D,GAAG,CAAC,cAAc,EAAE,CAAC;oBACrB,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;oBAClC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC;oBAC/C,MAAM,+CAAA,IAAI,EAAa,GAAG,CAAC,YAAY,CAAC,CAAC;gBAC3C,CAAC,CAAA,CAAC,CAAC;aACJ;YACD,4CAAmB,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE;gBAC9D,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,IAAI,wDAA+B,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,aAAa,EAAE;oBACxG,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,aAAa,CAAC;oBAC5D,uBAAA,IAAI,yBAAyB,aAAa,EAAC;oBAC3C,aAAa,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,GAAU,EAAE,EAAE;wBACxD,GAAG,CAAC,cAAc,EAAE,CAAC;wBACrB,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;wBAClC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,gBAAgB,CAAC;oBAChD,CAAC,CAAC,CAAC;oBACH,aAAa,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,GAAU,EAAE,EAAE;wBACzD,GAAG,CAAC,cAAc,EAAE,CAAC;oBACvB,CAAC,CAAC,CAAC;oBACH,aAAa,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,GAAU,EAAE,EAAE;wBACzD,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;wBAClC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC;oBACjD,CAAC,CAAC,CAAC;oBACH,aAAa,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAO,GAAc,EAAE,EAAE;wBAC9D,GAAG,CAAC,cAAc,EAAE,CAAC;wBACrB,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;wBAClC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC;wBAC/C,MAAM,+CAAA,IAAI,EAAa,GAAG,CAAC,YAAY,CAAC,CAAC;oBAC3C,CAAC,CAAA,CAAC,CAAC;iBACJ;YACH,CAAC,CAAC,CAAC,CAAC;SACL;IACH,CAAC;IAED,WAAW;QACT,4CAAmB,WAAW,EAAE,CAAC;IACnC,CAAC;;;;YA1IF,SAAS,SAAC;gBACT,QAAQ,EAAE,gBAAgB;gBAC1B,u5HAA2C;;aAE5C;;;YAbQ,qBAAqB;YAV5B,iBAAiB;YAaV,eAAe;YACf,kBAAkB;;;oBAiBxB,KAAK;mBACL,KAAK;uBACL,KAAK;yBACL,KAAK;kBACL,KAAK;sBACL,KAAK;uBACL,KAAK;wBACL,KAAK;2BACL,KAAK;mBAEL,KAAK;2BAML,KAAK;4BACL,KAAK;oBACL,KAAK;oBAEL,KAAK;0BAML,MAAM;uBACN,MAAM;2BACN,YAAY,SAAC,aAAa;qBAC1B,SAAS,SAAC,QAAQ","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  AfterViewInit,\r\n  ElementRef,\r\n  OnInit,\r\n  ViewChildren,\r\n  QueryList,\r\n  OnDestroy,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\nimport * as uuid from 'uuid';\r\nimport $ from 'jquery';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { Subscription, Subject } from 'rxjs';\r\nimport { startWith } from 'rxjs/operators';\r\n\r\n// https://stackoverflow.com/questions/4459379/preview-an-image-before-it-is-uploaded\r\n@Component({\r\n  selector: 'sd-upload-file',\r\n  templateUrl: './upload-file.component.html',\r\n  styleUrls: ['./upload-file.component.scss']\r\n})\r\nexport class SdUploadFile implements OnInit, AfterViewInit, OnDestroy {\r\n  id = `I${uuid.v4()}`;\r\n  #isMobileOrTablet = false;\r\n  #canvas1 = `C${uuid.v4()}`;\r\n  #canvas2 = `C${uuid.v4()}`;\r\n  previewFiles: PreviewFile[] = [];\r\n  selectedFile: PreviewFile;\r\n  @Input() label: string;\r\n  @Input() type: 'image' | 'file' = 'file';\r\n  @Input() disabled = false;\r\n  @Input() extensions: string[] = [];\r\n  @Input() max = 1;\r\n  @Input() maxSize: number;\r\n  @Input() maxWidth: number;\r\n  @Input() maxHeight: number;\r\n  @Input() scaleToPixel: number;\r\n  #srcs: string[];\r\n  @Input() set srcs(srcs: string[]) {\r\n    if (Array.isArray(srcs)) {\r\n      this.#srcs = srcs;\r\n      this.#srcChanges.next(this.#srcs);\r\n    }\r\n  }\r\n  @Input() previewWidth: string = '100px';\r\n  @Input() previewHeight: string = '100px';\r\n  @Input() align: 'left' | 'center' = 'center';\r\n  #model: PreviewFile[];\r\n  @Input() set model(model: PreviewFile[]) {\r\n    if (Array.isArray(model)) {\r\n      this.#model = model;\r\n      this.#modelChanges.next(this.#model);\r\n    }\r\n  }\r\n  @Output() modelChange = new EventEmitter<PreviewFile[]>();\r\n  @Output() sdChange = new EventEmitter<PreviewFile[]>();\r\n  @ViewChildren('dropElement') dropElements: QueryList<ElementRef>;\r\n  @ViewChild('canvas') canvas: ElementRef;\r\n  #subscription = new Subscription();\r\n  #currentDropContainer: any;\r\n  #srcChanges = new Subject();\r\n  #modelChanges = new Subject();\r\n  constructor(\r\n    deviceService: DeviceDetectorService,\r\n    private ref: ChangeDetectorRef,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService) {\r\n    this.#isMobileOrTablet = !deviceService.isDesktop();\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.#srcChanges.pipe(startWith(this.#srcs)).subscribe(() => {\r\n      if (!Array.isArray(this.#srcs)) {\r\n        return;\r\n      }\r\n      const previewFiles = this.#srcs.map(src => {\r\n        let extension = null;\r\n        const lastDot = src.lastIndexOf('.');\r\n        if (lastDot > 0) {\r\n          extension = src.substring(lastDot + 1);\r\n        }\r\n        return {\r\n          file: null,\r\n          previewSrc: null,\r\n          src,\r\n          isPreviewImage: this.type === 'image',\r\n          extension\r\n        }\r\n      });\r\n      this.previewFiles = previewFiles;\r\n      this.modelChange.emit(previewFiles);\r\n      // this.sdChange.emit(previewFiles);\r\n    }));\r\n    this.#subscription.add(this.#modelChanges.pipe(startWith([])).subscribe(() => {\r\n      if (Array.isArray(this.#model)) {\r\n        this.previewFiles = this.#model;\r\n      }\r\n    }));\r\n    if (!this.#isMobileOrTablet) {\r\n      if (this.dropElements.length > 0) {\r\n        const dropContainer = this.dropElements.first.nativeElement;\r\n        this.#currentDropContainer = dropContainer;\r\n        dropContainer.addEventListener('dragover', (evt: Event) => {\r\n          evt.preventDefault();\r\n          dropContainer.style.opacity = 0.9;\r\n          dropContainer.style.border = '2px solid grey';\r\n        });\r\n        dropContainer.addEventListener('dragenter', (evt: Event) => {\r\n          evt.preventDefault();\r\n        });\r\n        dropContainer.addEventListener('dragleave', (evt: Event) => {\r\n          dropContainer.style.opacity = 0.6;\r\n          dropContainer.style.border = '2px dashed grey';\r\n        });\r\n        dropContainer.addEventListener('drop', async (evt: DragEvent) => {\r\n          evt.preventDefault();\r\n          dropContainer.style.opacity = 0.6;\r\n          dropContainer.style.border = '2px dashed grey';\r\n          await this.#uploadFile(evt.dataTransfer);\r\n        });\r\n      }\r\n      this.#subscription.add(this.dropElements.changes.subscribe(() => {\r\n        if (this.dropElements.length > 0 && this.#currentDropContainer !== this.dropElements.first.nativeElement) {\r\n          const dropContainer = this.dropElements.first.nativeElement;\r\n          this.#currentDropContainer = dropContainer;\r\n          dropContainer.addEventListener('dragover', (evt: Event) => {\r\n            evt.preventDefault();\r\n            dropContainer.style.opacity = 0.9;\r\n            dropContainer.style.border = '2px solid grey';\r\n          });\r\n          dropContainer.addEventListener('dragenter', (evt: Event) => {\r\n            evt.preventDefault();\r\n          });\r\n          dropContainer.addEventListener('dragleave', (evt: Event) => {\r\n            dropContainer.style.opacity = 0.6;\r\n            dropContainer.style.border = '2px dashed grey';\r\n          });\r\n          dropContainer.addEventListener('drop', async (evt: DragEvent) => {\r\n            evt.preventDefault();\r\n            dropContainer.style.opacity = 0.6;\r\n            dropContainer.style.border = '2px dashed grey';\r\n            await this.#uploadFile(evt.dataTransfer);\r\n          });\r\n        }\r\n      }));\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  reload = (previewFiles: PreviewFile[]) => {\r\n    if (Array.isArray(previewFiles)) {\r\n      this.previewFiles = previewFiles;\r\n      this.modelChange.emit(previewFiles);\r\n      // this.sdChange.emit(previewFiles);\r\n    }\r\n  }\r\n\r\n  #validate = async (file: File): Promise<string> => {\r\n    if (this.type === 'image') {\r\n      if (file.type.split('/')[0] !== 'image') {\r\n        return `[${file.name}] ${this.translateService.translate('Uploaded file is not an image')}`;\r\n      }\r\n    }\r\n    if (this.extensions?.length) {\r\n      const lastDot = file.name.lastIndexOf('.');\r\n      const extension = file.name.substring(lastDot + 1);\r\n      if (!this.extensions.some(e => e.toUpperCase() === extension.toUpperCase())) {\r\n        return `[${file.name}] ${this.translateService.translate('Uploaded file is not match extension')} ${this.extensions.join(', ')}`;\r\n      }\r\n    }\r\n    if (this.maxSize) {\r\n      if (this.maxSize * 1024 * 1024 < file.size) {\r\n        return `[${file.name}] ${this.translateService.translate('Max file size')} ${this.maxSize} Mbs`;\r\n      }\r\n    }\r\n    if (this.type === 'image' && (this.maxWidth || this.maxHeight)) {\r\n      const message: string = await new Promise(resolve => {\r\n        const URL = window.URL || window.webkitURL;\r\n        const img = new Image();\r\n        img.onload = () => {\r\n          if (this.maxWidth && img.width > this.maxWidth) {\r\n            resolve(`[${file.name}] ${this.translateService.translate('Max image width')} ${this.maxWidth}px`);\r\n          }\r\n          if (this.maxHeight && img.height > this.maxHeight) {\r\n            resolve(`[${file.name}] ${this.translateService.translate('Max image height')} ${this.maxHeight}px`);\r\n          }\r\n          resolve(null);\r\n        };\r\n        img.src = URL.createObjectURL(file);\r\n      });\r\n      if (message) {\r\n        return message;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  #preview = () => {\r\n    for (const previewFile of this.previewFiles.filter(e => e.file)) {\r\n      const reader = new FileReader();\r\n      reader.onload = (evt) => {\r\n        previewFile.previewSrc = evt.target.result;\r\n        previewFile.isPreviewImage = previewFile.file?.type.split('/')[0] === 'image';\r\n        this.ref.detectChanges();\r\n      };\r\n      reader.readAsDataURL(previewFile.file);\r\n    }\r\n  }\r\n\r\n  onUpload = (previewFile?: PreviewFile) => {\r\n    if ($(`#${this.id}`).length) {\r\n      $('body').children(`#${this.id}`).remove();\r\n    }\r\n    if (previewFile || this.max === 1) {\r\n      $('body').append(`<input id=\"${this.id}\" style=\"display: none\" type=\"file\" />`);\r\n    } else {\r\n      $('body').append(`<input id=\"${this.id}\" style=\"display: none\" type=\"file\" multiple />`);\r\n    }\r\n    $(`#${this.id}`).on('change', async (evt: any) => {\r\n      await this.#uploadFile(evt.target, previewFile);\r\n      $('body').children(`#${this.id}`).remove();\r\n    });\r\n    $(`#${this.id}`).trigger('click');\r\n  }\r\n\r\n  #uploadFile = async (target: DataTransfer, previewFile?: PreviewFile) => {\r\n    if (!target.files.length) {\r\n      return;\r\n    }\r\n    const originFiles = target.files;\r\n    const files: File[] = [];\r\n    if (!previewFile) {\r\n      if (originFiles.length + this.previewFiles.length > this.max) {\r\n        this.notifyService.notify.warning(`${this.translateService.translate('Max number of files')} ${this.max}`);\r\n        return;\r\n      }\r\n      for (let i = 0; i < originFiles.length; i++) {\r\n        let file = originFiles.item(i);\r\n        if (this.type === 'image' && this.scaleToPixel > 0) {\r\n          file = await this.#resize(file);\r\n        }\r\n        const message = await this.#validate(file);\r\n        if (message) {\r\n          this.notifyService.notify.warning(message);\r\n          return;\r\n        }\r\n        files.push(file);\r\n      }\r\n      for (const file of files) {\r\n        const lastDot = file.name.lastIndexOf('.');\r\n        const extension = file.name.substring(lastDot + 1);\r\n        this.previewFiles.push({\r\n          file,\r\n          isPreviewImage: false,\r\n          previewSrc: null,\r\n          src: null,\r\n          fileName: file.name,\r\n          extension\r\n        });\r\n      }\r\n    } else {\r\n      const idx = this.previewFiles.indexOf(previewFile);\r\n      let file = originFiles.item(0);\r\n      if (this.type === 'image' && this.scaleToPixel > 0) {\r\n        file = await this.#resize(file);\r\n      }\r\n      const lastDot = file.name.lastIndexOf('.');\r\n      const extension = file.name.substring(lastDot + 1);\r\n      this.previewFiles[idx] = {\r\n        file,\r\n        isPreviewImage: false,\r\n        previewSrc: null,\r\n        src: null,\r\n        fileName: file.name,\r\n        extension\r\n      };\r\n    }\r\n    this.#preview();\r\n    this.modelChange.emit(this.previewFiles);\r\n    this.sdChange.emit(this.previewFiles);\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onRemove = (previewFile: PreviewFile) => {\r\n    this.notifyService.confirmDelete().then(() => {\r\n      const idx = this.previewFiles.indexOf(previewFile);\r\n      this.previewFiles.splice(idx, 1);\r\n      this.modelChange.emit(this.previewFiles);\r\n      this.sdChange.emit(this.previewFiles);\r\n    });\r\n  }\r\n\r\n  onDrop = (event: CdkDragDrop<string[]>) => {\r\n    moveItemInArray(this.previewFiles, event.previousIndex, event.currentIndex);\r\n    this.modelChange.emit(this.previewFiles);\r\n    this.sdChange.emit(this.previewFiles);\r\n  }\r\n\r\n  #resize = async (file: File): Promise<File> => {\r\n    if (!this.scaleToPixel) {\r\n      return file;\r\n    }\r\n    const lastDot = file.name.lastIndexOf('.');\r\n    if (lastDot === -1) {\r\n      return file;\r\n    }\r\n    return await new Promise((resolve, reject) => {\r\n      const URL = window.URL || window.webkitURL;\r\n      const img = new Image();\r\n      img.onload = () => {\r\n        try {\r\n          if (img.width * img.height <= this.scaleToPixel) {\r\n            return resolve(file);\r\n          }\r\n          const canvas1 = document.createElement('canvas');\r\n          canvas1.setAttribute('id', this.#canvas1);\r\n          const ctx1 = canvas1.getContext('2d');\r\n          const { width, height } = this.#scale(img.width, img.height, this.scaleToPixel);\r\n          canvas1.width = width;\r\n          canvas1.height = height;\r\n\r\n          const canvas2 = document.createElement('canvas');\r\n          canvas2.setAttribute('id', this.#canvas2);\r\n          const ctx2 = canvas2.getContext('2d');\r\n          canvas2.width = width;\r\n          canvas2.height = height;\r\n          ctx2.drawImage(img, 0, 0, canvas2.width, canvas2.height);\r\n          ctx2.drawImage(canvas2, 0, 0, canvas2.width * 0.5, canvas2.height * 0.5);\r\n          ctx1.drawImage(canvas2, 0, 0, canvas2.width * 0.5, canvas2.height * 0.5, 0, 0, canvas1.width, canvas1.height);\r\n          canvas1.toBlob(blob => {\r\n            resolve(this.#blobToFile(blob, `${file.name.substring(0, lastDot)}.png`));\r\n          });\r\n        } catch (err) {\r\n          reject(err);\r\n        } finally {\r\n          $(`#${this.#canvas1}`).remove();\r\n          $(`#${this.#canvas2}`).remove();\r\n        }\r\n      };\r\n      img.src = URL.createObjectURL(file);\r\n    });\r\n  }\r\n\r\n  #scale = (width: number, height: number, scaleToPixcel: number) => {\r\n    if (!width || !height || !scaleToPixcel) {\r\n      return {\r\n        width,\r\n        height\r\n      };\r\n    }\r\n    const ratio = width / height;\r\n    for (let i = 0; i < width; i++) {\r\n      width -= i;\r\n      height = Math.trunc(width / ratio);\r\n      if (width * height <= scaleToPixcel) {\r\n        break;\r\n      }\r\n    }\r\n    return {\r\n      width,\r\n      height\r\n    };\r\n  }\r\n\r\n  onSelect = (file: PreviewFile) => {\r\n    if (!this.#isMobileOrTablet) {\r\n      return;\r\n    }\r\n    if (this.selectedFile !== file) {\r\n      this.selectedFile = file;\r\n    } else {\r\n      this.selectedFile = null;\r\n    }\r\n  }\r\n\r\n  #blobToFile = (blob: Blob, fileName: string): File => {\r\n    const temp: any = blob;\r\n    temp.lastModifiedDate = new Date();\r\n    temp.name = fileName;\r\n    return blob as File;\r\n  }\r\n}\r\n\r\nexport interface PreviewFile {\r\n  file: File;\r\n  src: string;\r\n  previewSrc: string | ArrayBuffer;\r\n  isPreviewImage: boolean;\r\n  fileName?: string;\r\n  extension?: string;\r\n}\r\n"]}
|
|
418
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-file.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/upload-file/","sources":["src/lib/upload-file.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  AfterViewInit,\r\n  ElementRef,\r\n  OnInit,\r\n  ViewChildren,\r\n  QueryList,\r\n  OnDestroy,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\nimport * as uuid from 'uuid';\r\nimport $ from 'jquery';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { Subscription, Subject } from 'rxjs';\r\nimport { startWith } from 'rxjs/operators';\r\n\r\n// https://stackoverflow.com/questions/4459379/preview-an-image-before-it-is-uploaded\r\n@Component({\r\n  selector: 'sd-upload-file',\r\n  templateUrl: './upload-file.component.html',\r\n  styleUrls: ['./upload-file.component.scss']\r\n})\r\nexport class SdUploadFile implements OnInit, AfterViewInit, OnDestroy {\r\n  id = `I${uuid.v4()}`;\r\n  #isMobileOrTablet = false;\r\n  #canvas1 = `C${uuid.v4()}`;\r\n  #canvas2 = `C${uuid.v4()}`;\r\n  previewFiles: PreviewFile[] = [];\r\n  selectedFile: PreviewFile;\r\n  @Input() label: string;\r\n  @Input() type: 'image' | 'file' = 'file';\r\n  @Input() disabled = false;\r\n  @Input() extensions: string[] = [];\r\n  @Input() max = 1;\r\n  @Input() maxSize: number;\r\n  @Input() maxWidth: number;\r\n  @Input() maxHeight: number;\r\n  @Input() scaleToPixel: number;\r\n  #srcs: string[];\r\n  @Input() set srcs(srcs: string[]) {\r\n    if (Array.isArray(srcs)) {\r\n      this.#srcs = srcs;\r\n      this.#srcChanges.next(this.#srcs);\r\n    }\r\n  }\r\n  @Input() previewWidth: string = '100px';\r\n  @Input() previewHeight: string = '100px';\r\n  @Input() align: 'left' | 'center' = 'center';\r\n  #model: PreviewFile[];\r\n  @Input() set model(model: (string | PreviewFile)[]) {\r\n    if (Array.isArray(model) && this.#model !== model) {\r\n      let flag = false;\r\n      this.#model = model.map(src => {\r\n        if (typeof (src) === 'string') {\r\n          let extension = null;\r\n          const lastDot = src.lastIndexOf('.');\r\n          if (lastDot > 0) {\r\n            extension = src.substring(lastDot + 1);\r\n          }\r\n          flag = true;\r\n          return {\r\n            file: null,\r\n            previewSrc: null,\r\n            src,\r\n            isPreviewImage: this.type === 'image',\r\n            extension\r\n          }\r\n        }\r\n        return src;\r\n      });\r\n      if (flag) {\r\n        this.modelChange.emit(this.#model);\r\n      }\r\n      this.#modelChanges.next(this.#model);\r\n    }\r\n  }\r\n  @Output() modelChange = new EventEmitter<PreviewFile[]>();\r\n  @Output() sdChange = new EventEmitter<PreviewFile[]>();\r\n  @ViewChildren('dropElement') dropElements: QueryList<ElementRef>;\r\n  @ViewChild('canvas') canvas: ElementRef;\r\n  #subscription = new Subscription();\r\n  #currentDropContainer: any;\r\n  #srcChanges = new Subject();\r\n  #modelChanges = new Subject();\r\n  constructor(\r\n    deviceService: DeviceDetectorService,\r\n    private ref: ChangeDetectorRef,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService) {\r\n    this.#isMobileOrTablet = !deviceService.isDesktop();\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.#srcChanges.pipe(startWith(this.#srcs)).subscribe(() => {\r\n      if (!Array.isArray(this.#srcs)) {\r\n        return;\r\n      }\r\n      const previewFiles = this.#srcs.map(src => {\r\n        let extension = null;\r\n        const lastDot = src.lastIndexOf('.');\r\n        if (lastDot > 0) {\r\n          extension = src.substring(lastDot + 1);\r\n        }\r\n        return {\r\n          file: null,\r\n          previewSrc: null,\r\n          src,\r\n          isPreviewImage: this.type === 'image',\r\n          extension\r\n        }\r\n      });\r\n      this.previewFiles = previewFiles;\r\n      this.modelChange.emit(previewFiles);\r\n      // this.sdChange.emit(previewFiles);\r\n    }));\r\n    this.#subscription.add(this.#modelChanges.pipe(startWith([])).subscribe(() => {\r\n      if (Array.isArray(this.#model)) {\r\n        this.previewFiles = this.#model;\r\n      }\r\n    }));\r\n    if (!this.#isMobileOrTablet) {\r\n      if (this.dropElements.length > 0) {\r\n        const dropContainer = this.dropElements.first.nativeElement;\r\n        this.#currentDropContainer = dropContainer;\r\n        dropContainer.addEventListener('dragover', (evt: Event) => {\r\n          evt.preventDefault();\r\n          dropContainer.style.opacity = 0.9;\r\n          dropContainer.style.border = '2px solid grey';\r\n        });\r\n        dropContainer.addEventListener('dragenter', (evt: Event) => {\r\n          evt.preventDefault();\r\n        });\r\n        dropContainer.addEventListener('dragleave', (evt: Event) => {\r\n          dropContainer.style.opacity = 0.6;\r\n          dropContainer.style.border = '2px dashed grey';\r\n        });\r\n        dropContainer.addEventListener('drop', async (evt: DragEvent) => {\r\n          evt.preventDefault();\r\n          dropContainer.style.opacity = 0.6;\r\n          dropContainer.style.border = '2px dashed grey';\r\n          await this.#uploadFile(evt.dataTransfer);\r\n        });\r\n      }\r\n      this.#subscription.add(this.dropElements.changes.subscribe(() => {\r\n        if (this.dropElements.length > 0 && this.#currentDropContainer !== this.dropElements.first.nativeElement) {\r\n          const dropContainer = this.dropElements.first.nativeElement;\r\n          this.#currentDropContainer = dropContainer;\r\n          dropContainer.addEventListener('dragover', (evt: Event) => {\r\n            evt.preventDefault();\r\n            dropContainer.style.opacity = 0.9;\r\n            dropContainer.style.border = '2px solid grey';\r\n          });\r\n          dropContainer.addEventListener('dragenter', (evt: Event) => {\r\n            evt.preventDefault();\r\n          });\r\n          dropContainer.addEventListener('dragleave', (evt: Event) => {\r\n            dropContainer.style.opacity = 0.6;\r\n            dropContainer.style.border = '2px dashed grey';\r\n          });\r\n          dropContainer.addEventListener('drop', async (evt: DragEvent) => {\r\n            evt.preventDefault();\r\n            dropContainer.style.opacity = 0.6;\r\n            dropContainer.style.border = '2px dashed grey';\r\n            await this.#uploadFile(evt.dataTransfer);\r\n          });\r\n        }\r\n      }));\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  reload = (previewFiles: PreviewFile[]) => {\r\n    if (Array.isArray(previewFiles)) {\r\n      this.previewFiles = previewFiles;\r\n      this.modelChange.emit(previewFiles);\r\n      // this.sdChange.emit(previewFiles);\r\n    }\r\n  }\r\n\r\n  #validate = async (file: File): Promise<string> => {\r\n    if (this.type === 'image') {\r\n      if (file.type.split('/')[0] !== 'image') {\r\n        return `[${file.name}] ${this.translateService.translate('Uploaded file is not an image')}`;\r\n      }\r\n    }\r\n    if (this.extensions?.length) {\r\n      const lastDot = file.name.lastIndexOf('.');\r\n      const extension = file.name.substring(lastDot + 1);\r\n      if (!this.extensions.some(e => e.toUpperCase() === extension.toUpperCase())) {\r\n        return `[${file.name}] ${this.translateService.translate('Uploaded file is not match extension')} ${this.extensions.join(', ')}`;\r\n      }\r\n    }\r\n    if (this.maxSize) {\r\n      if (this.maxSize * 1024 * 1024 < file.size) {\r\n        return `[${file.name}] ${this.translateService.translate('Max file size')} ${this.maxSize} Mbs`;\r\n      }\r\n    }\r\n    if (this.type === 'image' && (this.maxWidth || this.maxHeight)) {\r\n      const message: string = await new Promise(resolve => {\r\n        const URL = window.URL || window.webkitURL;\r\n        const img = new Image();\r\n        img.onload = () => {\r\n          if (this.maxWidth && img.width > this.maxWidth) {\r\n            resolve(`[${file.name}] ${this.translateService.translate('Max image width')} ${this.maxWidth}px`);\r\n          }\r\n          if (this.maxHeight && img.height > this.maxHeight) {\r\n            resolve(`[${file.name}] ${this.translateService.translate('Max image height')} ${this.maxHeight}px`);\r\n          }\r\n          resolve(null);\r\n        };\r\n        img.src = URL.createObjectURL(file);\r\n      });\r\n      if (message) {\r\n        return message;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  #preview = () => {\r\n    for (const previewFile of this.previewFiles.filter(e => e.file)) {\r\n      const reader = new FileReader();\r\n      reader.onload = (evt) => {\r\n        previewFile.previewSrc = evt.target.result;\r\n        previewFile.isPreviewImage = previewFile.file?.type.split('/')[0] === 'image';\r\n        this.ref.detectChanges();\r\n      };\r\n      reader.readAsDataURL(previewFile.file);\r\n    }\r\n  }\r\n\r\n  onUpload = (previewFile?: PreviewFile) => {\r\n    if ($(`#${this.id}`).length) {\r\n      $('body').children(`#${this.id}`).remove();\r\n    }\r\n    if (previewFile || this.max === 1) {\r\n      $('body').append(`<input id=\"${this.id}\" style=\"display: none\" type=\"file\" />`);\r\n    } else {\r\n      $('body').append(`<input id=\"${this.id}\" style=\"display: none\" type=\"file\" multiple />`);\r\n    }\r\n    $(`#${this.id}`).on('change', async (evt: any) => {\r\n      await this.#uploadFile(evt.target, previewFile);\r\n      $('body').children(`#${this.id}`).remove();\r\n    });\r\n    $(`#${this.id}`).trigger('click');\r\n  }\r\n\r\n  #uploadFile = async (target: DataTransfer, previewFile?: PreviewFile) => {\r\n    if (!target.files.length) {\r\n      return;\r\n    }\r\n    const originFiles = target.files;\r\n    const files: File[] = [];\r\n    if (!previewFile) {\r\n      if (originFiles.length + this.previewFiles.length > this.max) {\r\n        this.notifyService.notify.warning(`${this.translateService.translate('Max number of files')} ${this.max}`);\r\n        return;\r\n      }\r\n      for (let i = 0; i < originFiles.length; i++) {\r\n        let file = originFiles.item(i);\r\n        if (this.type === 'image' && this.scaleToPixel > 0) {\r\n          file = await this.#resize(file);\r\n        }\r\n        const message = await this.#validate(file);\r\n        if (message) {\r\n          this.notifyService.notify.warning(message);\r\n          return;\r\n        }\r\n        files.push(file);\r\n      }\r\n      for (const file of files) {\r\n        const lastDot = file.name.lastIndexOf('.');\r\n        const extension = file.name.substring(lastDot + 1);\r\n        this.previewFiles.push({\r\n          file,\r\n          isPreviewImage: false,\r\n          previewSrc: null,\r\n          src: null,\r\n          fileName: file.name,\r\n          extension\r\n        });\r\n      }\r\n    } else {\r\n      const idx = this.previewFiles.indexOf(previewFile);\r\n      let file = originFiles.item(0);\r\n      if (this.type === 'image' && this.scaleToPixel > 0) {\r\n        file = await this.#resize(file);\r\n      }\r\n      const lastDot = file.name.lastIndexOf('.');\r\n      const extension = file.name.substring(lastDot + 1);\r\n      this.previewFiles[idx] = {\r\n        file,\r\n        isPreviewImage: false,\r\n        previewSrc: null,\r\n        src: null,\r\n        fileName: file.name,\r\n        extension\r\n      };\r\n    }\r\n    this.#preview();\r\n    this.modelChange.emit(this.previewFiles);\r\n    this.sdChange.emit(this.previewFiles);\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onRemove = (previewFile: PreviewFile) => {\r\n    this.notifyService.confirmDelete().then(() => {\r\n      const idx = this.previewFiles.indexOf(previewFile);\r\n      this.previewFiles.splice(idx, 1);\r\n      this.modelChange.emit(this.previewFiles);\r\n      this.sdChange.emit(this.previewFiles);\r\n    });\r\n  }\r\n\r\n  onDrop = (event: CdkDragDrop<string[]>) => {\r\n    moveItemInArray(this.previewFiles, event.previousIndex, event.currentIndex);\r\n    this.modelChange.emit(this.previewFiles);\r\n    this.sdChange.emit(this.previewFiles);\r\n  }\r\n\r\n  #resize = async (file: File): Promise<File> => {\r\n    if (!this.scaleToPixel) {\r\n      return file;\r\n    }\r\n    const lastDot = file.name.lastIndexOf('.');\r\n    if (lastDot === -1) {\r\n      return file;\r\n    }\r\n    return await new Promise((resolve, reject) => {\r\n      const URL = window.URL || window.webkitURL;\r\n      const img = new Image();\r\n      img.onload = () => {\r\n        try {\r\n          if (img.width * img.height <= this.scaleToPixel) {\r\n            return resolve(file);\r\n          }\r\n          const canvas1 = document.createElement('canvas');\r\n          canvas1.setAttribute('id', this.#canvas1);\r\n          const ctx1 = canvas1.getContext('2d');\r\n          const { width, height } = this.#scale(img.width, img.height, this.scaleToPixel);\r\n          canvas1.width = width;\r\n          canvas1.height = height;\r\n\r\n          const canvas2 = document.createElement('canvas');\r\n          canvas2.setAttribute('id', this.#canvas2);\r\n          const ctx2 = canvas2.getContext('2d');\r\n          canvas2.width = width;\r\n          canvas2.height = height;\r\n          ctx2.drawImage(img, 0, 0, canvas2.width, canvas2.height);\r\n          ctx2.drawImage(canvas2, 0, 0, canvas2.width * 0.5, canvas2.height * 0.5);\r\n          ctx1.drawImage(canvas2, 0, 0, canvas2.width * 0.5, canvas2.height * 0.5, 0, 0, canvas1.width, canvas1.height);\r\n          canvas1.toBlob(blob => {\r\n            resolve(this.#blobToFile(blob, `${file.name.substring(0, lastDot)}.png`));\r\n          });\r\n        } catch (err) {\r\n          reject(err);\r\n        } finally {\r\n          $(`#${this.#canvas1}`).remove();\r\n          $(`#${this.#canvas2}`).remove();\r\n        }\r\n      };\r\n      img.src = URL.createObjectURL(file);\r\n    });\r\n  }\r\n\r\n  #scale = (width: number, height: number, scaleToPixcel: number) => {\r\n    if (!width || !height || !scaleToPixcel) {\r\n      return {\r\n        width,\r\n        height\r\n      };\r\n    }\r\n    const ratio = width / height;\r\n    for (let i = 0; i < width; i++) {\r\n      width -= i;\r\n      height = Math.trunc(width / ratio);\r\n      if (width * height <= scaleToPixcel) {\r\n        break;\r\n      }\r\n    }\r\n    return {\r\n      width,\r\n      height\r\n    };\r\n  }\r\n\r\n  onSelect = (file: PreviewFile) => {\r\n    if (!this.#isMobileOrTablet) {\r\n      return;\r\n    }\r\n    if (this.selectedFile !== file) {\r\n      this.selectedFile = file;\r\n    } else {\r\n      this.selectedFile = null;\r\n    }\r\n  }\r\n\r\n  #blobToFile = (blob: Blob, fileName: string): File => {\r\n    const temp: any = blob;\r\n    temp.lastModifiedDate = new Date();\r\n    temp.name = fileName;\r\n    return blob as File;\r\n  }\r\n}\r\n\r\nexport interface PreviewFile {\r\n  file: File;\r\n  src: string;\r\n  previewSrc: string | ArrayBuffer;\r\n  isPreviewImage: boolean;\r\n  fileName?: string;\r\n  extension?: string;\r\n}\r\n"]}
|
|
@@ -10,8 +10,7 @@ import { Subject, Subscription, isObservable } from 'rxjs';
|
|
|
10
10
|
import { SdNotifyService } from '@sd-angular/core/notify';
|
|
11
11
|
import { moveItemInArray, DragDropModule } from '@angular/cdk/drag-drop';
|
|
12
12
|
import { startWith, debounceTime, map, switchMap } from 'rxjs/operators';
|
|
13
|
-
import
|
|
14
|
-
import hash__default from 'object-hash';
|
|
13
|
+
import hash from 'object-hash';
|
|
15
14
|
import { SdSettingService } from '@sd-angular/core/setting';
|
|
16
15
|
import { DeviceDetectorService } from 'ngx-device-detector';
|
|
17
16
|
import { SdLoadingService } from '@sd-angular/core/loading';
|
|
@@ -237,7 +236,7 @@ class SdGridFilterService {
|
|
|
237
236
|
prefix: __classPrivateFieldGet(this, _prefix),
|
|
238
237
|
key
|
|
239
238
|
});
|
|
240
|
-
key =
|
|
239
|
+
key = hash({
|
|
241
240
|
prefix: __classPrivateFieldGet(this, _prefix),
|
|
242
241
|
key
|
|
243
242
|
});
|
|
@@ -694,7 +693,7 @@ class SdPopupExport {
|
|
|
694
693
|
if (!((_b = (_a = this.gridOption) === null || _a === void 0 ? void 0 : _a.export) === null || _b === void 0 ? void 0 : _b.key)) {
|
|
695
694
|
return null;
|
|
696
695
|
}
|
|
697
|
-
return
|
|
696
|
+
return hash({
|
|
698
697
|
prefix,
|
|
699
698
|
key: (_d = (_c = this.gridOption) === null || _c === void 0 ? void 0 : _c.export) === null || _d === void 0 ? void 0 : _d.key
|
|
700
699
|
});
|
|
@@ -766,7 +765,7 @@ class SdGridConfigurationService {
|
|
|
766
765
|
if (!((_a = gridOption === null || gridOption === void 0 ? void 0 : gridOption.config) === null || _a === void 0 ? void 0 : _a.key) && !(gridOption === null || gridOption === void 0 ? void 0 : gridOption.key)) {
|
|
767
766
|
return null;
|
|
768
767
|
}
|
|
769
|
-
return
|
|
768
|
+
return hash({
|
|
770
769
|
prefix,
|
|
771
770
|
key: ((_b = gridOption === null || gridOption === void 0 ? void 0 : gridOption.config) === null || _b === void 0 ? void 0 : _b.key) || !(gridOption === null || gridOption === void 0 ? void 0 : gridOption.key)
|
|
772
771
|
});
|
|
@@ -1119,8 +1118,14 @@ class SdColumnValuesPipe {
|
|
|
1119
1118
|
if (column.type !== 'values' || !((_a = column.option) === null || _a === void 0 ? void 0 : _a.items) || !((_b = column.option) === null || _b === void 0 ? void 0 : _b.valueField) || !((_c = column.option) === null || _c === void 0 ? void 0 : _c.displayField)) {
|
|
1120
1119
|
return value;
|
|
1121
1120
|
}
|
|
1122
|
-
const { items, valueField, displayField } =
|
|
1123
|
-
|
|
1121
|
+
const _f = column.option, { items, valueField, displayField } = _f, remain = __rest(_f, ["items", "valueField", "displayField"]);
|
|
1122
|
+
const key = hash({
|
|
1123
|
+
prefix: __classPrivateFieldGet(this, _prefix$1),
|
|
1124
|
+
valueField,
|
|
1125
|
+
displayField,
|
|
1126
|
+
remain,
|
|
1127
|
+
value
|
|
1128
|
+
});
|
|
1124
1129
|
if (typeof (items) === 'function') {
|
|
1125
1130
|
if (!__classPrivateFieldGet(this, _cache$1)[key]) {
|
|
1126
1131
|
const values = yield items(value, true);
|
|
@@ -1166,7 +1171,7 @@ class SdEditorHandlerColumnPipe {
|
|
|
1166
1171
|
}
|
|
1167
1172
|
transform(value, item, gridOption) {
|
|
1168
1173
|
const { sdId, editorHandlerColumn, expandDetail, isExpanded, isExpanding, isSelected, sdGroup, selectable, actions, groupedActions, originItem, editorErrorMessage, editorHandlerRow } = item, remain = __rest(item, ["sdId", "editorHandlerColumn", "expandDetail", "isExpanded", "isExpanding", "isSelected", "sdGroup", "selectable", "actions", "groupedActions", "originItem", "editorErrorMessage", "editorHandlerRow"]);
|
|
1169
|
-
const key =
|
|
1174
|
+
const key = hash(remain);
|
|
1170
1175
|
if (sdId === key && editorHandlerColumn) {
|
|
1171
1176
|
return true;
|
|
1172
1177
|
}
|
|
@@ -1582,7 +1587,13 @@ class SdGridMaterial {
|
|
|
1582
1587
|
return;
|
|
1583
1588
|
}
|
|
1584
1589
|
if (column.transform) {
|
|
1585
|
-
|
|
1590
|
+
const transform = column.transform(item[column.field], item);
|
|
1591
|
+
if (transform instanceof Promise) {
|
|
1592
|
+
obj[column.field] = yield transform;
|
|
1593
|
+
}
|
|
1594
|
+
else {
|
|
1595
|
+
obj[column.field] = transform;
|
|
1596
|
+
}
|
|
1586
1597
|
}
|
|
1587
1598
|
else if (item[column.field] === undefined || item[column.field] === null || item[column.field] === '') {
|
|
1588
1599
|
obj[column.field] = '';
|
|
@@ -2633,7 +2644,7 @@ class SdSelectionActionFilterPipe {
|
|
|
2633
2644
|
if ('children' in action) {
|
|
2634
2645
|
const children = [];
|
|
2635
2646
|
for (const childAction of action.children) {
|
|
2636
|
-
const key =
|
|
2647
|
+
const key = hash(childAction);
|
|
2637
2648
|
if (selectedItems.every(e => e.actions.includes(key))) {
|
|
2638
2649
|
children.push(childAction);
|
|
2639
2650
|
}
|
|
@@ -2643,7 +2654,7 @@ class SdSelectionActionFilterPipe {
|
|
|
2643
2654
|
}
|
|
2644
2655
|
}
|
|
2645
2656
|
else {
|
|
2646
|
-
const key =
|
|
2657
|
+
const key = hash(action);
|
|
2647
2658
|
if (selectedItems.every(e => e.actions.includes(key))) {
|
|
2648
2659
|
results.push(action);
|
|
2649
2660
|
}
|
|
@@ -2676,7 +2687,7 @@ class SdSelectionDisablePipe {
|
|
|
2676
2687
|
const availableActions = actions.filter(action => {
|
|
2677
2688
|
if ('children' in action) {
|
|
2678
2689
|
for (const childAction of action.children) {
|
|
2679
|
-
const key =
|
|
2690
|
+
const key = hash(childAction);
|
|
2680
2691
|
if (selectedItems.every(e => e.actions.includes(key))) {
|
|
2681
2692
|
return true;
|
|
2682
2693
|
}
|
|
@@ -2684,7 +2695,7 @@ class SdSelectionDisablePipe {
|
|
|
2684
2695
|
return false;
|
|
2685
2696
|
}
|
|
2686
2697
|
else {
|
|
2687
|
-
const key =
|
|
2698
|
+
const key = hash(action);
|
|
2688
2699
|
return selectedItems.every(e => e.actions.includes(key));
|
|
2689
2700
|
}
|
|
2690
2701
|
});
|
|
@@ -2692,13 +2703,13 @@ class SdSelectionDisablePipe {
|
|
|
2692
2703
|
for (const action of availableActions) {
|
|
2693
2704
|
if ('children' in action) {
|
|
2694
2705
|
for (const childAction of action.children) {
|
|
2695
|
-
if (rowData.actions.includes(
|
|
2706
|
+
if (rowData.actions.includes(hash(childAction))) {
|
|
2696
2707
|
return false;
|
|
2697
2708
|
}
|
|
2698
2709
|
}
|
|
2699
2710
|
}
|
|
2700
2711
|
else {
|
|
2701
|
-
if (rowData.actions.includes(
|
|
2712
|
+
if (rowData.actions.includes(hash(action))) {
|
|
2702
2713
|
return false;
|
|
2703
2714
|
}
|
|
2704
2715
|
}
|
|
@@ -2754,7 +2765,7 @@ class SdGeneratedColumnService {
|
|
|
2754
2765
|
if (!(configuration === null || configuration === void 0 ? void 0 : configuration.key)) {
|
|
2755
2766
|
return null;
|
|
2756
2767
|
}
|
|
2757
|
-
const key =
|
|
2768
|
+
const key = hash({
|
|
2758
2769
|
prefix: '260f5e94-5865-4425-8ced-b9c083c390dd',
|
|
2759
2770
|
key: configuration.key
|
|
2760
2771
|
});
|
|
@@ -2783,7 +2794,7 @@ class SdGeneratedColumnService {
|
|
|
2783
2794
|
if (!(configuration === null || configuration === void 0 ? void 0 : configuration.systemColumn)) {
|
|
2784
2795
|
return null;
|
|
2785
2796
|
}
|
|
2786
|
-
const key =
|
|
2797
|
+
const key = hash({
|
|
2787
2798
|
prefix: '8b8050ca-1f44-4860-bad3-20e646c0d68f',
|
|
2788
2799
|
key: configuration.key
|
|
2789
2800
|
});
|
|
@@ -2998,7 +3009,7 @@ class SdEditorHandlerRowPipe {
|
|
|
2998
3009
|
}
|
|
2999
3010
|
// const { sdId, editorHandlerColumn, ...remain } = item;
|
|
3000
3011
|
const { sdId, editorHandlerColumn, expandDetail, isExpanded, isExpanding, isSelected, sdGroup, selectable, actions, groupedActions, originItem, editorErrorMessage, editorHandlerRow } = item, remain = __rest(item, ["sdId", "editorHandlerColumn", "expandDetail", "isExpanded", "isExpanding", "isSelected", "sdGroup", "selectable", "actions", "groupedActions", "originItem", "editorErrorMessage", "editorHandlerRow"]);
|
|
3001
|
-
item.sdId =
|
|
3012
|
+
item.sdId = hash(remain);
|
|
3002
3013
|
item.editorHandlerColumn = item.editorHandlerColumn || {};
|
|
3003
3014
|
const { columns } = gridOption;
|
|
3004
3015
|
for (const col of columns) {
|
|
@@ -3152,7 +3163,7 @@ class SdSelectionVisiblePipe {
|
|
|
3152
3163
|
let hasGroup = false;
|
|
3153
3164
|
for (const childAction of action.children) {
|
|
3154
3165
|
const { hidden, isGrouped } = childAction;
|
|
3155
|
-
const key =
|
|
3166
|
+
const key = hash(childAction);
|
|
3156
3167
|
if (isGrouped) {
|
|
3157
3168
|
hasGroup = true;
|
|
3158
3169
|
}
|
|
@@ -3174,15 +3185,15 @@ class SdSelectionVisiblePipe {
|
|
|
3174
3185
|
}
|
|
3175
3186
|
}
|
|
3176
3187
|
if (flag) {
|
|
3177
|
-
rowData.actions.push(
|
|
3188
|
+
rowData.actions.push(hash(action));
|
|
3178
3189
|
if (hasGroup) {
|
|
3179
|
-
groupedActions.push(
|
|
3190
|
+
groupedActions.push(hash(action));
|
|
3180
3191
|
}
|
|
3181
3192
|
}
|
|
3182
3193
|
}
|
|
3183
3194
|
else {
|
|
3184
3195
|
const { hidden, isGrouped } = action;
|
|
3185
|
-
const key =
|
|
3196
|
+
const key = hash(action);
|
|
3186
3197
|
if (typeof (hidden) === 'function') {
|
|
3187
3198
|
if (!hidden(rowData)) {
|
|
3188
3199
|
rowData.actions.push(key);
|
|
@@ -3423,7 +3434,7 @@ class SdGroupPipe {
|
|
|
3423
3434
|
for (const field of fields) {
|
|
3424
3435
|
obj = Object.assign(Object.assign({}, obj), ((_a = item[field]) !== null && _a !== void 0 ? _a : { [field]: item[field] }));
|
|
3425
3436
|
}
|
|
3426
|
-
const key =
|
|
3437
|
+
const key = hash(obj);
|
|
3427
3438
|
if (!groupItem[key]) {
|
|
3428
3439
|
groupItem[key] = [];
|
|
3429
3440
|
}
|