Home Bootstrap Create Marketing Admin Dashboard Template in React js

Create Marketing Admin Dashboard Template in React js

by therichpost
0 comments
Create Marketing Admin Dashboard Template in React js

Hello guys how are you? Welcome back to my blog. Today in this blog post we will create Create Marketing Admin Dashboard Template in React js.

  1. Reactjs
  2. Bootstrap 5
  3. Login page with auth Token functionality
  4. Admin Dashboard Page
  5. Chart.js
  6. Burger Menu
  7. Developer-friendly Codebase
  8. Cross-browser Compatible
  9. 100% Responsive
  10. Toggle Sidebar
Live demo
  1. Reactjs Tutorials
  2. Bootstrap 5
  3. React Free Ecommerce Templates
  4. React Free Admins

Here’s a basic implementation:

First, create a new React project, install Bootstrap 5, Charts, Font awesome:

npx create-react-app marketing-dashboard
cd marketing-dashboard
npm install bootstrap react-router-dom
npm install react-chartjs-2 chart.js
npm install chart.js@latest  
npm install @fortawesome/fontawesome-svg-core @fortawesome/free-solid-svg-icons @fortawesome/react-fontawesome  

Organize your project structure as follows:

project structure
project structure

Sidebar.js

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

const Sidebar = ({ isOpen }) => {
  return (
    <div className={`sidebar ${isOpen ? 'open' : 'closed'}`}>
      <div className="d-flex flex-column p-3 bg-light" style={{ height: '100vh' }}>
        <h5 className="d-flex align-items-center mb-3 mb-md-0 me-md-auto">Marketing Admin</h5>
        <hr />
        <ul className="nav nav-pills flex-column mb-auto">
          <li className="nav-item">
            <Link to="/dashboard" className="nav-link">Dashboard</Link>
          </li>
          <li>
            <Link to="/analytics" className="nav-link">Analytics</Link>
          </li>
          <li>
            <Link to="/campaigns" className="nav-link">Campaigns</Link>
          </li>
        </ul>
      </div>
    </div>
  );
};

export default Sidebar;

CampaignPerformance.js

import React from 'react';

const CampaignPerformance = () => {
  const campaigns = [
    { name: 'Campaign 1', clicks: 1500, conversions: 300 },
    { name: 'Campaign 2', clicks: 1200, conversions: 250 },
    { name: 'Campaign 3', clicks: 900, conversions: 150 },
  ];

  return (
    <div className="card mb-4">
      <div className="card-body">
        <h5 className="card-title">Campaign Performance</h5>
        <table className="table">
          <thead>
            <tr>
              <th scope="col">Campaign</th>
              <th scope="col">Clicks</th>
              <th scope="col">Conversions</th>
            </tr>
          </thead>
          <tbody>
            {campaigns.map((campaign, index) => (
              <tr key={index}>
                <td>{campaign.name}</td>
                <td>{campaign.clicks}</td>
                <td>{campaign.conversions}</td>
              </tr>
            ))}
          </tbody>
        </table>
      </div>
    </div>
  );
};

export default CampaignPerformance;

Chart.js

import React from 'react';
import { Line } from 'react-chartjs-2';
import {
  Chart as ChartJS,
  CategoryScale,
  LinearScale,
  PointElement,
  LineElement,
  Title,
  Tooltip,
  Legend,
} from 'chart.js';

ChartJS.register(
  CategoryScale,
  LinearScale,
  PointElement,
  LineElement,
  Title,
  Tooltip,
  Legend
);

const Chart = () => {
  const data = {
    labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],
    datasets: [
      {
        label: 'Sales',
        data: [65, 59, 80, 81, 56, 55, 40],
        fill: false,
        backgroundColor: 'rgba(75,192,192,0.2)',
        borderColor: 'rgba(75,192,192,1)',
      },
    ],
  };

  const options = {
    responsive: true,
    plugins: {
      legend: {
        display: true,
      },
      title: {
        display: true,
        text: 'Sales Chart',
      },
    },
    scales: {
      y: {
        beginAtZero: true,
      },
    },
  };

  return (
    <div className="card">
      <div className="card-body">
        <h5 className="card-title">Sales Chart</h5>
        <Line data={data} options={options} />
      </div>
    </div>
  );
};

