src/widgets/Shortcuts.js
author ymh <ymh.work@gmail.com>
Fri, 18 Oct 2024 10:24:57 +0200
changeset 1074 231ea5ea7de4
parent 1072 ac1eacb3aa33
permissions -rw-r--r--
change http to https for default thumb

import shortcutsStyles from "./Shortcuts.module.css";

const Shortcuts = function (ns) {
  return class extends ns.Widgets.Widget {
    constructor(player, config) {
      super(player, config);
    }

    /**
     * Keyboard shortcuts widget
     * This widgets add global shortcuts for common actions.
     * The default shortcuts are:
     * - Control-space for play/pause
     * - Control-left for rewind (+shift to go faster)
     * - Control-right for forward (+shift to go faster)
     */
    static defaults = {
      // Time increment, in ms, for backward/forward navigation
      time_increment: 2000,
    };

    draw() {
      var _this = this;

      /* Standard shortcuts */
      Mousetrap.bindGlobal("ctrl+space", function (e) {
        e.preventDefault();
        if (!_this.media.getPaused()) {
          _this.media.pause();
        } else {
          _this.media.play();
        }
        return false;
      });
      Mousetrap.bindGlobal("ctrl+left", function (e) {
        // Backward
        e.preventDefault();
        _this.media.setCurrentTime(
          Math.max(0, _this.media.getCurrentTime() - _this.time_increment)
        );
        return false;
      });
      Mousetrap.bindGlobal("ctrl+shift+left", function (e) {
        // Backward
        e.preventDefault();
        _this.media.setCurrentTime(
          Math.max(0, _this.media.getCurrentTime() - 5 * _this.time_increment)
        );
        return false;
      });
      Mousetrap.bindGlobal("ctrl+right", function (e) {
        // Forward
        e.preventDefault();
        _this.media.setCurrentTime(
          Math.min(
            _this.media.duration,
            _this.media.getCurrentTime() + _this.time_increment
          )
        );
        return false;
      });
      Mousetrap.bindGlobal("ctrl+shift+right", function (e) {
        // Forward
        e.preventDefault();
        _this.media.setCurrentTime(
          Math.min(
            _this.media.duration,
            _this.media.getCurrentTime() + 5 * _this.time_increment
          )
        );
        return false;
      });
      Mousetrap.bindGlobal("ctrl+a", function (e) {
        // Annotate
        e.preventDefault();
        _this.player.trigger("CreateAnnotation.toggle");
        return false;
      });
    }
  };
};

export { Shortcuts, shortcutsStyles };