back to all posts

Create a twitch clone using React — 1

by Nabendu Biswas / April 30th, 2019

#javascript #react #webdev
Series: Twitch-react

Welcome to the brand new series. Here, we will create a clone of the popular streaming service https://www.twitch.tv/ using ReactJS.

This series have been inspired by “Modern React with Redux” series by Stephen Grider on udemy.

Let’s start with the setup now. We will have React code and streaming code also. So, create a folder streams. Inside it generate a new folder client for react by using create-react-app client.

Initial SetupInitial Setup

Now, go inside that client directory and start your project by npm start. You will see the below screen after that.

Started on localhostStarted on localhost

Now, open your project(client directory) in VSCode and go inside src and delete everything.

Delete everythingDelete everything

Now, in src create a file index.js and write the below basic React boilerplate.

    import React from 'react';
    import ReactDOM from 'react-dom';
    import App from './components/App';

    ReactDOM.render(<App />, document.querySelector('#root'));

Now, create a components directory inside src and in it create a file App.js

    import React from 'react';

    const App = () => {
        return (
            <div>App Rendered</div>
        );
    }

    export default App;

If now typo, we will see App Rendered on our localhost.

**App Rendered**App Rendered

We will be having different pages in our app, so we will use React-router in the project. So, go ahead and stop the running instance of localhost and type npm install — save react-router-dom in the terminal.

npm installnpm install

Once, it is installed start you application by npm start. Next, we will create our different component files first. Inside components directory create streams directory and inside it create 5 files.

Five Stream filesFive Stream files

We will quickly add below boilerplate code to all five files. Add below to StreamCreate.js

    import React from 'react';

    const StreamCreate = () => {
        return (
            <div>
            StreamCreate
            </div>
        )
    }

    export default StreamCreate;

Add below to StreamDelete.js

    import React from 'react';

    const StreamDelete = () => {
        return (
            <div>
            StreamDelete
            </div>
        )
    }

    export default StreamDelete;

And similarly to other 3 files. Now, open App.js and import these 5 files and also three components BrowserRouter, Route, Link from react-router-dom. We are creating 5 different routes and wrapping them inside BrowserRouter.

    import React from 'react';
    import { BrowserRouter, Route } from 'react-router-dom';
    import StreamCreate from './streams/StreamCreate';
    import StreamEdit from './streams/StreamEdit';
    import StreamDelete from './streams/StreamDelete';
    import StreamList from './streams/StreamList';
    import StreamShow from './streams/StreamShow';**

    const App = () => {
        return (
            <div>
                <BrowserRouter>
                    <div>
                        <Route path="/" exact component={StreamList} />
                        <Route path="/streams/create" exact component={StreamCreate} />
                        <Route path="/streams/edit" exact component={StreamEdit} />
                        <Route path="/streams/delete" exact component={StreamDelete} />
                        <Route path="/streams/show" exact component={StreamShow} />
                    </div>
                </BrowserRouter>
            </div>
        );
    }

    export default App;

Now, once check all the routes are local properly by going to them.

Route CheckingRoute Checking

We will now create our Header component. The header will be visible in all pages, which we visit. So, go ahead and create a Header.js file inside components directory.

We will use the Link tag from react-router-dom here. We are creating two links now— one for logo and other for All Stream. Both will take us to the root url.

    import React from 'react';
    import { Link } from 'react-router-dom';
    import './Header.css';

    const Header = () => {
        return (
            <div className="headerWrapper">
                <div className="headerTitle">
                    <Link to="/">Stremer</Link>
                </div>
                <div className="otherLinks">
                    <Link to="/">All Streams</Link>
                </div>
            </div>
        )
    }

    export default Header;

You might have notice that we gave some classNames to our divs. This is because we are going to style our header next. Create a Header.css file in the same directory. Now, write the below code in it. It’s a simple CSS with a Flexbox and some styling.

    .headerWrapper{
        background: #ffc600 ;
        height: 5%;
        padding: 1%;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .headerTitle{
        font-size: 1.5rem;
        font-weight: bold;
        line-height: 1.25;
        color: #333333;
        text-shadow: 0px 4px 3px rgba(0,0,0,0.4),
                    0px 8px 13px rgba(0,0,0,0.1),
                    0px 18px 23px rgba(0,0,0,0.1);
    }

    .otherLinks {
        font-size: 16px;
        font-weight: bold;
        line-height: 1.25;
        color: #333333;
    }

Now, include Header in our App.js as below.

    import Header from './Header';

    const App = () => {
        return (
            <div>
                <BrowserRouter>
                    <div>
                        <Header />
                        <Route path="/" exact component={StreamList} />
                        <Route path="/streams/create" exact component={StreamCreate} />
                        <Route path="/streams/edit" exact component={StreamEdit} />
                        <Route path="/streams/delete" exact component={StreamDelete} />
                        <Route path="/streams/show" exact component={StreamShow} />
                    </div>
                </BrowserRouter>
            </div>
        );
    }

    export default App;

Now, head over to localhost and you can see our beautiful Header completed.

Beautiful HeaderBeautiful Header

This concludes Part-1 of the series.

Nabendu Biswas