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
115 lines
4.2 KiB
TypeScript
115 lines
4.2 KiB
TypeScript
import {
|
|
GridLayoutBase, ItemSpec as ItemSpecBase, View, layout,
|
|
rowProperty, columnProperty, rowSpanProperty, columnSpanProperty, GridUnitType
|
|
} from "./grid-layout-common";
|
|
|
|
export * from "./grid-layout-common";
|
|
|
|
function makeNativeSetter<T>(setter: (lp: org.nativescript.widgets.CommonLayoutParams, value: T) => void) {
|
|
return function (this: View, value: T) {
|
|
const nativeView: android.view.View = this.nativeViewProtected;
|
|
const lp = nativeView.getLayoutParams() || new org.nativescript.widgets.CommonLayoutParams();
|
|
if (lp instanceof org.nativescript.widgets.CommonLayoutParams) {
|
|
setter(lp, value);
|
|
nativeView.setLayoutParams(lp);
|
|
}
|
|
};
|
|
}
|
|
|
|
View.prototype[rowProperty.setNative] = makeNativeSetter<number>((lp, value) => lp.row = value);
|
|
View.prototype[columnProperty.setNative] = makeNativeSetter<number>((lp, value) => lp.column = value);
|
|
View.prototype[rowSpanProperty.setNative] = makeNativeSetter<number>((lp, value) => lp.rowSpan = value);
|
|
View.prototype[columnSpanProperty.setNative] = makeNativeSetter<number>((lp, value) => lp.columnSpan = value);
|
|
|
|
function createNativeSpec(itemSpec: ItemSpec): org.nativescript.widgets.ItemSpec {
|
|
switch (itemSpec.gridUnitType) {
|
|
case GridUnitType.AUTO:
|
|
return new org.nativescript.widgets.ItemSpec(itemSpec.value, org.nativescript.widgets.GridUnitType.auto);
|
|
|
|
case GridUnitType.STAR:
|
|
return new org.nativescript.widgets.ItemSpec(itemSpec.value, org.nativescript.widgets.GridUnitType.star);
|
|
|
|
case GridUnitType.PIXEL:
|
|
return new org.nativescript.widgets.ItemSpec(itemSpec.value * layout.getDisplayDensity(), org.nativescript.widgets.GridUnitType.pixel);
|
|
|
|
default:
|
|
throw new Error("Invalid gridUnitType: " + itemSpec.gridUnitType);
|
|
}
|
|
}
|
|
|
|
export class ItemSpec extends ItemSpecBase {
|
|
nativeSpec: org.nativescript.widgets.ItemSpec;
|
|
|
|
public get actualLength(): number {
|
|
if (this.nativeSpec) {
|
|
return Math.round(this.nativeSpec.getActualLength() / layout.getDisplayDensity());
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
export class GridLayout extends GridLayoutBase {
|
|
nativeViewProtected: org.nativescript.widgets.GridLayout;
|
|
|
|
public createNativeView() {
|
|
return new org.nativescript.widgets.GridLayout(this._context);
|
|
}
|
|
|
|
public initNativeView(): void {
|
|
super.initNativeView();
|
|
// Update native GridLayout
|
|
this.rowsInternal.forEach((itemSpec: ItemSpec, index, rows) => { this._onRowAdded(itemSpec); }, this);
|
|
this.columnsInternal.forEach((itemSpec: ItemSpec, index, rows) => { this._onColumnAdded(itemSpec); }, this);
|
|
}
|
|
|
|
public resetNativeView() {
|
|
// Update native GridLayout
|
|
for (let i = this.rowsInternal.length; i--; i >= 0) {
|
|
const itemSpec = <ItemSpec>this.rowsInternal[i];
|
|
this._onRowRemoved(itemSpec, i);
|
|
}
|
|
|
|
for (let i = this.columnsInternal.length; i--; i >= 0) {
|
|
const itemSpec = <ItemSpec>this.columnsInternal[i];
|
|
this._onColumnRemoved(itemSpec, i);
|
|
}
|
|
|
|
super.resetNativeView();
|
|
}
|
|
|
|
public _onRowAdded(itemSpec: ItemSpec) {
|
|
if (this.nativeViewProtected) {
|
|
const nativeSpec = createNativeSpec(itemSpec);
|
|
itemSpec.nativeSpec = nativeSpec;
|
|
this.nativeViewProtected.addRow(nativeSpec);
|
|
}
|
|
}
|
|
|
|
public _onColumnAdded(itemSpec: ItemSpec) {
|
|
if (this.nativeViewProtected) {
|
|
const nativeSpec = createNativeSpec(itemSpec);
|
|
itemSpec.nativeSpec = nativeSpec;
|
|
this.nativeViewProtected.addColumn(nativeSpec);
|
|
}
|
|
}
|
|
|
|
public _onRowRemoved(itemSpec: ItemSpec, index: number) {
|
|
itemSpec.nativeSpec = null;
|
|
if (this.nativeViewProtected) {
|
|
this.nativeViewProtected.removeRowAt(index);
|
|
}
|
|
}
|
|
|
|
public _onColumnRemoved(itemSpec: ItemSpec, index: number) {
|
|
itemSpec.nativeSpec = null;
|
|
if (this.nativeViewProtected) {
|
|
this.nativeViewProtected.removeColumnAt(index);
|
|
}
|
|
}
|
|
|
|
protected invalidate(): void {
|
|
// No need to request layout for android because it will be done in the native call.
|
|
}
|
|
}
|