docs: adds Native-UI Open external links and the file manager Fiddle example (#20524)
This commit is contained in:
parent
5733507040
commit
1b61fe780e
3 changed files with 173 additions and 0 deletions
104
docs/fiddles/native-ui/external-links-file-manager/index.html
Normal file
104
docs/fiddles/native-ui/external-links-file-manager/index.html
Normal file
|
@ -0,0 +1,104 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8" />
|
||||||
|
<title>Open external links and the file manager</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div>
|
||||||
|
<h1>
|
||||||
|
Open external links and the file manager
|
||||||
|
</h1>
|
||||||
|
<h3>
|
||||||
|
The <code>shell</code> module in Electron allows you to access certain
|
||||||
|
native elements like the file manager and default web browser.
|
||||||
|
</h3>
|
||||||
|
|
||||||
|
<p>This module works in both the main and renderer process.</p>
|
||||||
|
<p>
|
||||||
|
Open the
|
||||||
|
<a href="http://electron.atom.io/docs/api/shell">
|
||||||
|
full API documentation (opens in new window)
|
||||||
|
</a>
|
||||||
|
in your browser.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<div>
|
||||||
|
<h2>Open Path in File Manager</h2>
|
||||||
|
<div>
|
||||||
|
<div>
|
||||||
|
<button id="open-file-manager">
|
||||||
|
View Demo
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<p>
|
||||||
|
This demonstrates using the <code>shell</code> module to open the
|
||||||
|
system file manager at a particular location.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
Clicking the demo button will open your file manager at the root.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<div>
|
||||||
|
<h2>Open External Links</h2>
|
||||||
|
<div>
|
||||||
|
<div>
|
||||||
|
<button id="open-ex-links">View Demo</button>
|
||||||
|
</div>
|
||||||
|
<p>
|
||||||
|
If you do not want your app to open website links
|
||||||
|
<em>within</em> the app, you can use the <code>shell</code> module
|
||||||
|
to open them externally. When clicked, the links will open outside
|
||||||
|
of your app and in the user's default web browser.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
When the demo button is clicked, the electron website will open in
|
||||||
|
your browser.
|
||||||
|
</p>
|
||||||
|
<p></p>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<h2>ProTip</h2>
|
||||||
|
<strong>Open all outbound links externally.</strong>
|
||||||
|
<p>
|
||||||
|
You may want to open all <code>http</code> and
|
||||||
|
<code>https</code> links outside of your app. To do this, query
|
||||||
|
the document and loop through each link and add a listener. This
|
||||||
|
app uses the code below which is located in
|
||||||
|
<code>assets/ex-links.js</code>.
|
||||||
|
</p>
|
||||||
|
<h5>Renderer Process</h5>
|
||||||
|
<pre>
|
||||||
|
<code>
|
||||||
|
const shell = require('electron').shell
|
||||||
|
|
||||||
|
const links = document.querySelectorAll('a[href]')
|
||||||
|
|
||||||
|
Array.prototype.forEach.call(links, (link) => {
|
||||||
|
const url = link.getAttribute('href')
|
||||||
|
if (url.indexOf('http') === 0) {
|
||||||
|
link.addEventListener('click', (e) => {
|
||||||
|
e.preventDefault()
|
||||||
|
shell.openExternal(url)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
</code>
|
||||||
|
</pre>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
// You can also require other files to run in this process
|
||||||
|
require("./renderer.js");
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
56
docs/fiddles/native-ui/external-links-file-manager/main.js
Normal file
56
docs/fiddles/native-ui/external-links-file-manager/main.js
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
// Modules to control application life and create native browser window
|
||||||
|
const { app, BrowserWindow } = require('electron')
|
||||||
|
|
||||||
|
// Keep a global reference of the window object, if you don't, the window will
|
||||||
|
// be closed automatically when the JavaScript object is garbage collected.
|
||||||
|
let mainWindow
|
||||||
|
|
||||||
|
function createWindow () {
|
||||||
|
// Create the browser window.
|
||||||
|
mainWindow = new BrowserWindow({
|
||||||
|
width: 800,
|
||||||
|
height: 600,
|
||||||
|
webPreferences: {
|
||||||
|
nodeIntegration: true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
// and load the index.html of the app.
|
||||||
|
mainWindow.loadFile('index.html')
|
||||||
|
|
||||||
|
// Open the DevTools.
|
||||||
|
// mainWindow.webContents.openDevTools()
|
||||||
|
|
||||||
|
// Emitted when the window is closed.
|
||||||
|
mainWindow.on('closed', function () {
|
||||||
|
// Dereference the window object, usually you would store windows
|
||||||
|
// in an array if your app supports multi windows, this is the time
|
||||||
|
// when you should delete the corresponding element.
|
||||||
|
mainWindow = null
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// This method will be called when Electron has finished
|
||||||
|
// initialization and is ready to create browser windows.
|
||||||
|
// Some 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()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
// In this file you can include the rest of your app's specific main process
|
||||||
|
// code. You can also put them in separate files and require them here.
|
|
@ -0,0 +1,13 @@
|
||||||
|
const { shell } = require('electron')
|
||||||
|
const os = require('os')
|
||||||
|
|
||||||
|
const exLinksBtn = document.getElementById('open-ex-links')
|
||||||
|
const fileManagerBtn = document.getElementById('open-file-manager')
|
||||||
|
|
||||||
|
fileManagerBtn.addEventListener('click', (event) => {
|
||||||
|
shell.showItemInFolder(os.homedir())
|
||||||
|
})
|
||||||
|
|
||||||
|
exLinksBtn.addEventListener('click', (event) => {
|
||||||
|
shell.openExternal('http://electron.atom.io')
|
||||||
|
})
|
Loading…
Reference in a new issue