2024-07-09 20:41:29 +00:00
|
|
|
package pages
|
|
|
|
|
2024-07-15 10:57:51 +00:00
|
|
|
import (
|
2024-09-05 21:11:29 +00:00
|
|
|
"fmt"
|
2024-07-15 10:57:51 +00:00
|
|
|
c "git.ekzyis.com/ekzyis/delphi.market/server/router/context"
|
|
|
|
"git.ekzyis.com/ekzyis/delphi.market/server/router/pages/components"
|
|
|
|
"git.ekzyis.com/ekzyis/delphi.market/types"
|
|
|
|
"github.com/dustin/go-humanize"
|
2024-09-05 21:12:34 +00:00
|
|
|
"time"
|
2024-07-15 10:57:51 +00:00
|
|
|
)
|
2024-07-09 20:41:29 +00:00
|
|
|
|
2024-07-15 10:57:51 +00:00
|
|
|
templ Index(markets []types.Market) {
|
2024-07-09 20:41:29 +00:00
|
|
|
<html>
|
2024-07-10 04:21:22 +00:00
|
|
|
@components.Head()
|
2024-07-10 04:11:28 +00:00
|
|
|
<body class="container">
|
2024-07-12 05:38:28 +00:00
|
|
|
@components.Nav()
|
2024-07-12 03:40:45 +00:00
|
|
|
<div id="content" class="flex flex-col text-center">
|
2024-07-10 07:25:46 +00:00
|
|
|
@components.Figlet("random", "delphi")
|
2024-07-15 10:57:51 +00:00
|
|
|
<div class="font-mono my-3"><small>A prediction market using the lightning network</small></div>
|
|
|
|
<div
|
|
|
|
id="grid-container"
|
|
|
|
class="border border-muted text-start"
|
|
|
|
hx-target="#grid-container"
|
|
|
|
hx-swap="outerHTML"
|
|
|
|
hx-select="#grid-container"
|
|
|
|
hx-push-url="true"
|
|
|
|
>
|
|
|
|
<div class="border border-muted">
|
|
|
|
<button hx-get="/" class={ tabStyle(ctx.Value(c.ReqPathContextKey).(string), "/") }>markets</button>
|
|
|
|
<button hx-get="/create" class={ tabStyle(ctx.Value(c.ReqPathContextKey).(string), "/create") }>create</button>
|
|
|
|
</div>
|
|
|
|
if ctx.Value(c.ReqPathContextKey).(string) == "/" {
|
|
|
|
<div class="grid grid-cols-[auto_fit-content(10%)_fit-content(10%)]">
|
2024-09-05 21:11:29 +00:00
|
|
|
for _, m := range markets {
|
|
|
|
<span class="ps-3 border-b border-muted pb-3 mt-3">
|
|
|
|
<a href={ templ.SafeURL(fmt.Sprintf("/market/%d", m.Id)) }>{ m.Question }</a>
|
|
|
|
<div class="text-small text-muted">{ m.User.Name } / { humanize.Time(m.CreatedAt) } / { humanize.Time(m.EndDate) }</div>
|
|
|
|
</span>
|
|
|
|
<span class="px-3 border-b border-muted pb-3 mt-3 flex"><div class="self-center">51%</div></span>
|
|
|
|
<span class="pe-3 border-b border-muted pb-3 mt-3 flex"><div class="self-center">0</div></span>
|
|
|
|
}
|
2024-07-15 10:57:51 +00:00
|
|
|
</div>
|
|
|
|
} else {
|
|
|
|
<form
|
|
|
|
hx-post="/create"
|
|
|
|
hx-target="#modal"
|
|
|
|
hx-swap="outerHTML"
|
|
|
|
hx-select="#modal"
|
|
|
|
class="flex flex-col mx-3"
|
|
|
|
>
|
|
|
|
<label class="my-1" for="question">question</label>
|
|
|
|
<input
|
|
|
|
id="question"
|
|
|
|
name="question"
|
|
|
|
type="text"
|
|
|
|
class="my-1 p-1 text-black"
|
|
|
|
autocomplete="off"
|
|
|
|
required
|
|
|
|
/>
|
|
|
|
<div class="mt-3 mb-1">
|
|
|
|
<label for="description">description</label>
|
|
|
|
<span class="px-1 text-small text-muted">optional</span>
|
|
|
|
</div>
|
|
|
|
<textarea
|
|
|
|
id="description"
|
|
|
|
name="description"
|
|
|
|
type="text"
|
|
|
|
class="my-1 p-1 text-black"
|
|
|
|
></textarea>
|
|
|
|
<label class="mt-3" for="end_date">end date</label>
|
|
|
|
<input
|
|
|
|
id="end_date"
|
|
|
|
name="end_date"
|
|
|
|
type="date"
|
|
|
|
class="my-1 p-1 text-black"
|
|
|
|
autocomplete="off"
|
|
|
|
required
|
2024-09-05 21:12:34 +00:00
|
|
|
min={ minDate() }
|
2024-07-15 10:57:51 +00:00
|
|
|
/>
|
|
|
|
<button type="submit" class="mt-3">submit</button>
|
|
|
|
</form>
|
|
|
|
}
|
|
|
|
</div>
|
2024-07-09 20:41:29 +00:00
|
|
|
</div>
|
2024-07-15 10:57:51 +00:00
|
|
|
@components.Modal(nil)
|
2024-07-10 04:21:22 +00:00
|
|
|
@components.Footer()
|
2024-07-09 20:41:29 +00:00
|
|
|
</body>
|
|
|
|
</html>
|
|
|
|
}
|
2024-07-15 10:57:51 +00:00
|
|
|
|
2024-09-05 21:12:34 +00:00
|
|
|
func minDate() string {
|
|
|
|
return time.Now().Add(24 * time.Hour).Format("2006-01-02")
|
|
|
|
}
|
|
|
|
|
2024-07-15 10:57:51 +00:00
|
|
|
func tabStyle(path string, tab string) string {
|
|
|
|
class := "!no-underline"
|
|
|
|
if path == tab {
|
|
|
|
class += " font-bold border-b-none"
|
|
|
|
}
|
|
|
|
return class
|
|
|
|
}
|