An open API service indexing awesome lists of open source software.

https://github.com/hapticx/happyx-native

Macro-oriented web-framework compiles to native written with ♥
https://github.com/hapticx/happyx-native

app-framework frontend happyx native-apps nim web-native webnative

Last synced: 7 months ago
JSON representation

Macro-oriented web-framework compiles to native written with ♥

Awesome Lists containing this project

README

          

# HappyX Native

### macro-oriented web-framework compiles to native

[![API Reference](https://img.shields.io/badge/Reference-2b2e3b?style=for-the-badge&logo=&label=API&labelColor=3b3e4b)](https://hapticx.github.io/happyx-native/happyx_native.html)

## Install

```shell
nimble install happyx-native
```

or via GitHub:
```shell
nimble install https://github.com/HapticX/happyx-native
```

## Features

- Support for Chrome/Yandex/Edge browsers & Webview
- Support for Android

## Project Initialization

To init project you should use this command:
```shell
hpx-native init --name ProjectName
```

This command will automatically initialize your project.

It also fetches `ANDROID_SDK_ROOT` from environment (need for android compilation).

## Building

To build your project you should move into project folder
```shell
cd ProjectName
```

and just build it!
```shell
hpx-native build
```
This automatically builds your project for your OS as target platform.

### Cross-Compilation

To compile for other OS use
```shell
hpx-native build --target linux
```

Possible values:
| OS | value | aliases |
| :-- | :--: | :--: |
| Windows | windows | win |
| Linux | linux | unix |
| MacOS | macosx | mac, macos |
| Android | android | - |

### Android compilation

You should have:
- Android Studio with SDK and NDK;
- Gradle >= 7.5;
- Nim >= 2.0.0;

By default `hpx-native build --target android` supports all android architectures.
If you want to disable some architectures then use:
```shell
hpx-native build --target android --no-x86_64
```

Possible architectures
| Architecture | Disable Argument |
| :-- | :--: |
| x86 | `--no-x86` |
| x86_64 | `--no-x86_64` |
| armeabi-v7a | `--no-armeabi-v7a` |
| arm64-v8a | `--no-arm64-v8a` |

If you doesn't want to use gradle building then use
```shell
hpx-native build --target android --no-gradle
```
This command will build only `.so` libraries.

### Building Assets

HappyX Native supports "building" assets - all resources from app directory (by default `/assets`) and all subdirectories are "sewn" into executable file.

This way you can distribute your application over the network with only one executable file.

> This option can be disabled via `--no-build-assets`

### Webview Notes

When building with `-d:webview`, on Windows, you may notice that the window icon is not set
for you. This is due to a limitation within Happyx Native, that will be resolved in the
future. Currently, you may manually link in your desired window icon, like how is done in
.

In addition, Webview does not currently support window positioning
(see ), so the `x` and `y` arguments passed to
`nativeApp` will be ignored.

## Browsers

If you want choose other browser instead of default - use these flags:

| browser | flag |
| :-----: | :-------------: |
| Default browser | uses by default |
| Chrome | `-d:chrome` |
| Edge | `-d:edge` |
| Yandex | `-d:yandex` |
| Webview | `-d:webview` |