Truly-UI is a UI Framework for creating rich desktop applications
Quick Links • Motivation • Prerequisites • Installation • Usage • Available Features • Feedback • License
- ✨ Learn about it on the docs site
- 🚀 See it in action on Stackblitz
- 😎 Checkout the sample application
- 📖 Read the blog posts
- 📝 Learn about updates from the changelog
- 💬 Get to know the latest news first through slack
TrulyUI is an Angular Framework especially developed for Desktop Applications based on Web Components using the greatest technologies of the world. TrulyUI is based on Angular, maintained by world-wide community. By the way, we believe that Angular is the most promising Web Framework. We developed TrulyUI thinking to fill a gap on open-source Web Technologies that's poor when it's about applications on Desktop. Ex: Electron, App.js and NW.js
We assume that you have already installed the following packages at least and are already running an AngularIO project.
-
Having NPM installation run the following command on your terminal to install it:
$ npm install --save truly-ui @angular/animations @angular/cdk
-
Because NPM does not install
peerDependencies
, you should manually install the dependencies:$ npm install --save string-format ts-md5 object-path reflect-metadata $ npm install --save-dev @types/object-path
-
Configure styles of used font packages (Icon Packages are already installed when running npm install truly-ui):
Inside the
angular.json
file add the following paths to thestyles
key"styles": [ "src/styles.css", ... "node_modules/@angular/cdk/overlay-prebuilt.css", "node_modules/truly-ui/css/icons/dx-icons/css/icons.scss", "node_modules/truly-ui/css/icons/fa-icons/css/icons.scss", "node_modules/truly-ui/css/icons/ion-icons/css/icons.scss", "node_modules/truly-ui/css/icons/animations.scss" ]
-
Configure CoreModule on your AppModule:
import { BrowserModule } from '@angular/platform-browser'; import { FormsModule } from '@angular/forms'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { CoreModule } from 'truly-ui'; //CoreModule @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule, CoreModule.forRoot({theme: 'default'}) // Configurations ], providers: [], bootstrap: [AppComponent] }) export class AppModule { }
The use of the components is basically the importation of the main module and the use of the directives in its application: Example is the import of the input module and its use
import { BrowserModule } from '@angular/platform-browser';
import { FormsModule } from '@angular/forms';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
// Import your library, for example the InputComponent :
import { InputModule, ButtonModule, CoreModule } from 'truly-ui';//Import Modules
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
CoreModule.forRoot({theme: 'default'}),
// Specify your library as an import
InputModule,
ButtonModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
Once your library is imported, you can use its components, directives and pipes in your Angular application:
<!-- You can now use your library component in app.component.html -->
<tl-input
[(ngModel)]="Many Properties"
[iconBefore]="'ion-printer'"
[placeholder]="'With Placeholder'"
[textAfter]="'US'"
[clearButton]="true"
[autocomplete]="'off'">
</tl-input>
Feature | Notes | Docs |
---|---|---|
accordion | Docs | |
autocomplete | Docs | |
avatar | Docs | |
badge | Docs | |
blockui | Docs | |
button | Docs | |
buttongroup | Docs | |
calendar | Docs | |
chatlist | Docs | |
checkbox | Docs | |
colorpicker | Docs | |
contextmenu | Docs | |
datatable | Docs | |
datepicker | Docs | |
dialog | Docs | |
dropdownlist | Docs | |
editor | Docs | |
form | Docs | |
icon | Docs | |
input | Docs | |
listbox | Docs | |
menu | Docs | |
shortcut | Docs | |
modal | Docs | |
multiselect | Docs | |
multiview | Docs | |
navigator | Docs | |
overlaypanel | Docs | |
panelgroup | Docs | |
popupmenu | Docs | |
progressbar | Docs | |
radiobutton | Docs | |
sidebar | Docs | |
splitbutton | Docs | |
stopwatch | Docs | |
switch | Docs | |
tabcontrol | Docs | |
textarea | Docs | |
theming | Docs | |
timeavaliable | Docs | |
timeline | Docs | |
timepicker | Docs | |
toaster | Docs | |
toolbar | Docs | |
tooltip | Docs | |
validators | Docs |
Feature | Status | Docs | Issue |
---|---|---|---|
datetimepicker | non-planned | ||
clockpicker | In-progress, planned S1 2019 | ||
monthyearpicker | non-planned | ||
paginator | In-progress, planned S1 2019 | ||
schedule | In-progress, planned S1 2019 | ||
widget | non-planned |
Feedback is always welcome.
angular ui components angular 2 components, angular 4 components, angular electron, angular 5 components ng2 nw ng components ng-components ng2-components angular2 components angular4 electron angular 5 components angular 6 components angular 7 components angular electron components desktop applications library ui components desktop electron angular components electron angular
The MIT License (MIT)
Copyright (c) 2019 Temainfo Software
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.