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


TypeScript Menu.append方法代碼示例

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


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

示例1:

            session.plugins.getAllPlugins().forEach(plugin => {

                var subMenuItem = new Electron.MenuItem({
                    label: plugin.pluginName,
                    click: () => {
                        plugin.showDevTools();
                    }});
                subMenu.append(subMenuItem);
            });
開發者ID:waffle-iron,項目名稱:vim-electrify,代碼行數:9,代碼來源:ContextMenuCreator.ts

示例2: 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 })
    }
開發者ID:tamdao,項目名稱:desktop,代碼行數:18,代碼來源:main.ts

示例3: 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 })
    }
開發者ID:Aj-ajaam,項目名稱:desktop,代碼行數:21,代碼來源:main.ts

示例4: _rebuildContextMenu

    private _rebuildContextMenu(): void {
      var contextMenu = new Electron.Menu();

      this._sessionManager.getSessions()
        .forEach((session) => {
            var subMenu = new Electron.Menu();

            session.plugins.getAllPlugins().forEach(plugin => {

                var subMenuItem = new Electron.MenuItem({
                    label: plugin.pluginName,
                    click: () => {
                        plugin.showDevTools();
                    }});
                subMenu.append(subMenuItem);
            });

            var sessionItem = new Electron.MenuItem({
                label: session.name,
                submenu: subMenu
            });
            contextMenu.append(sessionItem);
        });


      var menuItem = new Electron.MenuItem({
          label: "Quit",
          click: () => {
            Electron.app.quit();
          }
      });

      contextMenu.append(menuItem);

      this._trayMenu.setToolTip('This is my application.');
      this._trayMenu.setContextMenu(contextMenu);
    }
開發者ID:waffle-iron,項目名稱:vim-electrify,代碼行數:37,代碼來源:ContextMenuCreator.ts

示例5: createMenu

function createMenu(): Electron.Menu {
  let main = new Menu();
  let scheduleMenu = new Menu();
  let newSchedule = new MenuItem({
    label: 'New',
    accelerator: 'CmdOrCtrl+N',
    click(item, focusedWindow) { createNewSchedule(); }
  });
  scheduleMenu.append(newSchedule);
  let open = new MenuItem({
    label: 'Open',
    accelerator: 'CmdOrCtrl+O',
    click(item, focusedWindow) { openScheduleFileDialog(); }
  });
  scheduleMenu.append(open);
  let merge = new MenuItem({
    label: 'Merge',
    accelerator: 'CmdOrCtrl+M',
    click(item, focusedWindow) {
      if (focusedWindow) {
        dialog.showOpenDialog(focusedWindow, {
          filters: [{ name: 'Schedules', extensions: ['json']}],
          properties: ['openFile'],
        }, (filenames: string[]) => {
          if (filenames && filenames[0]) {
            fs.readFile(filenames[0], 'utf8', (err, data) => {
              if (err) throw err;
              let new_schedule: Schedule = JSON.parse(data);
              getCurrentSchedule((schedule) => {
                schedule.series = schedule.series.concat(new_schedule.series);
                mainWindow.webContents.send('open-schedule', schedule);
              });
            });
          }
        });
      }
    }
  });
  scheduleMenu.append(merge);
  save = new MenuItem({
    label: 'Save',
    enabled: false,
    accelerator: 'CmdOrCtrl+S',
    click(item, focusedWindow) {
      if (focusedWindow) {
        getCurrentSchedule((schedule) => {
          if (currentFile) {
            fs.writeFile(currentFile, JSON.stringify(schedule, null, 2), 'utf8', (err) => {
              if (err) throw err;
            });
          }
        });
      }
    }
  });
  scheduleMenu.append(save);
  let saveAs = new MenuItem({
    label: 'Save As...',
    accelerator: 'CmdOrCtrl+Shift+S',
    click(item, focusedWindow) {
      if (focusedWindow) {
        getCurrentSchedule((schedule) => {
          dialog.showSaveDialog(focusedWindow, {
            filters: [{ name: 'Schedules', extensions: ['json']}],
          }, (filename: string) => {
            if (filename) {
              fs.writeFile(filename, JSON.stringify(schedule, null, 2), 'utf8', (err) => {
                if (err) throw err;
              });
            }
          });
        });
      }
    }
  });
  scheduleMenu.append(saveAs);
  main.append(new MenuItem({
    label: 'Schedule',
    submenu: scheduleMenu
  }));
  let generateMenu = new Menu();
  let posterWrapper = (window: Electron.BrowserWindow, month: number) => {
    dialog.showSaveDialog(window, {
      filters: [{ name: 'PDF', extensions: ['pdf']}],
    }, (filename: string) => {
      if (filename) {
        renderPoster(filename, month);
      }
    });
  };
  let poster = new MenuItem({
    label: 'Poster',
    submenu: [
      {
        label: 'August', accelerator: 'F8',
        click(item, focusedWindow) { posterWrapper(focusedWindow, 7); }
      },
      {
        label: 'September', accelerator: 'F9',
        click(item, focusedWindow) { posterWrapper(focusedWindow, 8); }
//.........這裏部分代碼省略.........
開發者ID:molisani,項目名稱:fcp-schedule,代碼行數:101,代碼來源:electron-main.ts


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