Call row/column removed callbacks on removeRows/removeColumns.

Changed callback names to _onRowRemoved, etc and changed visibility to
public to work around a TypeScript "protected" limitation.
This commit is contained in:
Hristo Deshev
2016-05-09 16:58:56 +03:00
parent de748d4a98
commit 21c74bdf5a
5 changed files with 62 additions and 30 deletions

View File

@ -12,10 +12,27 @@ import commonTests = require("./common-layout-tests");
var DELTA = 1; var DELTA = 1;
export class GridLayoutTest extends testModule.UITest<GridLayout> { class RemovalTrackingGridLayout extends GridLayout {
public removedRows = 0;
public removedCols = 0;
public create(): GridLayout { public _onRowRemoved(itemSpec: ItemSpec, index: number) {
return new GridLayout(); console.log("_onRowRemoved");
this.removedRows++;
super._onRowRemoved(itemSpec, index);
}
public _onColumnRemoved(itemSpec: ItemSpec, index: number) {
console.log("_onColumnRemoved");
this.removedCols++;
super._onColumnRemoved(itemSpec, index);
}
}
export class GridLayoutTest extends testModule.UITest<RemovalTrackingGridLayout> {
public create(): RemovalTrackingGridLayout {
return new RemovalTrackingGridLayout();
} }
private row(view: view.View): number { private row(view: view.View): number {
@ -194,16 +211,20 @@ export class GridLayoutTest extends testModule.UITest<GridLayout> {
public test_removeColumns() { public test_removeColumns() {
this.prepareGridLayout(false); this.prepareGridLayout(false);
TKUnit.assertTrue(this.testView.getColumns().length > 0, "There should be columns."); const colsBefore = this.testView.getColumns().length;
TKUnit.assertTrue(colsBefore > 0, "There should be columns.");
this.testView.removeColumns(); this.testView.removeColumns();
TKUnit.assertTrue(this.testView.getColumns().length === 0, "Columns should be empty."); TKUnit.assertTrue(this.testView.getColumns().length === 0, "Columns should be empty.");
TKUnit.assertTrue(this.testView.removedCols === colsBefore, "_onColumnRemoved called for each column.");
} }
public test_removeRows() { public test_removeRows() {
this.prepareGridLayout(false); this.prepareGridLayout(false);
TKUnit.assertTrue(this.testView.getRows().length > 0, "There should be rows."); const rowsBefore = this.testView.getRows().length;
TKUnit.assertTrue(rowsBefore > 0, "There should be rows.");
this.testView.removeRows(); this.testView.removeRows();
TKUnit.assertTrue(this.testView.getRows().length === 0, "Rows should be empty."); TKUnit.assertTrue(this.testView.getRows().length === 0, "Rows should be empty.");
TKUnit.assertTrue(this.testView.removedRows === rowsBefore, "_onRowRemoved called for each row.");
} }
public test_removeChildren() { public test_removeChildren() {

View File

@ -169,7 +169,7 @@ export class GridLayout extends LayoutBase implements definition.GridLayout, App
GridLayout.validateItemSpec(itemSpec); GridLayout.validateItemSpec(itemSpec);
itemSpec.owner = this; itemSpec.owner = this;
this._rows.push(itemSpec); this._rows.push(itemSpec);
this.onRowAdded(itemSpec); this._onRowAdded(itemSpec);
this.invalidate(); this.invalidate();
} }
@ -177,7 +177,7 @@ export class GridLayout extends LayoutBase implements definition.GridLayout, App
GridLayout.validateItemSpec(itemSpec); GridLayout.validateItemSpec(itemSpec);
itemSpec.owner = this; itemSpec.owner = this;
this._cols.push(itemSpec); this._cols.push(itemSpec);
this.onColumnAdded(itemSpec); this._onColumnAdded(itemSpec);
this.invalidate(); this.invalidate();
} }
@ -193,7 +193,7 @@ export class GridLayout extends LayoutBase implements definition.GridLayout, App
itemSpec.index = -1; itemSpec.index = -1;
this._rows.splice(index, 1); this._rows.splice(index, 1);
this.onRowRemoved(itemSpec, index); this._onRowRemoved(itemSpec, index);
this.invalidate(); this.invalidate();
} }
@ -209,21 +209,25 @@ export class GridLayout extends LayoutBase implements definition.GridLayout, App
itemSpec.index = -1; itemSpec.index = -1;
this._cols.splice(index, 1); this._cols.splice(index, 1);
this.onColumnRemoved(itemSpec, index); this._onColumnRemoved(itemSpec, index);
this.invalidate(); this.invalidate();
} }
public removeColumns() { public removeColumns() {
for (var i = 0; i < this._cols.length; i++) { for (var i = this._cols.length - 1; i >= 0; i--) {
this._cols[i].index = -1; const colSpec = this._cols[i];
this._onColumnRemoved(colSpec, i);
colSpec.index = -1;
} }
this._cols.length = 0; this._cols.length = 0;
this.invalidate(); this.invalidate();
} }
public removeRows() { public removeRows() {
for (var i = 0; i < this._rows.length; i++) { for (var i = this._rows.length - 1; i >= 0; i--) {
this._rows[i].index = -1; const rowSpec = this._rows[i];
this._onRowRemoved(rowSpec, i);
rowSpec.index = -1;
} }
this._rows.length = 0; this._rows.length = 0;
this.invalidate(); this.invalidate();
@ -245,19 +249,19 @@ export class GridLayout extends LayoutBase implements definition.GridLayout, App
this.invalidate(); this.invalidate();
} }
protected onRowAdded(itemSpec: ItemSpec) { public _onRowAdded(itemSpec: ItemSpec) {
// //
} }
protected onColumnAdded(itemSpec: ItemSpec) { public _onColumnAdded(itemSpec: ItemSpec) {
// //
} }
protected onRowRemoved(itemSpec: ItemSpec, index: number) { public _onRowRemoved(itemSpec: ItemSpec, index: number): void {
// //
} }
protected onColumnRemoved(itemSpec: ItemSpec, index: number) { public _onColumnRemoved(itemSpec: ItemSpec, index: number): void {
// //
} }

