Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
 
 

111 wiersze
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 Cookies from "cookies";
  20. const useStyles = makeStyles(styles);
  21. const Home = function ({
  22. backend,
  23. businessPartners,
  24. service,
  25. carousel,
  26. user,
  27. ...props
  28. }) {
  29. const classes = useStyles();
  30. const { ...rest } = props;
  31. <DataService service={props.service} />;
  32. return (
  33. <div>
  34. <Header
  35. rightLinks={<HeaderLinks username={user} />}
  36. fixed
  37. color="dark"
  38. changeColorOnScroll={{
  39. height: 400,
  40. color: "white",
  41. }}
  42. {...rest}
  43. />
  44. <Parallax
  45. image={require("assets/img/Promotion_2-1.jpg")}
  46. styles={{ marginTop: "50px" }}
  47. />
  48. <div className={classNames(classes.main, classes.mainRaised)}>
  49. <DataSnackbarContent />
  50. {/* <CoreValue /> */}
  51. <DataCarousel carousel={carousel} backend={backend} />
  52. <DataService service={service} backend={backend} />
  53. <DataFeature />
  54. {/* <DataBusinessPartner
  55. businessPartners={businessPartners}
  56. backend={backend}
  57. /> */}
  58. {/* <DataSosmed /> */}
  59. </div>
  60. <Footer />
  61. </div>
  62. );
  63. };
  64. export async function getServerSideProps(context) {
  65. var businessPartners = [];
  66. var service = [];
  67. var carousel = [];
  68. const backend = process.env.BACKEND_SERVER_URI;
  69. var { req, resp } = context;
  70. const cookies = new Cookies(req, resp);
  71. var user = "";
  72. var userObj = (await cookies.get("user"))
  73. ? JSON.parse(await cookies.get("user"))
  74. : null;
  75. if (userObj) {
  76. let sessionId = userObj["partners_login_states"].filter(function (i) {
  77. return (
  78. i.business_partner && i.business_partner.name.toUpperCase() == "YAMAHA"
  79. );
  80. });
  81. if (sessionId.length != 0) user = userObj["username"];
  82. }
  83. var res = await GetbusinessPartners.GetbusinessPartners();
  84. if (res["STATUS"] === 1) {
  85. businessPartners = res["DATA"]["businessPartners"];
  86. }
  87. var res = await Getservices.GetservicesYamaha();
  88. if (res["STATUS"] === 1) {
  89. service = res["DATA"]["services"];
  90. }
  91. var res = await Getcarousels.GetCarouselsYamaha();
  92. if (res["STATUS"] === 1) {
  93. carousel = res["DATA"]["carousels"];
  94. }
  95. return {
  96. props: { businessPartners, service, carousel, backend, user }, // will be passed to the page component as props
  97. };
  98. }
  99. export default Home;