本文整理匯總了TypeScript中wed.domutil.toGUISelector方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript domutil.toGUISelector方法的具體用法?TypeScript domutil.toGUISelector怎麽用?TypeScript domutil.toGUISelector使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類wed.domutil
的用法示例。
在下文中一共展示了domutil.toGUISelector方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: toGUISelector
toGUISelector(selector: string): string {
return domutil.toGUISelector(selector, this.mapping);
}
示例2: execute
execute(data: TransformationData): void {
const editor = this.editor;
const dataCaret = editor.caretManager.getDataCaret(true)!;
const mode = editor.modeTree.getMode(dataCaret.node);
if (!(mode instanceof Mode)) {
throw new Error("expected BTW mode");
}
const doc = editor.guiRoot.ownerDocument;
const mappings = mode.getAbsoluteNamespaceMappings();
const examples =
editor.guiRoot.querySelectorAll(domutil.toGUISelector(
"btw:example, btw:example-explained", mappings));
const labels: Element[] = [];
const radios: Element[] = [];
// tslint:disable-next-line:prefer-for-of
for (let i = 0; i < examples.length; ++i) {
const example = examples[i];
const dataNode = $.data(example, "wed_mirror_node");
let child = dataNode.firstElementChild;
let cit;
while (child) {
if (child.tagName === "btw:cit") {
cit = child;
break;
}
child = child.nextElementSibling;
}
const abbr = example.querySelector(util.classFromOriginalName("ref",
mappings));
// We skip those examples that do not have a ref in them yet, as links to
// them are meaningless.
if (abbr === null) {
continue;
}
const abbrCopy = abbr.cloneNode(true) as Element;
child = abbrCopy.firstElementChild;
while (child) {
const next = child.nextElementSibling;
if (child.classList.contains("_gui")) {
abbrCopy.removeChild(child);
}
child = next;
}
const span = doc.createElement("span");
span.setAttribute("data-wed-id", example.id);
span.textContent = ` ${abbrCopy.textContent} ${cit.textContent}`;
const radio = doc.createElement("input");
radio.type = "radio";
radio.name = "example";
const div = doc.createElement("div");
div.appendChild(radio);
div.appendChild(span);
labels.push(div);
radios.push(radio);
}
const hyperlinkModal = mode.hyperlinkModal;
const primary = hyperlinkModal.getPrimary()[0] as HTMLButtonElement;
const body = doc.createElement("div");
for (const label of labels) {
body.appendChild(label);
}
$(radios).on("click.wed", () => {
primary.disabled = false;
primary.classList.remove("disabled");
});
primary.disabled = true;
primary.classList.add("disabled");
hyperlinkModal.setBody(body);
hyperlinkModal.modal(() => {
const clicked = hyperlinkModal.getClickedAsText();
if (clicked === "Insert") {
const id = body.querySelector("input[type='radio']:checked")!
.nextElementSibling!.getAttribute("data-wed-id")!;
mode.insertPtrTr.execute({ ...data, target: id });
}
});
}
示例3: termsForSense
export function termsForSense(sense: Element,
mappings: Record<string, string>):
NodeListOf<Element> {
return sense.querySelectorAll(
domutil.toGUISelector("btw:english-rendition>btw:english-term", mappings));
}