View File

@ -85,11 +85,11 @@ export class GridLayout extends common.GridLayout {
this._layout = new org.nativescript.widgets.GridLayout(this._context); this._layout = new org.nativescript.widgets.GridLayout(this._context);
// Update native GridLayout // Update native GridLayout
this.getRows().forEach((itemSpec: ItemSpec, index, rows) => { this.onRowAdded(itemSpec); }, this); this.getRows().forEach((itemSpec: ItemSpec, index, rows) => { this._onRowAdded(itemSpec); }, this);
this.getColumns().forEach((itemSpec: ItemSpec, index, rows) => { this.onColumnAdded(itemSpec); }, this); this.getColumns().forEach((itemSpec: ItemSpec, index, rows) => { this._onColumnAdded(itemSpec); }, this);
} }
protected onRowAdded(itemSpec: ItemSpec) { public _onRowAdded(itemSpec: ItemSpec) {
if (this._layout) { if (this._layout) {
var nativeSpec = createNativeSpec(itemSpec); var nativeSpec = createNativeSpec(itemSpec);
itemSpec.nativeSpec = nativeSpec; itemSpec.nativeSpec = nativeSpec;
@ -97,7 +97,7 @@ export class GridLayout extends common.GridLayout {
} }
} }
protected onColumnAdded(itemSpec: ItemSpec) { public _onColumnAdded(itemSpec: ItemSpec) {
if (this._layout) { if (this._layout) {
var nativeSpec = createNativeSpec(itemSpec); var nativeSpec = createNativeSpec(itemSpec);
itemSpec.nativeSpec = nativeSpec; itemSpec.nativeSpec = nativeSpec;
@ -105,14 +105,14 @@ export class GridLayout extends common.GridLayout {
} }
} }
protected onRowRemoved(itemSpec: ItemSpec, index: number) { public _onRowRemoved(itemSpec: ItemSpec, index: number) {
itemSpec.nativeSpec = null; itemSpec.nativeSpec = null;
if (this._layout) { if (this._layout) {
this._layout.removeRowAt(index); this._layout.removeRowAt(index);
} }
} }
protected onColumnRemoved(itemSpec: ItemSpec, index: number) { public _onColumnRemoved(itemSpec: ItemSpec, index: number) {
itemSpec.nativeSpec = null; itemSpec.nativeSpec = null;
if (this._layout) { if (this._layout) {
this._layout.removeColumnAt(index); this._layout.removeColumnAt(index);

View File

@ -175,5 +175,12 @@
* Gets array of row specifications defined on this instance of GridLayout. * Gets array of row specifications defined on this instance of GridLayout.
*/ */
public getRows(): Array<ItemSpec>; public getRows(): Array<ItemSpec>;
//@private
public _onRowAdded(itemSpec: ItemSpec): void;
public _onColumnAdded(itemSpec: ItemSpec): void;
public _onRowRemoved(itemSpec: ItemSpec, index: number): void;
public _onColumnRemoved(itemSpec: ItemSpec, index: number): void;
//@endprivate
} }
} }

View File

@ -16,20 +16,20 @@ export class GridLayout extends common.GridLayout {
this.helper = new MeasureHelper(this); this.helper = new MeasureHelper(this);
} }
protected onRowAdded(itemSpec: common.ItemSpec) { public _onRowAdded(itemSpec: common.ItemSpec) {
this.helper.rows.push(new ItemGroup(itemSpec)); this.helper.rows.push(new ItemGroup(itemSpec));
} }
protected onColumnAdded(itemSpec: common.ItemSpec) { public _onColumnAdded(itemSpec: common.ItemSpec) {
this.helper.columns.push(new ItemGroup(itemSpec)); this.helper.columns.push(new ItemGroup(itemSpec));
} }
protected onRowRemoved(itemSpec: common.ItemSpec, index: number) { public _onRowRemoved(itemSpec: common.ItemSpec, index: number) {
this.helper.rows[index].children.length = 0; this.helper.rows[index].children.length = 0;
this.helper.rows.splice(index, 1); this.helper.rows.splice(index, 1);
} }
protected onColumnRemoved(itemSpec: common.ItemSpec, index: number) { public _onColumnRemoved(itemSpec: common.ItemSpec, index: number) {
this.helper.columns[index].children.length = 0; this.helper.columns[index].children.length = 0;
this.helper.columns.splice(index, 1); this.helper.columns.splice(index, 1);
} }