This project contains most Core functionality shared across Angular-based widget settings UI
It works in conjunction with Rise Vision, the digital signage management application that runs on Google Cloud.
At this time Chrome is the only browser that this project and Rise Vision supports.
A controller, settingsController
, is provided to enable settings loading and saving for UI page.
To create the settings UI page, use the ng-controller
directive to reference settingsController
at the top level DOM of your settings page, say in the <body>
tag or one of the top <div>
tags.
A settings parameter can be of one of the following types:
- URL parameters, stored in
$scope.settings.params
- Additional parameters, stored in
$scope.settings.additionalParams
Each settings parameter is binded either to a input control in the scope, or in a Angular custom component (directive).
In the case of a legacy component (e.g. a jQuery component wrapped in an Angular directive), two-way data binding must be achieved by listening to the collectAdditionalParams
.
A collectionAdditionalParams
event is triggered whenever the settings UI controller is about to save a page.
angular.module("...").directive("exampleCustomInput", {
...
scope: {
someParams: "="
},
link: function ($scope, $element) {
$scope.$on("collectAdditionalParams", function () {
$scope.someParam = $element.someJqueryMethod();
});
}
});
settingsGetter
low-level service that saves URL and additional parameters to Gadget APIsettingsSaver
low-level service that retrievers URL and additional parameters from Gadget API
In widgets, one may supply a default set of settings, which will be loaded during controller's initialization phase:
angular.module("app").value("defaultSettings", {
params: { foo: "bar" }
additionalParams: {...}
});
- NPM (node package manager)
- Angularjs
- Gulp
- Bower
- Karma and Mocha for testing
-
install the latest Node.js and NPM version, run this to install:
-
clone the repo using Git to your local:
git clone https://github.com/Rise-Vision/widget-settings-ui-core.git
- cd into the repo directory
cd widget-settings-ui-core
- from the root of the repo run this command to install all npm dependencies
npm install
- install Bower globally using the NPM install cmd:
npm install -g bower
- run Bower install to install all bower dependencies:
bower install
- install Gulp globally using the NPM install cmd:
npm install -g gulp
- Gulp - is used as a task runner. It lints, runs unit tests and E2E (end to end) tests, minimizes files, etc. all dependencies for this is in the gulp.js file.
- Bower - is used as a package manager for javascript libraries and frameworks. All third-party javascript frameworks and libraries are listed as dependencies in the bower.json file.
- NPM & Nodejs - the node package manager is used in hand in hand with gulp to start a server to host the app and all the dependencies needed from using a node server. All these node dependencies are listed in the package.json file
To run unit and E2E testing, do
gulp test
If you encounter problems or find defects we really want to hear about them. If you could take the time to add them as issues to this Repository it would be most appreciated. When reporting issues please use the following format where applicable:
Reproduction Steps
- did this
- then that
- followed by this (screenshots / video captures always help)
Expected Results
What you expected to happen.
Actual Results
What actually happened. (screenshots / video captures always help)
All contributions are greatly appreciated and welcome! If you would first like to sound out your contribution ideas please post your thoughts to our community, otherwise submit a pull request and we will do our best to incorporate it
If you would like translate the user interface for this product to another language please complete the following:
- Download the english translation file from this repository.
- Download and install POEdit. This is software that you can use to write translations into another language.
- Open the translation file in the POEdit program and set the language for which you are writing a translation.
- In the Source text window, you will see the English word or phrase to be translated. You can provide a translation for it in the Translation window.
- When the translation is complete, save it with a .po extension and email the file to support@risevision.com. Please be sure to indicate the Widget or app the translation file is for, as well as the language that it has been translated into, and we will integrate it after the translation has been verified.
If you have any questions or problems please don't hesitate to join our lively and responsive community at http://community.risevision.com.
If you are looking for user documentation on Rise Vision please see http://www.risevision.com/help/users/
If you would like more information on developing applications for Rise Vision please visit http://www.risevision.com/help/developers/.
Facilitator