happo 2.8.1 → 2.8.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/happo/public/026c001beac0620bb23a.worker.js +50 -0
- data/lib/happo/public/05ad45a945afc6882286.worker.js +56 -0
- data/lib/happo/public/0dd329b74ed90a207896.worker.js +56 -0
- data/lib/happo/public/174b944ab9e9053c766d.worker.js +56 -0
- data/lib/happo/public/196b75660e2791fda25a.worker.js +56 -0
- data/lib/happo/public/1d5c0eb9c479f44f0ec2.worker.js +56 -0
- data/lib/happo/public/1d6c41b4828b191ae315.worker.js +56 -0
- data/lib/happo/public/212269d558f1f8b1bc63.worker.js +56 -0
- data/lib/happo/public/25426637d793045ccb77.worker.js +56 -0
- data/lib/happo/public/28537ac53e64479763ba.worker.js +56 -0
- data/lib/happo/public/30e3af0e8f974da2885c.worker.js +56 -0
- data/lib/happo/public/32fc2a09f98d30cb2a06.worker.js +56 -0
- data/lib/happo/public/33c43f9f1296a6c3b236.worker.js +56 -0
- data/lib/happo/public/3a6592504d8ee1810017.worker.js +56 -0
- data/lib/happo/public/3a8bedd3121a2cdacb6d.worker.js +56 -0
- data/lib/happo/public/3d9ed68ca315896c8ec7.worker.js +56 -0
- data/lib/happo/public/3da88471c60703398f95.worker.js +56 -0
- data/lib/happo/public/40c1aadf458bda245630.worker.js +1 -0
- data/lib/happo/public/41749e1ff9db63f87a1e.worker.js +56 -0
- data/lib/happo/public/42bc2c20d61979a23a2f.worker.js +56 -0
- data/lib/happo/public/447f3bfe79be8a67b9cc.worker.js +56 -0
- data/lib/happo/public/4580dd75ba5a064f4366.worker.js +56 -0
- data/lib/happo/public/4975b25fe791d85e9827.worker.js +56 -0
- data/lib/happo/public/4b23fa5d7875a8fba618.worker.js +56 -0
- data/lib/happo/public/4ecbb720788698ce7a9b.worker.js +56 -0
- data/lib/happo/public/4ef2e26b666b08b7411a.worker.js +56 -0
- data/lib/happo/public/51ac7ca571ae07cd9d7a.worker.js +56 -0
- data/lib/happo/public/531d99f56a3343cee5f8.worker.js +56 -0
- data/lib/happo/public/53e6a60c2cf0558157a7.worker.js +56 -0
- data/lib/happo/public/55d488167040d5350534.worker.js +56 -0
- data/lib/happo/public/588f7a6b784ef2b87932.worker.js +56 -0
- data/lib/happo/public/59d03b8990473ae492e0.worker.js +56 -0
- data/lib/happo/public/5aded6f9af816e819a2b.worker.js +56 -0
- data/lib/happo/public/5e6771e4a41f597c26a9.worker.js +56 -0
- data/lib/happo/public/61e924aed1761ec05ca0.worker.js +56 -0
- data/lib/happo/public/65e7608bb10d0f2250d1.worker.js +56 -0
- data/lib/happo/public/6a71a1273a0cf4065e1e.worker.js +56 -0
- data/lib/happo/public/727ca4589d56ddcb9c7f.worker.js +56 -0
- data/lib/happo/public/769883a4d5abfa7384d4.worker.js +56 -0
- data/lib/happo/public/78fea81d29830297df57.worker.js +56 -0
- data/lib/happo/public/7bf45d52cf57b1949851.worker.js +56 -0
- data/lib/happo/public/7d4a4086de8530abe101.worker.js +56 -0
- data/lib/happo/public/7e330bc3ee246ab39910.worker.js +56 -0
- data/lib/happo/public/84f3a66517b77798456d.worker.js +56 -0
- data/lib/happo/public/856dbe98c40d8f4bd452.worker.js +56 -0
- data/lib/happo/public/90a4b81e4d7c2da63973.worker.js +56 -0
- data/lib/happo/public/92dd03e7cbe827a2df45.worker.js +56 -0
- data/lib/happo/public/94976fe48214f2bc68d6.worker.js +56 -0
- data/lib/happo/public/95f3e6e7eec59c0af3e5.worker.js +56 -0
- data/lib/happo/public/96c4c2f5df8175649a67.worker.js +56 -0
- data/lib/happo/public/973a6ae106ac4e664858.worker.js +56 -0
- data/lib/happo/public/989e9ba236891bdfcf46.worker.js +56 -0
- data/lib/happo/public/HappoApp.bundle.js +1 -2
- data/lib/happo/public/a50e9af74a422839a15c.worker.js +56 -0
- data/lib/happo/public/ad4fdfa82741585ce164.worker.js +56 -0
- data/lib/happo/public/ae0622a81101951ac112.worker.js +56 -0
- data/lib/happo/public/ae223678cdbfac88d9be.worker.js +56 -0
- data/lib/happo/public/b441a6c1393a5d39b5ff.worker.js +56 -0
- data/lib/happo/public/b4c84506199d5745d950.worker.js +56 -0
- data/lib/happo/public/b5176c936b696653a407.worker.js +56 -0
- data/lib/happo/public/b86b963a72892d8f0fd1.worker.js +56 -0
- data/lib/happo/public/ba50214d2b6ac001493b.worker.js +56 -0
- data/lib/happo/public/bb6413d1cea030ba7a1e.worker.js +56 -0
- data/lib/happo/public/bc084ad60fb7dbbe0818.worker.js +56 -0
- data/lib/happo/public/c15e6b44ae496af6af9b.worker.js +56 -0
- data/lib/happo/public/c4393394848f5242932e.worker.js +56 -0
- data/lib/happo/public/c60ceaff7849b394e27a.worker.js +56 -0
- data/lib/happo/public/c67c76de1e4def5019d5.worker.js +56 -0
- data/lib/happo/public/c7969739b50b79043b86.worker.js +56 -0
- data/lib/happo/public/cc82d7609935eb1d2738.worker.js +56 -0
- data/lib/happo/public/d135dda9b0318be75e3c.worker.js +56 -0
- data/lib/happo/public/d2aded5d63912f5b7e1b.worker.js +56 -0
- data/lib/happo/public/d2be644581f8f67b207d.worker.js +56 -0
- data/lib/happo/public/d6e037d3891cfb95fbca.worker.js +50 -0
- data/lib/happo/public/d7440908d264133044bb.worker.js +56 -0
- data/lib/happo/public/da071c51e9a641ed805c.worker.js +56 -0
- data/lib/happo/public/dbe8eef9555ef0d43469.worker.js +56 -0
- data/lib/happo/public/e1cbbfd7a3d705049eb0.worker.js +56 -0
- data/lib/happo/public/e3882591e6710cf03ed4.worker.js +56 -0
- data/lib/happo/public/e414c768d66b9bcf86bb.worker.js +56 -0
- data/lib/happo/public/e85bc4bb461158f5561d.worker.js +56 -0
- data/lib/happo/public/ed6256235d0a2b11aaf6.worker.js +56 -0
- data/lib/happo/public/edcc84bf4483670ba23e.worker.js +56 -0
- data/lib/happo/public/f3d33d482a4326121c45.worker.js +56 -0
- data/lib/happo/public/f67e23a954230ea878be.worker.js +56 -0
- data/lib/happo/public/f800c3a1d9200926bde6.worker.js +56 -0
- data/lib/happo/public/f8954fa2849952175e2c.worker.js +56 -0
- data/lib/happo/public/fde5a206ff86c3d7ab10.worker.js +56 -0
- data/lib/happo/public/globe-current.png +0 -0
- data/lib/happo/public/globe-previous.png +0 -0
- data/lib/happo/server.rb +7 -0
- data/lib/happo/version.rb +1 -1
- metadata +91 -3
- data/lib/happo/public/happo-logo.svg +0 -1
@@ -0,0 +1,56 @@
|
|
1
|
+
/******/ (function(modules) { // webpackBootstrap
|
2
|
+
/******/ // The module cache
|
3
|
+
/******/ var installedModules = {};
|
4
|
+
|
5
|
+
/******/ // The require function
|
6
|
+
/******/ function __webpack_require__(moduleId) {
|
7
|
+
|
8
|
+
/******/ // Check if module is in cache
|
9
|
+
/******/ if(installedModules[moduleId])
|
10
|
+
/******/ return installedModules[moduleId].exports;
|
11
|
+
|
12
|
+
/******/ // Create a new module (and put it into the cache)
|
13
|
+
/******/ var module = installedModules[moduleId] = {
|
14
|
+
/******/ exports: {},
|
15
|
+
/******/ id: moduleId,
|
16
|
+
/******/ loaded: false
|
17
|
+
/******/ };
|
18
|
+
|
19
|
+
/******/ // Execute the module function
|
20
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
21
|
+
|
22
|
+
/******/ // Flag the module as loaded
|
23
|
+
/******/ module.loaded = true;
|
24
|
+
|
25
|
+
/******/ // Return the exports of the module
|
26
|
+
/******/ return module.exports;
|
27
|
+
/******/ }
|
28
|
+
|
29
|
+
|
30
|
+
/******/ // expose the modules object (__webpack_modules__)
|
31
|
+
/******/ __webpack_require__.m = modules;
|
32
|
+
|
33
|
+
/******/ // expose the module cache
|
34
|
+
/******/ __webpack_require__.c = installedModules;
|
35
|
+
|
36
|
+
/******/ // __webpack_public_path__
|
37
|
+
/******/ __webpack_require__.p = "";
|
38
|
+
|
39
|
+
/******/ // Load entry module and return exports
|
40
|
+
/******/ return __webpack_require__(0);
|
41
|
+
/******/ })
|
42
|
+
/************************************************************************/
|
43
|
+
/******/ ([
|
44
|
+
/* 0 */
|
45
|
+
/***/ function(module, exports, __webpack_require__) {
|
46
|
+
|
47
|
+
eval("'use strict';\n\nvar _alignArrays = __webpack_require__(1);\n\nvar _alignArrays2 = _interopRequireDefault(_alignArrays);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction imageTo2DArray(_ref, paddingRight) {\n var data = _ref.data;\n var width = _ref.width;\n var height = _ref.height;\n\n // The imageData is a 1D array. Each element in the array corresponds to a\n // decimal value that represents one of the RGBA channels for that pixel.\n var rowSize = width * 4;\n\n var newData = [];\n for (var row = 0; row < height; row++) {\n var pixelsInRow = new Uint8ClampedArray(rowSize + paddingRight * 4);\n for (var location = 0; location < rowSize; location++) {\n pixelsInRow[location] = data[row * rowSize + location];\n }\n newData.push(pixelsInRow);\n }\n return newData;\n}\n\nfunction align(_ref2) {\n var previousImageData = _ref2.previousImageData;\n var currentImageData = _ref2.currentImageData;\n var maxWidth = _ref2.maxWidth;\n\n var hashedPreviousData = previousImageData.map(JSON.stringify);\n self.postMessage({ progress: 40 });\n var hashedCurrentData = currentImageData.map(JSON.stringify);\n self.postMessage({ progress: 60 });\n\n (0, _alignArrays2.default)(hashedPreviousData, hashedCurrentData);\n\n var transparentLine = new Uint8ClampedArray(maxWidth * 4);\n\n hashedPreviousData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n previousImageData.splice(i, 0, transparentLine);\n }\n });\n\n hashedCurrentData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n currentImageData.splice(i, 0, transparentLine);\n }\n });\n}\n\n/**\n * Takes two 2d images, computes the diff between the two, and injects pixels to\n * both in order to:\n * a) make both images the same height\n * b) properly visualize differences\n *\n * Please note that this method MUTATES data.\n *\n * @param {Array} previousData\n * @param {Array} currentData\n */\nfunction computeAndInjectDiffs(_ref3) {\n var previousData = _ref3.previousData;\n var currentData = _ref3.currentData;\n\n var maxWidth = Math.max(previousData.width, currentData.width);\n\n var previousImageData = imageTo2DArray(previousData, maxWidth - previousData.width);\n\n var currentImageData = imageTo2DArray(currentData, maxWidth - currentData.width);\n\n self.postMessage({ progress: 20 });\n\n align({\n previousImageData: previousImageData,\n currentImageData: currentImageData,\n maxWidth: maxWidth\n });\n\n self.postMessage({ progress: 85 });\n\n return {\n currentData: {\n data: currentImageData,\n height: currentImageData.length,\n width: maxWidth\n },\n previousData: {\n data: previousImageData,\n height: previousImageData.length,\n width: maxWidth\n }\n };\n}\n\nself.addEventListener('message', function (_ref4) {\n var _ref4$data = _ref4.data;\n var previousData = _ref4$data.previousData;\n var currentData = _ref4$data.currentData;\n\n var result = computeAndInjectDiffs({ previousData: previousData, currentData: currentData });\n self.postMessage(result);\n self.close();\n});//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvd29ya2Vycy9Db21wdXRlQW5kSW5qZWN0RGlmZnNXb3JrZXIuanM/ZGRiNSJdLCJuYW1lcyI6WyJpbWFnZVRvMkRBcnJheSIsInBhZGRpbmdSaWdodCIsImRhdGEiLCJ3aWR0aCIsImhlaWdodCIsInJvd1NpemUiLCJuZXdEYXRhIiwicm93IiwicGl4ZWxzSW5Sb3ciLCJVaW50OENsYW1wZWRBcnJheSIsImxvY2F0aW9uIiwicHVzaCIsImFsaWduIiwicHJldmlvdXNJbWFnZURhdGEiLCJjdXJyZW50SW1hZ2VEYXRhIiwibWF4V2lkdGgiLCJoYXNoZWRQcmV2aW91c0RhdGEiLCJtYXAiLCJKU09OIiwic3RyaW5naWZ5Iiwic2VsZiIsInBvc3RNZXNzYWdlIiwicHJvZ3Jlc3MiLCJoYXNoZWRDdXJyZW50RGF0YSIsInRyYW5zcGFyZW50TGluZSIsImZvckVhY2giLCJoYXNoZWRMaW5lIiwiaSIsInNwbGljZSIsImNvbXB1dGVBbmRJbmplY3REaWZmcyIsInByZXZpb3VzRGF0YSIsImN1cnJlbnREYXRhIiwiTWF0aCIsIm1heCIsImxlbmd0aCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXN1bHQiLCJjbG9zZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0FBRUEsU0FBU0EsY0FBVCxPQUFpREMsWUFBakQsRUFBK0Q7QUFBQSxNQUFyQ0MsSUFBcUMsUUFBckNBLElBQXFDO0FBQUEsTUFBL0JDLEtBQStCLFFBQS9CQSxLQUErQjtBQUFBLE1BQXhCQyxNQUF3QixRQUF4QkEsTUFBd0I7O0FBQzdEO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixRQUFRLENBQXhCOztBQUVBLE1BQU1HLFVBQVUsRUFBaEI7QUFDQSxPQUFLLElBQUlDLE1BQU0sQ0FBZixFQUFrQkEsTUFBTUgsTUFBeEIsRUFBZ0NHLEtBQWhDLEVBQXVDO0FBQ3JDLFFBQU1DLGNBQWMsSUFBSUMsaUJBQUosQ0FBc0JKLFVBQVdKLGVBQWUsQ0FBaEQsQ0FBcEI7QUFDQSxT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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFsaWduQXJyYXlzIGZyb20gJy4uL2FsaWduQXJyYXlzJztcblxuZnVuY3Rpb24gaW1hZ2VUbzJEQXJyYXkoeyBkYXRhLCB3aWR0aCwgaGVpZ2h0IH0sIHBhZGRpbmdSaWdodCkge1xuICAvLyBUaGUgaW1hZ2VEYXRhIGlzIGEgMUQgYXJyYXkuIEVhY2ggZWxlbWVudCBpbiB0aGUgYXJyYXkgY29ycmVzcG9uZHMgdG8gYVxuICAvLyBkZWNpbWFsIHZhbHVlIHRoYXQgcmVwcmVzZW50cyBvbmUgb2YgdGhlIFJHQkEgY2hhbm5lbHMgZm9yIHRoYXQgcGl4ZWwuXG4gIGNvbnN0IHJvd1NpemUgPSB3aWR0aCAqIDQ7XG5cbiAgY29uc3QgbmV3RGF0YSA9IFtdO1xuICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCBoZWlnaHQ7IHJvdysrKSB7XG4gICAgY29uc3QgcGl4ZWxzSW5Sb3cgPSBuZXcgVWludDhDbGFtcGVkQXJyYXkocm93U2l6ZSArIChwYWRkaW5nUmlnaHQgKiA0KSk7XG4gICAgZm9yIChsZXQgbG9jYXRpb24gPSAwOyBsb2NhdGlvbiA8IHJvd1NpemU7IGxvY2F0aW9uKyspIHtcbiAgICAgIHBpeGVsc0luUm93W2xvY2F0aW9uXSA9IGRhdGFbKHJvdyAqIHJvd1NpemUpICsgbG9jYXRpb25dO1xuICAgIH1cbiAgICBuZXdEYXRhLnB1c2gocGl4ZWxzSW5Sb3cpO1xuICB9XG4gIHJldHVybiBuZXdEYXRhO1xufVxuXG5mdW5jdGlvbiBhbGlnbih7XG4gIHByZXZpb3VzSW1hZ2VEYXRhLFxuICBjdXJyZW50SW1hZ2VEYXRhLFxuICBtYXhXaWR0aCxcbn0pIHtcbiAgY29uc3QgaGFzaGVkUHJldmlvdXNEYXRhID0gcHJldmlvdXNJbWFnZURhdGEubWFwKEpTT04uc3RyaW5naWZ5KTtcbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA0MCB9KTtcbiAgY29uc3QgaGFzaGVkQ3VycmVudERhdGEgPSBjdXJyZW50SW1hZ2VEYXRhLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UoeyBwcm9ncmVzczogNjAgfSk7XG5cbiAgYWxpZ25BcnJheXMoXG4gICAgaGFzaGVkUHJldmlvdXNEYXRhLFxuICAgIGhhc2hlZEN1cnJlbnREYXRhXG4gICk7XG5cbiAgY29uc3QgdHJhbnNwYXJlbnRMaW5lID0gbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KG1heFdpZHRoICogNCk7XG5cbiAgaGFzaGVkUHJldmlvdXNEYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBwcmV2aW91c0ltYWdlRGF0YS5zcGxpY2UoaSwgMCwgdHJhbnNwYXJlbnRMaW5lKTtcbiAgICB9XG4gIH0pO1xuXG4gIGhhc2hlZEN1cnJlbnREYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBjdXJyZW50SW1hZ2VEYXRhLnNwbGljZShpLCAwLCB0cmFuc3BhcmVudExpbmUpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogVGFrZXMgdHdvIDJkIGltYWdlcywgY29tcHV0ZXMgdGhlIGRpZmYgYmV0d2VlbiB0aGUgdHdvLCBhbmQgaW5qZWN0cyBwaXhlbHMgdG9cbiAqIGJvdGggaW4gb3JkZXIgdG86XG4gKiBhKSBtYWtlIGJvdGggaW1hZ2VzIHRoZSBzYW1lIGhlaWdodFxuICogYikgcHJvcGVybHkgdmlzdWFsaXplIGRpZmZlcmVuY2VzXG4gKlxuICogUGxlYXNlIG5vdGUgdGhhdCB0aGlzIG1ldGhvZCBNVVRBVEVTIGRhdGEuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gcHJldmlvdXNEYXRhXG4gKiBAcGFyYW0ge0FycmF5fSBjdXJyZW50RGF0YVxuICovXG5mdW5jdGlvbiBjb21wdXRlQW5kSW5qZWN0RGlmZnMoeyBwcmV2aW91c0RhdGEsIGN1cnJlbnREYXRhIH0pIHtcbiAgY29uc3QgbWF4V2lkdGggPSBNYXRoLm1heChwcmV2aW91c0RhdGEud2lkdGgsIGN1cnJlbnREYXRhLndpZHRoKTtcblxuICBjb25zdCBwcmV2aW91c0ltYWdlRGF0YSA9IGltYWdlVG8yREFycmF5KFxuICAgIHByZXZpb3VzRGF0YSwgbWF4V2lkdGggLSBwcmV2aW91c0RhdGEud2lkdGgpO1xuXG4gIGNvbnN0IGN1cnJlbnRJbWFnZURhdGEgPSBpbWFnZVRvMkRBcnJheShcbiAgICBjdXJyZW50RGF0YSwgbWF4V2lkdGggLSBjdXJyZW50RGF0YS53aWR0aCk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiAyMCB9KTtcblxuICBhbGlnbih7XG4gICAgcHJldmlvdXNJbWFnZURhdGEsXG4gICAgY3VycmVudEltYWdlRGF0YSxcbiAgICBtYXhXaWR0aCxcbiAgfSk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA4NSB9KTtcblxuICByZXR1cm4ge1xuICAgIGN1cnJlbnREYXRhOiB7XG4gICAgICBkYXRhOiBjdXJyZW50SW1hZ2VEYXRhLFxuICAgICAgaGVpZ2h0OiBjdXJyZW50SW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICAgIHByZXZpb3VzRGF0YToge1xuICAgICAgZGF0YTogcHJldmlvdXNJbWFnZURhdGEsXG4gICAgICBoZWlnaHQ6IHByZXZpb3VzSW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICB9O1xufVxuXG5zZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCAoeyBkYXRhOiB7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSB9KSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IGNvbXB1dGVBbmRJbmplY3REaWZmcyh7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UocmVzdWx0KTtcbiAgc2VsZi5jbG9zZSgpO1xufSk7XG5cblxuXG4vKiogV0VCUEFDSyBGT09URVIgKipcbiAqKiAuL2pzL3NyYy93b3JrZXJzL0NvbXB1dGVBbmRJbmplY3REaWZmc1dvcmtlci5qc1xuICoqLyJdLCJzb3VyY2VSb290IjoiIn0=");
|
48
|
+
|
49
|
+
/***/ },
|
50
|
+
/* 1 */
|
51
|
+
/***/ function(module, exports) {
|
52
|
+
|
53
|
+
eval("'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = alignArrays;\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar MOVEMENT = {\n none: 0,\n diagonal: 1,\n vertical: 2,\n horizontal: 3\n};\n\nfunction initMatrix(height, width) {\n var rows = new Array(height);\n for (var i = 0; i < rows.length; i++) {\n rows[i] = new Int32Array(width);\n }\n return rows;\n}\n\nfunction longestCommonSubsequence(a, b) {\n // adapted from\n // http://algorithms.tutorialhorizon.com/dynamic-programming-longest-common-subsequence/\n var aLength = a.length;\n var bLength = b.length;\n var memo = initMatrix(aLength + 1, bLength + 1);\n var solution = initMatrix(aLength + 1, bLength + 1);\n\n // Loop and find the solution\n for (var i = 1; i <= aLength; i++) {\n for (var j = 1; j <= bLength; j++) {\n if (a[i - 1] === b[j - 1]) {\n // diagonal\n memo[i][j] = memo[i - 1][j - 1] + 1;\n solution[i][j] = MOVEMENT.diagonal;\n } else {\n memo[i][j] = Math.max(memo[i - 1][j], memo[i][j - 1]);\n if (memo[i][j] === memo[i - 1][j]) {\n solution[i][j] = MOVEMENT.vertical;\n } else {\n solution[i][j] = MOVEMENT.horizontal;\n }\n }\n }\n }\n console.log(memo[aLength][bLength]);\n return solution;\n}\n\nfunction placeholders(count) {\n var result = new Array(count);\n for (var i = 0; i < count; i++) {\n result[i] = '+';\n }\n return result;\n}\n/**\n * Apply an lcs solution to arrays. Note that this will MUTATE the arrays,\n * injecting \"+\" where gaps are needed.\n *\n * @param {Array<Array>} solution as computed by `longestCommonSubsequence`\n * @param {Array} a\n * @param {Array} b\n */\nfunction applySolution(solution, a, b) {\n var movement = solution[a.length][b.length];\n var ai = a.length;\n var bi = b.length;\n\n var changes = 0;\n\n while (movement !== MOVEMENT.none) {\n if (movement === MOVEMENT.diagonal) {\n if (changes < 0) {\n b.splice.apply(b, [bi, 0].concat(_toConsumableArray(placeholders(Math.abs(changes)))));\n } else if (changes > 0) {\n a.splice.apply(a, [ai, 0].concat(_toConsumableArray(placeholders(changes))));\n }\n ai--;\n bi--;\n changes = 0;\n } else if (movement === MOVEMENT.horizontal) {\n bi--;\n changes++;\n } else if (movement === MOVEMENT.vertical) {\n ai--;\n changes--;\n }\n movement = solution[ai][bi];\n }\n}\n\n/**\n * Computes the longest common subsequence of two arrays, then uses that\n * solution to inject gaps into the arrays, making them align on common\n * subsequences.\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction alignArrays(a, b) {\n var lcsSolution = longestCommonSubsequence(a, b);\n applySolution(lcsSolution, a, b);\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvYWxpZ25BcnJheXMuanM/MDFiNyJdLCJuYW1lcyI6WyJhbGlnbkFycmF5cyIsIk1PVkVNRU5UIiwibm9uZSIsImRpYWdvbmFsIiwidmVydGljYWwiLCJob3Jpem9udGFsIiwiaW5pdE1hdHJpeCIsImhlaWdodCIsIndpZHRoIiwicm93cyIsIkFycmF5IiwiaSIsImxlbmd0aCIsIkludDMyQXJyYXkiLCJsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UiLCJhIiwiYiIsImFMZW5ndGgiLCJiTGVuZ3RoIiwibWVtbyIsInNvbHV0aW9uIiwiaiIsIk1hdGgiLCJtYXgiLCJjb25zb2xlIiwibG9nIiwicGxhY2Vob2xkZXJzIiwiY291bnQiLCJyZXN1bHQiLCJhcHBseVNvbHV0aW9uIiwibW92ZW1lbnQiLCJhaSIsImJpIiwiY2hhbmdlcyIsInNwbGljZSIsImFicyIsImxjc1NvbHV0aW9uIl0sIm1hcHBpbmdzIjoiOzs7OztrQkErRndCQSxXOzs7O0FBL0Z4QixJQUFNQyxXQUFXO0FBQ2ZDLFFBQU0sQ0FEUztBQUVmQyxZQUFVLENBRks7QUFHZkMsWUFBVSxDQUhLO0FBSWZDLGNBQVk7QUFKRyxDQUFqQjs7QUFPQSxTQUFTQyxVQUFULENBQW9CQyxNQUFwQixFQUE0QkMsS0FBNUIsRUFBbUM7QUFDakMsTUFBTUMsT0FBTyxJQUFJQyxLQUFKLENBQVVILE1BQVYsQ0FBYjtBQUNBLE9BQUssSUFBSUksSUFBSSxDQUFiLEVBQWdCQSxJQUFJRixLQUFLRyxNQUF6QixFQUFpQ0QsR0FBakMsRUFBc0M7QUFDcENGLFNBQUtFLENBQUwsSUFBVSxJQUFJRSxVQUFKLENBQWVMLEtBQWYsQ0FBVjtBQUNEO0FBQ0QsU0FBT0MsSUFBUDtBQUNEOztBQUVELFNBQVNLLHdCQUFULENBQWtDQyxDQUFsQyxFQUFxQ0MsQ0FBckMsRUFBd0M7QUFDdEM7QUFDQTtBQUNBLE1BQU1DLFVBQVVGLEVBQUVILE1BQWxCO0FBQ0EsTUFBTU0sVUFBVUYsRUFBRUos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QUNGOztBQUVEOzs7Ozs7OztBQVFlLFNBQVNoQyxXQUFULENBQXFCZSxDQUFyQixFQUF3QkMsQ0FBeEIsRUFBMkI7QUFDeEMsTUFBTW9CLGNBQWN0Qix5QkFBeUJDLENBQXpCLEVBQTRCQyxDQUE1QixDQUFwQjtBQUNBYSxnQkFBY08sV0FBZCxFQUEyQnJCLENBQTNCLEVBQThCQyxDQUE5QjtBQUNEIiwiZmlsZSI6IjEuanMiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBNT1ZFTUVOVCA9IHtcbiAgbm9uZTogMCxcbiAgZGlhZ29uYWw6IDEsXG4gIHZlcnRpY2FsOiAyLFxuICBob3Jpem9udGFsOiAzLFxufTtcblxuZnVuY3Rpb24gaW5pdE1hdHJpeChoZWlnaHQsIHdpZHRoKSB7XG4gIGNvbnN0IHJvd3MgPSBuZXcgQXJyYXkoaGVpZ2h0KTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCByb3dzLmxlbmd0aDsgaSsrKSB7XG4gICAgcm93c1tpXSA9IG5ldyBJbnQzMkFycmF5KHdpZHRoKTtcbiAgfVxuICByZXR1cm4gcm93cztcbn1cblxuZnVuY3Rpb24gbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlKGEsIGIpIHtcbiAgLy8gYWRhcHRlZCBmcm9tXG4gIC8vIGh0dHA6Ly9hbGdvcml0aG1zLnR1dG9yaWFsaG9yaXpvbi5jb20vZHluYW1pYy1wcm9ncmFtbWluZy1sb25nZXN0LWNvbW1vbi1zdWJzZXF1ZW5jZS9cbiAgY29uc3QgYUxlbmd0aCA9IGEubGVuZ3RoO1xuICBjb25zdCBiTGVuZ3RoID0gYi5sZW5ndGg7XG4gIGNvbnN0IG1lbW8gPSBpbml0TWF0cml4KGFMZW5ndGggKyAxLCBiTGVuZ3RoICsgMSk7XG4gIGNvbnN0IHNvbHV0aW9uID0gaW5pdE1hdHJpeChhTGVuZ3RoICsgMSwgYkxlbmd0aCArIDEpO1xuXG4gIC8vIExvb3AgYW5kIGZpbmQgdGhlIHNvbHV0aW9uXG4gIGZvciAobGV0IGkgPSAxOyBpIDw9IGFMZW5ndGg7IGkrKykge1xuICAgIGZvciAobGV0IGogPSAxOyBqIDw9IGJMZW5ndGg7IGorKykge1xuICAgICAgaWYgKGFbaSAtIDFdID09PSBiW2ogLSAxXSkge1xuICAgICAgICAvLyBkaWFnb25hbFxuICAgICAgICBtZW1vW2ldW2pdID0gbWVtb1tpIC0gMV1baiAtIDFdICsgMTtcbiAgICAgICAgc29sdXRpb25baV1bal0gPSBNT1ZFTUVOVC5kaWFnb25hbDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIG1lbW9baV1bal0gPSBNYXRoLm1heChtZW1vW2kgLSAxXVtqXSwgbWVtb1tpXVtqIC0gMV0pO1xuICAgICAgICBpZiAobWVtb1tpXVtqXSA9PT0gbWVtb1tpIC0gMV1bal0pIHtcbiAgICAgICAgICBzb2x1dGlvbltpXVtqXSA9IE1PVkVNRU5ULnZlcnRpY2FsO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHNvbHV0aW9uW2ldW2pdID0gTU9WRU1FTlQuaG9yaXpvbnRhbDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuICBjb25zb2xlLmxvZyhtZW1vW2FMZW5ndGhdW2JMZW5ndGhdKTtcbiAgcmV0dXJuIHNvbHV0aW9uO1xufVxuXG5mdW5jdGlvbiBwbGFjZWhvbGRlcnMoY291bnQpIHtcbiAgY29uc3QgcmVzdWx0ID0gbmV3IEFycmF5KGNvdW50KTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBjb3VudDsgaSsrKSB7XG4gICAgcmVzdWx0W2ldID0gJysnO1xuICB9XG4gIHJldHVybiByZXN1bHQ7XG59XG4vKipcbiAqIEFwcGx5IGFuIGxjcyBzb2x1dGlvbiB0byBhcnJheXMuIE5vdGUgdGhhdCB0aGlzIHdpbGwgTVVUQVRFIHRoZSBhcnJheXMsXG4gKiBpbmplY3RpbmcgXCIrXCIgd2hlcmUgZ2FwcyBhcmUgbmVlZGVkLlxuICpcbiAqIEBwYXJhbSB7QXJyYXk8QXJyYXk+fSBzb2x1dGlvbiBhcyBjb21wdXRlZCBieSBgbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlYFxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5mdW5jdGlvbiBhcHBseVNvbHV0aW9uKHNvbHV0aW9uLCBhLCBiKSB7XG4gIGxldCBtb3ZlbWVudCA9IHNvbHV0aW9uW2EubGVuZ3RoXVtiLmxlbmd0aF07XG4gIGxldCBhaSA9IGEubGVuZ3RoO1xuICBsZXQgYmkgPSBiLmxlbmd0aDtcblxuICBsZXQgY2hhbmdlcyA9IDA7XG5cbiAgd2hpbGUgKG1vdmVtZW50ICE9PSBNT1ZFTUVOVC5ub25lKSB7XG4gICAgaWYgKG1vdmVtZW50ID09PSBNT1ZFTUVOVC5kaWFnb25hbCkge1xuICAgICAgaWYgKGNoYW5nZXMgPCAwKSB7XG4gICAgICAgIGIuc3BsaWNlKGJpLCAwLCAuLi5wbGFjZWhvbGRlcnMoTWF0aC5hYnMoY2hhbmdlcykpKTtcbiAgICAgIH0gZWxzZSBpZiAoY2hhbmdlcyA+IDApIHtcbiAgICAgICAgYS5zcGxpY2UoYWksIDAsIC4uLnBsYWNlaG9sZGVycyhjaGFuZ2VzKSk7XG4gICAgICB9XG4gICAgICBhaS0tO1xuICAgICAgYmktLTtcbiAgICAgIGNoYW5nZXMgPSAwO1xuICAgIH0gZWxzZSBpZiAobW92ZW1lbnQgPT09IE1PVkVNRU5ULmhvcml6b250YWwpIHtcbiAgICAgIGJpLS07XG4gICAgICBjaGFuZ2VzKys7XG4gICAgfSBlbHNlIGlmIChtb3ZlbWVudCA9PT0gTU9WRU1FTlQudmVydGljYWwpIHtcbiAgICAgIGFpLS07XG4gICAgICBjaGFuZ2VzLS07XG4gICAgfVxuICAgIG1vdmVtZW50ID0gc29sdXRpb25bYWldW2JpXTtcbiAgfVxufVxuXG4vKipcbiAqIENvbXB1dGVzIHRoZSBsb25nZXN0IGNvbW1vbiBzdWJzZXF1ZW5jZSBvZiB0d28gYXJyYXlzLCB0aGVuIHVzZXMgdGhhdFxuICogc29sdXRpb24gdG8gaW5qZWN0IGdhcHMgaW50byB0aGUgYXJyYXlzLCBtYWtpbmcgdGhlbSBhbGlnbiBvbiBjb21tb25cbiAqIHN1YnNlcXVlbmNlcy5cbiAqXG4gKiBAcGFyYW0ge0FycmF5fSBhXG4gKiBAcGFyYW0ge0FycmF5fSBiXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFsaWduQXJyYXlzKGEsIGIpIHtcbiAgY29uc3QgbGNzU29sdXRpb24gPSBsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UoYSwgYik7XG4gIGFwcGx5U29sdXRpb24obGNzU29sdXRpb24sIGEsIGIpO1xufVxuXG5cblxuLyoqIFdFQlBBQ0sgRk9PVEVSICoqXG4gKiogLi9qcy9zcmMvYWxpZ25BcnJheXMuanNcbiAqKi8iXSwic291cmNlUm9vdCI6IiJ9");
|
54
|
+
|
55
|
+
/***/ }
|
56
|
+
/******/ ]);
|
@@ -0,0 +1 @@
|
|
1
|
+
!function(t){function r(e){if(a[e])return a[e].exports;var n=a[e]={exports:{},id:e,loaded:!1};return t[e].call(n.exports,n,n.exports,r),n.loaded=!0,n.exports}var a={};return r.m=t,r.c=a,r.p="",r(0)}([function(t,r,a){"use strict";function e(t){return t&&t.__esModule?t:{"default":t}}function n(t,r){for(var a=t.data,e=t.width,n=t.height,o=4*e,i=[],s=0;s<n;s++){for(var l=new Uint8ClampedArray(o+4*r),u=0;u<o;u++)l[u]=a[s*o+u];i.push(l)}return i}function o(t){var r=t.previousImageData,a=t.currentImageData,e=t.maxWidth,n=r.map(JSON.stringify);self.postMessage({progress:40});var o=a.map(JSON.stringify);self.postMessage({progress:60}),(0,l["default"])(n,o);var i=new Uint8ClampedArray(4*e);n.forEach(function(t,a){"+"===t&&r.splice(a,0,i)}),o.forEach(function(t,r){"+"===t&&a.splice(r,0,i)})}function i(t){var r=t.previousData,a=t.currentData,e=Math.max(r.width,a.width),i=n(r,e-r.width),s=n(a,e-a.width);return self.postMessage({progress:20}),o({previousImageData:i,currentImageData:s,maxWidth:e}),self.postMessage({progress:85}),{currentData:{data:s,height:s.length,width:e},previousData:{data:i,height:i.length,width:e}}}var s=a(1),l=e(s);self.addEventListener("message",function(t){var r=t.data,a=r.previousData,e=r.currentData,n=i({previousData:a,currentData:e});self.postMessage(n),self.close()})},function(t,r){"use strict";function a(t){if(Array.isArray(t)){for(var r=0,a=Array(t.length);r<t.length;r++)a[r]=t[r];return a}return Array.from(t)}function e(t,r){for(var a=new Array(t),e=0;e<a.length;e++)a[e]=new Int32Array(r);return a}function n(t,r){for(var a=t.length,n=r.length,o=e(a+1,n+1),i=e(a+1,n+1),s=1;s<=a;s++)for(var u=1;u<=n;u++)t[s-1]===r[u-1]?(o[s][u]=o[s-1][u-1]+1,i[s][u]=l.diagonal):(o[s][u]=Math.max(o[s-1][u],o[s][u-1]),o[s][u]===o[s-1][u]?i[s][u]=l.vertical:i[s][u]=l.horizontal);return i}function o(t){return new Array(t).fill(u)}function i(t,r,e){for(var n=t[r.length][e.length],i=r.length,s=e.length,u=0;n!==l.none;)n===l.diagonal?(u<0?e.splice.apply(e,[s,0].concat(a(o(Math.abs(u))))):u>0&&r.splice.apply(r,[i,0].concat(a(o(u)))),i--,s--,u=0):n===l.horizontal?(s--,u++):n===l.vertical&&(i--,u--),n=t[i][s];var c=r.length,f=e.length,h=c>f?e:r;h.splice.apply(h,[0,0].concat(a(o(Math.abs(c-f)))))}function s(t,r){var a=n(t,r);i(a,t,r)}Object.defineProperty(r,"__esModule",{value:!0}),r["default"]=s;var l={none:0,diagonal:1,vertical:2,horizontal:3},u="+"}]);
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/******/ (function(modules) { // webpackBootstrap
|
2
|
+
/******/ // The module cache
|
3
|
+
/******/ var installedModules = {};
|
4
|
+
|
5
|
+
/******/ // The require function
|
6
|
+
/******/ function __webpack_require__(moduleId) {
|
7
|
+
|
8
|
+
/******/ // Check if module is in cache
|
9
|
+
/******/ if(installedModules[moduleId])
|
10
|
+
/******/ return installedModules[moduleId].exports;
|
11
|
+
|
12
|
+
/******/ // Create a new module (and put it into the cache)
|
13
|
+
/******/ var module = installedModules[moduleId] = {
|
14
|
+
/******/ exports: {},
|
15
|
+
/******/ id: moduleId,
|
16
|
+
/******/ loaded: false
|
17
|
+
/******/ };
|
18
|
+
|
19
|
+
/******/ // Execute the module function
|
20
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
21
|
+
|
22
|
+
/******/ // Flag the module as loaded
|
23
|
+
/******/ module.loaded = true;
|
24
|
+
|
25
|
+
/******/ // Return the exports of the module
|
26
|
+
/******/ return module.exports;
|
27
|
+
/******/ }
|
28
|
+
|
29
|
+
|
30
|
+
/******/ // expose the modules object (__webpack_modules__)
|
31
|
+
/******/ __webpack_require__.m = modules;
|
32
|
+
|
33
|
+
/******/ // expose the module cache
|
34
|
+
/******/ __webpack_require__.c = installedModules;
|
35
|
+
|
36
|
+
/******/ // __webpack_public_path__
|
37
|
+
/******/ __webpack_require__.p = "";
|
38
|
+
|
39
|
+
/******/ // Load entry module and return exports
|
40
|
+
/******/ return __webpack_require__(0);
|
41
|
+
/******/ })
|
42
|
+
/************************************************************************/
|
43
|
+
/******/ ([
|
44
|
+
/* 0 */
|
45
|
+
/***/ function(module, exports, __webpack_require__) {
|
46
|
+
|
47
|
+
eval("'use strict';\n\nvar _alignArrays = __webpack_require__(1);\n\nvar _alignArrays2 = _interopRequireDefault(_alignArrays);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction imageTo2DArray(_ref, paddingRight) {\n var data = _ref.data;\n var width = _ref.width;\n var height = _ref.height;\n\n // The imageData is a 1D array. Each element in the array corresponds to a\n // decimal value that represents one of the RGBA channels for that pixel.\n var rowSize = width * 4;\n\n var newData = [];\n for (var row = 0; row < height; row++) {\n var pixelsInRow = new Uint8ClampedArray(rowSize + paddingRight * 4);\n for (var location = 0; location < rowSize; location++) {\n pixelsInRow[location] = data[row * rowSize + location];\n }\n newData.push(pixelsInRow);\n }\n return newData;\n}\n\nfunction align(_ref2) {\n var previousImageData = _ref2.previousImageData;\n var currentImageData = _ref2.currentImageData;\n var maxWidth = _ref2.maxWidth;\n\n var hashedPreviousData = previousImageData.map(JSON.stringify);\n self.postMessage({ progress: 40 });\n var hashedCurrentData = currentImageData.map(JSON.stringify);\n self.postMessage({ progress: 60 });\n\n (0, _alignArrays2.default)(hashedPreviousData, hashedCurrentData);\n\n var transparentLine = new Uint8ClampedArray(maxWidth * 4);\n\n hashedPreviousData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n previousImageData.splice(i, 0, transparentLine);\n }\n });\n\n hashedCurrentData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n currentImageData.splice(i, 0, transparentLine);\n }\n });\n}\n\n/**\n * Takes two 2d images, computes the diff between the two, and injects pixels to\n * both in order to:\n * a) make both images the same height\n * b) properly visualize differences\n *\n * Please note that this method MUTATES data.\n *\n * @param {Array} previousData\n * @param {Array} currentData\n */\nfunction computeAndInjectDiffs(_ref3) {\n var previousData = _ref3.previousData;\n var currentData = _ref3.currentData;\n\n var maxWidth = Math.max(previousData.width, currentData.width);\n\n var previousImageData = imageTo2DArray(previousData, maxWidth - previousData.width);\n\n var currentImageData = imageTo2DArray(currentData, maxWidth - currentData.width);\n\n self.postMessage({ progress: 20 });\n\n align({\n previousImageData: previousImageData,\n currentImageData: currentImageData,\n maxWidth: maxWidth\n });\n\n self.postMessage({ progress: 85 });\n\n return {\n currentData: {\n data: currentImageData,\n height: currentImageData.length,\n width: maxWidth\n },\n previousData: {\n data: previousImageData,\n height: previousImageData.length,\n width: maxWidth\n }\n };\n}\n\nself.addEventListener('message', function (_ref4) {\n var _ref4$data = _ref4.data;\n var previousData = _ref4$data.previousData;\n var currentData = _ref4$data.currentData;\n\n var result = computeAndInjectDiffs({ previousData: previousData, currentData: currentData });\n self.postMessage(result);\n self.close();\n});//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvd29ya2Vycy9Db21wdXRlQW5kSW5qZWN0RGlmZnNXb3JrZXIuanM/ZGRiNSJdLCJuYW1lcyI6WyJpbWFnZVRvMkRBcnJheSIsInBhZGRpbmdSaWdodCIsImRhdGEiLCJ3aWR0aCIsImhlaWdodCIsInJvd1NpemUiLCJuZXdEYXRhIiwicm93IiwicGl4ZWxzSW5Sb3ciLCJVaW50OENsYW1wZWRBcnJheSIsImxvY2F0aW9uIiwicHVzaCIsImFsaWduIiwicHJldmlvdXNJbWFnZURhdGEiLCJjdXJyZW50SW1hZ2VEYXRhIiwibWF4V2lkdGgiLCJoYXNoZWRQcmV2aW91c0RhdGEiLCJtYXAiLCJKU09OIiwic3RyaW5naWZ5Iiwic2VsZiIsInBvc3RNZXNzYWdlIiwicHJvZ3Jlc3MiLCJoYXNoZWRDdXJyZW50RGF0YSIsInRyYW5zcGFyZW50TGluZSIsImZvckVhY2giLCJoYXNoZWRMaW5lIiwiaSIsInNwbGljZSIsImNvbXB1dGVBbmRJbmplY3REaWZmcyIsInByZXZpb3VzRGF0YSIsImN1cnJlbnREYXRhIiwiTWF0aCIsIm1heCIsImxlbmd0aCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXN1bHQiLCJjbG9zZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0FBRUEsU0FBU0EsY0FBVCxPQUFpREMsWUFBakQsRUFBK0Q7QUFBQSxNQUFyQ0MsSUFBcUMsUUFBckNBLElBQXFDO0FBQUEsTUFBL0JDLEtBQStCLFFBQS9CQSxLQUErQjtBQUFBLE1BQXhCQyxNQUF3QixRQUF4QkEsTUFBd0I7O0FBQzdEO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixRQUFRLENBQXhCOztBQUVBLE1BQU1HLFVBQVUsRUFBaEI7QUFDQSxPQUFLLElBQUlDLE1BQU0sQ0FBZixFQUFrQkEsTUFBTUgsTUFBeEIsRUFBZ0NHLEtBQWhDLEVBQXVDO0FBQ3JDLFFBQU1DLGNBQWMsSUFBSUMsaUJBQUosQ0FBc0JKLFVBQVdKLGVBQWUsQ0FBaEQsQ0FBcEI7QUFDQSxT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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFsaWduQXJyYXlzIGZyb20gJy4uL2FsaWduQXJyYXlzJztcblxuZnVuY3Rpb24gaW1hZ2VUbzJEQXJyYXkoeyBkYXRhLCB3aWR0aCwgaGVpZ2h0IH0sIHBhZGRpbmdSaWdodCkge1xuICAvLyBUaGUgaW1hZ2VEYXRhIGlzIGEgMUQgYXJyYXkuIEVhY2ggZWxlbWVudCBpbiB0aGUgYXJyYXkgY29ycmVzcG9uZHMgdG8gYVxuICAvLyBkZWNpbWFsIHZhbHVlIHRoYXQgcmVwcmVzZW50cyBvbmUgb2YgdGhlIFJHQkEgY2hhbm5lbHMgZm9yIHRoYXQgcGl4ZWwuXG4gIGNvbnN0IHJvd1NpemUgPSB3aWR0aCAqIDQ7XG5cbiAgY29uc3QgbmV3RGF0YSA9IFtdO1xuICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCBoZWlnaHQ7IHJvdysrKSB7XG4gICAgY29uc3QgcGl4ZWxzSW5Sb3cgPSBuZXcgVWludDhDbGFtcGVkQXJyYXkocm93U2l6ZSArIChwYWRkaW5nUmlnaHQgKiA0KSk7XG4gICAgZm9yIChsZXQgbG9jYXRpb24gPSAwOyBsb2NhdGlvbiA8IHJvd1NpemU7IGxvY2F0aW9uKyspIHtcbiAgICAgIHBpeGVsc0luUm93W2xvY2F0aW9uXSA9IGRhdGFbKHJvdyAqIHJvd1NpemUpICsgbG9jYXRpb25dO1xuICAgIH1cbiAgICBuZXdEYXRhLnB1c2gocGl4ZWxzSW5Sb3cpO1xuICB9XG4gIHJldHVybiBuZXdEYXRhO1xufVxuXG5mdW5jdGlvbiBhbGlnbih7XG4gIHByZXZpb3VzSW1hZ2VEYXRhLFxuICBjdXJyZW50SW1hZ2VEYXRhLFxuICBtYXhXaWR0aCxcbn0pIHtcbiAgY29uc3QgaGFzaGVkUHJldmlvdXNEYXRhID0gcHJldmlvdXNJbWFnZURhdGEubWFwKEpTT04uc3RyaW5naWZ5KTtcbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA0MCB9KTtcbiAgY29uc3QgaGFzaGVkQ3VycmVudERhdGEgPSBjdXJyZW50SW1hZ2VEYXRhLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UoeyBwcm9ncmVzczogNjAgfSk7XG5cbiAgYWxpZ25BcnJheXMoXG4gICAgaGFzaGVkUHJldmlvdXNEYXRhLFxuICAgIGhhc2hlZEN1cnJlbnREYXRhXG4gICk7XG5cbiAgY29uc3QgdHJhbnNwYXJlbnRMaW5lID0gbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KG1heFdpZHRoICogNCk7XG5cbiAgaGFzaGVkUHJldmlvdXNEYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBwcmV2aW91c0ltYWdlRGF0YS5zcGxpY2UoaSwgMCwgdHJhbnNwYXJlbnRMaW5lKTtcbiAgICB9XG4gIH0pO1xuXG4gIGhhc2hlZEN1cnJlbnREYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBjdXJyZW50SW1hZ2VEYXRhLnNwbGljZShpLCAwLCB0cmFuc3BhcmVudExpbmUpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogVGFrZXMgdHdvIDJkIGltYWdlcywgY29tcHV0ZXMgdGhlIGRpZmYgYmV0d2VlbiB0aGUgdHdvLCBhbmQgaW5qZWN0cyBwaXhlbHMgdG9cbiAqIGJvdGggaW4gb3JkZXIgdG86XG4gKiBhKSBtYWtlIGJvdGggaW1hZ2VzIHRoZSBzYW1lIGhlaWdodFxuICogYikgcHJvcGVybHkgdmlzdWFsaXplIGRpZmZlcmVuY2VzXG4gKlxuICogUGxlYXNlIG5vdGUgdGhhdCB0aGlzIG1ldGhvZCBNVVRBVEVTIGRhdGEuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gcHJldmlvdXNEYXRhXG4gKiBAcGFyYW0ge0FycmF5fSBjdXJyZW50RGF0YVxuICovXG5mdW5jdGlvbiBjb21wdXRlQW5kSW5qZWN0RGlmZnMoeyBwcmV2aW91c0RhdGEsIGN1cnJlbnREYXRhIH0pIHtcbiAgY29uc3QgbWF4V2lkdGggPSBNYXRoLm1heChwcmV2aW91c0RhdGEud2lkdGgsIGN1cnJlbnREYXRhLndpZHRoKTtcblxuICBjb25zdCBwcmV2aW91c0ltYWdlRGF0YSA9IGltYWdlVG8yREFycmF5KFxuICAgIHByZXZpb3VzRGF0YSwgbWF4V2lkdGggLSBwcmV2aW91c0RhdGEud2lkdGgpO1xuXG4gIGNvbnN0IGN1cnJlbnRJbWFnZURhdGEgPSBpbWFnZVRvMkRBcnJheShcbiAgICBjdXJyZW50RGF0YSwgbWF4V2lkdGggLSBjdXJyZW50RGF0YS53aWR0aCk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiAyMCB9KTtcblxuICBhbGlnbih7XG4gICAgcHJldmlvdXNJbWFnZURhdGEsXG4gICAgY3VycmVudEltYWdlRGF0YSxcbiAgICBtYXhXaWR0aCxcbiAgfSk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA4NSB9KTtcblxuICByZXR1cm4ge1xuICAgIGN1cnJlbnREYXRhOiB7XG4gICAgICBkYXRhOiBjdXJyZW50SW1hZ2VEYXRhLFxuICAgICAgaGVpZ2h0OiBjdXJyZW50SW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICAgIHByZXZpb3VzRGF0YToge1xuICAgICAgZGF0YTogcHJldmlvdXNJbWFnZURhdGEsXG4gICAgICBoZWlnaHQ6IHByZXZpb3VzSW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICB9O1xufVxuXG5zZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCAoeyBkYXRhOiB7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSB9KSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IGNvbXB1dGVBbmRJbmplY3REaWZmcyh7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UocmVzdWx0KTtcbiAgc2VsZi5jbG9zZSgpO1xufSk7XG5cblxuXG4vKiogV0VCUEFDSyBGT09URVIgKipcbiAqKiAuL2pzL3NyYy93b3JrZXJzL0NvbXB1dGVBbmRJbmplY3REaWZmc1dvcmtlci5qc1xuICoqLyJdLCJzb3VyY2VSb290IjoiIn0=");
|
48
|
+
|
49
|
+
/***/ },
|
50
|
+
/* 1 */
|
51
|
+
/***/ function(module, exports) {
|
52
|
+
|
53
|
+
eval("'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = alignArrays;\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar MOVEMENT = {\n none: 0,\n diagonal: 1,\n vertical: 2,\n horizontal: 3\n};\n\nfunction initMatrix(height, width) {\n var rows = new Array(height);\n for (var i = 0; i < rows.length; i++) {\n rows[i] = new Int32Array(width);\n }\n return rows;\n}\n\nfunction longestCommonSubsequence(a, b) {\n // adapted from\n // http://algorithms.tutorialhorizon.com/dynamic-programming-longest-common-subsequence/\n var aLength = a.length;\n var bLength = b.length;\n var memo = initMatrix(aLength + 1, bLength + 1);\n var solution = initMatrix(aLength + 1, bLength + 1);\n\n // Loop and find the solution\n for (var i = 1; i <= aLength; i++) {\n for (var j = 1; j <= bLength; j++) {\n if (a[i - 1] === b[j - 1]) {\n // diagonal\n memo[i][j] = memo[i - 1][j - 1] + 1;\n solution[i][j] = MOVEMENT.diagonal;\n } else {\n memo[i][j] = Math.max(memo[i - 1][j], memo[i][j - 1]);\n if (memo[i][j] === memo[i - 1][j]) {\n solution[i][j] = MOVEMENT.vertical;\n } else {\n solution[i][j] = MOVEMENT.horizontal;\n }\n }\n }\n }\n if (memo[aLength][bLength] === 0) {\n // No soltuion found\n return null;\n }\n return solution;\n}\n\nfunction placeholders(count) {\n var result = new Array(count);\n for (var i = 0; i < count; i++) {\n result[i] = '+';\n }\n return result;\n}\n/**\n * Apply an lcs solution to arrays. Note that this will MUTATE the arrays,\n * injecting \"+\" where gaps are needed.\n *\n * @param {Array<Array>} solution as computed by `longestCommonSubsequence`\n * @param {Array} a\n * @param {Array} b\n */\nfunction applySolution(solution, a, b) {\n var movement = solution[a.length][b.length];\n var ai = a.length;\n var bi = b.length;\n var changes = 0;\n\n function applyChange() {\n if (changes < 0) {\n b.splice.apply(b, [bi, 0].concat(_toConsumableArray(placeholders(Math.abs(changes)))));\n } else if (changes > 0) {\n a.splice.apply(a, [ai, 0].concat(_toConsumableArray(placeholders(changes))));\n }\n changes = 0;\n }\n\n while (movement !== MOVEMENT.none) {\n if (movement === MOVEMENT.diagonal) {\n applyChange();\n ai--;\n bi--;\n } else if (movement === MOVEMENT.horizontal) {\n bi--;\n changes++;\n } else if (movement === MOVEMENT.vertical) {\n ai--;\n changes--;\n }\n movement = solution[ai][bi];\n }\n if (ai !== bi) {\n b.splice.apply(b, [0, 0].concat(_toConsumableArray(placeholders(bi))));\n a.splice.apply(a, [0, 0].concat(_toConsumableArray(placeholders(ai))));\n }\n}\n\n/**\n * To be called for arrays that share nothing in common.\n *\n * Note that this will MUTATE the arrays,\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction applyPadding(a, b) {\n var aLength = a.length;\n var bLength = b.length;\n var shorterArray = aLength > bLength ? b : a;\n shorterArray.push.apply(shorterArray, _toConsumableArray(placeholders(Math.abs(aLength - bLength))));\n}\n/**\n * Computes the longest common subsequence of two arrays, then uses that\n * solution to inject gaps into the arrays, making them align on common\n * subsequences.\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction alignArrays(a, b) {\n var lcsSolution = longestCommonSubsequence(a, b);\n if (lcsSolution) {\n applySolution(lcsSolution, a, b);\n } else {\n applyPadding(a, b);\n }\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvYWxpZ25BcnJheXMuanM/MDFiNyJdLCJuYW1lcyI6WyJhbGlnbkFycmF5cyIsIk1PVkVNRU5UIiwibm9uZSIsImRpYWdvbmFsIiwidmVydGljYWwiLCJob3Jpem9udGFsIiwiaW5pdE1hdHJpeCIsImhlaWdodCIsIndpZHRoIiwicm93cyIsIkFycmF5IiwiaSIsImxlbmd0aCIsIkludDMyQXJyYXkiLCJsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UiLCJhIiwiYiIsImFMZW5ndGgiLCJiTGVuZ3RoIiwibWVtbyIsInNvbHV0aW9uIiwiaiIsIk1hdGgiLCJtYXgiLCJwbGFjZWhvbGRlcnMiLCJjb3VudCIsInJlc3VsdCIsImFwcGx5U29sdXRpb24iLCJtb3ZlbWVudCIsImFpIiwiYmkiLCJjaGFuZ2VzIiwiYXBwbHlDaGFuZ2UiLCJzcGxpY2UiLCJhYnMiLCJhcHBseVBhZGRpbmciLCJzaG9ydGVyQXJyYXkiLCJwdXNoIiwibGNzU29sdXRpb24iXSwibWFwcGluZ3MiOiI7Ozs7O2tCQXVId0JBLFc7Ozs7QUF2SHhCLElBQU1DLFdBQVc7QUFDZkMsUUFBTSxDQURTO0FBRWZDLFlBQVUsQ0FGSztBQUdmQyxZQUFVLENBSEs7QUFJZkMsY0FBWTtBQUpHLENBQWpCOztBQU9BLFNBQVNDLFVBQVQsQ0FBb0JDLE1BQXBCLEVBQTRCQyxLQUE1QixFQUFtQztBQUNqQyxNQUFNQyxPQUFPLElBQUlDLEtBQUosQ0FBVUgsTUFBVixDQUFiO0FBQ0EsT0FBSyxJQUFJSSxJQUFJLENBQWIsRUFBZ0JBLElBQUlGLEtBQUtHLE1BQXpCLEVBQWlDRCxHQUFqQyxFQUFzQztBQUNwQ0YsU0FBS0UsQ0FBTCxJQUFVLElBQUlFLFVBQUosQ0FBZUwsS0FBZixDQUFWO0FBQ0Q7QUFDRCxTQUFPQyxJQUFQO0FBQ0Q7O0FBRUQsU0FBU0ssd0JBQVQsQ0FBa0NDLENBQWxDLEVBQXFDQyxDQUFyQyxFQUF3QztBQUN0QztBQUNBO0FBQ0EsTUFBTUMsVUFBVUYs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QixTQUFTRyxRQUExQixFQUFvQztBQUN6Q3lCO0FBQ0FFO0FBQ0Q7QUFDREgsZUFBV1IsU0FBU1MsRUFBVCxFQUFhQyxFQUFiLENBQVg7QUFDRDtBQUNELE1BQUlELE9BQU9DLEVBQVgsRUFBZTtBQUNiZCxNQUFFaUIsTUFBRixXQUFTLENBQVQsRUFBWSxDQUFaLDRCQUFrQlQsYUFBYU0sRUFBYixDQUFsQjtBQUNBZixNQUFFa0IsTUFBRixXQUFTLENBQVQsRUFBWSxDQUFaLDRCQUFrQlQsYUFBYUssRUFBYixDQUFsQjtBQUNEO0FBQ0Y7O0FBRUQ7Ozs7Ozs7O0FBUUEsU0FBU00sWUFBVCxDQUFzQnBCLENBQXRCLEVBQXlCQyxDQUF6QixFQUE0QjtBQUMxQixNQUFNQyxVQUFVRixFQUFFSCxNQUFsQjtBQUNBLE1BQU1NLFVBQVVGLEVBQUVKLE1BQWxCO0FBQ0EsTUFBTXdCLGVBQWVuQixVQUFVQyxPQUFWLEdBQW9CRixDQUFwQixHQUF3QkQsQ0FBN0M7QUFDQXFCLGVBQWFDLElBQWIsd0NBQXFCYixhQUFhRixLQUFLWSxHQUFMLENBQVNqQixVQUFVQyxPQUFuQixDQUFiLENBQXJCO0FBQ0Q7QUFDRDs7Ozs7Ozs7QUFRZSxTQUFTbEIsV0FBVCxDQUFxQmUsQ0FBckIsRUFBd0JDLENBQXhCLEVBQTJCO0FBQ3hDLE1BQU1zQixjQUFjeEIseUJBQXlCQyxDQUF6QixFQUE0QkMsQ0FBNUIsQ0FBcEI7QUFDQSxNQUFJc0IsV0FBSixFQUFpQjtBQUNmWCxrQkFBY1csV0FBZCxFQUEyQnZCLENBQTNCLEVBQThCQyxDQUE5QjtBQUNELEdBRkQsTUFFTztBQUNMbUIsaUJBQWFwQixDQUFiLEVBQWdCQyxDQUFoQjtBQUNEO0FBQ0YiLCJmaWxlIjoiMS5qcyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IE1PVkVNRU5UID0ge1xuICBub25lOiAwLFxuICBkaWFnb25hbDogMSxcbiAgdmVydGljYWw6IDIsXG4gIGhvcml6b250YWw6IDMsXG59O1xuXG5mdW5jdGlvbiBpbml0TWF0cml4KGhlaWdodCwgd2lkdGgpIHtcbiAgY29uc3Qgcm93cyA9IG5ldyBBcnJheShoZWlnaHQpO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IHJvd3MubGVuZ3RoOyBpKyspIHtcbiAgICByb3dzW2ldID0gbmV3IEludDMyQXJyYXkod2lkdGgpO1xuICB9XG4gIHJldHVybiByb3dzO1xufVxuXG5mdW5jdGlvbiBsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UoYSwgYikge1xuICAvLyBhZGFwdGVkIGZyb21cbiAgLy8gaHR0cDovL2FsZ29yaXRobXMudHV0b3JpYWxob3Jpem9uLmNvbS9keW5hbWljLXByb2dyYW1taW5nLWxvbmdlc3QtY29tbW9uLXN1YnNlcXVlbmNlL1xuICBjb25zdCBhTGVuZ3RoID0gYS5sZW5ndGg7XG4gIGNvbnN0IGJMZW5ndGggPSBiLmxlbmd0aDtcbiAgY29uc3QgbWVtbyA9IGluaXRNYXRyaXgoYUxlbmd0aCArIDEsIGJMZW5ndGggKyAxKTtcbiAgY29uc3Qgc29sdXRpb24gPSBpbml0TWF0cml4KGFMZW5ndGggKyAxLCBiTGVuZ3RoICsgMSk7XG5cbiAgLy8gTG9vcCBhbmQgZmluZCB0aGUgc29sdXRpb25cbiAgZm9yIChsZXQgaSA9IDE7IGkgPD0gYUxlbmd0aDsgaSsrKSB7XG4gICAgZm9yIChsZXQgaiA9IDE7IGogPD0gYkxlbmd0aDsgaisrKSB7XG4gICAgICBpZiAoYVtpIC0gMV0gPT09IGJbaiAtIDFdKSB7XG4gICAgICAgIC8vIGRpYWdvbmFsXG4gICAgICAgIG1lbW9baV1bal0gPSBtZW1vW2kgLSAxXVtqIC0gMV0gKyAxO1xuICAgICAgICBzb2x1dGlvbltpXVtqXSA9IE1PVkVNRU5ULmRpYWdvbmFsO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgbWVtb1tpXVtqXSA9IE1hdGgubWF4KG1lbW9baSAtIDFdW2pdLCBtZW1vW2ldW2ogLSAxXSk7XG4gICAgICAgIGlmIChtZW1vW2ldW2pdID09PSBtZW1vW2kgLSAxXVtqXSkge1xuICAgICAgICAgIHNvbHV0aW9uW2ldW2pdID0gTU9WRU1FTlQudmVydGljYWw7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc29sdXRpb25baV1bal0gPSBNT1ZFTUVOVC5ob3Jpem9udGFsO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGlmIChtZW1vW2FMZW5ndGhdW2JMZW5ndGhdID09PSAwKSB7XG4gICAgLy8gTm8gc29sdHVpb24gZm91bmRcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuICByZXR1cm4gc29sdXRpb247XG59XG5cbmZ1bmN0aW9uIHBsYWNlaG9sZGVycyhjb3VudCkge1xuICBjb25zdCByZXN1bHQgPSBuZXcgQXJyYXkoY291bnQpO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IGNvdW50OyBpKyspIHtcbiAgICByZXN1bHRbaV0gPSAnKyc7XG4gIH1cbiAgcmV0dXJuIHJlc3VsdDtcbn1cbi8qKlxuICogQXBwbHkgYW4gbGNzIHNvbHV0aW9uIHRvIGFycmF5cy4gTm90ZSB0aGF0IHRoaXMgd2lsbCBNVVRBVEUgdGhlIGFycmF5cyxcbiAqIGluamVjdGluZyBcIitcIiB3aGVyZSBnYXBzIGFyZSBuZWVkZWQuXG4gKlxuICogQHBhcmFtIHtBcnJheTxBcnJheT59IHNvbHV0aW9uIGFzIGNvbXB1dGVkIGJ5IGBsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2VgXG4gKiBAcGFyYW0ge0FycmF5fSBhXG4gKiBAcGFyYW0ge0FycmF5fSBiXG4gKi9cbmZ1bmN0aW9uIGFwcGx5U29sdXRpb24oc29sdXRpb24sIGEsIGIpIHtcbiAgbGV0IG1vdmVtZW50ID0gc29sdXRpb25bYS5sZW5ndGhdW2IubGVuZ3RoXTtcbiAgbGV0IGFpID0gYS5sZW5ndGg7XG4gIGxldCBiaSA9IGIubGVuZ3RoO1xuICBsZXQgY2hhbmdlcyA9IDA7XG5cbiAgZnVuY3Rpb24gYXBwbHlDaGFuZ2UoKSB7XG4gICAgaWYgKGNoYW5nZXMgPCAwKSB7XG4gICAgICBiLnNwbGljZShiaSwgMCwgLi4ucGxhY2Vob2xkZXJzKE1hdGguYWJzKGNoYW5nZXMpKSk7XG4gICAgfSBlbHNlIGlmIChjaGFuZ2VzID4gMCkge1xuICAgICAgYS5zcGxpY2UoYWksIDAsIC4uLnBsYWNlaG9sZGVycyhjaGFuZ2VzKSk7XG4gICAgfVxuICAgIGNoYW5nZXMgPSAwO1xuICB9XG5cbiAgd2hpbGUgKG1vdmVtZW50ICE9PSBNT1ZFTUVOVC5ub25lKSB7XG4gICAgaWYgKG1vdmVtZW50ID09PSBNT1ZFTUVOVC5kaWFnb25hbCkge1xuICAgICAgYXBwbHlDaGFuZ2UoKTtcbiAgICAgIGFpLS07XG4gICAgICBiaS0tO1xuICAgIH0gZWxzZSBpZiAobW92ZW1lbnQgPT09IE1PVkVNRU5ULmhvcml6b250YWwpIHtcbiAgICAgIGJpLS07XG4gICAgICBjaGFuZ2VzKys7XG4gICAgfSBlbHNlIGlmIChtb3ZlbWVudCA9PT0gTU9WRU1FTlQudmVydGljYWwpIHtcbiAgICAgIGFpLS07XG4gICAgICBjaGFuZ2VzLS07XG4gICAgfVxuICAgIG1vdmVtZW50ID0gc29sdXRpb25bYWldW2JpXTtcbiAgfVxuICBpZiAoYWkgIT09IGJpKSB7XG4gICAgYi5zcGxpY2UoMCwgMCwgLi4ucGxhY2Vob2xkZXJzKGJpKSk7XG4gICAgYS5zcGxpY2UoMCwgMCwgLi4ucGxhY2Vob2xkZXJzKGFpKSk7XG4gIH1cbn1cblxuLyoqXG4gKiBUbyBiZSBjYWxsZWQgZm9yIGFycmF5cyB0aGF0IHNoYXJlIG5vdGhpbmcgaW4gY29tbW9uLlxuICpcbiAqIE5vdGUgdGhhdCB0aGlzIHdpbGwgTVVUQVRFIHRoZSBhcnJheXMsXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5mdW5jdGlvbiBhcHBseVBhZGRpbmcoYSwgYikge1xuICBjb25zdCBhTGVuZ3RoID0gYS5sZW5ndGg7XG4gIGNvbnN0IGJMZW5ndGggPSBiLmxlbmd0aDtcbiAgY29uc3Qgc2hvcnRlckFycmF5ID0gYUxlbmd0aCA+IGJMZW5ndGggPyBiIDogYTtcbiAgc2hvcnRlckFycmF5LnB1c2goLi4ucGxhY2Vob2xkZXJzKE1hdGguYWJzKGFMZW5ndGggLSBiTGVuZ3RoKSkpO1xufVxuLyoqXG4gKiBDb21wdXRlcyB0aGUgbG9uZ2VzdCBjb21tb24gc3Vic2VxdWVuY2Ugb2YgdHdvIGFycmF5cywgdGhlbiB1c2VzIHRoYXRcbiAqIHNvbHV0aW9uIHRvIGluamVjdCBnYXBzIGludG8gdGhlIGFycmF5cywgbWFraW5nIHRoZW0gYWxpZ24gb24gY29tbW9uXG4gKiBzdWJzZXF1ZW5jZXMuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhbGlnbkFycmF5cyhhLCBiKSB7XG4gIGNvbnN0IGxjc1NvbHV0aW9uID0gbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlKGEsIGIpO1xuICBpZiAobGNzU29sdXRpb24pIHtcbiAgICBhcHBseVNvbHV0aW9uKGxjc1NvbHV0aW9uLCBhLCBiKTtcbiAgfSBlbHNlIHtcbiAgICBhcHBseVBhZGRpbmcoYSwgYik7XG4gIH1cbn1cblxuXG5cbi8qKiBXRUJQQUNLIEZPT1RFUiAqKlxuICoqIC4vanMvc3JjL2FsaWduQXJyYXlzLmpzXG4gKiovIl0sInNvdXJjZVJvb3QiOiIifQ==");
|
54
|
+
|
55
|
+
/***/ }
|
56
|
+
/******/ ]);
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/******/ (function(modules) { // webpackBootstrap
|
2
|
+
/******/ // The module cache
|
3
|
+
/******/ var installedModules = {};
|
4
|
+
|
5
|
+
/******/ // The require function
|
6
|
+
/******/ function __webpack_require__(moduleId) {
|
7
|
+
|
8
|
+
/******/ // Check if module is in cache
|
9
|
+
/******/ if(installedModules[moduleId])
|
10
|
+
/******/ return installedModules[moduleId].exports;
|
11
|
+
|
12
|
+
/******/ // Create a new module (and put it into the cache)
|
13
|
+
/******/ var module = installedModules[moduleId] = {
|
14
|
+
/******/ exports: {},
|
15
|
+
/******/ id: moduleId,
|
16
|
+
/******/ loaded: false
|
17
|
+
/******/ };
|
18
|
+
|
19
|
+
/******/ // Execute the module function
|
20
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
21
|
+
|
22
|
+
/******/ // Flag the module as loaded
|
23
|
+
/******/ module.loaded = true;
|
24
|
+
|
25
|
+
/******/ // Return the exports of the module
|
26
|
+
/******/ return module.exports;
|
27
|
+
/******/ }
|
28
|
+
|
29
|
+
|
30
|
+
/******/ // expose the modules object (__webpack_modules__)
|
31
|
+
/******/ __webpack_require__.m = modules;
|
32
|
+
|
33
|
+
/******/ // expose the module cache
|
34
|
+
/******/ __webpack_require__.c = installedModules;
|
35
|
+
|
36
|
+
/******/ // __webpack_public_path__
|
37
|
+
/******/ __webpack_require__.p = "";
|
38
|
+
|
39
|
+
/******/ // Load entry module and return exports
|
40
|
+
/******/ return __webpack_require__(0);
|
41
|
+
/******/ })
|
42
|
+
/************************************************************************/
|
43
|
+
/******/ ([
|
44
|
+
/* 0 */
|
45
|
+
/***/ function(module, exports, __webpack_require__) {
|
46
|
+
|
47
|
+
eval("'use strict';\n\nvar _alignArrays = __webpack_require__(1);\n\nvar _alignArrays2 = _interopRequireDefault(_alignArrays);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction imageTo2DArray(_ref, paddingRight) {\n var data = _ref.data;\n var width = _ref.width;\n var height = _ref.height;\n\n // The imageData is a 1D array. Each element in the array corresponds to a\n // decimal value that represents one of the RGBA channels for that pixel.\n var rowSize = width * 4;\n\n var newData = [];\n for (var row = 0; row < height; row++) {\n var pixelsInRow = new Uint8ClampedArray(rowSize + paddingRight * 4);\n for (var location = 0; location < rowSize; location++) {\n pixelsInRow[location] = data[row * rowSize + location];\n }\n newData.push(pixelsInRow);\n }\n return newData;\n}\n\nfunction align(_ref2) {\n var previousImageData = _ref2.previousImageData;\n var currentImageData = _ref2.currentImageData;\n var maxWidth = _ref2.maxWidth;\n\n var hashedPreviousData = previousImageData.map(JSON.stringify);\n self.postMessage({ progress: 40 });\n var hashedCurrentData = currentImageData.map(JSON.stringify);\n self.postMessage({ progress: 60 });\n\n (0, _alignArrays2.default)(hashedPreviousData, hashedCurrentData);\n\n var transparentLine = new Uint8ClampedArray(maxWidth * 4);\n\n hashedPreviousData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n previousImageData.splice(i, 0, transparentLine);\n }\n });\n\n hashedCurrentData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n currentImageData.splice(i, 0, transparentLine);\n }\n });\n}\n\n/**\n * Takes two 2d images, computes the diff between the two, and injects pixels to\n * both in order to:\n * a) make both images the same height\n * b) properly visualize differences\n *\n * Please note that this method MUTATES data.\n *\n * @param {Array} previousData\n * @param {Array} currentData\n */\nfunction computeAndInjectDiffs(_ref3) {\n var previousData = _ref3.previousData;\n var currentData = _ref3.currentData;\n\n var maxWidth = Math.max(previousData.width, currentData.width);\n\n var previousImageData = imageTo2DArray(previousData, maxWidth - previousData.width);\n\n var currentImageData = imageTo2DArray(currentData, maxWidth - currentData.width);\n\n self.postMessage({ progress: 20 });\n\n align({\n previousImageData: previousImageData,\n currentImageData: currentImageData,\n maxWidth: maxWidth\n });\n\n self.postMessage({ progress: 85 });\n\n return {\n currentData: {\n data: currentImageData,\n height: currentImageData.length,\n width: maxWidth\n },\n previousData: {\n data: previousImageData,\n height: previousImageData.length,\n width: maxWidth\n }\n };\n}\n\nself.addEventListener('message', function (_ref4) {\n var _ref4$data = _ref4.data;\n var previousData = _ref4$data.previousData;\n var currentData = _ref4$data.currentData;\n\n var result = computeAndInjectDiffs({ previousData: previousData, currentData: currentData });\n self.postMessage(result);\n self.close();\n});//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvd29ya2Vycy9Db21wdXRlQW5kSW5qZWN0RGlmZnNXb3JrZXIuanM/ZGRiNSJdLCJuYW1lcyI6WyJpbWFnZVRvMkRBcnJheSIsInBhZGRpbmdSaWdodCIsImRhdGEiLCJ3aWR0aCIsImhlaWdodCIsInJvd1NpemUiLCJuZXdEYXRhIiwicm93IiwicGl4ZWxzSW5Sb3ciLCJVaW50OENsYW1wZWRBcnJheSIsImxvY2F0aW9uIiwicHVzaCIsImFsaWduIiwicHJldmlvdXNJbWFnZURhdGEiLCJjdXJyZW50SW1hZ2VEYXRhIiwibWF4V2lkdGgiLCJoYXNoZWRQcmV2aW91c0RhdGEiLCJtYXAiLCJKU09OIiwic3RyaW5naWZ5Iiwic2VsZiIsInBvc3RNZXNzYWdlIiwicHJvZ3Jlc3MiLCJoYXNoZWRDdXJyZW50RGF0YSIsInRyYW5zcGFyZW50TGluZSIsImZvckVhY2giLCJoYXNoZWRMaW5lIiwiaSIsInNwbGljZSIsImNvbXB1dGVBbmRJbmplY3REaWZmcyIsInByZXZpb3VzRGF0YSIsImN1cnJlbnREYXRhIiwiTWF0aCIsIm1heCIsImxlbmd0aCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXN1bHQiLCJjbG9zZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0FBRUEsU0FBU0EsY0FBVCxPQUFpREMsWUFBakQsRUFBK0Q7QUFBQSxNQUFyQ0MsSUFBcUMsUUFBckNBLElBQXFDO0FBQUEsTUFBL0JDLEtBQStCLFFBQS9CQSxLQUErQjtBQUFBLE1BQXhCQyxNQUF3QixRQUF4QkEsTUFBd0I7O0FBQzdEO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixRQUFRLENBQXhCOztBQUVBLE1BQU1HLFVBQVUsRUFBaEI7QUFDQSxPQUFLLElBQUlDLE1BQU0sQ0FBZixFQUFrQkEsTUFBTUgsTUFBeEIsRUFBZ0NHLEtBQWhDLEVBQXVDO0FBQ3JDLFFBQU1DLGNBQWMsSUFBSUMsaUJBQUosQ0FBc0JKLFVBQVdKLGVBQWUsQ0FBaEQsQ0FBcEI7QUFDQSxT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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFsaWduQXJyYXlzIGZyb20gJy4uL2FsaWduQXJyYXlzJztcblxuZnVuY3Rpb24gaW1hZ2VUbzJEQXJyYXkoeyBkYXRhLCB3aWR0aCwgaGVpZ2h0IH0sIHBhZGRpbmdSaWdodCkge1xuICAvLyBUaGUgaW1hZ2VEYXRhIGlzIGEgMUQgYXJyYXkuIEVhY2ggZWxlbWVudCBpbiB0aGUgYXJyYXkgY29ycmVzcG9uZHMgdG8gYVxuICAvLyBkZWNpbWFsIHZhbHVlIHRoYXQgcmVwcmVzZW50cyBvbmUgb2YgdGhlIFJHQkEgY2hhbm5lbHMgZm9yIHRoYXQgcGl4ZWwuXG4gIGNvbnN0IHJvd1NpemUgPSB3aWR0aCAqIDQ7XG5cbiAgY29uc3QgbmV3RGF0YSA9IFtdO1xuICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCBoZWlnaHQ7IHJvdysrKSB7XG4gICAgY29uc3QgcGl4ZWxzSW5Sb3cgPSBuZXcgVWludDhDbGFtcGVkQXJyYXkocm93U2l6ZSArIChwYWRkaW5nUmlnaHQgKiA0KSk7XG4gICAgZm9yIChsZXQgbG9jYXRpb24gPSAwOyBsb2NhdGlvbiA8IHJvd1NpemU7IGxvY2F0aW9uKyspIHtcbiAgICAgIHBpeGVsc0luUm93W2xvY2F0aW9uXSA9IGRhdGFbKHJvdyAqIHJvd1NpemUpICsgbG9jYXRpb25dO1xuICAgIH1cbiAgICBuZXdEYXRhLnB1c2gocGl4ZWxzSW5Sb3cpO1xuICB9XG4gIHJldHVybiBuZXdEYXRhO1xufVxuXG5mdW5jdGlvbiBhbGlnbih7XG4gIHByZXZpb3VzSW1hZ2VEYXRhLFxuICBjdXJyZW50SW1hZ2VEYXRhLFxuICBtYXhXaWR0aCxcbn0pIHtcbiAgY29uc3QgaGFzaGVkUHJldmlvdXNEYXRhID0gcHJldmlvdXNJbWFnZURhdGEubWFwKEpTT04uc3RyaW5naWZ5KTtcbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA0MCB9KTtcbiAgY29uc3QgaGFzaGVkQ3VycmVudERhdGEgPSBjdXJyZW50SW1hZ2VEYXRhLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UoeyBwcm9ncmVzczogNjAgfSk7XG5cbiAgYWxpZ25BcnJheXMoXG4gICAgaGFzaGVkUHJldmlvdXNEYXRhLFxuICAgIGhhc2hlZEN1cnJlbnREYXRhXG4gICk7XG5cbiAgY29uc3QgdHJhbnNwYXJlbnRMaW5lID0gbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KG1heFdpZHRoICogNCk7XG5cbiAgaGFzaGVkUHJldmlvdXNEYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBwcmV2aW91c0ltYWdlRGF0YS5zcGxpY2UoaSwgMCwgdHJhbnNwYXJlbnRMaW5lKTtcbiAgICB9XG4gIH0pO1xuXG4gIGhhc2hlZEN1cnJlbnREYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBjdXJyZW50SW1hZ2VEYXRhLnNwbGljZShpLCAwLCB0cmFuc3BhcmVudExpbmUpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogVGFrZXMgdHdvIDJkIGltYWdlcywgY29tcHV0ZXMgdGhlIGRpZmYgYmV0d2VlbiB0aGUgdHdvLCBhbmQgaW5qZWN0cyBwaXhlbHMgdG9cbiAqIGJvdGggaW4gb3JkZXIgdG86XG4gKiBhKSBtYWtlIGJvdGggaW1hZ2VzIHRoZSBzYW1lIGhlaWdodFxuICogYikgcHJvcGVybHkgdmlzdWFsaXplIGRpZmZlcmVuY2VzXG4gKlxuICogUGxlYXNlIG5vdGUgdGhhdCB0aGlzIG1ldGhvZCBNVVRBVEVTIGRhdGEuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gcHJldmlvdXNEYXRhXG4gKiBAcGFyYW0ge0FycmF5fSBjdXJyZW50RGF0YVxuICovXG5mdW5jdGlvbiBjb21wdXRlQW5kSW5qZWN0RGlmZnMoeyBwcmV2aW91c0RhdGEsIGN1cnJlbnREYXRhIH0pIHtcbiAgY29uc3QgbWF4V2lkdGggPSBNYXRoLm1heChwcmV2aW91c0RhdGEud2lkdGgsIGN1cnJlbnREYXRhLndpZHRoKTtcblxuICBjb25zdCBwcmV2aW91c0ltYWdlRGF0YSA9IGltYWdlVG8yREFycmF5KFxuICAgIHByZXZpb3VzRGF0YSwgbWF4V2lkdGggLSBwcmV2aW91c0RhdGEud2lkdGgpO1xuXG4gIGNvbnN0IGN1cnJlbnRJbWFnZURhdGEgPSBpbWFnZVRvMkRBcnJheShcbiAgICBjdXJyZW50RGF0YSwgbWF4V2lkdGggLSBjdXJyZW50RGF0YS53aWR0aCk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiAyMCB9KTtcblxuICBhbGlnbih7XG4gICAgcHJldmlvdXNJbWFnZURhdGEsXG4gICAgY3VycmVudEltYWdlRGF0YSxcbiAgICBtYXhXaWR0aCxcbiAgfSk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA4NSB9KTtcblxuICByZXR1cm4ge1xuICAgIGN1cnJlbnREYXRhOiB7XG4gICAgICBkYXRhOiBjdXJyZW50SW1hZ2VEYXRhLFxuICAgICAgaGVpZ2h0OiBjdXJyZW50SW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICAgIHByZXZpb3VzRGF0YToge1xuICAgICAgZGF0YTogcHJldmlvdXNJbWFnZURhdGEsXG4gICAgICBoZWlnaHQ6IHByZXZpb3VzSW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICB9O1xufVxuXG5zZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCAoeyBkYXRhOiB7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSB9KSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IGNvbXB1dGVBbmRJbmplY3REaWZmcyh7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UocmVzdWx0KTtcbiAgc2VsZi5jbG9zZSgpO1xufSk7XG5cblxuXG4vKiogV0VCUEFDSyBGT09URVIgKipcbiAqKiAuL2pzL3NyYy93b3JrZXJzL0NvbXB1dGVBbmRJbmplY3REaWZmc1dvcmtlci5qc1xuICoqLyJdLCJzb3VyY2VSb290IjoiIn0=");
|
48
|
+
|
49
|
+
/***/ },
|
50
|
+
/* 1 */
|
51
|
+
/***/ function(module, exports) {
|
52
|
+
|
53
|
+
eval("'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = alignArrays;\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar MOVEMENT = {\n none: 0,\n diagonal: 1,\n vertical: 2,\n horizontal: 3\n};\n\nfunction initMatrix(height, width) {\n var rows = new Array(height);\n for (var i = 0; i < rows.length; i++) {\n rows[i] = new Int32Array(width);\n }\n return rows;\n}\n\nfunction longestCommonSubsequence(a, b) {\n // adapted from\n // http://algorithms.tutorialhorizon.com/dynamic-programming-longest-common-subsequence/\n var aLength = a.length;\n var bLength = b.length;\n var memo = initMatrix(aLength + 1, bLength + 1);\n var solution = initMatrix(aLength + 1, bLength + 1);\n\n // Loop and find the solution\n for (var i = 1; i <= aLength; i++) {\n for (var j = 1; j <= bLength; j++) {\n if (a[i - 1] === b[j - 1]) {\n // diagonal\n memo[i][j] = memo[i - 1][j - 1] + 1;\n solution[i][j] = MOVEMENT.diagonal;\n } else {\n memo[i][j] = Math.max(memo[i - 1][j], memo[i][j - 1]);\n if (memo[i][j] === memo[i - 1][j]) {\n solution[i][j] = MOVEMENT.vertical;\n } else {\n solution[i][j] = MOVEMENT.horizontal;\n }\n }\n }\n }\n console.log(memo);\n return solution;\n}\n\nfunction placeholders(count) {\n var result = new Array(count);\n for (var i = 0; i < count; i++) {\n result[i] = '+';\n }\n return result;\n}\n/**\n * Apply an lcs solution to arrays. Note that this will MUTATE the arrays,\n * injecting \"+\" where gaps are needed.\n *\n * @param {Array<Array>} solution as computed by `longestCommonSubsequence`\n * @param {Array} a\n * @param {Array} b\n */\nfunction applySolution(solution, a, b) {\n var movement = solution[a.length][b.length];\n var ai = a.length;\n var bi = b.length;\n\n while (movement !== MOVEMENT.none) {\n if (movement === MOVEMENT.diagonal) {\n var diffI = ai - bi;\n if (diffI < 0) {\n b.splice.apply(b, [bi, 0].concat(_toConsumableArray(placeholders(diffI))));\n } else if (diffI > 0) {\n a.splice.apply(a, [ai, 0].concat(_toConsumableArray(placeholders(Math.abs(diffI)))));\n }\n ai--;\n bi--;\n } else if (movement === MOVEMENT.horizontal) {\n bi--;\n } else if (movement === MOVEMENT.vertical) {\n ai--;\n }\n movement = solution[ai][bi];\n }\n}\n\n/**\n * Computes the longest common subsequence of two arrays, then uses that\n * solution to inject gaps into the arrays, making them align on common\n * subsequences.\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction alignArrays(a, b) {\n var lcsSolution = longestCommonSubsequence(a, b);\n applySolution(lcsSolution, a, b);\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvYWxpZ25BcnJheXMuanM/MDFiNyJdLCJuYW1lcyI6WyJhbGlnbkFycmF5cyIsIk1PVkVNRU5UIiwibm9uZSIsImRpYWdvbmFsIiwidmVydGljYWwiLCJob3Jpem9udGFsIiwiaW5pdE1hdHJpeCIsImhlaWdodCIsIndpZHRoIiwicm93cyIsIkFycmF5IiwiaSIsImxlbmd0aCIsIkludDMyQXJyYXkiLCJsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UiLCJhIiwiYiIsImFMZW5ndGgiLCJiTGVuZ3RoIiwibWVtbyIsInNvbHV0aW9uIiwiaiIsIk1hdGgiLCJtYXgiLCJjb25zb2xlIiwibG9nIiwicGxhY2Vob2xkZXJzIiwiY291bnQiLCJyZXN1bHQiLCJhcHBseVNvbHV0aW9uIiwibW92ZW1lbnQiLCJhaSIsImJpIiwiZGlmZkkiLCJzcGxpY2UiLCJhYnMiLCJsY3NTb2x1dGlvbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7a0JBMkZ3QkEsVzs7OztBQTNGeEIsSUFBTUMsV0FBVztBQUNmQyxRQUFNLENBRFM7QUFFZkMsWUFBVSxDQUZLO0FBR2ZDLFlBQVUsQ0FISztBQUlmQyxjQUFZO0FBSkcsQ0FBakI7O0FBT0EsU0FBU0MsVUFBVCxDQUFvQkMsTUFBcEIsRUFBNEJDLEtBQTVCLEVBQW1DO0FBQ2pDLE1BQU1DLE9BQU8sSUFBSUMsS0FBSixDQUFVSCxNQUFWLENBQWI7QUFDQSxPQUFLLElBQUlJLElBQUksQ0FBYixFQUFnQkEsSUFBSUYsS0FBS0csTUFBekIsRUFBaUNELEdBQWpDLEVBQXNDO0FBQ3BDRixTQUFLRSxDQUFMLElBQVUsSUFBSUUsVUFBSixDQUFlTCxLQUFmLENBQVY7QUFDRDtBQUNELFNBQU9DLElBQVA7QUFDRDs7QUFFRCxTQUFTSyx3QkFBVCxDQUFrQ0MsQ0FBbEMsRUFBcUNDLENBQXJDLEVBQXdDO0FBQ3RDO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixFQUFFSCxNQUFsQjtBQUNBLE1BQU1NLFVBQVVGLEVBQUVKLE1B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QUF3QkMsQ0FBeEIsRUFBMkI7QUFDeEMsTUFBTW9CLGNBQWN0Qix5QkFBeUJDLENBQXpCLEVBQTRCQyxDQUE1QixDQUFwQjtBQUNBYSxnQkFBY08sV0FBZCxFQUEyQnJCLENBQTNCLEVBQThCQyxDQUE5QjtBQUNEIiwiZmlsZSI6IjEuanMiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBNT1ZFTUVOVCA9IHtcbiAgbm9uZTogMCxcbiAgZGlhZ29uYWw6IDEsXG4gIHZlcnRpY2FsOiAyLFxuICBob3Jpem9udGFsOiAzLFxufTtcblxuZnVuY3Rpb24gaW5pdE1hdHJpeChoZWlnaHQsIHdpZHRoKSB7XG4gIGNvbnN0IHJvd3MgPSBuZXcgQXJyYXkoaGVpZ2h0KTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCByb3dzLmxlbmd0aDsgaSsrKSB7XG4gICAgcm93c1tpXSA9IG5ldyBJbnQzMkFycmF5KHdpZHRoKTtcbiAgfVxuICByZXR1cm4gcm93cztcbn1cblxuZnVuY3Rpb24gbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlKGEsIGIpIHtcbiAgLy8gYWRhcHRlZCBmcm9tXG4gIC8vIGh0dHA6Ly9hbGdvcml0aG1zLnR1dG9yaWFsaG9yaXpvbi5jb20vZHluYW1pYy1wcm9ncmFtbWluZy1sb25nZXN0LWNvbW1vbi1zdWJzZXF1ZW5jZS9cbiAgY29uc3QgYUxlbmd0aCA9IGEubGVuZ3RoO1xuICBjb25zdCBiTGVuZ3RoID0gYi5sZW5ndGg7XG4gIGNvbnN0IG1lbW8gPSBpbml0TWF0cml4KGFMZW5ndGggKyAxLCBiTGVuZ3RoICsgMSk7XG4gIGNvbnN0IHNvbHV0aW9uID0gaW5pdE1hdHJpeChhTGVuZ3RoICsgMSwgYkxlbmd0aCArIDEpO1xuXG4gIC8vIExvb3AgYW5kIGZpbmQgdGhlIHNvbHV0aW9uXG4gIGZvciAobGV0IGkgPSAxOyBpIDw9IGFMZW5ndGg7IGkrKykge1xuICAgIGZvciAobGV0IGogPSAxOyBqIDw9IGJMZW5ndGg7IGorKykge1xuICAgICAgaWYgKGFbaSAtIDFdID09PSBiW2ogLSAxXSkge1xuICAgICAgICAvLyBkaWFnb25hbFxuICAgICAgICBtZW1vW2ldW2pdID0gbWVtb1tpIC0gMV1baiAtIDFdICsgMTtcbiAgICAgICAgc29sdXRpb25baV1bal0gPSBNT1ZFTUVOVC5kaWFnb25hbDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIG1lbW9baV1bal0gPSBNYXRoLm1heChtZW1vW2kgLSAxXVtqXSwgbWVtb1tpXVtqIC0gMV0pO1xuICAgICAgICBpZiAobWVtb1tpXVtqXSA9PT0gbWVtb1tpIC0gMV1bal0pIHtcbiAgICAgICAgICBzb2x1dGlvbltpXVtqXSA9IE1PVkVNRU5ULnZlcnRpY2FsO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHNvbHV0aW9uW2ldW2pdID0gTU9WRU1FTlQuaG9yaXpvbnRhbDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuICBjb25zb2xlLmxvZyhtZW1vKVxuICByZXR1cm4gc29sdXRpb247XG59XG5cbmZ1bmN0aW9uIHBsYWNlaG9sZGVycyhjb3VudCkge1xuICBjb25zdCByZXN1bHQgPSBuZXcgQXJyYXkoY291bnQpO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IGNvdW50OyBpKyspIHtcbiAgICByZXN1bHRbaV0gPSAnKyc7XG4gIH1cbiAgcmV0dXJuIHJlc3VsdDtcbn1cbi8qKlxuICogQXBwbHkgYW4gbGNzIHNvbHV0aW9uIHRvIGFycmF5cy4gTm90ZSB0aGF0IHRoaXMgd2lsbCBNVVRBVEUgdGhlIGFycmF5cyxcbiAqIGluamVjdGluZyBcIitcIiB3aGVyZSBnYXBzIGFyZSBuZWVkZWQuXG4gKlxuICogQHBhcmFtIHtBcnJheTxBcnJheT59IHNvbHV0aW9uIGFzIGNvbXB1dGVkIGJ5IGBsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2VgXG4gKiBAcGFyYW0ge0FycmF5fSBhXG4gKiBAcGFyYW0ge0FycmF5fSBiXG4gKi9cbmZ1bmN0aW9uIGFwcGx5U29sdXRpb24oc29sdXRpb24sIGEsIGIpIHtcbiAgbGV0IG1vdmVtZW50ID0gc29sdXRpb25bYS5sZW5ndGhdW2IubGVuZ3RoXTtcbiAgbGV0IGFpID0gYS5sZW5ndGg7XG4gIGxldCBiaSA9IGIubGVuZ3RoO1xuXG4gIHdoaWxlIChtb3ZlbWVudCAhPT0gTU9WRU1FTlQubm9uZSkge1xuICAgIGlmIChtb3ZlbWVudCA9PT0gTU9WRU1FTlQuZGlhZ29uYWwpIHtcbiAgICAgIGNvbnN0IGRpZmZJID0gYWkgLSBiaTtcbiAgICAgIGlmIChkaWZmSSA8IDApIHtcbiAgICAgICAgYi5zcGxpY2UoYmksIDAsIC4uLnBsYWNlaG9sZGVycyhkaWZmSSkpO1xuICAgICAgfSBlbHNlIGlmIChkaWZmSSA+IDApIHtcbiAgICAgICAgYS5zcGxpY2UoYWksIDAsIC4uLnBsYWNlaG9sZGVycyhNYXRoLmFicyhkaWZmSSkpKTtcbiAgICAgIH1cbiAgICAgIGFpLS07XG4gICAgICBiaS0tO1xuICAgIH0gZWxzZSBpZiAobW92ZW1lbnQgPT09IE1PVkVNRU5ULmhvcml6b250YWwpIHtcbiAgICAgIGJpLS07XG4gICAgfSBlbHNlIGlmIChtb3ZlbWVudCA9PT0gTU9WRU1FTlQudmVydGljYWwpIHtcbiAgICAgIGFpLS07XG4gICAgfVxuICAgIG1vdmVtZW50ID0gc29sdXRpb25bYWldW2JpXTtcbiAgfVxufVxuXG4vKipcbiAqIENvbXB1dGVzIHRoZSBsb25nZXN0IGNvbW1vbiBzdWJzZXF1ZW5jZSBvZiB0d28gYXJyYXlzLCB0aGVuIHVzZXMgdGhhdFxuICogc29sdXRpb24gdG8gaW5qZWN0IGdhcHMgaW50byB0aGUgYXJyYXlzLCBtYWtpbmcgdGhlbSBhbGlnbiBvbiBjb21tb25cbiAqIHN1YnNlcXVlbmNlcy5cbiAqXG4gKiBAcGFyYW0ge0FycmF5fSBhXG4gKiBAcGFyYW0ge0FycmF5fSBiXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFsaWduQXJyYXlzKGEsIGIpIHtcbiAgY29uc3QgbGNzU29sdXRpb24gPSBsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UoYSwgYik7XG4gIGFwcGx5U29sdXRpb24obGNzU29sdXRpb24sIGEsIGIpO1xufVxuXG5cblxuLyoqIFdFQlBBQ0sgRk9PVEVSICoqXG4gKiogLi9qcy9zcmMvYWxpZ25BcnJheXMuanNcbiAqKi8iXSwic291cmNlUm9vdCI6IiJ9");
|
54
|
+
|
55
|
+
/***/ }
|
56
|
+
/******/ ]);
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/******/ (function(modules) { // webpackBootstrap
|
2
|
+
/******/ // The module cache
|
3
|
+
/******/ var installedModules = {};
|
4
|
+
|
5
|
+
/******/ // The require function
|
6
|
+
/******/ function __webpack_require__(moduleId) {
|
7
|
+
|
8
|
+
/******/ // Check if module is in cache
|
9
|
+
/******/ if(installedModules[moduleId])
|
10
|
+
/******/ return installedModules[moduleId].exports;
|
11
|
+
|
12
|
+
/******/ // Create a new module (and put it into the cache)
|
13
|
+
/******/ var module = installedModules[moduleId] = {
|
14
|
+
/******/ exports: {},
|
15
|
+
/******/ id: moduleId,
|
16
|
+
/******/ loaded: false
|
17
|
+
/******/ };
|
18
|
+
|
19
|
+
/******/ // Execute the module function
|
20
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
21
|
+
|
22
|
+
/******/ // Flag the module as loaded
|
23
|
+
/******/ module.loaded = true;
|
24
|
+
|
25
|
+
/******/ // Return the exports of the module
|
26
|
+
/******/ return module.exports;
|
27
|
+
/******/ }
|
28
|
+
|
29
|
+
|
30
|
+
/******/ // expose the modules object (__webpack_modules__)
|
31
|
+
/******/ __webpack_require__.m = modules;
|
32
|
+
|
33
|
+
/******/ // expose the module cache
|
34
|
+
/******/ __webpack_require__.c = installedModules;
|
35
|
+
|
36
|
+
/******/ // __webpack_public_path__
|
37
|
+
/******/ __webpack_require__.p = "";
|
38
|
+
|
39
|
+
/******/ // Load entry module and return exports
|
40
|
+
/******/ return __webpack_require__(0);
|
41
|
+
/******/ })
|
42
|
+
/************************************************************************/
|
43
|
+
/******/ ([
|
44
|
+
/* 0 */
|
45
|
+
/***/ function(module, exports, __webpack_require__) {
|
46
|
+
|
47
|
+
eval("'use strict';\n\nvar _alignArrays = __webpack_require__(1);\n\nvar _alignArrays2 = _interopRequireDefault(_alignArrays);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction imageTo2DArray(_ref, paddingRight) {\n var data = _ref.data;\n var width = _ref.width;\n var height = _ref.height;\n\n // The imageData is a 1D array. Each element in the array corresponds to a\n // decimal value that represents one of the RGBA channels for that pixel.\n var rowSize = width * 4;\n\n var newData = [];\n for (var row = 0; row < height; row++) {\n var pixelsInRow = new Uint8ClampedArray(rowSize + paddingRight * 4);\n for (var location = 0; location < rowSize; location++) {\n pixelsInRow[location] = data[row * rowSize + location];\n }\n newData.push(pixelsInRow);\n }\n return newData;\n}\n\nfunction align(_ref2) {\n var previousImageData = _ref2.previousImageData;\n var currentImageData = _ref2.currentImageData;\n var maxWidth = _ref2.maxWidth;\n\n var hashedPreviousData = previousImageData.map(JSON.stringify);\n self.postMessage({ progress: 40 });\n var hashedCurrentData = currentImageData.map(JSON.stringify);\n self.postMessage({ progress: 60 });\n\n (0, _alignArrays2.default)(hashedPreviousData, hashedCurrentData);\n\n var transparentLine = new Uint8ClampedArray(maxWidth * 4);\n\n hashedPreviousData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n previousImageData.splice(i, 0, transparentLine);\n }\n });\n\n hashedCurrentData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n currentImageData.splice(i, 0, transparentLine);\n }\n });\n}\n\n/**\n * Takes two 2d images, computes the diff between the two, and injects pixels to\n * both in order to:\n * a) make both images the same height\n * b) properly visualize differences\n *\n * Please note that this method MUTATES data.\n *\n * @param {Array} previousData\n * @param {Array} currentData\n */\nfunction computeAndInjectDiffs(_ref3) {\n var previousData = _ref3.previousData;\n var currentData = _ref3.currentData;\n\n var maxWidth = Math.max(previousData.width, currentData.width);\n\n var previousImageData = imageTo2DArray(previousData, maxWidth - previousData.width);\n\n var currentImageData = imageTo2DArray(currentData, maxWidth - currentData.width);\n\n self.postMessage({ progress: 20 });\n\n align({\n previousImageData: previousImageData,\n currentImageData: currentImageData,\n maxWidth: maxWidth\n });\n\n self.postMessage({ progress: 85 });\n\n return {\n currentData: {\n data: currentImageData,\n height: currentImageData.length,\n width: maxWidth\n },\n previousData: {\n data: previousImageData,\n height: previousImageData.length,\n width: maxWidth\n }\n };\n}\n\nself.addEventListener('message', function (_ref4) {\n var _ref4$data = _ref4.data;\n var previousData = _ref4$data.previousData;\n var currentData = _ref4$data.currentData;\n\n var result = computeAndInjectDiffs({ previousData: previousData, currentData: currentData });\n self.postMessage(result);\n self.close();\n});//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvd29ya2Vycy9Db21wdXRlQW5kSW5qZWN0RGlmZnNXb3JrZXIuanM/ZGRiNSJdLCJuYW1lcyI6WyJpbWFnZVRvMkRBcnJheSIsInBhZGRpbmdSaWdodCIsImRhdGEiLCJ3aWR0aCIsImhlaWdodCIsInJvd1NpemUiLCJuZXdEYXRhIiwicm93IiwicGl4ZWxzSW5Sb3ciLCJVaW50OENsYW1wZWRBcnJheSIsImxvY2F0aW9uIiwicHVzaCIsImFsaWduIiwicHJldmlvdXNJbWFnZURhdGEiLCJjdXJyZW50SW1hZ2VEYXRhIiwibWF4V2lkdGgiLCJoYXNoZWRQcmV2aW91c0RhdGEiLCJtYXAiLCJKU09OIiwic3RyaW5naWZ5Iiwic2VsZiIsInBvc3RNZXNzYWdlIiwicHJvZ3Jlc3MiLCJoYXNoZWRDdXJyZW50RGF0YSIsInRyYW5zcGFyZW50TGluZSIsImZvckVhY2giLCJoYXNoZWRMaW5lIiwiaSIsInNwbGljZSIsImNvbXB1dGVBbmRJbmplY3REaWZmcyIsInByZXZpb3VzRGF0YSIsImN1cnJlbnREYXRhIiwiTWF0aCIsIm1heCIsImxlbmd0aCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXN1bHQiLCJjbG9zZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0FBRUEsU0FBU0EsY0FBVCxPQUFpREMsWUFBakQsRUFBK0Q7QUFBQSxNQUFyQ0MsSUFBcUMsUUFBckNBLElBQXFDO0FBQUEsTUFBL0JDLEtBQStCLFFBQS9CQSxLQUErQjtBQUFBLE1BQXhCQyxNQUF3QixRQUF4QkEsTUFBd0I7O0FBQzdEO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixRQUFRLENBQXhCOztBQUVBLE1BQU1HLFVBQVUsRUFBaEI7QUFDQSxPQUFLLElBQUlDLE1BQU0sQ0FBZixFQUFrQkEsTUFBTUgsTUFBeEIsRUFBZ0NHLEtBQWhDLEVBQXVDO0FBQ3JDLFFBQU1DLGNBQWMsSUFBSUMsaUJBQUosQ0FBc0JKLFVBQVdKLGVBQWUsQ0FBaEQsQ0FBcEI7QUFDQSxT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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFsaWduQXJyYXlzIGZyb20gJy4uL2FsaWduQXJyYXlzJztcblxuZnVuY3Rpb24gaW1hZ2VUbzJEQXJyYXkoeyBkYXRhLCB3aWR0aCwgaGVpZ2h0IH0sIHBhZGRpbmdSaWdodCkge1xuICAvLyBUaGUgaW1hZ2VEYXRhIGlzIGEgMUQgYXJyYXkuIEVhY2ggZWxlbWVudCBpbiB0aGUgYXJyYXkgY29ycmVzcG9uZHMgdG8gYVxuICAvLyBkZWNpbWFsIHZhbHVlIHRoYXQgcmVwcmVzZW50cyBvbmUgb2YgdGhlIFJHQkEgY2hhbm5lbHMgZm9yIHRoYXQgcGl4ZWwuXG4gIGNvbnN0IHJvd1NpemUgPSB3aWR0aCAqIDQ7XG5cbiAgY29uc3QgbmV3RGF0YSA9IFtdO1xuICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCBoZWlnaHQ7IHJvdysrKSB7XG4gICAgY29uc3QgcGl4ZWxzSW5Sb3cgPSBuZXcgVWludDhDbGFtcGVkQXJyYXkocm93U2l6ZSArIChwYWRkaW5nUmlnaHQgKiA0KSk7XG4gICAgZm9yIChsZXQgbG9jYXRpb24gPSAwOyBsb2NhdGlvbiA8IHJvd1NpemU7IGxvY2F0aW9uKyspIHtcbiAgICAgIHBpeGVsc0luUm93W2xvY2F0aW9uXSA9IGRhdGFbKHJvdyAqIHJvd1NpemUpICsgbG9jYXRpb25dO1xuICAgIH1cbiAgICBuZXdEYXRhLnB1c2gocGl4ZWxzSW5Sb3cpO1xuICB9XG4gIHJldHVybiBuZXdEYXRhO1xufVxuXG5mdW5jdGlvbiBhbGlnbih7XG4gIHByZXZpb3VzSW1hZ2VEYXRhLFxuICBjdXJyZW50SW1hZ2VEYXRhLFxuICBtYXhXaWR0aCxcbn0pIHtcbiAgY29uc3QgaGFzaGVkUHJldmlvdXNEYXRhID0gcHJldmlvdXNJbWFnZURhdGEubWFwKEpTT04uc3RyaW5naWZ5KTtcbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA0MCB9KTtcbiAgY29uc3QgaGFzaGVkQ3VycmVudERhdGEgPSBjdXJyZW50SW1hZ2VEYXRhLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UoeyBwcm9ncmVzczogNjAgfSk7XG5cbiAgYWxpZ25BcnJheXMoXG4gICAgaGFzaGVkUHJldmlvdXNEYXRhLFxuICAgIGhhc2hlZEN1cnJlbnREYXRhXG4gICk7XG5cbiAgY29uc3QgdHJhbnNwYXJlbnRMaW5lID0gbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KG1heFdpZHRoICogNCk7XG5cbiAgaGFzaGVkUHJldmlvdXNEYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBwcmV2aW91c0ltYWdlRGF0YS5zcGxpY2UoaSwgMCwgdHJhbnNwYXJlbnRMaW5lKTtcbiAgICB9XG4gIH0pO1xuXG4gIGhhc2hlZEN1cnJlbnREYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBjdXJyZW50SW1hZ2VEYXRhLnNwbGljZShpLCAwLCB0cmFuc3BhcmVudExpbmUpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogVGFrZXMgdHdvIDJkIGltYWdlcywgY29tcHV0ZXMgdGhlIGRpZmYgYmV0d2VlbiB0aGUgdHdvLCBhbmQgaW5qZWN0cyBwaXhlbHMgdG9cbiAqIGJvdGggaW4gb3JkZXIgdG86XG4gKiBhKSBtYWtlIGJvdGggaW1hZ2VzIHRoZSBzYW1lIGhlaWdodFxuICogYikgcHJvcGVybHkgdmlzdWFsaXplIGRpZmZlcmVuY2VzXG4gKlxuICogUGxlYXNlIG5vdGUgdGhhdCB0aGlzIG1ldGhvZCBNVVRBVEVTIGRhdGEuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gcHJldmlvdXNEYXRhXG4gKiBAcGFyYW0ge0FycmF5fSBjdXJyZW50RGF0YVxuICovXG5mdW5jdGlvbiBjb21wdXRlQW5kSW5qZWN0RGlmZnMoeyBwcmV2aW91c0RhdGEsIGN1cnJlbnREYXRhIH0pIHtcbiAgY29uc3QgbWF4V2lkdGggPSBNYXRoLm1heChwcmV2aW91c0RhdGEud2lkdGgsIGN1cnJlbnREYXRhLndpZHRoKTtcblxuICBjb25zdCBwcmV2aW91c0ltYWdlRGF0YSA9IGltYWdlVG8yREFycmF5KFxuICAgIHByZXZpb3VzRGF0YSwgbWF4V2lkdGggLSBwcmV2aW91c0RhdGEud2lkdGgpO1xuXG4gIGNvbnN0IGN1cnJlbnRJbWFnZURhdGEgPSBpbWFnZVRvMkRBcnJheShcbiAgICBjdXJyZW50RGF0YSwgbWF4V2lkdGggLSBjdXJyZW50RGF0YS53aWR0aCk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiAyMCB9KTtcblxuICBhbGlnbih7XG4gICAgcHJldmlvdXNJbWFnZURhdGEsXG4gICAgY3VycmVudEltYWdlRGF0YSxcbiAgICBtYXhXaWR0aCxcbiAgfSk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA4NSB9KTtcblxuICByZXR1cm4ge1xuICAgIGN1cnJlbnREYXRhOiB7XG4gICAgICBkYXRhOiBjdXJyZW50SW1hZ2VEYXRhLFxuICAgICAgaGVpZ2h0OiBjdXJyZW50SW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICAgIHByZXZpb3VzRGF0YToge1xuICAgICAgZGF0YTogcHJldmlvdXNJbWFnZURhdGEsXG4gICAgICBoZWlnaHQ6IHByZXZpb3VzSW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICB9O1xufVxuXG5zZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCAoeyBkYXRhOiB7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSB9KSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IGNvbXB1dGVBbmRJbmplY3REaWZmcyh7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UocmVzdWx0KTtcbiAgc2VsZi5jbG9zZSgpO1xufSk7XG5cblxuXG4vKiogV0VCUEFDSyBGT09URVIgKipcbiAqKiAuL2pzL3NyYy93b3JrZXJzL0NvbXB1dGVBbmRJbmplY3REaWZmc1dvcmtlci5qc1xuICoqLyJdLCJzb3VyY2VSb290IjoiIn0=");
|
48
|
+
|
49
|
+
/***/ },
|
50
|
+
/* 1 */
|
51
|
+
/***/ function(module, exports) {
|
52
|
+
|
53
|
+
eval("'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = alignArrays;\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar MOVEMENT = {\n none: 0,\n diagonal: 1,\n vertical: 2,\n horizontal: 3\n};\n\nfunction initMatrix(height, width) {\n var rows = new Array(height);\n for (var i = 0; i < rows.length; i++) {\n rows[i] = new Int32Array(width);\n }\n return rows;\n}\n\nfunction longestCommonSubsequence(a, b) {\n // adapted from\n // http://algorithms.tutorialhorizon.com/dynamic-programming-longest-common-subsequence/\n var aLength = a.length;\n var bLength = b.length;\n var memo = initMatrix(aLength + 1, bLength + 1);\n var solution = initMatrix(aLength + 1, bLength + 1);\n\n // Loop and find the solution\n for (var i = 1; i <= aLength; i++) {\n for (var j = 1; j <= bLength; j++) {\n if (a[i - 1] === b[j - 1]) {\n // diagonal\n memo[i][j] = memo[i - 1][j - 1] + 1;\n solution[i][j] = MOVEMENT.diagonal;\n } else {\n memo[i][j] = Math.max(memo[i - 1][j], memo[i][j - 1]);\n if (memo[i][j] === memo[i - 1][j]) {\n solution[i][j] = MOVEMENT.vertical;\n } else {\n solution[i][j] = MOVEMENT.horizontal;\n }\n }\n }\n }\n if (memo[aLength][bLength] === 0) {\n // No soltuion found\n return null;\n }\n return solution;\n}\n\nfunction placeholders(count) {\n var result = new Array(count);\n for (var i = 0; i < count; i++) {\n result[i] = '+';\n }\n return result;\n}\n/**\n * Apply an lcs solution to arrays. Note that this will MUTATE the arrays,\n * injecting \"+\" where gaps are needed.\n *\n * @param {Array<Array>} solution as computed by `longestCommonSubsequence`\n * @param {Array} a\n * @param {Array} b\n */\nfunction applySolution(solution, a, b) {\n var movement = solution[a.length][b.length];\n var ai = a.length;\n var bi = b.length;\n\n var changes = 0;\n\n while (movement !== MOVEMENT.none) {\n if (movement === MOVEMENT.diagonal) {\n if (changes < 0) {\n b.splice.apply(b, [bi, 0].concat(_toConsumableArray(placeholders(Math.abs(changes)))));\n } else if (changes > 0) {\n a.splice.apply(a, [ai, 0].concat(_toConsumableArray(placeholders(changes))));\n }\n ai--;\n bi--;\n changes = 0;\n } else if (movement === MOVEMENT.horizontal) {\n bi--;\n changes++;\n } else if (movement === MOVEMENT.vertical) {\n ai--;\n changes--;\n }\n movement = solution[ai][bi];\n }\n}\n\n/**\n * To be called for arrays that share nothing in common.\n *\n * Note that this will MUTATE the arrays,\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction applyPadding(a, b) {\n var aLength = a.length;\n var bLength = b.Length;\n\n var shorterArray = aLength > bLength ? b : a;\n\n shorterArray.push(placeholders(Math.abs(aLength - bLength)));\n}\n/**\n * Computes the longest common subsequence of two arrays, then uses that\n * solution to inject gaps into the arrays, making them align on common\n * subsequences.\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction alignArrays(a, b) {\n var lcsSolution = longestCommonSubsequence(a, b);\n if (!lcsSolution) {\n applyPadding(a, b);\n }\n applySolution(lcsSolution, a, b);\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvYWxpZ25BcnJheXMuanM/MDFiNyJdLCJuYW1lcyI6WyJhbGlnbkFycmF5cyIsIk1PVkVNRU5UIiwibm9uZSIsImRpYWdvbmFsIiwidmVydGljYWwiLCJob3Jpem9udGFsIiwiaW5pdE1hdHJpeCIsImhlaWdodCIsIndpZHRoIiwicm93cyIsIkFycmF5IiwiaSIsImxlbmd0aCIsIkludDMyQXJyYXkiLCJsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UiLCJhIiwiYiIsImFMZW5ndGgiLCJiTGVuZ3RoIiwibWVtbyIsInNvbHV0aW9uIiwiaiIsIk1hdGgiLCJtYXgiLCJwbGFjZWhvbGRlcnMiLCJjb3VudCIsInJlc3VsdCIsImFwcGx5U29sdXRpb24iLCJtb3ZlbWVudCIsImFpIiwiYmkiLCJjaGFuZ2VzIiwic3BsaWNlIiwiYWJzIiwiYXBwbHlQYWRkaW5nIiwiTGVuZ3RoIiwic2hvcnRlckFycmF5IiwicHVzaCIsImxjc1NvbHV0aW9uIl0sIm1hcHBpbmdzIjoiOzs7OztrQkFrSHdCQSxXOzs7O0FBbEh4QixJQUFNQyxXQUFXO0FBQ2ZDLFFBQU0sQ0FEUztBQUVmQyxZQUFVLENBRks7QUFHZkMsWUFBVSxDQUhLO0FBSWZDLGNBQVk7QUFKRyxDQUFqQjs7QUFPQSxTQUFTQyxVQUFULENBQW9CQyxNQUFwQixFQUE0QkMsS0FBNUIsRUFBbUM7QUFDakMsTUFBTUMsT0FBTyxJQUFJQyxLQUFKLENBQVVILE1BQVYsQ0FBYjtBQUNBLE9BQUssSUFBSUksSUFBSSxDQUFiLEVBQWdCQSxJQUFJRixLQUFLRyxNQUF6QixFQUFpQ0QsR0FBakMsRUFBc0M7QUFDcENGLFNBQUtFLENBQUwsSUFBVSxJQUFJRSxVQUFKLENBQWVMLEtBQWYsQ0FBVjtBQUNEO0FBQ0QsU0FBT0MsSUFBUDtBQUNEOztBQUVELFNBQVNLLHdCQUFULENBQWtDQyxDQUFsQyxFQUFxQ0MsQ0FBckMsRUFBd0M7QUFDdEM7QUFDQTtBQUNBLE1BQU1DLFVBQVVGLEVBQUVI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O0FBQ0RILGVBQVdSLFNBQVNTLEVBQVQsRUFBYUMsRUFBYixDQUFYO0FBQ0Q7QUFDRjs7QUFFRDs7Ozs7Ozs7QUFRQSxTQUFTSSxZQUFULENBQXNCbkIsQ0FBdEIsRUFBeUJDLENBQXpCLEVBQTRCO0FBQzFCLE1BQU1DLFVBQVVGLEVBQUVILE1BQWxCO0FBQ0EsTUFBTU0sVUFBVUYsRUFBRW1CLE1BQWxCOztBQUVBLE1BQU1DLGVBQWVuQixVQUFVQyxPQUFWLEdBQW9CRixDQUFwQixHQUF3QkQsQ0FBN0M7O0FBRUFxQixlQUFhQyxJQUFiLENBQWtCYixhQUFhRixLQUFLVyxHQUFMLENBQVNoQixVQUFVQyxPQUFuQixDQUFiLENBQWxCO0FBQ0Q7QUFDRDs7Ozs7Ozs7QUFRZSxTQUFTbEIsV0FBVCxDQUFxQmUsQ0FBckIsRUFBd0JDLENBQXhCLEVBQTJCO0FBQ3hDLE1BQU1zQixjQUFjeEIseUJBQXlCQyxDQUF6QixFQUE0QkMsQ0FBNUIsQ0FBcEI7QUFDQSxNQUFJLENBQUNzQixXQUFMLEVBQWtCO0FBQ2hCSixpQkFBYW5CLENBQWIsRUFBZ0JDLENBQWhCO0FBQ0Q7QUFDRFcsZ0JBQWNXLFdBQWQsRUFBMkJ2QixDQUEzQixFQUE4QkMsQ0FBOUI7QUFDRCIsImZpbGUiOiIxLmpzIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgTU9WRU1FTlQgPSB7XG4gIG5vbmU6IDAsXG4gIGRpYWdvbmFsOiAxLFxuICB2ZXJ0aWNhbDogMixcbiAgaG9yaXpvbnRhbDogMyxcbn07XG5cbmZ1bmN0aW9uIGluaXRNYXRyaXgoaGVpZ2h0LCB3aWR0aCkge1xuICBjb25zdCByb3dzID0gbmV3IEFycmF5KGhlaWdodCk7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgcm93cy5sZW5ndGg7IGkrKykge1xuICAgIHJvd3NbaV0gPSBuZXcgSW50MzJBcnJheSh3aWR0aCk7XG4gIH1cbiAgcmV0dXJuIHJvd3M7XG59XG5cbmZ1bmN0aW9uIGxvbmdlc3RDb21tb25TdWJzZXF1ZW5jZShhLCBiKSB7XG4gIC8vIGFkYXB0ZWQgZnJvbVxuICAvLyBodHRwOi8vYWxnb3JpdGhtcy50dXRvcmlhbGhvcml6b24uY29tL2R5bmFtaWMtcHJvZ3JhbW1pbmctbG9uZ2VzdC1jb21tb24tc3Vic2VxdWVuY2UvXG4gIGNvbnN0IGFMZW5ndGggPSBhLmxlbmd0aDtcbiAgY29uc3QgYkxlbmd0aCA9IGIubGVuZ3RoO1xuICBjb25zdCBtZW1vID0gaW5pdE1hdHJpeChhTGVuZ3RoICsgMSwgYkxlbmd0aCArIDEpO1xuICBjb25zdCBzb2x1dGlvbiA9IGluaXRNYXRyaXgoYUxlbmd0aCArIDEsIGJMZW5ndGggKyAxKTtcblxuICAvLyBMb29wIGFuZCBmaW5kIHRoZSBzb2x1dGlvblxuICBmb3IgKGxldCBpID0gMTsgaSA8PSBhTGVuZ3RoOyBpKyspIHtcbiAgICBmb3IgKGxldCBqID0gMTsgaiA8PSBiTGVuZ3RoOyBqKyspIHtcbiAgICAgIGlmIChhW2kgLSAxXSA9PT0gYltqIC0gMV0pIHtcbiAgICAgICAgLy8gZGlhZ29uYWxcbiAgICAgICAgbWVtb1tpXVtqXSA9IG1lbW9baSAtIDFdW2ogLSAxXSArIDE7XG4gICAgICAgIHNvbHV0aW9uW2ldW2pdID0gTU9WRU1FTlQuZGlhZ29uYWw7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBtZW1vW2ldW2pdID0gTWF0aC5tYXgobWVtb1tpIC0gMV1bal0sIG1lbW9baV1baiAtIDFdKTtcbiAgICAgICAgaWYgKG1lbW9baV1bal0gPT09IG1lbW9baSAtIDFdW2pdKSB7XG4gICAgICAgICAgc29sdXRpb25baV1bal0gPSBNT1ZFTUVOVC52ZXJ0aWNhbDtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBzb2x1dGlvbltpXVtqXSA9IE1PVkVNRU5ULmhvcml6b250YWw7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgaWYgKG1lbW9bYUxlbmd0aF1bYkxlbmd0aF0gPT09IDApIHtcbiAgICAvLyBObyBzb2x0dWlvbiBmb3VuZFxuICAgIHJldHVybiBudWxsO1xuICB9XG4gIHJldHVybiBzb2x1dGlvbjtcbn1cblxuZnVuY3Rpb24gcGxhY2Vob2xkZXJzKGNvdW50KSB7XG4gIGNvbnN0IHJlc3VsdCA9IG5ldyBBcnJheShjb3VudCk7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgY291bnQ7IGkrKykge1xuICAgIHJlc3VsdFtpXSA9ICcrJztcbiAgfVxuICByZXR1cm4gcmVzdWx0O1xufVxuLyoqXG4gKiBBcHBseSBhbiBsY3Mgc29sdXRpb24gdG8gYXJyYXlzLiBOb3RlIHRoYXQgdGhpcyB3aWxsIE1VVEFURSB0aGUgYXJyYXlzLFxuICogaW5qZWN0aW5nIFwiK1wiIHdoZXJlIGdhcHMgYXJlIG5lZWRlZC5cbiAqXG4gKiBAcGFyYW0ge0FycmF5PEFycmF5Pn0gc29sdXRpb24gYXMgY29tcHV0ZWQgYnkgYGxvbmdlc3RDb21tb25TdWJzZXF1ZW5jZWBcbiAqIEBwYXJhbSB7QXJyYXl9IGFcbiAqIEBwYXJhbSB7QXJyYXl9IGJcbiAqL1xuZnVuY3Rpb24gYXBwbHlTb2x1dGlvbihzb2x1dGlvbiwgYSwgYikge1xuICBsZXQgbW92ZW1lbnQgPSBzb2x1dGlvblthLmxlbmd0aF1bYi5sZW5ndGhdO1xuICBsZXQgYWkgPSBhLmxlbmd0aDtcbiAgbGV0IGJpID0gYi5sZW5ndGg7XG5cbiAgbGV0IGNoYW5nZXMgPSAwO1xuXG4gIHdoaWxlIChtb3ZlbWVudCAhPT0gTU9WRU1FTlQubm9uZSkge1xuICAgIGlmIChtb3ZlbWVudCA9PT0gTU9WRU1FTlQuZGlhZ29uYWwpIHtcbiAgICAgIGlmIChjaGFuZ2VzIDwgMCkge1xuICAgICAgICBiLnNwbGljZShiaSwgMCwgLi4ucGxhY2Vob2xkZXJzKE1hdGguYWJzKGNoYW5nZXMpKSk7XG4gICAgICB9IGVsc2UgaWYgKGNoYW5nZXMgPiAwKSB7XG4gICAgICAgIGEuc3BsaWNlKGFpLCAwLCAuLi5wbGFjZWhvbGRlcnMoY2hhbmdlcykpO1xuICAgICAgfVxuICAgICAgYWktLTtcbiAgICAgIGJpLS07XG4gICAgICBjaGFuZ2VzID0gMDtcbiAgICB9IGVsc2UgaWYgKG1vdmVtZW50ID09PSBNT1ZFTUVOVC5ob3Jpem9udGFsKSB7XG4gICAgICBiaS0tO1xuICAgICAgY2hhbmdlcysrO1xuICAgIH0gZWxzZSBpZiAobW92ZW1lbnQgPT09IE1PVkVNRU5ULnZlcnRpY2FsKSB7XG4gICAgICBhaS0tO1xuICAgICAgY2hhbmdlcy0tO1xuICAgIH1cbiAgICBtb3ZlbWVudCA9IHNvbHV0aW9uW2FpXVtiaV07XG4gIH1cbn1cblxuLyoqXG4gKiBUbyBiZSBjYWxsZWQgZm9yIGFycmF5cyB0aGF0IHNoYXJlIG5vdGhpbmcgaW4gY29tbW9uLlxuICpcbiAqIE5vdGUgdGhhdCB0aGlzIHdpbGwgTVVUQVRFIHRoZSBhcnJheXMsXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5mdW5jdGlvbiBhcHBseVBhZGRpbmcoYSwgYikge1xuICBjb25zdCBhTGVuZ3RoID0gYS5sZW5ndGg7XG4gIGNvbnN0IGJMZW5ndGggPSBiLkxlbmd0aDtcblxuICBjb25zdCBzaG9ydGVyQXJyYXkgPSBhTGVuZ3RoID4gYkxlbmd0aCA/IGIgOiBhO1xuXG4gIHNob3J0ZXJBcnJheS5wdXNoKHBsYWNlaG9sZGVycyhNYXRoLmFicyhhTGVuZ3RoIC0gYkxlbmd0aCkpKTtcbn1cbi8qKlxuICogQ29tcHV0ZXMgdGhlIGxvbmdlc3QgY29tbW9uIHN1YnNlcXVlbmNlIG9mIHR3byBhcnJheXMsIHRoZW4gdXNlcyB0aGF0XG4gKiBzb2x1dGlvbiB0byBpbmplY3QgZ2FwcyBpbnRvIHRoZSBhcnJheXMsIG1ha2luZyB0aGVtIGFsaWduIG9uIGNvbW1vblxuICogc3Vic2VxdWVuY2VzLlxuICpcbiAqIEBwYXJhbSB7QXJyYXl9IGFcbiAqIEBwYXJhbSB7QXJyYXl9IGJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gYWxpZ25BcnJheXMoYSwgYikge1xuICBjb25zdCBsY3NTb2x1dGlvbiA9IGxvbmdlc3RDb21tb25TdWJzZXF1ZW5jZShhLCBiKTtcbiAgaWYgKCFsY3NTb2x1dGlvbikge1xuICAgIGFwcGx5UGFkZGluZyhhLCBiKTtcbiAgfVxuICBhcHBseVNvbHV0aW9uKGxjc1NvbHV0aW9uLCBhLCBiKTtcbn1cblxuXG5cbi8qKiBXRUJQQUNLIEZPT1RFUiAqKlxuICoqIC4vanMvc3JjL2FsaWduQXJyYXlzLmpzXG4gKiovIl0sInNvdXJjZVJvb3QiOiIifQ==");
|
54
|
+
|
55
|
+
/***/ }
|
56
|
+
/******/ ]);
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/******/ (function(modules) { // webpackBootstrap
|
2
|
+
/******/ // The module cache
|
3
|
+
/******/ var installedModules = {};
|
4
|
+
|
5
|
+
/******/ // The require function
|
6
|
+
/******/ function __webpack_require__(moduleId) {
|
7
|
+
|
8
|
+
/******/ // Check if module is in cache
|
9
|
+
/******/ if(installedModules[moduleId])
|
10
|
+
/******/ return installedModules[moduleId].exports;
|
11
|
+
|
12
|
+
/******/ // Create a new module (and put it into the cache)
|
13
|
+
/******/ var module = installedModules[moduleId] = {
|
14
|
+
/******/ exports: {},
|
15
|
+
/******/ id: moduleId,
|
16
|
+
/******/ loaded: false
|
17
|
+
/******/ };
|
18
|
+
|
19
|
+
/******/ // Execute the module function
|
20
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
21
|
+
|
22
|
+
/******/ // Flag the module as loaded
|
23
|
+
/******/ module.loaded = true;
|
24
|
+
|
25
|
+
/******/ // Return the exports of the module
|
26
|
+
/******/ return module.exports;
|
27
|
+
/******/ }
|
28
|
+
|
29
|
+
|
30
|
+
/******/ // expose the modules object (__webpack_modules__)
|
31
|
+
/******/ __webpack_require__.m = modules;
|
32
|
+
|
33
|
+
/******/ // expose the module cache
|
34
|
+
/******/ __webpack_require__.c = installedModules;
|
35
|
+
|
36
|
+
/******/ // __webpack_public_path__
|
37
|
+
/******/ __webpack_require__.p = "";
|
38
|
+
|
39
|
+
/******/ // Load entry module and return exports
|
40
|
+
/******/ return __webpack_require__(0);
|
41
|
+
/******/ })
|
42
|
+
/************************************************************************/
|
43
|
+
/******/ ([
|
44
|
+
/* 0 */
|
45
|
+
/***/ function(module, exports, __webpack_require__) {
|
46
|
+
|
47
|
+
eval("'use strict';\n\nvar _alignArrays = __webpack_require__(1);\n\nvar _alignArrays2 = _interopRequireDefault(_alignArrays);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction imageTo2DArray(_ref, paddingRight) {\n var data = _ref.data;\n var width = _ref.width;\n var height = _ref.height;\n\n // The imageData is a 1D array. Each element in the array corresponds to a\n // decimal value that represents one of the RGBA channels for that pixel.\n var rowSize = width * 4;\n\n var newData = [];\n for (var row = 0; row < height; row++) {\n var pixelsInRow = new Uint8ClampedArray(rowSize + paddingRight * 4);\n for (var location = 0; location < rowSize; location++) {\n pixelsInRow[location] = data[row * rowSize + location];\n }\n newData.push(pixelsInRow);\n }\n return newData;\n}\n\nfunction align(_ref2) {\n var previousImageData = _ref2.previousImageData;\n var currentImageData = _ref2.currentImageData;\n var maxWidth = _ref2.maxWidth;\n\n var hashedPreviousData = previousImageData.map(JSON.stringify);\n self.postMessage({ progress: 40 });\n var hashedCurrentData = currentImageData.map(JSON.stringify);\n self.postMessage({ progress: 60 });\n\n (0, _alignArrays2.default)(hashedPreviousData, hashedCurrentData);\n\n var transparentLine = new Uint8ClampedArray(maxWidth * 4);\n\n hashedPreviousData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n previousImageData.splice(i, 0, transparentLine);\n }\n });\n\n hashedCurrentData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n currentImageData.splice(i, 0, transparentLine);\n }\n });\n}\n\n/**\n * Takes two 2d images, computes the diff between the two, and injects pixels to\n * both in order to:\n * a) make both images the same height\n * b) properly visualize differences\n *\n * Please note that this method MUTATES data.\n *\n * @param {Array} previousData\n * @param {Array} currentData\n */\nfunction computeAndInjectDiffs(_ref3) {\n var previousData = _ref3.previousData;\n var currentData = _ref3.currentData;\n\n var maxWidth = Math.max(previousData.width, currentData.width);\n\n var previousImageData = imageTo2DArray(previousData, maxWidth - previousData.width);\n\n var currentImageData = imageTo2DArray(currentData, maxWidth - currentData.width);\n\n self.postMessage({ progress: 20 });\n\n align({\n previousImageData: previousImageData,\n currentImageData: currentImageData,\n maxWidth: maxWidth\n });\n\n self.postMessage({ progress: 85 });\n\n return {\n currentData: {\n data: currentImageData,\n height: currentImageData.length,\n width: maxWidth\n },\n previousData: {\n data: previousImageData,\n height: previousImageData.length,\n width: maxWidth\n }\n };\n}\n\nself.addEventListener('message', function (_ref4) {\n var _ref4$data = _ref4.data;\n var previousData = _ref4$data.previousData;\n var currentData = _ref4$data.currentData;\n\n var result = computeAndInjectDiffs({ previousData: previousData, currentData: currentData });\n self.postMessage(result);\n self.close();\n});//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvd29ya2Vycy9Db21wdXRlQW5kSW5qZWN0RGlmZnNXb3JrZXIuanM/ZGRiNSJdLCJuYW1lcyI6WyJpbWFnZVRvMkRBcnJheSIsInBhZGRpbmdSaWdodCIsImRhdGEiLCJ3aWR0aCIsImhlaWdodCIsInJvd1NpemUiLCJuZXdEYXRhIiwicm93IiwicGl4ZWxzSW5Sb3ciLCJVaW50OENsYW1wZWRBcnJheSIsImxvY2F0aW9uIiwicHVzaCIsImFsaWduIiwicHJldmlvdXNJbWFnZURhdGEiLCJjdXJyZW50SW1hZ2VEYXRhIiwibWF4V2lkdGgiLCJoYXNoZWRQcmV2aW91c0RhdGEiLCJtYXAiLCJKU09OIiwic3RyaW5naWZ5Iiwic2VsZiIsInBvc3RNZXNzYWdlIiwicHJvZ3Jlc3MiLCJoYXNoZWRDdXJyZW50RGF0YSIsInRyYW5zcGFyZW50TGluZSIsImZvckVhY2giLCJoYXNoZWRMaW5lIiwiaSIsInNwbGljZSIsImNvbXB1dGVBbmRJbmplY3REaWZmcyIsInByZXZpb3VzRGF0YSIsImN1cnJlbnREYXRhIiwiTWF0aCIsIm1heCIsImxlbmd0aCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXN1bHQiLCJjbG9zZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0FBRUEsU0FBU0EsY0FBVCxPQUFpREMsWUFBakQsRUFBK0Q7QUFBQSxNQUFyQ0MsSUFBcUMsUUFBckNBLElBQXFDO0FBQUEsTUFBL0JDLEtBQStCLFFBQS9CQSxLQUErQjtBQUFBLE1BQXhCQyxNQUF3QixRQUF4QkEsTUFBd0I7O0FBQzdEO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixRQUFRLENBQXhCOztBQUVBLE1BQU1HLFVBQVUsRUFBaEI7QUFDQSxPQUFLLElBQUlDLE1BQU0sQ0FBZixFQUFrQkEsTUFBTUgsTUFBeEIsRUFBZ0NHLEtBQWhDLEVBQXVDO0FBQ3JDLFFBQU1DLGNBQWMsSUFBSUMsaUJBQUosQ0FBc0JKLFVBQVdKLGVBQWUsQ0FBaEQsQ0FBcEI7QUFDQSxT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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFsaWduQXJyYXlzIGZyb20gJy4uL2FsaWduQXJyYXlzJztcblxuZnVuY3Rpb24gaW1hZ2VUbzJEQXJyYXkoeyBkYXRhLCB3aWR0aCwgaGVpZ2h0IH0sIHBhZGRpbmdSaWdodCkge1xuICAvLyBUaGUgaW1hZ2VEYXRhIGlzIGEgMUQgYXJyYXkuIEVhY2ggZWxlbWVudCBpbiB0aGUgYXJyYXkgY29ycmVzcG9uZHMgdG8gYVxuICAvLyBkZWNpbWFsIHZhbHVlIHRoYXQgcmVwcmVzZW50cyBvbmUgb2YgdGhlIFJHQkEgY2hhbm5lbHMgZm9yIHRoYXQgcGl4ZWwuXG4gIGNvbnN0IHJvd1NpemUgPSB3aWR0aCAqIDQ7XG5cbiAgY29uc3QgbmV3RGF0YSA9IFtdO1xuICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCBoZWlnaHQ7IHJvdysrKSB7XG4gICAgY29uc3QgcGl4ZWxzSW5Sb3cgPSBuZXcgVWludDhDbGFtcGVkQXJyYXkocm93U2l6ZSArIChwYWRkaW5nUmlnaHQgKiA0KSk7XG4gICAgZm9yIChsZXQgbG9jYXRpb24gPSAwOyBsb2NhdGlvbiA8IHJvd1NpemU7IGxvY2F0aW9uKyspIHtcbiAgICAgIHBpeGVsc0luUm93W2xvY2F0aW9uXSA9IGRhdGFbKHJvdyAqIHJvd1NpemUpICsgbG9jYXRpb25dO1xuICAgIH1cbiAgICBuZXdEYXRhLnB1c2gocGl4ZWxzSW5Sb3cpO1xuICB9XG4gIHJldHVybiBuZXdEYXRhO1xufVxuXG5mdW5jdGlvbiBhbGlnbih7XG4gIHByZXZpb3VzSW1hZ2VEYXRhLFxuICBjdXJyZW50SW1hZ2VEYXRhLFxuICBtYXhXaWR0aCxcbn0pIHtcbiAgY29uc3QgaGFzaGVkUHJldmlvdXNEYXRhID0gcHJldmlvdXNJbWFnZURhdGEubWFwKEpTT04uc3RyaW5naWZ5KTtcbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA0MCB9KTtcbiAgY29uc3QgaGFzaGVkQ3VycmVudERhdGEgPSBjdXJyZW50SW1hZ2VEYXRhLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UoeyBwcm9ncmVzczogNjAgfSk7XG5cbiAgYWxpZ25BcnJheXMoXG4gICAgaGFzaGVkUHJldmlvdXNEYXRhLFxuICAgIGhhc2hlZEN1cnJlbnREYXRhXG4gICk7XG5cbiAgY29uc3QgdHJhbnNwYXJlbnRMaW5lID0gbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KG1heFdpZHRoICogNCk7XG5cbiAgaGFzaGVkUHJldmlvdXNEYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBwcmV2aW91c0ltYWdlRGF0YS5zcGxpY2UoaSwgMCwgdHJhbnNwYXJlbnRMaW5lKTtcbiAgICB9XG4gIH0pO1xuXG4gIGhhc2hlZEN1cnJlbnREYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBjdXJyZW50SW1hZ2VEYXRhLnNwbGljZShpLCAwLCB0cmFuc3BhcmVudExpbmUpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogVGFrZXMgdHdvIDJkIGltYWdlcywgY29tcHV0ZXMgdGhlIGRpZmYgYmV0d2VlbiB0aGUgdHdvLCBhbmQgaW5qZWN0cyBwaXhlbHMgdG9cbiAqIGJvdGggaW4gb3JkZXIgdG86XG4gKiBhKSBtYWtlIGJvdGggaW1hZ2VzIHRoZSBzYW1lIGhlaWdodFxuICogYikgcHJvcGVybHkgdmlzdWFsaXplIGRpZmZlcmVuY2VzXG4gKlxuICogUGxlYXNlIG5vdGUgdGhhdCB0aGlzIG1ldGhvZCBNVVRBVEVTIGRhdGEuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gcHJldmlvdXNEYXRhXG4gKiBAcGFyYW0ge0FycmF5fSBjdXJyZW50RGF0YVxuICovXG5mdW5jdGlvbiBjb21wdXRlQW5kSW5qZWN0RGlmZnMoeyBwcmV2aW91c0RhdGEsIGN1cnJlbnREYXRhIH0pIHtcbiAgY29uc3QgbWF4V2lkdGggPSBNYXRoLm1heChwcmV2aW91c0RhdGEud2lkdGgsIGN1cnJlbnREYXRhLndpZHRoKTtcblxuICBjb25zdCBwcmV2aW91c0ltYWdlRGF0YSA9IGltYWdlVG8yREFycmF5KFxuICAgIHByZXZpb3VzRGF0YSwgbWF4V2lkdGggLSBwcmV2aW91c0RhdGEud2lkdGgpO1xuXG4gIGNvbnN0IGN1cnJlbnRJbWFnZURhdGEgPSBpbWFnZVRvMkRBcnJheShcbiAgICBjdXJyZW50RGF0YSwgbWF4V2lkdGggLSBjdXJyZW50RGF0YS53aWR0aCk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiAyMCB9KTtcblxuICBhbGlnbih7XG4gICAgcHJldmlvdXNJbWFnZURhdGEsXG4gICAgY3VycmVudEltYWdlRGF0YSxcbiAgICBtYXhXaWR0aCxcbiAgfSk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA4NSB9KTtcblxuICByZXR1cm4ge1xuICAgIGN1cnJlbnREYXRhOiB7XG4gICAgICBkYXRhOiBjdXJyZW50SW1hZ2VEYXRhLFxuICAgICAgaGVpZ2h0OiBjdXJyZW50SW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICAgIHByZXZpb3VzRGF0YToge1xuICAgICAgZGF0YTogcHJldmlvdXNJbWFnZURhdGEsXG4gICAgICBoZWlnaHQ6IHByZXZpb3VzSW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICB9O1xufVxuXG5zZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCAoeyBkYXRhOiB7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSB9KSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IGNvbXB1dGVBbmRJbmplY3REaWZmcyh7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UocmVzdWx0KTtcbiAgc2VsZi5jbG9zZSgpO1xufSk7XG5cblxuXG4vKiogV0VCUEFDSyBGT09URVIgKipcbiAqKiAuL2pzL3NyYy93b3JrZXJzL0NvbXB1dGVBbmRJbmplY3REaWZmc1dvcmtlci5qc1xuICoqLyJdLCJzb3VyY2VSb290IjoiIn0=");
|
48
|
+
|
49
|
+
/***/ },
|
50
|
+
/* 1 */
|
51
|
+
/***/ function(module, exports) {
|
52
|
+
|
53
|
+
eval("'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = alignArrays;\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar MOVEMENT = {\n none: 0,\n diagonal: 1,\n vertical: 2,\n horizontal: 3\n};\n\nfunction initMatrix(height, width) {\n var rows = new Array(height);\n for (var i = 0; i < rows.length; i++) {\n rows[i] = new Int32Array(width);\n }\n return rows;\n}\n\nfunction longestCommonSubsequence(a, b) {\n // adapted from\n // http://algorithms.tutorialhorizon.com/dynamic-programming-longest-common-subsequence/\n var aLength = a.length;\n var bLength = b.length;\n var memo = initMatrix(aLength + 1, bLength + 1);\n var solution = initMatrix(aLength + 1, bLength + 1);\n\n // Loop and find the solution\n for (var i = 1; i <= aLength; i++) {\n for (var j = 1; j <= bLength; j++) {\n if (a[i - 1] === b[j - 1]) {\n // diagonal\n memo[i][j] = memo[i - 1][j - 1] + 1;\n solution[i][j] = MOVEMENT.diagonal;\n } else {\n memo[i][j] = Math.max(memo[i - 1][j], memo[i][j - 1]);\n if (memo[i][j] === memo[i - 1][j]) {\n solution[i][j] = MOVEMENT.vertical;\n } else {\n solution[i][j] = MOVEMENT.horizontal;\n }\n }\n }\n }\n if (memo[aLength][bLength] === 0) {\n // No soltuion found\n return null;\n }\n return solution;\n}\n\nfunction placeholders(count) {\n var result = new Array(count);\n for (var i = 0; i < count; i++) {\n result[i] = '+';\n }\n return result;\n}\n/**\n * Apply an lcs solution to arrays. Note that this will MUTATE the arrays,\n * injecting \"+\" where gaps are needed.\n *\n * @param {Array<Array>} solution as computed by `longestCommonSubsequence`\n * @param {Array} a\n * @param {Array} b\n */\nfunction applySolution(solution, a, b) {\n var movement = solution[a.length][b.length];\n var ai = a.length;\n var bi = b.length;\n var changes = 0;\n\n function applyChange() {\n if (changes < 0) {\n b.splice.apply(b, [bi, 0].concat(_toConsumableArray(placeholders(Math.abs(changes)))));\n } else if (changes > 0) {\n a.splice.apply(a, [ai, 0].concat(_toConsumableArray(placeholders(changes))));\n }\n changes = 0;\n }\n\n while (movement !== MOVEMENT.none) {\n if (movement === MOVEMENT.diagonal) {\n applyChange();\n ai--;\n bi--;\n } else if (movement === MOVEMENT.horizontal) {\n bi--;\n changes++;\n } else if (movement === MOVEMENT.vertical) {\n ai--;\n changes--;\n }\n movement = solution[ai][bi];\n }\n changes = bi - ai;\n ai = 0;\n bi = 0;\n applyChange();\n}\n\n/**\n * To be called for arrays that share nothing in common.\n *\n * Note that this will MUTATE the arrays,\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction applyPadding(a, b) {\n var aLength = a.length;\n var bLength = b.length;\n var shorterArray = aLength > bLength ? b : a;\n shorterArray.push.apply(shorterArray, _toConsumableArray(placeholders(Math.abs(aLength - bLength))));\n}\n/**\n * Computes the longest common subsequence of two arrays, then uses that\n * solution to inject gaps into the arrays, making them align on common\n * subsequences.\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction alignArrays(a, b) {\n var lcsSolution = longestCommonSubsequence(a, b);\n if (lcsSolution) {\n applySolution(lcsSolution, a, b);\n } else {\n applyPadding(a, b);\n }\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvYWxpZ25BcnJheXMuanM/MDFiNyJdLCJuYW1lcyI6WyJhbGlnbkFycmF5cyIsIk1PVkVNRU5UIiwibm9uZSIsImRpYWdvbmFsIiwidmVydGljYWwiLCJob3Jpem9udGFsIiwiaW5pdE1hdHJpeCIsImhlaWdodCIsIndpZHRoIiwicm93cyIsIkFycmF5IiwiaSIsImxlbmd0aCIsIkludDMyQXJyYXkiLCJsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UiLCJhIiwiYiIsImFMZW5ndGgiLCJiTGVuZ3RoIiwibWVtbyIsInNvbHV0aW9uIiwiaiIsIk1hdGgiLCJtYXgiLCJwbGFjZWhvbGRlcnMiLCJjb3VudCIsInJlc3VsdCIsImFwcGx5U29sdXRpb24iLCJtb3ZlbWVudCIsImFpIiwiYmkiLCJjaGFuZ2VzIiwiYXBwbHlDaGFuZ2UiLCJzcGxpY2UiLCJhYnMiLCJhcHBseVBhZGRpbmciLCJzaG9ydGVyQXJyYXkiLCJwdXNoIiwibGNzU29sdXRpb24iXSwibWFwcGluZ3MiOiI7Ozs7O2tCQXVId0JBLFc7Ozs7QUF2SHhCLElBQU1DLFdBQVc7QUFDZkMsUUFBTSxDQURTO0FBRWZDLFlBQVUsQ0FGSztBQUdmQyxZQUFVLENBSEs7QUFJZkMsY0FBWTtBQUpHLENBQWpCOztBQU9BLFNBQVNDLFVBQVQsQ0FBb0JDLE1BQXBCLEVBQTRCQyxLQUE1QixFQUFtQztBQUNqQyxNQUFNQyxPQUFPLElBQUlDLEtBQUosQ0FBVUgsTUFBVixDQUFiO0FBQ0EsT0FBSyxJQUFJSSxJQUFJLENBQWIsRUFBZ0JBLElBQUlGLEtBQUtHLE1BQXpCLEVBQWlDRCxHQUFqQyxFQUFzQztBQUNwQ0YsU0FBS0UsQ0FBTCxJQUFVLElBQUlFLFVBQUosQ0FBZUwsS0FBZixDQUFWO0FBQ0Q7QUFDRCxTQUFPQyxJQUFQO0FBQ0Q7O0FBRUQsU0FBU0ssd0JBQVQsQ0FBa0NDLENBQWxDLEVBQXFDQyxDQUFyQyxFQUF3QztBQUN0QztBQUNBO0FBQ0EsTUFBTUMsVUFBVUYs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QixTQUFTRyxRQUExQixFQUFvQztBQUN6Q3lCO0FBQ0FFO0FBQ0Q7QUFDREgsZUFBV1IsU0FBU1MsRUFBVCxFQUFhQyxFQUFiLENBQVg7QUFDRDtBQUNEQyxZQUFVRCxLQUFLRCxFQUFmO0FBQ0FBLE9BQUssQ0FBTDtBQUNBQyxPQUFLLENBQUw7QUFDQUU7QUFDRDs7QUFFRDs7Ozs7Ozs7QUFRQSxTQUFTRyxZQUFULENBQXNCcEIsQ0FBdEIsRUFBeUJDLENBQXpCLEVBQTRCO0FBQzFCLE1BQU1DLFVBQVVGLEVBQUVILE1BQWxCO0FBQ0EsTUFBTU0sVUFBVUYsRUFBRUosTUFBbEI7QUFDQSxNQUFNd0IsZUFBZW5CLFVBQVVDLE9BQVYsR0FBb0JGLENBQXBCLEdBQXdCRCxDQUE3QztBQUNBcUIsZUFBYUMsSUFBYix3Q0FBcUJiLGFBQWFGLEtBQUtZLEdBQUwsQ0FBU2pCLFVBQVVDLE9BQW5CLENBQWIsQ0FBckI7QUFDRDtBQUNEOzs7Ozs7OztBQVFlLFNBQVNsQixXQUFULENBQXFCZSxDQUFyQixFQUF3QkMsQ0FBeEIsRUFBMkI7QUFDeEMsTUFBTXNCLGNBQWN4Qix5QkFBeUJDLENBQXpCLEVBQTRCQyxDQUE1QixDQUFwQjtBQUNBLE1BQUlzQixXQUFKLEVBQWlCO0FBQ2ZYLGtCQUFjVyxXQUFkLEVBQTJCdkIsQ0FBM0IsRUFBOEJDLENBQTlCO0FBQ0QsR0FGRCxNQUVPO0FBQ0xtQixpQkFBYXBCLENBQWIsRUFBZ0JDLENBQWhCO0FBQ0Q7QUFDRiIsImZpbGUiOiIxLmpzIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgTU9WRU1FTlQgPSB7XG4gIG5vbmU6IDAsXG4gIGRpYWdvbmFsOiAxLFxuICB2ZXJ0aWNhbDogMixcbiAgaG9yaXpvbnRhbDogMyxcbn07XG5cbmZ1bmN0aW9uIGluaXRNYXRyaXgoaGVpZ2h0LCB3aWR0aCkge1xuICBjb25zdCByb3dzID0gbmV3IEFycmF5KGhlaWdodCk7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgcm93cy5sZW5ndGg7IGkrKykge1xuICAgIHJvd3NbaV0gPSBuZXcgSW50MzJBcnJheSh3aWR0aCk7XG4gIH1cbiAgcmV0dXJuIHJvd3M7XG59XG5cbmZ1bmN0aW9uIGxvbmdlc3RDb21tb25TdWJzZXF1ZW5jZShhLCBiKSB7XG4gIC8vIGFkYXB0ZWQgZnJvbVxuICAvLyBodHRwOi8vYWxnb3JpdGhtcy50dXRvcmlhbGhvcml6b24uY29tL2R5bmFtaWMtcHJvZ3JhbW1pbmctbG9uZ2VzdC1jb21tb24tc3Vic2VxdWVuY2UvXG4gIGNvbnN0IGFMZW5ndGggPSBhLmxlbmd0aDtcbiAgY29uc3QgYkxlbmd0aCA9IGIubGVuZ3RoO1xuICBjb25zdCBtZW1vID0gaW5pdE1hdHJpeChhTGVuZ3RoICsgMSwgYkxlbmd0aCArIDEpO1xuICBjb25zdCBzb2x1dGlvbiA9IGluaXRNYXRyaXgoYUxlbmd0aCArIDEsIGJMZW5ndGggKyAxKTtcblxuICAvLyBMb29wIGFuZCBmaW5kIHRoZSBzb2x1dGlvblxuICBmb3IgKGxldCBpID0gMTsgaSA8PSBhTGVuZ3RoOyBpKyspIHtcbiAgICBmb3IgKGxldCBqID0gMTsgaiA8PSBiTGVuZ3RoOyBqKyspIHtcbiAgICAgIGlmIChhW2kgLSAxXSA9PT0gYltqIC0gMV0pIHtcbiAgICAgICAgLy8gZGlhZ29uYWxcbiAgICAgICAgbWVtb1tpXVtqXSA9IG1lbW9baSAtIDFdW2ogLSAxXSArIDE7XG4gICAgICAgIHNvbHV0aW9uW2ldW2pdID0gTU9WRU1FTlQuZGlhZ29uYWw7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBtZW1vW2ldW2pdID0gTWF0aC5tYXgobWVtb1tpIC0gMV1bal0sIG1lbW9baV1baiAtIDFdKTtcbiAgICAgICAgaWYgKG1lbW9baV1bal0gPT09IG1lbW9baSAtIDFdW2pdKSB7XG4gICAgICAgICAgc29sdXRpb25baV1bal0gPSBNT1ZFTUVOVC52ZXJ0aWNhbDtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBzb2x1dGlvbltpXVtqXSA9IE1PVkVNRU5ULmhvcml6b250YWw7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgaWYgKG1lbW9bYUxlbmd0aF1bYkxlbmd0aF0gPT09IDApIHtcbiAgICAvLyBObyBzb2x0dWlvbiBmb3VuZFxuICAgIHJldHVybiBudWxsO1xuICB9XG4gIHJldHVybiBzb2x1dGlvbjtcbn1cblxuZnVuY3Rpb24gcGxhY2Vob2xkZXJzKGNvdW50KSB7XG4gIGNvbnN0IHJlc3VsdCA9IG5ldyBBcnJheShjb3VudCk7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgY291bnQ7IGkrKykge1xuICAgIHJlc3VsdFtpXSA9ICcrJztcbiAgfVxuICByZXR1cm4gcmVzdWx0O1xufVxuLyoqXG4gKiBBcHBseSBhbiBsY3Mgc29sdXRpb24gdG8gYXJyYXlzLiBOb3RlIHRoYXQgdGhpcyB3aWxsIE1VVEFURSB0aGUgYXJyYXlzLFxuICogaW5qZWN0aW5nIFwiK1wiIHdoZXJlIGdhcHMgYXJlIG5lZWRlZC5cbiAqXG4gKiBAcGFyYW0ge0FycmF5PEFycmF5Pn0gc29sdXRpb24gYXMgY29tcHV0ZWQgYnkgYGxvbmdlc3RDb21tb25TdWJzZXF1ZW5jZWBcbiAqIEBwYXJhbSB7QXJyYXl9IGFcbiAqIEBwYXJhbSB7QXJyYXl9IGJcbiAqL1xuZnVuY3Rpb24gYXBwbHlTb2x1dGlvbihzb2x1dGlvbiwgYSwgYikge1xuICBsZXQgbW92ZW1lbnQgPSBzb2x1dGlvblthLmxlbmd0aF1bYi5sZW5ndGhdO1xuICBsZXQgYWkgPSBhLmxlbmd0aDtcbiAgbGV0IGJpID0gYi5sZW5ndGg7XG4gIGxldCBjaGFuZ2VzID0gMDtcblxuICBmdW5jdGlvbiBhcHBseUNoYW5nZSgpIHtcbiAgICBpZiAoY2hhbmdlcyA8IDApIHtcbiAgICAgIGIuc3BsaWNlKGJpLCAwLCAuLi5wbGFjZWhvbGRlcnMoTWF0aC5hYnMoY2hhbmdlcykpKTtcbiAgICB9IGVsc2UgaWYgKGNoYW5nZXMgPiAwKSB7XG4gICAgICBhLnNwbGljZShhaSwgMCwgLi4ucGxhY2Vob2xkZXJzKGNoYW5nZXMpKTtcbiAgICB9XG4gICAgY2hhbmdlcyA9IDA7XG4gIH1cblxuICB3aGlsZSAobW92ZW1lbnQgIT09IE1PVkVNRU5ULm5vbmUpIHtcbiAgICBpZiAobW92ZW1lbnQgPT09IE1PVkVNRU5ULmRpYWdvbmFsKSB7XG4gICAgICBhcHBseUNoYW5nZSgpO1xuICAgICAgYWktLTtcbiAgICAgIGJpLS07XG4gICAgfSBlbHNlIGlmIChtb3ZlbWVudCA9PT0gTU9WRU1FTlQuaG9yaXpvbnRhbCkge1xuICAgICAgYmktLTtcbiAgICAgIGNoYW5nZXMrKztcbiAgICB9IGVsc2UgaWYgKG1vdmVtZW50ID09PSBNT1ZFTUVOVC52ZXJ0aWNhbCkge1xuICAgICAgYWktLTtcbiAgICAgIGNoYW5nZXMtLTtcbiAgICB9XG4gICAgbW92ZW1lbnQgPSBzb2x1dGlvblthaV1bYmldO1xuICB9XG4gIGNoYW5nZXMgPSBiaSAtIGFpO1xuICBhaSA9IDA7XG4gIGJpID0gMDtcbiAgYXBwbHlDaGFuZ2UoKTtcbn1cblxuLyoqXG4gKiBUbyBiZSBjYWxsZWQgZm9yIGFycmF5cyB0aGF0IHNoYXJlIG5vdGhpbmcgaW4gY29tbW9uLlxuICpcbiAqIE5vdGUgdGhhdCB0aGlzIHdpbGwgTVVUQVRFIHRoZSBhcnJheXMsXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5mdW5jdGlvbiBhcHBseVBhZGRpbmcoYSwgYikge1xuICBjb25zdCBhTGVuZ3RoID0gYS5sZW5ndGg7XG4gIGNvbnN0IGJMZW5ndGggPSBiLmxlbmd0aDtcbiAgY29uc3Qgc2hvcnRlckFycmF5ID0gYUxlbmd0aCA+IGJMZW5ndGggPyBiIDogYTtcbiAgc2hvcnRlckFycmF5LnB1c2goLi4ucGxhY2Vob2xkZXJzKE1hdGguYWJzKGFMZW5ndGggLSBiTGVuZ3RoKSkpO1xufVxuLyoqXG4gKiBDb21wdXRlcyB0aGUgbG9uZ2VzdCBjb21tb24gc3Vic2VxdWVuY2Ugb2YgdHdvIGFycmF5cywgdGhlbiB1c2VzIHRoYXRcbiAqIHNvbHV0aW9uIHRvIGluamVjdCBnYXBzIGludG8gdGhlIGFycmF5cywgbWFraW5nIHRoZW0gYWxpZ24gb24gY29tbW9uXG4gKiBzdWJzZXF1ZW5jZXMuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhbGlnbkFycmF5cyhhLCBiKSB7XG4gIGNvbnN0IGxjc1NvbHV0aW9uID0gbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlKGEsIGIpO1xuICBpZiAobGNzU29sdXRpb24pIHtcbiAgICBhcHBseVNvbHV0aW9uKGxjc1NvbHV0aW9uLCBhLCBiKTtcbiAgfSBlbHNlIHtcbiAgICBhcHBseVBhZGRpbmcoYSwgYik7XG4gIH1cbn1cblxuXG5cbi8qKiBXRUJQQUNLIEZPT1RFUiAqKlxuICoqIC4vanMvc3JjL2FsaWduQXJyYXlzLmpzXG4gKiovIl0sInNvdXJjZVJvb3QiOiIifQ==");
|
54
|
+
|
55
|
+
/***/ }
|
56
|
+
/******/ ]);
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/******/ (function(modules) { // webpackBootstrap
|
2
|
+
/******/ // The module cache
|
3
|
+
/******/ var installedModules = {};
|
4
|
+
|
5
|
+
/******/ // The require function
|
6
|
+
/******/ function __webpack_require__(moduleId) {
|
7
|
+
|
8
|
+
/******/ // Check if module is in cache
|
9
|
+
/******/ if(installedModules[moduleId])
|
10
|
+
/******/ return installedModules[moduleId].exports;
|
11
|
+
|
12
|
+
/******/ // Create a new module (and put it into the cache)
|
13
|
+
/******/ var module = installedModules[moduleId] = {
|
14
|
+
/******/ exports: {},
|
15
|
+
/******/ id: moduleId,
|
16
|
+
/******/ loaded: false
|
17
|
+
/******/ };
|
18
|
+
|
19
|
+
/******/ // Execute the module function
|
20
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
21
|
+
|
22
|
+
/******/ // Flag the module as loaded
|
23
|
+
/******/ module.loaded = true;
|
24
|
+
|
25
|
+
/******/ // Return the exports of the module
|
26
|
+
/******/ return module.exports;
|
27
|
+
/******/ }
|
28
|
+
|
29
|
+
|
30
|
+
/******/ // expose the modules object (__webpack_modules__)
|
31
|
+
/******/ __webpack_require__.m = modules;
|
32
|
+
|
33
|
+
/******/ // expose the module cache
|
34
|
+
/******/ __webpack_require__.c = installedModules;
|
35
|
+
|
36
|
+
/******/ // __webpack_public_path__
|
37
|
+
/******/ __webpack_require__.p = "";
|
38
|
+
|
39
|
+
/******/ // Load entry module and return exports
|
40
|
+
/******/ return __webpack_require__(0);
|
41
|
+
/******/ })
|
42
|
+
/************************************************************************/
|
43
|
+
/******/ ([
|
44
|
+
/* 0 */
|
45
|
+
/***/ function(module, exports, __webpack_require__) {
|
46
|
+
|
47
|
+
eval("'use strict';\n\nvar _alignArrays = __webpack_require__(1);\n\nvar _alignArrays2 = _interopRequireDefault(_alignArrays);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction imageTo2DArray(_ref, paddingRight) {\n var data = _ref.data;\n var width = _ref.width;\n var height = _ref.height;\n\n // The imageData is a 1D array. Each element in the array corresponds to a\n // decimal value that represents one of the RGBA channels for that pixel.\n var rowSize = width * 4;\n\n var newData = [];\n for (var row = 0; row < height; row++) {\n var pixelsInRow = new Uint8ClampedArray(rowSize + paddingRight * 4);\n for (var location = 0; location < rowSize; location++) {\n pixelsInRow[location] = data[row * rowSize + location];\n }\n newData.push(pixelsInRow);\n }\n return newData;\n}\n\nfunction align(_ref2) {\n var previousImageData = _ref2.previousImageData;\n var currentImageData = _ref2.currentImageData;\n var maxWidth = _ref2.maxWidth;\n\n var hashedPreviousData = previousImageData.map(JSON.stringify);\n self.postMessage({ progress: 40 });\n var hashedCurrentData = currentImageData.map(JSON.stringify);\n self.postMessage({ progress: 60 });\n\n (0, _alignArrays2.default)(hashedPreviousData, hashedCurrentData);\n\n var transparentLine = new Uint8ClampedArray(maxWidth * 4);\n\n hashedPreviousData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n previousImageData.splice(i, 0, transparentLine);\n }\n });\n\n hashedCurrentData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n currentImageData.splice(i, 0, transparentLine);\n }\n });\n}\n\n/**\n * Takes two 2d images, computes the diff between the two, and injects pixels to\n * both in order to:\n * a) make both images the same height\n * b) properly visualize differences\n *\n * Please note that this method MUTATES data.\n *\n * @param {Array} previousData\n * @param {Array} currentData\n */\nfunction computeAndInjectDiffs(_ref3) {\n var previousData = _ref3.previousData;\n var currentData = _ref3.currentData;\n\n var maxWidth = Math.max(previousData.width, currentData.width);\n\n var previousImageData = imageTo2DArray(previousData, maxWidth - previousData.width);\n\n var currentImageData = imageTo2DArray(currentData, maxWidth - currentData.width);\n\n self.postMessage({ progress: 20 });\n\n align({\n previousImageData: previousImageData,\n currentImageData: currentImageData,\n maxWidth: maxWidth\n });\n\n self.postMessage({ progress: 85 });\n\n return {\n currentData: {\n data: currentImageData,\n height: currentImageData.length,\n width: maxWidth\n },\n previousData: {\n data: previousImageData,\n height: previousImageData.length,\n width: maxWidth\n }\n };\n}\n\nself.addEventListener('message', function (_ref4) {\n var _ref4$data = _ref4.data;\n var previousData = _ref4$data.previousData;\n var currentData = _ref4$data.currentData;\n\n var result = computeAndInjectDiffs({ previousData: previousData, currentData: currentData });\n self.postMessage(result);\n self.close();\n});//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvd29ya2Vycy9Db21wdXRlQW5kSW5qZWN0RGlmZnNXb3JrZXIuanM/ZGRiNSJdLCJuYW1lcyI6WyJpbWFnZVRvMkRBcnJheSIsInBhZGRpbmdSaWdodCIsImRhdGEiLCJ3aWR0aCIsImhlaWdodCIsInJvd1NpemUiLCJuZXdEYXRhIiwicm93IiwicGl4ZWxzSW5Sb3ciLCJVaW50OENsYW1wZWRBcnJheSIsImxvY2F0aW9uIiwicHVzaCIsImFsaWduIiwicHJldmlvdXNJbWFnZURhdGEiLCJjdXJyZW50SW1hZ2VEYXRhIiwibWF4V2lkdGgiLCJoYXNoZWRQcmV2aW91c0RhdGEiLCJtYXAiLCJKU09OIiwic3RyaW5naWZ5Iiwic2VsZiIsInBvc3RNZXNzYWdlIiwicHJvZ3Jlc3MiLCJoYXNoZWRDdXJyZW50RGF0YSIsInRyYW5zcGFyZW50TGluZSIsImZvckVhY2giLCJoYXNoZWRMaW5lIiwiaSIsInNwbGljZSIsImNvbXB1dGVBbmRJbmplY3REaWZmcyIsInByZXZpb3VzRGF0YSIsImN1cnJlbnREYXRhIiwiTWF0aCIsIm1heCIsImxlbmd0aCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXN1bHQiLCJjbG9zZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0FBRUEsU0FBU0EsY0FBVCxPQUFpREMsWUFBakQsRUFBK0Q7QUFBQSxNQUFyQ0MsSUFBcUMsUUFBckNBLElBQXFDO0FBQUEsTUFBL0JDLEtBQStCLFFBQS9CQSxLQUErQjtBQUFBLE1BQXhCQyxNQUF3QixRQUF4QkEsTUFBd0I7O0FBQzdEO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixRQUFRLENBQXhCOztBQUVBLE1BQU1HLFVBQVUsRUFBaEI7QUFDQSxPQUFLLElBQUlDLE1BQU0sQ0FBZixFQUFrQkEsTUFBTUgsTUFBeEIsRUFBZ0NHLEtBQWhDLEVBQXVDO0FBQ3JDLFFBQU1DLGNBQWMsSUFBSUMsaUJBQUosQ0FBc0JKLFVBQVdKLGVBQWUsQ0FBaEQsQ0FBcEI7QUFDQSxT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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFsaWduQXJyYXlzIGZyb20gJy4uL2FsaWduQXJyYXlzJztcblxuZnVuY3Rpb24gaW1hZ2VUbzJEQXJyYXkoeyBkYXRhLCB3aWR0aCwgaGVpZ2h0IH0sIHBhZGRpbmdSaWdodCkge1xuICAvLyBUaGUgaW1hZ2VEYXRhIGlzIGEgMUQgYXJyYXkuIEVhY2ggZWxlbWVudCBpbiB0aGUgYXJyYXkgY29ycmVzcG9uZHMgdG8gYVxuICAvLyBkZWNpbWFsIHZhbHVlIHRoYXQgcmVwcmVzZW50cyBvbmUgb2YgdGhlIFJHQkEgY2hhbm5lbHMgZm9yIHRoYXQgcGl4ZWwuXG4gIGNvbnN0IHJvd1NpemUgPSB3aWR0aCAqIDQ7XG5cbiAgY29uc3QgbmV3RGF0YSA9IFtdO1xuICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCBoZWlnaHQ7IHJvdysrKSB7XG4gICAgY29uc3QgcGl4ZWxzSW5Sb3cgPSBuZXcgVWludDhDbGFtcGVkQXJyYXkocm93U2l6ZSArIChwYWRkaW5nUmlnaHQgKiA0KSk7XG4gICAgZm9yIChsZXQgbG9jYXRpb24gPSAwOyBsb2NhdGlvbiA8IHJvd1NpemU7IGxvY2F0aW9uKyspIHtcbiAgICAgIHBpeGVsc0luUm93W2xvY2F0aW9uXSA9IGRhdGFbKHJvdyAqIHJvd1NpemUpICsgbG9jYXRpb25dO1xuICAgIH1cbiAgICBuZXdEYXRhLnB1c2gocGl4ZWxzSW5Sb3cpO1xuICB9XG4gIHJldHVybiBuZXdEYXRhO1xufVxuXG5mdW5jdGlvbiBhbGlnbih7XG4gIHByZXZpb3VzSW1hZ2VEYXRhLFxuICBjdXJyZW50SW1hZ2VEYXRhLFxuICBtYXhXaWR0aCxcbn0pIHtcbiAgY29uc3QgaGFzaGVkUHJldmlvdXNEYXRhID0gcHJldmlvdXNJbWFnZURhdGEubWFwKEpTT04uc3RyaW5naWZ5KTtcbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA0MCB9KTtcbiAgY29uc3QgaGFzaGVkQ3VycmVudERhdGEgPSBjdXJyZW50SW1hZ2VEYXRhLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UoeyBwcm9ncmVzczogNjAgfSk7XG5cbiAgYWxpZ25BcnJheXMoXG4gICAgaGFzaGVkUHJldmlvdXNEYXRhLFxuICAgIGhhc2hlZEN1cnJlbnREYXRhXG4gICk7XG5cbiAgY29uc3QgdHJhbnNwYXJlbnRMaW5lID0gbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KG1heFdpZHRoICogNCk7XG5cbiAgaGFzaGVkUHJldmlvdXNEYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBwcmV2aW91c0ltYWdlRGF0YS5zcGxpY2UoaSwgMCwgdHJhbnNwYXJlbnRMaW5lKTtcbiAgICB9XG4gIH0pO1xuXG4gIGhhc2hlZEN1cnJlbnREYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBjdXJyZW50SW1hZ2VEYXRhLnNwbGljZShpLCAwLCB0cmFuc3BhcmVudExpbmUpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogVGFrZXMgdHdvIDJkIGltYWdlcywgY29tcHV0ZXMgdGhlIGRpZmYgYmV0d2VlbiB0aGUgdHdvLCBhbmQgaW5qZWN0cyBwaXhlbHMgdG9cbiAqIGJvdGggaW4gb3JkZXIgdG86XG4gKiBhKSBtYWtlIGJvdGggaW1hZ2VzIHRoZSBzYW1lIGhlaWdodFxuICogYikgcHJvcGVybHkgdmlzdWFsaXplIGRpZmZlcmVuY2VzXG4gKlxuICogUGxlYXNlIG5vdGUgdGhhdCB0aGlzIG1ldGhvZCBNVVRBVEVTIGRhdGEuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gcHJldmlvdXNEYXRhXG4gKiBAcGFyYW0ge0FycmF5fSBjdXJyZW50RGF0YVxuICovXG5mdW5jdGlvbiBjb21wdXRlQW5kSW5qZWN0RGlmZnMoeyBwcmV2aW91c0RhdGEsIGN1cnJlbnREYXRhIH0pIHtcbiAgY29uc3QgbWF4V2lkdGggPSBNYXRoLm1heChwcmV2aW91c0RhdGEud2lkdGgsIGN1cnJlbnREYXRhLndpZHRoKTtcblxuICBjb25zdCBwcmV2aW91c0ltYWdlRGF0YSA9IGltYWdlVG8yREFycmF5KFxuICAgIHByZXZpb3VzRGF0YSwgbWF4V2lkdGggLSBwcmV2aW91c0RhdGEud2lkdGgpO1xuXG4gIGNvbnN0IGN1cnJlbnRJbWFnZURhdGEgPSBpbWFnZVRvMkRBcnJheShcbiAgICBjdXJyZW50RGF0YSwgbWF4V2lkdGggLSBjdXJyZW50RGF0YS53aWR0aCk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiAyMCB9KTtcblxuICBhbGlnbih7XG4gICAgcHJldmlvdXNJbWFnZURhdGEsXG4gICAgY3VycmVudEltYWdlRGF0YSxcbiAgICBtYXhXaWR0aCxcbiAgfSk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA4NSB9KTtcblxuICByZXR1cm4ge1xuICAgIGN1cnJlbnREYXRhOiB7XG4gICAgICBkYXRhOiBjdXJyZW50SW1hZ2VEYXRhLFxuICAgICAgaGVpZ2h0OiBjdXJyZW50SW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICAgIHByZXZpb3VzRGF0YToge1xuICAgICAgZGF0YTogcHJldmlvdXNJbWFnZURhdGEsXG4gICAgICBoZWlnaHQ6IHByZXZpb3VzSW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICB9O1xufVxuXG5zZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCAoeyBkYXRhOiB7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSB9KSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IGNvbXB1dGVBbmRJbmplY3REaWZmcyh7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UocmVzdWx0KTtcbiAgc2VsZi5jbG9zZSgpO1xufSk7XG5cblxuXG4vKiogV0VCUEFDSyBGT09URVIgKipcbiAqKiAuL2pzL3NyYy93b3JrZXJzL0NvbXB1dGVBbmRJbmplY3REaWZmc1dvcmtlci5qc1xuICoqLyJdLCJzb3VyY2VSb290IjoiIn0=");
|
48
|
+
|
49
|
+
/***/ },
|
50
|
+
/* 1 */
|
51
|
+
/***/ function(module, exports) {
|
52
|
+
|
53
|
+
eval("'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = alignArrays;\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar MOVEMENT = {\n none: 0,\n diagonal: 1,\n vertical: 2,\n horizontal: 3\n};\n\nfunction initMatrix(height, width) {\n var rows = new Array(height);\n for (var i = 0; i < rows.length; i++) {\n rows[i] = new Int32Array(width);\n }\n return rows;\n}\n\nfunction longestCommonSubsequence(a, b) {\n // adapted from\n // http://algorithms.tutorialhorizon.com/dynamic-programming-longest-common-subsequence/\n var aLength = a.length;\n var bLength = b.length;\n var memo = initMatrix(aLength + 1, bLength + 1);\n var solution = initMatrix(aLength + 1, bLength + 1);\n\n // Loop and find the solution\n for (var i = 1; i <= aLength; i++) {\n for (var j = 1; j <= bLength; j++) {\n if (a[i - 1] === b[j - 1]) {\n // diagonal\n memo[i][j] = memo[i - 1][j - 1] + 1;\n solution[i][j] = MOVEMENT.diagonal;\n } else {\n memo[i][j] = Math.max(memo[i - 1][j], memo[i][j - 1]);\n if (memo[i][j] === memo[i - 1][j]) {\n solution[i][j] = MOVEMENT.vertical;\n } else {\n solution[i][j] = MOVEMENT.horizontal;\n }\n }\n }\n }\n if (memo[aLength][bLength] === 0) {\n // No soltuion found\n return null;\n }\n return solution;\n}\n\nfunction placeholders(count) {\n console.log(count);\n var result = new Array(count);\n for (var i = 0; i < count; i++) {\n result[i] = '+';\n }\n return result;\n}\n/**\n * Apply an lcs solution to arrays. Note that this will MUTATE the arrays,\n * injecting \"+\" where gaps are needed.\n *\n * @param {Array<Array>} solution as computed by `longestCommonSubsequence`\n * @param {Array} a\n * @param {Array} b\n */\nfunction applySolution(solution, a, b) {\n var movement = solution[a.length][b.length];\n var ai = a.length;\n var bi = b.length;\n\n var changes = 0;\n\n while (movement !== MOVEMENT.none) {\n if (movement === MOVEMENT.diagonal) {\n if (changes < 0) {\n b.splice.apply(b, [bi, 0].concat(_toConsumableArray(placeholders(Math.abs(changes)))));\n } else if (changes > 0) {\n a.splice.apply(a, [ai, 0].concat(_toConsumableArray(placeholders(changes))));\n }\n ai--;\n bi--;\n changes = 0;\n } else if (movement === MOVEMENT.horizontal) {\n bi--;\n changes++;\n } else if (movement === MOVEMENT.vertical) {\n ai--;\n changes--;\n }\n movement = solution[ai][bi];\n }\n}\n\n/**\n * To be called for arrays that share nothing in common.\n *\n * Note that this will MUTATE the arrays,\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction applyPadding(a, b) {\n var aLength = a.length;\n var bLength = b.Length;\n\n var shorterArray = aLength > bLength ? b : a;\n\n shorterArray.push(placeholders(Math.abs(aLength - bLength)));\n}\n/**\n * Computes the longest common subsequence of two arrays, then uses that\n * solution to inject gaps into the arrays, making them align on common\n * subsequences.\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction alignArrays(a, b) {\n var lcsSolution = longestCommonSubsequence(a, b);\n if (!lcsSolution) {\n applyPadding(a, b);\n }\n applySolution(lcsSolution, a, b);\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvYWxpZ25BcnJheXMuanM/MDFiNyJdLCJuYW1lcyI6WyJhbGlnbkFycmF5cyIsIk1PVkVNRU5UIiwibm9uZSIsImRpYWdvbmFsIiwidmVydGljYWwiLCJob3Jpem9udGFsIiwiaW5pdE1hdHJpeCIsImhlaWdodCIsIndpZHRoIiwicm93cyIsIkFycmF5IiwiaSIsImxlbmd0aCIsIkludDMyQXJyYXkiLCJsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UiLCJhIiwiYiIsImFMZW5ndGgiLCJiTGVuZ3RoIiwibWVtbyIsInNvbHV0aW9uIiwiaiIsIk1hdGgiLCJtYXgiLCJwbGFjZWhvbGRlcnMiLCJjb3VudCIsImNvbnNvbGUiLCJsb2ciLCJyZXN1bHQiLCJhcHBseVNvbHV0aW9uIiwibW92ZW1lbnQiLCJhaSIsImJpIiwiY2hhbmdlcyIsInNwbGljZSIsImFicyIsImFwcGx5UGFkZGluZyIsIkxlbmd0aCIsInNob3J0ZXJBcnJheSIsInB1c2giLCJsY3NTb2x1dGlvbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7a0JBbUh3QkEsVzs7OztBQW5IeEIsSUFBTUMsV0FBVztBQUNmQyxRQUFNLENBRFM7QUFFZkMsWUFBVSxDQUZLO0FBR2ZDLFlBQVUsQ0FISztBQUlmQyxjQUFZO0FBSkcsQ0FBakI7O0FBT0EsU0FBU0MsVUFBVCxDQUFvQkMsTUFBcEIsRUFBNEJDLEtBQTVCLEVBQW1DO0FBQ2pDLE1BQU1DLE9BQU8sSUFBSUMsS0FBSixDQUFVSCxNQUFWLENBQWI7QUFDQSxPQUFLLElBQUlJLElBQUksQ0FBYixFQUFnQkEsSUFBSUYsS0FBS0csTUFBekIsRUFBaUNELEdBQWpDLEVBQXNDO0FBQ3BDRixTQUFLRSxDQUFMLElBQVUsSUFBSUUsVUFBSixDQUFlTCxLQUFmLENBQVY7QUFDRDtBQUNELFNBQU9DLElBQVA7QUFDRDs7QUFFRCxTQUFTSyx3QkFBVCxDQUFrQ0MsQ0FBbEMsRUFBcUNDLENBQXJDLEVBQXdDO0FBQ3RDO0FBQ0E7QUFDQSxN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LElBQUlILGFBQWE3QixTQUFTRyxRQUExQixFQUFvQztBQUN6QzJCO0FBQ0FFO0FBQ0Q7QUFDREgsZUFBV1YsU0FBU1csRUFBVCxFQUFhQyxFQUFiLENBQVg7QUFDRDtBQUNGOztBQUVEOzs7Ozs7OztBQVFBLFNBQVNJLFlBQVQsQ0FBc0JyQixDQUF0QixFQUF5QkMsQ0FBekIsRUFBNEI7QUFDMUIsTUFBTUMsVUFBVUYsRUFBRUgsTUFBbEI7QUFDQSxNQUFNTSxVQUFVRixFQUFFcUIsTUFBbEI7O0FBRUEsTUFBTUMsZUFBZXJCLFVBQVVDLE9BQVYsR0FBb0JGLENBQXBCLEdBQXdCRCxDQUE3Qzs7QUFFQXVCLGVBQWFDLElBQWIsQ0FBa0JmLGFBQWFGLEtBQUthLEdBQUwsQ0FBU2xCLFVBQVVDLE9BQW5CLENBQWIsQ0FBbEI7QUFDRDtBQUNEOzs7Ozs7OztBQVFlLFNBQVNsQixXQUFULENBQXFCZSxDQUFyQixFQUF3QkMsQ0FBeEIsRUFBMkI7QUFDeEMsTUFBTXdCLGNBQWMxQix5QkFBeUJDLENBQXpCLEVBQTRCQyxDQUE1QixDQUFwQjtBQUNBLE1BQUksQ0FBQ3dCLFdBQUwsRUFBa0I7QUFDaEJKLGlCQUFhckIsQ0FBYixFQUFnQkMsQ0FBaEI7QUFDRDtBQUNEYSxnQkFBY1csV0FBZCxFQUEyQnpCLENBQTNCLEVBQThCQyxDQUE5QjtBQUNEIiwiZmlsZSI6IjEuanMiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBNT1ZFTUVOVCA9IHtcbiAgbm9uZTogMCxcbiAgZGlhZ29uYWw6IDEsXG4gIHZlcnRpY2FsOiAyLFxuICBob3Jpem9udGFsOiAzLFxufTtcblxuZnVuY3Rpb24gaW5pdE1hdHJpeChoZWlnaHQsIHdpZHRoKSB7XG4gIGNvbnN0IHJvd3MgPSBuZXcgQXJyYXkoaGVpZ2h0KTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCByb3dzLmxlbmd0aDsgaSsrKSB7XG4gICAgcm93c1tpXSA9IG5ldyBJbnQzMkFycmF5KHdpZHRoKTtcbiAgfVxuICByZXR1cm4gcm93cztcbn1cblxuZnVuY3Rpb24gbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlKGEsIGIpIHtcbiAgLy8gYWRhcHRlZCBmcm9tXG4gIC8vIGh0dHA6Ly9hbGdvcml0aG1zLnR1dG9yaWFsaG9yaXpvbi5jb20vZHluYW1pYy1wcm9ncmFtbWluZy1sb25nZXN0LWNvbW1vbi1zdWJzZXF1ZW5jZS9cbiAgY29uc3QgYUxlbmd0aCA9IGEubGVuZ3RoO1xuICBjb25zdCBiTGVuZ3RoID0gYi5sZW5ndGg7XG4gIGNvbnN0IG1lbW8gPSBpbml0TWF0cml4KGFMZW5ndGggKyAxLCBiTGVuZ3RoICsgMSk7XG4gIGNvbnN0IHNvbHV0aW9uID0gaW5pdE1hdHJpeChhTGVuZ3RoICsgMSwgYkxlbmd0aCArIDEpO1xuXG4gIC8vIExvb3AgYW5kIGZpbmQgdGhlIHNvbHV0aW9uXG4gIGZvciAobGV0IGkgPSAxOyBpIDw9IGFMZW5ndGg7IGkrKykge1xuICAgIGZvciAobGV0IGogPSAxOyBqIDw9IGJMZW5ndGg7IGorKykge1xuICAgICAgaWYgKGFbaSAtIDFdID09PSBiW2ogLSAxXSkge1xuICAgICAgICAvLyBkaWFnb25hbFxuICAgICAgICBtZW1vW2ldW2pdID0gbWVtb1tpIC0gMV1baiAtIDFdICsgMTtcbiAgICAgICAgc29sdXRpb25baV1bal0gPSBNT1ZFTUVOVC5kaWFnb25hbDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIG1lbW9baV1bal0gPSBNYXRoLm1heChtZW1vW2kgLSAxXVtqXSwgbWVtb1tpXVtqIC0gMV0pO1xuICAgICAgICBpZiAobWVtb1tpXVtqXSA9PT0gbWVtb1tpIC0gMV1bal0pIHtcbiAgICAgICAgICBzb2x1dGlvbltpXVtqXSA9IE1PVkVNRU5ULnZlcnRpY2FsO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHNvbHV0aW9uW2ldW2pdID0gTU9WRU1FTlQuaG9yaXpvbnRhbDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuICBpZiAobWVtb1thTGVuZ3RoXVtiTGVuZ3RoXSA9PT0gMCkge1xuICAgIC8vIE5vIHNvbHR1aW9uIGZvdW5kXG4gICAgcmV0dXJuIG51bGw7XG4gIH1cbiAgcmV0dXJuIHNvbHV0aW9uO1xufVxuXG5mdW5jdGlvbiBwbGFjZWhvbGRlcnMoY291bnQpIHtcbiAgY29uc29sZS5sb2coY291bnQpXG4gIGNvbnN0IHJlc3VsdCA9IG5ldyBBcnJheShjb3VudCk7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgY291bnQ7IGkrKykge1xuICAgIHJlc3VsdFtpXSA9ICcrJztcbiAgfVxuICByZXR1cm4gcmVzdWx0O1xufVxuLyoqXG4gKiBBcHBseSBhbiBsY3Mgc29sdXRpb24gdG8gYXJyYXlzLiBOb3RlIHRoYXQgdGhpcyB3aWxsIE1VVEFURSB0aGUgYXJyYXlzLFxuICogaW5qZWN0aW5nIFwiK1wiIHdoZXJlIGdhcHMgYXJlIG5lZWRlZC5cbiAqXG4gKiBAcGFyYW0ge0FycmF5PEFycmF5Pn0gc29sdXRpb24gYXMgY29tcHV0ZWQgYnkgYGxvbmdlc3RDb21tb25TdWJzZXF1ZW5jZWBcbiAqIEBwYXJhbSB7QXJyYXl9IGFcbiAqIEBwYXJhbSB7QXJyYXl9IGJcbiAqL1xuZnVuY3Rpb24gYXBwbHlTb2x1dGlvbihzb2x1dGlvbiwgYSwgYikge1xuICBsZXQgbW92ZW1lbnQgPSBzb2x1dGlvblthLmxlbmd0aF1bYi5sZW5ndGhdO1xuICBsZXQgYWkgPSBhLmxlbmd0aDtcbiAgbGV0IGJpID0gYi5sZW5ndGg7XG5cbiAgbGV0IGNoYW5nZXMgPSAwO1xuXG4gIHdoaWxlIChtb3ZlbWVudCAhPT0gTU9WRU1FTlQubm9uZSkge1xuICAgIGlmIChtb3ZlbWVudCA9PT0gTU9WRU1FTlQuZGlhZ29uYWwpIHtcbiAgICAgIGlmIChjaGFuZ2VzIDwgMCkge1xuICAgICAgICBiLnNwbGljZShiaSwgMCwgLi4ucGxhY2Vob2xkZXJzKE1hdGguYWJzKGNoYW5nZXMpKSk7XG4gICAgICB9IGVsc2UgaWYgKGNoYW5nZXMgPiAwKSB7XG4gICAgICAgIGEuc3BsaWNlKGFpLCAwLCAuLi5wbGFjZWhvbGRlcnMoY2hhbmdlcykpO1xuICAgICAgfVxuICAgICAgYWktLTtcbiAgICAgIGJpLS07XG4gICAgICBjaGFuZ2VzID0gMDtcbiAgICB9IGVsc2UgaWYgKG1vdmVtZW50ID09PSBNT1ZFTUVOVC5ob3Jpem9udGFsKSB7XG4gICAgICBiaS0tO1xuICAgICAgY2hhbmdlcysrO1xuICAgIH0gZWxzZSBpZiAobW92ZW1lbnQgPT09IE1PVkVNRU5ULnZlcnRpY2FsKSB7XG4gICAgICBhaS0tO1xuICAgICAgY2hhbmdlcy0tO1xuICAgIH1cbiAgICBtb3ZlbWVudCA9IHNvbHV0aW9uW2FpXVtiaV07XG4gIH1cbn1cblxuLyoqXG4gKiBUbyBiZSBjYWxsZWQgZm9yIGFycmF5cyB0aGF0IHNoYXJlIG5vdGhpbmcgaW4gY29tbW9uLlxuICpcbiAqIE5vdGUgdGhhdCB0aGlzIHdpbGwgTVVUQVRFIHRoZSBhcnJheXMsXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5mdW5jdGlvbiBhcHBseVBhZGRpbmcoYSwgYikge1xuICBjb25zdCBhTGVuZ3RoID0gYS5sZW5ndGg7XG4gIGNvbnN0IGJMZW5ndGggPSBiLkxlbmd0aDtcblxuICBjb25zdCBzaG9ydGVyQXJyYXkgPSBhTGVuZ3RoID4gYkxlbmd0aCA/IGIgOiBhO1xuXG4gIHNob3J0ZXJBcnJheS5wdXNoKHBsYWNlaG9sZGVycyhNYXRoLmFicyhhTGVuZ3RoIC0gYkxlbmd0aCkpKTtcbn1cbi8qKlxuICogQ29tcHV0ZXMgdGhlIGxvbmdlc3QgY29tbW9uIHN1YnNlcXVlbmNlIG9mIHR3byBhcnJheXMsIHRoZW4gdXNlcyB0aGF0XG4gKiBzb2x1dGlvbiB0byBpbmplY3QgZ2FwcyBpbnRvIHRoZSBhcnJheXMsIG1ha2luZyB0aGVtIGFsaWduIG9uIGNvbW1vblxuICogc3Vic2VxdWVuY2VzLlxuICpcbiAqIEBwYXJhbSB7QXJyYXl9IGFcbiAqIEBwYXJhbSB7QXJyYXl9IGJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gYWxpZ25BcnJheXMoYSwgYikge1xuICBjb25zdCBsY3NTb2x1dGlvbiA9IGxvbmdlc3RDb21tb25TdWJzZXF1ZW5jZShhLCBiKTtcbiAgaWYgKCFsY3NTb2x1dGlvbikge1xuICAgIGFwcGx5UGFkZGluZyhhLCBiKTtcbiAgfVxuICBhcHBseVNvbHV0aW9uKGxjc1NvbHV0aW9uLCBhLCBiKTtcbn1cblxuXG5cbi8qKiBXRUJQQUNLIEZPT1RFUiAqKlxuICoqIC4vanMvc3JjL2FsaWduQXJyYXlzLmpzXG4gKiovIl0sInNvdXJjZVJvb3QiOiIifQ==");
|
54
|
+
|
55
|
+
/***/ }
|
56
|
+
/******/ ]);
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/******/ (function(modules) { // webpackBootstrap
|
2
|
+
/******/ // The module cache
|
3
|
+
/******/ var installedModules = {};
|
4
|
+
|
5
|
+
/******/ // The require function
|
6
|
+
/******/ function __webpack_require__(moduleId) {
|
7
|
+
|
8
|
+
/******/ // Check if module is in cache
|
9
|
+
/******/ if(installedModules[moduleId])
|
10
|
+
/******/ return installedModules[moduleId].exports;
|
11
|
+
|
12
|
+
/******/ // Create a new module (and put it into the cache)
|
13
|
+
/******/ var module = installedModules[moduleId] = {
|
14
|
+
/******/ exports: {},
|
15
|
+
/******/ id: moduleId,
|
16
|
+
/******/ loaded: false
|
17
|
+
/******/ };
|
18
|
+
|
19
|
+
/******/ // Execute the module function
|
20
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
21
|
+
|
22
|
+
/******/ // Flag the module as loaded
|
23
|
+
/******/ module.loaded = true;
|
24
|
+
|
25
|
+
/******/ // Return the exports of the module
|
26
|
+
/******/ return module.exports;
|
27
|
+
/******/ }
|
28
|
+
|
29
|
+
|
30
|
+
/******/ // expose the modules object (__webpack_modules__)
|
31
|
+
/******/ __webpack_require__.m = modules;
|
32
|
+
|
33
|
+
/******/ // expose the module cache
|
34
|
+
/******/ __webpack_require__.c = installedModules;
|
35
|
+
|
36
|
+
/******/ // __webpack_public_path__
|
37
|
+
/******/ __webpack_require__.p = "";
|
38
|
+
|
39
|
+
/******/ // Load entry module and return exports
|
40
|
+
/******/ return __webpack_require__(0);
|
41
|
+
/******/ })
|
42
|
+
/************************************************************************/
|
43
|
+
/******/ ([
|
44
|
+
/* 0 */
|
45
|
+
/***/ function(module, exports, __webpack_require__) {
|
46
|
+
|
47
|
+
eval("'use strict';\n\nvar _alignArrays = __webpack_require__(1);\n\nvar _alignArrays2 = _interopRequireDefault(_alignArrays);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction imageTo2DArray(_ref, paddingRight) {\n var data = _ref.data;\n var width = _ref.width;\n var height = _ref.height;\n\n // The imageData is a 1D array. Each element in the array corresponds to a\n // decimal value that represents one of the RGBA channels for that pixel.\n var rowSize = width * 4;\n\n var newData = [];\n for (var row = 0; row < height; row++) {\n var pixelsInRow = new Uint8ClampedArray(rowSize + paddingRight * 4);\n for (var location = 0; location < rowSize; location++) {\n pixelsInRow[location] = data[row * rowSize + location];\n }\n newData.push(pixelsInRow);\n }\n return newData;\n}\n\nfunction align(_ref2) {\n var previousImageData = _ref2.previousImageData;\n var currentImageData = _ref2.currentImageData;\n var maxWidth = _ref2.maxWidth;\n\n var hashedPreviousData = previousImageData.map(JSON.stringify);\n self.postMessage({ progress: 40 });\n var hashedCurrentData = currentImageData.map(JSON.stringify);\n self.postMessage({ progress: 60 });\n\n (0, _alignArrays2.default)(hashedPreviousData, hashedCurrentData);\n\n var transparentLine = new Uint8ClampedArray(maxWidth * 4);\n\n hashedPreviousData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n previousImageData.splice(i, 0, transparentLine);\n }\n });\n\n hashedCurrentData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n currentImageData.splice(i, 0, transparentLine);\n }\n });\n}\n\n/**\n * Takes two 2d images, computes the diff between the two, and injects pixels to\n * both in order to:\n * a) make both images the same height\n * b) properly visualize differences\n *\n * Please note that this method MUTATES data.\n *\n * @param {Array} previousData\n * @param {Array} currentData\n */\nfunction computeAndInjectDiffs(_ref3) {\n var previousData = _ref3.previousData;\n var currentData = _ref3.currentData;\n\n var maxWidth = Math.max(previousData.width, currentData.width);\n\n var previousImageData = imageTo2DArray(previousData, maxWidth - previousData.width);\n\n var currentImageData = imageTo2DArray(currentData, maxWidth - currentData.width);\n\n self.postMessage({ progress: 20 });\n\n align({\n previousImageData: previousImageData,\n currentImageData: currentImageData,\n maxWidth: maxWidth\n });\n\n self.postMessage({ progress: 85 });\n\n return {\n currentData: {\n data: currentImageData,\n height: currentImageData.length,\n width: maxWidth\n },\n previousData: {\n data: previousImageData,\n height: previousImageData.length,\n width: maxWidth\n }\n };\n}\n\nself.addEventListener('message', function (_ref4) {\n var _ref4$data = _ref4.data;\n var previousData = _ref4$data.previousData;\n var currentData = _ref4$data.currentData;\n\n var result = computeAndInjectDiffs({ previousData: previousData, currentData: currentData });\n self.postMessage(result);\n self.close();\n});//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvd29ya2Vycy9Db21wdXRlQW5kSW5qZWN0RGlmZnNXb3JrZXIuanM/ZGRiNSJdLCJuYW1lcyI6WyJpbWFnZVRvMkRBcnJheSIsInBhZGRpbmdSaWdodCIsImRhdGEiLCJ3aWR0aCIsImhlaWdodCIsInJvd1NpemUiLCJuZXdEYXRhIiwicm93IiwicGl4ZWxzSW5Sb3ciLCJVaW50OENsYW1wZWRBcnJheSIsImxvY2F0aW9uIiwicHVzaCIsImFsaWduIiwicHJldmlvdXNJbWFnZURhdGEiLCJjdXJyZW50SW1hZ2VEYXRhIiwibWF4V2lkdGgiLCJoYXNoZWRQcmV2aW91c0RhdGEiLCJtYXAiLCJKU09OIiwic3RyaW5naWZ5Iiwic2VsZiIsInBvc3RNZXNzYWdlIiwicHJvZ3Jlc3MiLCJoYXNoZWRDdXJyZW50RGF0YSIsInRyYW5zcGFyZW50TGluZSIsImZvckVhY2giLCJoYXNoZWRMaW5lIiwiaSIsInNwbGljZSIsImNvbXB1dGVBbmRJbmplY3REaWZmcyIsInByZXZpb3VzRGF0YSIsImN1cnJlbnREYXRhIiwiTWF0aCIsIm1heCIsImxlbmd0aCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXN1bHQiLCJjbG9zZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0FBRUEsU0FBU0EsY0FBVCxPQUFpREMsWUFBakQsRUFBK0Q7QUFBQSxNQUFyQ0MsSUFBcUMsUUFBckNBLElBQXFDO0FBQUEsTUFBL0JDLEtBQStCLFFBQS9CQSxLQUErQjtBQUFBLE1BQXhCQyxNQUF3QixRQUF4QkEsTUFBd0I7O0FBQzdEO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixRQUFRLENBQXhCOztBQUVBLE1BQU1HLFVBQVUsRUFBaEI7QUFDQSxPQUFLLElBQUlDLE1BQU0sQ0FBZixFQUFrQkEsTUFBTUgsTUFBeEIsRUFBZ0NHLEtBQWhDLEVBQXVDO0FBQ3JDLFFBQU1DLGNBQWMsSUFBSUMsaUJBQUosQ0FBc0JKLFVBQVdKLGVBQWUsQ0FBaEQsQ0FBcEI7QUFDQSxT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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFsaWduQXJyYXlzIGZyb20gJy4uL2FsaWduQXJyYXlzJztcblxuZnVuY3Rpb24gaW1hZ2VUbzJEQXJyYXkoeyBkYXRhLCB3aWR0aCwgaGVpZ2h0IH0sIHBhZGRpbmdSaWdodCkge1xuICAvLyBUaGUgaW1hZ2VEYXRhIGlzIGEgMUQgYXJyYXkuIEVhY2ggZWxlbWVudCBpbiB0aGUgYXJyYXkgY29ycmVzcG9uZHMgdG8gYVxuICAvLyBkZWNpbWFsIHZhbHVlIHRoYXQgcmVwcmVzZW50cyBvbmUgb2YgdGhlIFJHQkEgY2hhbm5lbHMgZm9yIHRoYXQgcGl4ZWwuXG4gIGNvbnN0IHJvd1NpemUgPSB3aWR0aCAqIDQ7XG5cbiAgY29uc3QgbmV3RGF0YSA9IFtdO1xuICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCBoZWlnaHQ7IHJvdysrKSB7XG4gICAgY29uc3QgcGl4ZWxzSW5Sb3cgPSBuZXcgVWludDhDbGFtcGVkQXJyYXkocm93U2l6ZSArIChwYWRkaW5nUmlnaHQgKiA0KSk7XG4gICAgZm9yIChsZXQgbG9jYXRpb24gPSAwOyBsb2NhdGlvbiA8IHJvd1NpemU7IGxvY2F0aW9uKyspIHtcbiAgICAgIHBpeGVsc0luUm93W2xvY2F0aW9uXSA9IGRhdGFbKHJvdyAqIHJvd1NpemUpICsgbG9jYXRpb25dO1xuICAgIH1cbiAgICBuZXdEYXRhLnB1c2gocGl4ZWxzSW5Sb3cpO1xuICB9XG4gIHJldHVybiBuZXdEYXRhO1xufVxuXG5mdW5jdGlvbiBhbGlnbih7XG4gIHByZXZpb3VzSW1hZ2VEYXRhLFxuICBjdXJyZW50SW1hZ2VEYXRhLFxuICBtYXhXaWR0aCxcbn0pIHtcbiAgY29uc3QgaGFzaGVkUHJldmlvdXNEYXRhID0gcHJldmlvdXNJbWFnZURhdGEubWFwKEpTT04uc3RyaW5naWZ5KTtcbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA0MCB9KTtcbiAgY29uc3QgaGFzaGVkQ3VycmVudERhdGEgPSBjdXJyZW50SW1hZ2VEYXRhLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UoeyBwcm9ncmVzczogNjAgfSk7XG5cbiAgYWxpZ25BcnJheXMoXG4gICAgaGFzaGVkUHJldmlvdXNEYXRhLFxuICAgIGhhc2hlZEN1cnJlbnREYXRhXG4gICk7XG5cbiAgY29uc3QgdHJhbnNwYXJlbnRMaW5lID0gbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KG1heFdpZHRoICogNCk7XG5cbiAgaGFzaGVkUHJldmlvdXNEYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBwcmV2aW91c0ltYWdlRGF0YS5zcGxpY2UoaSwgMCwgdHJhbnNwYXJlbnRMaW5lKTtcbiAgICB9XG4gIH0pO1xuXG4gIGhhc2hlZEN1cnJlbnREYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBjdXJyZW50SW1hZ2VEYXRhLnNwbGljZShpLCAwLCB0cmFuc3BhcmVudExpbmUpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogVGFrZXMgdHdvIDJkIGltYWdlcywgY29tcHV0ZXMgdGhlIGRpZmYgYmV0d2VlbiB0aGUgdHdvLCBhbmQgaW5qZWN0cyBwaXhlbHMgdG9cbiAqIGJvdGggaW4gb3JkZXIgdG86XG4gKiBhKSBtYWtlIGJvdGggaW1hZ2VzIHRoZSBzYW1lIGhlaWdodFxuICogYikgcHJvcGVybHkgdmlzdWFsaXplIGRpZmZlcmVuY2VzXG4gKlxuICogUGxlYXNlIG5vdGUgdGhhdCB0aGlzIG1ldGhvZCBNVVRBVEVTIGRhdGEuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gcHJldmlvdXNEYXRhXG4gKiBAcGFyYW0ge0FycmF5fSBjdXJyZW50RGF0YVxuICovXG5mdW5jdGlvbiBjb21wdXRlQW5kSW5qZWN0RGlmZnMoeyBwcmV2aW91c0RhdGEsIGN1cnJlbnREYXRhIH0pIHtcbiAgY29uc3QgbWF4V2lkdGggPSBNYXRoLm1heChwcmV2aW91c0RhdGEud2lkdGgsIGN1cnJlbnREYXRhLndpZHRoKTtcblxuICBjb25zdCBwcmV2aW91c0ltYWdlRGF0YSA9IGltYWdlVG8yREFycmF5KFxuICAgIHByZXZpb3VzRGF0YSwgbWF4V2lkdGggLSBwcmV2aW91c0RhdGEud2lkdGgpO1xuXG4gIGNvbnN0IGN1cnJlbnRJbWFnZURhdGEgPSBpbWFnZVRvMkRBcnJheShcbiAgICBjdXJyZW50RGF0YSwgbWF4V2lkdGggLSBjdXJyZW50RGF0YS53aWR0aCk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiAyMCB9KTtcblxuICBhbGlnbih7XG4gICAgcHJldmlvdXNJbWFnZURhdGEsXG4gICAgY3VycmVudEltYWdlRGF0YSxcbiAgICBtYXhXaWR0aCxcbiAgfSk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA4NSB9KTtcblxuICByZXR1cm4ge1xuICAgIGN1cnJlbnREYXRhOiB7XG4gICAgICBkYXRhOiBjdXJyZW50SW1hZ2VEYXRhLFxuICAgICAgaGVpZ2h0OiBjdXJyZW50SW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICAgIHByZXZpb3VzRGF0YToge1xuICAgICAgZGF0YTogcHJldmlvdXNJbWFnZURhdGEsXG4gICAgICBoZWlnaHQ6IHByZXZpb3VzSW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICB9O1xufVxuXG5zZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCAoeyBkYXRhOiB7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSB9KSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IGNvbXB1dGVBbmRJbmplY3REaWZmcyh7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UocmVzdWx0KTtcbiAgc2VsZi5jbG9zZSgpO1xufSk7XG5cblxuXG4vKiogV0VCUEFDSyBGT09URVIgKipcbiAqKiAuL2pzL3NyYy93b3JrZXJzL0NvbXB1dGVBbmRJbmplY3REaWZmc1dvcmtlci5qc1xuICoqLyJdLCJzb3VyY2VSb290IjoiIn0=");
|
48
|
+
|
49
|
+
/***/ },
|
50
|
+
/* 1 */
|
51
|
+
/***/ function(module, exports) {
|
52
|
+
|
53
|
+
eval("'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = alignArrays;\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar MOVEMENT = {\n none: 0,\n diagonal: 1,\n vertical: 2,\n horizontal: 3\n};\n\nfunction initMatrix(height, width) {\n var rows = new Array(height);\n for (var i = 0; i < rows.length; i++) {\n rows[i] = new Int32Array(width);\n }\n return rows;\n}\n\nfunction longestCommonSubsequence(a, b) {\n // adapted from\n // http://algorithms.tutorialhorizon.com/dynamic-programming-longest-common-subsequence/\n var aLength = a.length;\n var bLength = b.length;\n var memo = initMatrix(aLength + 1, bLength + 1);\n var solution = initMatrix(aLength + 1, bLength + 1);\n\n // Loop and find the solution\n for (var i = 1; i <= aLength; i++) {\n for (var j = 1; j <= bLength; j++) {\n if (a[i - 1] === b[j - 1]) {\n // diagonal\n memo[i][j] = memo[i - 1][j - 1] + 1;\n solution[i][j] = MOVEMENT.diagonal;\n } else {\n memo[i][j] = Math.max(memo[i - 1][j], memo[i][j - 1]);\n if (memo[i][j] === memo[i - 1][j]) {\n solution[i][j] = MOVEMENT.vertical;\n } else {\n solution[i][j] = MOVEMENT.horizontal;\n }\n }\n }\n }\n if (memo[aLength][bLength] === 0) {\n // No soltuion found\n return null;\n }\n return solution;\n}\n\nfunction placeholders(count) {\n var result = new Array(count);\n for (var i = 0; i < count; i++) {\n result[i] = '+';\n }\n return result;\n}\n/**\n * Apply an lcs solution to arrays. Note that this will MUTATE the arrays,\n * injecting \"+\" where gaps are needed.\n *\n * @param {Array<Array>} solution as computed by `longestCommonSubsequence`\n * @param {Array} a\n * @param {Array} b\n */\nfunction applySolution(solution, a, b) {\n var movement = solution[a.length][b.length];\n var ai = a.length;\n var bi = b.length;\n var changes = 0;\n\n function applyChange() {\n if (changes < 0) {\n b.splice.apply(b, [bi, 0].concat(_toConsumableArray(placeholders(Math.abs(changes)))));\n } else if (changes > 0) {\n a.splice.apply(a, [ai, 0].concat(_toConsumableArray(placeholders(changes))));\n }\n changes = 0;\n }\n\n while (movement !== MOVEMENT.none) {\n if (movement === MOVEMENT.diagonal) {\n applyChange();\n ai--;\n bi--;\n } else if (movement === MOVEMENT.horizontal) {\n bi--;\n changes++;\n } else if (movement === MOVEMENT.vertical) {\n ai--;\n changes--;\n }\n movement = solution[ai][bi];\n }\n if (ai + bi !== 0) {\n applyChange();\n }\n}\n\n/**\n * To be called for arrays that share nothing in common.\n *\n * Note that this will MUTATE the arrays,\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction applyPadding(a, b) {\n var aLength = a.length;\n var bLength = b.length;\n var shorterArray = aLength > bLength ? b : a;\n shorterArray.push.apply(shorterArray, _toConsumableArray(placeholders(Math.abs(aLength - bLength))));\n}\n/**\n * Computes the longest common subsequence of two arrays, then uses that\n * solution to inject gaps into the arrays, making them align on common\n * subsequences.\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction alignArrays(a, b) {\n var lcsSolution = longestCommonSubsequence(a, b);\n if (lcsSolution) {\n applySolution(lcsSolution, a, b);\n } else {\n applyPadding(a, b);\n }\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvYWxpZ25BcnJheXMuanM/MDFiNyJdLCJuYW1lcyI6WyJhbGlnbkFycmF5cyIsIk1PVkVNRU5UIiwibm9uZSIsImRpYWdvbmFsIiwidmVydGljYWwiLCJob3Jpem9udGFsIiwiaW5pdE1hdHJpeCIsImhlaWdodCIsIndpZHRoIiwicm93cyIsIkFycmF5IiwiaSIsImxlbmd0aCIsIkludDMyQXJyYXkiLCJsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UiLCJhIiwiYiIsImFMZW5ndGgiLCJiTGVuZ3RoIiwibWVtbyIsInNvbHV0aW9uIiwiaiIsIk1hdGgiLCJtYXgiLCJwbGFjZWhvbGRlcnMiLCJjb3VudCIsInJlc3VsdCIsImFwcGx5U29sdXRpb24iLCJtb3ZlbWVudCIsImFpIiwiYmkiLCJjaGFuZ2VzIiwiYXBwbHlDaGFuZ2UiLCJzcGxpY2UiLCJhYnMiLCJhcHBseVBhZGRpbmciLCJzaG9ydGVyQXJyYXkiLCJwdXNoIiwibGNzU29sdXRpb24iXSwibWFwcGluZ3MiOiI7Ozs7O2tCQXVId0JBLFc7Ozs7QUF2SHhCLElBQU1DLFdBQVc7QUFDZkMsUUFBTSxDQURTO0FBRWZDLFlBQVUsQ0FGSztBQUdmQyxZQUFVLENBSEs7QUFJZkMsY0FBWTtBQUpHLENBQWpCOztBQU9BLFNBQVNDLFVBQVQsQ0FBb0JDLE1BQXBCLEVBQTRCQyxLQUE1QixFQUFtQztBQUNqQyxNQUFNQyxPQUFPLElBQUlDLEtBQUosQ0FBVUgsTUFBVixDQUFiO0FBQ0EsT0FBSyxJQUFJSSxJQUFJLENBQWIsRUFBZ0JBLElBQUlGLEtBQUtHLE1BQXpCLEVBQWlDRCxHQUFqQyxFQUFzQztBQUNwQ0YsU0FBS0UsQ0FBTCxJQUFVLElBQUlFLFVBQUosQ0FBZUwsS0FBZixDQUFWO0FBQ0Q7QUFDRCxTQUFPQyxJQUFQO0FBQ0Q7O0FBRUQsU0FBU0ssd0JBQVQsQ0FBa0NDLENBQWxDLEVBQXFDQyxDQUFyQyxFQUF3QztBQUN0QztBQUNBO0FBQ0EsTUFBTUMsVUFBVUYs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QixTQUFTRyxRQUExQixFQUFvQztBQUN6Q3lCO0FBQ0FFO0FBQ0Q7QUFDREgsZUFBV1IsU0FBU1MsRUFBVCxFQUFhQyxFQUFiLENBQVg7QUFDRDtBQUNELE1BQUlELEtBQUtDLEVBQUwsS0FBWSxDQUFoQixFQUFtQjtBQUNqQkU7QUFFRDtBQUNGOztBQUVEOzs7Ozs7OztBQVFBLFNBQVNHLFlBQVQsQ0FBc0JwQixDQUF0QixFQUF5QkMsQ0FBekIsRUFBNEI7QUFDMUIsTUFBTUMsVUFBVUYsRUFBRUgsTUFBbEI7QUFDQSxNQUFNTSxVQUFVRixFQUFFSixNQUFsQjtBQUNBLE1BQU13QixlQUFlbkIsVUFBVUMsT0FBVixHQUFvQkYsQ0FBcEIsR0FBd0JELENBQTdDO0FBQ0FxQixlQUFhQyxJQUFiLHdDQUFxQmIsYUFBYUYsS0FBS1ksR0FBTCxDQUFTakIsVUFBVUMsT0FBbkIsQ0FBYixDQUFyQjtBQUNEO0FBQ0Q7Ozs7Ozs7O0FBUWUsU0FBU2xCLFdBQVQsQ0FBcUJlLENBQXJCLEVBQXdCQyxDQUF4QixFQUEyQjtBQUN4QyxNQUFNc0IsY0FBY3hCLHlCQUF5QkMsQ0FBekIsRUFBNEJDLENBQTVCLENBQXBCO0FBQ0EsTUFBSXNCLFdBQUosRUFBaUI7QUFDZlgsa0JBQWNXLFdBQWQsRUFBMkJ2QixDQUEzQixFQUE4QkMsQ0FBOUI7QUFDRCxHQUZELE1BRU87QUFDTG1CLGlCQUFhcEIsQ0FBYixFQUFnQkMsQ0FBaEI7QUFDRDtBQUNGIiwiZmlsZSI6IjEuanMiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBNT1ZFTUVOVCA9IHtcbiAgbm9uZTogMCxcbiAgZGlhZ29uYWw6IDEsXG4gIHZlcnRpY2FsOiAyLFxuICBob3Jpem9udGFsOiAzLFxufTtcblxuZnVuY3Rpb24gaW5pdE1hdHJpeChoZWlnaHQsIHdpZHRoKSB7XG4gIGNvbnN0IHJvd3MgPSBuZXcgQXJyYXkoaGVpZ2h0KTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCByb3dzLmxlbmd0aDsgaSsrKSB7XG4gICAgcm93c1tpXSA9IG5ldyBJbnQzMkFycmF5KHdpZHRoKTtcbiAgfVxuICByZXR1cm4gcm93cztcbn1cblxuZnVuY3Rpb24gbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlKGEsIGIpIHtcbiAgLy8gYWRhcHRlZCBmcm9tXG4gIC8vIGh0dHA6Ly9hbGdvcml0aG1zLnR1dG9yaWFsaG9yaXpvbi5jb20vZHluYW1pYy1wcm9ncmFtbWluZy1sb25nZXN0LWNvbW1vbi1zdWJzZXF1ZW5jZS9cbiAgY29uc3QgYUxlbmd0aCA9IGEubGVuZ3RoO1xuICBjb25zdCBiTGVuZ3RoID0gYi5sZW5ndGg7XG4gIGNvbnN0IG1lbW8gPSBpbml0TWF0cml4KGFMZW5ndGggKyAxLCBiTGVuZ3RoICsgMSk7XG4gIGNvbnN0IHNvbHV0aW9uID0gaW5pdE1hdHJpeChhTGVuZ3RoICsgMSwgYkxlbmd0aCArIDEpO1xuXG4gIC8vIExvb3AgYW5kIGZpbmQgdGhlIHNvbHV0aW9uXG4gIGZvciAobGV0IGkgPSAxOyBpIDw9IGFMZW5ndGg7IGkrKykge1xuICAgIGZvciAobGV0IGogPSAxOyBqIDw9IGJMZW5ndGg7IGorKykge1xuICAgICAgaWYgKGFbaSAtIDFdID09PSBiW2ogLSAxXSkge1xuICAgICAgICAvLyBkaWFnb25hbFxuICAgICAgICBtZW1vW2ldW2pdID0gbWVtb1tpIC0gMV1baiAtIDFdICsgMTtcbiAgICAgICAgc29sdXRpb25baV1bal0gPSBNT1ZFTUVOVC5kaWFnb25hbDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIG1lbW9baV1bal0gPSBNYXRoLm1heChtZW1vW2kgLSAxXVtqXSwgbWVtb1tpXVtqIC0gMV0pO1xuICAgICAgICBpZiAobWVtb1tpXVtqXSA9PT0gbWVtb1tpIC0gMV1bal0pIHtcbiAgICAgICAgICBzb2x1dGlvbltpXVtqXSA9IE1PVkVNRU5ULnZlcnRpY2FsO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHNvbHV0aW9uW2ldW2pdID0gTU9WRU1FTlQuaG9yaXpvbnRhbDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuICBpZiAobWVtb1thTGVuZ3RoXVtiTGVuZ3RoXSA9PT0gMCkge1xuICAgIC8vIE5vIHNvbHR1aW9uIGZvdW5kXG4gICAgcmV0dXJuIG51bGw7XG4gIH1cbiAgcmV0dXJuIHNvbHV0aW9uO1xufVxuXG5mdW5jdGlvbiBwbGFjZWhvbGRlcnMoY291bnQpIHtcbiAgY29uc3QgcmVzdWx0ID0gbmV3IEFycmF5KGNvdW50KTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBjb3VudDsgaSsrKSB7XG4gICAgcmVzdWx0W2ldID0gJysnO1xuICB9XG4gIHJldHVybiByZXN1bHQ7XG59XG4vKipcbiAqIEFwcGx5IGFuIGxjcyBzb2x1dGlvbiB0byBhcnJheXMuIE5vdGUgdGhhdCB0aGlzIHdpbGwgTVVUQVRFIHRoZSBhcnJheXMsXG4gKiBpbmplY3RpbmcgXCIrXCIgd2hlcmUgZ2FwcyBhcmUgbmVlZGVkLlxuICpcbiAqIEBwYXJhbSB7QXJyYXk8QXJyYXk+fSBzb2x1dGlvbiBhcyBjb21wdXRlZCBieSBgbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlYFxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5mdW5jdGlvbiBhcHBseVNvbHV0aW9uKHNvbHV0aW9uLCBhLCBiKSB7XG4gIGxldCBtb3ZlbWVudCA9IHNvbHV0aW9uW2EubGVuZ3RoXVtiLmxlbmd0aF07XG4gIGxldCBhaSA9IGEubGVuZ3RoO1xuICBsZXQgYmkgPSBiLmxlbmd0aDtcbiAgbGV0IGNoYW5nZXMgPSAwO1xuXG4gIGZ1bmN0aW9uIGFwcGx5Q2hhbmdlKCkge1xuICAgIGlmIChjaGFuZ2VzIDwgMCkge1xuICAgICAgYi5zcGxpY2UoYmksIDAsIC4uLnBsYWNlaG9sZGVycyhNYXRoLmFicyhjaGFuZ2VzKSkpO1xuICAgIH0gZWxzZSBpZiAoY2hhbmdlcyA+IDApIHtcbiAgICAgIGEuc3BsaWNlKGFpLCAwLCAuLi5wbGFjZWhvbGRlcnMoY2hhbmdlcykpO1xuICAgIH1cbiAgICBjaGFuZ2VzID0gMDtcbiAgfVxuXG4gIHdoaWxlIChtb3ZlbWVudCAhPT0gTU9WRU1FTlQubm9uZSkge1xuICAgIGlmIChtb3ZlbWVudCA9PT0gTU9WRU1FTlQuZGlhZ29uYWwpIHtcbiAgICAgIGFwcGx5Q2hhbmdlKCk7XG4gICAgICBhaS0tO1xuICAgICAgYmktLTtcbiAgICB9IGVsc2UgaWYgKG1vdmVtZW50ID09PSBNT1ZFTUVOVC5ob3Jpem9udGFsKSB7XG4gICAgICBiaS0tO1xuICAgICAgY2hhbmdlcysrO1xuICAgIH0gZWxzZSBpZiAobW92ZW1lbnQgPT09IE1PVkVNRU5ULnZlcnRpY2FsKSB7XG4gICAgICBhaS0tO1xuICAgICAgY2hhbmdlcy0tO1xuICAgIH1cbiAgICBtb3ZlbWVudCA9IHNvbHV0aW9uW2FpXVtiaV07XG4gIH1cbiAgaWYgKGFpICsgYmkgIT09IDApIHtcbiAgICBhcHBseUNoYW5nZSgpO1xuXG4gIH1cbn1cblxuLyoqXG4gKiBUbyBiZSBjYWxsZWQgZm9yIGFycmF5cyB0aGF0IHNoYXJlIG5vdGhpbmcgaW4gY29tbW9uLlxuICpcbiAqIE5vdGUgdGhhdCB0aGlzIHdpbGwgTVVUQVRFIHRoZSBhcnJheXMsXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5mdW5jdGlvbiBhcHBseVBhZGRpbmcoYSwgYikge1xuICBjb25zdCBhTGVuZ3RoID0gYS5sZW5ndGg7XG4gIGNvbnN0IGJMZW5ndGggPSBiLmxlbmd0aDtcbiAgY29uc3Qgc2hvcnRlckFycmF5ID0gYUxlbmd0aCA+IGJMZW5ndGggPyBiIDogYTtcbiAgc2hvcnRlckFycmF5LnB1c2goLi4ucGxhY2Vob2xkZXJzKE1hdGguYWJzKGFMZW5ndGggLSBiTGVuZ3RoKSkpO1xufVxuLyoqXG4gKiBDb21wdXRlcyB0aGUgbG9uZ2VzdCBjb21tb24gc3Vic2VxdWVuY2Ugb2YgdHdvIGFycmF5cywgdGhlbiB1c2VzIHRoYXRcbiAqIHNvbHV0aW9uIHRvIGluamVjdCBnYXBzIGludG8gdGhlIGFycmF5cywgbWFraW5nIHRoZW0gYWxpZ24gb24gY29tbW9uXG4gKiBzdWJzZXF1ZW5jZXMuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhbGlnbkFycmF5cyhhLCBiKSB7XG4gIGNvbnN0IGxjc1NvbHV0aW9uID0gbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlKGEsIGIpO1xuICBpZiAobGNzU29sdXRpb24pIHtcbiAgICBhcHBseVNvbHV0aW9uKGxjc1NvbHV0aW9uLCBhLCBiKTtcbiAgfSBlbHNlIHtcbiAgICBhcHBseVBhZGRpbmcoYSwgYik7XG4gIH1cbn1cblxuXG5cbi8qKiBXRUJQQUNLIEZPT1RFUiAqKlxuICoqIC4vanMvc3JjL2FsaWduQXJyYXlzLmpzXG4gKiovIl0sInNvdXJjZVJvb3QiOiIifQ==");
|
54
|
+
|
55
|
+
/***/ }
|
56
|
+
/******/ ]);
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/******/ (function(modules) { // webpackBootstrap
|
2
|
+
/******/ // The module cache
|
3
|
+
/******/ var installedModules = {};
|
4
|
+
|
5
|
+
/******/ // The require function
|
6
|
+
/******/ function __webpack_require__(moduleId) {
|
7
|
+
|
8
|
+
/******/ // Check if module is in cache
|
9
|
+
/******/ if(installedModules[moduleId])
|
10
|
+
/******/ return installedModules[moduleId].exports;
|
11
|
+
|
12
|
+
/******/ // Create a new module (and put it into the cache)
|
13
|
+
/******/ var module = installedModules[moduleId] = {
|
14
|
+
/******/ exports: {},
|
15
|
+
/******/ id: moduleId,
|
16
|
+
/******/ loaded: false
|
17
|
+
/******/ };
|
18
|
+
|
19
|
+
/******/ // Execute the module function
|
20
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
21
|
+
|
22
|
+
/******/ // Flag the module as loaded
|
23
|
+
/******/ module.loaded = true;
|
24
|
+
|
25
|
+
/******/ // Return the exports of the module
|
26
|
+
/******/ return module.exports;
|
27
|
+
/******/ }
|
28
|
+
|
29
|
+
|
30
|
+
/******/ // expose the modules object (__webpack_modules__)
|
31
|
+
/******/ __webpack_require__.m = modules;
|
32
|
+
|
33
|
+
/******/ // expose the module cache
|
34
|
+
/******/ __webpack_require__.c = installedModules;
|
35
|
+
|
36
|
+
/******/ // __webpack_public_path__
|
37
|
+
/******/ __webpack_require__.p = "";
|
38
|
+
|
39
|
+
/******/ // Load entry module and return exports
|
40
|
+
/******/ return __webpack_require__(0);
|
41
|
+
/******/ })
|
42
|
+
/************************************************************************/
|
43
|
+
/******/ ([
|
44
|
+
/* 0 */
|
45
|
+
/***/ function(module, exports, __webpack_require__) {
|
46
|
+
|
47
|
+
eval("'use strict';\n\nvar _alignArrays = __webpack_require__(1);\n\nvar _alignArrays2 = _interopRequireDefault(_alignArrays);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction imageTo2DArray(_ref, paddingRight) {\n var data = _ref.data;\n var width = _ref.width;\n var height = _ref.height;\n\n // The imageData is a 1D array. Each element in the array corresponds to a\n // decimal value that represents one of the RGBA channels for that pixel.\n var rowSize = width * 4;\n\n var newData = [];\n for (var row = 0; row < height; row++) {\n var pixelsInRow = new Uint8ClampedArray(rowSize + paddingRight * 4);\n for (var location = 0; location < rowSize; location++) {\n pixelsInRow[location] = data[row * rowSize + location];\n }\n newData.push(pixelsInRow);\n }\n return newData;\n}\n\nfunction align(_ref2) {\n var previousImageData = _ref2.previousImageData;\n var currentImageData = _ref2.currentImageData;\n var maxWidth = _ref2.maxWidth;\n\n var hashedPreviousData = previousImageData.map(JSON.stringify);\n self.postMessage({ progress: 40 });\n var hashedCurrentData = currentImageData.map(JSON.stringify);\n self.postMessage({ progress: 60 });\n\n (0, _alignArrays2.default)(hashedPreviousData, hashedCurrentData);\n\n var transparentLine = new Uint8ClampedArray(maxWidth * 4);\n\n hashedPreviousData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n previousImageData.splice(i, 0, transparentLine);\n }\n });\n\n hashedCurrentData.forEach(function (hashedLine, i) {\n if (hashedLine === '+') {\n currentImageData.splice(i, 0, transparentLine);\n }\n });\n}\n\n/**\n * Takes two 2d images, computes the diff between the two, and injects pixels to\n * both in order to:\n * a) make both images the same height\n * b) properly visualize differences\n *\n * Please note that this method MUTATES data.\n *\n * @param {Array} previousData\n * @param {Array} currentData\n */\nfunction computeAndInjectDiffs(_ref3) {\n var previousData = _ref3.previousData;\n var currentData = _ref3.currentData;\n\n var maxWidth = Math.max(previousData.width, currentData.width);\n\n var previousImageData = imageTo2DArray(previousData, maxWidth - previousData.width);\n\n var currentImageData = imageTo2DArray(currentData, maxWidth - currentData.width);\n\n self.postMessage({ progress: 20 });\n\n align({\n previousImageData: previousImageData,\n currentImageData: currentImageData,\n maxWidth: maxWidth\n });\n\n self.postMessage({ progress: 85 });\n\n return {\n currentData: {\n data: currentImageData,\n height: currentImageData.length,\n width: maxWidth\n },\n previousData: {\n data: previousImageData,\n height: previousImageData.length,\n width: maxWidth\n }\n };\n}\n\nself.addEventListener('message', function (_ref4) {\n var _ref4$data = _ref4.data;\n var previousData = _ref4$data.previousData;\n var currentData = _ref4$data.currentData;\n\n var result = computeAndInjectDiffs({ previousData: previousData, currentData: currentData });\n self.postMessage(result);\n self.close();\n});//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvd29ya2Vycy9Db21wdXRlQW5kSW5qZWN0RGlmZnNXb3JrZXIuanM/ZGRiNSJdLCJuYW1lcyI6WyJpbWFnZVRvMkRBcnJheSIsInBhZGRpbmdSaWdodCIsImRhdGEiLCJ3aWR0aCIsImhlaWdodCIsInJvd1NpemUiLCJuZXdEYXRhIiwicm93IiwicGl4ZWxzSW5Sb3ciLCJVaW50OENsYW1wZWRBcnJheSIsImxvY2F0aW9uIiwicHVzaCIsImFsaWduIiwicHJldmlvdXNJbWFnZURhdGEiLCJjdXJyZW50SW1hZ2VEYXRhIiwibWF4V2lkdGgiLCJoYXNoZWRQcmV2aW91c0RhdGEiLCJtYXAiLCJKU09OIiwic3RyaW5naWZ5Iiwic2VsZiIsInBvc3RNZXNzYWdlIiwicHJvZ3Jlc3MiLCJoYXNoZWRDdXJyZW50RGF0YSIsInRyYW5zcGFyZW50TGluZSIsImZvckVhY2giLCJoYXNoZWRMaW5lIiwiaSIsInNwbGljZSIsImNvbXB1dGVBbmRJbmplY3REaWZmcyIsInByZXZpb3VzRGF0YSIsImN1cnJlbnREYXRhIiwiTWF0aCIsIm1heCIsImxlbmd0aCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXN1bHQiLCJjbG9zZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0FBRUEsU0FBU0EsY0FBVCxPQUFpREMsWUFBakQsRUFBK0Q7QUFBQSxNQUFyQ0MsSUFBcUMsUUFBckNBLElBQXFDO0FBQUEsTUFBL0JDLEtBQStCLFFBQS9CQSxLQUErQjtBQUFBLE1BQXhCQyxNQUF3QixRQUF4QkEsTUFBd0I7O0FBQzdEO0FBQ0E7QUFDQSxNQUFNQyxVQUFVRixRQUFRLENBQXhCOztBQUVBLE1BQU1HLFVBQVUsRUFBaEI7QUFDQSxPQUFLLElBQUlDLE1BQU0sQ0FBZixFQUFrQkEsTUFBTUgsTUFBeEIsRUFBZ0NHLEtBQWhDLEVBQXVDO0FBQ3JDLFFBQU1DLGNBQWMsSUFBSUMsaUJBQUosQ0FBc0JKLFVBQVdKLGVBQWUsQ0FBaEQsQ0FBcEI7QUFDQSxT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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFsaWduQXJyYXlzIGZyb20gJy4uL2FsaWduQXJyYXlzJztcblxuZnVuY3Rpb24gaW1hZ2VUbzJEQXJyYXkoeyBkYXRhLCB3aWR0aCwgaGVpZ2h0IH0sIHBhZGRpbmdSaWdodCkge1xuICAvLyBUaGUgaW1hZ2VEYXRhIGlzIGEgMUQgYXJyYXkuIEVhY2ggZWxlbWVudCBpbiB0aGUgYXJyYXkgY29ycmVzcG9uZHMgdG8gYVxuICAvLyBkZWNpbWFsIHZhbHVlIHRoYXQgcmVwcmVzZW50cyBvbmUgb2YgdGhlIFJHQkEgY2hhbm5lbHMgZm9yIHRoYXQgcGl4ZWwuXG4gIGNvbnN0IHJvd1NpemUgPSB3aWR0aCAqIDQ7XG5cbiAgY29uc3QgbmV3RGF0YSA9IFtdO1xuICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCBoZWlnaHQ7IHJvdysrKSB7XG4gICAgY29uc3QgcGl4ZWxzSW5Sb3cgPSBuZXcgVWludDhDbGFtcGVkQXJyYXkocm93U2l6ZSArIChwYWRkaW5nUmlnaHQgKiA0KSk7XG4gICAgZm9yIChsZXQgbG9jYXRpb24gPSAwOyBsb2NhdGlvbiA8IHJvd1NpemU7IGxvY2F0aW9uKyspIHtcbiAgICAgIHBpeGVsc0luUm93W2xvY2F0aW9uXSA9IGRhdGFbKHJvdyAqIHJvd1NpemUpICsgbG9jYXRpb25dO1xuICAgIH1cbiAgICBuZXdEYXRhLnB1c2gocGl4ZWxzSW5Sb3cpO1xuICB9XG4gIHJldHVybiBuZXdEYXRhO1xufVxuXG5mdW5jdGlvbiBhbGlnbih7XG4gIHByZXZpb3VzSW1hZ2VEYXRhLFxuICBjdXJyZW50SW1hZ2VEYXRhLFxuICBtYXhXaWR0aCxcbn0pIHtcbiAgY29uc3QgaGFzaGVkUHJldmlvdXNEYXRhID0gcHJldmlvdXNJbWFnZURhdGEubWFwKEpTT04uc3RyaW5naWZ5KTtcbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA0MCB9KTtcbiAgY29uc3QgaGFzaGVkQ3VycmVudERhdGEgPSBjdXJyZW50SW1hZ2VEYXRhLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UoeyBwcm9ncmVzczogNjAgfSk7XG5cbiAgYWxpZ25BcnJheXMoXG4gICAgaGFzaGVkUHJldmlvdXNEYXRhLFxuICAgIGhhc2hlZEN1cnJlbnREYXRhXG4gICk7XG5cbiAgY29uc3QgdHJhbnNwYXJlbnRMaW5lID0gbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KG1heFdpZHRoICogNCk7XG5cbiAgaGFzaGVkUHJldmlvdXNEYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBwcmV2aW91c0ltYWdlRGF0YS5zcGxpY2UoaSwgMCwgdHJhbnNwYXJlbnRMaW5lKTtcbiAgICB9XG4gIH0pO1xuXG4gIGhhc2hlZEN1cnJlbnREYXRhLmZvckVhY2goKGhhc2hlZExpbmUsIGkpID0+IHtcbiAgICBpZiAoaGFzaGVkTGluZSA9PT0gJysnKSB7XG4gICAgICBjdXJyZW50SW1hZ2VEYXRhLnNwbGljZShpLCAwLCB0cmFuc3BhcmVudExpbmUpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogVGFrZXMgdHdvIDJkIGltYWdlcywgY29tcHV0ZXMgdGhlIGRpZmYgYmV0d2VlbiB0aGUgdHdvLCBhbmQgaW5qZWN0cyBwaXhlbHMgdG9cbiAqIGJvdGggaW4gb3JkZXIgdG86XG4gKiBhKSBtYWtlIGJvdGggaW1hZ2VzIHRoZSBzYW1lIGhlaWdodFxuICogYikgcHJvcGVybHkgdmlzdWFsaXplIGRpZmZlcmVuY2VzXG4gKlxuICogUGxlYXNlIG5vdGUgdGhhdCB0aGlzIG1ldGhvZCBNVVRBVEVTIGRhdGEuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gcHJldmlvdXNEYXRhXG4gKiBAcGFyYW0ge0FycmF5fSBjdXJyZW50RGF0YVxuICovXG5mdW5jdGlvbiBjb21wdXRlQW5kSW5qZWN0RGlmZnMoeyBwcmV2aW91c0RhdGEsIGN1cnJlbnREYXRhIH0pIHtcbiAgY29uc3QgbWF4V2lkdGggPSBNYXRoLm1heChwcmV2aW91c0RhdGEud2lkdGgsIGN1cnJlbnREYXRhLndpZHRoKTtcblxuICBjb25zdCBwcmV2aW91c0ltYWdlRGF0YSA9IGltYWdlVG8yREFycmF5KFxuICAgIHByZXZpb3VzRGF0YSwgbWF4V2lkdGggLSBwcmV2aW91c0RhdGEud2lkdGgpO1xuXG4gIGNvbnN0IGN1cnJlbnRJbWFnZURhdGEgPSBpbWFnZVRvMkRBcnJheShcbiAgICBjdXJyZW50RGF0YSwgbWF4V2lkdGggLSBjdXJyZW50RGF0YS53aWR0aCk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiAyMCB9KTtcblxuICBhbGlnbih7XG4gICAgcHJldmlvdXNJbWFnZURhdGEsXG4gICAgY3VycmVudEltYWdlRGF0YSxcbiAgICBtYXhXaWR0aCxcbiAgfSk7XG5cbiAgc2VsZi5wb3N0TWVzc2FnZSh7IHByb2dyZXNzOiA4NSB9KTtcblxuICByZXR1cm4ge1xuICAgIGN1cnJlbnREYXRhOiB7XG4gICAgICBkYXRhOiBjdXJyZW50SW1hZ2VEYXRhLFxuICAgICAgaGVpZ2h0OiBjdXJyZW50SW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICAgIHByZXZpb3VzRGF0YToge1xuICAgICAgZGF0YTogcHJldmlvdXNJbWFnZURhdGEsXG4gICAgICBoZWlnaHQ6IHByZXZpb3VzSW1hZ2VEYXRhLmxlbmd0aCxcbiAgICAgIHdpZHRoOiBtYXhXaWR0aCxcbiAgICB9LFxuICB9O1xufVxuXG5zZWxmLmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCAoeyBkYXRhOiB7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSB9KSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IGNvbXB1dGVBbmRJbmplY3REaWZmcyh7IHByZXZpb3VzRGF0YSwgY3VycmVudERhdGEgfSk7XG4gIHNlbGYucG9zdE1lc3NhZ2UocmVzdWx0KTtcbiAgc2VsZi5jbG9zZSgpO1xufSk7XG5cblxuXG4vKiogV0VCUEFDSyBGT09URVIgKipcbiAqKiAuL2pzL3NyYy93b3JrZXJzL0NvbXB1dGVBbmRJbmplY3REaWZmc1dvcmtlci5qc1xuICoqLyJdLCJzb3VyY2VSb290IjoiIn0=");
|
48
|
+
|
49
|
+
/***/ },
|
50
|
+
/* 1 */
|
51
|
+
/***/ function(module, exports) {
|
52
|
+
|
53
|
+
eval("'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = alignArrays;\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar MOVEMENT = {\n none: 0,\n diagonal: 1,\n vertical: 2,\n horizontal: 3\n};\n\nfunction initMatrix(height, width) {\n var rows = new Array(height);\n for (var i = 0; i < rows.length; i++) {\n rows[i] = new Int32Array(width);\n }\n return rows;\n}\n\nfunction longestCommonSubsequence(a, b) {\n // adapted from\n // http://algorithms.tutorialhorizon.com/dynamic-programming-longest-common-subsequence/\n var aLength = a.length;\n var bLength = b.length;\n var memo = initMatrix(aLength + 1, bLength + 1);\n var solution = initMatrix(aLength + 1, bLength + 1);\n\n // Loop and find the solution\n for (var i = 1; i <= aLength; i++) {\n for (var j = 1; j <= bLength; j++) {\n if (a[i - 1] === b[j - 1]) {\n // diagonal\n memo[i][j] = memo[i - 1][j - 1] + 1;\n solution[i][j] = MOVEMENT.diagonal;\n } else {\n memo[i][j] = Math.max(memo[i - 1][j], memo[i][j - 1]);\n if (memo[i][j] === memo[i - 1][j]) {\n solution[i][j] = MOVEMENT.vertical;\n } else {\n solution[i][j] = MOVEMENT.horizontal;\n }\n }\n }\n }\n console.log(memo);\n return solution;\n}\n\nfunction placeholders(count) {\n return new Array(count).map(function () {\n return 'x';\n });\n}\n/**\n * Apply an lcs solution to arrays. Note that this will MUTATE the arrays,\n * injecting \"+\" where gaps are needed.\n *\n * @param {Array<Array>} solution as computed by `longestCommonSubsequence`\n * @param {Array} a\n * @param {Array} b\n */\nfunction applySolution(solution, a, b) {\n var movement = solution[a.length][b.length];\n var ai = a.length;\n var bi = b.length;\n var horizSinceLastDiagonal = 0;\n var vertSinceLastDiagonal = 0;\n\n while (movement !== MOVEMENT.none) {\n if (movement === MOVEMENT.diagonal) {\n var diffI = ai - bi;\n if (diffI > 0) {\n b.splice.apply(b, [bi, 0].concat(_toConsumableArray('+')));\n }\n a.splice(ai, 0, '+');\n b.splice(bi, 0, '+');\n ai--;\n bi--;\n } else if (movement === MOVEMENT.horizontal) {\n bi--;\n } else if (movement === MOVEMENT.vertical) {\n ai--;\n }\n movement = solution[ai][bi];\n }\n}\n\n/**\n * Computes the longest common subsequence of two arrays, then uses that\n * solution to inject gaps into the arrays, making them align on common\n * subsequences.\n *\n * @param {Array} a\n * @param {Array} b\n */\nfunction alignArrays(a, b) {\n var lcsSolution = longestCommonSubsequence(a, b);\n applySolution(lcsSolution, a, b);\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9qcy9zcmMvYWxpZ25BcnJheXMuanM/MDFiNyJdLCJuYW1lcyI6WyJhbGlnbkFycmF5cyIsIk1PVkVNRU5UIiwibm9uZSIsImRpYWdvbmFsIiwidmVydGljYWwiLCJob3Jpem9udGFsIiwiaW5pdE1hdHJpeCIsImhlaWdodCIsIndpZHRoIiwicm93cyIsIkFycmF5IiwiaSIsImxlbmd0aCIsIkludDMyQXJyYXkiLCJsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UiLCJhIiwiYiIsImFMZW5ndGgiLCJiTGVuZ3RoIiwibWVtbyIsInNvbHV0aW9uIiwiaiIsIk1hdGgiLCJtYXgiLCJjb25zb2xlIiwibG9nIiwicGxhY2Vob2xkZXJzIiwiY291bnQiLCJtYXAiLCJhcHBseVNvbHV0aW9uIiwibW92ZW1lbnQiLCJhaSIsImJpIiwiaG9yaXpTaW5jZUxhc3REaWFnb25hbCIsInZlcnRTaW5jZUxhc3REaWFnb25hbCIsImRpZmZJIiwic3BsaWNlIiwibGNzU29sdXRpb24iXSwibWFwcGluZ3MiOiI7Ozs7O2tCQXlGd0JBLFc7Ozs7QUF6RnhCLElBQU1DLFdBQVc7QUFDZkMsUUFBTSxDQURTO0FBRWZDLFlBQVUsQ0FGSztBQUdmQyxZQUFVLENBSEs7QUFJZkMsY0FBWTtBQUpHLENBQWpCOztBQU9BLFNBQVNDLFVBQVQsQ0FBb0JDLE1BQXBCLEVBQTRCQyxLQUE1QixFQUFtQztBQUNqQyxNQUFNQyxPQUFPLElBQUlDLEtBQUosQ0FBVUgsTUFBVixDQUFiO0FBQ0EsT0FBSyxJQUFJSSxJQUFJLENBQWIsRUFBZ0JBLElBQUlGLEtBQUtHLE1BQXpCLEVBQWlDRCxHQUFqQyxFQUFzQztBQUNwQ0YsU0FBS0UsQ0FBTCxJQUFVLElBQUlFLFVBQUosQ0FBZUwsS0FBZixDQUFWO0FBQ0Q7QUFDRCxTQUFPQyxJQUFQO0FBQ0Q7O0FBRUQsU0FBU0ssd0JBQVQsQ0FBa0NDLENBQWxDLEVBQXFDQyxDQUFyQyxFQUF3QztBQUN0QztBQUNBO0FBQ0EsTUFBTUMsVUFB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QUFNcUIsY0FBY3ZCLHlCQUF5QkMsQ0FBekIsRUFBNEJDLENBQTVCLENBQXBCO0FBQ0FhLGdCQUFjUSxXQUFkLEVBQTJCdEIsQ0FBM0IsRUFBOEJDLENBQTlCO0FBQ0QiLCJmaWxlIjoiMS5qcyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IE1PVkVNRU5UID0ge1xuICBub25lOiAwLFxuICBkaWFnb25hbDogMSxcbiAgdmVydGljYWw6IDIsXG4gIGhvcml6b250YWw6IDMsXG59O1xuXG5mdW5jdGlvbiBpbml0TWF0cml4KGhlaWdodCwgd2lkdGgpIHtcbiAgY29uc3Qgcm93cyA9IG5ldyBBcnJheShoZWlnaHQpO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IHJvd3MubGVuZ3RoOyBpKyspIHtcbiAgICByb3dzW2ldID0gbmV3IEludDMyQXJyYXkod2lkdGgpO1xuICB9XG4gIHJldHVybiByb3dzO1xufVxuXG5mdW5jdGlvbiBsb25nZXN0Q29tbW9uU3Vic2VxdWVuY2UoYSwgYikge1xuICAvLyBhZGFwdGVkIGZyb21cbiAgLy8gaHR0cDovL2FsZ29yaXRobXMudHV0b3JpYWxob3Jpem9uLmNvbS9keW5hbWljLXByb2dyYW1taW5nLWxvbmdlc3QtY29tbW9uLXN1YnNlcXVlbmNlL1xuICBjb25zdCBhTGVuZ3RoID0gYS5sZW5ndGg7XG4gIGNvbnN0IGJMZW5ndGggPSBiLmxlbmd0aDtcbiAgY29uc3QgbWVtbyA9IGluaXRNYXRyaXgoYUxlbmd0aCArIDEsIGJMZW5ndGggKyAxKTtcbiAgY29uc3Qgc29sdXRpb24gPSBpbml0TWF0cml4KGFMZW5ndGggKyAxLCBiTGVuZ3RoICsgMSk7XG5cbiAgLy8gTG9vcCBhbmQgZmluZCB0aGUgc29sdXRpb25cbiAgZm9yIChsZXQgaSA9IDE7IGkgPD0gYUxlbmd0aDsgaSsrKSB7XG4gICAgZm9yIChsZXQgaiA9IDE7IGogPD0gYkxlbmd0aDsgaisrKSB7XG4gICAgICBpZiAoYVtpIC0gMV0gPT09IGJbaiAtIDFdKSB7XG4gICAgICAgIC8vIGRpYWdvbmFsXG4gICAgICAgIG1lbW9baV1bal0gPSBtZW1vW2kgLSAxXVtqIC0gMV0gKyAxO1xuICAgICAgICBzb2x1dGlvbltpXVtqXSA9IE1PVkVNRU5ULmRpYWdvbmFsO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgbWVtb1tpXVtqXSA9IE1hdGgubWF4KG1lbW9baSAtIDFdW2pdLCBtZW1vW2ldW2ogLSAxXSk7XG4gICAgICAgIGlmIChtZW1vW2ldW2pdID09PSBtZW1vW2kgLSAxXVtqXSkge1xuICAgICAgICAgIHNvbHV0aW9uW2ldW2pdID0gTU9WRU1FTlQudmVydGljYWw7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc29sdXRpb25baV1bal0gPSBNT1ZFTUVOVC5ob3Jpem9udGFsO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGNvbnNvbGUubG9nKG1lbW8pXG4gIHJldHVybiBzb2x1dGlvbjtcbn1cblxuZnVuY3Rpb24gcGxhY2Vob2xkZXJzKGNvdW50KSB7XG4gIHJldHVybiBuZXcgQXJyYXkoY291bnQpLm1hcCgoKSA9PiAneCcpO1xufVxuLyoqXG4gKiBBcHBseSBhbiBsY3Mgc29sdXRpb24gdG8gYXJyYXlzLiBOb3RlIHRoYXQgdGhpcyB3aWxsIE1VVEFURSB0aGUgYXJyYXlzLFxuICogaW5qZWN0aW5nIFwiK1wiIHdoZXJlIGdhcHMgYXJlIG5lZWRlZC5cbiAqXG4gKiBAcGFyYW0ge0FycmF5PEFycmF5Pn0gc29sdXRpb24gYXMgY29tcHV0ZWQgYnkgYGxvbmdlc3RDb21tb25TdWJzZXF1ZW5jZWBcbiAqIEBwYXJhbSB7QXJyYXl9IGFcbiAqIEBwYXJhbSB7QXJyYXl9IGJcbiAqL1xuZnVuY3Rpb24gYXBwbHlTb2x1dGlvbihzb2x1dGlvbiwgYSwgYikge1xuICBsZXQgbW92ZW1lbnQgPSBzb2x1dGlvblthLmxlbmd0aF1bYi5sZW5ndGhdO1xuICBsZXQgYWkgPSBhLmxlbmd0aDtcbiAgbGV0IGJpID0gYi5sZW5ndGg7XG4gIGxldCBob3JpelNpbmNlTGFzdERpYWdvbmFsID0gMDtcbiAgbGV0IHZlcnRTaW5jZUxhc3REaWFnb25hbCA9IDA7XG5cbiAgd2hpbGUgKG1vdmVtZW50ICE9PSBNT1ZFTUVOVC5ub25lKSB7XG4gICAgaWYgKG1vdmVtZW50ID09PSBNT1ZFTUVOVC5kaWFnb25hbCkge1xuICAgICAgY29uc3QgZGlmZkkgPSBhaSAtIGJpO1xuICAgICAgaWYgKGRpZmZJID4gMCkge1xuICAgICAgICBiLnNwbGljZShiaSwgMCwgLi4uJysnKTtcbiAgICAgIH1cbiAgICAgIGEuc3BsaWNlKGFpLCAwLCAnKycpO1xuICAgICAgYi5zcGxpY2UoYmksIDAsICcrJyk7XG4gICAgICBhaS0tO1xuICAgICAgYmktLTtcbiAgICB9IGVsc2UgaWYgKG1vdmVtZW50ID09PSBNT1ZFTUVOVC5ob3Jpem9udGFsKSB7XG4gICAgICBiaS0tO1xuICAgIH0gZWxzZSBpZiAobW92ZW1lbnQgPT09IE1PVkVNRU5ULnZlcnRpY2FsKSB7XG4gICAgICBhaS0tO1xuICAgIH1cbiAgICBtb3ZlbWVudCA9IHNvbHV0aW9uW2FpXVtiaV07XG4gIH1cbn1cblxuLyoqXG4gKiBDb21wdXRlcyB0aGUgbG9uZ2VzdCBjb21tb24gc3Vic2VxdWVuY2Ugb2YgdHdvIGFycmF5cywgdGhlbiB1c2VzIHRoYXRcbiAqIHNvbHV0aW9uIHRvIGluamVjdCBnYXBzIGludG8gdGhlIGFycmF5cywgbWFraW5nIHRoZW0gYWxpZ24gb24gY29tbW9uXG4gKiBzdWJzZXF1ZW5jZXMuXG4gKlxuICogQHBhcmFtIHtBcnJheX0gYVxuICogQHBhcmFtIHtBcnJheX0gYlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhbGlnbkFycmF5cyhhLCBiKSB7XG4gIGNvbnN0IGxjc1NvbHV0aW9uID0gbG9uZ2VzdENvbW1vblN1YnNlcXVlbmNlKGEsIGIpO1xuICBhcHBseVNvbHV0aW9uKGxjc1NvbHV0aW9uLCBhLCBiKTtcbn1cblxuXG5cbi8qKiBXRUJQQUNLIEZPT1RFUiAqKlxuICoqIC4vanMvc3JjL2FsaWduQXJyYXlzLmpzXG4gKiovIl0sInNvdXJjZVJvb3QiOiIifQ==");
|
54
|
+
|
55
|
+
/***/ }
|
56
|
+
/******/ ]);
|