Skip to content

Commit

Permalink
Add front end for caching new collections.
Browse files Browse the repository at this point in the history
  • Loading branch information
ctslater committed Oct 21, 2024
1 parent 1b4a809 commit f7e0114
Show file tree
Hide file tree
Showing 5 changed files with 115 additions and 2 deletions.
25 changes: 25 additions & 0 deletions app/_components/AddCollectionSelectServer.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@

'use server'

export async function pollJob(jobId) {

console.log(`pollJob ${jobId}`)
let res = await fetch(`http://production-tools/plot-navigator/cache/job/${jobId}`)
let data = await res.json()
console.log(res.json())
return data
}

export async function putCollection(repo, collectionName) {

let res = await fetch("http://production-tools/plot-navigator/cache/",
{method: "PUT",
body: JSON.stringify({repo: repo, collection: collectionName}),
headers: {"Content-Type": "application/json"}}
)
let data = await res.json()
console.log(`putCollection ${JSON.stringify(data)}`)

return data.jobId

}
63 changes: 63 additions & 0 deletions app/_components/addCollectionSelect.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
'use client'

import React from 'react';
import { useState, useEffect } from 'react'

import {putCollection, pollJob} from './AddCollectionSelectServer.js'

export default function AddCollectionSelect({repos}) {

const [repo, setRepo] = useState(repos[0]);
const [collectionName, setCollectionName] = useState("");
const [jobId, setJobId] = useState("");
const [statusMessage, setStatusMessage] = useState("");
const [statusClasses, setStatusClasses] = useState("");

const pollUpdates = async () => {
if(jobId == "") {
return
}
await new Promise(r => setTimeout(r, 5000));
console.log(`Polling ${jobId}`)
const res = await pollJob(jobId)
setStatusMessage(res.status.replace("_", " "))
bounceText()
setStatusClasses("bg-sky-500/10")
if(res.status == "in_progress") {
await pollUpdates()
}
}
useEffect(() => {pollUpdates(jobId)}, [jobId])

const submitForm = async () => {
const jobId = await putCollection(repo, collectionName)
setJobId(jobId)
setStatusMessage("Started")

}

const bounceText = () => {
setStatusClasses("bg-sky-500/10")
}

useEffect(() => {setStatusClasses("duration-1000")}, [statusClasses])

return (
<div className="p-2">
<select className="p-1 m-2" value={repo} onChange={(e) => {
setRepo(e.target.value);
}}>
{repos.map(
(repo) => <option value={repo} key={repo}>{repo}</option>
)}
</select>
<input className="m-2 border-2" type="text" size={40} value={collectionName} onChange={(e) => setCollectionName(e.target.value)} />
<button className="p-2 px-4 m-2 rounded-md text-white bg-sky-600" onClick={submitForm}>Add</button>
<div className={`m-2 p-2 px-4 inline-block ${statusClasses}`}>{statusMessage}</div>
{ /*
<button className="p-2 px-4 m-2 rounded-md text-white bg-sky-600" onClick={bounceText}>Bounce</button>
*/ }
</div>
)
}

23 changes: 23 additions & 0 deletions app/addcollection/page.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@

export const dynamic = 'force-dynamic'

import Link from 'next/link'

import AddCollectionSelect from '@/components/addCollectionSelect'

export default async function AddCollection() {


const repoUrls = JSON.parse(process.env.REPO_URLS ?? "[]")

/* REPO_URLS */
return (
<div>
<div className="text-m m-5"><Link href={"/"}>&lt;- Back to collections</Link></div>
<div className="text-2xl m-5">Add a Collection:</div>
<AddCollectionSelect repos={Object.keys(repoUrls)} />
</div>

)

}
5 changes: 3 additions & 2 deletions app/layout.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,9 @@ export default function RootLayout({ children }) {
<div className="bg-black text-rubin-blue text-3xl p-2">Rubin Plot Navigator</div>
<ul className="flex flex-row p-2">
<li className="p-2 px-3 text-xl"><a href="/plot-navigator">Plots</a></li>
<li className="p-2 px-3 text-xl"><a href="/plot-navigator/metrics">Metrics</a></li>
<li className="p-2 px-3 text-xl"><a href="/plot-navigator/bokeh">Bokeh</a></li>
{(process.env.PAGE_LINKS ?? "").split(',').map((page) =>
<li className="p-2 px-3 text-xl" key={page}><a href={`/plot-navigator/${page.toLowerCase()}`}>{page}</a></li>
)}
</ul>
</div>
{children}
Expand Down
1 change: 1 addition & 0 deletions env.local.example
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@ BASE_URL=
BUTLER_URL=
BUCKET_NAME=
BUCKET_URL=
PAGE_LINKS=
S3_KEY=
S3_SECRET=

0 comments on commit f7e0114

Please sign in to comment.