Calendar improvements

This commit is contained in:
Eduard Urbach 2017-11-22 12:20:57 +01:00
parent 473f9ae024
commit 9d13262b97
4 changed files with 39 additions and 8 deletions

View File

@ -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)

View File

@ -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

View File

@ -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) {

View File

@ -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
} }