restyle TeamPanel and Calendar

This commit is contained in:
2025-12-19 09:18:16 +01:00
parent 1968c21c96
commit e2677b60a3
3 changed files with 154 additions and 118 deletions

View File

@@ -344,6 +344,7 @@ def last_submissions(
times[r.time.date()] = {} times[r.time.date()] = {}
times[r.time.date()][r.user] = ( times[r.time.date()][r.user] = (
times[r.time.date()].get(r.user, "") times[r.time.date()].get(r.user, "")
+ " "
+ translate_tablename[survey.__tablename__] + translate_tablename[survey.__tablename__]
) )
return times return times

View File

@@ -55,16 +55,35 @@ const Calendar = ({ playerId }: { playerId: number }) => {
// Render month navigation // Render month navigation
const renderMonthNavigation = () => { const renderMonthNavigation = () => {
return ( return (
<div className="month-navigation"> <div className="field has-addons">
<button onClick={handlePrevMonth}>&lt;</button> <p className="control">
<span> <button
<button onClick={() => setSelectedDate(new Date())}>📅</button> className="button is-light is-size-7-mobile"
onClick={handlePrevMonth}
>
&lt;
</button>
</p>
<p className="control">
<button
className="button is-light is-size-7-mobile"
onClick={() => setSelectedDate(new Date())}
>
📅{" "}
{selectedDate.toLocaleString("default", { {selectedDate.toLocaleString("default", {
month: "long", month: "long",
year: "numeric", year: "numeric",
})} })}
</span> </button>
<button onClick={handleNextMonth}>&gt;</button> </p>
<p className="control">
<button
className="button is-light is-size-7-mobile"
onClick={handleNextMonth}
>
&gt;
</button>
</p>
</div> </div>
); );
}; };
@@ -89,11 +108,14 @@ const Calendar = ({ playerId }: { playerId: number }) => {
const date = new Date(0); const date = new Date(0);
date.setDate(i + 5); date.setDate(i + 5);
days.push( days.push(
<div key={"weekday_" + i} className="weekday"> <button
key={"weekday_" + i}
className="button is-size-7-mobile is-white is-static"
>
{date.toLocaleString("default", { {date.toLocaleString("default", {
weekday: "narrow", weekday: "narrow",
})} })}
</div> </button>
); );
} }
@@ -109,34 +131,34 @@ const Calendar = ({ playerId }: { playerId: number }) => {
const todaysEvents = getEventsForDay(date); const todaysEvents = getEventsForDay(date);
days.push( days.push(
<div <button
key={date.getDate()} key={date.getDate()}
className={ className={
"day" + "cell button is-size-7-mobile" +
(date.toDateString() === selectedDate.toDateString() (date.toDateString() === selectedDate.toDateString()
? " selected-day" ? " is-focused is-active is-primary is-light"
: " is-white") +
(date.toDateString() === new Date().toDateString()
? " is-danger has-text-weight-extrabold"
: "") +
(todaysEvents ? " is-warning is-light" : "") +
(todaysEvents && playerId in todaysEvents
? " is-hovered has-text-weight-semibold"
: "") : "")
} }
onClick={() => handleDayClick(date)} onClick={() => handleDayClick(date)}
>
<div
className={
"day-circle" +
(date.toDateString() === new Date().toDateString()
? " today"
: "") +
(todaysEvents ? " has-event" : "") +
(todaysEvents && playerId in todaysEvents ? " active-player" : "")
}
> >
{day} {day}
</div> </button>
</div>
); );
day++; day++;
} }
return <div className="calendar">{days}</div>; return (
<div className="fixed-grid has-7-cols">
<div className="grid is-gap-0.5">{days}</div>
</div>
);
}; };
// Render events for the selected day // Render events for the selected day
@@ -144,29 +166,38 @@ const Calendar = ({ playerId }: { playerId: number }) => {
const eventsForDay = getEventsForDay(selectedDate); const eventsForDay = getEventsForDay(selectedDate);
return ( return (
<div className="events"> <div className="events">
{eventsForDay && ( {eventsForDay &&
<ul> Object.entries(eventsForDay).map(([id, sub]) => {
{Object.entries(eventsForDay).map(([id, sub]) => {
const name = players?.find((p) => p.id === Number(id)); const name = players?.find((p) => p.id === Number(id));
return ( return (
<li key={id}> <p className="field">
{name !== undefined ? name.display_name : ""}:{" "} <div className="control" key={id}>
<span style={{ letterSpacing: 8 }}>{sub}</span> <div className="tags are-medium has-addons">
</li> <span className="tag is-warning is-size-7-mobile">
{name !== undefined ? name.display_name : ""}
</span>
<span className="tag is-primary is-light is-size-7-mobile">
{sub}
</span>
</div>
</div>
</p>
); );
})} })}
</ul>
)}
</div> </div>
); );
}; };
return ( return (
<div className="calendar-container"> <div className="block is-size-7-mobile">
<h2>Latest Submissions</h2> <h2 className="title is-4">Latest Submissions</h2>
<div className="columns is-6">
<div className="column" style={{ maxWidth: 600 }}>
{renderMonthNavigation()} {renderMonthNavigation()}
{renderCalendar()} {renderCalendar()}
{renderEvents()} </div>
<div className="column is-narrow">{renderEvents()}</div>
</div>
</div> </div>
); );
}; };

