Skip to content

Commit

Permalink
npf.js: build lists before returning content
Browse files Browse the repository at this point in the history
also fixes an issue where lists under readmores would not be built
  • Loading branch information
AprilSylph committed Nov 5, 2021
1 parent 63be7f8 commit 9b1c655
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 7 deletions.
12 changes: 8 additions & 4 deletions src/lib/npf.js
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,10 @@ export const renderContent = ({ content: blocks, layout }) => {
}
});

buildLists(content);
if (askContent instanceof DocumentFragment) buildLists(askContent);
if (details instanceof Element) buildLists(details);

return {
content,
ask: askContent ? { content: askContent, ...ask } : undefined
Expand Down Expand Up @@ -308,13 +312,13 @@ const splitArray = (array, index) => [
array.slice(index)
];

export const buildLists = parentNode => {
const getFirstListItem = () => parentNode.querySelector(':scope > li[data-ordered]');
while (getFirstListItem() !== null) {
const buildLists = parentNode => {
const getFirstListItem = () => [...parentNode.children].find(element => element.matches('li[data-ordered]'));
while (getFirstListItem() !== undefined) {
const firstListItem = getFirstListItem();
const { ordered } = firstListItem.dataset;

const listElement = document.createElement(ordered === "true" ? 'ol' : 'ul');
const listElement = document.createElement(ordered === 'true' ? 'ol' : 'ul');
parentNode.insertBefore(listElement, firstListItem);
while (listElement.nextElementSibling?.dataset.ordered === ordered) {
listElement.append(listElement.nextElementSibling);
Expand Down
4 changes: 1 addition & 3 deletions src/manage.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { renderContent, buildLists } from './lib/npf.js';
import { renderContent } from './lib/npf.js';

const anonymousAvatarSrc = '';

Expand Down Expand Up @@ -74,11 +74,9 @@ const constructItem = ([timestamp, { recipient, recipientUrl, content, layout }]
}

askElement.append(ask.content);
buildLists(askElement);
}

bodyElement.append(renderedContent);
buildLists(bodyElement);

const footerElement = document.createElement('footer');
articleElement.appendChild(footerElement);
Expand Down

0 comments on commit 9b1c655

Please sign in to comment.