ok that is pretty nice

This commit is contained in:
Bel LaPointe
2023-10-25 09:58:55 -06:00
parent f436a6d046
commit 12e5c37ba3

View File

@@ -7,7 +7,6 @@ import (
"log" "log"
"net/http" "net/http"
"os" "os"
"path"
"slices" "slices"
"sort" "sort"
"strings" "strings"
@@ -50,9 +49,21 @@ func main() {
like = append(like, ledger.LikeAfter(*likeAfter)) like = append(like, ledger.LikeAfter(*likeAfter))
foo := func(w http.ResponseWriter, r *http.Request) { foo := func(w http.ResponseWriter, r *http.Request) {
switch path.Dir(r.URL.Path) { foolike := make(ledger.Likes, 0)
case "/bal": for _, v := range r.URL.Query()["likeName"] {
register := deltas.Like(like...).Register() foolike = append(foolike, ledger.LikeName(v))
}
for _, v := range r.URL.Query()["likeAfter"] {
foolike = append(foolike, ledger.LikeAfter(v))
}
for _, v := range r.URL.Query()["likeBefore"] {
foolike = append(foolike, ledger.LikeBefore(v))
}
if len(foolike) == 0 {
foolike = like
}
register := deltas.Like(foolike...).Register()
nameCurrencyDateValue := map[string]map[ledger.Currency]map[string]float64{} nameCurrencyDateValue := map[string]map[ledger.Currency]map[string]float64{}
dates := []string{} dates := []string{}
for date, balances := range register { for date, balances := range register {
@@ -73,21 +84,51 @@ func main() {
line := charts.NewLine() line := charts.NewLine()
line.AddXAxis(dates) line.AddXAxis(dates)
switch r.URL.Path {
default:
http.NotFound(w, r)
return
case "/bal":
for name, currencyDateValue := range nameCurrencyDateValue { for name, currencyDateValue := range nameCurrencyDateValue {
for currency, dateValue := range currencyDateValue { for currency, dateValue := range currencyDateValue {
series := make([]int, len(dates)) series := make([]int, len(dates))
for i, date := range dates { for i := range dates {
series[i] = int(dateValue[date]) var lastValue float64
for j := range dates[:i+1] {
if newLastValue, ok := dateValue[dates[j]]; ok {
lastValue = newLastValue
}
}
series[i] = int(lastValue)
} }
key := fmt.Sprintf("%s (%s)", name, currency) key := fmt.Sprintf("%s (%s)", name, currency)
line.AddYAxis(key, series) line.AddYAxis(key, series)
} }
} }
case "/reg":
for name, currencyDateValue := range nameCurrencyDateValue {
for currency, dateValue := range currencyDateValue {
series := make([]int, len(dates))
for i := range dates {
var prevValue float64
var lastValue float64
for j := range dates[:i+1] {
if newLastValue, ok := dateValue[dates[j]]; ok {
prevValue = lastValue
lastValue = newLastValue
}
}
series[i] = int(lastValue - prevValue)
}
key := fmt.Sprintf("%s (%s)", name, currency)
line.AddYAxis(key, series)
}
}
}
if err := line.Render(w); err != nil { if err := line.Render(w); err != nil {
panic(err) panic(err)
} }
case "/reg":
}
} }
log.Println("listening on", *httpOutput) log.Println("listening on", *httpOutput)