diff --git a/frontend/.env.sample b/frontend/.env.sample new file mode 100644 index 000000000..04fe2efd4 --- /dev/null +++ b/frontend/.env.sample @@ -0,0 +1 @@ +NEXT_PUBLIC_BACKEND_URL=http://localhost:8000 diff --git a/frontend/.eslintrc.json b/frontend/.eslintrc.json index 7d9c5af0a..247a7b4d9 100755 --- a/frontend/.eslintrc.json +++ b/frontend/.eslintrc.json @@ -1,6 +1,6 @@ { "extends": [ - "next/core-web-vitals", + "next/core-web-vitals", "plugin:react/recommended" ], "parserOptions": { @@ -11,5 +11,7 @@ "sourceType": "module" }, "plugins": ["react"], - "rules": {} + "rules": { + "react/react-in-jsx-scope": "off" + } } diff --git a/frontend/README.md b/frontend/README.md index b12f3e33e..267e59d56 100755 --- a/frontend/README.md +++ b/frontend/README.md @@ -2,7 +2,13 @@ This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next ## Getting Started -First, run the development server: +Copy the .env.sample file to .env.local: + +```bash +cp .env.sample .env.local +``` + +Next run the development server: ```bash npm run dev diff --git a/frontend/components/Buttons/Button.test.js b/frontend/components/Buttons/Button.test.js index 3d8f6e82d..34f2e5a87 100644 --- a/frontend/components/Buttons/Button.test.js +++ b/frontend/components/Buttons/Button.test.js @@ -88,14 +88,18 @@ describe("Button", () => { }); describe("rendering an Icon outside of a button", () => { + afterAll(jest.restoreAllMocks); + it("throws an error", () => { + jest.spyOn(console, "error").mockImplementation(() => jest.fn()); + expect(() => { render(
Something
); - }).toThrow(/must be used within a Button/); + }).toThrow(); }); }); }); diff --git a/frontend/components/Buttons/HolonButton.js b/frontend/components/Buttons/HolonButton.js index 19a2c595c..ee5a99611 100644 --- a/frontend/components/Buttons/HolonButton.js +++ b/frontend/components/Buttons/HolonButton.js @@ -1,21 +1,22 @@ import React, { createContext, useContext } from "react"; +import PropTypes from "prop-types"; const variants = { darkmode: - "border-white text-white bg-holon-blue-900 shadow-holon-white hover:translate-x-holon-bh-x hover:translate-y-holon-bh-y hover:bg-holon-blue-500 hover:shadow-holon-white-hover", - gold: "bg-holon-gold-200 border-holon-blue-900 shadow-holon-blue hover:translate-x-holon-bh-x hover:translate-y-holon-bh-y hover:bg-holon-gold-600 hover:shadow-holon-blue-hover", - blue: "bg-holon-blue-200 border-holon-blue-900 shadow-holon-blue hover:translate-x-holon-bh-x hover:translate-y-holon-bh-y hover:bg-holon-blue-500 hover:shadow-holon-blue-hover hover:text-white", + "border-white text-white bg-holon-blue-900 shadow-holon-white enabled:hover:bg-holon-blue-500 enabled:active:shadow-holon-white-hover", + gold: "bg-holon-gold-200 border-holon-blue-900 shadow-holon-blue hover:bg-holon-gold-600 active:shadow-holon-blue-hover", + blue: "bg-holon-blue-200 border-holon-blue-900 shadow-holon-blue hover:bg-holon-blue-500 active:shadow-holon-blue-hover hover:text-white", darkblue: - "text-white bg-holon-blue-500 border-holon-blue-900 shadow-holon-blue hover:translate-x-holon-bh-x hover:translate-y-holon-bh-y hover:bg-holon-blue-900 hover:shadow-holon-blue-hover", + "text-white bg-holon-blue-500 border-holon-blue-900 shadow-holon-blue hover:bg-holon-blue-900 active:shadow-holon-blue-hover", }; const ButtonContext = createContext(); -export default function Button({ children, variant = "darkmode", ...rest }) { +export default function Button({ children, className, variant = "darkmode", ...rest }) { const colorClasses = variants[variant] || variants.darkmode; return (