Weekly Planner
Preview
Site time: 2026-05-16 04:53:26
12 am
1 am
2 am
3 am
4 am
5 am
6 am
7 am
8 am
9 am
10 am
11 am
12 pm
1 pm
2 pm
3 pm
4 pm
5 pm
6 pm
7 pm
8 pm
9 pm
10 pm
11 pm
Mon
11
var dump looped_date: 2026-05-11
var dump slot_date: 2026-05-11 00:00:00
var dump slot_date: 2026-05-11 01:00:00
var dump slot_date: 2026-05-11 02:00:00
var dump slot_date: 2026-05-11 03:00:00
var dump slot_date: 2026-05-11 04:00:00
var dump slot_date: 2026-05-11 05:00:00
var dump slot_date: 2026-05-11 06:00:00
var dump slot_date: 2026-05-11 07:00:00
var dump slot_date: 2026-05-11 08:00:00
var dump slot_date: 2026-05-11 09:00:00
var dump slot_date: 2026-05-11 10:00:00
var dump slot_date: 2026-05-11 11:00:00
var dump slot_date: 2026-05-11 12:00:00
var dump slot_date: 2026-05-11 13:00:00
var dump slot_date: 2026-05-11 14:00:00
var dump slot_date: 2026-05-11 15:00:00
var dump slot_date: 2026-05-11 16:00:00
var dump slot_date: 2026-05-11 17:00:00
var dump slot_date: 2026-05-11 18:00:00
var dump slot_date: 2026-05-11 19:00:00
var dump slot_date: 2026-05-11 20:00:00
var dump slot_date: 2026-05-11 21:00:00
var dump slot_date: 2026-05-11 22:00:00
var dump slot_date: 2026-05-11 23:00:00
Tue
12
var dump looped_date: 2026-05-12
var dump slot_date: 2026-05-12 00:00:00
var dump slot_date: 2026-05-12 01:00:00
var dump slot_date: 2026-05-12 02:00:00
var dump slot_date: 2026-05-12 03:00:00
var dump slot_date: 2026-05-12 04:00:00
var dump slot_date: 2026-05-12 05:00:00
var dump slot_date: 2026-05-12 06:00:00
var dump slot_date: 2026-05-12 07:00:00
var dump slot_date: 2026-05-12 08:00:00
var dump slot_date: 2026-05-12 09:00:00
var dump slot_date: 2026-05-12 10:00:00
var dump slot_date: 2026-05-12 11:00:00
var dump slot_date: 2026-05-12 12:00:00
var dump slot_date: 2026-05-12 13:00:00
var dump slot_date: 2026-05-12 14:00:00
var dump slot_date: 2026-05-12 15:00:00
var dump slot_date: 2026-05-12 16:00:00
var dump slot_date: 2026-05-12 17:00:00
var dump slot_date: 2026-05-12 18:00:00
var dump slot_date: 2026-05-12 19:00:00
var dump slot_date: 2026-05-12 20:00:00
var dump slot_date: 2026-05-12 21:00:00
var dump slot_date: 2026-05-12 22:00:00
var dump slot_date: 2026-05-12 23:00:00
Wed
13
var dump looped_date: 2026-05-13
var dump slot_date: 2026-05-13 00:00:00
var dump slot_date: 2026-05-13 01:00:00
var dump slot_date: 2026-05-13 02:00:00
var dump slot_date: 2026-05-13 03:00:00
var dump slot_date: 2026-05-13 04:00:00
var dump slot_date: 2026-05-13 05:00:00
var dump slot_date: 2026-05-13 06:00:00
var dump slot_date: 2026-05-13 07:00:00
var dump slot_date: 2026-05-13 08:00:00
var dump slot_date: 2026-05-13 09:00:00
var dump slot_date: 2026-05-13 10:00:00
var dump slot_date: 2026-05-13 11:00:00
var dump slot_date: 2026-05-13 12:00:00
var dump slot_date: 2026-05-13 13:00:00
var dump slot_date: 2026-05-13 14:00:00
var dump slot_date: 2026-05-13 15:00:00
var dump slot_date: 2026-05-13 16:00:00
var dump slot_date: 2026-05-13 17:00:00
var dump slot_date: 2026-05-13 18:00:00
var dump slot_date: 2026-05-13 19:00:00
var dump slot_date: 2026-05-13 20:00:00
var dump slot_date: 2026-05-13 21:00:00
var dump slot_date: 2026-05-13 22:00:00
var dump slot_date: 2026-05-13 23:00:00
Thu
14
var dump looped_date: 2026-05-14
var dump slot_date: 2026-05-14 00:00:00
var dump slot_date: 2026-05-14 01:00:00
var dump slot_date: 2026-05-14 02:00:00
var dump slot_date: 2026-05-14 03:00:00
var dump slot_date: 2026-05-14 04:00:00
var dump slot_date: 2026-05-14 05:00:00
var dump slot_date: 2026-05-14 06:00:00
var dump slot_date: 2026-05-14 07:00:00
var dump slot_date: 2026-05-14 08:00:00
var dump slot_date: 2026-05-14 09:00:00
var dump slot_date: 2026-05-14 10:00:00
var dump slot_date: 2026-05-14 11:00:00
var dump slot_date: 2026-05-14 12:00:00
var dump slot_date: 2026-05-14 13:00:00
var dump slot_date: 2026-05-14 14:00:00
var dump slot_date: 2026-05-14 15:00:00
var dump slot_date: 2026-05-14 16:00:00
var dump slot_date: 2026-05-14 17:00:00
var dump slot_date: 2026-05-14 18:00:00
var dump slot_date: 2026-05-14 19:00:00
var dump slot_date: 2026-05-14 20:00:00
var dump slot_date: 2026-05-14 21:00:00
var dump slot_date: 2026-05-14 22:00:00
var dump slot_date: 2026-05-14 23:00:00
Fri
15
var dump looped_date: 2026-05-15
var dump slot_date: 2026-05-15 00:00:00
var dump slot_date: 2026-05-15 01:00:00
var dump slot_date: 2026-05-15 02:00:00
var dump slot_date: 2026-05-15 03:00:00
var dump slot_date: 2026-05-15 04:00:00
var dump slot_date: 2026-05-15 05:00:00
var dump slot_date: 2026-05-15 06:00:00
var dump slot_date: 2026-05-15 07:00:00
var dump slot_date: 2026-05-15 08:00:00
var dump slot_date: 2026-05-15 09:00:00
var dump slot_date: 2026-05-15 10:00:00
var dump slot_date: 2026-05-15 11:00:00
var dump slot_date: 2026-05-15 12:00:00
var dump slot_date: 2026-05-15 13:00:00
var dump slot_date: 2026-05-15 14:00:00
var dump slot_date: 2026-05-15 15:00:00
var dump slot_date: 2026-05-15 16:00:00
var dump slot_date: 2026-05-15 17:00:00
var dump slot_date: 2026-05-15 18:00:00
var dump slot_date: 2026-05-15 19:00:00
var dump slot_date: 2026-05-15 20:00:00
var dump slot_date: 2026-05-15 21:00:00
var dump slot_date: 2026-05-15 22:00:00
var dump slot_date: 2026-05-15 23:00:00
Sat
16
var dump looped_date: 2026-05-16
var dump slot_date: 2026-05-16 00:00:00
var dump slot_date: 2026-05-16 01:00:00
var dump slot_date: 2026-05-16 02:00:00
var dump slot_date: 2026-05-16 03:00:00
var dump slot_date: 2026-05-16 04:00:00
var dump slot_date: 2026-05-16 05:00:00
var dump slot_date: 2026-05-16 06:00:00
var dump slot_date: 2026-05-16 07:00:00
var dump slot_date: 2026-05-16 08:00:00
var dump slot_date: 2026-05-16 09:00:00
var dump slot_date: 2026-05-16 10:00:00
var dump slot_date: 2026-05-16 11:00:00
var dump slot_date: 2026-05-16 12:00:00
var dump slot_date: 2026-05-16 13:00:00
var dump slot_date: 2026-05-16 14:00:00
var dump slot_date: 2026-05-16 15:00:00
var dump slot_date: 2026-05-16 16:00:00
var dump slot_date: 2026-05-16 17:00:00
var dump slot_date: 2026-05-16 18:00:00
var dump slot_date: 2026-05-16 19:00:00
var dump slot_date: 2026-05-16 20:00:00
var dump slot_date: 2026-05-16 21:00:00
var dump slot_date: 2026-05-16 22:00:00
var dump slot_date: 2026-05-16 23:00:00
Sun
17
var dump looped_date: 2026-05-17
var dump slot_date: 2026-05-17 00:00:00
var dump slot_date: 2026-05-17 01:00:00
var dump slot_date: 2026-05-17 02:00:00
var dump slot_date: 2026-05-17 03:00:00
var dump slot_date: 2026-05-17 04:00:00
var dump slot_date: 2026-05-17 05:00:00
var dump slot_date: 2026-05-17 06:00:00
var dump slot_date: 2026-05-17 07:00:00
var dump slot_date: 2026-05-17 08:00:00
var dump slot_date: 2026-05-17 09:00:00
var dump slot_date: 2026-05-17 10:00:00
var dump slot_date: 2026-05-17 11:00:00
var dump slot_date: 2026-05-17 12:00:00
var dump slot_date: 2026-05-17 13:00:00
var dump slot_date: 2026-05-17 14:00:00
var dump slot_date: 2026-05-17 15:00:00
var dump slot_date: 2026-05-17 16:00:00
var dump slot_date: 2026-05-17 17:00:00
var dump slot_date: 2026-05-17 18:00:00
var dump slot_date: 2026-05-17 19:00:00
var dump slot_date: 2026-05-17 20:00:00
var dump slot_date: 2026-05-17 21:00:00
var dump slot_date: 2026-05-17 22:00:00
var dump slot_date: 2026-05-17 23:00:00
<Set current_date><Date format="Y-m-d">today</Date></Set>
<Set current_hour><Date format="H">now</Date></Set>
<Set minute_to_percent><Math><Date format="i">now</Date> / 60 * 100</Math>%</Set>
<pre>Site time: <Date format="Y-m-d H:i:s">now</Date></pre><br />
<Loop type=calendar_week>
<div class="week-view">
<div class="week-view__labels">
<Loop times=24>
<div class="week-view__labels__label">
<span class="week-view__labels__label__inner">
<Format date="g a"><Math><Get loop=count /> - 1</Math>:00</Format>
</span>
</div>
</Loop>
</div>
<Loop type=calendar_day week="{Field week}">
<Set is_today><If variable=current_date value="{Field date date_format='Y-m-d'}">true</If></Set>
<Set looped_date><Field date date_format='Y-m-d' /></Set>
<div class="week-view__day">
<div class="week-view__day__heading {If variable=is_today}week-view__day__heading--today{/If}">
<div class="week-view__day__heading__weekday">
<Field short_name />
</div>
<div class="week-view__day__heading__date">
<Field day />
</div>
</div>
<div>
<div class="week-view__day__slot--all-day">
<Note>All day events here</Note>
</div>
<Loop times=24>
<Set index_to_hour><Math><Get loop=count /> - 1</Math></Set>
<Set slot_date><Format date="Y-m-d H:i:s"><Get looped_date /> <Get index_to_hour />:00</Format></Set>
<div class="week-view__day__slot">
<Note>Inline Events Here</Note>
<If variable=is_today>
<If variable=current_hour value="{Get index_to_hour}"><div class="week-view__day__time-marker" style="top: {Get minute_to_percent}"></div></If>
</If>
</div>
</Loop>
</div>
</div>
</Loop>
</div>
</Loop>
.week-view {
display: grid;
grid-template-columns: max-content repeat(7, 1fr);
&__labels {
padding-top: 80px;
&__label {
min-height: 50px;
display: flex;
align-items: flex-end;
justify-content: flex-end;
text-transform: uppercase;
font-size: 14px;
line-height: 1.2;
&__inner {
transform: translateY(50%);
display: flex;
align-items: center;
gap: 0.5em;
&::after {
content: "";
display: block;
width: 0.8em;
height: 1px;
background-color: #eee;
}
}
}
}
&__day__heading {
text-align: center;
min-height: 80px;
border-bottom: 1px solid #eee;
&__date {
width: 1.8em;
height: 1.8em;
display: inline-flex;
align-items: center;
justify-content: center;
border-radius: 100%;
}
&__weekday {
text-transform: uppercase;
font-size: 14px;
line-height: 1.2;
}
&--today {
.week-view__day__heading__date {
background-color: #002deb;
color: #fff;
}
}
}
[class^="week-view__day__slot"] {
min-height: 50px;
border-right: 1px solid #eee;
border-bottom: 1px solid #eee;
position: relative;
}
.week-view__labels + .week-view__day [class^="week-view__day__slot"] {
border-left: 1px solid #eee;
}
.week-view__day__time-marker {
display: block;
pointer-events: none;
height: 2px;
transform: translateY(1px);
background-color: red;
position: absolute;
left: -6px;
right: 0;
&::before {
content: "";
width: 12px;
height: 12px;
border-radius: 100%;
display: block;
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
background-color: red;
}
}
}
