feat: work without any nodeIntegration requirements
This commit is contained in:
parent
986f762ae1
commit
2b8e506f5a
3 changed files with 15 additions and 6 deletions
|
@ -23,7 +23,6 @@ Electron-tabs uses webviews, so you first need to use the following `webPreferen
|
||||||
```js
|
```js
|
||||||
const mainWindow = new electron.BrowserWindow({
|
const mainWindow = new electron.BrowserWindow({
|
||||||
webPreferences: {
|
webPreferences: {
|
||||||
nodeIntegration: true,
|
|
||||||
webviewTag: true
|
webviewTag: true
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -4,7 +4,6 @@ const app = electron.app;
|
||||||
app.on('ready', function () {
|
app.on('ready', function () {
|
||||||
const mainWindow = new electron.BrowserWindow({
|
const mainWindow = new electron.BrowserWindow({
|
||||||
webPreferences: {
|
webPreferences: {
|
||||||
nodeIntegration: true,
|
|
||||||
webviewTag: true
|
webviewTag: true
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
19
index.js
19
index.js
|
@ -1,5 +1,3 @@
|
||||||
const EventEmitter = require("events");
|
|
||||||
|
|
||||||
if (!document) {
|
if (!document) {
|
||||||
throw Error("electron-tabs module must be called in renderer process");
|
throw Error("electron-tabs module must be called in renderer process");
|
||||||
}
|
}
|
||||||
|
@ -22,6 +20,19 @@ if (!document) {
|
||||||
document.getElementsByTagName("head")[0].appendChild(styleTag);
|
document.getElementsByTagName("head")[0].appendChild(styleTag);
|
||||||
})();
|
})();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This makes the browser EventTarget API work similar to EventEmitter
|
||||||
|
*/
|
||||||
|
class EventEmitter extends EventTarget {
|
||||||
|
emit (type, ...args) {
|
||||||
|
this.dispatchEvent(new CustomEvent(type, { detail: args }));
|
||||||
|
}
|
||||||
|
|
||||||
|
on (type, fn) {
|
||||||
|
this.addEventListener(type, ({ detail }) => fn.apply(this, detail));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
class TabGroup extends EventEmitter {
|
class TabGroup extends EventEmitter {
|
||||||
constructor (args = {}) {
|
constructor (args = {}) {
|
||||||
super();
|
super();
|
||||||
|
@ -126,8 +137,8 @@ const TabGroupPrivate = {
|
||||||
|
|
||||||
initVisibility: function () {
|
initVisibility: function () {
|
||||||
function toggleTabsVisibility(tab, tabGroup) {
|
function toggleTabsVisibility(tab, tabGroup) {
|
||||||
var visibilityThreshold = this.options.visibilityThreshold;
|
let visibilityThreshold = this.options.visibilityThreshold;
|
||||||
var el = tabGroup.tabContainer.parentNode;
|
let el = tabGroup.tabContainer.parentNode;
|
||||||
if (this.tabs.length >= visibilityThreshold) {
|
if (this.tabs.length >= visibilityThreshold) {
|
||||||
el.classList.add("visible");
|
el.classList.add("visible");
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue