Skip to content

Commit

Permalink
Merge pull request #81 from cabcookie/cabcookie/issue80
Browse files Browse the repository at this point in the history
UI auf shadcn/ui und Tailwind CSS umstellen
  • Loading branch information
cabcookie authored May 28, 2024
2 parents 7ce137f + e9b0a13 commit ef6130a
Show file tree
Hide file tree
Showing 142 changed files with 13,395 additions and 23,269 deletions.
1 change: 0 additions & 1 deletion .eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@
},
"extends": [
"next/core-web-vitals",
"plugin:storybook/recommended",
"eslint:recommended",
"plugin:@typescript-eslint/recommended",
"plugin:prettier/recommended"
Expand Down
35 changes: 0 additions & 35 deletions .storybook/main.ts

This file was deleted.

16 changes: 0 additions & 16 deletions .storybook/preview.ts

This file was deleted.

4 changes: 3 additions & 1 deletion .vscode/extensions.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
"recommendations": [
"esbenp.prettier-vscode",
"dbaeumer.vscode-eslint",
"davidanson.vscode-markdownlint"
"davidanson.vscode-markdownlint",
"bradlc.vscode-tailwindcss",
"austenc.tailwind-docs"
]
}
42 changes: 35 additions & 7 deletions api/useDayplans.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { type Schema } from "@/amplify/data/resource";
import { Context } from "@/contexts/ContextContext";
import { sortByDate } from "@/helpers/functional";
import { toISODateString } from "@/helpers/functional";
import { SelectionSet, generateClient } from "aws-amplify/data";
import { useEffect, useState } from "react";
import useSWR from "swr";
Expand Down Expand Up @@ -33,7 +33,7 @@ export type DayPlanTodo = {

type DayPlan = {
id: string;
day: string;
day: Date;
dayGoal: string;
context: Context;
done: boolean;
Expand Down Expand Up @@ -81,7 +81,7 @@ const mapDayPlan: (dayplan: DayPlanData) => DayPlan = ({
todos,
}) => ({
id,
day,
day: new Date(day),
dayGoal,
context: context || "work",
done: !!done,
Expand Down Expand Up @@ -140,7 +140,7 @@ const fetchDayPlans = (context?: Context) => async () => {
if (!context) return;
return (await fetchDayPlansWithToken(context))
?.map(mapDayPlan)
.sort((a, b) => sortByDate(true)([a.day, b.day]));
.sort((a, b) => b.day.getTime() - a.day.getTime());
};

export type CreateTodoFn = (props: {
Expand Down Expand Up @@ -244,7 +244,7 @@ const useDayPlans = (context?: Context) => {
};

const createDayPlan = async (
day: string,
day: Date,
dayGoal: string,
context?: Context
) => {
Expand All @@ -261,7 +261,7 @@ const useDayPlans = (context?: Context) => {
};
mutate([newDayPlan, ...(dayPlans || [])], false);
const { data, errors } = await client.models.DayPlan.create({
day,
day: toISODateString(day),
dayGoal,
done: false,
context,
Expand All @@ -271,15 +271,42 @@ const useDayPlans = (context?: Context) => {
mutate([{ ...newDayPlan, id: data.id }, ...(dayPlans || [])]);
};

const undoDayplanCompletion = async (dayplan: Schema["DayPlan"]["type"]) => {
const updatedDayPlans: DayPlan[] = [
...(dayPlans?.filter(({ id }) => id !== dayplan.id) || []),
{
id: dayplan.id,
context: dayplan.context,
day: new Date(dayplan.day),
dayGoal: dayplan.dayGoal,
done: false,
nonprojectTasks: [],
projectTasks: [],
todos: [],
},
];
mutate(updatedDayPlans, false);
const { data, errors } = await client.models.DayPlan.update({
id: dayplan.id,
done: false,
});
if (errors) handleApiErrors(errors, "Error undoing completion of day plan");
if (!data) return;
mutate(updatedDayPlans);
return data;
};

const completeDayPlan = async (dayPlanId: string) => {
const updatedDayPlans = dayPlans?.filter(({ id }) => id !== dayPlanId);
mutate(updatedDayPlans, false);
const { errors } = await client.models.DayPlan.update({
const { data, errors } = await client.models.DayPlan.update({
id: dayPlanId,
done: true,
});
if (errors) handleApiErrors(errors, "Error completing day plan");
if (!data) return;
mutate(updatedDayPlans);
return data;
};

const createTodo: CreateTodoFn = async ({ todo, dayplanId, projectId }) => {
Expand Down Expand Up @@ -330,6 +357,7 @@ const useDayPlans = (context?: Context) => {
loadingDayPlans,
createDayPlan,
completeDayPlan,
undoDayplanCompletion,
createTodo,
switchTodoDone,
migrateLegacyTasks,
Expand Down
17 changes: 17 additions & 0 deletions components.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
{
"$schema": "https://ui.shadcn.com/schema.json",
"style": "default",
"rsc": false,
"tsx": true,
"tailwind": {
"config": "tailwind.config.ts",
"css": "styles/globals.css",
"baseColor": "slate",
"cssVariables": true,
"prefix": ""
},
"aliases": {
"components": "@/components",
"utils": "@/lib/utils"
}
}
78 changes: 0 additions & 78 deletions components/CategoryTitle.module.css

This file was deleted.

92 changes: 49 additions & 43 deletions components/CategoryTitle.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
import { useRouter } from "next/router";
import { ChangeEvent, FC, useEffect, useRef, useState } from "react";
import { IoChevronBackOutline } from "react-icons/io5";
import styles from "./CategoryTitle.module.css";
import SubmitButton from "./ui-elements/buttons/submit-button";
import { Button } from "./ui/button";

export type CategoryTitleProps = {
title?: string;
Expand Down Expand Up @@ -46,47 +45,54 @@ const CategoryTitle: FC<CategoryTitleProps> = (props) => {
};

return (
<header className={styles.content}>
{(props.drawBackBtn || props.onBackBtnClick) && (
<div
className={styles.backAction}
onClick={
props.onBackBtnClick ? props.onBackBtnClick : () => router.back()
}
>
<IoChevronBackOutline className={styles.backBtn} />
</div>
)}
{title &&
(props.saveTitle && isEditing ? (
<textarea
rows={1}
ref={textAreaRef}
value={title}
onChange={handleTitleChange}
onBlur={handleBlur}
className={`${styles.editableTitle} ${styles.alignCenterOnMedium} ${styles.flush}`}
autoFocus
/>
) : (
<h1
className={`${styles.alignCenterOnMedium} ${styles.flush} ${
props.saveTitle ? styles.isEditable : ""
}`}
onClick={() => (props.saveTitle ? setIsEditing(true) : null)}
>
{title}
</h1>
))}
{props.addButton && (
<SubmitButton
btnClassName={styles.actionBtn}
wrapperClassName={styles.action}
onClick={props.addButton.onClick}
>
{props.addButton.label}
</SubmitButton>
)}
<header className="sticky top-12 z-40 bg-bgTransparent pt-3 md:pt-8 pb-4">
<div className="flex justify-between gap-2">
{(props.drawBackBtn || props.onBackBtnClick) && (
<div>
<Button
size="icon"
variant="ghost"
className="h-8 w-8 text-lg md:text-xl text-[--context-color]"
onClick={
props.onBackBtnClick
? props.onBackBtnClick
: () => router.back()
}
>
<IoChevronBackOutline />
</Button>
</div>
)}
{title && (
<div className="text-left md:text-center flex-1 text-2xl md:text-3xl font-bold leading-8 p-0 mt-0 tracking-tight">
{props.saveTitle && isEditing ? (
<textarea
rows={1}
ref={textAreaRef}
value={title}
onChange={handleTitleChange}
onBlur={handleBlur}
autoFocus
className="border-none outline-none w-full overflow-hidden resize-none textarea-bottom-line"
/>
) : (
<div
className={
props.saveTitle && "cursor-pointer hover:border-b-2 mb-1"
}
onClick={() => (props.saveTitle ? setIsEditing(true) : null)}
>
{title}
</div>
)}
</div>
)}
{props.addButton && (
<Button size="sm" onClick={props.addButton.onClick}>
{props.addButton.label}
</Button>
)}
</div>
</header>
);
};
Expand Down
Loading

0 comments on commit ef6130a

Please sign in to comment.