ui balance filters and groups to houseyMcHouseface

main
bel 2024-07-20 09:48:46 -06:00
parent 6d174b031b
commit ee6ce95c0a
3 changed files with 44 additions and 35 deletions

View File

@ -1,32 +1,16 @@
package http
import (
"embed"
"flag"
"fmt"
"io/fs"
"log"
"net/http"
"os"
_ "embed"
"gogs.inhome.blapointe.com/ana-ledger/src/ledger"
)
//go:embed public/*
var _staticFileDir embed.FS
var publicHandler = func() http.Handler {
if os.Getenv("DEBUG") != "" {
return http.FileServer(http.Dir("./http/public"))
}
sub, err := fs.Sub(_staticFileDir, "public")
if err != nil {
panic(err)
}
return http.FileServer(http.FS(sub))
}()
func Main() {
likeName := flag.String("like-name", ".", "regexp to match")
likeBefore := flag.String("like-before", "9", "date str to compare")

View File

@ -35,12 +35,14 @@
function load() {
http("GET", "/api/transactions" /*?f="+f*/, (body, status) => {
var d = JSON.parse(body)
console.log("loading", d)
loadBalances(d.balances)
loadDeltas(d.deltas)
loadLastNLines(d.lastNLines)
})
}
function loadBalances(balances) {
console.log("loading balances", balances)
var result = `<table>`
for (var k in balances) {
result += `<tr style="display: flex; flex-direction: row; width: 100%; justify-content: space-between;"><td>${k}</td><td>${Math.floor(balances[k]["$"])}</td></tr>`

View File

@ -1,10 +1,12 @@
package http
import (
"embed"
"encoding/json"
"fmt"
"io/fs"
"net/http"
"path"
"os"
"slices"
"strconv"
"strings"
@ -15,6 +17,9 @@ import (
"gogs.inhome.blapointe.com/ana-ledger/src/view"
)
//go:embed public/*
var _staticFileDir embed.FS
type Router struct {
files ledger.Files
like struct {
@ -42,38 +47,48 @@ func NewRouter(files ledger.Files, likeName, likeBefore, likeAfter string, group
}
func (router Router) ServeHTTP(w http.ResponseWriter, r *http.Request) {
switch strings.Split(r.URL.Path, "/")[1] {
case "api":
router.API(w, r)
default:
router.FS(w, r)
}
}
func (router Router) FS(w http.ResponseWriter, r *http.Request) {
if os.Getenv("DEBUG") != "" {
http.FileServer(http.Dir("./http/public")).ServeHTTP(w, r)
} else {
sub, err := fs.Sub(_staticFileDir, "public")
if err != nil {
panic(err)
}
http.FileServer(http.FS(sub)).ServeHTTP(w, r)
}
}
func (router Router) API(w http.ResponseWriter, r *http.Request) {
switch r.URL.Path {
case "/api/transactions":
bpis, err := router.bpis()
if err != nil {
panic(err)
}
if !strings.HasPrefix(r.URL.Path, "/api") {
publicHandler.ServeHTTP(w, r)
return
}
reqF := router.files
if queryF := r.URL.Query().Get("f"); queryF != "" {
queryF = path.Join("http", queryF)
reqF, err = ledger.NewFiles(queryF)
lastNLines, err := router.files.TempGetLastNLines(20)
if err != nil {
panic(err)
}
}
switch r.URL.Path {
case "/api/transactions":
lastNLines, err := reqF.TempGetLastNLines(20)
if err != nil {
panic(err)
}
deltas, err := reqF.Deltas()
deltas, err := router.files.Deltas()
if err != nil {
panic(err)
}
json.NewEncoder(w).Encode(map[string]any{
"deltas": deltas.Like(ledger.LikeAfter(time.Now().Add(-1 * time.Hour * 24 * 365 / 2).Format("2006-01"))),
"balances": deltas.Balances().Like("^AssetAccount:").WithBPIs(bpis),
"balances": deltas.Balances().
Like("^(Bel:Asset|Zach:Asset|HouseyMcHouseface:Debts:Credit)").
Group(`^[^:]*`).
WithBPIs(bpis),
"lastNLines": lastNLines,
})
return
@ -86,14 +101,14 @@ func (router Router) ServeHTTP(w http.ResponseWriter, r *http.Request) {
if err := json.NewDecoder(r.Body).Decode(&lines); err != nil {
panic(err)
}
if err := reqF.TempSetLastNLines(20, lines); err != nil {
if err := router.files.TempSetLastNLines(20, lines); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
}
w.WriteHeader(http.StatusResetContent)
return
}
deltas, err := reqF.Deltas()
deltas, err := router.files.Deltas()
if err != nil {
panic(err)
}
@ -178,6 +193,10 @@ func (router Router) ServeHTTP(w http.ResponseWriter, r *http.Request) {
if err != nil {
panic(err)
}
bpis, err := router.bpis()
if err != nil {
panic(err)
}
bpis, err = ana.BPIsWithFixedGrowthPrediction(bpis, window, currency, rate)
if err != nil {
panic(err)
@ -186,6 +205,10 @@ func (router Router) ServeHTTP(w http.ResponseWriter, r *http.Request) {
}
if r.URL.Query().Get("bpi") == "true" {
bpis, err := router.bpis()
if err != nil {
panic(err)
}
register = register.WithBPIs(bpis)
predicted = predicted.WithBPIs(bpis)
}