1.1.1 • Published 3 years ago

react-full-screen v1.1.1

Weekly downloads
57,003
License
MIT
Repository
github
Last release
3 years ago

React Fullscreen

A React component that sets its children to fullscreen using the Fullscreen API, normalized using fscreen.

Usage

* Install.

yarn add react-full-screen

* Import component and hook

import { FullScreen, useFullScreenHandle } from "react-full-screen";

* Setup and render.

You must use one handle per full screen element. It is not possible to start in Fullscreen. Fullscreen must be enabled from a user action such as onClick.

import React, {useCallback} from 'react';
import { FullScreen, useFullScreenHandle } from "react-full-screen";

function App() {
  const handle = useFullScreenHandle();

  return (
    <div>
      <button onClick={handle.enter}>
        Enter fullscreen
      </button>

      <FullScreen handle={handle}>
        Any fullscreen content here
      </FullScreen>
    </div>
  );
}

export default App;

When you have many elements you need one handle per element.

import React, {useCallback} from 'react';
import { FullScreen, useFullScreenHandle } from "react-full-screen";

function App() {
  const screen1 = useFullScreenHandle();
  const screen2 = useFullScreenHandle();

  const reportChange = useCallback((state, handle) => {
    if (handle === screen1) {
      console.log('Screen 1 went to', state, handle);
    }
    if (handle === screen2) {
      console.log('Screen 2 went to', state, handle);
    }
  }, [screen1, screen2]);

  return (
    <div>
      <button onClick={screen1.enter}>
        First
      </button>

      <button onClick={screen2.enter}>
        Second
      </button>

      <FullScreen handle={screen1} onChange={reportChange}>
        <div className="full-screenable-node" style={{background: "red"}}>
          First
          <button onClick={screen2.enter}>
            Switch
          </button>
          <button onClick={screen1.exit}>
            Exit
          </button>
        </div>
      </FullScreen>

      <FullScreen handle={screen2} onChange={reportChange}>
        <div className="full-screenable-node" style={{background: "green"}}>
          Second
          <button onClick={screen1.enter}>
            Switch
          </button>
          <button onClick={screen2.exit}>
            Exit
          </button>
        </div>
      </FullScreen>
    </div>
  );
}

export default App;

Types

interface FullScreenHandle {
  active: boolean;
  // Specifies if attached element is currently full screen.

  enter: () => Promise<void>;
  // Requests this element to go full screen.

  exit: () => Promise<void>;
  // Requests this element to exit full screen.

  node: React.MutableRefObject<HTMLDivElement | null>;
  // The attached DOM node
}
interface FullScreenProps {
  handle: FullScreenHandle;
  // Handle that helps operate the full screen state.

  onChange?: (state: boolean, handle: FullScreenHandle) => void;
  // Optional callback that gets called when this screen changes state.
  
  className?: string;
  // Optional prop allowing you to apply a custom class name to the FullScreen container
}

CSS

Class fullscreen-enabled will be added to component when it goes fullscreen. If you want to alter child elements when this happens you can use a typical CSS statement.

.my-component {
  background: #fff;
}

.fullscreen-enabled .my-component {
  background: #000;
}

In the wild

Used with MegamanJS

@borderfreefinancial/revo-consumer@borderfreefinancial/revo-core@borderfreefinancial/revo-core-api@borderfreefinancial/revo-web-video-testreact-mindeemindee-sdk-react@dovydasbu/react-snakezenstatereact-images-tmpgatsby-theme-evelangatsby-theme-sanity-evelan@mindee/react-web-essentialsmirador-biblissimareact-image-annotate-filterablereact-presentation-renderer-libraryviveljspe-layoutsarclight-reactchinese-mirador@infinitebrahmanuniverse/nolb-react-fu@everything-registry/sub-chunk-2556ra-miradortamu-miradorsysom-flamegraphthe-fit-b2bvideo-player-tp-glvosviewer-online@columbia-libraries/mirador@borderfreefinancial/jitsi-meetreact-vidsync-playerreafletjstt-frontend-componentstusk-annotatetusk-annotate-tool@arkondata/react-bpmn-modeler@arcblock/www@arifzeeshan-ign/react-image-annotate@advancedsolutions/react-image-annotate@azu/react-comic-viewer@choengteur/react-comic-viewer@de-mklinger/react-slideshow@dataquiver/react-ui@dataunion.app/react-annotate@dataunion/react-annotateyss-image-annotatewasssap-2wasssap-20wasssap-200wasssap-24wasssapp-20vad-header-footerziyar-metaspace@dts-stn/decd-design-system@dts-stn/service-canada-design-system@europeana/mirador@geourjoa/mirador-r18@glints/video-rooms-client@inner-desktop/react-images@innovatrics/food-kitchen@logangroup/game-player@mathewjordan/mirador-garb@nakamura196/mirador@exabyte-io/cove.js@eylonkoenig/react-image-annotate@medmain/medmain-images-integrator@medmain/react-ui-kit@mindee/web-elements@intelligence-stack/react-image-annotate@jesses/react-images@hxsllc/mirador@hxsllc/mirador-react17@sammarks/react-editor@sampoder/holocron@saran-ign/react-image-annotate@rediminds/image-video-annotator@regang/mirador@palustris/react-images@skidding/react-images@splunk/dashboard-core@snakesilk/react-presenter@silentnerd/react-image-annotate@searpent/react-image-annotate@rogeliolb/react-v-playermtc-react-image-annotatemodule-the-fitmichibox-componentsmiradormirador-knaw-huc-mui5mirador-third-rockmirador-videons_workflow_image_annotationns_workflow_image_annotation_2024ns_workflow_image_annotationspaz-check-web-appreact-multiple-image-annotatereact-comic-viewerreact-comic-viewer-revertreact-covideo-embedreact-cp-youtubesaurabhorionlib
1.1.1

3 years ago

1.1.0

4 years ago

1.1.0-0

4 years ago

1.0.2

4 years ago

1.0.2-0

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago

0.3.2-0

4 years ago

1.0.0-0

4 years ago

0.3.1

5 years ago

0.3.1-0

5 years ago

0.2.5

5 years ago

0.2.4

6 years ago

0.2.3

7 years ago

0.2.3-0

7 years ago

0.2.2

7 years ago

0.2.1

7 years ago

0.2.0

7 years ago

0.1.7

7 years ago

0.1.6

7 years ago

0.1.5

7 years ago

0.1.4

7 years ago

0.1.3

7 years ago

0.1.2

7 years ago

0.1.0

7 years ago

0.0.2

8 years ago

0.0.1

8 years ago