Skip to content

Commit

Permalink
feat: implement electron with capacitor
Browse files Browse the repository at this point in the history
  • Loading branch information
ibuioli committed Feb 10, 2020
1 parent e6dead3 commit df62f6a
Show file tree
Hide file tree
Showing 55 changed files with 11,043 additions and 11,309 deletions.
File renamed without changes.
File renamed without changes.
File renamed without changes.
8 changes: 8 additions & 0 deletions capacitor.config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"appId": "com.ibuioli.rosetta",
"appName": "Rosetta",
"bundledWebRuntime": false,
"npmClient": "npm",
"webDir": "dist",
"cordova": {}
}
File renamed without changes.
File renamed without changes.
File renamed without changes.
6 changes: 6 additions & 0 deletions electron/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# NPM renames .gitignore to .npmignore
# In order to prevent that, we remove the initial "."
# And the CLI then renames it

app/
node_modules/
8 changes: 8 additions & 0 deletions electron/capacitor.config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"appId": "com.ibuioli.rosetta",
"appName": "Rosetta",
"bundledWebRuntime": false,
"npmClient": "npm",
"webDir": "dist",
"cordova": {}
}
File renamed without changes
88 changes: 88 additions & 0 deletions electron/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
const { app, BrowserWindow, Menu } = require('electron');
// const isDevMode = require('electron-is-dev');
const { CapacitorSplashScreen, configCapacitor } = require('@capacitor/electron');

const path = require('path');

// Place holders for our windows so they don't get garbage collected.
let mainWindow = null;

// Placeholder for SplashScreen ref
let splashScreen = null;

//Change this if you do not wish to have a splash screen
let useSplashScreen = true;

// Create simple menu for easy devtools access, and for demo
/*const menuTemplateDev = [
{
label: 'Options',
submenu: [
{
label: 'Open Dev Tools',
click() {
mainWindow.openDevTools();
},
},
],
},
];*/

async function createWindow () {
// Define our main window size
mainWindow = new BrowserWindow({
height: 750,
width: 1200,
show: false,
icon: 'icon.png',
webPreferences: {
nodeIntegration: true,
preload: path.join(__dirname, 'node_modules', '@capacitor', 'electron', 'dist', 'electron-bridge.js')
}
});

configCapacitor(mainWindow);
Menu.setApplicationMenu(null);

//if (isDevMode) {
// Set our above template to the Menu Object if we are in development mode, dont want users having the devtools.
//Menu.setApplicationMenu(Menu.buildFromTemplate(menuTemplateDev));
// If we are developers we might as well open the devtools by default.
//mainWindow.webContents.openDevTools();
//}

if(useSplashScreen) {
splashScreen = new CapacitorSplashScreen(mainWindow);
splashScreen.init(false);
} else {
mainWindow.loadURL(`file://${__dirname}/app/index.html`);
mainWindow.webContents.on('dom-ready', () => {
mainWindow.show();
});
}

}

// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some Electron APIs can only be used after this event occurs.
app.on('ready', createWindow);

// Quit when all windows are closed.
app.on('window-all-closed', function () {
// On OS X it is common for applications and their menu bar
// to stay active until the user quits explicitly with Cmd + Q
if (process.platform !== 'darwin') {
app.quit();
}
});

app.on('activate', function () {
// On OS X it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (mainWindow === null) {
createWindow();
}
});

// Define any IPC or other custom functionality below here
Loading

0 comments on commit df62f6a

Please sign in to comment.