export default Chart;

Footer.css

.footer {
    background-color: #f8f9fa;
    border-top: 1px solid #e7e7e7;
  }
  
  .footer .text-muted {
    color: #6c757d !important;
  }
  
  .footer a {
    color: #6c757d;
    text-decoration: none;
  }
  
  .footer a:hover {
    text-decoration: underline;
  }
  

Footer.js

import React from 'react';
import './Footer.css';

const Footer = () => {
  return (
    <footer className="footer mt-auto py-3 bg-light">
      <div className="container">
        <div className="row">
          <div className="col-md-6">
            <span className="text-muted">&copy; 2024 Your Company</span>
          </div>
          <div className="col-md-6 text-md-end">
            <a href="#" className="text-muted me-3">Privacy Policy</a>
            <a href="#" className="text-muted">Terms of Service</a>
          </div>
        </div>
      </div>
    </footer>
  );
};

export default Footer;

Navbar.js

import React from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faBell, faEnvelope, faBars, faSignOutAlt } from '@fortawesome/free-solid-svg-icons';

const Navbar = ({ toggleSidebar, handleLogout }) => {
  return (
    <nav className="navbar navbar-light bg-light">
      <div className="container-fluid d-flex justify-content-between">
        <button className="btn btn-link" onClick={toggleSidebar}>
          <FontAwesomeIcon icon={faBars} size="lg" />
        </button>
        <span className="navbar-brand mb-0 h1">Marketing Dashboard</span>
        <div className="d-flex align-items-center">
          <div className="position-relative me-3">
            <FontAwesomeIcon icon={faEnvelope} size="lg" />
            <span className="position-absolute top-0 start-100 translate-middle badge rounded-pill bg-danger">
              3
              <span className="visually-hidden">unread messages</span>
            </span>
          </div>
          <div className="position-relative me-3">
            <FontAwesomeIcon icon={faBell} size="lg" />
            <span className="position-absolute top-0 start-100 translate-middle badge rounded-pill bg-danger">
              5
              <span className="visually-hidden">unread notifications</span>
            </span>
          </div>
          <button className="btn btn-link" onClick={handleLogout}>
            <FontAwesomeIcon icon={faSignOutAlt} size="lg" />
          </button>
        </div>
      </div>
    </nav>
  );
};

export default Navbar;

RecentActivities.js

import React from 'react';

const RecentActivities = () => {
  const activities = [
    { id: 1, description: 'User A signed up', time: '2 hours ago' },
    { id: 2, description: 'User B subscribed to newsletter', time: '1 day ago' },
    { id: 3, description: 'Campaign 1 launched', time: '3 days ago' },
  ];

  return (
    <div className="card mb-4">
      <div className="card-body">
        <h5 className="card-title">Recent Activities</h5>
        <ul className="list-group list-group-flush">
          {activities.map((activity) => (
            <li className="list-group-item" key={activity.id}>
              {activity.description} - <small>{activity.time}</small>
            </li>
          ))}
        </ul>
      </div>
    </div>
  );
};

export default RecentActivities;

Sidebar.css

.sidebar {
    width: 250px;
    transition: width 0.3s;
    overflow: hidden;
  }
  
  .sidebar.closed {
    width: 0;
  }
  
  .sidebar .nav-link {
    white-space: nowrap;
  }
  
  .sidebar .nav-item {
    display: block;
  }
  

Table.js

import React from 'react';

