/libui-napi

Experimental bindings for libui using n-api

Primary LanguageCMIT LicenseMIT

libui-node

Node.js bindings for libui library.

libui is a lightweight, portable GUI library that uses the native GUI technologies of each platform it supports.

It is in early stage of development, but is evolving at great pace and is really awesome. It could become an awesome alternative to Electron to develop multiplatform GUI, expecially suited to develop small apps.

Join the community on Spectrum Travis Build Status AppVeyor Build Status NPM module NPM downloads

Screenshots

macOS

macOS

Linux

Linux

Windows

Windows

Supported platforms

  • Windows: Windows Vista SP2 with Platform Update or newer
  • Unix: GTK+ 3.10 or newer
  • Mac OS X: OS X 10.8 or newer
  • Node.js version 4 or greater.

Prerequisites

Prebuilt binaries

All prebuilds are build on CI and afterwards downloaded and published in the npm install phase. Prebuild t binaries are available for the following platforms:

  • macOS 64bit
  • Windows 64bit
  • Linux 64bit

If you are using one of these platform, you don't need to recompile libui-node source code from scratch.

The only additional dependecy you nedd is GTK+ 3 to run on Linux.

Otherwise, libui-node sources will be compiled during part of the install phase. You need the following additionl dependency in order to compile:

Windows

Linux

If they are not provided by default in your distribution:

macOS

Installation

npm install -S libui-node

libui prebuilt binaries are automatically downloaded after install.

If you get this error on Windows:

'__pfnDliNotifyHook2': redefinition; different type modifiers

you need to install latest npm version:

$ npm i -g npm

see this node-gyp issue for more details.

Documentation & examples

Documentation is in docs folder. You can also find working examples in example folder.

How to run the examples

First, you have to clone the GitHub repo and npm install it:

git clone https://github.com/parro-it/libui-node.git
npm install

Then, to run the control gallery example (requires Node.js >= 6), type:

node example/core-api.js

Contribution & design

  1. Make sure to read and agree with our code of conduct
  2. Follow guidelines provided in our contribution guide

Related projects

Contributors

Andrea Parodi | Juha Järvi | Niklas Mischkulnig | Gustav Hansen ---|---|---|--- Andrea Parodi | Juha Järvi | Niklas Mischkulnig | Gustav Hansen

License

The MIT License (MIT)

Copyright (c) 2018 parro-it