Rename to Pollo! Bumped to v5!
This commit is contained in:
parent
8461d80130
commit
b47071957f
13 changed files with 101 additions and 106 deletions
|
@ -1,6 +1,6 @@
|
|||
# Sprint Padawan data:image/s3,"s3://crabby-images/c5869/c58690979d3075f886fcb253aa3a81e0c56f47a7" alt="Status"
|
||||
# Pollo
|
||||
|
||||
A scrum poker tool that helps agile teams plan their sprints in real-time.
|
||||
A dead-simple real-time voting tool.
|
||||
|
||||
## Stack
|
||||
|
||||
|
@ -19,7 +19,3 @@ A scrum poker tool that helps agile teams plan their sprints in real-time.
|
|||
## Contributing
|
||||
|
||||
Feel free to propose changes via PR. I'm not awfully picky about formatting right now, so I'll accept/reject on a case-by-case basis. Please make sure to have an issue first though.
|
||||
|
||||
## Stats
|
||||
|
||||
data:image/s3,"s3://crabby-images/e2458/e245894266692fd1badf24795f5524b605214ea9" alt="Alt"
|
||||
|
|
|
@ -15,7 +15,7 @@ export default function ErrorPage() {
|
|||
<h2 className="text-2xl font-bold m-2">
|
||||
If you believe you reached this page in error, please file an issue{" "}
|
||||
<a
|
||||
href="https://github.com/atridadl/sprintpadawan/issues/new"
|
||||
href="https://github.com/atridadl/pollo/issues/new"
|
||||
className="link link-secondary"
|
||||
>
|
||||
here
|
||||
|
@ -41,7 +41,7 @@ export default function ErrorPage() {
|
|||
<h2 className="text-2xl font-bold m-2">
|
||||
If you believe you reached this page in error, please file an issue{" "}
|
||||
<a
|
||||
href="https://github.com/atridadl/sprintpadawan/issues/new"
|
||||
href="https://github.com/atridadl/pollo/issues/new"
|
||||
className="link link-secondary"
|
||||
>
|
||||
here
|
||||
|
@ -63,7 +63,7 @@ export default function ErrorPage() {
|
|||
<h2 className="text-2xl font-bold m-2">
|
||||
If you believe you reached this page in error, please file an issue{" "}
|
||||
<a
|
||||
href="https://github.com/atridadl/sprintpadawan/issues/new"
|
||||
href="https://github.com/atridadl/pollo/issues/new"
|
||||
className="link link-secondary"
|
||||
>
|
||||
here
|
||||
|
|
|
@ -19,7 +19,7 @@ const Footer = () => {
|
|||
-{" "}
|
||||
<a
|
||||
className="link link-primary link-hover"
|
||||
href={`https://github.com/atridadl/sprintpadawan/releases/tag/${packagejson.version}`}
|
||||
href={`https://github.com/atridadl/pollo/releases/tag/${packagejson.version}`}
|
||||
rel="noreferrer"
|
||||
target="_blank"
|
||||
>
|
||||
|
|
|
@ -16,8 +16,8 @@ import "./tailwind.css";
|
|||
|
||||
export const meta: MetaFunction = () => {
|
||||
return [
|
||||
{ title: "Sprint Padawan" },
|
||||
{ name: "description", content: "Plan. Sprint. Repeat." },
|
||||
{ title: "Pollo" },
|
||||
{ name: "description", content: "Simple Real-Time Voting" },
|
||||
];
|
||||
};
|
||||
|
||||
|
@ -35,7 +35,7 @@ function App() {
|
|||
<Links />
|
||||
</head>
|
||||
<body className="h-[100%] w-[100%] fixed overflow-y-auto">
|
||||
<Header title={"Sprint Padawan"} />
|
||||
<Header title={"Pollo"} />
|
||||
<div className="flex flex-row items-center justify-center min-h-[calc(100%-114px)]">
|
||||
<Outlet />
|
||||
</div>
|
||||
|
|
|
@ -3,7 +3,7 @@ export default function Index() {
|
|||
<div className="flex flex-col text-center items-center justify-center px-4 py-16 gap-4">
|
||||
<h1 className="text-3xl sm:text-6xl font-bold">
|
||||
<span className="bg-gradient-to-r from-primary via-accent to-secondary bg-clip-text text-transparent box-decoration-clone">
|
||||
Sprint Padawan
|
||||
Pollo
|
||||
</span>
|
||||
</h1>
|
||||
|
||||
|
|
|
@ -25,7 +25,7 @@ export async function action({ request, params, context }: ActionFunctionArgs) {
|
|||
created_at: Date.now().toString(),
|
||||
userId: userId || "",
|
||||
roomName: data.name,
|
||||
storyName: "First Story!",
|
||||
topicName: "First Topic!",
|
||||
scale: "0.5,1,2,3,5,8",
|
||||
visible: false,
|
||||
})
|
||||
|
|
|
@ -44,7 +44,7 @@ export async function action({ request, params, context }: ActionFunctionArgs) {
|
|||
})
|
||||
),
|
||||
roomName: oldRoom.roomName,
|
||||
storyName: oldRoom.storyName,
|
||||
topicName: oldRoom.topicName,
|
||||
}));
|
||||
}
|
||||
|
||||
|
@ -56,7 +56,7 @@ export async function action({ request, params, context }: ActionFunctionArgs) {
|
|||
? await db
|
||||
.update(rooms)
|
||||
.set({
|
||||
storyName: data.name,
|
||||
topicName: data.name,
|
||||
visible: data.visible,
|
||||
scale: [...new Set(data.scale.split(","))]
|
||||
.filter((item) => item !== "")
|
||||
|
|
|
@ -29,7 +29,7 @@ type RoomsResponse =
|
|||
id: string;
|
||||
created_at: Date | null;
|
||||
userId: string;
|
||||
storyName: string | null;
|
||||
topicName: string | null;
|
||||
visible: boolean;
|
||||
scale: string;
|
||||
}[]
|
||||
|
|
|
@ -113,7 +113,7 @@ function RoomContent() {
|
|||
| PresenceItem[]
|
||||
| undefined;
|
||||
|
||||
const [storyNameText, setStoryNameText] = useState<string>("");
|
||||
const [topicNameText, setTopicNameText] = useState<string>("");
|
||||
const [roomScale, setRoomScale] = useState<string>("");
|
||||
|
||||
const [copied, setCopied] = useState<boolean>(false);
|
||||
|
@ -142,7 +142,7 @@ function RoomContent() {
|
|||
cache: "no-cache",
|
||||
method: "PUT",
|
||||
body: JSON.stringify({
|
||||
name: storyNameText,
|
||||
name: topicNameText,
|
||||
visible: data.visible,
|
||||
scale: roomScale,
|
||||
reset: data.reset ? data.reset : false,
|
||||
|
@ -175,7 +175,7 @@ function RoomContent() {
|
|||
userId: item.userId,
|
||||
roomId: item.roomId,
|
||||
roomName: item.roomName,
|
||||
storyName: item.storyName,
|
||||
topicName: item.topicName,
|
||||
scale: item.scale,
|
||||
votes: item.votes,
|
||||
};
|
||||
|
@ -186,7 +186,7 @@ function RoomContent() {
|
|||
userId: roomFromDbParsed.userId,
|
||||
roomId: roomFromDbParsed.id,
|
||||
roomName: roomFromDbParsed.roomName,
|
||||
storyName: storyNameText,
|
||||
topicName: topicNameText,
|
||||
scale: roomScale,
|
||||
votes: votesFromDbParsed?.map((vote) => {
|
||||
return {
|
||||
|
@ -240,7 +240,7 @@ function RoomContent() {
|
|||
// =================================
|
||||
useEffect(() => {
|
||||
if (roomFromDb) {
|
||||
setStoryNameText(roomFromDbParsed?.storyName || "");
|
||||
setTopicNameText(roomFromDbParsed?.topicName || "");
|
||||
setRoomScale(roomFromDbParsed?.scale || "ERROR");
|
||||
}
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
|
@ -276,7 +276,7 @@ function RoomContent() {
|
|||
<div className="card card-compact bg-base-100 shadow-xl">
|
||||
<div className="card-body">
|
||||
<h2 className="card-title mx-auto">
|
||||
Story: {roomFromDbParsed?.storyName}
|
||||
Topic: {roomFromDbParsed?.topicName}
|
||||
</h2>
|
||||
|
||||
<ul className="p-0 flex flex-row flex-wrap justify-center items-center text-ceter gap-4">
|
||||
|
@ -351,8 +351,7 @@ function RoomContent() {
|
|||
return (
|
||||
<button
|
||||
key={index}
|
||||
className={`join-item ${
|
||||
getVoteForCurrentUser()?.value === scaleItem
|
||||
className={`join-item ${getVoteForCurrentUser()?.value === scaleItem
|
||||
? "btn btn-active btn-primary"
|
||||
: "btn"
|
||||
}`}
|
||||
|
@ -389,15 +388,15 @@ function RoomContent() {
|
|||
}}
|
||||
/>
|
||||
|
||||
<label className="label">{"Story Name:"} </label>
|
||||
<label className="label">{"Topic Name:"} </label>
|
||||
|
||||
<input
|
||||
type="text"
|
||||
placeholder="Story Name"
|
||||
placeholder="Topic Name"
|
||||
className="input input-bordered"
|
||||
value={storyNameText}
|
||||
value={topicNameText}
|
||||
onChange={(event) => {
|
||||
setStoryNameText(event.target.value);
|
||||
setTopicNameText(event.target.value);
|
||||
}}
|
||||
/>
|
||||
|
||||
|
@ -434,7 +433,7 @@ function RoomContent() {
|
|||
visible: false,
|
||||
reset: true,
|
||||
log:
|
||||
roomFromDbParsed?.storyName === storyNameText ||
|
||||
roomFromDbParsed?.topicName === topicNameText ||
|
||||
votesFromDb?.length === 0
|
||||
? false
|
||||
: true,
|
||||
|
@ -447,7 +446,7 @@ function RoomContent() {
|
|||
).length <= 1
|
||||
}
|
||||
>
|
||||
{roomFromDbParsed?.storyName === storyNameText ||
|
||||
{roomFromDbParsed?.topicName === topicNameText ||
|
||||
votesFromDb?.length === 0 ? (
|
||||
<>
|
||||
<RefreshCwIcon className="text-xl mr-1" /> Reset
|
||||
|
|
|
@ -12,7 +12,7 @@ export const rooms = pgTable("Room", {
|
|||
created_at: text("created_at"),
|
||||
userId: text("userId").notNull(),
|
||||
roomName: text("roomName"),
|
||||
storyName: text("storyName"),
|
||||
topicName: text("topicName"),
|
||||
visible: boolean("visible").default(false).notNull(),
|
||||
scale: text("scale").default("0.5,1,2,3,5").notNull(),
|
||||
});
|
||||
|
@ -58,7 +58,7 @@ export const logs = pgTable(
|
|||
scale: text("scale"),
|
||||
votes: text("votes"),
|
||||
roomName: text("roomName"),
|
||||
storyName: text("storyName"),
|
||||
topicName: text("topicName"),
|
||||
},
|
||||
(table) => {
|
||||
return {
|
||||
|
|
|
@ -22,7 +22,7 @@ export type RoomsResponse =
|
|||
id: string;
|
||||
created_at: Date | null;
|
||||
userId: string;
|
||||
storyName: string | null;
|
||||
topicName: string | null;
|
||||
visible: boolean;
|
||||
scale: string;
|
||||
}[]
|
||||
|
@ -35,7 +35,7 @@ export type RoomResponse =
|
|||
created_at: Date | null;
|
||||
userId: string;
|
||||
roomName: string | null;
|
||||
storyName: string | null;
|
||||
topicName: string | null;
|
||||
visible: boolean;
|
||||
scale: string | null;
|
||||
logs: {
|
||||
|
@ -44,7 +44,7 @@ export type RoomResponse =
|
|||
userId: string;
|
||||
roomId: string;
|
||||
roomName: string | null;
|
||||
storyName: string | null;
|
||||
topicName: string | null;
|
||||
scale: string | null;
|
||||
votes: unknown;
|
||||
}[];
|
||||
|
|
BIN
bun.lockb
BIN
bun.lockb
Binary file not shown.
|
@ -1,6 +1,6 @@
|
|||
{
|
||||
"name": "sprintpadawan",
|
||||
"version": "4.3.2",
|
||||
"name": "pollo",
|
||||
"version": "5.0.0",
|
||||
"private": true,
|
||||
"sideEffects": false,
|
||||
"type": "module",
|
||||
|
|
Loading…
Add table
Reference in a new issue