index.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  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, Button } 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. class App extends Component {
  22. constructor(props) {
  23. super(props);
  24. this.state = {
  25. isOpen: false,
  26. };
  27. }
  28. static getInitialProps = ({ pathname }) => ({ pathname });
  29. toggleCollapse = () => {
  30. this.setState({
  31. isOpen: !this.state.isOpen,
  32. });
  33. };
  34. render() {
  35. return (
  36. <div>
  37. <Navbar className="navbar-color" expand="md" dark>
  38. <NavbarBrand href="/">
  39. <img className="img-fluid" src="/static/img/Logo-vputih.png" alt="App Logo" />
  40. <img className="img-text-vputih" src="/static/img/Logo-text-vputih.png" alt="App Logo" />
  41. </NavbarBrand>
  42. <NavbarToggler onClick={this.toggleCollapse} />
  43. <Collapse isOpen={this.state.isOpen} navbar>
  44. <Nav className="ml-auto" navbar>
  45. {menu.map((e) => (
  46. <NavItem active={e.path === this.props.pathname ? true : false}>
  47. <Link href={e.path}>
  48. <NavLink style={{ cursor: "pointer" }}>{e.title}</NavLink>
  49. </Link>
  50. </NavItem>
  51. ))}
  52. </Nav>
  53. </Collapse>
  54. </Navbar>
  55. <ContentWrapper>
  56. <Jumbotron>
  57. <Row>
  58. <Col lg={8} className="d-flex flex-column justify-content-center align-items-start">
  59. <h1 className="display-5">Sistem Informasi Pengendalian Kelembagaan Perguruan Tinggi pada Pendidikan Tinggi Akademik</h1>
  60. <p className="lead">Layanan Pelaporan Pelanggaran Perguruan Tinggi Penyelenggara Pendidikan Tinggi Akademik</p>
  61. <hr className="my-4" />
  62. <p>Disediakan kepada masyarakat untuk melaporkan pelanggaran perguruan tinggi yang menyelenggarakan pendidikan tinggi akademik</p>
  63. <p className="lead">
  64. {/* <Link href="/laporan/new">
  65. <button className="btn btn-info btn-lg"><img className="icon-buatlaporan" src="/static/img/icon-buat-laporan.png" alt="icon"/>Buat Laporan</button>
  66. </Link> */}
  67. <Link href="/laporan/new">
  68. <Button color="info" className="btn-labeled">
  69. <span className="btn-label">
  70. <img className="icon-buatlaporan" src="/static/img/icon-buat-laporan.png" alt="icon" />
  71. </span>
  72. <text className="text-home-1">Buat Laporan</text>
  73. </Button>
  74. </Link>
  75. <Link href="/pemantauan">
  76. <Button color="info" className="btn-labeled-2">
  77. <span className="btn-label">
  78. <img className="icon-pemantauan" src="/static/img/icon-pemantauan.png" alt="icon" />
  79. </span>
  80. <text className="text-home-1">Pemantauan</text>
  81. </Button>
  82. </Link>
  83. </p>
  84. </Col>
  85. <Col>
  86. <Login />
  87. </Col>
  88. </Row>
  89. </Jumbotron>
  90. </ContentWrapper>
  91. </div>
  92. );
  93. }
  94. }
  95. App.Layout = BasePage;
  96. export default App;