UNPKG

replay-viewer

Version:

Rocket League replay viewer React component and tooling

80 lines 3.41 kB
var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { if (typeof b !== "function" && b !== null) throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; import MUISlider from "@mui/material/Slider"; import debounce from "lodash.debounce"; import React, { Component } from "react"; import { addFrameListener, removeFrameListener, } from "../../eventbus/events/frame"; import DataManager from "../../managers/DataManager"; import { GameManager } from "../../managers/GameManager"; var SLIDER_OUTLINE_RADIUS = 24; var Slider = /** @class */ (function (_super) { __extends(Slider, _super); function Slider(props) { var _this = _super.call(this, props) || this; _this.onFrame = debounce(function (_a) { var frame = _a.frame; _this.setState({ frame: frame }); }, 250, { maxWait: 250 }); _this.handleChange = function (_, value) { var frame = Math.round(value); GameManager.getInstance().clock.setFrame(frame); }; _this.state = { frame: 0, maxFrame: DataManager.getInstance().data.frames.length - 1, }; addFrameListener(_this.onFrame); return _this; } Slider.prototype.componentWillUnmount = function () { removeFrameListener(this.onFrame); this.onFrame.cancel(); }; Slider.prototype.render = function () { var _a = this.state, frame = _a.frame, maxFrame = _a.maxFrame; return (React.createElement("div", { style: { display: "flex", alignItems: "center", height: 12, marginLeft: -SLIDER_OUTLINE_RADIUS / 2, marginRight: -SLIDER_OUTLINE_RADIUS / 2, } }, React.createElement("div", { style: { display: "flex", alignItems: "center", overflow: "hidden", height: SLIDER_OUTLINE_RADIUS * 2, width: "calc(100% - 12px)", paddingLeft: SLIDER_OUTLINE_RADIUS, paddingRight: SLIDER_OUTLINE_RADIUS, } }, React.createElement(MUISlider, __assign({}, this.props, { value: frame, "aria-labelledby": "label", onChange: this.handleChange, min: 0, max: maxFrame }))))); }; return Slider; }(Component)); export default Slider; //# sourceMappingURL=Slider.js.map