Skip to content

Commit

Permalink
feat: Wire up design settings (button colour)
Browse files Browse the repository at this point in the history
  • Loading branch information
DafyddLlyr committed Jan 16, 2024
1 parent 148f9c0 commit 6f06ae0
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 14 deletions.
Original file line number Diff line number Diff line change
@@ -1,23 +1,59 @@
import Button from "@mui/material/Button";
import Link from "@mui/material/Link";
import { darken, getContrastRatio, useTheme } from "@mui/material/styles";
import { Team, TeamTheme } from "@opensystemslab/planx-core/types";
import { useFormik } from "formik";
import React from "react";
import { useStore } from "pages/FlowEditor/lib/store";
import React, { useEffect, useState } from "react";
import { getContrastTextColor } from "styleUtils";
import ColorPicker from "ui/editor/ColorPicker";
import InputDescription from "ui/editor/InputDescription";
import InputRow from "ui/shared/InputRow";
import InputRowItem from "ui/shared/InputRowItem";

import { DesignPreview, EXAMPLE_COLOUR, SettingsForm } from ".";
import { DesignPreview, SettingsForm } from ".";

export const ButtonForm: React.FC = () => {
const formik = useFormik<{
buttonColor: string;
}>({
initialValues: {
buttonColor: EXAMPLE_COLOUR,
type FormValues = Pick<TeamTheme, "actionColour">;

export const ButtonForm: React.FC<{ team: Team; onSuccess: () => void }> = ({
team,
onSuccess,
}) => {
const theme = useTheme();

useEffect(() => {
setInitialValues({ actionColour: team.theme?.actionColour });
}, [team]);

const [initialValues, setInitialValues] = useState<FormValues>({
actionColour: "",
});

const formik = useFormik<FormValues>({
initialValues,
onSubmit: async (values, { resetForm }) => {
const isSuccess = await useStore.getState().updateTeamTheme(values);
if (isSuccess) {
onSuccess();
// Reset "dirty" status to disable Save & Reset buttons
resetForm({ values });
}
},
validateOnBlur: false,
validateOnChange: false,
enableReinitialize: true,
validate: ({ actionColour }) => {
const isContrastThresholdMet =
getContrastRatio("#FFF", actionColour) >
theme.palette.contrastThreshold;

if (!isContrastThresholdMet) {
return {
primaryColour:
"Theme colour does not meet accessability contrast requirements (3:1)",
};
}
},
onSubmit: () => {},
validate: () => {},
});

return (
Expand All @@ -42,16 +78,29 @@ export const ButtonForm: React.FC = () => {
<InputRow>
<InputRowItem>
<ColorPicker
color={formik.values.buttonColor}
onChange={(color) => formik.setFieldValue("buttonColor", color)}
color={formik.values.actionColour}
onChange={(color) => formik.setFieldValue("actionColour", color)}
label="Button colour"
/>
</InputRowItem>
</InputRow>
}
preview={
<DesignPreview bgcolor="white">
<Button variant="contained" sx={{ backgroundColor: EXAMPLE_COLOUR }}>
<Button
variant="contained"
sx={{
backgroundColor: formik.values.actionColour,
color: formik.values.actionColour
? getContrastTextColor(formik.values.actionColour, "#FFF")
: "#FFF",
"&:hover": {
backgroundColor: formik.values.actionColour
? darken(formik.values.actionColour, 0.2)
: theme.palette.prompt.dark,
},
}}
>
Example primary button
</Button>
</DesignPreview>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,7 @@ const DesignSettings: React.FC = () => {
) : (
<>
<ThemeAndLogoForm team={team} onSuccess={() => setOpen(true)} />
<ButtonForm />
<ButtonForm team={team} onSuccess={() => setOpen(true)} />
<TextLinkForm />
<FaviconForm />
<Snackbar open={open} autoHideDuration={6000} onClose={handleClose}>
Expand Down

0 comments on commit 6f06ae0

Please sign in to comment.