const Table = () => {
  return (
    <div className="card">
      <div className="card-body">
        <h5 className="card-title">Table</h5>
        <table className="table">
          <thead>
            <tr>
              <th scope="col">#</th>
              <th scope="col">First</th>
              <th scope="col">Last</th>
              <th scope="col">Handle</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <th scope="row">1</th>
              <td>Mark</td>
              <td>Otto</td>
              <td>@mdo</td>
            </tr>
            <tr>
              <th scope="row">2</th>
              <td>Jacob</td>
              <td>Thornton</td>
              <td>@fat</td>
            </tr>
          </tbody>
        </table>
      </div>
    </div>
  );
};

export default Table;

UserDemographics.js

import React from 'react';
import { Pie } from 'react-chartjs-2';
import {
  Chart as ChartJS,
  ArcElement,
  Tooltip,
  Legend,
} from 'chart.js';

ChartJS.register(ArcElement, Tooltip, Legend);

const UserDemographics = () => {
  const data = {
    labels: ['Male', 'Female', 'Other'],
    datasets: [
      {
        data: [300, 450, 50],
        backgroundColor: ['#36A2EB', '#FF6384', '#FFCE56'],
        hoverBackgroundColor: ['#36A2EB', '#FF6384', '#FFCE56'],
      },
    ],
  };

  return (
    <div className="card mb-4">
      <div className="card-body">
        <h5 className="card-title">User Demographics</h5>
        <Pie data={data} />
      </div>
    </div>
  );
};

export default UserDemographics;

Analytics.js

import React from 'react';

const Analytics = () => {
  return (
    <div>
      <h2>Analytics</h2>
      <p>Analytics content goes here.</p>
    </div>
  );
};

export default Analytics;

Campaigns.js

import React from 'react';

const Campaigns = () => {
  return (
    <div>
      <h2>Campaigns</h2>
      <p>Campaigns content goes here.</p>
    </div>
  );
};

export default Campaigns;

Dashboard.css

.dashboard-container {
    padding: 20px;
    background-color: #f8f9fa;
  }
  
  .dashboard-container h2 {
    font-size: 24px;
    font-weight: 700;
    color: #333;
  }
  
  .card {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    border: none;
    margin-bottom: 20px;
  }
  
  .card .card-body {
    padding: 20px;
  }
  
  .card-title {
    font-size: 18px;
    font-weight: 600;
    color: #333;
  }
  
  .table th, .table td {
    vertical-align: middle;
  }
  
  .table {
    margin-bottom: 0;
  }
  

Dashboard.js

import React from 'react';
import Chart from '../components/Chart';
import Table from '../components/Table';
import CampaignPerformance from '../components/CampaignPerformance';
import RecentActivities from '../components/RecentActivities';
import UserDemographics from '../components/UserDemographics';
import './Dashboard.css';

const Dashboard = () => {
  return (
    <div className="dashboard-container">
      <h2 className="mb-4">Dashboard</h2>
      <div className="row mb-4">
        <div className="col-md-6 mb-4">
          <div className="card border-primary">
            <div className="card-body">
              <Chart />
            </div>
          </div>
        </div>
        <div className="col-md-6 mb-4">
          <div className="card border-success">
            <div className="card-body">
              <CampaignPerformance />
            </div>
          </div>
        </div>
      </div>
      <div className="row mb-4">
        <div className="col-md-6 mb-4">
          <div className="card border-warning">
            <div className="card-body">
              <RecentActivities />
            </div>
          </div>
        </div>
        <div className="col-md-6 mb-4">
          <div className="card border-danger">
            <div className="card-body">
              <UserDemographics />
            </div>
          </div>
        </div>
      </div>
      <div className="row">
        <div className="col-12">
          <div className="card border-info">
            <div className="card-body">
              <Table />
            </div>
          </div>
        </div>
      </div>
    </div>
  );
};

export default Dashboard;

Login.css

