Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
05978f7fc3 | ||
|
|
4c3a508b84 | ||
|
|
6733ccd4b8 | ||
|
|
2f0c09ff72 |
@@ -61,6 +61,18 @@ func ToStrArr(k string) []string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func ToTime(s string) time.Time {
|
func ToTime(s string) time.Time {
|
||||||
v, _ := time.Parse("2006-01-02 15:04:05", s)
|
v, err := time.Parse("2006-01-02 15:04:05", s)
|
||||||
|
if err != nil || v.IsZero() {
|
||||||
|
v, err = time.Parse("2006-01-02", s)
|
||||||
|
}
|
||||||
|
if err != nil || v.IsZero() {
|
||||||
|
v, err = time.Parse("1/2/06", s)
|
||||||
|
}
|
||||||
|
if err != nil || v.IsZero() {
|
||||||
|
v, err = time.Parse("02 Jan 2006 3:04 PM", s)
|
||||||
|
}
|
||||||
|
if err != nil || v.IsZero() {
|
||||||
|
v, err = time.Parse("02 Jan 2006 3:04 PM", strings.ReplaceAll(s, "+", " "))
|
||||||
|
}
|
||||||
return v
|
return v
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -79,6 +79,18 @@ func TestToTime(t *testing.T) {
|
|||||||
in: "5",
|
in: "5",
|
||||||
out: "0001-01-01 00:00:00",
|
out: "0001-01-01 00:00:00",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
in: "1/2/03",
|
||||||
|
out: "2003-01-02 00:00:00",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
in: "11/12/03",
|
||||||
|
out: "2003-11-12 00:00:00",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
in: "01+Jan+2020+12:00+PM",
|
||||||
|
out: "2020-01-01 12:00:00",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
|
|||||||
@@ -94,6 +94,7 @@ func (a *Ajax) storageListTasks(listID string, filters ...func(t *task.Task) boo
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if filtered {
|
if filtered {
|
||||||
|
//task.Title = fmt.Sprintf("[%d] %s", task.Index, task.Title)
|
||||||
tasks = append(tasks, task)
|
tasks = append(tasks, task)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -54,7 +54,8 @@ func filterTags(tags []string) func(t *task.Task) bool {
|
|||||||
|
|
||||||
func filterSubstr(substr string) func(t *task.Task) bool {
|
func filterSubstr(substr string) func(t *task.Task) bool {
|
||||||
return func(t *task.Task) bool {
|
return func(t *task.Task) bool {
|
||||||
return substr == "" || strings.Contains(fmt.Sprintf("%+v", t), substr)
|
found := substr == "" || strings.Contains(strings.ToLower(fmt.Sprintf("%+v %+v", t.Title, t.Tags)), strings.ToLower(substr))
|
||||||
|
return found
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -39,7 +39,7 @@ func New(r *http.Request) (*Task, error) {
|
|||||||
UUID: form.NewUUID(),
|
UUID: form.NewUUID(),
|
||||||
Title: form.Get(r, "title"),
|
Title: form.Get(r, "title"),
|
||||||
Priority: form.ToInt(form.Get(r, "prio")),
|
Priority: form.ToInt(form.Get(r, "prio")),
|
||||||
Tags: StrList(form.ToStrArr(form.Get(r, "tags"))),
|
Tags: append(StrList(form.ToStrArr(form.Get(r, "tag"))), StrList(form.ToStrArr(form.Get(r, "tags")))...),
|
||||||
Created: time.Now(),
|
Created: time.Now(),
|
||||||
Edited: time.Now(),
|
Edited: time.Now(),
|
||||||
|
|
||||||
@@ -110,6 +110,13 @@ func (t *Task) MarshalJSON() ([]byte, error) {
|
|||||||
"dueInt": t.Due.Unix(),
|
"dueInt": t.Due.Unix(),
|
||||||
"dueTitle": "Due ",
|
"dueTitle": "Due ",
|
||||||
}
|
}
|
||||||
|
if t.Due.IsZero() {
|
||||||
|
for k := range m {
|
||||||
|
if strings.HasPrefix(k, "due") {
|
||||||
|
delete(m, k)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
if t.Complete {
|
if t.Complete {
|
||||||
m["dateCompleted"] = t.Completed.Format(fullFormat)
|
m["dateCompleted"] = t.Completed.Format(fullFormat)
|
||||||
m["dateCompletedInline"] = t.Completed.Format(shortFormat)
|
m["dateCompletedInline"] = t.Completed.Format(shortFormat)
|
||||||
|
|||||||
@@ -95,7 +95,8 @@ func (s *Server) phpProxy(w http.ResponseWriter, r *http.Request) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
http.Error(w, err.Error(), http.StatusInternalServerError)
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
} else {
|
} else {
|
||||||
log.Println("proxying", url.String(), r.URL.Path)
|
log.Println("WOULD proxy", url.String(), r.URL.Path)
|
||||||
|
s.index(w, r)
|
||||||
//proxy := httputil.NewSingleHostReverseProxy(url)
|
//proxy := httputil.NewSingleHostReverseProxy(url)
|
||||||
//proxy.ServeHTTP(w, r)
|
//proxy.ServeHTTP(w, r)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user