2023-05-09 15:55:35 +03:00
|
|
|
import 'core-js/features/object/assign';
|
|
|
|
import 'core-js/features/object/values';
|
|
|
|
import 'core-js/features/symbol';
|
|
|
|
import 'core-js/features/promise/finally';
|
|
|
|
import { decode as decodeBase64 } from '../utils/base64';
|
2020-02-18 18:22:44 +02:00
|
|
|
|
2023-07-13 12:49:16 +03:00
|
|
|
if (!Object.hasOwn(HTMLCanvasElement.prototype, 'toBlob')) {
|
2018-04-23 10:15:51 +03:00
|
|
|
const BASE64_MARKER = ';base64,';
|
|
|
|
|
|
|
|
Object.defineProperty(HTMLCanvasElement.prototype, 'toBlob', {
|
2023-05-10 13:59:29 +03:00
|
|
|
value: function (
|
|
|
|
this: HTMLCanvasElement,
|
|
|
|
callback: BlobCallback,
|
|
|
|
type = 'image/png',
|
2023-07-13 12:26:45 +03:00
|
|
|
quality: unknown,
|
2023-05-10 13:59:29 +03:00
|
|
|
) {
|
|
|
|
const dataURL: string = this.toDataURL(type, quality);
|
2018-04-23 10:15:51 +03:00
|
|
|
let data;
|
|
|
|
|
2023-07-13 12:49:16 +03:00
|
|
|
if (dataURL.includes(BASE64_MARKER)) {
|
2018-04-23 10:15:51 +03:00
|
|
|
const [, base64] = dataURL.split(BASE64_MARKER);
|
|
|
|
data = decodeBase64(base64);
|
|
|
|
} else {
|
|
|
|
[, data] = dataURL.split(',');
|
|
|
|
}
|
|
|
|
|
|
|
|
callback(new Blob([data], { type }));
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|