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


TypeScript actions.evolveTab方法代碼示例

本文整理匯總了TypeScript中common/actions.actions.evolveTab方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript actions.evolveTab方法的具體用法?TypeScript actions.evolveTab怎麽用?TypeScript actions.evolveTab使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在common/actions.actions的用法示例。


在下文中一共展示了actions.evolveTab方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: async

  watcher.on(actions.tabParamsChanged, async (store, action) => {
    let { tab, params, window } = action.payload;
    const sp = Space.fromStore(store, window, tab);

    const newParams = {
      ...sp.query(),
      ...params,
    };

    const previousURL = sp.url();
    const parsed = nodeURL.parse(previousURL);
    const { host, protocol, pathname } = parsed;
    const newURL = nodeURL.format({
      host,
      protocol,
      pathname,
      slashes: true,
      search: `?${querystring.stringify(newParams)}`,
    });

    store.dispatch(
      actions.evolveTab({
        window,
        tab,
        url: newURL,
        replace: true,
        onlyParamsChange: true,
      })
    );
  });
開發者ID:HorrerGames,項目名稱:itch,代碼行數:30,代碼來源:navigation.ts

示例2: makeEvolve

 makeEvolve(
   payload: Subtract<
     EvolveTabPayload,
     {
       tab: string;
       wind: string;
     }
   >
 ): Action<EvolveTabPayload> {
   return actions.evolveTab({
     wind: ambientWind(),
     tab: this.tab,
     ...payload,
   });
 }
開發者ID:itchio,項目名稱:itch,代碼行數:15,代碼來源:space.ts

示例3:

 const onNewPath = (url: string, resource: string) => {
   if (resource) {
     logger.debug(`Got resource ${resource}`);
     store.dispatch(
       actions.evolveTab({
         wind,
         tab,
         url,
         resource,
         replace: true,
         onlyIfMatchingURL: true,
         fromWebContents: true,
       })
     );
   }
 };
開發者ID:itchio,項目名稱:itch,代碼行數:16,代碼來源:web-contents.ts

示例4:

 const onNewPath = (url: string, resource: string) => {
   if (resource) {
     // FIXME: we need this to be better - analyze can finish after we've already navigated away
     // so we need to only set resource if the url is what we think it is
     logger.debug(`Got resource ${resource}`);
     store.dispatch(
       actions.evolveTab({
         window,
         tab,
         url,
         resource,
         replace: true,
       })
     );
   }
 };
開發者ID:HorrerGames,項目名稱:itch,代碼行數:16,代碼來源:web-contents.ts

示例5: parseWellKnownUrl

  const didNavigate = (url: string, navMode?: NavMode) => {
    let resource = null;
    const result = parseWellKnownUrl(url);
    if (result) {
      url = result.url;
      resource = result.resource;
      logger.debug(`Parsed well-known url: ${url} => ${resource}`);
    }

    store.dispatch(
      actions.evolveTab({
        wind,
        tab,
        url,
        label: wc.getTitle(),
        resource,
        replace: navMode === NavMode.Replace,
        fromWebContents: true,
      })
    );
  };
開發者ID:itchio,項目名稱:itch,代碼行數:21,代碼來源:web-contents.ts

示例6: parseWellKnownUrl

    const didNavigate = (url: string, replace?: boolean) => {
      if (url !== "about:blank") {
        let resource = null;
        const result = parseWellKnownUrl(url);
        if (result) {
          url = result.url;
          resource = result.resource;
          console.log(`Caught well-known url: `, result);
        }

        store.dispatch(
          actions.evolveTab({
            window,
            tab,
            url,
            resource,
            replace,
          })
        );
      }
    };
開發者ID:HorrerGames,項目名稱:itch,代碼行數:21,代碼來源:web-contents.ts

示例7: async

  watcher.on(actions.navigate, async (store, action) => {
    let { url, resource, wind, background, replace } = action.payload;
    logger.debug(`Navigating to ${url} ${background ? "(in background)" : ""}`);

    if (opensInWindow(url)) {
      store.dispatch(
        actions.openWind({
          initialURL: url,
          role: "secondary",
        })
      );
      return;
    }

    const space = Space.fromInstance("fictional-tab", {
      history: [{ url, resource }],
      currentIndex: 0,
      sequence: 0,
    });
    if (space.protocol() == "mailto:") {
      logger.debug(`Is mailto link, opening as external and skipping tab open`);
      shell.openExternal(space.suffix);
      return;
    }

    const rs = store.getState();
    if (hasMultipleTabs(rs, wind)) {
      const nativeWindow = getNativeWindow(rs, "root");
      if (
        nativeWindow &&
        nativeWindow.isFocused() &&
        !background &&
        url !== "itch://new-tab"
      ) {
        // let it navigate the open tab
      } else {
        // open a new tab!
        const tab = uuid();
        store.dispatch(
          actions.tabOpened({
            wind,
            tab,
            url,
            resource,
            background,
          })
        );
        return;
      }
    }

    {
      const { navigation } = rs.winds[wind];
      const tab = navigation.tab;

      // navigate the single tab
      store.dispatch(
        actions.evolveTab({
          tab,
          replace,
          wind,
          url,
          resource,
        })
      );
      store.dispatch(
        actions.focusWind({
          wind,
        })
      );
    }
  });
開發者ID:itchio,項目名稱:itch,代碼行數:72,代碼來源:navigation.ts


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