wotnot-video-react
Version:
Video-React is a web video player built from the ground up for an HTML5 world using React library.
104 lines (79 loc) • 4.17 kB
JavaScript
;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireWildcard(require("react"));
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
var propTypes = {
actions: _propTypes["default"].object,
className: _propTypes["default"].string,
seconds: _propTypes["default"].oneOf([5, 10, 30])
};
var defaultProps = {
seconds: 10
};
var _default = function _default(mode) {
var ForwardReplayControl = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(ForwardReplayControl, _Component);
var _super = _createSuper(ForwardReplayControl);
function ForwardReplayControl(props, context) {
var _this;
(0, _classCallCheck2["default"])(this, ForwardReplayControl);
_this = _super.call(this, props, context);
_this.handleClick = _this.handleClick.bind((0, _assertThisInitialized2["default"])(_this));
return _this;
}
(0, _createClass2["default"])(ForwardReplayControl, [{
key: "handleClick",
value: function handleClick() {
var _this$props = this.props,
actions = _this$props.actions,
seconds = _this$props.seconds; // Depends mode to implement different actions
if (mode === 'forward') {
actions.forward(seconds);
} else {
actions.replay(seconds);
}
}
}, {
key: "render",
value: function render() {
var _this2 = this;
var _this$props2 = this.props,
seconds = _this$props2.seconds,
className = _this$props2.className;
var classNames = ['video-react-control', 'video-react-button', 'video-react-icon'];
classNames.push("video-react-icon-".concat(mode, "-").concat(seconds), "video-react-".concat(mode, "-control"));
if (className) {
classNames.push(className);
}
return /*#__PURE__*/_react["default"].createElement("button", {
ref: function ref(c) {
_this2.button = c;
},
className: classNames.join(' '),
type: "button",
onClick: this.handleClick
}, /*#__PURE__*/_react["default"].createElement("span", {
className: "video-react-control-text"
}, "".concat(mode, " ").concat(seconds, " seconds")));
}
}]);
return ForwardReplayControl;
}(_react.Component);
ForwardReplayControl.propTypes = propTypes;
ForwardReplayControl.defaultProps = defaultProps;
return ForwardReplayControl;
};
exports["default"] = _default;