.login-container {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100vh;
    background-color: #f8f9fa;
  }
  
  .login-form {
    width: 100%;
    max-width: 400px;
    padding: 20px;
    border: 1px solid #ddd;
    border-radius: 8px;
    background-color: #fff;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  }
  
  .login-form h2 {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 20px;
    color: #333;
  }
  
  .login-form .form-label {
    font-weight: 600;
  }
  

Login.js

Ensure that the Login component correctly sets the isAuthenticated state when the user logs in.

import React, { useState } from 'react';
import { useNavigate } from 'react-router-dom';
import './Login.css';

const Login = ({ setIsAuthenticated }) => {
  const [email, setEmail] = useState('');
  const [password, setPassword] = useState('');
  const navigate = useNavigate();

  const handleLogin = (e) => {
    e.preventDefault();
    // Add your authentication logic here
    if (email === 'admin@example.com' && password === 'password') {
      setIsAuthenticated(true);
      navigate('/dashboard');
    } else {
      alert('Invalid credentials');
    }
  };

  return (
    <div className="login-container">
      <form onSubmit={handleLogin} className="login-form">
        <h2 className="mb-4">Login</h2>
        <div className="mb-3">
          <label htmlFor="email" className="form-label">Email address</label>
          <input
            type="email"
            className="form-control"
            id="email"
            value={email}
            onChange={(e) => setEmail(e.target.value)}
            required
          />
        </div>
        <div className="mb-3">
          <label htmlFor="password" className="form-label">Password</label>
          <input
            type="password"
            className="form-control"
            id="password"
            value={password}
            onChange={(e) => setPassword(e.target.value)}
            required
          />
        </div>
        <button type="submit" className="btn btn-primary">Login</button>
      </form>
    </div>
  );
};

export default Login;
import React, { useState } from 'react';
import { BrowserRouter as Router, Route, Routes, Navigate } from 'react-router-dom';
import Sidebar from './components/Sidebar';
import Navbar from './components/Navbar';
import Footer from './components/Footer';
import Dashboard from './pages/Dashboard';
import Analytics from './pages/Analytics';
import Campaigns from './pages/Campaigns';
import Login from './pages/Login';

import 'bootstrap/dist/css/bootstrap.min.css';

const App = () => {
  const [isAuthenticated, setIsAuthenticated] = useState(false);
  const [isSidebarOpen, setIsSidebarOpen] = useState(true);

  const toggleSidebar = () => {
    setIsSidebarOpen(!isSidebarOpen);
  };

  const handleLogout = () => {
    setIsAuthenticated(false);
  };

  const PrivateRoute = ({ element }) => {
    return isAuthenticated ? element : <Navigate to="/login" />;
  };

  return (
    <Router>
      <div className="d-flex flex-column min-vh-100">
        <div className="d-flex flex-grow-1">
          {isAuthenticated && <Sidebar isOpen={isSidebarOpen} />}
          <div className="flex-grow-1">
            {isAuthenticated && <Navbar toggleSidebar={toggleSidebar} handleLogout={handleLogout} />}
            <div className="container mt-3">
              <Routes>
                <Route path="/login" element={<Login setIsAuthenticated={setIsAuthenticated} />} />
                <Route path="/dashboard" element={<PrivateRoute element={<Dashboard />} />} />
                <Route path="/analytics" element={<PrivateRoute element={<Analytics />} />} />
                <Route path="/campaigns" element={<PrivateRoute element={<Campaigns />} />} />
                <Route path="/" element={<Navigate to="/login" />} />
              </Routes>
            </div>
          </div>
        </div>
        <Footer />
      </div>
    </Router>
  );
};

export default App;

Now, run your project using:

npm start

Your dashboard should now display a real chart using react-chartjs-2. You can further customize the chart by modifying the data and options in the Chart.js component.

This setup provides a basic example of integrating a real chart into your marketing admin dashboard. You can add more types of charts and customize them as needed to fit your specific requirements.

This is it guys and if you will have any kind of query, suggestion or requirement then feel free to comment below.

Thanks

Ajay

You may also like

Leave a Comment

This site uses Akismet to reduce spam. Learn how your comment data is processed.