mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-15 19:26:42 +08:00

* chore: move tns-core-modules to nativescript-core * chore: preparing compat generate script * chore: add missing definitions * chore: no need for http-request to be private * chore: packages chore * test: generate tests for tns-core-modules * chore: add anroid module for consistency * chore: add .npmignore * chore: added privateModulesWhitelist * chore(webpack): added bundle-entry-points * chore: scripts * chore: tests changed to use @ns/core * test: add scoped-packages test project * test: fix types * test: update test project * chore: build scripts * chore: update build script * chore: npm scripts cleanup * chore: make the compat pgk work with old wp config * test: generate diff friendly tests * chore: create barrel exports * chore: move files after rebase * chore: typedoc config * chore: compat mode * chore: review of barrels * chore: remove tns-core-modules import after rebase * chore: dev workflow setup * chore: update developer-workflow * docs: experiment with API extractor * chore: api-extractor and barrel exports * chore: api-extractor configs * chore: generate d.ts rollup with api-extractor * refactor: move methods inside Frame * chore: fic tests to use Frame static methods * refactor: create Builder class * refactor: use Builder class in tests * refactor: include Style in ui barrel * chore: separate compat build script * chore: fix tslint errors * chore: update NATIVESCRIPT_CORE_ARGS * chore: fix compat pack * chore: fix ui-test-app build with linked modules * chore: Application, ApplicationSettings, Connectivity and Http * chore: export Trace, Profiling and Utils * refactor: Static create methods for ImageSource * chore: fix deprecated usages of ImageSource * chore: move Span and FormattedString to ui * chore: add events-args and ImageSource to index files * chore: check for CLI >= 6.2 when building for IOS * chore: update travis build * chore: copy Pod file to compat package * chore: update error msg ui-tests-app * refactor: Apply suggestions from code review Co-Authored-By: Martin Yankov <m.i.yankov@gmail.com> * chore: typings and refs * chore: add missing d.ts files for public API * chore: adress code review FB * chore: update api-report * chore: dev-workflow for other apps * chore: api update * chore: update api-report
110 lines
3.9 KiB
TypeScript
110 lines
3.9 KiB
TypeScript
import { View, PageBase, Color, actionBarHiddenProperty, statusBarStyleProperty, androidStatusBarBackgroundProperty } from "./page-common";
|
|
import { ActionBar } from "../action-bar";
|
|
import { GridLayout } from "../layouts/grid-layout";
|
|
import { device } from "../../platform";
|
|
import { profile } from "../../profiling";
|
|
|
|
export * from "./page-common";
|
|
|
|
const SYSTEM_UI_FLAG_LIGHT_STATUS_BAR = 0x00002000;
|
|
const STATUS_BAR_LIGHT_BCKG = -657931;
|
|
const STATUS_BAR_DARK_BCKG = 1711276032;
|
|
|
|
export class Page extends PageBase {
|
|
nativeViewProtected: org.nativescript.widgets.GridLayout;
|
|
|
|
public createNativeView() {
|
|
const layout = new org.nativescript.widgets.GridLayout(this._context);
|
|
layout.addRow(new org.nativescript.widgets.ItemSpec(1, org.nativescript.widgets.GridUnitType.auto));
|
|
layout.addRow(new org.nativescript.widgets.ItemSpec(1, org.nativescript.widgets.GridUnitType.star));
|
|
|
|
return layout;
|
|
}
|
|
|
|
public initNativeView(): void {
|
|
super.initNativeView();
|
|
this.nativeViewProtected.setBackgroundColor(-1); // White color.
|
|
}
|
|
|
|
public _addViewToNativeVisualTree(child: View, atIndex?: number): boolean {
|
|
// Set the row property for the child
|
|
if (this.nativeViewProtected && child.nativeViewProtected) {
|
|
if (child instanceof ActionBar) {
|
|
GridLayout.setRow(child, 0);
|
|
child.horizontalAlignment = "stretch";
|
|
child.verticalAlignment = "top";
|
|
}
|
|
else {
|
|
GridLayout.setRow(child, 1);
|
|
}
|
|
}
|
|
|
|
return super._addViewToNativeVisualTree(child, atIndex);
|
|
}
|
|
|
|
@profile
|
|
public onLoaded() {
|
|
super.onLoaded();
|
|
if (this.actionBarHidden !== undefined) {
|
|
this.updateActionBar();
|
|
}
|
|
}
|
|
|
|
private updateActionBar() {
|
|
this.actionBar.update();
|
|
}
|
|
|
|
[actionBarHiddenProperty.setNative](value: boolean) {
|
|
this.updateActionBar();
|
|
}
|
|
|
|
[statusBarStyleProperty.getDefault](): { color: number, systemUiVisibility: number } {
|
|
if (device.sdkVersion >= "21") {
|
|
const window = (<androidx.appcompat.app.AppCompatActivity>this._context).getWindow();
|
|
const decorView = window.getDecorView();
|
|
|
|
return {
|
|
color: (<any>window).getStatusBarColor(),
|
|
systemUiVisibility: decorView.getSystemUiVisibility()
|
|
};
|
|
}
|
|
|
|
return null;
|
|
}
|
|
[statusBarStyleProperty.setNative](value: "dark" | "light" | { color: number, systemUiVisibility: number }) {
|
|
if (device.sdkVersion >= "21") {
|
|
const window = (<androidx.appcompat.app.AppCompatActivity>this._context).getWindow();
|
|
const decorView = window.getDecorView();
|
|
|
|
if (value === "light") {
|
|
(<any>window).setStatusBarColor(STATUS_BAR_LIGHT_BCKG);
|
|
decorView.setSystemUiVisibility(SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
|
|
|
|
} else if (value === "dark") {
|
|
(<any>window).setStatusBarColor(STATUS_BAR_DARK_BCKG);
|
|
decorView.setSystemUiVisibility(0);
|
|
} else {
|
|
(<any>window).setStatusBarColor(value.color);
|
|
decorView.setSystemUiVisibility(value.systemUiVisibility);
|
|
}
|
|
}
|
|
}
|
|
|
|
[androidStatusBarBackgroundProperty.getDefault](): number {
|
|
if (device.sdkVersion >= "21") {
|
|
const window = (<androidx.appcompat.app.AppCompatActivity>this._context).getWindow();
|
|
|
|
return (<any>window).getStatusBarColor();
|
|
}
|
|
|
|
return null;
|
|
}
|
|
[androidStatusBarBackgroundProperty.setNative](value: number | Color) {
|
|
if (device.sdkVersion >= "21") {
|
|
const window = (<androidx.appcompat.app.AppCompatActivity>this._context).getWindow();
|
|
const color = value instanceof Color ? value.android : value;
|
|
(<any>window).setStatusBarColor(color);
|
|
}
|
|
}
|
|
}
|