Skip to content
No description, website, or topics provided.
JavaScript CSS
Branch: master
Clone or download
Pull request Compare This branch is 15 commits behind webOS-ports:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Type Name Latest commit message Commit time
Failed to load latest commit information.


A selection of enyo2 kinds to restore functionality missing from enyo1

Unified from webos-ports-lib, webOS-Ext & enyo1-to-enyo2 kinds by ShiftyAxel, Jason Robitaille and Arthur Thornton

Full documentation can be found at


Ported from Enyo 1, the AppMenu kind will replicate the behavior of the standard app menu shown in webOS apps. This will have a slightly different style, though, since it uses onyx.Menu as opposed to a custom background image.


{kind:"AppMenu", onSelect: "appMenuItemSelected", components: [{content:"Do something", ontap: "doSomething"}]}


A convenient subkind of enyo.Signals that outlines all of the webOS-specific events from webos-lib.


 {kind: "enyo.ApplicationEvents", onbackbutton: "handleBackGesture", onactivate: "handleActivate", ondeactivate: "handleDeactivate", onmenubutton: "handleMenuButton", onrelaunch: "handleRelaunch", onlowmemory:"handleLowMemory", onvirtualkeyboard: "handleVirtualKeyboard"}


A function that listens for the webOS Back Gesture and fires the onbackbutton signal. Both 2.x and Open webOS are supported, as well as phonegap and the Esc key on desktop browsers.


 {kind: "enyo.Signals", onbackbutton: "handleBackGesture"}


An in-app gesture area that can be used for debugging. Emulates the Open webOS back gesture by default, set fingerTracking to true in order to emulate the new Finger Tracking API events. Only shows itself on non-palm platforms, so it's safe to ship with your app.

 //KeyUp-based Gesture
 components: [
 	{kind: "Signals", onkeyup: "handleKeyUp"},
 	{kind: "CoreNavi", fingerTracking: false}
 handleKeyUp: function(inSender, inEvent) {
if(inEvent.keyIdentifier == "U+1200001") {
	//Do Stuff
 //Finger Tracking API
 components: [
 	{kind: "Signals",
onCoreNaviDragStart: "handleCoreNaviDragStart",
onCoreNaviDrag: "handleCoreNaviDrag",
onCoreNaviDragFinish: "handleCoreNaviDragFinish"}
 	{kind: "Panels",
 	arrangerKind: "CarouselArranger",
 		{content: "Foo"},
 		{content: "Bar"},
 		{content: "DecafIsBad"},
 	{kind: "CoreNavi", fingerTracking: true}
 handleCoreNaviDragStart: function(inSender, inEvent) {
 handleCoreNaviDrag: function(inSender, inEvent) {
 handleCoreNaviDragFinish: function(inSender, inEvent) {



Ported from the non-published set of Enyo 1 APIs to Enyo2, CrossAppUI takes a 'path' parameter (the HTML file to open) and displays it inside your application. The child application can pass stringified JSON prefixed with 'enyoCrossAppResult=' up to the CrossAppUI via the 'message' event (window scope). CrossAppUI will strip off the prefix, parse it into an object and fire onResult. This is intended to be used as a base class for app-in-app kinds, such as FilePicker (see below).

message Event Example:


Corresponding onResult Output:



 {kind:"CrossAppUI", style: "width: 100%; height: 100%;", path: "/path/to/app/html.html", onResult: "handleResult"}


Ported across from Enyo 1, this is a CrossAppUI kind that points to the built-in webOS filepicker. The onPickFile event is called when the file is chosen.

onPickFile Output:



 {name: "ImagePicker", kind: "FilePicker", fileType:["image"], onPickFile: "selectedImageFile"}


Ported from Enyo 1, this is just a standard enyo.Control with allowHtml:true set so you don't have to


{kind:"HtmlContent", content:"This content is<br />separated by an HTML line break (&lt;br /&gt;) tag"}


Binds LunaSysMgr application events to Enyo signals.

onactivate: When the window is activated
ondeactivate: When the window is deactivated
onmenubutton: When the app menu is toggled
onrelaunch: When the app is relaunched
onlowmemory: To monitor for high memory usage


{kind: "enyo.Signals", onactivate: "handleActivate", ondeactivate: "handleDeactivate", onmenubutton: "handleMenuButton", onrelaunch: "handleRelaunch", onlowmemory:"handleLowMemory"}


Another kind ported from Enyo 1, this is an onyx.Popup that has modal:true and autoDismiss:false set to act like a modal dialog


{name: "myDialog", kind:"ModalDialog", components[/* your components */, { kind: onyx.Button, content: "Close popup", ontap: "closePopup"}]}
closePopup: function() {this.$.myDialog.hide()};


enyo.PalmService is a component similar to enyo.WebService, but for Palm service requests, with the ability to manage one or more active requests at any given time.


{kind: "enyo.PalmService", service: "palm://com.palm.systemservice/time", method: "getSystemTime", onResponse:"handleResponse", onError:"handleError"}


An onyx.Toolbar that displays the app icon, a custom title and an optional random tagline.


 {kind: "PortsHeader",
 title: "FooApp",
 taglines: [
      "My foo-st app",
      "Banana boat.",
      "Fweeeeeeep. F'tang."


A variant of the PortsHeader that contains an animated, expandable search bar. onSearch is fired based on the 'instant' member variable. If true, it will fire every time the text is changed, otherwise it will fire when the user presses enter or the field loses focus after modification. Setting the 'submitCloses' variable to true will close the search box in this situation.


 {kind: "PortsSearch",
 title: "SearchyFooApp",
 instant: false,
 submitCloses: true,
 taglines: [
      "My foo-st app",
      "Banana boat.",
      "Fweeeeeeep. F'tang."
 onSearch: "searchFieldChanged"}	


A circular variant of the onyx progress bar with an button in the center. Uses an enyo.Animator for smooth transitions between values. Published properties are value, min and max. This is an enyo2 reimagining of the progress indicator from the webOS 2.x Browser.


 {name: "FooOrb",
 kind: "ProgressOrb",
 style: "position: absolute; right: 8px; bottom: 8px;",
 content: "O",
 onButtonTap: "buttonTapped"},
 buttonTapped: function(inSender, inEvent) {
this.$.FooOrb.setValue(this.$.FooOrb.value + 100);


An extension of the enyo.Async object designed for webOS service requests. Supports subscription services.


var request = new enyo.ServiceRequest({
	service: "palm://com.palm.systemservice/time",
	method: "getSystemTime"
request.response(this, "responseSuccess");
request.error(this, "responseFailure");
request.go({}); //any params would go in here


Static symkey functionality for webOS 1.x and 2.x.

When the symkey on the physical keyboard is pressed, this properly opens the symtable within webOS. Automatically opens on the symkey, but can also be manually activated from webos.showSymTable().


Collection of static webOS virtual keyboard functions and constants. Sends an onvirtualkeyboard signal that you can listen for.


{kind: "enyo.Signals", onvirtualkeyboard: "handleVirtualKeyboard"}


This is a port of code from Enyo 1 to Enyo 2 to enable the use of a WebView widget (think of it like an iframe) inside an Enyo app on webOS. This uses Enyo 1 code and was slightly modified to enable it to work with Enyo 2. For complete documentation, refer to this document (ignore the Inheritance section and all other kinds)


A collection of static variables and functions core to webOS functionality and the webOS feature-set. A large amount of PalmSystem bindings combined with some utility functions.

You can’t perform that action at this time.