-
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
infinite scroll and swap addition leading into code refactory
- Loading branch information
Showing
10 changed files
with
817 additions
and
326 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,117 @@ | ||
package main | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
"log/slog" | ||
"net/http" | ||
"path/filepath" | ||
"strconv" | ||
|
||
"github.com/donseba/go-partial" | ||
"github.com/donseba/go-partial/connector" | ||
) | ||
|
||
type ( | ||
App struct { | ||
PartialService *partial.Service | ||
} | ||
) | ||
|
||
func main() { | ||
logger := slog.Default() | ||
|
||
app := &App{ | ||
PartialService: partial.NewService(&partial.Config{ | ||
Logger: logger, | ||
Connector: connector.NewPartial(&connector.Config{ | ||
UseURLQuery: true, | ||
}), | ||
}), | ||
} | ||
|
||
mux := http.NewServeMux() | ||
|
||
mux.Handle("GET /js/", http.StripPrefix("/js/", http.FileServer(http.Dir("../../js")))) | ||
|
||
mux.HandleFunc("GET /", app.home) | ||
|
||
server := &http.Server{ | ||
Addr: ":8080", | ||
Handler: mux, | ||
} | ||
|
||
logger.Info("starting server on :8080") | ||
err := server.ListenAndServe() | ||
if err != nil { | ||
logger.Error("error starting server", "error", err) | ||
} | ||
} | ||
|
||
// super simple example of how to use the partial service to render a layout with a content partial | ||
func (a *App) home(w http.ResponseWriter, r *http.Request) { | ||
// layout, footer, index could be abstracted away and shared over multiple handlers within the same module, for instance. | ||
layout := a.PartialService.NewLayout() | ||
footer := partial.NewID("footer", filepath.Join("templates", "footer.gohtml")) | ||
index := partial.NewID("index", filepath.Join("templates", "index.gohtml")).WithOOB(footer) | ||
|
||
content := partial.NewID("content", filepath.Join("templates", "content.gohtml")).WithAction(func(ctx context.Context, p *partial.Partial, data *partial.Data) (*partial.Partial, error) { | ||
switch p.GetRequestedAction() { | ||
case "infinite-scroll": | ||
return handleInfiniteScroll(p, data) | ||
default: | ||
return p, nil | ||
} | ||
}) | ||
|
||
// set the layout content and wrap it with the main template | ||
layout.Set(content).Wrap(index) | ||
|
||
err := layout.WriteWithRequest(r.Context(), w, r) | ||
if err != nil { | ||
http.Error(w, fmt.Errorf("error rendering layout: %w", err).Error(), http.StatusInternalServerError) | ||
} | ||
} | ||
|
||
type ( | ||
Row struct { | ||
ID int | ||
Name string | ||
Desc string | ||
} | ||
) | ||
|
||
func handleInfiniteScroll(p *partial.Partial, data *partial.Data) (*partial.Partial, error) { | ||
startID := 0 | ||
if p.GetRequest().URL.Query().Get("ID") != "" { | ||
startID, _ = strconv.Atoi(p.GetRequest().URL.Query().Get("ID")) | ||
} | ||
|
||
if startID >= 100 { | ||
p.SetResponseHeaders(map[string]string{ | ||
"X-Swap": "innerHTML", | ||
"X-Infinite-Scroll": "stop", | ||
}) | ||
p = partial.NewID("rickrolled", filepath.Join("templates", "rickrolled.gohtml")) | ||
} else { | ||
data.Data["Rows"] = generateNextRows(startID, 10) | ||
} | ||
|
||
return p, nil | ||
} | ||
|
||
func generateNextRows(lastID int, count int) []Row { | ||
var out []Row | ||
start := lastID + 1 | ||
end := lastID + count | ||
|
||
for i := start; i <= end; i++ { | ||
out = append(out, Row{ | ||
ID: i, | ||
Name: fmt.Sprintf("Name %d", i), | ||
Desc: fmt.Sprintf("Description %d", i), | ||
}) | ||
} | ||
|
||
return out | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
{{ with .Data.rickrolled }} | ||
{{ . }} | ||
{{ else }} | ||
{{ range $k, $v := .Data.Rows }} | ||
<div class="row" x-params='{"ID": {{ $v.ID }}}'> | ||
<div class="col-sm"> | ||
{{ $v.ID }} | ||
</div> | ||
<div class="col-sm"> | ||
{{ $v.Name }} | ||
</div> | ||
<div class="col-sm"> | ||
{{ $v.Desc }} | ||
</div> | ||
</div> | ||
{{ end}} | ||
{{ end }} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
<div id="footer" {{ if swapOOB }}x-swap-oob="outerHTML"{{end}} class="container">footer time : {{ formatDate now "15:04:05" }} - {{ if swapOOB }}swapped with OOB{{else}}rendered on load{{end}}</div> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
<!DOCTYPE html> | ||
<html lang="en"> | ||
<head> | ||
<title>Infinite Scroll</title> | ||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.0-beta1/dist/css/bootstrap.min.css"> | ||
<script type="application/javascript" src="/js/partial.js"></script> | ||
</head> | ||
|
||
<body> | ||
|
||
|
||
<div class="mt-3 container"> | ||
<div>(rendered on load at : {{ formatDate now "15:04:05" }})</div> | ||
<div class="mt-3">What the handler looks like: </div> | ||
|
||
<pre class="mt-3 p-1" style="background-color: gray"><small>func (a *App) home(w http.ResponseWriter, r *http.Request) { | ||
// layout, footer, index could be abstracted away and shared over multiple handlers within the same module, for instance. | ||
layout := a.PartialService.NewLayout() | ||
footer := partial.NewID("footer", filepath.Join("templates", "footer.gohtml")) | ||
index := partial.NewID("index", filepath.Join("templates", "index.gohtml")).WithOOB(footer) | ||
|
||
content := partial.NewID("content", filepath.Join("templates", "content.gohtml")).WithAction(func(ctx context.Context, p *partial.Partial, data *partial.Data) (*partial.Partial, error) { | ||
switch p.GetRequestedAction() { | ||
case "infinite-scroll": | ||
return handleInfiniteScroll(p, data) | ||
default: | ||
return p, nil | ||
} | ||
}) | ||
|
||
// set the layout content and wrap it with the main template | ||
layout.Set(content).Wrap(index) | ||
|
||
err := layout.WriteWithRequest(r.Context(), w, r) | ||
if err != nil { | ||
http.Error(w, fmt.Errorf("error rendering layout: %w", err).Error(), http.StatusInternalServerError) | ||
} | ||
}</small></pre> | ||
</div> | ||
|
||
{{ child "footer" }} | ||
|
||
<div class="mt-3 container" id="content" x-infinite-scroll="true" x-get="/" x-swap="beforeend"> | ||
{{ child "content" }} | ||
</div> | ||
|
||
<script> | ||
// Initialize the handler with optional configuration | ||
const partial = new Partial(); | ||
</script> | ||
</body> | ||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
<div> | ||
<h1>Don’t scroll too far, there are consequences</h1> | ||
<div>That's enough scrolling for you today.</div> | ||
<iframe id="rick" width="560" height="315" src="https://www.youtube.com/embed/dQw4w9WgXcQ?autoplay=1" allow='autoplay'></iframe> | ||
</div> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.