mirror of
https://github.com/notion-enhancer/notion-enhancer.git
synced 2025-10-24 10:48:08 +11:00
extension: weekly view
This commit is contained in:
parent
8a1eb811a6
commit
6d40349389
@ -6,58 +6,36 @@
|
|||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
const pageSelector = '.notion-page-content',
|
||||||
|
calendarSelector = '.notion-calendar-view:not([data-calendar-scroll])',
|
||||||
|
scrollerSelector = '.notion-frame > .notion-scroller',
|
||||||
|
toolbarSelector = '.notion-calendar-view > :first-child > :first-child > :first-child',
|
||||||
|
todaySelector = '.notion-calendar-view-day[style*="background:"]';
|
||||||
|
|
||||||
export default function ({ web }, db) {
|
export default function ({ web }, db) {
|
||||||
const toolbarSelector = '.notion-calendar-view > :first-child > :first-child > :first-child',
|
const insertButton = () => {
|
||||||
|
document.querySelectorAll(calendarSelector).forEach(($calendar) => {
|
||||||
|
$calendar.dataset.calendarScroll = true;
|
||||||
|
const $page = document.querySelector(pageSelector);
|
||||||
|
if ($page) return;
|
||||||
|
const $toolbar = $calendar.querySelector(toolbarSelector),
|
||||||
|
$pageScroller = document.querySelector(scrollerSelector),
|
||||||
$scrollButton = web.html`<button id="enhancer--calendar-scroll">Scroll</button>`;
|
$scrollButton = web.html`<button id="enhancer--calendar-scroll">Scroll</button>`;
|
||||||
$scrollButton.addEventListener('click', async (event) => {
|
$scrollButton.addEventListener('click', async (event) => {
|
||||||
const $toolbar = document.querySelector(toolbarSelector),
|
let $today = $calendar.querySelector(todaySelector);
|
||||||
now = new Date(),
|
if (!$today) {
|
||||||
thisYear = now.getFullYear(),
|
$toolbar.children[4].click();
|
||||||
thisMonth = now.getMonth(),
|
await new Promise((res, rej) => setTimeout(res, 500));
|
||||||
allMonths = {
|
$today = $calendar.querySelector(todaySelector);
|
||||||
'January': 0,
|
|
||||||
'February': 1,
|
|
||||||
'March': 2,
|
|
||||||
'April': 3,
|
|
||||||
'May': 4,
|
|
||||||
'June': 5,
|
|
||||||
'July': 6,
|
|
||||||
'August': 7,
|
|
||||||
'September': 8,
|
|
||||||
'October': 9,
|
|
||||||
'November': 10,
|
|
||||||
'December': 11,
|
|
||||||
};
|
|
||||||
let $today;
|
|
||||||
while (!$today) {
|
|
||||||
const visibleYear = +$toolbar.children[0].innerText.split(' ')[1],
|
|
||||||
visibleMonth = allMonths[$toolbar.children[0].innerText.split(' ')[0]];
|
|
||||||
switch (true) {
|
|
||||||
case thisYear < visibleYear:
|
|
||||||
case thisYear === visibleYear && thisMonth < visibleMonth:
|
|
||||||
$toolbar.children[3].click();
|
|
||||||
break;
|
|
||||||
case thisYear > visibleYear:
|
|
||||||
case thisYear === visibleYear && thisMonth > visibleMonth:
|
|
||||||
$toolbar.children[5].click();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
$today = document.querySelector('.notion-calendar-view-day[style*="background:"]');
|
|
||||||
}
|
}
|
||||||
await new Promise((res, rej) => requestAnimationFrame(res));
|
$pageScroller.scroll({
|
||||||
}
|
|
||||||
const $scroller = document.querySelector('.notion-frame .notion-scroller');
|
|
||||||
$scroller.scroll({
|
|
||||||
top: $today.offsetParent.offsetParent.offsetTop + 70,
|
top: $today.offsetParent.offsetParent.offsetTop + 70,
|
||||||
behavior: 'auto',
|
behavior: 'auto',
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
$toolbar.insertBefore($scrollButton, $toolbar.children[2]);
|
||||||
const insertButton = () => {
|
});
|
||||||
if (document.contains($scrollButton)) return;
|
|
||||||
const $toolbar = document.querySelector(toolbarSelector);
|
|
||||||
if ($toolbar) $toolbar.insertBefore($scrollButton, $toolbar.children[2]);
|
|
||||||
};
|
};
|
||||||
web.addDocumentObserver(insertButton, ['.notion-calendar-view']);
|
web.addDocumentObserver(insertButton, [calendarSelector]);
|
||||||
insertButton();
|
insertButton();
|
||||||
}
|
}
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
"topbar-icons",
|
"topbar-icons",
|
||||||
"word-counter",
|
"word-counter",
|
||||||
"calendar-scroll",
|
"calendar-scroll",
|
||||||
|
"weekly-view",
|
||||||
"collapse-properties",
|
"collapse-properties",
|
||||||
"focus-mode"
|
"focus-mode"
|
||||||
]
|
]
|
||||||
|
@ -2,8 +2,8 @@
|
|||||||
"name": "right to left",
|
"name": "right to left",
|
||||||
"id": "b28ee2b9-4d34-4e36-be8a-ab5be3d79f51",
|
"id": "b28ee2b9-4d34-4e36-be8a-ab5be3d79f51",
|
||||||
"version": "1.5.0",
|
"version": "1.5.0",
|
||||||
"description": "enables auto rtl/ltr text direction detection..",
|
"description": "enables auto rtl/ltr text direction detection.",
|
||||||
"tags": ["extension", "automation"],
|
"tags": ["extension", "usability"],
|
||||||
"authors": [
|
"authors": [
|
||||||
{
|
{
|
||||||
"name": "obahareth",
|
"name": "obahareth",
|
||||||
|
43
repo/weekly-view/client.mjs
Normal file
43
repo/weekly-view/client.mjs
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
/*
|
||||||
|
* notion-enhancer: weekly view
|
||||||
|
* (c) 2021 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/)
|
||||||
|
* (https://notion-enhancer.github.io/) under the MIT license
|
||||||
|
*/
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
export default async function ({ web }, db) {
|
||||||
|
const pageSelector = '.notion-page-content',
|
||||||
|
calendarSelector = '.notion-calendar-view',
|
||||||
|
viewSelector = '.notion-collection-view-select:not([data-weekly-view])',
|
||||||
|
todaySelector = '.notion-calendar-view-day[style*="background"]',
|
||||||
|
weekSelector = '[style="position: relative; display: flex; height: 124px;"]',
|
||||||
|
toolbarBtnSelector =
|
||||||
|
'.notion-calendar-view > :first-child > :first-child > :first-child > :nth-last-child(2)';
|
||||||
|
|
||||||
|
const transformCalendarView = () => {
|
||||||
|
const $page = document.querySelector(pageSelector);
|
||||||
|
document.querySelectorAll(viewSelector).forEach(async ($view) => {
|
||||||
|
if ($view.innerText.toLowerCase() !== 'weekly') return;
|
||||||
|
const $calendar = $view.parentElement.parentElement.parentElement.parentElement;
|
||||||
|
if (!$calendar.querySelector(todaySelector)) {
|
||||||
|
$calendar.querySelector(toolbarBtnSelector).click();
|
||||||
|
}
|
||||||
|
await new Promise((res, rej) => requestAnimationFrame(res));
|
||||||
|
if ($page) {
|
||||||
|
for (const $week of $calendar.querySelectorAll(weekSelector)) {
|
||||||
|
if (!$week.querySelector(todaySelector)) $week.style.height = '0';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
const $weekContainer = $calendar.querySelector(weekSelector).parentElement;
|
||||||
|
$weekContainer.style.maxHeight = '124px';
|
||||||
|
for (const $week of $calendar.querySelectorAll(weekSelector)) {
|
||||||
|
if (!$week.querySelector(todaySelector)) {
|
||||||
|
$week.style.height = '0';
|
||||||
|
} else break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
web.addDocumentObserver(transformCalendarView, [calendarSelector]);
|
||||||
|
}
|
20
repo/weekly-view/mod.json
Normal file
20
repo/weekly-view/mod.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "weekly view",
|
||||||
|
"id": "4c7acaea-6596-4590-85e5-8ac5a1455e8f",
|
||||||
|
"version": "0.6.0",
|
||||||
|
"description": "calendar views named \"weekly\" will show only the current week.",
|
||||||
|
"tags": ["extension", "layout"],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "dragonwocky",
|
||||||
|
"email": "thedragonring.bod@gmail.com",
|
||||||
|
"homepage": "https://dragonwocky.me/",
|
||||||
|
"avatar": "https://dragonwocky.me/avatar.jpg"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"js": {
|
||||||
|
"client": ["client.mjs"]
|
||||||
|
},
|
||||||
|
"css": {},
|
||||||
|
"options": []
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user