本文整理匯總了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,
})
);
});
示例2: makeEvolve
makeEvolve(
payload: Subtract<
EvolveTabPayload,
{
tab: string;
wind: string;
}
>
): Action<EvolveTabPayload> {
return actions.evolveTab({
wind: ambientWind(),
tab: this.tab,
...payload,
});
}
示例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,
})
);
}
};
示例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,
})
);
}
};
示例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,
})
);
};
示例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,
})
);
}
};
示例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,
})
);
}
});