No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.
 
 

109 líneas
3.3 KiB

  1. import React from "react";
  2. import classNames from "classnames";
  3. import { makeStyles } from "@material-ui/core/styles";
  4. import Header from "components/Header/Header.js";
  5. import HeaderLinks from "components/Header/HeaderLinks.js";
  6. import Parallax from "components/Parallax/Parallax.js";
  7. import styles from "assets/jss/nextjs-material-kit/pages/components.js";
  8. import Footer from "components/Footer/Footer.js";
  9. import GetbusinessPartners from "../../api/home/businessPartner.js";
  10. import Getservices from "../../api/home/service.js";
  11. import Getcarousels from "../../api/home/carousel.js";
  12. import DataSnackbarContent from "../../pages-sections/yamaha/snackbar.js";
  13. import DataCarousel from "../../pages-sections/yamaha/home/carousel.js";
  14. import DataService from "../../pages-sections/yamaha/home/service.js";
  15. import DataBusinessPartner from "../../pages-sections/yamaha/home/business_partner.js";
  16. import DataSosmed from "../../pages-sections/yamaha/home/sosmed.js";
  17. import CoreValue from "../../pages-sections/yamaha/home/core_value.js";
  18. import DataFeature from "../../pages-sections/yamaha/home/feature.js";
  19. import stylecss from "pages/home.css";
  20. import Cookies from "cookies";
  21. const useStyles = makeStyles(styles);
  22. const Home = function ({
  23. backend,
  24. businessPartners,
  25. service,
  26. carousel,
  27. user,
  28. ...props
  29. }) {
  30. const classes = useStyles();
  31. const { ...rest } = props;
  32. <DataService service={props.service} />;
  33. return (
  34. <div>
  35. <Header
  36. rightLinks={<HeaderLinks username={user} />}
  37. fixed
  38. color="dark"
  39. changeColorOnScroll={{
  40. height: 400,
  41. color: "white",
  42. }}
  43. {...rest}
  44. />
  45. <Parallax
  46. image={require("assets/img/Promotion_2-1.jpg")}
  47. styles={{ marginTop: "50px" }}
  48. />
  49. <div className={classNames(classes.main, classes.mainRaised)}>
  50. <DataSnackbarContent />
  51. <DataCarousel carousel={carousel} backend={backend} />
  52. <DataService service={service} backend={backend} />
  53. <DataFeature />
  54. <a href="https://wa.me/087797315685" target="_blank" class="float">
  55. <i class="fa fa-phone my-float"></i>
  56. </a>
  57. </div>
  58. <Footer />
  59. </div>
  60. );
  61. };
  62. export async function getServerSideProps(context) {
  63. var businessPartners = [];
  64. var service = [];
  65. var carousel = [];
  66. const backend = process.env.BACKEND_SERVER_URI;
  67. var { req, resp } = context;
  68. const cookies = new Cookies(req, resp);
  69. var user = "";
  70. var userObj = (await cookies.get("user"))
  71. ? JSON.parse(await cookies.get("user"))
  72. : null;
  73. if (userObj) {
  74. let sessionId = userObj["partners_login_states"].filter(function (i) {
  75. return (
  76. i.business_partner && i.business_partner.name.toUpperCase() == "YAMAHA"
  77. );
  78. });
  79. if (sessionId.length != 0) user = userObj["username"];
  80. }
  81. var res = await GetbusinessPartners.GetbusinessPartners();
  82. if (res["STATUS"] === 1) {
  83. businessPartners = res["DATA"]["businessPartners"];
  84. }
  85. var res = await Getservices.GetservicesYamaha();
  86. if (res["STATUS"] === 1) {
  87. service = res["DATA"]["services"];
  88. }
  89. var res = await Getcarousels.GetCarouselsYamaha();
  90. if (res["STATUS"] === 1) {
  91. carousel = res["DATA"]["carousels"];
  92. }
  93. return {
  94. props: { businessPartners, service, carousel, backend, user }, // will be passed to the page component as props
  95. };
  96. }
  97. export default Home;