1
Fork 0
mirror of https://github.com/Steffo99/festa.git synced 2025-01-08 23:09:45 +00:00

Improve (?) date visualization

This commit is contained in:
Steffo 2022-06-08 17:31:34 +02:00
parent 3bb63cc9e6
commit 24c1ba8f54
Signed by: steffo
GPG key ID: 6965406171929D01
4 changed files with 69 additions and 31 deletions

24
components/HumanDate.tsx Normal file
View file

@ -0,0 +1,24 @@
import { useTranslation } from "next-i18next"
type HumanDateProps = {
date: Date
}
export function HumanDate({date}: HumanDateProps) {
const {t} = useTranslation()
if(Number.isNaN(date.getTime())) {
return (
<span className="disabled">
{t("dateNaN")}
</span>
)
}
return (
<time dateTime={date.toISOString()}>
{date.toLocaleString()}
</time>
)
}

View file

@ -4,6 +4,7 @@ import { EditingContext } from "../../contexts/editing"
import { useDefinedContext } from "../../utils/definedContext" import { useDefinedContext } from "../../utils/definedContext"
import { FestaIcon } from "../extensions/FestaIcon" import { FestaIcon } from "../extensions/FestaIcon"
import { FormDateRange } from "../form/FormDateRange" import { FormDateRange } from "../form/FormDateRange"
import { HumanDate } from "../HumanDate"
type EditableDateRangeProps = { type EditableDateRangeProps = {
@ -15,44 +16,56 @@ type EditableDateRangeProps = {
export function EditableDateRange(props: EditableDateRangeProps) { export function EditableDateRange(props: EditableDateRangeProps) {
const [editing,] = useDefinedContext(EditingContext) const [editing,] = useDefinedContext(EditingContext)
const startDate = props.startProps if(editing) {
return (
<FormDateRange
preview={false}
icon={
<FestaIcon icon={faClock}/>
}
start={
<input
type="datetime-local"
{...props.startProps}
/>
}
connector={
<FestaIcon icon={faChevronRight}/>
}
end={
<input
type="datetime-local"
{...props.endProps}
/>
}
/>
)
}
return editing ? ( const startTime = Date.parse(props.startProps.value!)
<FormDateRange const endTime = Date.parse(props.endProps.value!)
preview={false}
icon={ if(Number.isNaN(startTime) && Number.isNaN(endTime)) {
<FestaIcon icon={faClock}/> return null
} }
start={
<input const startDate = new Date(startTime)
type="datetime-local" const endDate = new Date(endTime)
{...props.startProps}
/> return (
}
connector={
<FestaIcon icon={faChevronRight}/>
}
end={
<input
type="datetime-local"
{...props.endProps}
/>
}
/>
) : (
<FormDateRange <FormDateRange
preview={true} preview={true}
icon={ icon={
<FestaIcon icon={faClock}/> <FestaIcon icon={faClock}/>
} }
start={ start={
new Date(Date.parse(props.startProps.value!)).toLocaleString() <HumanDate date={startDate}/>
} }
connector={ connector={
<FestaIcon icon={faChevronRight}/> <FestaIcon icon={faChevronRight}/>
} }
end={ end={
new Date(Date.parse(props.endProps.value!)).toLocaleString() <HumanDate date={endDate}/>
} }
/> />
) )

View file

@ -51,8 +51,8 @@ export default function PageEventDetail({event}: PageEventDetailProps) {
const [title, setTitle] = useState<string>(event.name) const [title, setTitle] = useState<string>(event.name)
const [description, setDescription] = useState<string>(event.description) const [description, setDescription] = useState<string>(event.description)
const [postcard, setPostcard] = useState<string | null>(event.postcard) const [postcard, setPostcard] = useState<string | null>(event.postcard)
const [startingAt, setStartingAt] = useState<string | null>(event.startingAt?.toISOString() ?? null) const [startingAt, setStartingAt] = useState<string>(event.startingAt?.toISOString() ?? "")
const [endingAt, setEndingAt] = useState<string | null>(event.endingAt?.toISOString() ?? null) const [endingAt, setEndingAt] = useState<string>(event.endingAt?.toISOString() ?? "")
const setPostcardBlob = useCallback( const setPostcardBlob = useCallback(
(e: ChangeEvent<HTMLInputElement>) => { (e: ChangeEvent<HTMLInputElement>) => {
@ -105,11 +105,11 @@ export default function PageEventDetail({event}: PageEventDetailProps) {
daterange={ daterange={
<EditableDateRange <EditableDateRange
startProps={{ startProps={{
value: startingAt ?? undefined, value: startingAt ?? "",
onChange: (e: ChangeEvent<HTMLInputElement>) => setStartingAt(e.target.value) onChange: (e: ChangeEvent<HTMLInputElement>) => setStartingAt(e.target.value)
}} }}
endProps={{ endProps={{
value: endingAt ?? undefined, value: endingAt ?? "",
onChange: (e: ChangeEvent<HTMLInputElement>) => setEndingAt(e.target.value) onChange: (e: ChangeEvent<HTMLInputElement>) => setEndingAt(e.target.value)
}} }}
/> />

View file

@ -31,5 +31,6 @@
"eventDetailsTitlePlaceholder": "Titolo", "eventDetailsTitlePlaceholder": "Titolo",
"eventDetailsDescriptionPlaceholder": "Descrizione evento", "eventDetailsDescriptionPlaceholder": "Descrizione evento",
"eventDetailsPostcardPlaceholder": "Cartolina", "eventDetailsPostcardPlaceholder": "Cartolina",
"workInProgress": "Questa pagina è ancora in sviluppo e potrebbe contenere errori o testo inaspettato." "workInProgress": "Questa pagina è ancora in sviluppo e potrebbe contenere errori o testo inaspettato.",
"dateNaN": "Non specificata"
} }