इलेक्ट्रॉन - सिस्टम डायलॉग्स

किसी भी एप के लिए यूजर फ्रेंडली होना बहुत जरूरी है। परिणामस्वरूप आपको अलर्ट () कॉल का उपयोग करके संवाद बॉक्स नहीं बनाना चाहिए। इलेक्ट्रॉन संवाद बॉक्स बनाने के कार्य को पूरा करने के लिए एक बहुत अच्छा इंटरफ़ेस प्रदान करता है। इस पर एक नजर डालते हैं।

इलेक्ट्रॉन एक प्रदान करता है dialog मॉड्यूल जिसका उपयोग हम फाइल खोलने, सहेजने, इत्यादि के लिए देशी सिस्टम संवाद प्रदर्शित करने के लिए कर सकते हैं।

आइए हम सीधे एक उदाहरण में कूदें और सरल टेक्स्टफाइल्स प्रदर्शित करने के लिए एक ऐप बनाएं।

एक नया main.js फ़ाइल बनाएँ और उसमें निम्न कोड डालें -

const {app, BrowserWindow} = require('electron') 
const url = require('url') 
const path = require('path') 
const {ipcMain} = require('electron')  

let win  

function createWindow() { 
   win = new BrowserWindow({width: 800, height: 600}) 
   win.loadURL(url.format ({ 
      pathname: path.join(__dirname, 'index.html'), 
      protocol: 'file:', 
      slashes: true 
   })) 
}  

ipcMain.on('openFile', (event, path) => { 
   const {dialog} = require('electron') 
   const fs = require('fs') 
   dialog.showOpenDialog(function (fileNames) { 
      
      // fileNames is an array that contains all the selected 
      if(fileNames === undefined) { 
         console.log("No file selected"); 
      
      } else { 
         readFile(fileNames[0]); 
      } 
   });
   
   function readFile(filepath) { 
      fs.readFile(filepath, 'utf-8', (err, data) => { 
         
         if(err){ 
            alert("An error ocurred reading the file :" + err.message) 
            return 
         } 
         
         // handle the file content 
         event.sender.send('fileData', data) 
      }) 
   } 
})  
app.on('ready', createWindow)

जब भी हमारी मुख्य प्रक्रिया एक रेंडरर प्रक्रिया से एक 'ओपनफाइल' संदेश की पुनरावृत्ति करती है, तो यह कोड खुले संवाद बॉक्स को पॉप करेगा। यह संदेश फ़ाइल सामग्री को रेंडरर प्रक्रिया में वापस भेज देगा। अब, हमें सामग्री को प्रिंट करना होगा।

अब, एक नया बनाएँ index.html निम्नलिखित सामग्री के साथ फ़ाइल -

<!DOCTYPE html> 
<html> 
   <head> 
      <meta charset = "UTF-8"> 
      <title>File read using system dialogs</title> 
   </head> 
   
   <body> 
      <script type = "text/javascript"> 
         const {ipcRenderer} = require('electron') 
         ipcRenderer.send('openFile', () => { 
            console.log("Event sent."); 
         }) 
         
         ipcRenderer.on('fileData', (event, data) => { 
            document.write(data) 
         }) 
      </script> 
   </body> 
</html>

अब जब भी हम अपना ऐप चलाते हैं, तो एक मूल ओपन डायलॉग बॉक्स पॉप अप होगा जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है -

एक बार जब हम प्रदर्शित करने के लिए एक फ़ाइल का चयन करते हैं, तो इसकी सामग्री ऐप विंडो पर प्रदर्शित होगी -

यह केवल चार संवादों में से एक था जो इलेक्ट्रॉन प्रदान करता है। हालांकि इन सभी का उपयोग समान है। एक बार जब आप इसका उपयोग करना सीख जाते हैंshowOpenDialog, तो आप किसी भी अन्य संवाद का उपयोग कर सकते हैं।

समान कार्यक्षमता वाले संवाद हैं -

  • showSaveDialog ([browserWindow,] विकल्प [, कॉलबैक])
  • showMessageDialog ([browserWindow,] विकल्प [, कॉलबैक])
  • showErrorDialog (शीर्षक, सामग्री)