2023-04-23 22:12:33 +03:00
|
|
|
// Copyright 2023 The Gitea Authors. All rights reserved.
|
|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
|
|
|
|
package timeutil
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"html"
|
|
|
|
"html/template"
|
2024-01-03 18:41:03 +08:00
|
|
|
"strings"
|
2023-04-26 03:48:30 +08:00
|
|
|
"time"
|
2023-04-23 22:12:33 +03:00
|
|
|
)
|
|
|
|
|
2023-04-26 03:48:30 +08:00
|
|
|
// DateTime renders an absolute time HTML element by datetime.
|
2024-01-03 18:41:03 +08:00
|
|
|
func DateTime(format string, datetime any, extraAttrs ...string) template.HTML {
|
2023-04-26 03:48:30 +08:00
|
|
|
if p, ok := datetime.(*time.Time); ok {
|
|
|
|
datetime = *p
|
|
|
|
}
|
|
|
|
if p, ok := datetime.(*TimeStamp); ok {
|
|
|
|
datetime = *p
|
|
|
|
}
|
|
|
|
switch v := datetime.(type) {
|
|
|
|
case TimeStamp:
|
|
|
|
datetime = v.AsTime()
|
|
|
|
case int:
|
|
|
|
datetime = TimeStamp(v).AsTime()
|
|
|
|
case int64:
|
|
|
|
datetime = TimeStamp(v).AsTime()
|
|
|
|
}
|
|
|
|
|
|
|
|
var datetimeEscaped, textEscaped string
|
|
|
|
switch v := datetime.(type) {
|
|
|
|
case nil:
|
2023-05-02 11:54:29 +02:00
|
|
|
return "-"
|
2023-04-26 03:48:30 +08:00
|
|
|
case string:
|
|
|
|
datetimeEscaped = html.EscapeString(v)
|
|
|
|
textEscaped = datetimeEscaped
|
|
|
|
case time.Time:
|
|
|
|
if v.IsZero() || v.Unix() == 0 {
|
2023-05-02 11:54:29 +02:00
|
|
|
return "-"
|
2023-04-26 03:48:30 +08:00
|
|
|
}
|
|
|
|
datetimeEscaped = html.EscapeString(v.Format(time.RFC3339))
|
|
|
|
if format == "full" {
|
|
|
|
textEscaped = html.EscapeString(v.Format("2006-01-02 15:04:05 -07:00"))
|
|
|
|
} else {
|
|
|
|
textEscaped = html.EscapeString(v.Format("2006-01-02"))
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
panic(fmt.Sprintf("Unsupported time type %T", datetime))
|
|
|
|
}
|
|
|
|
|
2024-01-03 18:41:03 +08:00
|
|
|
attrs := make([]string, 0, 10+len(extraAttrs))
|
|
|
|
attrs = append(attrs, extraAttrs...)
|
|
|
|
attrs = append(attrs, `data-tooltip-content`, `data-tooltip-interactive="true"`)
|
|
|
|
attrs = append(attrs, `format="datetime"`, `weekday=""`, `year="numeric"`)
|
|
|
|
|
2023-04-23 22:12:33 +03:00
|
|
|
switch format {
|
|
|
|
case "short":
|
2024-01-03 18:41:03 +08:00
|
|
|
attrs = append(attrs, `month="short"`, `day="numeric"`)
|
2023-04-23 22:12:33 +03:00
|
|
|
case "long":
|
2024-01-03 18:41:03 +08:00
|
|
|
attrs = append(attrs, `month="long"`, `day="numeric"`)
|
2023-04-23 22:12:33 +03:00
|
|
|
case "full":
|
2024-01-03 18:41:03 +08:00
|
|
|
attrs = append(attrs, `month="short"`, `day="numeric"`, `hour="numeric"`, `minute="numeric"`, `second="numeric"`)
|
|
|
|
default:
|
|
|
|
panic(fmt.Sprintf("Unsupported format %s", format))
|
2023-04-23 22:12:33 +03:00
|
|
|
}
|
2024-01-03 18:41:03 +08:00
|
|
|
return template.HTML(fmt.Sprintf(`<relative-time %s datetime="%s">%s</relative-time>`, strings.Join(attrs, " "), datetimeEscaped, textEscaped))
|
2023-04-23 22:12:33 +03:00
|
|
|
}
|