本文整理匯總了TypeScript中common/butlerd.asRequestError函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript asRequestError函數的具體用法?TypeScript asRequestError怎麽用?TypeScript asRequestError使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了asRequestError函數的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: makeInstallErrorModal
export function makeInstallErrorModal(params: InstallErrorParams) {
let buttons: IModalButtonSpec[] = [];
let detail: ILocalizedString;
let shouldRetry = true;
let forceDetails = false;
const { store, e, log, retryAction, stopAction, game } = params;
const { i18n } = store.getState();
const re = asRequestError(e);
if (re) {
switch (re.rpcError.code) {
case messages.Code.UnsupportedPackaging: {
const learnMore = t(i18n, ["docs.how_to_help"]);
detail = `[${learnMore}](https://itch.io/docs/itch/integrating/quickstart.html)`;
shouldRetry = false;
forceDetails = true;
break;
}
}
}
if (shouldRetry) {
buttons = [
...buttons,
{
label: ["game.install.try_again"],
icon: "repeat",
action: retryAction(),
},
];
}
buttons = [
...buttons,
{
label: ["grid.item.discard_download"],
icon: "delete",
action: stopAction(),
},
"cancel",
];
return modalWidgets.showError.make({
window: "root",
title: ["prompt.install_error.title"],
message: t(i18n, formatError(e)),
detail,
widgetParams: { rawError: e, log, forceDetails, game },
buttons,
});
}
示例2: isNetworkError
export function isNetworkError(e: Error) {
// this operates under the assumption that:
// * all our internal network errors should start with "err::"
// * all of chrome's already do
// * we transform fetch's into err:: variants.
// we coerce e.message into a string on the off chance that it's not defined
// or not a string.
const isJavaScriptNetworkError = e && ("" + e.message).indexOf("net::") === 0;
if (isJavaScriptNetworkError) {
return true;
}
const re = asRequestError(e);
if (re) {
if (re.rpcError.code === Code.NetworkDisconnected) {
return true;
}
}
return false;
}
示例3: async
onError: async (e: Error, log) => {
let title = game ? game.title : "<missing game>";
const re = asRequestError(e);
if (re) {
switch (re.rpcError.code) {
case Code.OperationAborted:
// just ignore it
return;
case Code.InstallFolderDisappeared:
// oh we can do something about that.
store.dispatch(
actions.openModal(
modalWidgets.naked.make({
window: "root",
title: ["game.install.could_not_launch", { title }],
coverUrl: game.coverUrl,
stillCoverUrl: game.stillCoverUrl,
message: `The folder where **${title}** was installed doesn't exist anymore.`,
detail: `That means we can't open it.`,
bigButtons: [
{
icon: "delete",
label: "Remove install entry",
tags: [{ label: "Recommended" }],
action: actions.queueCaveUninstall({ caveId: cave.id }),
},
{
icon: "folder-open",
label: "Open parent folder",
className: "secondary",
tags: [{ label: "Seeing is believing." }],
action: actions.exploreCave({ caveId: cave.id }),
},
],
buttons: ["nevermind"],
widgetParams: null,
})
)
);
return;
}
}
await promisedModal(
store,
modalWidgets.showError.make({
window: "root",
title: ["game.install.could_not_launch", { title }],
coverUrl: game.coverUrl,
stillCoverUrl: game.stillCoverUrl,
message: t(store.getState().i18n, formatError(e)),
detail: isInternalError(e)
? ["game.install.could_not_launch.detail"]
: null,
widgetParams: { rawError: e, log, game, forceDetails: true },
buttons: [
{
label: ["prompt.action.ok"],
},
{
label: showInExplorerString(),
className: "secondary",
action: actions.exploreCave({ caveId: cave.id }),
},
"cancel",
],
})
);
},
示例4: showInstallErrorModal
export async function showInstallErrorModal(params: InstallErrorParams) {
let buttons: ModalButtonSpec[] = [];
let detail: LocalizedString;
let shouldRetry = true;
let forceDetails = false;
const { store, e, log, retryAction, stopAction, game } = params;
const { i18n } = store.getState();
const re = asRequestError(e);
if (re) {
switch (re.rpcError.code) {
case messages.Code.UnsupportedPackaging: {
const learnMore = t(i18n, ["docs.how_to_help"]);
detail = `[${learnMore}](https://itch.io/docs/itch/integrating/quickstart.html)`;
shouldRetry = false;
forceDetails = true;
break;
}
}
}
if (shouldRetry) {
buttons = [
...buttons,
{
label: ["game.install.try_again"],
icon: "repeat",
action: retryAction(),
},
];
}
buttons = [
...buttons,
{
label: ["grid.item.discard_download"],
icon: "delete",
action: "widgetResponse",
},
"cancel",
];
const allowReport = isInternalError(e);
const typedModal = modals.showError.make({
wind: "root",
title: ["prompt.install_error.title"],
message: t(i18n, formatError(e)),
detail,
widgetParams: {
rawError: e,
log,
forceDetails,
game,
showSendReport: allowReport,
},
buttons,
});
const res = await promisedModal(store, typedModal);
if (res) {
store.dispatch(stopAction());
if (allowReport && res.sendReport) {
store.dispatch(
actions.sendFeedback({
log: mergeLogAndError(log, e),
})
);
}
}
}