Thank you for Purchasing



Luxiren - React JS Landing Page Collection

Version 1.0.0


  • Created : 19 Nov 2019
  • Latest Update : 19 Nov 2019

What is Luxiren?


banner

Luxiren Is a powerful, beautiful and pixel-perfect landing page collection. Built with React, Next Js, Material UI, and Sketch files included. It's suitable for Corporate, Startup, Saas company, Agencies, Cloud business, Architect company, Freelancers, Personal portfolios, eCommerce shop, and any type of business to introduce and promote their profile, products, or services.

Luxiren provides you clean modern design along with dark mode to make it easy on your eyes. Beside that multi color scheme is the one of the best feature, so you will easly to adjust the theme with your brand identity. Not stop until that, this template also has RTL support and translation ready with 6 languages.

What's Inside?
This template contain 8 templates + starter-project. Designed for multipurpose industries including Agency, Architect, Cryptocurrency, Fashion, Hosting, Mobile, Portfolio and Saas. Those extraordinary things is supported by more than 80 components based on material-ui designs. That all for you to boost your web app development process. Luxiren is the template you will love to work on.

Template Feature


React + Next JS version

  • 8 landing page templates. Built with one of most popular javascript library React.JS, Material UI and Next.JS with SSR
  • Various modern design Agency, Architect, Cryptocurrency, Fashion, Hosting, Mobile, Portfolio and Saas
  • Premium designs. Simple and elegant multi color scheme
  • Dark Mode. Creative and modern design along with dark mode to make it easy on your eyes.
  • RTL Support.Auto RTL adjustment styling with jss-rtl
  • Support multilanguage. Including 6 translation English, Deutsch, Arabic, Chinese, Bahasa Indonesia, Español.
  • 80+ section components and UI modules which reusable and easy to modify.
  • Interactive and Attractive show. Stunning animation, parallax, scrolling effects, until video background will make your site wilder
  • Next Generation JavaScript written in ES6
  • Responsive design Based on standard 12 Grid System
  • Starter Project. Build app from scratch without without being distracted from innate feature.
  • Support mono repo, . Modern architecture to managing modules in multiple project.
  • High Performance. Styling with JSS (CSS in JS) and Async Code Splitting.
  • Clean code maintained by eslint.
  • Fully vector icons and font icons.
  • And many more...

Sketch Version

  • 8 elaborate high quality designs
  • Including Dark and Light version
  • Based on standard 12 Grid System
  • Fully Vector Icons
  • Easy to edit and well organized layers, and goups.

Files and Folder Structure


└── packages
    ├── agency-theme
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    ├── architect-theme
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    ├── crypto-theme
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    ├── fashion-theme
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    ├── hosting-theme
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    ├── mobile-apps-theme
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    ├── profile-theme
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    ├── saas-theme
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    ├── showcase
    │   ├── components
    │   ├── pages
    │   ├── static
    │   ├── theme
    │   └── vendors
    └── starter-project
        ├── components
        ├── pages
        ├── static
        ├── theme
        └── vendors                                                                  
                        

Installation and Running App


Luxiren is built on top of Material UI
  • Connect to the internet
  • Install NodeJs from NodeJs Official Page
  • Unzip the Luxiren file to a folder in your computer
  • Open Terminal
  • Go to your file project (where you've unzipped the product)
  • Go to packages and choose a template. Example packages/agency/
  • Install Modules
    Install module dependencies by run this script in terminal
    npm install
    It will download some necessary dependencies, and just wait until finish.
    process
  • For installation by use lerna, please check this link Installation using lerna
  • Run App
    After build installation complete, then run the app.
    npm run dev
    The process might take a moment.
    process
    INFO:
    - Just run this script whenever you want start the project.
    - Run npm install again if you have new module dependencies,
  • For agency template please navigate to http://localhost:3001
  • Here's the port list for each template
    Template Port Landing Page URL
    Starter Project 3000 http://localhost:3000
    Agency Theme 3001 http://localhost:3001
    Architect Theme 3002 http://localhost:3002
    Cryptocurrency Theme 3003 http://localhost:3003
    Fashion Theme 3004 http://localhost:3004
    Hosting Theme 3005 http://localhost:3005
    Mobile Apps Theme 3006 http://localhost:3006
    Portfolio Theme 3007 http://localhost:3007
    Saas Theme 3008 http://localhost:3008
    Showcase 3009 http://localhost:3009

Installation With Lerna

Lerna is A tool for managing JavaScript projects with multiple packages. This template has 10 packages(projects) inside packages/ folder. So to install them at once you can use lerna. See full docs of lerna here https://github.com/lerna/lerna. Here's the installation guide:

  • Let's start by installing Lerna globally with npm:
    npm install --global lerna
  • Go to your root project (where you've unzipped the product)
  • Then install all packages
    lerna bootstrap
    Note: This process will take some minutes, because there's lot of modules to be installed. If got stuck for this step. Please install the packages(projects) one by one by use npm install instead.

Deployment


Build project

  • Here'a bellow an example for agency-theme. You can use the same steps to other packages(projects)
  • First you need to build the production assets first
    npm run build
    It usually take longer time than development to generate and compress production code. The generated files will be placed in build/ process
  • Then start the app
    npm start
  • Then navigate to http://localhost:3001
  • Node: In Windows system you need to install win-node-env, because setting NODE_ENV=production before command babel doesn't work on Windows. Here's the packages https://www.npmjs.com/package/win-node-env



Run app in background process

If you want run it in background you may try PM2 pm2.keymetrics.io and https://www.npmjs.com/package/pm2. PM2 is a daemon process manager that will help you manage and keep your application online 24/7


  • Install the pm2 globally
    npm install pm2@latest -g
  • Go to project folder i.e packages/agency
  • Create ecosystem file
    pm2 ecosystem
    It will generate ecosystem.config.js in your root project
  • Open ecosystem.config.js. Then Change the script target to ./index.js like this:
                                      
    module.exports = {
      apps : [{
        name      : 'luxi-react', // Your project name
        script    : './index.js', // Change the script target to ./index.js
        env: {
          NODE_ENV: 'development'
        },
        env_production : {
          NODE_ENV: 'production'
        }
      }],
    
      deploy : {
        production : {
          user : 'node',
          host : '212.83.163.1',
          ref  : 'origin/master',
          repo : 'git@github.com:repo.git',
          path : '/var/www/production',
          'post-deploy' : 'npm install && pm2 reload ecosystem.config.js --env production'
        }
      }
    };
                                      
                                    
  • Run the project
    pm2 start ecosystem.config.js --env production
  • Then navigate to http://localhost:3001

Troublehooting


Here's most common error problem when installation and first setup project

  • if got warning like this :
    
    npm WARN slick-carousel@1.8.1 requires a peer of jquery@>=1.8.0 but none is installed. You must install peer dependencies yourself.
            
    Don't worry the app will run as well

    For warning some of dependencies need another dependencies too, maybe once you install them, there’s some changes from the 3rd party vendor so probably it will make a warning to another dependencies.

  • if got an error with a dependencies installation. Try to remove the all module node_modules/. Then install again with npm install. If error still happen, please try to remove the problematic package node_modules/ foler. After that try to install the problematic package manually. npm install ‹package_name› --save-dev
  • if still got an error. Try to update the problematic package instead.
  • If you get error messages when start project npm start like this
    ERROR in ./app/styles/layout/base.scss (./node_modules/css-loader/dist/cjs.js??ref--8-1!./node_modules/postcss-loader/src??ref--8-2!./node_modules/sass-loader/lib/loader.js??ref--8-3!./app/styles/layout/base.scss)
    Module build failed (from ./node_modules/sass-loader/lib/loader.js):
            
  • It mean the node-sass not installed succesfully. May because connection problem, changed node environment during installation, or blocked node-sass repository
  • Please install node-sass manually by npm install node-sass --save
  • Build dll libraries npm run build:dll
  • Try to start project again npm start
  • Once build finish you may get warning getInitialProps.
    Warning: You have opted-out of Automatic Prerendering due to `getInitialProps` in `pages/_app`.
    Read more: https://err.sh/next.js/opt-out-automatic-prerendering
            
  • It because this template use next.js eith custom _app. So just ignore this, that's Next.js telling you that all your pages will have SSR.
  • You will get this warning message if not use HTTPS
    A cookie associated with a resource at http://doubleclick.net/ was set with `SameSite=None` but without `Secure`. A future release of Chrome will only deliver cookies marked `SameSite=None` if they are also marked `Secure`. You can review cookies in developer tools under Application>Storage>Cookies and see more details at https://www.chromestatus.com/feature/5633521622188032.
            
    Here's the guide to setup HTTPS with NextJS:
  • Development: Every changes the code will show warning messages.
    
    Warning: Can't perform a React state update on an unmounted component. This is a no-op, but it indicates a memory leak in your application. To fix, cancel all subscriptions and asynchronous tasks in a useEffect cleanup function.
            
    It because window scrolling function with HMR. This message will show in development only, you can ignore it by reload the browser.


Basic Code Structure


Folder structure

project-theme                                                                            
│   ├───components                                                                          
│   ├───pages                                                                               
│   ├───static                                                                              
│   │   ├───favicons                                                                        
│   │   ├───images                                                                          
│   │   ├───locales                                                                       
│   │   └───text                                                                            
│   ├───theme                                                                               
│   └───vendors                                                                             
                        

Code preview



Landing Page

Landing page structure /pages/index.js

code

Header

You can put google analytics, font icon, embeded fonts, etc here. /components/header.js

code2

Document body

/pages/_document.js

code2


Directory Alias

This template use babel-plugin-root-import. So you can call any components or images from root project easly.

Name Alias Directory Sample Use
UI Components ~/components /components import Header from '~/components/Header';
Images ~/static/images static/images import imgAPI from '~/static/images/imgAPI';
Dummy text and link ~/static/text static/text import brand from '~/static/text/brand';
Component Style Overider ~/vendors /vendors import '~/vendors/slick/slick-theme.css';
And any your files ~/yourfolder /yourfolder import '~/yourfolder/file';



Template Architecture

This is template architecture in diagram visuailzation. Click diagram or full screen button full screen to show in new tab with full screen

Starter Project


This source code made for you who want build app from scratch without without being distracted from innate feature. In other word it's an initial(empty) project with built in configuration setup.

  • You can go through to /packages/starter-project/ folder
  • Connect to the internet
  • Open Terminal
  • The next installation process are same like was described above. Installation Step
  • Install module dependencies by run this script in terminal
    npm install
    It will download some necessary dependencies, it could take some minutes, just wait until finish.
  • Run App
    npm run dev

    process
    INFO:
    - Just run this script whenever you want start the project.
    - Run npm install again if you have new module dependencies,
  • Navigate to http://localhost:3000
  • After this you can can start develop your app with this initial project. And will bo more suitable when use other ready-template as a reference

UI and Languages


Follow this guide bellow to modify user interface, branding identity and default language.

Create New Page


  • In example we want to create an "About" page by adding the following content to pages/about.js:
  • 
    export default function About() {
      return (
        <div>
          <p>This is the about page</p>
         </div>
      );
    }
    
    Login.getInitialProps = async () => ({
      namespacesRequired: ['common'], // required for translation
    });
                                  
  • Then we can access that page with http://localhost:3000/about.




Create New Component


  • Go to /components/
  • Create new folder ex: MyComponent. The name must in capitalize
  • Create new js file inside that folder MyComponent, ex SampleComponent.js. The name must in capitalize
  • Inside the file create a simple ES6 Class ex:
    // file: /components/MyComponent/SampleComponent.js
    
    import React from 'react';
    
    function SampleComponent(){
        return (
          <H1>Hello World</H1>
        );
      }
    }
    
    export default SampleComponent;
    
    
  • Open a target page where you want use it. Ex: Open /pages/about.js. (Example page that we've made in previous section)
  • Import component form component library
    import SampleComponent from '~/components/MyComponent/SampleComponent.js'
  • Then use it inside render function
    render() {
      return (
        <SampleComponent />
      );
    }
                                
  • Here's complete code
    // file: app/containers/MyPage/SamplePage.js
    import React from 'react';
    import Head from 'next/head';
    import SampleComponent from '~/components/MyComponent/SampleComponent.js'
    
    export default function About() {
      return (
        <div>
          <Head>
            <title>
              { brand.crypto.name }
              &nbsp; - Blank page
            </title>
          </Head>
          <SampleComponent />
        </div>
      );
    }
    
    export default About;
    
    
  • Then you can check the result at http://localhost:3000/about

Clean Code with Eslint


Eslint is disabled by default. You can enable it to keep your code consistent and avoiding bug.
NOTE: By enable eslint the running app process at beginning will slower.

Just follow this step to enable eslint
  • Go to /next.config.js
  • Just uncomment this code bellow
    const withCSS = require('@zeit/next-css')
    const withImages = require('next-images');
    
    module.exports = withImages(
      withCSS({
        publicRuntimeConfig: {
          localeSubpaths: typeof process.env.LOCALE_SUBPATHS === 'string'
            ? process.env.LOCALE_SUBPATHS
            : 'none',
        },
        webpack: (config, options) => {
          cssModules: true,
          //      config.module.rules.push({
          //          enforce: 'pre',
          //          test: /\.js?$/,
          //          exclude: [/node_modules/],
          //          loader: 'eslint-loader',
          //          options: {
          //            quiet: true,
          //          }
          //      });
          config.node = {
            fs: 'empty'
          }
          return config;
        },
      })
    );
  • Then should become like this
    const withCSS = require('@zeit/next-css')
    const withImages = require('next-images');
    
    module.exports = withImages(
      withCSS({
        publicRuntimeConfig: {
          localeSubpaths: typeof process.env.LOCALE_SUBPATHS === 'string'
            ? process.env.LOCALE_SUBPATHS
            : 'none',
        },
        webpack: (config, options) => {
          cssModules: true,
          config.module.rules.push({
             enforce: 'pre',
             test: /\.js?$/,
             exclude: [/node_modules/],
             loader: 'eslint-loader',
             options: {
               quiet: true,
             }
          });
          config.node = {
            fs: 'empty'
          }
          return config;
        },
      })
    );
    
  • Run the project npm run dev.
    You will be notified with an error message if your code not clean or consistent. ESLint itself is a tool for identifying and reporting on patterns found in ECMAScript/JavaScript code, with the goal of making code more consistent and avoiding bugs.
    More about elint https://eslint.org/docs/user-guide/getting-started

External Reference

Here's some external reference of library that we used


Fonts Used




roboto font

Icons Used


To use icon, it has two method

Material Font Icons

  • Please make sure Google Material Icons already embeded in components/head.js.
    If not just embed this inside head tag
    <head>
          <link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet" />
    </head>
  • Connect to internet
  • Import Material UI Icon to your component
    import Icon from '@material-ui/core/Icon';
  • Then add it inside render method. Example for use access_time icon
    <Icon>access_time<Icon />



Material SVG Icons

It's interesting to have the building blocks needed to implement custom icons. This template use NPM package, @material-ui/icons, that includes the 900+ official Material icons converted to SvgIcon components.

  • Import all necessary icons form Material UI Icons library
    import AccessTime from '@material-ui/icons/AccessTime';
    import Adjust from '@material-ui/icons/Adjust';
    import BatteryStd from '@material-ui/icons/BatteryStd';
                                
  • Use them as component in render method
     render() {
      return (
        <div>
          <AccessTime />
          <Adjust />
          <BatteryStd />
        <div />
      );
    }
                                

Or from original source Google Material Icons




IonIcons Font

  • Please make sure IonIcons already embeded in components/head.js.
    If not just embed this inside head tag
    <head>
        <link href="http://code.ionicframework.com/ionicons/2.0.1/css/ionicons.min.css" rel="stylesheet" />
    </head>
  • Connect to internet
  • The sample usage
    
    <span className="ion-ios-world-outline" />  
                              
  • Here's the ionicons cheatsheet https://ionicons.com/v2/cheatsheet.html


  • Sources and Credit


    Fonts :
    Roboto, Robot Condensed, Lato, Open Sans, Montserrat

    Preview Images Used
    Unsplash
    Pixabay
    randomuser.me

    Note: All images are just used for Preview Purpose Only. They are not part of the template and NOT included in the final purchase files.


    Credits
    Name Repository License
    @babel.js https://github.com/babel/babel MIT
    @material-ui https://github.com/mui-org/material-ui MIT
    clsx https://www.npmjs.com/package/clsx MIT
    express https://github.com/expressjs/express MIT
    jss-rtl https://github.com/alitaheri/jss-rtl MIT
    material-ui-pickers https://github.com/dmtrKovalenko/material-ui-pickers MIT
    next.js https://nextjs.org/ MIT
    next-i18next https://www.npmjs.com/package/next-i18next MIT
    react https://github.com/facebook/react MIT
    react-countup https://github.com/glennreyes/react-countup MIT
    react-google-maps https://github.com/tomchentw/react-google-maps MIT
    react-loading-bar https://github.com/mironov/react-redux-loading-bar MIT
    react-material-ui-form-validator https://www.npmjs.com/package/react-material-ui-form-validator MIT
    react-slick https://github.com/akiran/react-slick MIT
    react-youtube https://www.npmjs.com/package/react-youtube MIT
    redux-form https://github.com/erikras/redux-form-material-ui MIT
    webpack https://github.com/webpack/webpack MIT

    Online Suport


    If you have any questions about customization of this template wich are not covered in the documentation feel free to ask a question in the comment section or contact me directly via e-mail form on my profile page.

    A product by Ilham Meidi Brata



    Enjoy and don’t forget to rate my template.

    Thank you very much!

    Change Log


    Version 1.0 – 19 Nov, 2019
    Luxiren released