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@borderfreefinancial/jitsi-meetimage-annotate-reacthandposeinview_editorholman-react-image-annotately-cloud-bpm-uimatch-viewer@wcarpenter96/react-image-annotate@ulugbekov/react-images@viveljs/ui@xr3ngine/client-networking@yoonjae.yang/react-image-annotate@ylzcc/video-player@zalastax/nolb-react-fuai-image-annotatorb2bwidgetaviscous-imagesannotinder-clientarvest-mv@palustris/react-images@peerline/hogak-playergac-pavi@splunk/dashboard-coreflatpage3d-viewer-package-new@choengteur/react-comic-viewer@azu/react-comic-viewercatalyst-vc-reactccs-annotator-clientcoraldd-react-image-annotatecoone-annotation-tooldash_ifc_heatroomdash_ifc_wtgcustom-react-image-annotatedbmx-confydesign-system-medclubdataverse-ui-componentsbeem-metaverse-kitbeem-metaverse-kit-2beemup-deployment-kit-metaspace-testbeemup-deployment-kit-metaspace-test-2biominer-components@arcblock/www@advancedsolutions/react-image-annotate@arifzeeshan-ign/react-image-annotate@arkondata/react-bpmn-modeler@amnstak/react-image-annotatereact-vidsync-playerreafletjstt-frontend-componentstusk-annotatetusk-annotate-toolyss-image-annotatewasssap-2wasssap-20wasssap-200wasssap-24wasssapp-20vad-header-footerziyar-metaspace@logangroup/game-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-annotate
1.1.1

3 years ago

1.1.0

4 years ago

1.1.0-0

4 years ago

1.0.2

5 years ago

1.0.2-0

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago

0.3.2-0

5 years ago

1.0.0-0

5 years ago

0.3.1

5 years ago

0.3.1-0

5 years ago

0.2.5

5 years ago

0.2.4

7 years ago

0.2.3

7 years ago

0.2.3-0

7 years ago

0.2.2

8 years ago

0.2.1

8 years ago

0.2.0

8 years ago

0.1.7

8 years ago

0.1.6

8 years ago

0.1.5

8 years ago

0.1.4

8 years ago

0.1.3

8 years ago

0.1.2

8 years ago

0.1.0

8 years ago

0.0.2

8 years ago

0.0.1

8 years ago