當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript domutil.toGUISelector方法代碼示例

本文整理匯總了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);
 }
開發者ID:mangalam-research,項目名稱:btw,代碼行數:3,代碼來源:mapped-util.ts

示例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 });
      }
    });
  }
開發者ID:mangalam-research,項目名稱:btw,代碼行數:87,代碼來源:btw-actions.ts

示例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));
}
開發者ID:mangalam-research,項目名稱:btw,代碼行數:6,代碼來源:btw-util.ts


注:本文中的wed.domutil.toGUISelector方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。