@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.
- package/Player.js +945 -0
- package/control/AudioTracksMenuButton.js +91 -0
- package/control/AudioTracksMenuButton.jsx +80 -0
- package/control/ControlBar.js +303 -0
- package/control/ControlBar.jsx +264 -0
- package/control/CurrentTimeDisplay.js +34 -0
- package/control/CurrentTimeDisplay.jsx +35 -0
- package/control/DurationDisplay.js +38 -0
- package/control/DurationDisplay.jsx +48 -0
- package/control/ForwardBackwardControl.js +76 -0
- package/control/ForwardBackwardControl.jsx +79 -0
- package/control/FullscreenToggle.js +82 -0
- package/control/FullscreenToggle.jsx +83 -0
- package/control/MarkInControl.js +124 -0
- package/control/MarkInControl.jsx +109 -0
- package/control/MarkOutControl.js +137 -0
- package/control/MarkOutControl.jsx +131 -0
- package/control/MarkerBar.js +127 -0
- package/control/MarkerBar.jsx +107 -0
- package/control/MarkingControl.js +82 -0
- package/control/MarkingControl.jsx +143 -0
- package/control/MarkingDuration.js +44 -0
- package/control/MarkingPreview.js +49 -0
- package/control/MarkingPreview.jsx +60 -0
- package/control/PlayBackRateControl.js +106 -0
- package/control/PlayBackRateControl.jsx +106 -0
- package/control/PlayProgressBar.js +61 -0
- package/control/PlayProgressBar.jsx +92 -0
- package/control/PlayToggle.js +56 -0
- package/control/PlayToggle.jsx +57 -0
- package/control/PointersBar.js +231 -0
- package/control/PointersBar.jsx +286 -0
- package/control/ProgressControl.js +127 -0
- package/control/ProgressControl.jsx +155 -0
- package/control/SeekBar.js +204 -0
- package/control/SeekBar.jsx +229 -0
- package/control/SettingsMenuButton.js +63 -0
- package/control/SettingsMenuButton.jsx +69 -0
- package/control/Slider.js +274 -0
- package/control/Slider.jsx +243 -0
- package/control/Timeline.js +118 -0
- package/control/Timeline.jsx +131 -0
- package/control/VolumeBar.js +198 -0
- package/control/VolumeBar.jsx +174 -0
- package/control/VolumeLevel.js +61 -0
- package/control/VolumeLevel.jsx +66 -0
- package/control/VolumneMenuButton.js +112 -0
- package/control/VolumneMenuButton.jsx +111 -0
- package/header/Header.js +309 -0
- package/header/Header.jsx +479 -0
- package/index.js +9 -151
- package/media/AudioMeter.js +381 -0
- package/media/AudioMeter.jsx +411 -0
- package/media/SDOutline.js +82 -0
- package/media/SDOutline.jsx +90 -0
- package/media/Video.js +684 -0
- package/media/Video.jsx +714 -0
- package/package.json +5 -1
- package/playlist/Playlist.js +67 -0
- package/playlist/Playlist.jsx +91 -0
- package/playlist/index.js +13 -0
- package/shortcuts/Shortcut.js +662 -0
- package/utils/Menu.js +50 -0
- package/utils/Menu.jsx +105 -0
- package/{colors.js → utils/colors.js} +13 -13
- package/utils/dom.js +6 -16
- package/utils/index.js +52 -122
- package/Manager.js +0 -124
- package/actions/player.js +0 -375
- package/actions/video.js +0 -230
- package/components/AudioMeter.js +0 -414
- package/components/BigPlayButton.js +0 -110
- package/components/ImageViewer.js +0 -318
- package/components/MarkerBar.js +0 -138
- package/components/Menu.js +0 -77
- package/components/Player.js +0 -821
- package/components/PlayerHeader.js +0 -472
- package/components/Playlist.js +0 -133
- package/components/PointersBar.js +0 -299
- package/components/PosterImage.js +0 -61
- package/components/SDOutline.js +0 -68
- package/components/Shortcut.js +0 -621
- package/components/Slider.js +0 -317
- package/components/TagsBar.js +0 -100
- package/components/Video.js +0 -1431
- package/components/control-bar/AudioTracksMenuButton.js +0 -113
- package/components/control-bar/CameraButton.js +0 -88
- package/components/control-bar/CommentsButton.js +0 -216
- package/components/control-bar/ControlBar.js +0 -260
- package/components/control-bar/EditorControlMenuButton.js +0 -412
- package/components/control-bar/ForwardControl.js +0 -17
- package/components/control-bar/ForwardReplayControl.js +0 -122
- package/components/control-bar/FullscreenToggle.js +0 -101
- package/components/control-bar/PlayToggle.js +0 -98
- package/components/control-bar/ReplayControl.js +0 -17
- package/components/control-bar/SettingsMenuButton.js +0 -43
- package/components/control-bar/SubtitleLanguagesMenuButton.js +0 -174
- package/components/control-bar/VolumeMenuButton.js +0 -134
- package/components/control-bar/ZoomMenuButton.js +0 -116
- package/components/marking-controls/MarkInControl.js +0 -140
- package/components/marking-controls/MarkOutControl.js +0 -155
- package/components/marking-controls/MarkingAddButton.js +0 -94
- package/components/marking-controls/MarkingControl.js +0 -135
- package/components/marking-controls/MarkingDeleteButton.js +0 -84
- package/components/marking-controls/MarkingDuration.js +0 -77
- package/components/marking-controls/MarkingPreview.js +0 -86
- package/components/progress-bar/AudioWaveform.js +0 -144
- package/components/progress-bar/LoadProgressBar.js +0 -90
- package/components/progress-bar/MouseTimeDisplay.js +0 -53
- package/components/progress-bar/PlayProgressBar.js +0 -79
- package/components/progress-bar/ProgressControl.js +0 -222
- package/components/progress-bar/SeekBar.js +0 -261
- package/components/progress-bar/Timeline.js +0 -134
- package/components/settings-menu-control/PlaybackRateControl.js +0 -147
- package/components/settings-menu-control/SafeAreaControl.js +0 -92
- package/components/settings-menu-control/SettingsMenu.js +0 -68
- package/components/settings-menu-control/SubtitleControl.js +0 -1
- package/components/time-controls/CurrentTimeDisplay.js +0 -53
- package/components/time-controls/DurationDisplay.js +0 -51
- package/components/time-controls/TimeDivider.js +0 -41
- package/components/volume-control/VolumeBar.js +0 -216
- package/components/volume-control/VolumeControl.js +0 -35
- package/components/volume-control/VolumeLevel.js +0 -78
- package/components/zoom-control/ZoomBar.js +0 -189
- package/components/zoom-control/ZoomLevel.js +0 -68
- package/reducers/index.js +0 -23
- package/reducers/operation.js +0 -36
- package/reducers/player.js +0 -222
- package/utils/browser.js +0 -29
- 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';
|