本文整理匯總了TypeScript中electron.BrowserWindow.fromWebContents方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript BrowserWindow.fromWebContents方法的具體用法?TypeScript BrowserWindow.fromWebContents怎麽用?TypeScript BrowserWindow.fromWebContents使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類electron.BrowserWindow
的用法示例。
在下文中一共展示了BrowserWindow.fromWebContents方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: findMenuItemByID
(event: Electron.IpcMessageEvent, { id }: { id: string }) => {
const menuItem = findMenuItemByID(menu, id)
if (menuItem) {
const window = BrowserWindow.fromWebContents(event.sender)
const fakeEvent = { preventDefault: () => {}, sender: event.sender }
menuItem.click(fakeEvent, window, event.sender)
}
}
示例2: buildContextMenu
(event: Electron.IpcMessageEvent, items: ReadonlyArray<IMenuItem>) => {
const menu = buildContextMenu(items, ix =>
event.sender.send('contextual-menu-action', ix)
)
const window = BrowserWindow.fromWebContents(event.sender)
menu.popup({ window })
}
示例3: createMenu
ipcMain.on(CONTEXT_MENU_CHANNEL, (event: Event, contextMenuId: number, items: ISerializableContextMenuItem[], onClickChannel: string, options?: IPopupOptions) => {
const menu = createMenu(event, onClickChannel, items);
menu.popup({
window: BrowserWindow.fromWebContents(event.sender),
x: options ? options.x : void 0,
y: options ? options.y : void 0,
positioningItem: options ? options.positioningItem : void 0,
callback: () => {
event.sender.send(CONTEXT_MENU_CLOSE_CHANNEL, contextMenuId);
}
});
});
示例4: Menu
(event: Electron.IpcMessageEvent, items: ReadonlyArray<any>) => {
const menu = new Menu()
const menuItems = items.map((item, i) => {
return new MenuItem({
label: item.label,
click: () => event.sender.send('contextual-menu-action', i),
type: item.type,
enabled: item.enabled,
})
})
for (const item of menuItems) {
menu.append(item)
}
const window = BrowserWindow.fromWebContents(event.sender)
menu.popup(window, { async: true })
}
示例5: createMenu
ipcMain.on(CONTEXT_MENU_CHANNEL, (event: Event, contextMenuId: number, items: ISerializableContextMenuItem[], onClickChannel: string, options?: IPopupOptions) => {
const menu = createMenu(event, onClickChannel, items);
menu.popup({
window: BrowserWindow.fromWebContents(event.sender),
x: options ? options.x : undefined,
y: options ? options.y : undefined,
positioningItem: options ? options.positioningItem : undefined,
callback: () => {
// Workaround for https://github.com/Microsoft/vscode/issues/72447
// It turns out that the menu gets GC'ed if not referenced anymore
// As such we drag it into this scope so that it is not being GC'ed
if (menu) {
event.sender.send(CONTEXT_MENU_CLOSE_CHANNEL, contextMenuId);
}
}
});
});
示例6: Menu
(event: Electron.IpcMessageEvent, items: ReadonlyArray<any>) => {
const menu = new Menu()
const menuItems = items.map((item, i) => {
return new MenuItem({
label: item.label,
click: () => event.sender.send('contextual-menu-action', i),
type: item.type,
enabled: item.enabled,
})
})
for (const item of menuItems) {
menu.append(item)
}
const window = BrowserWindow.fromWebContents(event.sender)
// TODO: read https://github.com/desktop/desktop/issues/1003
// to clean up this sin against T Y P E S
const anyMenu: any = menu
anyMenu.popup(window, { async: true })
}