@desynova-digital/player 3.9.7 → 4.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (130) hide show
  1. package/Player.js +945 -0
  2. package/control/AudioTracksMenuButton.js +91 -0
  3. package/control/AudioTracksMenuButton.jsx +80 -0
  4. package/control/ControlBar.js +303 -0
  5. package/control/ControlBar.jsx +264 -0
  6. package/control/CurrentTimeDisplay.js +34 -0
  7. package/control/CurrentTimeDisplay.jsx +35 -0
  8. package/control/DurationDisplay.js +38 -0
  9. package/control/DurationDisplay.jsx +48 -0
  10. package/control/ForwardBackwardControl.js +76 -0
  11. package/control/ForwardBackwardControl.jsx +79 -0
  12. package/control/FullscreenToggle.js +82 -0
  13. package/control/FullscreenToggle.jsx +83 -0
  14. package/control/MarkInControl.js +124 -0
  15. package/control/MarkInControl.jsx +109 -0
  16. package/control/MarkOutControl.js +137 -0
  17. package/control/MarkOutControl.jsx +131 -0
  18. package/control/MarkerBar.js +127 -0
  19. package/control/MarkerBar.jsx +107 -0
  20. package/control/MarkingControl.js +82 -0
  21. package/control/MarkingControl.jsx +143 -0
  22. package/control/MarkingDuration.js +44 -0
  23. package/control/MarkingPreview.js +49 -0
  24. package/control/MarkingPreview.jsx +60 -0
  25. package/control/PlayBackRateControl.js +106 -0
  26. package/control/PlayBackRateControl.jsx +106 -0
  27. package/control/PlayProgressBar.js +61 -0
  28. package/control/PlayProgressBar.jsx +92 -0
  29. package/control/PlayToggle.js +56 -0
  30. package/control/PlayToggle.jsx +57 -0
  31. package/control/PointersBar.js +231 -0
  32. package/control/PointersBar.jsx +286 -0
  33. package/control/ProgressControl.js +127 -0
  34. package/control/ProgressControl.jsx +155 -0
  35. package/control/SeekBar.js +204 -0
  36. package/control/SeekBar.jsx +229 -0
  37. package/control/SettingsMenuButton.js +63 -0
  38. package/control/SettingsMenuButton.jsx +69 -0
  39. package/control/Slider.js +274 -0
  40. package/control/Slider.jsx +243 -0
  41. package/control/Timeline.js +118 -0
  42. package/control/Timeline.jsx +131 -0
  43. package/control/VolumeBar.js +198 -0
  44. package/control/VolumeBar.jsx +174 -0
  45. package/control/VolumeLevel.js +61 -0
  46. package/control/VolumeLevel.jsx +66 -0
  47. package/control/VolumneMenuButton.js +112 -0
  48. package/control/VolumneMenuButton.jsx +111 -0
  49. package/header/Header.js +309 -0
  50. package/header/Header.jsx +479 -0
  51. package/index.js +9 -151
  52. package/media/AudioMeter.js +381 -0
  53. package/media/AudioMeter.jsx +411 -0
  54. package/media/SDOutline.js +82 -0
  55. package/media/SDOutline.jsx +90 -0
  56. package/media/Video.js +684 -0
  57. package/media/Video.jsx +714 -0
  58. package/package.json +5 -1
  59. package/playlist/Playlist.js +67 -0
  60. package/playlist/Playlist.jsx +91 -0
  61. package/playlist/index.js +13 -0
  62. package/shortcuts/Shortcut.js +662 -0
  63. package/utils/Menu.js +50 -0
  64. package/utils/Menu.jsx +105 -0
  65. package/{colors.js → utils/colors.js} +13 -13
  66. package/utils/dom.js +6 -16
  67. package/utils/index.js +52 -122
  68. package/Manager.js +0 -124
  69. package/actions/player.js +0 -375
  70. package/actions/video.js +0 -230
  71. package/components/AudioMeter.js +0 -414
  72. package/components/BigPlayButton.js +0 -110
  73. package/components/ImageViewer.js +0 -318
  74. package/components/MarkerBar.js +0 -138
  75. package/components/Menu.js +0 -77
  76. package/components/Player.js +0 -821
  77. package/components/PlayerHeader.js +0 -472
  78. package/components/Playlist.js +0 -133
  79. package/components/PointersBar.js +0 -299
  80. package/components/PosterImage.js +0 -61
  81. package/components/SDOutline.js +0 -68
  82. package/components/Shortcut.js +0 -621
  83. package/components/Slider.js +0 -317
  84. package/components/TagsBar.js +0 -100
  85. package/components/Video.js +0 -1431
  86. package/components/control-bar/AudioTracksMenuButton.js +0 -113
  87. package/components/control-bar/CameraButton.js +0 -88
  88. package/components/control-bar/CommentsButton.js +0 -216
  89. package/components/control-bar/ControlBar.js +0 -260
  90. package/components/control-bar/EditorControlMenuButton.js +0 -412
  91. package/components/control-bar/ForwardControl.js +0 -17
  92. package/components/control-bar/ForwardReplayControl.js +0 -122
  93. package/components/control-bar/FullscreenToggle.js +0 -101
  94. package/components/control-bar/PlayToggle.js +0 -98
  95. package/components/control-bar/ReplayControl.js +0 -17
  96. package/components/control-bar/SettingsMenuButton.js +0 -43
  97. package/components/control-bar/SubtitleLanguagesMenuButton.js +0 -174
  98. package/components/control-bar/VolumeMenuButton.js +0 -134
  99. package/components/control-bar/ZoomMenuButton.js +0 -116
  100. package/components/marking-controls/MarkInControl.js +0 -140
  101. package/components/marking-controls/MarkOutControl.js +0 -155
  102. package/components/marking-controls/MarkingAddButton.js +0 -94
  103. package/components/marking-controls/MarkingControl.js +0 -135
  104. package/components/marking-controls/MarkingDeleteButton.js +0 -84
  105. package/components/marking-controls/MarkingDuration.js +0 -77
  106. package/components/marking-controls/MarkingPreview.js +0 -86
  107. package/components/progress-bar/AudioWaveform.js +0 -144
  108. package/components/progress-bar/LoadProgressBar.js +0 -90
  109. package/components/progress-bar/MouseTimeDisplay.js +0 -53
  110. package/components/progress-bar/PlayProgressBar.js +0 -79
  111. package/components/progress-bar/ProgressControl.js +0 -222
  112. package/components/progress-bar/SeekBar.js +0 -261
  113. package/components/progress-bar/Timeline.js +0 -134
  114. package/components/settings-menu-control/PlaybackRateControl.js +0 -147
  115. package/components/settings-menu-control/SafeAreaControl.js +0 -92
  116. package/components/settings-menu-control/SettingsMenu.js +0 -68
  117. package/components/settings-menu-control/SubtitleControl.js +0 -1
  118. package/components/time-controls/CurrentTimeDisplay.js +0 -53
  119. package/components/time-controls/DurationDisplay.js +0 -51
  120. package/components/time-controls/TimeDivider.js +0 -41
  121. package/components/volume-control/VolumeBar.js +0 -216
  122. package/components/volume-control/VolumeControl.js +0 -35
  123. package/components/volume-control/VolumeLevel.js +0 -78
  124. package/components/zoom-control/ZoomBar.js +0 -189
  125. package/components/zoom-control/ZoomLevel.js +0 -68
  126. package/reducers/index.js +0 -23
  127. package/reducers/operation.js +0 -36
  128. package/reducers/player.js +0 -222
  129. package/utils/browser.js +0 -29
  130. package/utils/fullscreen.js +0 -73
