Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to show an open file native dialog with Electron?

I am trying to add functionality to my Electron app that will allow users to open a file in the app, specifically plain text files. After looking at the Electron documentation, I found this page. I added this code to my app.js file, which I linked to in my index.html.

var fs = require('fs');
var dialog = require('electron');
$openFile = $('#openBtn');
$editor = $('#editor');

$openFile.click(function(){
  dialog.showOpenDialog(function(fileNames) {
    if (fileNames === undefined) return;
    var fileName = fileNames[0];

    fs.readFile(fileName, 'utf-8', function (err, data) {
      $editor.val(data);
    });
  });
});

However, when I run this, this error shows up in the console: Uncaught TypeError: dialog.showOpenDialog is not a function I have tried using remote, but to no avail.

Has anyone know how to fix this problem? Thanks in advance

like image 468
Inigo Mantoya Avatar asked Aug 23 '17 21:08

Inigo Mantoya


2 Answers

const {dialog} = require('electron').remote;

document.querySelector('#selectBtn').addEventListener('click', function (event) {
    dialog.showOpenDialog({
        properties: ['openFile', 'multiSelections']
    }, function (files) {
        if (files !== undefined) {
            // handle files
        }
    });
});
like image 191
KBIIX Avatar answered Nov 08 '22 12:11

KBIIX


On the main process you can use

const {dialog} = require('electron');

dialog.showOpenDialog({properties: ['openFile'] }).then(function (response) {
    if (!response.canceled) {
        // handle fully qualified file name
      console.log(response.filePaths[0]);
    } else {
      console.log("no file selected");
    }
});

response looks like:

{
 canceled: false,
 filePaths: [
    '<fullpath>/<filename>'
 ]
}
like image 9
Air One Avatar answered Nov 08 '22 14:11

Air One