index.js 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. import React, { Component } from "react";
  2. import BasePage from "@/components/Layout/BasePage";
  3. import { Row, Col, Navbar, NavItem, NavLink, NavbarBrand, NavbarToggler, Nav, Collapse, Jumbotron } from "reactstrap";
  4. import ContentWrapper from "@/components/Layout/ContentWrapper";
  5. import Link from "next/link";
  6. import Login from "@/components/Main/Login";
  7. const menu = [
  8. {
  9. title: "Home",
  10. path: "/app",
  11. },
  12. {
  13. title: "Buat Laporan",
  14. path: "/laporan/new",
  15. },
  16. {
  17. title: "Pemantauan",
  18. path: "/pemantauan",
  19. },
  20. {
  21. title: "Login",
  22. path: "/login",
  23. },
  24. ];
  25. class App extends Component {
  26. constructor(props) {
  27. super(props);
  28. this.state = {
  29. isOpen: false,
  30. };
  31. }
  32. static getInitialProps = ({ pathname }) => ({ pathname });
  33. toggleCollapse = () => {
  34. this.setState({
  35. isOpen: !this.state.isOpen,
  36. });
  37. };
  38. render() {
  39. return (
  40. <div>
  41. <Navbar color="info" expand="md" dark>
  42. <NavbarBrand href="/">
  43. <img className="img-fluid" src="/static/img/logo-single.png" alt="App Logo" /> Sidali Dikti
  44. </NavbarBrand>
  45. <NavbarToggler onClick={this.toggleCollapse} />
  46. <Collapse isOpen={this.state.isOpen} navbar>
  47. <Nav className="ml-auto" navbar>
  48. {menu.map((e) => (
  49. <NavItem active={e.path === this.props.pathname ? true : false}>
  50. <Link href={e.path}>
  51. <NavLink style={{ cursor: "pointer" }}>{e.title}</NavLink>
  52. </Link>
  53. </NavItem>
  54. ))}
  55. </Nav>
  56. </Collapse>
  57. </Navbar>
  58. <ContentWrapper>
  59. <Jumbotron>
  60. <Row>
  61. <Col lg={8} className="d-flex flex-column justify-content-center align-items-start">
  62. <h1 className="display-5">Sistem Informasi Pengendalian Kelembagaan Perguruan Tinggi pada Pendidikan Tinggi Akademik</h1>
  63. <p className="lead">Layanan Pelaporan Pelanggaran Perguruan Tinggi Penyelenggara Pendidikan Tinggi Akademik</p>
  64. <hr className="my-4" />
  65. <p>Disediakan kepada masyarakat untuk melaporkan pelanggaran perguruan tinggi yang menyelenggarakan pendidikan tinggi akademik</p>
  66. <p className="lead">
  67. <Link href="/laporan/new">
  68. <button className="btn btn-info btn-lg">Buat Laporan</button>
  69. </Link>
  70. </p>
  71. </Col>
  72. <Col>
  73. <Login />
  74. </Col>
  75. </Row>
  76. </Jumbotron>
  77. </ContentWrapper>
  78. </div>
  79. );
  80. }
  81. }
  82. App.Layout = BasePage;
  83. export default App;