Calendar improvements
This commit is contained in:
parent
473f9ae024
commit
9d13262b97
@ -8,5 +8,8 @@ component Calendar(days []*utils.CalendarDay, user *arn.User)
|
|||||||
.calendar-entries
|
.calendar-entries
|
||||||
each entry in day.Entries
|
each entry in day.Entries
|
||||||
.calendar-entry
|
.calendar-entry
|
||||||
.calendar-entry-title= entry.Anime.Title.ByUser(user)
|
a.ajax(href=entry.Anime.Link())
|
||||||
.calendar-entry-episode= "Ep: " + strconv.Itoa(entry.Episode.Number)
|
.calendar-entry-title= entry.Anime.Title.ByUser(user)
|
||||||
|
.calendar-entry-info
|
||||||
|
.calendar-entry-time.utc-date-absolute(data-date=entry.Episode.AiringDate.Start)
|
||||||
|
.calendar-entry-episode= "Ep: " + strconv.Itoa(entry.Episode.Number)
|
@ -12,21 +12,30 @@
|
|||||||
|
|
||||||
.weekday-name
|
.weekday-name
|
||||||
text-align center
|
text-align center
|
||||||
|
margin-bottom 1rem
|
||||||
|
|
||||||
.calendar-entries
|
.calendar-entries
|
||||||
vertical
|
vertical
|
||||||
|
|
||||||
.calendar-entry
|
.calendar-entry
|
||||||
ui-element
|
ui-element
|
||||||
padding 0.75rem 1rem
|
padding 0.5rem 1rem
|
||||||
margin-bottom 0.5rem
|
margin-bottom 0.5rem
|
||||||
overflow hidden
|
overflow hidden
|
||||||
|
|
||||||
|
.calendar-entry-info
|
||||||
|
horizontal
|
||||||
|
|
||||||
.calendar-entry-title
|
.calendar-entry-title
|
||||||
clip-long-text
|
clip-long-text
|
||||||
|
|
||||||
|
.calendar-entry-time
|
||||||
|
opacity 0.85
|
||||||
|
font-size 0.9rem
|
||||||
|
flex 1
|
||||||
|
|
||||||
.calendar-entry-episode
|
.calendar-entry-episode
|
||||||
opacity 0.75
|
opacity 0.65
|
||||||
text-align right
|
text-align right
|
||||||
font-size 0.9rem
|
font-size 0.9rem
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@ import { Analytics } from "./Analytics"
|
|||||||
import { SideBar } from "./SideBar"
|
import { SideBar } from "./SideBar"
|
||||||
import { InfiniteScroller } from "./InfiniteScroller"
|
import { InfiniteScroller } from "./InfiniteScroller"
|
||||||
import { ServiceWorkerManager } from "./ServiceWorkerManager"
|
import { ServiceWorkerManager } from "./ServiceWorkerManager"
|
||||||
import { displayAiringDate, displayDate } from "./DateView"
|
import { displayAiringDate, displayDate, displayTime } from "./DateView"
|
||||||
import { findAll, delay, canUseWebP, swapElements } from "./Utils"
|
import { findAll, delay, canUseWebP, swapElements } from "./Utils"
|
||||||
import * as actions from "./Actions"
|
import * as actions from "./Actions"
|
||||||
import { darkTheme } from "./Actions";
|
import { darkTheme } from "./Actions";
|
||||||
@ -362,6 +362,10 @@ export class AnimeNotifier {
|
|||||||
for(let element of findAll("utc-date")) {
|
for(let element of findAll("utc-date")) {
|
||||||
displayDate(element, now)
|
displayDate(element, now)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for(let element of findAll("utc-date-absolute")) {
|
||||||
|
displayTime(element, now)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
reloadContent(cached?: boolean) {
|
reloadContent(cached?: boolean) {
|
||||||
|
@ -55,7 +55,7 @@ function getRemainingTime(remaining: number): string {
|
|||||||
if(remainingAbs >= oneSecond) {
|
if(remainingAbs >= oneSecond) {
|
||||||
return plural(Math.round(remaining / oneSecond), " second")
|
return plural(Math.round(remaining / oneSecond), " second")
|
||||||
}
|
}
|
||||||
|
|
||||||
return "Just now"
|
return "Just now"
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -75,7 +75,7 @@ export function displayAiringDate(element: HTMLElement, now: Date) {
|
|||||||
h = endDate.getHours()
|
h = endDate.getHours()
|
||||||
m = endDate.getMinutes()
|
m = endDate.getMinutes()
|
||||||
let endTime = (h <= 9 ? "0" + h : h) + ":" + (m <= 9 ? "0" + m : m)
|
let endTime = (h <= 9 ? "0" + h : h) + ":" + (m <= 9 ? "0" + m : m)
|
||||||
|
|
||||||
let airingVerb = "will be airing"
|
let airingVerb = "will be airing"
|
||||||
|
|
||||||
let remaining = startDate.getTime() - now.getTime()
|
let remaining = startDate.getTime() - now.getTime()
|
||||||
@ -106,7 +106,7 @@ export function displayDate(element: HTMLElement, now: Date) {
|
|||||||
let h = startDate.getHours()
|
let h = startDate.getHours()
|
||||||
let m = startDate.getMinutes()
|
let m = startDate.getMinutes()
|
||||||
let startTime = (h <= 9 ? "0" + h : h) + ":" + (m <= 9 ? "0" + m : m)
|
let startTime = (h <= 9 ? "0" + h : h) + ":" + (m <= 9 ? "0" + m : m)
|
||||||
|
|
||||||
let remaining = startDate.getTime() - now.getTime()
|
let remaining = startDate.getTime() - now.getTime()
|
||||||
let remainingString = getRemainingTime(remaining)
|
let remainingString = getRemainingTime(remaining)
|
||||||
|
|
||||||
@ -118,4 +118,19 @@ export function displayDate(element: HTMLElement, now: Date) {
|
|||||||
element.innerText = remainingString
|
element.innerText = remainingString
|
||||||
|
|
||||||
element.title = dayNames[startDate.getDay()] + " " + startTime
|
element.title = dayNames[startDate.getDay()] + " " + startTime
|
||||||
|
}
|
||||||
|
|
||||||
|
export function displayTime(element: HTMLElement, now: Date) {
|
||||||
|
if(element.dataset.date === "") {
|
||||||
|
element.innerText = ""
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
let startDate = new Date(element.dataset.date)
|
||||||
|
|
||||||
|
let h = startDate.getHours()
|
||||||
|
let m = startDate.getMinutes()
|
||||||
|
let startTime = (h <= 9 ? "0" + h : h) + ":" + (m <= 9 ? "0" + m : m)
|
||||||
|
|
||||||
|
element.innerText = startTime
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user