Skip to content

Customized cross-platform notifications using Electron's BrowserWindow.

Notifications You must be signed in to change notification settings

Arubinu/electron-custom-notifications

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

electron-custom-notifications

Display customized HTML/CSS notifications in a cross-platform way. Instead of relying on Windows, Mac or Linux APIs to show notifications, this uses an extra Electron window to display them, giving the developer the freedom to style the notifications as they choose to.

Disclaimer

For this module to work properly in the foreground, it is advisable to disable hardware acceleration (which prevents clicking in transparent areas):

app.disableHardwareAcceleration();

Installation

To install simply:

npm i --save https://github.com/Arubinu/electron-custom-notifications

Full Usage

Please note that you need to use this inside an existing Electron application after the .on('ready') event has been fired.

  const {
    setContainerWidth,
    setGlobalStyles,
    setDefaultTemplate,
    createNotification,
  } = require("electron-custom-notifications");
  
  // OPTIONAL: Set optional container width.
  // DEFAULT: 300
  setContainerWidth(350);

  // OPTIONAL: Set custom styles.
  setGlobalStyles(`
    * {
      font-family: Helvetica;
    }
    notification {
      display:block;
      padding:20px;
      background-color:#fff;
      border-radius:12px;
      margin:10px;
      box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
    }
    notification h1 {
      font-weight:bold;
    }
  `);
  
  // OPTIONAL: Set a default template for ALL notifications.
  // * Root element MUST be "notification".
  // * Use %var% syntax for variables to have them replaced during runtime.
  //   These must be defined in the "parameters" property of each notification.
  // * Always include id="%id%" in the root element. No need to define
  //   id in the parameters property, they are auto-generated.
  setDefaultTemplate(`
    <notification id="%id%">
      <h1>%title%</h1>
      <p>%body%</p>
    </notification>  
  `);
  
  const notification = createNotification({
    // OPTIONAL: Parameters to replace in the template during runtime.
    parameters: [
      { key: "title", value: "My first notification" },
      { key: "body", value: "Hello, this is my first notification!" },
    ],

    // OPTIONAL: Custom template ONLY for this notification.
    // * Root element MUST be "notification".
    // * Use %var% syntax for variables to have them replaced during runtime.
    //   These must be defined in the "parameters" property.
    // * Always include id="%id%" in the root element.
    //
    // template: `
    //  <notification id="%id%">
    //    <h1>Notification title</h1>
    //    <p>Notification body</p>
    //  </notification>
    //`,

    // OPTIONAL: Specify a timeout.
    // timeout: 3000,
  });
  
  // When the notification was clicked.
  notification.on("click", () => {
    console.log("Notification has been clicked");
  });

  // When the notification was closed.
  notification.on("close", () => {
    console.log("Notification has been closed");
  });
  
  // Close the notification at will.
  // notification.close();

Result

alt text

(Notifications stack on top of each other)

Adding Images

To add images, we will load them in base64 encoding. Using relative/absolute paths will most likely not work. Here's an example of a YouTube-styled notification:

const {
 setGlobalStyles,
 createNotification,
} = require("electron-custom-notifications");

// Load image in base64 encoding.
const logo = require("fs").readFileSync("youtube.png", "base64");

setGlobalStyles(`
 * {
   font-family: Helvetica;
 }
 notification {
   overflow:hidden;
   display:block;
   padding:20px;
   background-color:#fff;
   border-radius:12px;
   margin:10px;
   box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
   display:flex;
 }
 notification h1 {
   font-weight:bold;
 }
 notification #logo {
   background-image:url("data:image/png;base64,${logo}");
   background-size:cover;
   background-position:center;
   width:80px;
   height:50px;
 }
`);

app.on("ready", () => {
 const notification = createNotification({
   template: `
   <notification id="%id%">
     <div id="logo"></div>
     <div id="content">
       <h1>Watch on Youtube</h1>
       <p>This is a notification about a YouTube video.</p>
     </div>
   </notification> 
   `,

   timeout: 3000,
 });

 notification.on("click", () => {
   // Open the YouTube link in a browser.
   require("electron").shell.openExternal(
     "https://www.youtube.com/watch?v=M9FGaan35s0"
   );
 });
});

Result

alt text

Adding custom fonts

Same thing as with the images. We will need to use base64 encoding to add them to our styles.

const {
 setGlobalStyles,
 createNotification,
} = require("electron-custom-notifications");

const fs = require("fs");

const logo = fs.readFileSync("youtube.png", "base64");
const robotoRegular = fs.readFileSync("Roboto-Regular.ttf", "base64");
const robotoBold = fs.readFileSync("Roboto-Bold.ttf", "base64");

setGlobalStyles(`
 @font-face {
   font-family: 'Roboto';
   src: url(data:font/truetype;charset=utf-8;base64,${robotoRegular}) format('truetype');
   font-weight: normal;
   font-style: normal;
 }
 @font-face {
   font-family: 'Roboto';
   src: url(data:font/truetype;charset=utf-8;base64,${robotoBold}) format('truetype');
   font-weight: bold;
   font-style: normal;
 }
 * {
   font-family: Roboto;
 }
 notification {
   overflow:hidden;
   display:block;
   padding:20px;
   background-color:#fff;
   border-radius:12px;
   margin:10px;
   box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
   display:flex;
 }
 notification h1 {
   font-weight:bold;
 }
 notification #logo {
   background-image:url("data:image/png;base64,${logo}");
   background-size:cover;
   background-position:center;
   width:80px;
   height:50px;
 }
`);

app.on("ready", () => {
 const notification = createNotification({
   template: `
   <notification id="%id%">
     <div id="logo"></div>
     <div id="content">
       <h1>Watch on Youtube</h1>
       <p>This is a notification about a YouTube video.</p>
     </div>
   </notification> 
   `,

   //timeout: 3000,
 });

 notification.on("click", () => {
   require("electron").shell.openExternal(
     "https://www.youtube.com/watch?v=M9FGaan35s0"
   );
 });
}); 

Result

Our notification has the best font in the world.

alt text

Animations

You can write up your own CSS animations in setGlobalStyles(), or you can use Animate.css library, which is already included and ready to use in this library. Example animated notification template:

<notification id="%id%" class="animated fade-in-up">
  <div id="logo"></div>
  <div id="content">
    <h1>Watch on Youtube</h1>
    <p>This is a notification about a YouTube video.</p>
  </div>
</notification> 

Check out Animate.css for more animations

Result

alt text

About

Customized cross-platform notifications using Electron's BrowserWindow.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 82.9%
  • TypeScript 17.1%