Project import generated by Copybara.
GitOrigin-RevId: 63746295f1a5ab5a619056791995793d65529e62
diff --git a/src/inc/calendarsView.php b/src/inc/calendarsView.php
new file mode 100644
index 0000000..eddc230
--- /dev/null
+++ b/src/inc/calendarsView.php
@@ -0,0 +1,44 @@
+<?php
+class calendarsView {
+ public static function renderCalendar($current, $ends, $selectedFunc, $disabled = false, $extra = false) {
+ $interval = new DateInterval("P1D");
+
+ echo '<div class="overflow-wrapper">';
+
+ $start = true;
+ $day = 0;
+ while ($current->diff($ends)->invert === 0) {
+ $dow = (int)$current->format("w");
+ if ($dow == 0) $dow = 7;
+ $dom = (int)$current->format("d");
+
+ if ($dow == 1) echo "</tr>";
+ if ($dom == 1) echo "</table>";
+ if ($dom == 1 || $start) echo "<div class='month'>".security::htmlsafe(ucfirst(strftime("%B %G", $current->getTimestamp())))."</div><table class='calendar'>";
+ if ($dow == 1 || $start) echo "<tr>";
+ if ($dom == 1 || $start) {
+ for ($i = 1; $i < $dow; $i++) {
+ echo "<td></td>";
+ }
+ }
+
+ echo "<td class='day'><span class='date'>".$dom."</span><br><select name='type[$day]'".($disabled ? " disabled" : "").">";
+
+ foreach (calendars::$types as $id => $type) {
+ echo "<option value='".(int)$id."'".($selectedFunc($current->getTimestamp(), $id, $dow, $dom, $extra) ? " selected" : "").">".security::htmlsafe($type)."</option>";
+ }
+
+ echo "</td>";
+
+ $start = false;
+ $day++;
+ $current->add($interval);
+ }
+
+ for ($i = $dow + 1; $i <= 7; $i++) {
+ echo "<td></td>";
+ }
+
+ echo "</tr></table></div>";
+ }
+}