本文整理匯總了TypeScript中@nteract/core.actions.publishGist方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript actions.publishGist方法的具體用法?TypeScript actions.publishGist怎麽用?TypeScript actions.publishGist使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類@nteract/core.actions
的用法示例。
在下文中一共展示了actions.publishGist方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: catch
remote.ipcMain.on("auth", (_event: Event, auth: string) => {
try {
const accessToken = JSON.parse(auth).access_token;
store.dispatch(actions.setGithubToken(accessToken));
const notificationSystem = selectors.notificationSystem(state);
notificationSystem.addNotification({
title: "Authenticated",
message: "🔒",
level: "info"
});
// We are now authenticated and can finally publish
store.dispatch(actions.publishGist(ownProps));
} catch (e) {
store.dispatch(actions.coreError(e));
} finally {
win.close();
}
});
示例2: dispatchPublishGist
export function dispatchPublishGist(
ownProps: { contentRef: ContentRef },
store: DesktopStore,
_event: Event
) {
const state = store.getState();
const githubToken = state.app.get("githubToken");
// The simple case -- we have a token and can publish
if (githubToken != null) {
store.dispatch(actions.publishGist(ownProps));
return;
}
// If the Github Token isn't set, use our oauth server to acquire a token
// Because the remote object from Electron main <--> renderer can be "cleaned up"
// we re-require electron here and get the remote object
const remote = require("electron").remote;
// Create our oauth window
const win = new remote.BrowserWindow({
show: false,
webPreferences: { zoomFactor: 0.75 }
});
// TODO: This needs to be moved to an epic
win.webContents.on("dom-ready", () => {
// When we're at our callback code page, keep the page hidden
if (win.webContents.getURL().indexOf("callback?code=") !== -1) {
// Extract the text content
win.webContents.executeJavaScript(
"require('electron').ipcRenderer.send('auth', document.body.textContent);"
);
remote.ipcMain.on("auth", (_event: Event, auth: string) => {
try {
const accessToken = JSON.parse(auth).access_token;
store.dispatch(actions.setGithubToken(accessToken));
const notificationSystem = selectors.notificationSystem(state);
notificationSystem.addNotification({
title: "Authenticated",
message: "🔒",
level: "info"
});
// We are now authenticated and can finally publish
store.dispatch(actions.publishGist(ownProps));
} catch (e) {
store.dispatch(actions.coreError(e));
} finally {
win.close();
}
});
} else {
win.show();
}
});
win.loadURL("https://oauth.nteract.io/github");
}