react-browser-components
TypeScript icon, indicating that this package has built-in type declarations

1.0.7 • Public • Published

🪟 react-browser-components ✨

React component for browser-windows like containers, with tabs functionality.

npm i react-browser-components

npm GitHub license npm bundle size

ChromeBrowser ArcBrowser

You can use the components to demonstrate functionality with browsers, or as decorative elements in your project. The components are not designed to be used as actual browsers.

Basic Usage

import { ChromeBrowser, ArcBrowser } from "react-browser-components";
import { useState } from "react";

const App = () => {
  const [tab, setTab] = useState(0);
  const tabs = [
    {
      name: "Google",
      link: "https://google.com",
      content: <div>Content</div>,
      icon: (
        <img
          src="https://google.com/favicon.ico"
          style={{ width: "100%", height: "100%" }}
        />
      ),
    },
  ];

  return (
    <>
      <ChromeBrowser tabs={tabs} tab={tab} setTab={setTab} />
      <ArcBrowser tabs={tabs} tab={tab} setTab={setTab} />
    </>
  );
};

Props

Name Type Description
theme "light" | "dark" Theme of the browser, default is light. The light and dark theme of ArcBrowser is the same.
tabs Array<{name: string;link: string;content: React.ReactNode;icon: React.ReactNode;}> Pages in the browser.
shadow boolean Shadow of the browser, default is true.
useContentSize boolean Default is false: browser will be the size of its parent element. True: browser will be the size of its content.
contentScroll boolean If content inside the container should be scrollable, default is true.
leftIcons React.ReactNode Leave empty for default icons.
rightIcons React.ReactNode Leave empty for default icons.
lightTheme Theme Changes the light theme of the browser.
darkTheme Theme Changes the dark theme of the browser.
children React.ReactNode Content displayed over all pages.
tab number Active tab index.
setTab (tab: number) => void Function to set the active tab index.
export default interface Theme {
  theme: string;
  bg: string;
  text: string;
  contentBg: string;
  contentText: string;
  border: string;
  searchBarBg: string;
  tabBarBg: string;
  tabDivider: string;
  tabHoverBg: string;
  tabSelectedBg: string;
}

Development

To get started:

git clone https://github.com/EnhancedJax/react-browser-components.git
cd react-browser-components
npm i

Actions:

npm run storybook # start storybook
npm run build # build the library
npm run test # test the library

Testing in another project

npm run build
npm link
npm link "../your-project/node_modules/react"
cd ../your-project
npm link react-browser-components

Dependencies (0)

    Dev Dependencies (31)

    Package Sidebar

    Install

    npm i react-browser-components

    Weekly Downloads

    5

    Version

    1.0.7

    License

    ISC

    Unpacked Size

    802 kB

    Total Files

    20

    Last publish

    Collaborators

    • enhanced-jax