Elektron - Pemberitahuan

Electron menyediakan API notifikasi asli hanya untuk MacOS. Jadi kita tidak akan menggunakannya, sebaliknya kita akan menggunakan modul npm yang disebut node-notifier . Ini memungkinkan kami memberi tahu pengguna di Windows, MacOS, dan Linux.

Instal modul node-notifier di folder aplikasi Anda menggunakan perintah berikut di folder itu -

$ npm install --save node-notifier

Sekarang mari kita buat aplikasi yang memiliki tombol yang akan menghasilkan pemberitahuan setiap kali kita mengklik tombol ini.

Buat yang baru main.js file dan masukkan kode berikut di dalamnya -

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

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
   }))
}

app.on('ready', createWindow)

Sekarang mari kita buat halaman web dan skrip yang akan memicu notifikasi. Buat yang baruindex.html file dengan kode berikut -

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "UTF-8">
      <title>Menus</title>
   </head>
   
   <body>
      <button type = "button" id = "notify" name = "button">
         Click here to trigger a notification!</button>
      <script type = "text/javascript">
         const notifier = require('node-notifier')
         const path = require('path');
         
         document.getElementById('notify').onclick = (event) => {
            notifier.notify ({
               title: 'My awesome title',
               message: 'Hello from electron, Mr. User!',
               icon: path.join('','/home/ayushgp/Desktop/images.png'),  // Absolute path 
                  (doesn't work on balloons)
               sound: true,  // Only Notification Center or Windows Toasters
               wait: true    // Wait with callback, until user action is taken 
               against notification
            
            }, function (err, response) {
               // Response is response from notification
            });

            notifier.on('click', function (notifierObject, options) {
               console.log("You clicked on the notification")
            });

            notifier.on('timeout', function (notifierObject, options) {
               console.log("Notification timed out!")
            });
         }
      </script>
   </body>
</html>

Itu notify metode memungkinkan kita untuk menyebarkannya objectwithinformasi seperti judul, pesan, gambar kecil, dll. yang membantu kami menyesuaikan pemberitahuan. Kami juga dapat mengatur beberapa pendengar acara di notifikasi.

Sekarang, jalankan aplikasi menggunakan perintah berikut -

$ electron ./main.js

Ketika Anda mengklik tombol yang kami buat, Anda akan melihat pemberitahuan asli dari sistem operasi Anda seperti yang ditunjukkan pada gambar berikut -

Kami juga telah menangani peristiwa di mana, pengguna mengklik pemberitahuan atau waktu pemberitahuan habis. Metode ini membantu kami membuat aplikasi lebih interaktif jika berjalan di latar belakang.