From 99ffb1ccc7b7761ee54797d71d6a4ea3f171df8f Mon Sep 17 00:00:00 2001 From: DrMint Date: Sat, 25 Dec 2021 16:04:03 +0100 Subject: [PATCH] Visual improvement to scrollbars and chronology --- .../Chronology/ChronologyItemComponent.tsx | 83 ++++++++++++++----- .../Chronology/ChronologyYearComponent.tsx | 8 +- src/pages/chronology/overview.tsx | 10 +-- .../ChronologyItemComponent.module.css | 16 ++-- .../ChronologyYearComponent.module.css | 5 ++ src/styles/Panels/ContentPanel.module.css | 6 ++ src/styles/globals.css | 24 +++++- 7 files changed, 113 insertions(+), 39 deletions(-) create mode 100644 src/styles/Chronology/ChronologyYearComponent.module.css diff --git a/src/components/Chronology/ChronologyItemComponent.tsx b/src/components/Chronology/ChronologyItemComponent.tsx index f8cbd1e..58b73ab 100644 --- a/src/components/Chronology/ChronologyItemComponent.tsx +++ b/src/components/Chronology/ChronologyItemComponent.tsx @@ -5,7 +5,14 @@ import { ChronologyItemsEventTranslation, } from "queries/chronology/overview"; -export default function ChronologyItemComponent(pageProps: ChronologyItem) { +export type ChronologyItemComponentProps = { + item: ChronologyItem; + displayYear: boolean; +}; + +export default function ChronologyItemComponent( + props: ChronologyItemComponentProps +) { function generateAnchor( year: number, month: number, @@ -14,8 +21,8 @@ export default function ChronologyItemComponent(pageProps: ChronologyItem) { ): string { let result: string = ""; result += year; - if (month) result += "-" + month; - if (day) result += "-" + day; + if (month) result += "-" + month.toString().padStart(2, "0"); + if (day) result += "-" + day.toString().padStart(2, "0"); return result; } @@ -28,9 +35,29 @@ export default function ChronologyItemComponent(pageProps: ChronologyItem) { } function generateDate(month: number, day: number): string { + let lut = [ + "Jan", + "Feb", + "Mar", + "Apr", + "May", + "Jun", + "Jul", + "Aug", + "Sep", + "Oct", + "Nov", + "Dec", + ]; + let result: string = ""; - if (month) result += month.toString().padStart(2, "0"); - if (day) result += "/" + day.toString().padStart(2, "0"); + if (month) { + result += lut[month - 1]; + if (day) { + result += " " + day.toString().padStart(2, "0"); + } + } + return result; } @@ -38,33 +65,47 @@ export default function ChronologyItemComponent(pageProps: ChronologyItem) {
-

- {generateYear( - pageProps.attributes.displayed_date, - pageProps.attributes.year - )} -

+ {props.displayYear ? ( +

+ {generateYear( + props.item.attributes.displayed_date, + props.item.attributes.year + )} +

+ ) : ( + "" + )}

- {generateDate(pageProps.attributes.month, pageProps.attributes.day)} + {generateDate(props.item.attributes.month, props.item.attributes.day)}

- {pageProps.attributes.events.map((event: ChronologyItemsEvent) => ( + {props.item.attributes.events.map((event: ChronologyItemsEvent) => (
{event.translations.map( (translation: ChronologyItemsEventTranslation) => ( <> -

{translation.title}

-

1 ? styles.bulletItem : ""}> - {translation.description} - {translation.note} -

+ {translation.title ?

{translation.title}

: ""} + + {translation.description ? ( +

1 ? styles.bulletItem : "" + } + > + {translation.description} + +

+ ) : ( + "" + )} + {translation.note ? {"Notes: " + translation.note} : ""} ) )} diff --git a/src/components/Chronology/ChronologyYearComponent.tsx b/src/components/Chronology/ChronologyYearComponent.tsx index ed4e4da..6dc6b39 100644 --- a/src/components/Chronology/ChronologyYearComponent.tsx +++ b/src/components/Chronology/ChronologyYearComponent.tsx @@ -10,12 +10,12 @@ type ChronologyYearComponentProps = { export default function ChronologyYearComponent(props: ChronologyYearComponentProps) { return ( -
+
1 ? props.items[0].attributes.year.toString() : undefined}> {props.items.map((item: ChronologyItem, index: number) => ( ))}
diff --git a/src/pages/chronology/overview.tsx b/src/pages/chronology/overview.tsx index b8212ac..f161e55 100644 --- a/src/pages/chronology/overview.tsx +++ b/src/pages/chronology/overview.tsx @@ -32,11 +32,7 @@ export default function ChronologyOverview(props: Props): JSX.Element { } else { chronologyItemYearGroups[item.attributes.year].push(item); } - }); - - console.log(chronologyItemYearGroups); - - + }); return ( <> @@ -77,9 +73,9 @@ export default function ChronologyOverview(props: Props): JSX.Element { ")" ); } - if (event.translations.length !== 1) { + if (event.translations.length < 1) { console.warn( - "Wrong number of Translation(s) on ChronologyItem (" + + "Missing Translation on ChronologyItem (" + item.id + "), Event (" + event.id + diff --git a/src/styles/Chronology/ChronologyItemComponent.module.css b/src/styles/Chronology/ChronologyItemComponent.module.css index d33b4b5..6f4e16d 100644 --- a/src/styles/Chronology/ChronologyItemComponent.module.css +++ b/src/styles/Chronology/ChronologyItemComponent.module.css @@ -8,40 +8,40 @@ place-content: start; grid-template-rows: auto 1fr; grid-template-columns: 4em; - margin-bottom: 1.5em; + padding: 1em 2em; } .chronologyItem:target { background-color: var(--color-main-base); border-radius: 1em; - padding: 1em 2em 1em 1.5em; } .chronologyItem > .year { grid-area: year; margin: 0; font-weight: bold; + font-size: 1.3em; + margin-top: -0.25em; } .chronologyItem > .date { grid-area: date; margin: 0; + color: var(--color-main-dark); + font-size: 0.9em; } .chronologyItem > .events { grid-area: events; } -.event { - margin-bottom: 1em; -} - .event > h3 { margin: 0; } .event > p { margin: 0; + white-space: break-spaces; } .event > .bulletItem::before { @@ -56,6 +56,10 @@ margin-top: .5em; } +.event ~ .event { + margin-top: 1em; +} + .source { color: var(--color-main-dark); font-size: 80%; diff --git a/src/styles/Chronology/ChronologyYearComponent.module.css b/src/styles/Chronology/ChronologyYearComponent.module.css new file mode 100644 index 0000000..4fc5284 --- /dev/null +++ b/src/styles/Chronology/ChronologyYearComponent.module.css @@ -0,0 +1,5 @@ +.chronologyYear:target { + background-color: var(--color-main-base); + border-radius: 1em; + padding: 1em 2em 1em 1.5em; +} \ No newline at end of file diff --git a/src/styles/Panels/ContentPanel.module.css b/src/styles/Panels/ContentPanel.module.css index 0f90c36..a94b6ac 100644 --- a/src/styles/Panels/ContentPanel.module.css +++ b/src/styles/Panels/ContentPanel.module.css @@ -1,9 +1,15 @@ .panel { padding-top: 5rem; + scrollbar-width: thin; + border: none; } .panelInside { max-width: 50rem; text-align: justify; text-justify: inter-word; +} + +.panel::-webkit-scrollbar { + display: unset; } \ No newline at end of file diff --git a/src/styles/globals.css b/src/styles/globals.css index 9f91a81..f42759f 100644 --- a/src/styles/globals.css +++ b/src/styles/globals.css @@ -76,11 +76,33 @@ button:hover { color: var(--color-main-light); } + +/* SCROLLBARS STYLING */ + +* { + scrollbar-color: var(--color-main-dark) transparent; +} + *::selection { background-color: var(--color-main-dark); - color: var(--color-main-light) + color: var(--color-main-light); + border-radius: 1em; } *:target { scroll-margin-top: 1em; +} + +*::-webkit-scrollbar { + width: 12px; /* width of the entire scrollbar */ +} + +*::-webkit-scrollbar-track { + background: transparent; /* color of the tracking area */ +} + +*::-webkit-scrollbar-thumb { + background-color: var(--color-main-dark); /* color of the scroll thumb */ + border-radius: 100vmax; /* roundness of the scroll thumb */ + border: 3px solid var(--color-main-light); /* creates padding around scroll thumb */ } \ No newline at end of file