apache/cordova-plugin-statusbar


Apache Cordova

License: Apache-2.0

Language: Objective-C

Keywords: cordova, cplusplus, csharp, java, javascript, library, mobile, nodejs, objective-c


title description
Statusbar
Control the device status bar.
AppVeyor Travis CI
Build status Build Status

cordova-plugin-statusbar

The StatusBar object provides some functions to customize the iOS and Android StatusBar.

Installation

This installation method requires cordova 5.0+

cordova plugin add cordova-plugin-statusbar

Older versions of cordova can still install via the deprecated id

cordova plugin add org.apache.cordova.statusbar

It is also possible to install via repo url directly ( unstable )

cordova plugin add https://github.com/apache/cordova-plugin-statusbar.git

Preferences

config.xml

  • StatusBarOverlaysWebView (boolean, defaults to true). Make the statusbar overlay or not overlay the WebView at startup.

     <preference name="StatusBarOverlaysWebView" value="true" />
    
    Android Quirks

    Only supported on Android 5 or later. Earlier versions will ignore this preference.

  • StatusBarBackgroundColor (color hex string, no default value). Set the background color of the statusbar by a hex string (#RRGGBB) at startup. If this value is not set, the background color will be transparent.

      <preference name="StatusBarBackgroundColor" value="#000000" />
    
  • StatusBarStyle (status bar style, defaults to lightcontent). Set the status bar style. Available options default, lightcontent, blacktranslucent, blackopaque.

      <preference name="StatusBarStyle" value="lightcontent" />
    
  • StatusBarDefaultScrollToTop (boolean, defaults to false). On iOS, allows the Cordova WebView to use default scroll-to-top behavior. Defaults to false so you can listen to the "statusTap" event (described below) and customize the behavior instead.

      <preference name="StatusBarDefaultScrollToTop" value="false" />
    

Android Quirks

The Android 5+ guidelines specify using a different color for the statusbar than your main app color (unlike the uniform statusbar color of many iOS apps), so you may want to set the statusbar color at runtime instead via StatusBar.backgroundColorByHexString or StatusBar.backgroundColorByName. One way to do that would be:

if (cordova.platformId == 'android') {
    StatusBar.backgroundColorByHexString("#333");
}

It is also possible to make the status bar semi-transparent. Android uses hexadecimal ARGB values, which are formatted as #AARRGGBB. That first pair of letters, the AA, represent the alpha channel. You must convert your decimal opacity values to a hexadecimal value. You can read more about it here.

For example, a black status bar with 20% opacity:

if (cordova.platformId == 'android') {
    StatusBar.overlaysWebView(true);
    StatusBar.backgroundColorByHexString('#33000000');
}

Hiding at startup

During runtime you can use the StatusBar.hide function below, but if you want the StatusBar to be hidden at app startup on iOS, you must modify your app's Info.plist file.

Add/edit these two attributes if not present. Set "Status bar is initially hidden" to "YES" and set "View controller-based status bar appearance" to "NO". If you edit it manually without Xcode, the keys and values are:

<key>UIStatusBarHidden</key>
<true/>
<key>UIViewControllerBasedStatusBarAppearance</key>
<false/>

Methods

This plugin defines global StatusBar object.

Although in the global scope, it is not available until after the deviceready event.

document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
    console.log(StatusBar);
}
  • StatusBar.overlaysWebView
  • StatusBar.styleDefault
  • StatusBar.styleLightContent
  • StatusBar.styleBlackTranslucent
  • StatusBar.styleBlackOpaque
  • StatusBar.backgroundColorByName
  • StatusBar.backgroundColorByHexString
  • StatusBar.hide
  • StatusBar.show

Properties

  • StatusBar.isVisible

Events

  • statusTap

StatusBar.overlaysWebView

Make the statusbar overlay or not overlay the WebView.

StatusBar.overlaysWebView(true);

Description

Set to true to make the statusbar overlay on top of your app. Ensure that you adjust your styling accordingly so that your app's title bar or content is not covered. Set to false to make the statusbar solid and not overlay your app. You can then set the style and background color to suit using the other functions.

Supported Platforms

  • iOS 7+
  • Android 5+

Quick Example

StatusBar.overlaysWebView(true);
StatusBar.overlaysWebView(false);

StatusBar.styleDefault

Use the default statusbar (dark text, for light backgrounds).

StatusBar.styleDefault();

Supported Platforms

  • iOS
  • Android 6+
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

StatusBar.styleLightContent

Use the lightContent statusbar (light text, for dark backgrounds).

StatusBar.styleLightContent();

Supported Platforms

  • iOS
  • Android 6+
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

StatusBar.styleBlackTranslucent

Use the blackTranslucent statusbar (light text, for dark backgrounds).

StatusBar.styleBlackTranslucent();

Supported Platforms

  • iOS
  • Android 6+
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

StatusBar.styleBlackOpaque