@@ -0,0 +1,381 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _propTypes = require("prop-types");
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
+ var _components = require("@desynova-digital/components");
12
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
13
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
14
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
15
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
16
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
17
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
18
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
19
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
20
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
21
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
22
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
23
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
24
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
25
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
26
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
27
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
28
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
29
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
30
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
31
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
32
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
33
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
34
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
35
+ var propTypes = {
36
+ height: _propTypes.PropTypes.number,
37
+ player: _propTypes.PropTypes.instanceOf(Object)
38
+ };
39
+ var defaultProps = {
40
+ height: 0
41
+ };
42
+ var AudioMeterBlock = _styledComponents["default"].div(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n width: 70px;\n right: 14px;\n top: 0px;\n position: absolute;\n height: 100%;\n"])));
43
+ var RangeBlock = (0, _styledComponents["default"])('div')(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n position: absolute;\n right: -12px;\n height: 100%;\n overflow: hidden;\n .range {\n color: #aaaaaa;\n font-family: SFUIText-Medium;\n text-align: right;\n font-size: 8px;\n box-sizing: border-box;\n }\n"])));
44
+ var MeterBlock = (0, _styledComponents["default"])('div')(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n width: 100%;\n height: 100%;\n position: absolute;\n left: 0;\n top: 0;\n display: flex;\n justify-content: space-evenly;\n align-items: center;\n .track-block {\n position: relative;\n width: 15px;\n height: 100%;\n overflow: visible;\n &.left-track,\n &.right-track {\n &:after {\n position: absolute;\n color: #aaaaaa;\n bottom: -12px;\n font-size: 10px;\n left: 50%;\n transform: translateX(-50%);\n font-family: SFUIText-Regular;\n }\n }\n &.left-track:after {\n content: 'L';\n }\n &.right-track:after {\n content: 'R';\n }\n }\n"])));
45
+ var ColorMeter = (0, _styledComponents["default"])('div')(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["\n width: 100%;\n height: 100%;\n background: linear-gradient(to top, #00c8e7, #00e6b9 57%, #ff8d29 83%, #f6462c);\n position: absolute;\n left: 0;\n top: 0;\n z-index: 1;\n .stack-block {\n height: 2px;\n margin-bottom: 3px;\n background: #000000;\n }\n"])));
46
+ var BlackMeter = (0, _styledComponents["default"])('div')(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["\n width: 100%;\n background: #000000;\n position: absolute;\n left: 0;\n top: 0;\n z-index: 1;\n height: 100%;\n transition: all 0.25s ease-in-out;\n -moz-transition: all 0.25s ease-in-out;\n -webkit-transition: all 0.25s ease-in-out;\n -ms-transition: all 0.25s ease-in-out;\n -o-transition: all 0.25s ease-in-out;\n .stack-block {\n height: 2px;\n margin-bottom: 3px;\n background: #304153;\n }\n"])));
47
+ var AudioMute = (0, _styledComponents["default"])('div')(_templateObject6 || (_templateObject6 = _taggedTemplateLiteral(["\n position: absolute;\n top: -20px;\n left: 50%;\n transform: translateX(-50%);\n color: #aaaaaa;\n cursor: pointer;\n"])));
48
+ var AudioMeter = /*#__PURE__*/function (_Component) {
49
+ _inherits(AudioMeter, _Component);
50
+ var _super = _createSuper(AudioMeter);
51
+ function AudioMeter(props, context) {
52
+ var _this;
53
+ _classCallCheck(this, AudioMeter);
54
+ _this = _super.call(this, props, context);
55
+ _this.state = {
56
+ stacksArr: [],
57
+ rangeArray: [],
58
+ unitBlockHeight: 30,
59
+ audioPan: {
60
+ left: true,
61
+ right: true
62
+ }
63
+ };
64
+ _this.dbRange = -48;
65
+ _this.channelCount = 2;
66
+ _this.maskSizes = ['100%', '100%'];
67
+ _this.handleClick = _this.handleClick.bind(_assertThisInitialized(_this));
68
+ _this.getNoOfStacks = _this.getNoOfStacks.bind(_assertThisInitialized(_this));
69
+ _this.maskSize = _this.maskSize.bind(_assertThisInitialized(_this));
70
+ _this.updateMeter = _this.updateMeter.bind(_assertThisInitialized(_this));
71
+ _this.paintMeter = _this.paintMeter.bind(_assertThisInitialized(_this));
72
+ return _this;
73
+ }
74
+ _createClass(AudioMeter, [{
75
+ key: "componentDidMount",
76
+ value: function componentDidMount() {
77
+ var _this$props = this.props,
78
+ hasStarted = _this$props.hasStarted,
79
+ height = _this$props.height;
80
+ if (hasStarted) {
81
+ this.initializeMeter();
82
+ }
83
+ if (height) {
84
+ this.getNoOfStacks();
85
+ }
86
+ }
87
+ }, {
88
+ key: "componentWillUnmount",
89
+ value: function componentWillUnmount() {
90
+ this.disconnectMeter();
91
+ }
92
+ }, {
93
+ key: "disconnectMeter",
94
+ value: function disconnectMeter() {
95
+ if (this.sourceNode && this.meterNode) {
96
+ this.sourceNode.disconnect(this.meterNode);
97
+ this.meterNode.disconnect(this.audioCtx.destination);
98
+ }
99
+ }
100
+ }, {
101
+ key: "getBaseLog",
102
+ value: function getBaseLog(x, y) {
103
+ return Math.log(y) / Math.log(x);
104
+ }
105
+ }, {
106
+ key: "getNoOfStacks",
107
+ value: function getNoOfStacks() {
108
+ if (this._meterBlockRef) {
109
+ var stacksArr = this.state.stacksArr;
110
+ var stackHeight = 5;
111
+ var height = this._meterBlockRef.offsetHeight;
112
+ if (height) {
113
+ var stacksLength = Math.round(height / stackHeight);
114
+ var stackArr = _toConsumableArray(Array(stacksLength)).map(function (x, i) {
115
+ return i;
116
+ });
117
+ var numOfSteps = Math.round(height / 30);
118
+ var singleStep = Math.round(this.dbRange / numOfSteps) || 1;
119
+ if (singleStep > 1) {
120
+ singleStep = Math.ceil(singleStep / 2) * 2;
121
+ }
122
+ var unitArray = [];
123
+ for (var i = this.dbRange; i < 0 - singleStep / 2; i = i - singleStep) {
124
+ unitArray.push(i);
125
+ }
126
+ var blockHeight = parseFloat(height / unitArray.length);
127
+ if (stacksArr !== stackArr) {
128
+ this.setState({
129
+ stacksArr: stackArr,
130
+ rangeArray: unitArray.reverse(),
131
+ unitBlockHeight: blockHeight
132
+ });
133
+ }
134
+ }
135
+ }
136
+ }
137
+ }, {
138
+ key: "createMeterNode",
139
+ value: function createMeterNode() {
140
+ var c = this.sourceNode.channelCount;
141
+ this.meterNode = this.audioCtx.createScriptProcessor(2048, c, c);
142
+ this.sourceNode.connect(this.meterNode);
143
+ this.meterNode.connect(this.audioCtx.destination);
144
+ return this.meterNode;
145
+ }
146
+ }, {
147
+ key: "createMeter",
148
+ value: function createMeter(meterNode) {
149
+ meterNode.onaudioprocess = this.updateMeter;
150
+ this.paintMeter();
151
+ }
152
+ }, {
153
+ key: "updateMeter",
154
+ value: function updateMeter(audioProcessingEvent) {
155
+ var inputBuffer = audioProcessingEvent.inputBuffer;
156
+ var i = 0;
157
+ var channelData = [];
158
+ var channelMaxes = [];
159
+ for (i = 0; i < this.channelCount; i++) {
160
+ channelData[i] = inputBuffer.getChannelData(i);
161
+ channelMaxes[i] = 0.0;
162
+ }
163
+ for (var sample = 0; sample < inputBuffer.length; sample++) {
164
+ for (i = 0; i < this.channelCount; i++) {
165
+ if (Math.abs(channelData[i][sample]) > channelMaxes[i]) {
166
+ channelMaxes[i] = Math.abs(channelData[i][sample]);
167
+ }
168
+ }
169
+ }
170
+ for (i = 0; i < this.channelCount; i++) {
171
+ var size = this.maskSize(channelMaxes[i]);
172
+ this.maskSizes[i] = size + '%';
173
+ }
174
+ }
175
+ }, {
176
+ key: "maskSize",
177
+ value: function maskSize(floatVal) {
178
+ var returnVal = Math.floor(this.dbFromFloat(floatVal) * 100 / this.dbRange);
179
+ if (returnVal > 100) {
180
+ return 100;
181
+ } else {
182
+ return returnVal;
183
+ }
184
+ }
185
+ }, {
186
+ key: "dbFromFloat",
187
+ value: function dbFromFloat(floatVal) {
188
+ return this.getBaseLog(10, floatVal) * 20;
189
+ }
190
+ }, {
191
+ key: "paintMeter",
192
+ value: function paintMeter() {
193
+ for (var i = 0; i < this.channelCount; i++) {
194
+ var audioPan = this.state.audioPan;
195
+ var leftPan = audioPan.left;
196
+ var rightPan = audioPan.right;
197
+ var elem = document.getElementById("channel-".concat(i));
198
+ if (elem) {
199
+ if (i === 0 && !leftPan) {
200
+ elem.style.height = '100%';
201
+ } else if (i === 1 && !rightPan) {
202
+ elem.style.height = '100%';
203
+ } else {
204
+ elem.style.height = this.maskSizes[i];
205
+ }
206
+ }
207
+ }
208
+ window.requestAnimationFrame(this.paintMeter);
209
+ }
210
+ }, {
211
+ key: "muteAudio",
212
+ value: function muteAudio(position) {
213
+ var audioPan = this.state.audioPan;
214
+ var leftPan = audioPan.left;
215
+ var rightPan = audioPan.right;
216
+ switch (position) {
217
+ case 'left':
218
+ leftPan = !leftPan;
219
+ break;
220
+ case 'right':
221
+ rightPan = !rightPan;
222
+ break;
223
+ }
224
+ if (leftPan && rightPan) {
225
+ this.gainL.connect(this.merger, 0, 0);
226
+ this.gainR.connect(this.merger, 0, 1);
227
+ }
228
+ if (!leftPan && rightPan) {
229
+ this.gainL.disconnect();
230
+ this.gainR.connect(this.merger, 0, 1);
231
+ }
232
+ if (leftPan && !rightPan) {
233
+ this.gainL.connect(this.merger, 0, 0);
234
+ this.gainR.disconnect();
235
+ }
236
+ if (!leftPan && !rightPan) {
237
+ this.gainL.disconnect();
238
+ this.gainR.disconnect();
239
+ }
240
+ this.setState({
241
+ audioPan: {
242
+ left: leftPan,
243
+ right: rightPan
244
+ }
245
+ });
246
+ }
247
+ }, {
248
+ key: "initializeMeter",
249
+ value: function initializeMeter() {
250
+ this.getNoOfStacks();
251
+ var myVideo = document.querySelector('video');
252
+ this.audioCtx = this.audioCtx || new window.AudioContext();
253
+ this.audioCtx.createGain = this.audioCtx.createGain || this.audioCtx.createGainNode; //fallback for gain naming
254
+ this.gainL = this.audioCtx.createGain();
255
+ this.gainR = this.audioCtx.createGain();
256
+ this.merger = this.audioCtx.createChannelMerger(2);
257
+ var splitter = this.audioCtx.createChannelSplitter(2);
258
+ this.sourceNode = this.sourceNode || this.audioCtx.createMediaElementSource(myVideo);
259
+ this.sourceNode.connect(splitter, 0, 0);
260
+
261
+ //Connect splitter' outputs to each Gain Nodes
262
+ splitter.connect(this.gainL, 0);
263
+ splitter.connect(this.gainR, 1);
264
+
265
+ /*
266
+ *Connect Left and Right Nodes to the output
267
+ *Assuming stereo as initial status
268
+ */
269
+ this.gainL.connect(this.merger, 0, 0);
270
+ this.gainR.connect(this.merger, 0, 1);
271
+ this.merger.connect(this.audioCtx.destination, 0, 0);
272
+ var meterNode = this.createMeterNode();
273
+ this.createMeter(meterNode);
274
+ }
275
+ }, {
276
+ key: "UNSAFE_componentWillReceiveProps",
277
+ value: function UNSAFE_componentWillReceiveProps(newProps) {
278
+ var _this$props2 = this.props,
279
+ height = _this$props2.height,
280
+ hasStarted = _this$props2.hasStarted;
281
+ if (height && height !== newProps.height) {
282
+ this.getNoOfStacks();
283
+ }
284
+ if (hasStarted !== newProps.hasStarted && newProps.hasStarted) {
285
+ this.initializeMeter();
286
+ }
287
+ }
288
+ }, {
289
+ key: "handleClick",
290
+ value: function handleClick() {}
291
+ }, {
292
+ key: "render",
293
+ value: function render() {
294
+ var _this2 = this;
295
+ var _this$state = this.state,
296
+ stacksArr = _this$state.stacksArr,
297
+ rangeArray = _this$state.rangeArray,
298
+ unitBlockHeight = _this$state.unitBlockHeight,
299
+ audioPan = _this$state.audioPan;
300
+ console.log('stackArray', stacksArr);
301
+ return (
302
+ /*#__PURE__*/
303
+ // <AudioMeterBlock id="audio-meter-block">
304
+ _react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(RangeBlock, null, rangeArray.map(function (range) {
305
+ return /*#__PURE__*/_react["default"].createElement("div", {
306
+ key: 'range' + range,
307
+ style: {
308
+ height: unitBlockHeight + 'px'
309
+ },
310
+ className: "range"
311
+ }, range);
312
+ })), /*#__PURE__*/_react["default"].createElement(MeterBlock, {
313
+ ref: function ref(meterBlockRef) {
314
+ _this2._meterBlockRef = meterBlockRef;
315
+ }
316
+ }, /*#__PURE__*/_react["default"].createElement("div", {
317
+ className: "track-block left-track"
318
+ }, /*#__PURE__*/_react["default"].createElement(ColorMeter, null, stacksArr.map(function (num) {
319
+ return /*#__PURE__*/_react["default"].createElement("div", {
320
+ className: "stack-block",
321
+ key: num
322
+ });
323
+ })), /*#__PURE__*/_react["default"].createElement(BlackMeter, {
324
+ id: "channel-0"
325
+ }, stacksArr.map(function (num) {
326
+ return /*#__PURE__*/_react["default"].createElement("div", {
327
+ className: "stack-block",
328
+ key: num
329
+ });
330
+ })), /*#__PURE__*/_react["default"].createElement(AudioMute, {
331
+ onClick: function onClick() {
332
+ _this2.muteAudio('left');
333
+ }
334
+ }, audioPan.left ? /*#__PURE__*/_react["default"].createElement(_components.Icon, {
335
+ name: "volume",
336
+ width: 14,
337
+ height: 14,
338
+ color: "#aaaaaa"
339
+ }) : /*#__PURE__*/_react["default"].createElement(_components.Icon, {
340
+ name: "mute",
341
+ width: 14,
342
+ height: 14,
343
+ color: "#aaaaaa"
344
+ }))), /*#__PURE__*/_react["default"].createElement("div", {
345
+ className: "track-block right-track"
346
+ }, /*#__PURE__*/_react["default"].createElement(ColorMeter, null, stacksArr.map(function (num) {
347
+ return /*#__PURE__*/_react["default"].createElement("div", {
348
+ className: "stack-block",
349
+ key: num
350
+ });
351
+ })), /*#__PURE__*/_react["default"].createElement(BlackMeter, {
352
+ id: "channel-1"
353
+ }, stacksArr.map(function (num) {
354
+ return /*#__PURE__*/_react["default"].createElement("div", {
355
+ className: "stack-block",
356
+ key: num
357
+ });
358
+ })), /*#__PURE__*/_react["default"].createElement(AudioMute, {
359
+ onClick: function onClick() {
360
+ _this2.muteAudio('right');
361
+ }
362
+ }, audioPan.right ? /*#__PURE__*/_react["default"].createElement(_components.Icon, {
363
+ name: "volume",
364
+ width: 14,
365
+ height: 14,
366
+ color: "#aaaaaa"
367
+ }) : /*#__PURE__*/_react["default"].createElement(_components.Icon, {
368
+ name: "mute",
369
+ width: 14,
370
+ height: 14,
371
+ color: "#aaaaaa"
372
+ })))))
373
+ );
374
+ }
375
+ }]);
376
+ return AudioMeter;
377
+ }(_react.Component);
378
+ exports["default"] = AudioMeter;
379
+ AudioMeter.propTypes = propTypes;
380
+ AudioMeter.defaultProps = defaultProps;
381
+ AudioMeter.displayName = 'AudioMeter';