From 6db5092690c1951d7dfe666eee51851ae4dcb057 Mon Sep 17 00:00:00 2001
From: James Dooley
Date: Mon, 3 Dec 2018 00:26:02 +0000
Subject: [PATCH 01/15] Starting css refactor
---
package-lock.json | 931 +++++++++++++++++-----
package.json | 1 +
src/index.js | 14 +-
src/index.module.css | 28 +-
src/lib/TranscriptEditor/index.js | 20 +-
src/lib/TranscriptEditor/index.module.css | 31 -
6 files changed, 741 insertions(+), 284 deletions(-)
diff --git a/package-lock.json b/package-lock.json
index 019fb0b7..6aa44d4f 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1,6 +1,6 @@
{
"name": "@bbc/react-transcript-editor",
- "version": "0.1.4",
+ "version": "0.1.9",
"lockfileVersion": 1,
"requires": true,
"dependencies": {
@@ -1233,6 +1233,11 @@
"integrity": "sha512-sY5AXXVZv4Y1VACTtR11UJCPHHudgY5i26Qj5TypE6DKlIApbwb5uqhXcJ5UUGbvZNRh7EeIoW+LrJumBsKp7w==",
"dev": true
},
+ "abbrev": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
+ "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q=="
+ },
"accepts": {
"version": "1.3.5",
"resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz",
@@ -1298,7 +1303,6 @@
"version": "6.5.5",
"resolved": "https://registry.npmjs.org/ajv/-/ajv-6.5.5.tgz",
"integrity": "sha512-7q7gtRQDJSyuEHjuVgHoUa2VuemFiCMrfQc9Tc08XTAc4Zj/5U1buQJ0HU6i7fKjXU09SVgSmxa4sLvuvS8Iyg==",
- "dev": true,
"requires": {
"fast-deep-equal": "^2.0.1",
"fast-json-stable-stringify": "^2.0.0",
@@ -1324,6 +1328,11 @@
"integrity": "sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM=",
"dev": true
},
+ "amdefine": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz",
+ "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU="
+ },
"ansi-colors": {
"version": "3.2.1",
"resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.1.tgz",
@@ -1345,8 +1354,7 @@
"ansi-regex": {
"version": "3.0.0",
"resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz",
- "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=",
- "dev": true
+ "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg="
},
"ansi-styles": {
"version": "3.2.1",
@@ -1379,8 +1387,16 @@
"aproba": {
"version": "1.2.0",
"resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz",
- "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==",
- "dev": true
+ "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw=="
+ },
+ "are-we-there-yet": {
+ "version": "1.1.5",
+ "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz",
+ "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==",
+ "requires": {
+ "delegates": "^1.0.0",
+ "readable-stream": "^2.0.6"
+ }
},
"argparse": {
"version": "1.0.10",
@@ -1431,6 +1447,11 @@
"integrity": "sha1-fajPLiZijtcygDWB/SH2fKzS7uw=",
"dev": true
},
+ "array-find-index": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz",
+ "integrity": "sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E="
+ },
"array-flatten": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-2.1.1.tgz",
@@ -1506,7 +1527,6 @@
"version": "0.2.4",
"resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz",
"integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==",
- "dev": true,
"requires": {
"safer-buffer": "~2.1.0"
}
@@ -1551,8 +1571,7 @@
"assert-plus": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz",
- "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=",
- "dev": true
+ "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU="
},
"assign-symbols": {
"version": "1.0.0",
@@ -1587,6 +1606,11 @@
"integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=",
"dev": true
},
+ "async-foreach": {
+ "version": "0.1.3",
+ "resolved": "https://registry.npmjs.org/async-foreach/-/async-foreach-0.1.3.tgz",
+ "integrity": "sha1-NhIfhFwFeBct5Bmpfb6x0W7DRUI="
+ },
"async-limiter": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz",
@@ -1596,8 +1620,7 @@
"asynckit": {
"version": "0.4.0",
"resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
- "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=",
- "dev": true
+ "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k="
},
"atob": {
"version": "2.1.2",
@@ -1641,14 +1664,12 @@
"aws-sign2": {
"version": "0.7.0",
"resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz",
- "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=",
- "dev": true
+ "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg="
},
"aws4": {
"version": "1.8.0",
"resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz",
- "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==",
- "dev": true
+ "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ=="
},
"axobject-query": {
"version": "2.0.2",
@@ -2196,8 +2217,7 @@
"balanced-match": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
- "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
- "dev": true
+ "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c="
},
"base": {
"version": "0.11.2",
@@ -2270,7 +2290,6 @@
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz",
"integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=",
- "dev": true,
"requires": {
"tweetnacl": "^0.14.3"
}
@@ -2299,6 +2318,14 @@
"integrity": "sha512-DYWGk01lDcxeS/K9IHPGWfT8PsJmbXRtRd2Sx72Tnb8pcYZQFF1oSDb8hJtS1vhp212q1Rzi5dUf9+nq0o9UIg==",
"dev": true
},
+ "block-stream": {
+ "version": "0.0.9",
+ "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz",
+ "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=",
+ "requires": {
+ "inherits": "~2.0.0"
+ }
+ },
"bluebird": {
"version": "3.5.3",
"resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.3.tgz",
@@ -2364,7 +2391,6 @@
"version": "1.1.11",
"resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
"integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dev": true,
"requires": {
"balanced-match": "^1.0.0",
"concat-map": "0.0.1"
@@ -2551,8 +2577,7 @@
"builtin-modules": {
"version": "1.1.1",
"resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz",
- "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=",
- "dev": true
+ "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8="
},
"builtin-status-codes": {
"version": "3.0.0",
@@ -2667,6 +2692,22 @@
"integrity": "sha512-faqwZqnWxbxn+F1d399ygeamQNy3lPp/H9H6rNrqYh4FSVCtcY+3cub1MxA8o9mDd55mM8Aghuu/kuyYA6VTsA==",
"dev": true
},
+ "camelcase-keys": {
+ "version": "2.1.0",
+ "resolved": "http://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz",
+ "integrity": "sha1-MIvur/3ygRkFHvodkyITyRuPkuc=",
+ "requires": {
+ "camelcase": "^2.0.0",
+ "map-obj": "^1.0.0"
+ },
+ "dependencies": {
+ "camelcase": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz",
+ "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8="
+ }
+ }
+ },
"caniuse-api": {
"version": "3.0.0",
"resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz",
@@ -2703,8 +2744,7 @@
"caseless": {
"version": "0.12.0",
"resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz",
- "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=",
- "dev": true
+ "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw="
},
"chalk": {
"version": "2.4.1",
@@ -2909,8 +2949,7 @@
"code-point-at": {
"version": "1.1.0",
"resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz",
- "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=",
- "dev": true
+ "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c="
},
"collection-visit": {
"version": "1.0.0",
@@ -2967,7 +3006,6 @@
"version": "1.0.7",
"resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz",
"integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==",
- "dev": true,
"requires": {
"delayed-stream": "~1.0.0"
}
@@ -3023,8 +3061,7 @@
"concat-map": {
"version": "0.0.1",
"resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
- "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
- "dev": true
+ "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s="
},
"concat-stream": {
"version": "1.6.2",
@@ -3059,6 +3096,11 @@
"date-now": "^0.1.4"
}
},
+ "console-control-strings": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz",
+ "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4="
+ },
"constants-browserify": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz",
@@ -3132,8 +3174,7 @@
"core-util-is": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
- "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=",
- "dev": true
+ "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac="
},
"cosmiconfig": {
"version": "5.0.7",
@@ -3337,7 +3378,7 @@
},
"regjsparser": {
"version": "0.1.5",
- "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.1.5.tgz",
+ "resolved": "http://registry.npmjs.org/regjsparser/-/regjsparser-0.1.5.tgz",
"integrity": "sha1-fuj4Tcb6eS0/0K4ijSS9lJ6tIFw=",
"dev": true,
"requires": {
@@ -3556,6 +3597,14 @@
"cssom": "0.3.x"
}
},
+ "currently-unhandled": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz",
+ "integrity": "sha1-mI3zP+qxke95mmE2nddsF635V+o=",
+ "requires": {
+ "array-find-index": "^1.0.1"
+ }
+ },
"cyclist": {
"version": "0.2.2",
"resolved": "https://registry.npmjs.org/cyclist/-/cyclist-0.2.2.tgz",
@@ -3572,7 +3621,6 @@
"version": "1.14.1",
"resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz",
"integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=",
- "dev": true,
"requires": {
"assert-plus": "^1.0.0"
}
@@ -3606,8 +3654,7 @@
"decamelize": {
"version": "1.2.0",
"resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz",
- "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=",
- "dev": true
+ "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA="
},
"decode-uri-component": {
"version": "0.2.0",
@@ -3755,8 +3802,12 @@
"delayed-stream": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz",
- "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=",
- "dev": true
+ "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk="
+ },
+ "delegates": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz",
+ "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o="
},
"depd": {
"version": "1.1.2",
@@ -4026,7 +4077,6 @@
"version": "0.1.2",
"resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz",
"integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=",
- "dev": true,
"requires": {
"jsbn": "~0.1.0",
"safer-buffer": "^2.1.0"
@@ -4157,7 +4207,6 @@
"version": "1.3.2",
"resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
"integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
- "dev": true,
"requires": {
"is-arrayish": "^0.2.1"
}
@@ -4195,8 +4244,7 @@
"escape-string-regexp": {
"version": "1.0.5",
"resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
- "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
- "dev": true
+ "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ="
},
"escodegen": {
"version": "1.11.0",
@@ -4710,8 +4758,7 @@
"extend": {
"version": "3.0.2",
"resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz",
- "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==",
- "dev": true
+ "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g=="
},
"extend-shallow": {
"version": "3.0.2",
@@ -4813,14 +4860,12 @@
"extsprintf": {
"version": "1.3.0",
"resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz",
- "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=",
- "dev": true
+ "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU="
},
"fast-deep-equal": {
"version": "2.0.1",
"resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz",
- "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=",
- "dev": true
+ "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk="
},
"fast-glob": {
"version": "2.2.4",
@@ -4839,8 +4884,7 @@
"fast-json-stable-stringify": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz",
- "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=",
- "dev": true
+ "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I="
},
"fast-levenshtein": {
"version": "2.0.6",
@@ -5050,7 +5094,6 @@
"version": "1.1.2",
"resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz",
"integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=",
- "dev": true,
"requires": {
"path-exists": "^2.0.0",
"pinkie-promise": "^2.0.0"
@@ -5122,8 +5165,7 @@
"forever-agent": {
"version": "0.6.1",
"resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz",
- "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=",
- "dev": true
+ "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE="
},
"fork-ts-checker-webpack-plugin-alt": {
"version": "0.4.14",
@@ -5145,7 +5187,6 @@
"version": "2.3.3",
"resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz",
"integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==",
- "dev": true,
"requires": {
"asynckit": "^0.4.0",
"combined-stream": "^1.0.6",
@@ -5215,8 +5256,7 @@
"fs.realpath": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
- "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=",
- "dev": true
+ "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8="
},
"fsevents": {
"version": "1.2.4",
@@ -5747,6 +5787,17 @@
}
}
},
+ "fstream": {
+ "version": "1.0.11",
+ "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz",
+ "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=",
+ "requires": {
+ "graceful-fs": "^4.1.2",
+ "inherits": "~2.0.0",
+ "mkdirp": ">=0.5 0",
+ "rimraf": "2"
+ }
+ },
"function-bind": {
"version": "1.1.1",
"resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
@@ -5770,11 +5821,66 @@
"integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=",
"dev": true
},
+ "gauge": {
+ "version": "2.7.4",
+ "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz",
+ "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=",
+ "requires": {
+ "aproba": "^1.0.3",
+ "console-control-strings": "^1.0.0",
+ "has-unicode": "^2.0.0",
+ "object-assign": "^4.1.0",
+ "signal-exit": "^3.0.0",
+ "string-width": "^1.0.1",
+ "strip-ansi": "^3.0.1",
+ "wide-align": "^1.1.0"
+ },
+ "dependencies": {
+ "ansi-regex": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
+ "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8="
+ },
+ "is-fullwidth-code-point": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz",
+ "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=",
+ "requires": {
+ "number-is-nan": "^1.0.0"
+ }
+ },
+ "string-width": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz",
+ "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=",
+ "requires": {
+ "code-point-at": "^1.0.0",
+ "is-fullwidth-code-point": "^1.0.0",
+ "strip-ansi": "^3.0.0"
+ }
+ },
+ "strip-ansi": {
+ "version": "3.0.1",
+ "resolved": "http://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
+ "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
+ "requires": {
+ "ansi-regex": "^2.0.0"
+ }
+ }
+ }
+ },
+ "gaze": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.3.tgz",
+ "integrity": "sha512-BRdNm8hbWzFzWHERTrejLqwHDfS4GibPoq5wjTPIoJHoBtKGPg3xAFfxmM+9ztbXelxcf2hwQcaz1PtmFeue8g==",
+ "requires": {
+ "globule": "^1.0.0"
+ }
+ },
"get-caller-file": {
"version": "1.0.3",
"resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz",
- "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==",
- "dev": true
+ "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w=="
},
"get-own-enumerable-property-symbols": {
"version": "3.0.0",
@@ -5807,7 +5913,6 @@
"version": "0.1.7",
"resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz",
"integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=",
- "dev": true,
"requires": {
"assert-plus": "^1.0.0"
}
@@ -5832,7 +5937,6 @@
"version": "7.1.3",
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz",
"integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==",
- "dev": true,
"requires": {
"fs.realpath": "^1.0.0",
"inflight": "^1.0.4",
@@ -5948,11 +6052,20 @@
"pinkie-promise": "^2.0.0"
}
},
+ "globule": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/globule/-/globule-1.2.1.tgz",
+ "integrity": "sha512-g7QtgWF4uYSL5/dn71WxubOrS7JVGCnFPEnoeChJmBnyR9Mw8nGoEwOgJL/RC2Te0WhbsEUCejfH8SZNJ+adYQ==",
+ "requires": {
+ "glob": "~7.1.1",
+ "lodash": "~4.17.10",
+ "minimatch": "~3.0.2"
+ }
+ },
"graceful-fs": {
"version": "4.1.15",
"resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz",
- "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==",
- "dev": true
+ "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA=="
},
"growly": {
"version": "1.3.0",
@@ -6061,14 +6174,12 @@
"har-schema": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz",
- "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=",
- "dev": true
+ "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI="
},
"har-validator": {
"version": "5.1.3",
"resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz",
"integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==",
- "dev": true,
"requires": {
"ajv": "^6.5.5",
"har-schema": "^2.0.0"
@@ -6093,7 +6204,6 @@
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz",
"integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=",
- "dev": true,
"requires": {
"ansi-regex": "^2.0.0"
},
@@ -6101,8 +6211,7 @@
"ansi-regex": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
- "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=",
- "dev": true
+ "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8="
}
}
},
@@ -6118,6 +6227,11 @@
"integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=",
"dev": true
},
+ "has-unicode": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz",
+ "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk="
+ },
"has-value": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz",
@@ -6227,8 +6341,7 @@
"hosted-git-info": {
"version": "2.7.1",
"resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz",
- "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==",
- "dev": true
+ "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w=="
},
"hpack.js": {
"version": "2.1.6",
@@ -6397,7 +6510,6 @@
"version": "1.2.0",
"resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz",
"integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=",
- "dev": true,
"requires": {
"assert-plus": "^1.0.0",
"jsprim": "^1.2.2",
@@ -6675,6 +6787,19 @@
"integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
"dev": true
},
+ "in-publish": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/in-publish/-/in-publish-2.0.0.tgz",
+ "integrity": "sha1-4g/146KvwmkDILbcVSaCqcf631E="
+ },
+ "indent-string": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-2.1.0.tgz",
+ "integrity": "sha1-ji1INIdCEhtKghi3oTfppSBJ3IA=",
+ "requires": {
+ "repeating": "^2.0.0"
+ }
+ },
"indexes-of": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/indexes-of/-/indexes-of-1.0.1.tgz",
@@ -6691,7 +6816,6 @@
"version": "1.0.6",
"resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
"integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
- "dev": true,
"requires": {
"once": "^1.3.0",
"wrappy": "1"
@@ -6700,8 +6824,7 @@
"inherits": {
"version": "2.0.3",
"resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
- "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=",
- "dev": true
+ "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4="
},
"ini": {
"version": "1.3.5",
@@ -6752,8 +6875,7 @@
"invert-kv": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz",
- "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=",
- "dev": true
+ "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY="
},
"ip": {
"version": "1.1.5",
@@ -6802,8 +6924,7 @@
"is-arrayish": {
"version": "0.2.1",
"resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
- "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=",
- "dev": true
+ "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0="
},
"is-binary-path": {
"version": "1.0.1",
@@ -6830,7 +6951,6 @@
"version": "1.0.0",
"resolved": "http://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz",
"integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=",
- "dev": true,
"requires": {
"builtin-modules": "^1.0.0"
}
@@ -6946,7 +7066,6 @@
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz",
"integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=",
- "dev": true,
"requires": {
"number-is-nan": "^1.0.0"
}
@@ -6954,8 +7073,7 @@
"is-fullwidth-code-point": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz",
- "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=",
- "dev": true
+ "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8="
},
"is-generator-fn": {
"version": "1.0.0",
@@ -7126,14 +7244,12 @@
"is-typedarray": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
- "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=",
- "dev": true
+ "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo="
},
"is-utf8": {
"version": "0.2.1",
"resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz",
- "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=",
- "dev": true
+ "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI="
},
"is-windows": {
"version": "1.0.2",
@@ -7150,8 +7266,7 @@
"isarray": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
- "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=",
- "dev": true
+ "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE="
},
"isemail": {
"version": "3.2.0",
@@ -7165,8 +7280,7 @@
"isexe": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
- "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
- "dev": true
+ "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA="
},
"isobject": {
"version": "3.0.1",
@@ -7186,8 +7300,7 @@
"isstream": {
"version": "0.1.2",
"resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz",
- "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=",
- "dev": true
+ "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo="
},
"istanbul-api": {
"version": "1.3.7",
@@ -8341,6 +8454,11 @@
"topo": "2.x.x"
}
},
+ "js-base64": {
+ "version": "2.4.9",
+ "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-2.4.9.tgz",
+ "integrity": "sha512-xcinL3AuDJk7VSzsHgb9DvvIXayBbadtMZ4HFPx8rUszbW1MuNMlwYVC4zzCZ6e1sqZpnNS5ZFYOhXqA39T7LQ=="
+ },
"js-levenshtein": {
"version": "1.1.4",
"resolved": "https://registry.npmjs.org/js-levenshtein/-/js-levenshtein-1.1.4.tgz",
@@ -8365,8 +8483,7 @@
"jsbn": {
"version": "0.1.1",
"resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz",
- "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=",
- "dev": true
+ "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM="
},
"jsdom": {
"version": "13.0.0",
@@ -8425,14 +8542,12 @@
"json-schema": {
"version": "0.2.3",
"resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz",
- "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=",
- "dev": true
+ "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM="
},
"json-schema-traverse": {
"version": "0.4.1",
"resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
- "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
- "dev": true
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg=="
},
"json-stable-stringify": {
"version": "1.0.1",
@@ -8452,8 +8567,7 @@
"json-stringify-safe": {
"version": "5.0.1",
"resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz",
- "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=",
- "dev": true
+ "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus="
},
"json3": {
"version": "3.3.2",
@@ -8497,7 +8611,6 @@
"version": "1.4.1",
"resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz",
"integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=",
- "dev": true,
"requires": {
"assert-plus": "1.0.0",
"extsprintf": "1.3.0",
@@ -8552,7 +8665,6 @@
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz",
"integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=",
- "dev": true,
"requires": {
"invert-kv": "^1.0.0"
}
@@ -8660,8 +8772,7 @@
"lodash": {
"version": "4.17.11",
"resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz",
- "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==",
- "dev": true
+ "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg=="
},
"lodash._reinterpolate": {
"version": "3.0.0",
@@ -8669,12 +8780,22 @@
"integrity": "sha1-DM8tiRZq8Ds2Y8eWU4t1rG4RTZ0=",
"dev": true
},
+ "lodash.assign": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-4.2.0.tgz",
+ "integrity": "sha1-DZnzzNem0mHRm9rrkkUAXShYCOc="
+ },
"lodash.camelcase": {
"version": "4.3.0",
"resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz",
"integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=",
"dev": true
},
+ "lodash.clonedeep": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz",
+ "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8="
+ },
"lodash.debounce": {
"version": "4.0.8",
"resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz",
@@ -8705,6 +8826,11 @@
"integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=",
"dev": true
},
+ "lodash.mergewith": {
+ "version": "4.6.1",
+ "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.1.tgz",
+ "integrity": "sha512-eWw5r+PYICtEBgrBE5hhlT6aAa75f411bgDz/ZL2KZqYV03USvucsxcHUIlGTDTECs1eunpI7HOV7U+WLDvNdQ=="
+ },
"lodash.sortby": {
"version": "4.7.0",
"resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz",
@@ -8756,6 +8882,15 @@
"js-tokens": "^3.0.0 || ^4.0.0"
}
},
+ "loud-rejection": {
+ "version": "1.6.0",
+ "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz",
+ "integrity": "sha1-W0b4AUft7leIcPCG0Eghz5mOVR8=",
+ "requires": {
+ "currently-unhandled": "^0.4.1",
+ "signal-exit": "^3.0.0"
+ }
+ },
"lower-case": {
"version": "1.1.4",
"resolved": "https://registry.npmjs.org/lower-case/-/lower-case-1.1.4.tgz",
@@ -8766,7 +8901,6 @@
"version": "4.1.4",
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.4.tgz",
"integrity": "sha512-EPstzZ23znHUVLKj+lcXO1KvZkrlw+ZirdwvOmnAnA/1PB4ggyXJ77LRkCqkff+ShQ+cqoxCxLQOh4cKITO5iA==",
- "dev": true,
"requires": {
"pseudomap": "^1.0.2",
"yallist": "^3.0.2"
@@ -8819,6 +8953,11 @@
"integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=",
"dev": true
},
+ "map-obj": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz",
+ "integrity": "sha1-2TPOuSBdgr3PSIb2dCvcK03qFG0="
+ },
"map-visit": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz",
@@ -8876,6 +9015,79 @@
"readable-stream": "^2.0.1"
}
},
+ "meow": {
+ "version": "3.7.0",
+ "resolved": "http://registry.npmjs.org/meow/-/meow-3.7.0.tgz",
+ "integrity": "sha1-cstmi0JSKCkKu/qFaJJYcwioAfs=",
+ "requires": {
+ "camelcase-keys": "^2.0.0",
+ "decamelize": "^1.1.2",
+ "loud-rejection": "^1.0.0",
+ "map-obj": "^1.0.1",
+ "minimist": "^1.1.3",
+ "normalize-package-data": "^2.3.4",
+ "object-assign": "^4.0.1",
+ "read-pkg-up": "^1.0.1",
+ "redent": "^1.0.0",
+ "trim-newlines": "^1.0.0"
+ },
+ "dependencies": {
+ "load-json-file": {
+ "version": "1.1.0",
+ "resolved": "http://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz",
+ "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=",
+ "requires": {
+ "graceful-fs": "^4.1.2",
+ "parse-json": "^2.2.0",
+ "pify": "^2.0.0",
+ "pinkie-promise": "^2.0.0",
+ "strip-bom": "^2.0.0"
+ }
+ },
+ "minimist": {
+ "version": "1.2.0",
+ "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz",
+ "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ="
+ },
+ "path-type": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz",
+ "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=",
+ "requires": {
+ "graceful-fs": "^4.1.2",
+ "pify": "^2.0.0",
+ "pinkie-promise": "^2.0.0"
+ }
+ },
+ "read-pkg": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz",
+ "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=",
+ "requires": {
+ "load-json-file": "^1.0.0",
+ "normalize-package-data": "^2.3.2",
+ "path-type": "^1.0.0"
+ }
+ },
+ "read-pkg-up": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz",
+ "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=",
+ "requires": {
+ "find-up": "^1.0.0",
+ "read-pkg": "^1.0.0"
+ }
+ },
+ "strip-bom": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz",
+ "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=",
+ "requires": {
+ "is-utf8": "^0.2.0"
+ }
+ }
+ }
+ },
"merge": {
"version": "1.2.1",
"resolved": "https://registry.npmjs.org/merge/-/merge-1.2.1.tgz",
@@ -8971,14 +9183,12 @@
"mime-db": {
"version": "1.37.0",
"resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz",
- "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg==",
- "dev": true
+ "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg=="
},
"mime-types": {
"version": "2.1.21",
"resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz",
"integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==",
- "dev": true,
"requires": {
"mime-db": "~1.37.0"
}
@@ -9016,7 +9226,6 @@
"version": "3.0.4",
"resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
"integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
- "dev": true,
"requires": {
"brace-expansion": "^1.1.7"
}
@@ -9024,8 +9233,7 @@
"minimist": {
"version": "0.0.8",
"resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz",
- "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=",
- "dev": true
+ "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0="
},
"mississippi": {
"version": "3.0.0",
@@ -9088,7 +9296,6 @@
"version": "0.5.1",
"resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz",
"integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=",
- "dev": true,
"requires": {
"minimist": "0.0.8"
}
@@ -9149,9 +9356,7 @@
"nan": {
"version": "2.11.1",
"resolved": "https://registry.npmjs.org/nan/-/nan-2.11.1.tgz",
- "integrity": "sha512-iji6k87OSXa0CcrLl9z+ZiYSuR2o+c0bGuNmXdrhTQTakxytAFsC56SArGYoiHlJlFoHSnvmhpceZJaXkVuOtA==",
- "dev": true,
- "optional": true
+ "integrity": "sha512-iji6k87OSXa0CcrLl9z+ZiYSuR2o+c0bGuNmXdrhTQTakxytAFsC56SArGYoiHlJlFoHSnvmhpceZJaXkVuOtA=="
},
"nanomatch": {
"version": "1.2.13",
@@ -9233,6 +9438,32 @@
"integrity": "sha512-MmbQJ2MTESTjt3Gi/3yG1wGpIMhUfcIypUCGtTizFR9IiccFwxSpfp0vtIZlkFclEqERemxfnSdZEMR9VqqEFQ==",
"dev": true
},
+ "node-gyp": {
+ "version": "3.8.0",
+ "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-3.8.0.tgz",
+ "integrity": "sha512-3g8lYefrRRzvGeSowdJKAKyks8oUpLEd/DyPV4eMhVlhJ0aNaZqIrNUIPuEWWTAoPqyFkfGrM67MC69baqn6vA==",
+ "requires": {
+ "fstream": "^1.0.0",
+ "glob": "^7.0.3",
+ "graceful-fs": "^4.1.2",
+ "mkdirp": "^0.5.0",
+ "nopt": "2 || 3",
+ "npmlog": "0 || 1 || 2 || 3 || 4",
+ "osenv": "0",
+ "request": "^2.87.0",
+ "rimraf": "2",
+ "semver": "~5.3.0",
+ "tar": "^2.0.0",
+ "which": "1"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "5.3.0",
+ "resolved": "http://registry.npmjs.org/semver/-/semver-5.3.0.tgz",
+ "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8="
+ }
+ }
+ },
"node-int64": {
"version": "0.4.0",
"resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz",
@@ -9299,21 +9530,105 @@
"semver": "^5.3.0"
}
},
- "nomnom": {
- "version": "1.6.2",
- "resolved": "https://registry.npmjs.org/nomnom/-/nomnom-1.6.2.tgz",
- "integrity": "sha1-hKZqJgF0QI/Ft3oY+IjszET7aXE=",
- "dev": true,
+ "node-sass": {
+ "version": "4.10.0",
+ "resolved": "https://registry.npmjs.org/node-sass/-/node-sass-4.10.0.tgz",
+ "integrity": "sha512-fDQJfXszw6vek63Fe/ldkYXmRYK/QS6NbvM3i5oEo9ntPDy4XX7BcKZyTKv+/kSSxRtXXc7l+MSwEmYc0CSy6Q==",
"requires": {
- "colors": "0.5.x",
- "underscore": "~1.4.4"
- }
- },
- "normalize-package-data": {
- "version": "2.4.0",
- "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz",
- "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==",
- "dev": true,
+ "async-foreach": "^0.1.3",
+ "chalk": "^1.1.1",
+ "cross-spawn": "^3.0.0",
+ "gaze": "^1.0.0",
+ "get-stdin": "^4.0.1",
+ "glob": "^7.0.3",
+ "in-publish": "^2.0.0",
+ "lodash.assign": "^4.2.0",
+ "lodash.clonedeep": "^4.3.2",
+ "lodash.mergewith": "^4.6.0",
+ "meow": "^3.7.0",
+ "mkdirp": "^0.5.1",
+ "nan": "^2.10.0",
+ "node-gyp": "^3.8.0",
+ "npmlog": "^4.0.0",
+ "request": "^2.88.0",
+ "sass-graph": "^2.2.4",
+ "stdout-stream": "^1.4.0",
+ "true-case-path": "^1.0.2"
+ },
+ "dependencies": {
+ "ansi-regex": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
+ "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8="
+ },
+ "ansi-styles": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz",
+ "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4="
+ },
+ "chalk": {
+ "version": "1.1.3",
+ "resolved": "http://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz",
+ "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=",
+ "requires": {
+ "ansi-styles": "^2.2.1",
+ "escape-string-regexp": "^1.0.2",
+ "has-ansi": "^2.0.0",
+ "strip-ansi": "^3.0.0",
+ "supports-color": "^2.0.0"
+ }
+ },
+ "cross-spawn": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-3.0.1.tgz",
+ "integrity": "sha1-ElYDfsufDF9549bvE14wdwGEuYI=",
+ "requires": {
+ "lru-cache": "^4.0.1",
+ "which": "^1.2.9"
+ }
+ },
+ "get-stdin": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz",
+ "integrity": "sha1-uWjGsKBDhDJJAui/Gl3zJXmkUP4="
+ },
+ "strip-ansi": {
+ "version": "3.0.1",
+ "resolved": "http://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
+ "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
+ "requires": {
+ "ansi-regex": "^2.0.0"
+ }
+ },
+ "supports-color": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz",
+ "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc="
+ }
+ }
+ },
+ "nomnom": {
+ "version": "1.6.2",
+ "resolved": "https://registry.npmjs.org/nomnom/-/nomnom-1.6.2.tgz",
+ "integrity": "sha1-hKZqJgF0QI/Ft3oY+IjszET7aXE=",
+ "dev": true,
+ "requires": {
+ "colors": "0.5.x",
+ "underscore": "~1.4.4"
+ }
+ },
+ "nopt": {
+ "version": "3.0.6",
+ "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz",
+ "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=",
+ "requires": {
+ "abbrev": "1"
+ }
+ },
+ "normalize-package-data": {
+ "version": "2.4.0",
+ "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz",
+ "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==",
"requires": {
"hosted-git-info": "^2.1.4",
"is-builtin-module": "^1.0.0",
@@ -9357,6 +9672,17 @@
"path-key": "^2.0.0"
}
},
+ "npmlog": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz",
+ "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==",
+ "requires": {
+ "are-we-there-yet": "~1.1.2",
+ "console-control-strings": "~1.1.0",
+ "gauge": "~2.7.3",
+ "set-blocking": "~2.0.0"
+ }
+ },
"nth-check": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.2.tgz",
@@ -9375,8 +9701,7 @@
"number-is-nan": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz",
- "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=",
- "dev": true
+ "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0="
},
"nwsapi": {
"version": "2.0.9",
@@ -9387,8 +9712,7 @@
"oauth-sign": {
"version": "0.9.0",
"resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz",
- "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==",
- "dev": true
+ "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ=="
},
"object-assign": {
"version": "4.1.1",
@@ -9549,7 +9873,6 @@
"version": "1.4.0",
"resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
"integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
- "dev": true,
"requires": {
"wrappy": "1"
}
@@ -9632,8 +9955,7 @@
"os-homedir": {
"version": "1.0.2",
"resolved": "http://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz",
- "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=",
- "dev": true
+ "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M="
},
"os-locale": {
"version": "2.1.0",
@@ -9683,8 +10005,16 @@
"os-tmpdir": {
"version": "1.0.2",
"resolved": "http://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
- "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=",
- "dev": true
+ "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ="
+ },
+ "osenv": {
+ "version": "0.1.5",
+ "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz",
+ "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==",
+ "requires": {
+ "os-homedir": "^1.0.0",
+ "os-tmpdir": "^1.0.0"
+ }
},
"output-file-sync": {
"version": "2.0.1",
@@ -9817,7 +10147,6 @@
"version": "2.2.0",
"resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz",
"integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=",
- "dev": true,
"requires": {
"error-ex": "^1.2.0"
}
@@ -9865,7 +10194,6 @@
"version": "2.1.0",
"resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz",
"integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=",
- "dev": true,
"requires": {
"pinkie-promise": "^2.0.0"
}
@@ -9873,8 +10201,7 @@
"path-is-absolute": {
"version": "1.0.1",
"resolved": "http://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
- "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
- "dev": true
+ "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18="
},
"path-is-inside": {
"version": "1.0.2",
@@ -9925,26 +10252,22 @@
"performance-now": {
"version": "2.1.0",
"resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz",
- "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=",
- "dev": true
+ "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns="
},
"pify": {
"version": "2.3.0",
"resolved": "http://registry.npmjs.org/pify/-/pify-2.3.0.tgz",
- "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=",
- "dev": true
+ "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw="
},
"pinkie": {
"version": "2.0.4",
"resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz",
- "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=",
- "dev": true
+ "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA="
},
"pinkie-promise": {
"version": "2.0.1",
"resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz",
"integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=",
- "dev": true,
"requires": {
"pinkie": "^2.0.0"
}
@@ -11986,8 +12309,7 @@
"process-nextick-args": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz",
- "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==",
- "dev": true
+ "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw=="
},
"progress": {
"version": "2.0.1",
@@ -12047,14 +12369,12 @@
"pseudomap": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz",
- "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=",
- "dev": true
+ "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM="
},
"psl": {
"version": "1.1.29",
"resolved": "https://registry.npmjs.org/psl/-/psl-1.1.29.tgz",
- "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ==",
- "dev": true
+ "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ=="
},
"public-encrypt": {
"version": "4.0.3",
@@ -12106,8 +12426,7 @@
"punycode": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz",
- "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==",
- "dev": true
+ "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A=="
},
"q": {
"version": "1.5.1",
@@ -12118,8 +12437,7 @@
"qs": {
"version": "6.5.2",
"resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz",
- "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==",
- "dev": true
+ "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA=="
},
"query-string": {
"version": "4.3.4",
@@ -12594,7 +12912,6 @@
"version": "2.3.6",
"resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz",
"integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==",
- "dev": true,
"requires": {
"core-util-is": "~1.0.0",
"inherits": "~2.0.3",
@@ -12634,6 +12951,15 @@
"minimatch": "3.0.4"
}
},
+ "redent": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/redent/-/redent-1.0.0.tgz",
+ "integrity": "sha1-z5Fqsf1fHxbfsggi3W7H9zDCr94=",
+ "requires": {
+ "indent-string": "^2.1.0",
+ "strip-indent": "^1.0.1"
+ }
+ },
"regenerate": {
"version": "1.4.0",
"resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.0.tgz",
@@ -12838,7 +13164,6 @@
"version": "2.0.1",
"resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz",
"integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=",
- "dev": true,
"requires": {
"is-finite": "^1.0.0"
}
@@ -12847,7 +13172,6 @@
"version": "2.88.0",
"resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz",
"integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==",
- "dev": true,
"requires": {
"aws-sign2": "~0.7.0",
"aws4": "^1.8.0",
@@ -12894,8 +13218,7 @@
"require-directory": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
- "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=",
- "dev": true
+ "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I="
},
"require-from-string": {
"version": "2.0.2",
@@ -12906,8 +13229,7 @@
"require-main-filename": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz",
- "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=",
- "dev": true
+ "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE="
},
"require-uncached": {
"version": "1.0.3",
@@ -13005,7 +13327,6 @@
"version": "2.6.2",
"resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz",
"integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==",
- "dev": true,
"requires": {
"glob": "^7.0.5"
}
@@ -13072,8 +13393,7 @@
"safe-buffer": {
"version": "5.1.2",
"resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
- "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
- "dev": true
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
},
"safe-regex": {
"version": "1.1.0",
@@ -13114,6 +13434,155 @@
}
}
},
+ "sass-graph": {
+ "version": "2.2.4",
+ "resolved": "https://registry.npmjs.org/sass-graph/-/sass-graph-2.2.4.tgz",
+ "integrity": "sha1-E/vWPNHK8JCLn9k0dq1DpR0eC0k=",
+ "requires": {
+ "glob": "^7.0.0",
+ "lodash": "^4.0.0",
+ "scss-tokenizer": "^0.2.3",
+ "yargs": "^7.0.0"
+ },
+ "dependencies": {
+ "ansi-regex": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
+ "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8="
+ },
+ "camelcase": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz",
+ "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo="
+ },
+ "cliui": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz",
+ "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=",
+ "requires": {
+ "string-width": "^1.0.1",
+ "strip-ansi": "^3.0.1",
+ "wrap-ansi": "^2.0.0"
+ }
+ },
+ "is-fullwidth-code-point": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz",
+ "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=",
+ "requires": {
+ "number-is-nan": "^1.0.0"
+ }
+ },
+ "load-json-file": {
+ "version": "1.1.0",
+ "resolved": "http://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz",
+ "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=",
+ "requires": {
+ "graceful-fs": "^4.1.2",
+ "parse-json": "^2.2.0",
+ "pify": "^2.0.0",
+ "pinkie-promise": "^2.0.0",
+ "strip-bom": "^2.0.0"
+ }
+ },
+ "os-locale": {
+ "version": "1.4.0",
+ "resolved": "http://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz",
+ "integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=",
+ "requires": {
+ "lcid": "^1.0.0"
+ }
+ },
+ "path-type": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz",
+ "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=",
+ "requires": {
+ "graceful-fs": "^4.1.2",
+ "pify": "^2.0.0",
+ "pinkie-promise": "^2.0.0"
+ }
+ },
+ "read-pkg": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz",
+ "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=",
+ "requires": {
+ "load-json-file": "^1.0.0",
+ "normalize-package-data": "^2.3.2",
+ "path-type": "^1.0.0"
+ }
+ },
+ "read-pkg-up": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz",
+ "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=",
+ "requires": {
+ "find-up": "^1.0.0",
+ "read-pkg": "^1.0.0"
+ }
+ },
+ "string-width": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz",
+ "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=",
+ "requires": {
+ "code-point-at": "^1.0.0",
+ "is-fullwidth-code-point": "^1.0.0",
+ "strip-ansi": "^3.0.0"
+ }
+ },
+ "strip-ansi": {
+ "version": "3.0.1",
+ "resolved": "http://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
+ "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
+ "requires": {
+ "ansi-regex": "^2.0.0"
+ }
+ },
+ "strip-bom": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz",
+ "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=",
+ "requires": {
+ "is-utf8": "^0.2.0"
+ }
+ },
+ "which-module": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/which-module/-/which-module-1.0.0.tgz",
+ "integrity": "sha1-u6Y8qGGUiZT/MHc2CJ47lgJsKk8="
+ },
+ "yargs": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/yargs/-/yargs-7.1.0.tgz",
+ "integrity": "sha1-a6MY6xaWFyf10oT46gA+jWFU0Mg=",
+ "requires": {
+ "camelcase": "^3.0.0",
+ "cliui": "^3.2.0",
+ "decamelize": "^1.1.1",
+ "get-caller-file": "^1.0.1",
+ "os-locale": "^1.4.0",
+ "read-pkg-up": "^1.0.1",
+ "require-directory": "^2.1.1",
+ "require-main-filename": "^1.0.1",
+ "set-blocking": "^2.0.0",
+ "string-width": "^1.0.2",
+ "which-module": "^1.0.0",
+ "y18n": "^3.2.1",
+ "yargs-parser": "^5.0.0"
+ }
+ },
+ "yargs-parser": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-5.0.0.tgz",
+ "integrity": "sha1-J17PDX/+Bcd+ZOfIbkzZS/DhIoo=",
+ "requires": {
+ "camelcase": "^3.0.0"
+ }
+ }
+ }
+ },
"sass-loader": {
"version": "7.1.0",
"resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-7.1.0.tgz",
@@ -13211,6 +13680,25 @@
"ajv-keywords": "^3.1.0"
}
},
+ "scss-tokenizer": {
+ "version": "0.2.3",
+ "resolved": "https://registry.npmjs.org/scss-tokenizer/-/scss-tokenizer-0.2.3.tgz",
+ "integrity": "sha1-jrBtualyMzOCTT9VMGQRSYR85dE=",
+ "requires": {
+ "js-base64": "^2.1.8",
+ "source-map": "^0.4.2"
+ },
+ "dependencies": {
+ "source-map": {
+ "version": "0.4.4",
+ "resolved": "http://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz",
+ "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=",
+ "requires": {
+ "amdefine": ">=0.0.4"
+ }
+ }
+ }
+ },
"select-hose": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz",
@@ -13229,8 +13717,7 @@
"semver": {
"version": "5.6.0",
"resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz",
- "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==",
- "dev": true
+ "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg=="
},
"semver-compare": {
"version": "1.0.0",
@@ -13303,8 +13790,7 @@
"set-blocking": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz",
- "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=",
- "dev": true
+ "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc="
},
"set-value": {
"version": "2.0.0",
@@ -13415,8 +13901,7 @@
"signal-exit": {
"version": "3.0.2",
"resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz",
- "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=",
- "dev": true
+ "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0="
},
"simple-swizzle": {
"version": "0.2.2",
@@ -13651,7 +14136,6 @@
"version": "3.0.2",
"resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.0.2.tgz",
"integrity": "sha512-q9hedtzyXHr5S0A1vEPoK/7l8NpfkFYTq6iCY+Pno2ZbdZR6WexZFtqeVGkGxW3TEJMN914Z55EnAGMmenlIQQ==",
- "dev": true,
"requires": {
"spdx-expression-parse": "^3.0.0",
"spdx-license-ids": "^3.0.0"
@@ -13660,14 +14144,12 @@
"spdx-exceptions": {
"version": "2.2.0",
"resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz",
- "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==",
- "dev": true
+ "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA=="
},
"spdx-expression-parse": {
"version": "3.0.0",
"resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz",
"integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==",
- "dev": true,
"requires": {
"spdx-exceptions": "^2.1.0",
"spdx-license-ids": "^3.0.0"
@@ -13676,8 +14158,7 @@
"spdx-license-ids": {
"version": "3.0.2",
"resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.2.tgz",
- "integrity": "sha512-qky9CVt0lVIECkEsYbNILVnPvycuEBkXoMFLRWsREkomQLevYhtRKC+R91a5TOAQ3bCMjikRwhyaRqj1VYatYg==",
- "dev": true
+ "integrity": "sha512-qky9CVt0lVIECkEsYbNILVnPvycuEBkXoMFLRWsREkomQLevYhtRKC+R91a5TOAQ3bCMjikRwhyaRqj1VYatYg=="
},
"spdy": {
"version": "3.4.7",
@@ -13727,7 +14208,6 @@
"version": "1.15.2",
"resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.15.2.tgz",
"integrity": "sha512-Ra/OXQtuh0/enyl4ETZAfTaeksa6BXks5ZcjpSUNrjBr0DvrJKX+1fsKDPpT9TBXgHAFsa4510aNVgI8g/+SzA==",
- "dev": true,
"requires": {
"asn1": "~0.2.3",
"assert-plus": "^1.0.0",
@@ -13788,6 +14268,14 @@
"integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==",
"dev": true
},
+ "stdout-stream": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/stdout-stream/-/stdout-stream-1.4.1.tgz",
+ "integrity": "sha512-j4emi03KXqJWcIeF8eIXkjMFN1Cmb8gUlDYGeBALLPo5qdyTfA9bOtl8m33lRoC+vFMkP3gl0WsDr6+gzxbbTA==",
+ "requires": {
+ "readable-stream": "^2.0.1"
+ }
+ },
"stealthy-require": {
"version": "1.1.1",
"resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz",
@@ -13853,7 +14341,6 @@
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
"integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==",
- "dev": true,
"requires": {
"is-fullwidth-code-point": "^2.0.0",
"strip-ansi": "^4.0.0"
@@ -13874,7 +14361,6 @@
"version": "1.1.1",
"resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
"integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
- "dev": true,
"requires": {
"safe-buffer": "~5.1.0"
}
@@ -13894,7 +14380,6 @@
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz",
"integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=",
- "dev": true,
"requires": {
"ansi-regex": "^3.0.0"
}
@@ -13921,6 +14406,21 @@
"integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=",
"dev": true
},
+ "strip-indent": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-1.0.1.tgz",
+ "integrity": "sha1-DHlipq3vp7vUrDZkYKY4VSrhoKI=",
+ "requires": {
+ "get-stdin": "^4.0.1"
+ },
+ "dependencies": {
+ "get-stdin": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz",
+ "integrity": "sha1-uWjGsKBDhDJJAui/Gl3zJXmkUP4="
+ }
+ }
+ },
"strip-json-comments": {
"version": "2.0.1",
"resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
@@ -14092,6 +14592,16 @@
"integrity": "sha512-IlqtmLVaZA2qab8epUXbVWRn3aB1imbDMJtjB3nu4X0NqPkcY/JH9ZtCBWKHWPxs8Svi9tyo8w2dBoi07qZbBA==",
"dev": true
},
+ "tar": {
+ "version": "2.2.1",
+ "resolved": "http://registry.npmjs.org/tar/-/tar-2.2.1.tgz",
+ "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=",
+ "requires": {
+ "block-stream": "*",
+ "fstream": "^1.0.2",
+ "inherits": "2"
+ }
+ },
"terser": {
"version": "3.10.12",
"resolved": "https://registry.npmjs.org/terser/-/terser-3.10.12.tgz",
@@ -14509,7 +15019,6 @@
"version": "2.4.3",
"resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz",
"integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==",
- "dev": true,
"requires": {
"psl": "^1.1.24",
"punycode": "^1.4.1"
@@ -14518,8 +15027,7 @@
"punycode": {
"version": "1.4.1",
"resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz",
- "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=",
- "dev": true
+ "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4="
}
}
},
@@ -14532,6 +15040,11 @@
"punycode": "^2.1.0"
}
},
+ "trim-newlines": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-1.0.0.tgz",
+ "integrity": "sha1-WIeWa7WCpFA6QetST301ARgVphM="
+ },
"trim-repeated": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/trim-repeated/-/trim-repeated-1.0.0.tgz",
@@ -14547,6 +15060,14 @@
"integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=",
"dev": true
},
+ "true-case-path": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/true-case-path/-/true-case-path-1.0.3.tgz",
+ "integrity": "sha512-m6s2OdQe5wgpFMC+pAJ+q9djG82O2jcHPOI6RNg1yy9rCYR+WD6Nbpl32fDpfC56nirdRy+opFa/Vk7HYhqaew==",
+ "requires": {
+ "glob": "^7.1.2"
+ }
+ },
"tryer": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/tryer/-/tryer-1.0.1.tgz",
@@ -14569,7 +15090,6 @@
"version": "0.6.0",
"resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz",
"integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=",
- "dev": true,
"requires": {
"safe-buffer": "^5.0.1"
}
@@ -14577,8 +15097,7 @@
"tweetnacl": {
"version": "0.14.5",
"resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz",
- "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=",
- "dev": true
+ "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q="
},
"type-check": {
"version": "0.3.2",
@@ -14921,7 +15440,6 @@
"version": "4.2.2",
"resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz",
"integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==",
- "dev": true,
"requires": {
"punycode": "^2.1.0"
}
@@ -14989,8 +15507,7 @@
"util-deprecate": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
- "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=",
- "dev": true
+ "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="
},
"util.promisify": {
"version": "1.0.0",
@@ -15017,14 +15534,12 @@
"uuid": {
"version": "3.3.2",
"resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz",
- "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==",
- "dev": true
+ "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA=="
},
"validate-npm-package-license": {
"version": "3.0.4",
"resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
"integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
- "dev": true,
"requires": {
"spdx-correct": "^3.0.0",
"spdx-expression-parse": "^3.0.0"
@@ -15046,7 +15561,6 @@
"version": "1.10.0",
"resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz",
"integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=",
- "dev": true,
"requires": {
"assert-plus": "^1.0.0",
"core-util-is": "1.0.2",
@@ -15531,7 +16045,6 @@
"version": "1.3.1",
"resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
"integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
- "dev": true,
"requires": {
"isexe": "^2.0.0"
}
@@ -15542,6 +16055,14 @@
"integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=",
"dev": true
},
+ "wide-align": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz",
+ "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==",
+ "requires": {
+ "string-width": "^1.0.2 || 2"
+ }
+ },
"wordwrap": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz",
@@ -15729,7 +16250,6 @@
"version": "2.1.0",
"resolved": "http://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz",
"integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=",
- "dev": true,
"requires": {
"string-width": "^1.0.1",
"strip-ansi": "^3.0.1"
@@ -15738,14 +16258,12 @@
"ansi-regex": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
- "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=",
- "dev": true
+ "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8="
},
"is-fullwidth-code-point": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz",
"integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=",
- "dev": true,
"requires": {
"number-is-nan": "^1.0.0"
}
@@ -15754,7 +16272,6 @@
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz",
"integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=",
- "dev": true,
"requires": {
"code-point-at": "^1.0.0",
"is-fullwidth-code-point": "^1.0.0",
@@ -15765,7 +16282,6 @@
"version": "3.0.1",
"resolved": "http://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
"integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
- "dev": true,
"requires": {
"ansi-regex": "^2.0.0"
}
@@ -15775,8 +16291,7 @@
"wrappy": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
- "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
- "dev": true
+ "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8="
},
"write": {
"version": "0.2.1",
@@ -15834,14 +16349,12 @@
"y18n": {
"version": "3.2.1",
"resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz",
- "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=",
- "dev": true
+ "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE="
},
"yallist": {
"version": "3.0.3",
"resolved": "https://registry.npmjs.org/yallist/-/yallist-3.0.3.tgz",
- "integrity": "sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A==",
- "dev": true
+ "integrity": "sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A=="
},
"yargs": {
"version": "11.1.0",
diff --git a/package.json b/package.json
index b87a74a1..8acf80de 100644
--- a/package.json
+++ b/package.json
@@ -76,6 +76,7 @@
"babel-polyfill": "^6.26.0",
"draft-js": "^0.10.5",
"mousetrap": "1.5.2",
+ "node-sass": "^4.10.0",
"prop-types": "^15.6.2",
"react": "^16.6.0",
"react-dom": "^16.6.0",
diff --git a/src/index.js b/src/index.js
index 25e4b93d..8af55fbe 100644
--- a/src/index.js
+++ b/src/index.js
@@ -1,11 +1,13 @@
import React from 'react';
import { render } from 'react-dom';
+
import { TranscriptEditor } from './lib';
-// import kaldiTranscript from './sample-data/kaldi-transcription-20181029235300.json';
+
import kaldiTedTalkTranscript from './sample-data/KateDarling_2018S-bbc-kaldi.json';
-import styles from './index.module.css';
import SttTypeSelect from './select-stt-json-type'
+import style from './index.module.css';
+
const tedTalkVideoUrl = 'https://download.ted.com/talks/KateDarling_2018S-950k.mp4';
class App extends React.Component {
@@ -102,8 +104,8 @@ class App extends React.Component {
render() {
return (
-
-
+
+
Demo page for React Transcript Editor - Component |{' '}
Text Is Editable
-
diff --git a/src/index.module.css b/src/index.module.css
index 6ba7ec1b..1715713a 100644
--- a/src/index.module.css
+++ b/src/index.module.css
@@ -1,31 +1,5 @@
-
-.container{
+.container {
height: 100vh;
- /* width: 640px; */
- /* margin: 15px auto; */
font-family: Consolas, Helvetica Neue, Helvetica, Arial, sans-serif;
- /* font-family: Helvetica Neue, Helvetica, Arial, sans-serif; */
background-color: #f1f1f1;
}
-
-/* body{
- background-color: #f1f1f1;
- margin: 0px;
-}
-
-.title{
- font-size: 1.5rem;
-} */
-
-/* https://www.w3schools.com/css/css3_buttons.asp */
-/* button {
- background-color: white;
- color: black;
- border: none;
- padding: 4px 4px;
- text-align: center;
- text-decoration: none;
- display: inline-block;
- font-size: 12px;
- margin:3px;
-} */
diff --git a/src/lib/TranscriptEditor/index.js b/src/lib/TranscriptEditor/index.js
index c969772f..ff8c46e9 100644
--- a/src/lib/TranscriptEditor/index.js
+++ b/src/lib/TranscriptEditor/index.js
@@ -4,7 +4,7 @@ import PropTypes from 'prop-types';
import TimedTextEditor from './TimedTextEditor';
import MediaPlayer from './MediaPlayer';
-import styles from './index.module.css';
+import style from './index.module.css';
class TranscriptEditor extends React.Component {
constructor(props) {
@@ -61,10 +61,9 @@ class TranscriptEditor extends React.Component {
render() {
return (
-
-
-
-
+
+
);
}
}
diff --git a/src/lib/TranscriptEditor/index.module.css b/src/lib/TranscriptEditor/index.module.css
index f2a30bf0..883ac379 100644
--- a/src/lib/TranscriptEditor/index.module.css
+++ b/src/lib/TranscriptEditor/index.module.css
@@ -1,23 +1,3 @@
-/* .simple-form-group {
- margin-bottom: 1rem;
- }
- .simple-text-label {
- display: block;
- color: red;
- }
- .simple-text-input {
- display: inline-block;
- margin-bottom: 0.5rem;
- font-size: 16px;
- font-weight: 400;
- color: rgb(33, 37, 41);
- } */
-
-
- /* https://medium.com/samsung-internet-dev/common-responsive-layouts-with-css-grid-and-some-without-245a862f48df */
-
-
-
/* Desktop size */
@media (min-width: 768px) {
.container {
@@ -43,7 +23,6 @@
/* padding: 20px; */
/* background-color: #936; */
}
-
}
/* Mobile devices */
@@ -58,13 +37,3 @@
width: 100%;
}
}
-
-
-
-
-
-
-
-
-
-
From 89e99e5e568cebf17cb7c048ff8080ab3208024d Mon Sep 17 00:00:00 2001
From: James Dooley
Date: Mon, 3 Dec 2018 00:26:34 +0000
Subject: [PATCH 02/15] Separating Speaker ID, timecodes and text into three
columns
---
.../TimedTextEditor/SpeakerLabel.js | 4 ++--
.../TimedTextEditor/WrapperBlock.js | 12 ++++++----
.../TimedTextEditor/WrapperBlock.module.css | 23 ++++++++++++++++---
.../TranscriptEditor/TimedTextEditor/index.js | 7 +++---
.../TimedTextEditor/index.module.css | 5 ----
5 files changed, 32 insertions(+), 19 deletions(-)
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js b/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
index bb5df627..6d23bc70 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
@@ -6,13 +6,13 @@ import style from './WrapperBlock.module.css';
class SpeakerLabel extends PureComponent {
render() {
return (
-
+
{this.props.name}
✏️
-
+
)
}
}
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.js b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.js
index a29fedd9..ae65a4ae 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.js
@@ -38,14 +38,16 @@ class WrapperBlock extends React.Component {
render() {
return (
-
+
-
- {this.state.start}
-
+ />
+ {this.state.start}
+
+
+
+
);
}
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
index 710c0d9a..b2236676 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
+++ b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
@@ -1,10 +1,27 @@
-.WrapperBlock {}
+.WrapperBlock {
+ width: 100%;
+ margin-bottom: 2em;
+ overflow: auto;
+}
+
+.markers {
+ width: 30%;
+ float: left;
+}
+
+.text {
+ width: 70%;
+ float: right;
+ clear: right;
+}
-.SpeakerBlock {
+.speaker {
+ display: inline-block;
font-weight: bold;
}
-.TimeBlock {
+.time {
+ display: inline-block;
font-weight: lighter;
margin-bottom: 8px;
}
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/index.js b/src/lib/TranscriptEditor/TimedTextEditor/index.js
index 8da6b294..14438eb2 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/index.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/index.js
@@ -2,10 +2,8 @@ import React from 'react';
import PropTypes from 'prop-types';
import {
- // Draft,
Editor,
EditorState,
- // ContentState,
CompositeDecorator,
convertFromRaw,
convertToRaw,
@@ -15,7 +13,8 @@ import Word from './Word';
import WrapperBlock from './WrapperBlock';
import sttJsonAdapter from './adapters/index.js';
-import styles from './index.module.css';
+
+import style from './index.module.css';
class TimedTextEditor extends React.Component {
constructor(props) {
@@ -222,7 +221,7 @@ class TimedTextEditor extends React.Component {
return (
this.handleDoubleClick(event) }
// onClick={ event => this.handleOnClick(event) }
>
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/index.module.css b/src/lib/TranscriptEditor/TimedTextEditor/index.module.css
index f1cf989d..70456dfd 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/index.module.css
+++ b/src/lib/TranscriptEditor/TimedTextEditor/index.module.css
@@ -8,8 +8,3 @@ https://github.com/facebook/draft-js/issues/528
background-color:#fff;
padding: 20px;
}
-
-/* "paragraphs" */
-div[data-block] + div[data-block] {
- margin-top: 1em;
-}
From ce896632c4031a2ed4bcda4e93ac98662dc17d6d Mon Sep 17 00:00:00 2001
From: James Dooley
Date: Mon, 3 Dec 2018 12:05:34 +0000
Subject: [PATCH 03/15] Added colour variables, more styling fixes
---
.../MediaPlayer/ProgressBar.module.css | 1 -
.../TimedTextEditor/SpeakerLabel.js | 4 +++-
src/lib/TranscriptEditor/TimedTextEditor/Word.js | 5 ++++-
.../TimedTextEditor/WrapperBlock.js | 5 +++--
.../TimedTextEditor/WrapperBlock.module.css | 13 ++++++++++++-
src/lib/TranscriptEditor/TimedTextEditor/index.js | 8 ++++----
.../TimedTextEditor/index.module.css | 2 +-
src/lib/TranscriptEditor/colours.module.css | 5 +++++
src/lib/TranscriptEditor/index.module.css | 10 ++++++++++
9 files changed, 42 insertions(+), 11 deletions(-)
create mode 100644 src/lib/TranscriptEditor/colours.module.css
diff --git a/src/lib/TranscriptEditor/MediaPlayer/ProgressBar.module.css b/src/lib/TranscriptEditor/MediaPlayer/ProgressBar.module.css
index e475f080..5f81cd92 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/ProgressBar.module.css
+++ b/src/lib/TranscriptEditor/MediaPlayer/ProgressBar.module.css
@@ -3,4 +3,3 @@
width: 100%;
background-color: grey;
}
-
\ No newline at end of file
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js b/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
index 6d23bc70..d28277b0 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
@@ -10,7 +10,9 @@ class SpeakerLabel extends PureComponent {
{this.props.name}
✏️
+ onClick={ this.props.handleOnClickEdit }
+ role='img'
+ aria-label='Pencil'> ✏️
)
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/Word.js b/src/lib/TranscriptEditor/TimedTextEditor/Word.js
index af01002c..a24e8067 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/Word.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/Word.js
@@ -14,7 +14,10 @@ class Word extends PureComponent {
prevTimes += `${ i } `;
}
- if (data.start % 1 > 0.5) prevTimes += ` ${ Math.floor(data.start) }.5`;
+ if (data.start % 1 > 0) {
+ const dec = Math.round((data.start % 1 - 0.5) * 4.0) / 4.0;
+ prevTimes += ` ${ Math.floor(data.start) + dec }`;
+ }
return (
- {this.state.start}
+ {secondsToTimecode(this.state.start)}
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
index b2236676..94057af4 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
+++ b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
@@ -1,29 +1,40 @@
+@value color-labs-red, color-light-grey, color-mid-grey, color-dark-grey from '../colours.module.css';
+
.WrapperBlock {
width: 100%;
margin-bottom: 2em;
overflow: auto;
+ line-height: 1em;
}
.markers {
width: 30%;
+ font-size: 0.8em;
float: left;
}
.text {
- width: 70%;
+ width: 65%;
+ font-size: 1em;
float: right;
clear: right;
+ /* color: color-light-grey; */
}
.speaker {
display: inline-block;
font-weight: bold;
+ text-transform: uppercase;
+ width: 50%;
+ color: color-mid-grey;
}
.time {
display: inline-block;
font-weight: lighter;
margin-bottom: 8px;
+ width: 50%;
+ text-align: right;
}
.EditLabel {
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/index.js b/src/lib/TranscriptEditor/TimedTextEditor/index.js
index 14438eb2..31b5d3b4 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/index.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/index.js
@@ -211,12 +211,12 @@ class TimedTextEditor extends React.Component {
render() {
const currentWord = this.getCurrentWord();
- const highlightColour = 'lightblue';
- const unplayedColor = 'grey';
+ const highlightColour = '#69e3c2';
+ const unplayedColor = '#767676';
const correctionBorder = '1px dotted blue';
// Time to the nearest half second
- const time = Math.round(this.props.currentTime * 2.0) / 2.0;
+ const time = Math.round(this.props.currentTime * 4.0) / 4.0;
return (
@@ -226,7 +226,7 @@ class TimedTextEditor extends React.Component {
// onClick={ event => this.handleOnClick(event) }
>
+
+
+
+ );
+
return (
- this.handleDoubleClick(event) }
- // onClick={ event => this.handleOnClick(event) }
- >
-
-
-
-
+ { this.props.transcriptData !== null ? editor : null }
);
}
From cd6f502a4d7bc50eaa702242fbb6baf02f5e1cae Mon Sep 17 00:00:00 2001
From: James Dooley
Date: Mon, 10 Dec 2018 17:50:10 +0000
Subject: [PATCH 12/15] Fix: Make player controls position fixed, Move speaker
edit button
---
src/index.module.css | 6 ------
src/lib/TranscriptEditor/MediaPlayer/index.module.css | 5 ++++-
src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js | 2 +-
src/lib/TranscriptEditor/TimedTextEditor/index.module.css | 8 ++++++++
src/lib/TranscriptEditor/index.module.css | 1 +
5 files changed, 14 insertions(+), 8 deletions(-)
diff --git a/src/index.module.css b/src/index.module.css
index 939d7547..a2383559 100644
--- a/src/index.module.css
+++ b/src/index.module.css
@@ -1,10 +1,4 @@
-@font-face {
- font-family: 'BBCReithSans';
- src: url('http://gel.files.bbci.co.uk/r2.302/subsets/BBCReithSansCd_WLatn_Bd.woff2') format('woff2');
-}
-
.container {
height: 100vh;
- /* font-family: Consolas, Helvetica Neue, Helvetica, Arial, sans-serif; */
font-family: ReithSerif, Fallback, sans-serif;
}
diff --git a/src/lib/TranscriptEditor/MediaPlayer/index.module.css b/src/lib/TranscriptEditor/MediaPlayer/index.module.css
index b10075d8..35aa3a6b 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/index.module.css
+++ b/src/lib/TranscriptEditor/MediaPlayer/index.module.css
@@ -1,8 +1,11 @@
@value color-light-grey from '../colours.module.css';
.topSection {
- height: 100%;
+ /* height: 100%; */
background: black;
+ position: fixed;
+ top: 0;
+ left: 0;
}
.playerSection {
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js b/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
index d28277b0..1b6d0044 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
@@ -7,13 +7,13 @@ class SpeakerLabel extends PureComponent {
render() {
return (
- {this.props.name}
✏️
+ {this.props.name}
)
}
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/index.module.css b/src/lib/TranscriptEditor/TimedTextEditor/index.module.css
index a6732299..be49bccf 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/index.module.css
+++ b/src/lib/TranscriptEditor/TimedTextEditor/index.module.css
@@ -13,3 +13,11 @@ https://github.com/facebook/draft-js/issues/528
width: 80%;
margin: 0 auto;
}
+
+
+@media (max-width: 768px) {
+ .editor {
+ width: 100%;
+ margin: 0 auto;
+ }
+}
diff --git a/src/lib/TranscriptEditor/index.module.css b/src/lib/TranscriptEditor/index.module.css
index 86f3921f..84a445cf 100644
--- a/src/lib/TranscriptEditor/index.module.css
+++ b/src/lib/TranscriptEditor/index.module.css
@@ -9,6 +9,7 @@
flex-wrap: nowrap;
/* min-height: 100vh; */
background-color: #f9f9f9;
+ position: relative;
}
.main {
From d845f8a4478723bf559080e7f41a17e96df34bfd Mon Sep 17 00:00:00 2001
From: James Dooley
Date: Mon, 10 Dec 2018 18:12:46 +0000
Subject: [PATCH 13/15] Fix: Added keyword spacing rules for eslint, eslint
-fix
---
.eslintrc | 5 +-
src/index.js | 55 ++++---
.../MediaPlayer/PauseWhileTyping.js | 30 ++--
.../MediaPlayer/PlaybackRate.js | 50 +++----
.../MediaPlayer/PlayerControls.js | 2 +-
.../TranscriptEditor/MediaPlayer/RollBack.js | 50 +++----
.../MediaPlayer/VolumeControl.js | 28 ++--
.../MediaPlayer/defaultHotKeys.js | 2 +-
src/lib/TranscriptEditor/MediaPlayer/index.js | 135 +++++++++---------
.../TimedTextEditor/SpeakerLabel.js | 24 ++--
.../TimedTextEditor/WrapperBlock.js | 4 +-
.../adapters/autoEdit2/index.js | 5 +-
.../adapters/autoEdit2/index.test.js | 6 +-
.../adapters/bbc-kaldi/index.test.js | 6 +-
.../generate-entities-ranges/index.js | 7 +-
.../generate-entities-ranges/index.test.js | 24 ++--
.../TimedTextEditor/adapters/index.js | 33 +++--
.../TranscriptEditor/TimedTextEditor/index.js | 24 ++--
src/lib/TranscriptEditor/index.js | 43 +++---
src/lib/Util/timecode-converter/index.js | 6 +-
src/lib/Util/timecode-converter/index.test.js | 30 ++--
.../timecode-converter/padTimeToTimecode.js | 68 ++++-----
.../padTimeToTimecode.test.js | 14 +-
.../timecode-converter/secondsToTimecode.js | 17 +--
.../secondsToTimecode.test.js | 6 +-
.../timecode-converter/timecodeToSeconds.js | 22 +--
.../timecodeToSeconds.test.js | 6 +-
src/select-stt-json-type.js | 2 +-
28 files changed, 365 insertions(+), 339 deletions(-)
diff --git a/.eslintrc b/.eslintrc
index c0d69ad2..fde6f4d7 100644
--- a/.eslintrc
+++ b/.eslintrc
@@ -8,6 +8,7 @@
"jest": true
},
"rules": {
+ "indent": ["warn", 2],
"arrow-spacing": ["error", { "before": true, "after": true }],
"space-in-parens": [ 0, "never" ],
"template-curly-spacing": [ 2, "always" ],
@@ -17,7 +18,7 @@
"no-multiple-empty-lines": [ 2, { "max": 1, "maxEOF": 0, "maxBOF": 0 } ],
"quotes": [ 1, "single", "avoid-escape" ],
"no-use-before-define": [ 2, { "functions": false } ],
- "semi": [0, "never"],
+ "semi": [1, "always"],
"prefer-const": 1,
"react/prefer-es6-class": 0,
"react/jsx-filename-extension": 0,
@@ -34,6 +35,8 @@
"no-shadow": [ 1 ],
"camelcase": [ 1 ],
"no-underscore-dangle" : [0, "always"],
+ "keyword-spacing": ["error", { "before": true, "after": true }],
+ "newline-before-return": "error",
"prefer-destructuring": ["error", {
"VariableDeclarator": {
"array": false,
diff --git a/src/index.js b/src/index.js
index 8af55fbe..b44bc275 100644
--- a/src/index.js
+++ b/src/index.js
@@ -4,7 +4,7 @@ import { render } from 'react-dom';
import { TranscriptEditor } from './lib';
import kaldiTedTalkTranscript from './sample-data/KateDarling_2018S-bbc-kaldi.json';
-import SttTypeSelect from './select-stt-json-type'
+import SttTypeSelect from './select-stt-json-type';
import style from './index.module.css';
@@ -76,19 +76,19 @@ class App extends React.Component {
}
handleIsTextEditable = (e) => {
- this.setState((prevState, props) => ({ isTextEditable: (prevState.isTextEditable) !== true }))
+ this.setState((prevState, props) => ({ isTextEditable: (prevState.isTextEditable) !== true }));
}
// https://stackoverflow.com/questions/21733847/react-jsx-selecting-selected-on-selected-select-option
handleSttTypeChange = (event) => {
- console.log(event.target.name, event.target.value)
+ console.log(event.target.name, event.target.value);
this.setState({ [event.target.name]: event.target.value });
}
getEditorContent = () => {
const tmpEditorsContnet = this.refs.transcriptEditor.getEditorContent(this.state.sttType);
- this.download(JSON.stringify(tmpEditorsContnet, null, 2), `${ this.state.mediaUrl } .json`)
+ this.download(JSON.stringify(tmpEditorsContnet, null, 2), `${ this.state.mediaUrl } .json`);
}
// https://stackoverflow.com/questions/2897619/using-html5-javascript-to-generate-and-save-a-file
@@ -108,44 +108,43 @@ class App extends React.Component {
Demo page for React Transcript Editor - Component |{' '}
+ href="https://github.com/bbc/react-transcript-editor"
+ rel="noopener noreferrer"
+ target="_blank"
+ >
Github Repo
-
+
open Transcript Json
this.handleChangeLoadTranscriptJson(e.target.files) }
- />
+ type="file"
+ onChange={ e => this.handleChangeLoadTranscriptJson(e.target.files) }
+ />
Load Local Media
this.handleChangeLoadMedia(e.target.files) }
- />
+ type="file"
+ onChange={ e => this.handleChangeLoadMedia(e.target.files) }
+ />
-
Text Is Editable
+ defaultChecked="true"
+ onChange={ this.handleIsTextEditable }
+ />
@@ -154,12 +153,12 @@ class App extends React.Component {
+ transcriptData={ this.state.transcriptData }
+ mediaUrl={ this.state.mediaUrl }
+ isEditable={ this.state.isTextEditable }
+ sttJsonType={ this.state.sttType }
+ ref={ 'transcriptEditor' }
+ />
);
}
diff --git a/src/lib/TranscriptEditor/MediaPlayer/PauseWhileTyping.js b/src/lib/TranscriptEditor/MediaPlayer/PauseWhileTyping.js
index 0c739ed9..b7412112 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/PauseWhileTyping.js
+++ b/src/lib/TranscriptEditor/MediaPlayer/PauseWhileTyping.js
@@ -3,24 +3,24 @@ import PropTypes from 'prop-types';
import styles from './VolumeControl.module.css';
class PauseWhileTyping extends React.Component {
- render() {
- return (
-
-
Pause While Typing
-
-
-
-
-
- );
- }
+ render() {
+ return (
+
+
Pause While Typing
+
+
+
+
+
+ );
+ }
}
PauseWhileTyping.propTypes = {
handleToggle: PropTypes.func
};
-export default PauseWhileTyping;
\ No newline at end of file
+export default PauseWhileTyping;
diff --git a/src/lib/TranscriptEditor/MediaPlayer/PlaybackRate.js b/src/lib/TranscriptEditor/MediaPlayer/PlaybackRate.js
index f2532fa2..7b70f62f 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/PlaybackRate.js
+++ b/src/lib/TranscriptEditor/MediaPlayer/PlaybackRate.js
@@ -2,32 +2,32 @@ import React from 'react';
import PropTypes from 'prop-types';
import styles from './PlaybackRate.module.css';
class PlaybackRate extends React.Component {
-
- render() {
- return (
-
-
Playback Rate
-
-
-
-
-
-
- );
- }
+
+ render() {
+ return (
+
+
Playback Rate
+
+
+
+
+
+
+ );
+ }
}
PlaybackRate.propTypes = {
- handlePlayBackRateChange: PropTypes.func,
- playBackRate: PropTypes.number,
- setPlayBackRate: PropTypes.func
- };
+ handlePlayBackRateChange: PropTypes.func,
+ playBackRate: PropTypes.number,
+ setPlayBackRate: PropTypes.func
+};
-export default PlaybackRate;
\ No newline at end of file
+export default PlaybackRate;
diff --git a/src/lib/TranscriptEditor/MediaPlayer/PlayerControls.js b/src/lib/TranscriptEditor/MediaPlayer/PlayerControls.js
index 32d399d7..92cdff1e 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/PlayerControls.js
+++ b/src/lib/TranscriptEditor/MediaPlayer/PlayerControls.js
@@ -44,7 +44,7 @@ class PlayerControls extends React.Component {
diff --git a/src/lib/TranscriptEditor/MediaPlayer/RollBack.js b/src/lib/TranscriptEditor/MediaPlayer/RollBack.js
index d22684fa..f792cd68 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/RollBack.js
+++ b/src/lib/TranscriptEditor/MediaPlayer/RollBack.js
@@ -2,34 +2,34 @@ import React from 'react';
import PropTypes from 'prop-types';
import styles from './RollBack.module.css';
class RollBack extends React.Component {
-
- render() {
- return (
-
-
Rollback
- Seconds
-
-
-
-
+ render() {
+ return (
+
+
Rollback
+ Seconds
+
-
- );
- }
+
+
+
+
+
+ );
+ }
}
RollBack.propTypes = {
- rollBackValueInSeconds: PropTypes.number,
- handleChangeReplayRollbackValue: PropTypes.func,
- rollBack: PropTypes.func
- };
+ rollBackValueInSeconds: PropTypes.number,
+ handleChangeReplayRollbackValue: PropTypes.func,
+ rollBack: PropTypes.func
+};
-export default RollBack;
\ No newline at end of file
+export default RollBack;
diff --git a/src/lib/TranscriptEditor/MediaPlayer/VolumeControl.js b/src/lib/TranscriptEditor/MediaPlayer/VolumeControl.js
index c4babbeb..1250462b 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/VolumeControl.js
+++ b/src/lib/TranscriptEditor/MediaPlayer/VolumeControl.js
@@ -3,20 +3,20 @@ import PropTypes from 'prop-types';
import styles from './VolumeControl.module.css';
class VolumeControl extends React.Component {
- render() {
- return (
-
-
-
-
-
- Volume
-
- );
- }
+ render() {
+ return (
+
+
+
+
+
+ Volume
+
+ );
+ }
}
VolumeControl.propTypes = {
diff --git a/src/lib/TranscriptEditor/MediaPlayer/defaultHotKeys.js b/src/lib/TranscriptEditor/MediaPlayer/defaultHotKeys.js
index 36cecebd..6256c112 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/defaultHotKeys.js
+++ b/src/lib/TranscriptEditor/MediaPlayer/defaultHotKeys.js
@@ -45,6 +45,6 @@ function returnHotKeys(self) {
// handler: (event) => { console.log('save');},
// helperText: 'Save'
// }
- }
+ };
}
export default returnHotKeys;
diff --git a/src/lib/TranscriptEditor/MediaPlayer/index.js b/src/lib/TranscriptEditor/MediaPlayer/index.js
index c0e4b096..61d67953 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/index.js
+++ b/src/lib/TranscriptEditor/MediaPlayer/index.js
@@ -25,9 +25,9 @@ class MediaPlayer extends React.Component {
timecodeOffset: 0,
hotKeys: returnHotKeys(this),
isPausedWhileTyping: false
- }
+ };
}
- /*eslint-disable camel case */
+ /*eslint-disable camelcase */
hot_keys = returnHotKeys(this);
componentDidMount() {
@@ -53,7 +53,7 @@ class MediaPlayer extends React.Component {
}
promptSetCurrentTime = () => {
- this.setCurrentTime( prompt('Jump to time - hh:mm:ss:ff hh:mm:ss mm:ss m:ss m.ss seconds'))
+ this.setCurrentTime( prompt('Jump to time - hh:mm:ss:ff hh:mm:ss mm:ss m:ss m.ss seconds'));
}
setTimeCodeOffset = (newTimeCodeOffSet) => {
@@ -62,7 +62,7 @@ class MediaPlayer extends React.Component {
let newCurrentTimeInSeconds = newTimeCodeOffSet;
if (newTimeCodeOffSet.includes(':')) {
newCurrentTimeInSeconds = timecodeToSeconds(newTimeCodeOffSet);
- this.setState({ timecodeOffset: newCurrentTimeInSeconds })
+ this.setState({ timecodeOffset: newCurrentTimeInSeconds });
}
}
}
@@ -79,11 +79,11 @@ class MediaPlayer extends React.Component {
handleTimeUpdate = (e) => {
// eslint-disable-next-line react/prop-types
- this.props.hookOnTimeUpdate(e.target.currentTime)
+ this.props.hookOnTimeUpdate(e.target.currentTime);
}
handlePlayBackRateChange = (e) => {
- this.setPlayBackRate(e.target.value)
+ this.setPlayBackRate(e.target.value);
}
increasePlaybackRate = () => {
@@ -116,7 +116,7 @@ class MediaPlayer extends React.Component {
playBackRate: speedValue,
}, () => {
this.videoRef.current.playbackRate = speedValue;
- })
+ });
}
}
}
@@ -125,7 +125,7 @@ class MediaPlayer extends React.Component {
if (this.videoRef.current !== null) {
this.setState({
rollBackValueInSeconds: e.target.value,
- })
+ });
}
}
@@ -141,12 +141,13 @@ class MediaPlayer extends React.Component {
}
handleTogglePauseWhileTyping = () => {
- console.log('triggered')
- console.log(this.state.isPausedWhileTyping)
+ console.log('triggered');
+ console.log(this.state.isPausedWhileTyping);
this.setState((prevState, props) => {
- console.log(prevState.isPausedWhileTyping)
- return { isPausedWhileTyping: !prevState.isPausedWhileTyping }
- })
+ console.log(prevState.isPausedWhileTyping);
+
+ return { isPausedWhileTyping: !prevState.isPausedWhileTyping };
+ });
}
isPlaying = () => {
@@ -154,6 +155,7 @@ class MediaPlayer extends React.Component {
if (this.videoRef.current.paused) {
return false;
}
+
return true;
}
}
@@ -169,23 +171,23 @@ class MediaPlayer extends React.Component {
if (this.videoRef.current !== null) {
// if playMedia is being triggered by PlayerControl or Video element
// then it will have a target attribute
- if(playPauseBool.target !== undefined){
- // checks on whether to use default fallback if no param is provided
- if (this.videoRef.current.paused) {
+ if (playPauseBool.target !== undefined){
+ // checks on whether to use default fallback if no param is provided
+ if (this.videoRef.current.paused) {
+ this.videoRef.current.play();
+ } else {
+ this.videoRef.current.pause();
+ }
+ }
+ else {
+ // if param is provided and if pausedWhileTyping Toggle is on
+ if (this.state.isPausedWhileTyping){
+ if (playPauseBool) {
this.videoRef.current.play();
} else {
this.videoRef.current.pause();
}
- }
- else{
- // if param is provided and if pausedWhileTyping Toggle is on
- if(this.state.isPausedWhileTyping){
- if (playPauseBool) {
- this.videoRef.current.play();
- } else {
- this.videoRef.current.pause();
- }
- }
+ }
}
}
}
@@ -214,33 +216,35 @@ class MediaPlayer extends React.Component {
}
getMediaCurrentTime = () => {
- if(this.videoRef.current !== null) {
- return secondsToTimecode(this.videoRef.current.currentTime + this.state.timecodeOffset)
- }
- return '00:00:00:00';
+ if (this.videoRef.current !== null) {
+ return secondsToTimecode(this.videoRef.current.currentTime + this.state.timecodeOffset);
+ }
+
+ return '00:00:00:00';
}
getMediaDuration = () => {
- if(this.videoRef.current !== null) {
+ if (this.videoRef.current !== null) {
return secondsToTimecode(this.videoRef.current.duration + this.state.timecodeOffset);
}
- return '00:00:00:00';
+
+ return '00:00:00:00';
}
render() {
const mediaPlayerEl = (
- );
+ id="video"
+ playsInline
+ src={ this.props.mediaUrl }
+ onTimeUpdate={ this.handleTimeUpdate }
+ // TODO: video type - add logic to identify if video is playable and raise error if it's not
+ type="video/mp4"
+ data-testid="media-player-id"
+ onClick={ this.playMedia.bind(this) }
+ ref={ this.videoRef }
+ />
+ );
const playerControlsSection = (
@@ -248,19 +252,19 @@ class MediaPlayer extends React.Component {
{ this.props.mediaUrl }
);
@@ -273,22 +277,22 @@ class MediaPlayer extends React.Component {
// list of keyboard shortcuts helper text
const keyboardShortcutsElements = Object.keys(this.state.hotKeys).map((shortcutKey, index) => {
- return
- {shortcutKey}
-
- {this.state.hotKeys[shortcutKey].helperText}
-
-
- })
+ {shortcutKey}
+
+ {this.state.hotKeys[shortcutKey].helperText}
+
+ ;
+ });
let keyboardShortcuts;
- if(this.props.mediaUrl !== null ){
+ if (this.props.mediaUrl !== null ){
keyboardShortcuts = {keyboardShortcutsElements}
Double click on a word to be taken to that time in the media.
-
+ ;
}
return (
@@ -307,6 +311,7 @@ class MediaPlayer extends React.Component {
MediaPlayer.propTypes = {
hookSeek: PropTypes.func,
hookPlayMedia: PropTypes.func,
+ hookIsPlaying: PropTypes. func,
mediaUrl: PropTypes.string,
hookOnTimeUpdate: PropTypes.func
};
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js b/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
index 1b6d0044..7264f7d1 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/SpeakerLabel.js
@@ -4,19 +4,19 @@ import PropTypes from 'prop-types';
import style from './WrapperBlock.module.css';
class SpeakerLabel extends PureComponent {
- render() {
- return (
-
- ✏️
-
- {this.props.name}
+ render() {
+ return (
+
+ ✏️
- )
- }
+ {this.props.name}
+
+ );
+ }
}
SpeakerLabel.propTypes = {
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.js b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.js
index 061c7123..b76f018f 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.js
@@ -25,7 +25,7 @@ class WrapperBlock extends React.Component {
this.setState({
speaker: speaker,
start: start
- })
+ });
}
handleOnClickEdit = (e) => {
@@ -43,7 +43,7 @@ class WrapperBlock extends React.Component {
+ />
{secondsToTimecode(this.state.start)}
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/adapters/autoEdit2/index.js b/src/lib/TranscriptEditor/TimedTextEditor/adapters/autoEdit2/index.js
index 493d6105..99cca7f5 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/adapters/autoEdit2/index.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/adapters/autoEdit2/index.js
@@ -62,8 +62,8 @@ const groupWordsInParagraphs = (autoEditText) => {
paragraph.words.push(tmpWord);
paragraph.text.push(word.text);
}
- })
- })
+ });
+ });
});
return results;
@@ -88,6 +88,7 @@ const autoEdit2ToDraft = (autoEdit2Json) => {
// console.log(JSON.stringify(draftJsContentBlockParagraph,null,2))
results.push(draftJsContentBlockParagraph);
});
+
// console.log(JSON.stringify(results,null,2))
return results;
};
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/adapters/autoEdit2/index.test.js b/src/lib/TranscriptEditor/TimedTextEditor/adapters/autoEdit2/index.test.js
index dabfed23..f39f4c3a 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/adapters/autoEdit2/index.test.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/adapters/autoEdit2/index.test.js
@@ -7,9 +7,9 @@ describe('bbcKaldiToDraft', () => {
const result = autoEdit2ToDraft(autoEdit2TedTalkTranscript, 'text');
it('Should be defined', ( ) => {
expect(result).toBeDefined();
- })
+ });
it('Should be equal to expected value', ( ) => {
expect(result).toEqual(draftTranscriptExample);
- })
-})
+ });
+});
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/adapters/bbc-kaldi/index.test.js b/src/lib/TranscriptEditor/TimedTextEditor/adapters/bbc-kaldi/index.test.js
index 5dd26668..a1fd8546 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/adapters/bbc-kaldi/index.test.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/adapters/bbc-kaldi/index.test.js
@@ -7,9 +7,9 @@ describe('bbcKaldiToDraft', () => {
const result = bbcKaldiToDraft(kaldiTedTalkTranscript);
it('Should be defined', ( ) => {
expect(result).toBeDefined();
- })
+ });
it('Should be equal to expected value', ( ) => {
expect(result).toEqual(draftTranscriptExample);
- })
-})
+ });
+});
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/adapters/generate-entities-ranges/index.js b/src/lib/TranscriptEditor/TimedTextEditor/adapters/generate-entities-ranges/index.js
index dff0d5c6..4c2e0088 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/adapters/generate-entities-ranges/index.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/adapters/generate-entities-ranges/index.js
@@ -12,6 +12,7 @@
*/
const generateEntitiesRanges = (words, wordAttributeName) => {
let position = 0;
+
return words.map((word) => {
const result = {
start: word.start,
@@ -23,12 +24,12 @@ const generateEntitiesRanges = (words, wordAttributeName) => {
key: Math.random()
.toString(36)
.substring(6),
- }
+ };
// increase position counter - to determine word offset in paragraph
position = position + word[wordAttributeName].length + 1;
return result;
- })
-}
+ });
+};
export default generateEntitiesRanges;
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/adapters/generate-entities-ranges/index.test.js b/src/lib/TranscriptEditor/TimedTextEditor/adapters/generate-entities-ranges/index.test.js
index 774c191a..82f7e2e9 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/adapters/generate-entities-ranges/index.test.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/adapters/generate-entities-ranges/index.test.js
@@ -82,22 +82,22 @@ describe('Generate Entity Ranges', () => {
const resultFirstElement = result[0];
it('Should be defined', ( ) => {
expect(result).toBeDefined();
- })
+ });
it('Should return a list of entities', ( ) => {
expect(result).toEqual(expectedValue);
- })
+ });
it('Should have expected attributes', ( ) => {
- expect(resultFirstElement).toHaveProperty('start')
- expect(resultFirstElement).toHaveProperty('end')
- expect(resultFirstElement).toHaveProperty('confidence')
- expect(resultFirstElement).toHaveProperty('text')
- expect(resultFirstElement).toHaveProperty('offset')
- expect(resultFirstElement).toHaveProperty('length')
- expect(resultFirstElement).toHaveProperty('key')
- })
+ expect(resultFirstElement).toHaveProperty('start');
+ expect(resultFirstElement).toHaveProperty('end');
+ expect(resultFirstElement).toHaveProperty('confidence');
+ expect(resultFirstElement).toHaveProperty('text');
+ expect(resultFirstElement).toHaveProperty('offset');
+ expect(resultFirstElement).toHaveProperty('length');
+ expect(resultFirstElement).toHaveProperty('key');
+ });
it('Should return a list of entities', ( ) => {
expect(typeof resultFirstElement.key).toBe('string');
- })
-})
+ });
+});
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/adapters/index.js b/src/lib/TranscriptEditor/TimedTextEditor/adapters/index.js
index 10f26235..9ed5e5d6 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/adapters/index.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/adapters/index.js
@@ -6,7 +6,7 @@ import autoEdit2ToDraft from './autoEdit2/index';
* @param {string} sttJsonType - the type of transcript supported by the available adapters
*/
- // converts nested arrays into one dimensional array
+// converts nested arrays into one dimensional array
const flatten = list => list.reduce((a, b) => a.concat(Array.isArray(b) ? flatten(b) : b), []);
const createEntityMap = (blocks) => {
@@ -21,26 +21,29 @@ const createEntityMap = (blocks) => {
type: 'WORD',
mutability: 'MUTABLE',
data,
- }
+ };
});
+
return entityMap;
-}
+};
const sttJsonAdapter = (transcriptData, sttJsonType) => {
let blocks;
switch (sttJsonType) {
- case 'bbckaldi':
- blocks = bbcKaldiToDraft(transcriptData);
- return { blocks, entityMap: createEntityMap(blocks) };
- case 'autoedit2':
- blocks = autoEdit2ToDraft(transcriptData);
- return { blocks, entityMap: createEntityMap(blocks) };
- case 'draftjs':
- return transcriptData; // (typeof transcriptData === 'string')? JSON.parse(transcriptData): transcriptData;
- default:
- // code block
- console.error('not recognised the stt enginge');
+ case 'bbckaldi':
+ blocks = bbcKaldiToDraft(transcriptData);
+
+ return { blocks, entityMap: createEntityMap(blocks) };
+ case 'autoedit2':
+ blocks = autoEdit2ToDraft(transcriptData);
+
+ return { blocks, entityMap: createEntityMap(blocks) };
+ case 'draftjs':
+ return transcriptData; // (typeof transcriptData === 'string')? JSON.parse(transcriptData): transcriptData;
+ default:
+ // code block
+ console.error('not recognised the stt enginge');
}
-}
+};
export default sttJsonAdapter;
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/index.js b/src/lib/TranscriptEditor/TimedTextEditor/index.js
index 6dd5f543..92189a10 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/index.js
+++ b/src/lib/TranscriptEditor/TimedTextEditor/index.js
@@ -38,8 +38,9 @@ class TimedTextEditor extends React.Component {
return {
transcriptData: nextProps.transcriptData,
isEditable: nextProps.isEditable,
- }
+ };
}
+
return null;
}
@@ -55,8 +56,8 @@ class TimedTextEditor extends React.Component {
// doing editorStateChangeType === 'insert-characters' is triggered even
// outside of draftJS eg when clicking play button so using this instead
// see issue https://github.com/facebook/draft-js/issues/1060
- if(this.state.editorState.getCurrentContent() !== editorState.getCurrentContent()){
- if(this.props.isPlaying()){
+ if (this.state.editorState.getCurrentContent() !== editorState.getCurrentContent()){
+ if (this.props.isPlaying()){
this.props.playMedia(false);
// Pause video for X seconds
const pauseWhileTypingIntervalInMilliseconds = 3000;
@@ -89,7 +90,7 @@ class TimedTextEditor extends React.Component {
loadData() {
if (this.props.transcriptData !== null) {
const blocks = sttJsonAdapter(this.props.transcriptData, this.props.sttJsonType);
- this.setEditorContentState(blocks)
+ this.setEditorContentState(blocks);
}
}
@@ -118,6 +119,7 @@ class TimedTextEditor extends React.Component {
localStorage.setItem(`draftJs-${ mediaUrl }`, JSON.stringify(data));
const newLastLocalSavedDate = new Date().toString();
localStorage.setItem(`timestamp-${ mediaUrl }`, newLastLocalSavedDate);
+
return newLastLocalSavedDate;
}
@@ -127,6 +129,7 @@ class TimedTextEditor extends React.Component {
if (data !== null) {
return true;
}
+
return false;
}
@@ -134,10 +137,12 @@ class TimedTextEditor extends React.Component {
const data = JSON.parse(localStorage.getItem(`draftJs-${ mediaUrl }`));
if (data !== null) {
const lastLocalSavedDate = localStorage.getItem(`timestamp-${ mediaUrl }`);
- this.setEditorContentState(data)
+ this.setEditorContentState(data);
+
return lastLocalSavedDate;
}
- return ''
+
+ return '';
}
// set DraftJS Editor content state from blocks
@@ -164,6 +169,7 @@ class TimedTextEditor extends React.Component {
renderBlockWithTimecodes = (contentBlock) => {
const type = contentBlock.getType();
+
return {
component: WrapperBlock,
editable: true,
@@ -193,19 +199,20 @@ class TimedTextEditor extends React.Component {
};
if (this.state.transcriptData) {
- const contentState = this.state.editorState.getCurrentContent()
+ const contentState = this.state.editorState.getCurrentContent();
const contentStateConvertEdToRaw = convertToRaw(contentState);
const entityMap = contentStateConvertEdToRaw.entityMap;
for (var entityKey in entityMap){
const entity = entityMap[entityKey];
const word = entity.data;
- if(word.start <= this.props.currentTime && word.end >= this.props.currentTime){
+ if (word.start <= this.props.currentTime && word.end >= this.props.currentTime){
currentWord.start = word.start;
currentWord.end = word.end;
}
}
}
+
return currentWord;
}
@@ -256,6 +263,7 @@ const getEntityStrategy = mutability => (contentBlock, callback, contentState) =
if (entityKey === null) {
return false;
}
+
return contentState.getEntity(entityKey).getMutability() === mutability;
}, callback);
};
diff --git a/src/lib/TranscriptEditor/index.js b/src/lib/TranscriptEditor/index.js
index ff8c46e9..b01d8990 100644
--- a/src/lib/TranscriptEditor/index.js
+++ b/src/lib/TranscriptEditor/index.js
@@ -14,7 +14,7 @@ class TranscriptEditor extends React.Component {
currentTime: 0,
lastLocalSavedTime: '',
transcriptData: null,
- }
+ };
}
static getDerivedStateFromProps(nextProps, prevState) {
@@ -23,6 +23,7 @@ class TranscriptEditor extends React.Component {
transcriptData: nextProps.transcriptData,
};
}
+
return null;
}
@@ -47,15 +48,15 @@ class TranscriptEditor extends React.Component {
handleTimeUpdate = (currentTime) => {
this.setState({
currentTime,
- })
+ });
}
handlePlayMedia = (bool) => {
- this.playMedia(bool)
+ this.playMedia(bool);
}
handleIsPlaying = () => {
- return this.isPlaying()
+ return this.isPlaying();
}
getEditorContent = sttType => this.refs.timedTextEditor.getEditorContent(sttType)
@@ -64,26 +65,26 @@ class TranscriptEditor extends React.Component {
this.setCurrentTime = foo }
- hookPlayMedia={ foo => this.playMedia = foo }
- hookIsPlaying={ foo => this.isPlaying = foo }
- hookOnTimeUpdate={ this.handleTimeUpdate }
- mediaUrl={ this.props.mediaUrl }
- />
+ // eslint-disable-next-line no-return-assign
+ hookSeek={ foo => this.setCurrentTime = foo }
+ hookPlayMedia={ foo => this.playMedia = foo }
+ hookIsPlaying={ foo => this.isPlaying = foo }
+ hookOnTimeUpdate={ this.handleTimeUpdate }
+ mediaUrl={ this.props.mediaUrl }
+ />
+ transcriptData={ this.state.transcriptData }
+ onWordClick={ this.handleWordClick }
+ playMedia={ this.handlePlayMedia }
+ isPlaying={ this.handleIsPlaying }
+ currentTime={ this.state.currentTime }
+ isEditable={ this.props.isEditable }
+ sttJsonType={ this.props.sttJsonType }
+ ref={ 'timedTextEditor' }
+ mediaUrl={ this.props.mediaUrl }
+ />
);
diff --git a/src/lib/Util/timecode-converter/index.js b/src/lib/Util/timecode-converter/index.js
index b780590c..b321a68b 100644
--- a/src/lib/Util/timecode-converter/index.js
+++ b/src/lib/Util/timecode-converter/index.js
@@ -20,10 +20,12 @@ const timecodeToSeconds = (time) => {
if (typeof time === 'string') {
const resultPadded = padTimeToTimecode(time);
const resultConverted = timecodeToSecondsHelper(resultPadded);
+
return resultConverted;
}
+
// assuming it receive timecode as seconds as string '600'
return parseFloat(time);
-}
+};
-export { secondsToTimecode, timecodeToSeconds }
+export { secondsToTimecode, timecodeToSeconds };
diff --git a/src/lib/Util/timecode-converter/index.test.js b/src/lib/Util/timecode-converter/index.test.js
index 7f109725..f064346f 100644
--- a/src/lib/Util/timecode-converter/index.test.js
+++ b/src/lib/Util/timecode-converter/index.test.js
@@ -5,77 +5,77 @@ describe('Timecode conversion TC- convertToSeconds', () => {
const demoTcValue = '00:10:00:00';
const result = timecodeToSeconds(demoTcValue);
expect(result).toBeDefined();
- })
+ });
it('Should be able to convert: hh:mm:ss:ms ', ( ) => {
const demoTcValue = '00:10:00:00';
const demoExpectedResultInSeconds = 600;
const result = timecodeToSeconds(demoTcValue);
expect(result).toEqual(demoExpectedResultInSeconds);
- })
+ });
it('Should be able to conver: mm:ss ', ( ) => {
const demoTcValue = '10:00';
const demoExpectedResultInSeconds = 600;
const result = timecodeToSeconds(demoTcValue);
expect(result).toEqual(demoExpectedResultInSeconds);
- })
+ });
it('Should be able to convert: m:ss ', ( ) => {
const demoTcValue = '09:00';
const demoExpectedResultInSeconds = 540;
const result = timecodeToSeconds(demoTcValue);
expect(result).toEqual(demoExpectedResultInSeconds);
- })
+ });
it('Should be able to convert: m.ss ', ( ) => {
const demoTcValue = '9.01';
const demoExpectedResultInSeconds = 541;
const result = timecodeToSeconds(demoTcValue);
expect(result).toEqual(demoExpectedResultInSeconds);
- })
+ });
it('Should be able to convert: ss - seconds ', ( ) => {
const demoTcValue = 600;
const demoExpectedResultInSeconds = 600;
const result = timecodeToSeconds(demoTcValue);
expect(result).toEqual(demoExpectedResultInSeconds);
- })
+ });
xit('Should be able to convert: ss - seconds - eve if it is string ', ( ) => {
const demoTcValue = '600';
const demoExpectedResultInSeconds = 600;
const result = timecodeToSeconds(demoTcValue);
expect(result).toEqual(demoExpectedResultInSeconds);
- })
+ });
it('Should be able to convert: hh:mm:ss ', ( ) => {
const demoTcValue = '00:10:00';
const demoExpectedResultInSeconds = 600;
const result = timecodeToSeconds(demoTcValue);
expect(result).toEqual(demoExpectedResultInSeconds);
- })
+ });
xit(' "sss" seconds number as string --> ss', ( ) => {
const demoTime = '56';
const expectedTimecode = '56';
const result = timecodeToSeconds(demoTime);
expect(result).toEqual(expectedTimecode);
- })
+ });
xit(' "sss" seconds number as string --> ss', ( ) => {
const demoTime = '116';
const expectedTimecode = '116';
const result = timecodeToSeconds(demoTime);
expect(result).toEqual(expectedTimecode);
- })
+ });
it('120 sec --> 120', ( ) => {
const demoTime = 120;
const expectedTimecode = 120;
const result = timecodeToSeconds(demoTime);
expect(result).toEqual(expectedTimecode);
- })
+ });
// xit('Should be able to convert: hh:mm:ss,ms ', ( )=> {
// const demoTcValue = '00:10:00,00';
@@ -97,7 +97,7 @@ describe('Timecode conversion TC- convertToSeconds', () => {
// const result = convertToSeconds(demoTcValue);
// expect(result).toEqual(demoExpectedResultInSeconds);
// })
-})
+});
describe('Timecode conversion seconds to - convertToTimecode ', () => {
it('Should be able to seconds to timecode hh:mm:ss:ms ', ( ) => {
@@ -105,12 +105,12 @@ describe('Timecode conversion seconds to - convertToTimecode ', () => {
const demoExpectedResultInTc = '00:10:00:00';
const result = secondsToTimecode(demoSeconds);
expect(result).toEqual(demoExpectedResultInTc);
- })
+ });
it('Should be able to seconds - string to timecode hh:mm:ss:ms ', ( ) => {
const demoSeconds = '600';
const demoExpectedResultInTc = '00:10:00:00';
const result = secondsToTimecode(demoSeconds);
expect(result).toEqual(demoExpectedResultInTc);
- })
-})
+ });
+});
diff --git a/src/lib/Util/timecode-converter/padTimeToTimecode.js b/src/lib/Util/timecode-converter/padTimeToTimecode.js
index 966bb689..5921bdc8 100644
--- a/src/lib/Util/timecode-converter/padTimeToTimecode.js
+++ b/src/lib/Util/timecode-converter/padTimeToTimecode.js
@@ -1,50 +1,50 @@
-const countColon = timecode => timecode.split(':').length
+const countColon = timecode => timecode.split(':').length;
-const includesFullStop = timecode => timecode.includes('.')
+const includesFullStop = timecode => timecode.includes('.');
-const isOneDigit = str => str.length === 1
+const isOneDigit = str => str.length === 1;
const padTimeToTimecode = (time) => {
if (typeof time === 'string') {
switch (countColon(time)) {
- case 4:
- // is already in timecode format
- // hh:mm:ss:ff
- return time;
- case 2:
- // m:ss
- if (isOneDigit(time.split(':')[0])) {
- return `00:0${ time }:00`;
- }
- // mm:ss
- return `00:${ time }:00`;
- case 3:
- // hh:mm:ss
- return `${ time }:00`;
- default:
- // mm.ss
- if (includesFullStop(time)) {
- // m.ss
- if (isOneDigit(time.split('.')[0])) {
- return `00:0${ time.split('.')[0] }:${ time.split('.')[1] }:00`;
- }
- // mm.ss
- return `00:${ time.replace('.', ':') }:00`;
- }
+ case 4:
+ // is already in timecode format
+ // hh:mm:ss:ff
+ return time;
+ case 2:
+ // m:ss
+ if (isOneDigit(time.split(':')[0])) {
+ return `00:0${ time }:00`;
+ }
- // if just int, then it's seconds
- // s
- if (isOneDigit(time)) {
- return `00:00:0${ time }:00`;
+ return `00:${ time }:00`;
+ case 3:
+ // hh:mm:ss
+ return `${ time }:00`;
+ default:
+ // mm.ss
+ if (includesFullStop(time)) {
+ // m.ss
+ if (isOneDigit(time.split('.')[0])) {
+ return `00:0${ time.split('.')[0] }:${ time.split('.')[1] }:00`;
}
- // ss
- return `00:00:${ time }:00`;
+
+ return `00:${ time.replace('.', ':') }:00`;
+ }
+
+ // if just int, then it's seconds
+ // s
+ if (isOneDigit(time)) {
+ return `00:00:0${ time }:00`;
+ }
+
+ return `00:00:${ time }:00`;
}
// edge case if it's number return a number coz cannot refactor
// TODO: might need to refactor and move this elsewhere
} else {
return time;
}
-}
+};
export default padTimeToTimecode;
diff --git a/src/lib/Util/timecode-converter/padTimeToTimecode.test.js b/src/lib/Util/timecode-converter/padTimeToTimecode.test.js
index 0c23411a..a4b9ff49 100644
--- a/src/lib/Util/timecode-converter/padTimeToTimecode.test.js
+++ b/src/lib/Util/timecode-converter/padTimeToTimecode.test.js
@@ -5,39 +5,39 @@ describe('Timecode conversion TC- convertToSeconds', () => {
const demoTimecode = '12:34:56:78';
const result = padTimeToTimecode(demoTimecode);
expect(result).toBeDefined();
- })
+ });
it('hh:mm:ss:ff --> hh:mm:ss:ff ', ( ) => {
const demoTimecode = '12:34:56:78';
const result = padTimeToTimecode(demoTimecode);
expect(result).toEqual(demoTimecode);
- })
+ });
it('mm:ss --> convert to hh:mm:ss:ms', ( ) => {
const demoTime = '34:56';
const expectedTimecode = '00:34:56:00';
const result = padTimeToTimecode(demoTime);
expect(result).toEqual(expectedTimecode);
- })
+ });
xit('hh:mm:ss --> convert to hh:mm:ss:ms', ( ) => {
const demoTime = '34:56:78';
const expectedTimecode = '00:34:56:78';
const result = padTimeToTimecode(demoTime);
expect(result).toEqual(expectedTimecode);
- })
+ });
it('mm.ss--> convert to hh:mm:ss:ms', ( ) => {
const demoTime = '34.56';
const expectedTimecode = '00:34:56:00';
const result = padTimeToTimecode(demoTime);
expect(result).toEqual(expectedTimecode);
- })
+ });
it('120 sec --> 120', ( ) => {
const demoTime = 120;
const expectedTimecode = 120;
const result = padTimeToTimecode(demoTime);
expect(result).toEqual(expectedTimecode);
- })
-})
+ });
+});
diff --git a/src/lib/Util/timecode-converter/secondsToTimecode.js b/src/lib/Util/timecode-converter/secondsToTimecode.js
index e4ffb322..f5a68bdb 100644
--- a/src/lib/Util/timecode-converter/secondsToTimecode.js
+++ b/src/lib/Util/timecode-converter/secondsToTimecode.js
@@ -15,8 +15,8 @@
* @param {*} fps
*/
const normalisePlayerTime = function (seconds, fps) {
- return Number((1.0 / fps * Math.floor(Number((fps * seconds).toPrecision(12)))).toFixed(2))
-}
+ return Number((1.0 / fps * Math.floor(Number((fps * seconds).toPrecision(12)))).toFixed(2));
+};
/*
* @param {*} seconds
@@ -31,13 +31,14 @@ const secondsToTimecode = function (seconds, framePerSeconds) {
const normalisedSeconds = normalisePlayerTime(seconds, fps);
- const wholeSeconds = Math.floor(normalisedSeconds)
- const frames = ((normalisedSeconds - wholeSeconds) * fps).toFixed(2)
+ const wholeSeconds = Math.floor(normalisedSeconds);
+ const frames = ((normalisedSeconds - wholeSeconds) * fps).toFixed(2);
// prepends zero - example pads 3 to 03
function _padZero(n) {
- if (n < 10) return `0${ parseInt(n) }`
- return parseInt(n)
+ if (n < 10) return `0${ parseInt(n) }`;
+
+ return parseInt(n);
}
return `${ _padZero((wholeSeconds / 60 / 60) % 60)
@@ -46,7 +47,7 @@ const secondsToTimecode = function (seconds, framePerSeconds) {
}:${
_padZero(wholeSeconds % 60)
}:${
- _padZero(frames) }`
-}
+ _padZero(frames) }`;
+};
export default secondsToTimecode;
diff --git a/src/lib/Util/timecode-converter/secondsToTimecode.test.js b/src/lib/Util/timecode-converter/secondsToTimecode.test.js
index 1ec80772..ab6dfb5c 100644
--- a/src/lib/Util/timecode-converter/secondsToTimecode.test.js
+++ b/src/lib/Util/timecode-converter/secondsToTimecode.test.js
@@ -6,12 +6,12 @@ describe('Timecode conversion TC- convertToSeconds', () => {
// const demoExpectedTc = '00:10:00:00';
const result = secondsToTimecode(dmoSecondsValue);
expect(result).toBeDefined();
- })
+ });
it('Should be able to convert to: hh:mm:ss:ff ', ( ) => {
const dmoSecondsValue = 600;
const demoExpectedTc = '00:10:00:00';
const result = secondsToTimecode(dmoSecondsValue);
expect(result).toEqual(demoExpectedTc);
- })
-})
+ });
+});
diff --git a/src/lib/Util/timecode-converter/timecodeToSeconds.js b/src/lib/Util/timecode-converter/timecodeToSeconds.js
index 8e59e9c1..27069972 100644
--- a/src/lib/Util/timecode-converter/timecodeToSeconds.js
+++ b/src/lib/Util/timecode-converter/timecodeToSeconds.js
@@ -6,13 +6,14 @@
const timecodeToFrames = function (tc, fps) {
// TODO make 29.97 fps drop-frame aware - works for 25 only.
- const s = tc.split(':')
- let frames = parseInt(s[3])
- frames += parseInt(s[2]) * fps
- frames += parseInt(s[1]) * (fps * 60)
- frames += parseInt(s[0]) * (fps * 60 * 60)
- return frames
-}
+ const s = tc.split(':');
+ let frames = parseInt(s[3]);
+ frames += parseInt(s[2]) * fps;
+ frames += parseInt(s[1]) * (fps * 60);
+ frames += parseInt(s[0]) * (fps * 60 * 60);
+
+ return frames;
+};
/**
* Convert broadcast timecodes to seconds
@@ -24,8 +25,9 @@ const timecodeToSecondsHelper = function (tc, framePerSeconds) {
if (framePerSeconds !== undefined) {
fps = framePerSeconds;
}
- const frames = timecodeToFrames(tc, fps)
- return Number(Number(frames / fps).toFixed(2))
-}
+ const frames = timecodeToFrames(tc, fps);
+
+ return Number(Number(frames / fps).toFixed(2));
+};
export default timecodeToSecondsHelper;
diff --git a/src/lib/Util/timecode-converter/timecodeToSeconds.test.js b/src/lib/Util/timecode-converter/timecodeToSeconds.test.js
index 19765c6d..842ddcba 100644
--- a/src/lib/Util/timecode-converter/timecodeToSeconds.test.js
+++ b/src/lib/Util/timecode-converter/timecodeToSeconds.test.js
@@ -5,12 +5,12 @@ describe('Timecode conversion TC- convertToSeconds', () => {
const demoTcValue = '00:10:00:00';
const result = timecodeToSecondsHelper(demoTcValue);
expect(result).toBeDefined();
- })
+ });
it('Should be able to convert from: hh:mm:ss:ff ', ( ) => {
const demoTcValue = '00:10:00:00';
const demoExpectedResultInSeconds = 600;
const result = timecodeToSecondsHelper(demoTcValue);
expect(result).toEqual(demoExpectedResultInSeconds);
- })
-})
+ });
+});
diff --git a/src/select-stt-json-type.js b/src/select-stt-json-type.js
index 4dfc583d..9b61bc2d 100644
--- a/src/select-stt-json-type.js
+++ b/src/select-stt-json-type.js
@@ -15,7 +15,7 @@ const SttTypeSelect = props => (
)
+);
SttTypeSelect.propTypes = {
name: PropTypes.string,
From 1ab2071f503cb9aec811646751ac95b5d6478c3f Mon Sep 17 00:00:00 2001
From: James Dooley
Date: Fri, 14 Dec 2018 12:43:06 +0000
Subject: [PATCH 14/15] Fix: Stopped scrolling within paragraph blocks
---
.../TimedTextEditor/WrapperBlock.module.css | 17 +++++++++--------
src/lib/TranscriptEditor/index.module.css | 1 +
2 files changed, 10 insertions(+), 8 deletions(-)
diff --git a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
index ed51e068..06ef0be3 100644
--- a/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
+++ b/src/lib/TranscriptEditor/TimedTextEditor/WrapperBlock.module.css
@@ -1,10 +1,11 @@
@value color-labs-red, color-light-grey, color-mid-grey, color-dark-grey from '../colours.module.css';
.WrapperBlock {
+ height: 100%;
width: 100%;
margin-bottom: 2em;
- overflow: auto;
- line-height: 1em;
+ line-height: 1.2em;
+ overflow: hidden;
}
.markers {
@@ -18,27 +19,27 @@
font-size: 1em;
float: right;
clear: right;
- line-height: 1.2em;
}
.speaker {
display: inline-block;
+ width: 55%;
+ padding-right: 2em;
+ vertical-align: middle;
+ color: color-mid-grey;
font-weight: bold;
text-transform: uppercase;
text-align: right;
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
- padding-right: 2em;
- width: 55%;
- color: color-mid-grey;
- vertical-align: middle;
}
.time {
display: inline-block;
- font-weight: lighter;
width: 30%;
+ font-weight: lighter;
+ vertical-align: middle;
}
.EditLabel {
diff --git a/src/lib/TranscriptEditor/index.module.css b/src/lib/TranscriptEditor/index.module.css
index 84a445cf..1c11a960 100644
--- a/src/lib/TranscriptEditor/index.module.css
+++ b/src/lib/TranscriptEditor/index.module.css
@@ -28,6 +28,7 @@
@media (max-width: 768px) {
.container {
flex-wrap: wrap;
+ position: relative;
}
.main {
width: 100%;
From f24f8f7acc4a8783bfff71c23507d3a90234ec38 Mon Sep 17 00:00:00 2001
From: James Dooley
Date: Fri, 14 Dec 2018 13:02:38 +0000
Subject: [PATCH 15/15] Fix: Removed position:fixed on media player, parent div
to 100%
---
package.json | 1 -
src/lib/TranscriptEditor/MediaPlayer/index.module.css | 7 ++++---
src/lib/TranscriptEditor/index.module.css | 2 --
3 files changed, 4 insertions(+), 6 deletions(-)
diff --git a/package.json b/package.json
index 8acf80de..b87a74a1 100644
--- a/package.json
+++ b/package.json
@@ -76,7 +76,6 @@
"babel-polyfill": "^6.26.0",
"draft-js": "^0.10.5",
"mousetrap": "1.5.2",
- "node-sass": "^4.10.0",
"prop-types": "^15.6.2",
"react": "^16.6.0",
"react-dom": "^16.6.0",
diff --git a/src/lib/TranscriptEditor/MediaPlayer/index.module.css b/src/lib/TranscriptEditor/MediaPlayer/index.module.css
index 35aa3a6b..0ae135a7 100644
--- a/src/lib/TranscriptEditor/MediaPlayer/index.module.css
+++ b/src/lib/TranscriptEditor/MediaPlayer/index.module.css
@@ -3,14 +3,15 @@
.topSection {
/* height: 100%; */
background: black;
- position: fixed;
- top: 0;
- left: 0;
+ /* position: fixed; */
+ /* top: 0; */
+ /* left: 0; */
}
.playerSection {
display: inline-flex;
align-items: flex-start;
+ width: 100%;
}
video {
diff --git a/src/lib/TranscriptEditor/index.module.css b/src/lib/TranscriptEditor/index.module.css
index 1c11a960..56764336 100644
--- a/src/lib/TranscriptEditor/index.module.css
+++ b/src/lib/TranscriptEditor/index.module.css
@@ -19,8 +19,6 @@
.aside {
width: 100%;
- /* padding: 20px; */
- /* background-color: #936; */
}
}