Use the blackOpaque statusbar (light text, for dark backgrounds).

StatusBar.styleBlackOpaque();

Supported Platforms

  • iOS
  • Android 6+
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

StatusBar.backgroundColorByName

On iOS, when you set StatusBar.overlaysWebView to false, you can set the background color of the statusbar by color name.

StatusBar.backgroundColorByName("red");

Supported color names are:

black, darkGray, lightGray, white, gray, red, green, blue, cyan, yellow, magenta, orange, purple, brown

Supported Platforms

  • iOS
  • Android 5+
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

StatusBar.backgroundColorByHexString

Sets the background color of the statusbar by a hex string.

StatusBar.backgroundColorByHexString("#C0C0C0");

CSS shorthand properties are also supported.

StatusBar.backgroundColorByHexString("#333"); // => #333333
StatusBar.backgroundColorByHexString("#FAB"); // => #FFAABB

On iOS, when you set StatusBar.overlaysWebView to false, you can set the background color of the statusbar by a hex string (#RRGGBB).

On Android, when StatusBar.overlaysWebView is true, and on WP7&8, you can also specify values as #AARRGGBB, where AA is an alpha value.

Supported Platforms

  • iOS
  • Android 5+
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

StatusBar.hide

Hide the statusbar.

StatusBar.hide();

Supported Platforms

  • iOS
  • Android
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

StatusBar.show

Shows the statusbar.

StatusBar.show();

Supported Platforms

  • iOS
  • Android
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

StatusBar.isVisible

Read this property to see if the statusbar is visible or not.

if (StatusBar.isVisible) {
	// do something
}

Supported Platforms

  • iOS
  • Android
  • Windows Phone 7
  • Windows Phone 8
  • Windows Phone 8.1

statusTap

Listen for this event to know if the statusbar was tapped.

window.addEventListener('statusTap', function() {
    // scroll-up with document.body.scrollTop = 0; or do whatever you want
});

Supported Platforms

  • iOS

Project Statistics

Sourcerank 16
Repository Size 333 KB
Stars 517
Forks 348
Watchers 58
Open issues 28
Dependencies 1
Contributors 48
Tags 43
Created
Last updated
Last pushed

Top Contributors See all

Steve Gill Jesse MacFadyen Shazron Abdullah jcesarmobile Jan Piotrowski Alexander Sorokin agrieve Andrey Kurdyumov Vladimir Kotikov Marcel Kinard Sergey Shakhnazarov Simon MacDonald Ian Clelland Fil Maj Dmitry Blotsky Eddy Verbruggen Joe Bowser Carlos Santana Josh Soref Brad Berger

Packages Referencing this Repo

diogo-cordova-plugin-statusbar
Cordova StatusBar Plugin
Latest release 2.4.4-dev - Updated - 517 stars
cordova-plugin-bst-statusbar
Cordova StatusBar Plugin
Latest release 1.0.5 - Updated - 517 stars
ch.rts.cordova.fork.cordova.plugin.statusbar
Cordova StatusBar Plugin
Latest release 0.1.1 - Updated - 517 stars
cordova-plugin-statusbar
Cordova StatusBar Plugin
Latest release 2.2.0 - Updated - 517 stars
cordova-plugin-statusbar
Cordova StatusBar Plugin
Latest release 2.4.2 - Updated - 517 stars
fitatu-cordova-plugin-statusbar
Cordova StatusBar Plugin
Latest release 2.4.4 - Updated - 517 stars
cordova-plugin-wininsoft-statusbar
Cordova StatusBar Plugin
Latest release 2.4.3 - Published - 517 stars

Recent Tags See all

rel/2.4.3 June 19, 2019
2.4.3 June 19, 2019
rel/2.4.2 April 13, 2018
2.4.2 April 13, 2018
rel/2.4.1 December 28, 2017
2.4.1 December 28, 2017
rel/2.4.0 December 16, 2017
2.4.0 December 16, 2017
rel/2.3.0 November 06, 2017
2.3.0 November 06, 2017
rel/2.2.3 April 27, 2017
2.2.3 April 27, 2017
rel/2.2.2 March 03, 2017
2.2.2 March 03, 2017
rel/2.2.1 December 08, 2016

Interesting Forks See all

EddyVerbruggen/cordova-plugin-statusbar
Mirror of Apache Cordova
Objective-C - Apache-2.0 - Last pushed - 2 stars
bjhorn/cordova-plugin-statusbar
Mirror of Apache Cordova
Objective-C - Updated - 1 stars
pbakondy/cordova-plugin-statusbar
Mirror of Apache Cordova
This repository is no longer available - 1 stars
montaserfzy/cordova-plugin-statusbar
Mirror of Apache Cordova
Apache-2.0 - Updated - 1 stars

Something wrong with this page? Make a suggestion

Last synced: 2019-09-06 01:23:49 UTC

Login to resync this repository