UNPKG

botframework-webchat-component

Version:
240 lines (193 loc) 19.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = downscaleImageToDataURLUsingWorker; exports.checkSupport = checkSupport; var _blobToArrayBuffer = _interopRequireDefault(require("./blobToArrayBuffer")); var _downscaleImageToDataURLUsingWorker = _interopRequireDefault(require("./downscaleImageToDataURLUsingWorker.worker")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } function createWorker(fn) { var blob = new Blob(["(".concat(fn, ")()")], { type: 'text/javascript' }); var url = window.URL.createObjectURL(blob); return new Promise(function (resolve, reject) { var worker = new Worker(url); worker.onerror = function (_ref) { var error = _ref.error, message = _ref.message; return reject(error || new Error(message)); }; worker.onmessage = function (_ref2) { var data = _ref2.data; return data === 'ready' && resolve(worker); }; }).finally(function () { window.URL.revokeObjectURL(url); }); } var workerPromise; function getWorker() { return _getWorker.apply(this, arguments); } // We are using a lazy-check because: // 1. OffscreenCanvas.getContext has a toll // 2. Developers could bring polyfills function _getWorker() { _getWorker = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3() { var worker; return regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: if (!workerPromise) { _context3.next = 6; break; } _context3.next = 3; return workerPromise; case 3: worker = _context3.sent; _context3.next = 11; break; case 6: workerPromise = createWorker(_downscaleImageToDataURLUsingWorker.default); _context3.next = 9; return workerPromise; case 9: worker = _context3.sent; worker.addEventListener('error', function () { // Current worker errored out, will create a new worker next time. workerPromise = null; worker.terminate(); }); case 11: return _context3.abrupt("return", worker); case 12: case "end": return _context3.stop(); } } }, _callee3); })); return _getWorker.apply(this, arguments); } var checkSupportOffscreenCanvas = function checkSupportOffscreenCanvas() { var hasOffscreenCanvas = typeof window.OffscreenCanvas !== 'undefined' && (typeof window.OffscreenCanvas.prototype.convertToBlob !== 'undefined' || typeof window.OffscreenCanvas.prototype.toBlob !== 'undefined'); var isOffscreenCanvasSupportGetContext2D; if (hasOffscreenCanvas) { try { new OffscreenCanvas(1, 1).getContext('2d'); isOffscreenCanvasSupportGetContext2D = true; } catch (err) { isOffscreenCanvasSupportGetContext2D = false; } } return typeof window.createImageBitmap !== 'undefined' && hasOffscreenCanvas && isOffscreenCanvasSupportGetContext2D; }; var checkSupportWebWorkerPromise; function checkSupportWebWorker() { return checkSupportWebWorkerPromise || (checkSupportWebWorkerPromise = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { var worker; return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: if (!(typeof window.MessageChannel === 'undefined' || typeof window.Worker === 'undefined')) { _context.next = 2; break; } return _context.abrupt("return", false); case 2: _context.prev = 2; _context.next = 5; return createWorker('function(){postMessage("ready")}'); case 5: worker = _context.sent; _context.next = 11; break; case 8: _context.prev = 8; _context.t0 = _context["catch"](2); return _context.abrupt("return", false); case 11: worker.terminate(); return _context.abrupt("return", true); case 13: case "end": return _context.stop(); } } }, _callee, null, [[2, 8]]); }))()); } var checkSupportPromise; function checkSupport() { return checkSupportPromise || (checkSupportPromise = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() { var results; return regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: _context2.prev = 0; _context2.next = 3; return Promise.all([checkSupportOffscreenCanvas(), checkSupportWebWorker()]); case 3: results = _context2.sent; return _context2.abrupt("return", results.every(function (result) { return result; })); case 7: _context2.prev = 7; _context2.t0 = _context2["catch"](0); return _context2.abrupt("return", false); case 10: case "end": return _context2.stop(); } } }, _callee2, null, [[0, 7]]); }))()); } function downscaleImageToDataURLUsingWorker(blob, maxWidth, maxHeight, type, quality) { return new Promise(function (resolve, reject) { var _MessageChannel = new MessageChannel(), port1 = _MessageChannel.port1, port2 = _MessageChannel.port2; port1.onmessage = function (_ref5) { var _ref5$data = _ref5.data, error = _ref5$data.error, result = _ref5$data.result; if (error) { var err = new Error(error.message); err.stack = error.stack; reject(err); } else { resolve(result); } port1.close(); port2.close(); }; Promise.all([(0, _blobToArrayBuffer.default)(blob), getWorker()]).then(function (_ref6) { var _ref7 = _slicedToArray(_ref6, 2), arrayBuffer = _ref7[0], worker = _ref7[1]; return worker.postMessage({ arrayBuffer: arrayBuffer, maxHeight: maxHeight, maxWidth: maxWidth, quality: quality, type: type }, [arrayBuffer, port2]); }); }); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Utils/downscaleImageToDataURL/downscaleImageToDataURLUsingWorker.js"],"names":["createWorker","fn","blob","Blob","type","url","window","URL","createObjectURL","Promise","resolve","reject","worker","Worker","onerror","error","message","Error","onmessage","data","finally","revokeObjectURL","workerPromise","getWorker","workerFunction","addEventListener","terminate","checkSupportOffscreenCanvas","hasOffscreenCanvas","OffscreenCanvas","prototype","convertToBlob","toBlob","isOffscreenCanvasSupportGetContext2D","getContext","err","createImageBitmap","checkSupportWebWorkerPromise","checkSupportWebWorker","MessageChannel","checkSupportPromise","checkSupport","all","results","every","result","downscaleImageToDataURLUsingWorker","maxWidth","maxHeight","quality","port1","port2","stack","close","then","arrayBuffer","postMessage"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import blobToArrayBuffer from './blobToArrayBuffer';\nimport workerFunction from './downscaleImageToDataURLUsingWorker.worker';\n\nfunction createWorker(fn) {\n  const blob = new Blob([`(${fn})()`], { type: 'text/javascript' });\n  const url = window.URL.createObjectURL(blob);\n\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(url);\n\n    worker.onerror = ({ error, message }) => reject(error || new Error(message));\n    worker.onmessage = ({ data }) => data === 'ready' && resolve(worker);\n  }).finally(() => {\n    window.URL.revokeObjectURL(url);\n  });\n}\n\nlet workerPromise;\n\nasync function getWorker() {\n  let worker;\n\n  if (workerPromise) {\n    worker = await workerPromise;\n  } else {\n    workerPromise = createWorker(workerFunction);\n\n    worker = await workerPromise;\n    worker.addEventListener('error', () => {\n      // Current worker errored out, will create a new worker next time.\n      workerPromise = null;\n      worker.terminate();\n    });\n  }\n\n  return worker;\n}\n\n// We are using a lazy-check because:\n// 1. OffscreenCanvas.getContext has a toll\n// 2. Developers could bring polyfills\n\nconst checkSupportOffscreenCanvas = () => {\n  const hasOffscreenCanvas =\n    typeof window.OffscreenCanvas !== 'undefined' &&\n    (typeof window.OffscreenCanvas.prototype.convertToBlob !== 'undefined' ||\n      typeof window.OffscreenCanvas.prototype.toBlob !== 'undefined');\n  let isOffscreenCanvasSupportGetContext2D;\n\n  if (hasOffscreenCanvas) {\n    try {\n      new OffscreenCanvas(1, 1).getContext('2d');\n      isOffscreenCanvasSupportGetContext2D = true;\n    } catch (err) {\n      isOffscreenCanvasSupportGetContext2D = false;\n    }\n  }\n\n  return typeof window.createImageBitmap !== 'undefined' && hasOffscreenCanvas && isOffscreenCanvasSupportGetContext2D;\n};\n\nlet checkSupportWebWorkerPromise;\n\nfunction checkSupportWebWorker() {\n  return (\n    checkSupportWebWorkerPromise ||\n    (checkSupportWebWorkerPromise = (async () => {\n      if (typeof window.MessageChannel === 'undefined' || typeof window.Worker === 'undefined') {\n        return false;\n      }\n\n      let worker;\n\n      try {\n        worker = await createWorker('function(){postMessage(\"ready\")}');\n      } catch (err) {\n        return false;\n      }\n\n      worker.terminate();\n\n      return true;\n    })())\n  );\n}\n\nlet checkSupportPromise;\n\nfunction checkSupport() {\n  return (\n    checkSupportPromise ||\n    (checkSupportPromise = (async () => {\n      try {\n        const results = await Promise.all([checkSupportOffscreenCanvas(), checkSupportWebWorker()]);\n\n        return results.every(result => result);\n      } catch (err) {\n        return false;\n      }\n    })())\n  );\n}\n\nexport default function downscaleImageToDataURLUsingWorker(blob, maxWidth, maxHeight, type, quality) {\n  return new Promise((resolve, reject) => {\n    const { port1, port2 } = new MessageChannel();\n\n    port1.onmessage = ({ data: { error, result } }) => {\n      if (error) {\n        const err = new Error(error.message);\n\n        err.stack = error.stack;\n\n        reject(err);\n      } else {\n        resolve(result);\n      }\n\n      port1.close();\n      port2.close();\n    };\n\n    Promise.all([blobToArrayBuffer(blob), getWorker()]).then(([arrayBuffer, worker]) =>\n      worker.postMessage({ arrayBuffer, maxHeight, maxWidth, quality, type }, [arrayBuffer, port2])\n    );\n  });\n}\n\nexport { checkSupport };\n"]}