View File

@@ -70,29 +70,21 @@ const TeamPanel = () => {
(team) => team.id == teams?.activeTeam (team) => team.id == teams?.activeTeam
)[0]; )[0];
return ( return (
<div className="team-panel"> <section className="section">
<h1>{activeTeam.name}</h1> <h1 className="title">{activeTeam.name}</h1>
<div> <h2 className="subtitle">
<input type="text" value={activeTeam.location || ""} disabled /> {activeTeam.location}, {activeTeam.country}
<br /> </h2>
<input type="text" value={activeTeam.country || ""} disabled /> <div className="box">
<hr style={{ width: "100%" }} /> <h2 className="title is-4">Players</h2>
<h2>players</h2>
{players ? ( {players ? (
<div <div className="buttons">
style={{
display: "flex",
flexWrap: "wrap",
justifyContent: "center",
}}
>
{players.map((p) => ( {players.map((p) => (
<button <button
className={ className={
"team-player " + "button is-primary is-light " +
p.gender + p.gender +
(p.id === player.id ? " active-player" : "") (p.id === player.id ? " is-focused is-active" : "")
} }
key={p.id} key={p.id}
onClick={() => { onClick={() => {
@@ -104,7 +96,7 @@ const TeamPanel = () => {
</button> </button>
))} ))}
<button <button
className="team-player new-player" className="button is-success is-light new-player"
key="add-player" key="add-player"
onClick={() => { onClick={() => {
setPlayer(newPlayerTemplate); setPlayer(newPlayerTemplate);
@@ -117,12 +109,14 @@ const TeamPanel = () => {
) : ( ) : (
<span className="loader" /> <span className="loader" />
)} )}
<hr style={{ width: "100%" }} /> </div>
<form className="new-player-inputs" onSubmit={handleSubmit}> <form className="container block" onSubmit={handleSubmit}>
<div> <div className="field">
<label>name</label> <label className="label">name</label>
<div className="control">
<input <input
className="input"
type="text" type="text"
required required
value={player.display_name} value={player.display_name}
@@ -138,9 +132,12 @@ const TeamPanel = () => {
}} }}
/> />
</div> </div>
<div> </div>
<label>username</label> <div className="field">
<label className="label">username</label>
<div className="control">
<input <input
className="input"
type="text" type="text"
required required
disabled={player.id !== 0} disabled={player.id !== 0}
@@ -151,8 +148,11 @@ const TeamPanel = () => {
}} }}
/> />
</div> </div>
<div> </div>
<label>gender</label> <div className="field">
<label className="label">gender</label>
<div className="control">
<div className="select">
<select <select
name="gender" name="gender"
value={player.gender} value={player.gender}
@@ -166,9 +166,13 @@ const TeamPanel = () => {
<option value="mmp">MMP</option> <option value="mmp">MMP</option>
</select> </select>
</div> </div>
<div> </div>
<label>number (optional)</label> </div>
<div className="field">
<label className="label">number (optional)</label>
<div className="control">
<input <input
className="input"
type="text" type="text"
value={player.number || ""} value={player.number || ""}
onChange={(e) => { onChange={(e) => {
@@ -177,9 +181,12 @@ const TeamPanel = () => {
}} }}
/> />
</div> </div>
<div> </div>
<label>email (optional)</label> <div className="field">
<label className="label">email (optional)</label>
<div className="control">
<input <input
className="input"
type="email" type="email"
value={player.email || ""} value={player.email || ""}
onChange={(e) => { onChange={(e) => {
@@ -188,36 +195,33 @@ const TeamPanel = () => {
}} }}
/> />
</div> </div>
<div style={{ margin: "auto" }}>
{error?.message && ( {error?.message && (
<span <p className={"help" + (error.ok ? " is-success" : " is-danger")}>
style={{
color: error.ok ? "green" : "red",
}}
>
{error.message} {error.message}
</span> </p>
)} )}
</div> </div>
<div style={{ margin: "auto" }}> <div className="field is-grouped">
<button className="team-player new-player"> <button
className={
"button is-light" +
(player.id === 0 ? " is-success" : " is-link")
}
>
{player.id === 0 ? "add player" : "modify player"} {player.id === 0 ? "add player" : "modify player"}
</button> </button>
</div>
{player.id !== 0 && ( {player.id !== 0 && (
<div style={{ margin: "auto" }}>
<button <button
className="team-player disable-player" className="button is-danger is-light"
onClick={handleDisable} onClick={handleDisable}
> >
remove player remove player
</button> </button>
</div>
)} )}
</div>
</form> </form>
</div>
<Calendar playerId={player.id} /> <Calendar playerId={player.id} />
</div> </section>
); );
} else <span className="loader" />; } else <span className="loader" />;
}; };