Skip to content

Commit

Permalink
use optdata()
Browse files Browse the repository at this point in the history
  • Loading branch information
saschanaz committed Dec 4, 2019
1 parent 7c31963 commit e358ec8
Show file tree
Hide file tree
Showing 6 changed files with 38 additions and 46 deletions.
2 changes: 1 addition & 1 deletion src/core/import-maps.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ export const webidl2 = _webidl2;
/** @type {import("nanohtml").default} */
// @ts-ignore
export const hyperHTML = _html;
/** @type {import("nanohtml/raw")} */
/** @type {import("nanohtml/raw").default} */
// @ts-ignore
export const raw = _raw;
/** @type {import("marked")} */
Expand Down
23 changes: 9 additions & 14 deletions src/core/inline-idl-parser.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
// and renders its components as HTML

import { hyperHTML, raw } from "./import-maps.js";
import { showInlineError } from "./utils.js";
import { optdata, showInlineError } from "./utils.js";
const idlPrimitiveRegex = /^[a-z]+(\s+[a-z]+)+$/; // {{unrestricted double}} {{ double }}
const exceptionRegex = /\B"([^"]*)"\B/; // {{ "SomeException" }}
const methodRegex = /(\w+)\((.*)\)$/;
Expand Down Expand Up @@ -153,15 +153,12 @@ function renderInternalSlot(details) {
const { identifier, parent, renderParent } = details;
const { identifier: linkFor } = parent || {};
const lt = `[[${identifier}]]`;
const dot = parent && renderParent ? "." : "";
const anchor = hyperHTML`<a
const html = hyperHTML`${parent && renderParent ? "." : ""}[[<a
data-xref-type="attribute"
${optdata("link-for", linkFor)}
${optdata("xref-for", linkFor)}
data-lt="${lt}"><code>[[${identifier}]]</code></a>`;
if (linkFor) {
anchor.dataset.linkFor = linkFor;
anchor.dataset.xrefFor = linkFor;
}
return hyperHTML`${dot}${anchor}${""}`; // TODO: remove dangling empty string
return html;
}

/**
Expand Down Expand Up @@ -206,15 +203,13 @@ function renderMethod(details) {
function renderEnum(details) {
const { identifier, enumValue, parent } = details;
const forContext = parent ? parent.identifier : identifier;
const anchor = hyperHTML`<a
const html = hyperHTML`"<a
data-xref-type="enum-value"
data-link-for="${forContext}"
data-xref-for="${forContext}"
><code>${enumValue}</code></a>`;
if (!enumValue) {
anchor.dataset.lt = "the-empty-string";
}
return hyperHTML`"${anchor}"`;
${optdata("lt", !enumValue ? "the-empty-string" : null)}
><code>${enumValue}</code></a>"`;
return html;
}

/**
Expand Down
20 changes: 6 additions & 14 deletions src/core/inlines.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import {
InsensitiveStringSet,
getTextNodes,
norm,
optdata,
refTypeFromContext,
showInlineError,
showInlineWarning,
Expand Down Expand Up @@ -138,11 +139,7 @@ function inlineVariableMatches(matched) {
// remove "|" at the beginning and at the end, then split at an optional `:`
const matches = matched.slice(1, -1).split(":", 2);
const [varName, type] = matches.map(s => s.trim());
const element = hyperHTML`<var>${varName}</var>`;
if (type) {
element.dataset.type = type;
}
return element;
return hyperHTML`<var ${optdata("type", type)}>${varName}</var>`;
}

/**
Expand All @@ -161,15 +158,10 @@ function inlineAnchorMatches(matched) {
: [null, content];
const processedContent = processInlineContent(text);
const forContext = isFor ? norm(isFor) : null;
const anchor = hyperHTML`<a>${processedContent}</a>`;
if (forContext) {
anchor.dataset.linkFor = forContext;
anchor.dataset.xrefFor = forContext;
}
if (linkingText) {
anchor.dataset.lt = linkingText;
}
return anchor;
return hyperHTML`<a
${optdata("link-for", forContext)}
${optdata("xref-for", forContext)}
${optdata("lt", linkingText)}>${processedContent}</a>`;
}

function inlineCodeMatches(matched) {
Expand Down
13 changes: 13 additions & 0 deletions src/core/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -851,3 +851,16 @@ function* walkTree(walker) {
yield /** @type {T} */ (walker.currentNode);
}
}

/**
* Generates an object with data-${name} field, useful for templating libraries.
* @param {string} dataAttrName
* @param {*} value
*/
export function optdata(dataAttrName, value) {
if (value == null) {
// null or undefined
return {};
}
return { [`data-${dataAttrName}`]: value };
}
17 changes: 6 additions & 11 deletions src/core/webidl.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
import { decorateDfn, findDfn } from "./dfn-finder.js";
import {
flatten,
optdata,
showInlineError,
showInlineWarning,
xmlEscape,
Expand Down Expand Up @@ -70,14 +71,10 @@ const templates = {
}
}
}
const anchor = hyperHTML`<a data-xref-type="${type}">${wrapped}</a>`;
if (cite) {
anchor.dataset.cite = cite;
}
if (lt) {
anchor.dataset.lt = lt;
}
return anchor;
return hyperHTML`<a
data-xref-type="${type}"
${optdata("cite", cite)}
${optdata("lt", lt)}>${wrapped}</a>`;
},
name(escaped, { data, parent }) {
if (data.idlType && data.idlType.type === "argument-type") {
Expand Down Expand Up @@ -166,13 +163,11 @@ function defineIdlName(escaped, data, parent) {
}

const unlinkedAnchor = hyperHTML`<a
${optdata("idl", data.partial ? "partial" : null)}
data-link-type="${linkType}"
data-title="${data.name}"
data-xref-type="${linkType}"
>${escaped}</a>`;
if (data.partial) {
unlinkedAnchor.dataset.idl = "partial";
}

const showWarnings =
name && data.type !== "typedef" && !(data.partial && !dfn);
Expand Down
9 changes: 3 additions & 6 deletions src/w3c/templates/sotd.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
// @ts-check
import { hyperHTML as html, raw } from "../../core/import-maps.js";
import { optdata } from "../../core/utils.js";

export default (conf, opts) => {
return html`
Expand Down Expand Up @@ -217,8 +218,8 @@ function renderDeliverer(conf) {
const wontBeRec = recNotExpected
? "The group does not expect this document to become a W3C Recommendation."
: "";
const paragraph = html`
<p>
return html`
<p ${optdata("deliverer", isNote ? wgId : null)}>
${producers} ${wontBeRec}
${!isNote && !isIGNote
? html`
Expand Down Expand Up @@ -257,10 +258,6 @@ function renderDeliverer(conf) {
: ""}
</p>
`;
if (isNote) {
paragraph.dataset.deliverer = wgId;
}
return paragraph;
}

function noteForSubmission(conf, opts) {
Expand Down

0 comments on commit e358ec8

Please sign in to comment.