Files
NativeScript/ui/segmented-bar/segmented-bar-common.ts
2015-03-04 16:53:24 +02:00

40 lines
1.4 KiB
TypeScript

import definition = require("ui/segmented-bar");
import view = require("ui/core/view");
import proxy = require("ui/core/proxy");
import dependencyObservable = require("ui/core/dependency-observable");
export module knownCollections {
export var items = "items";
}
export class SegmentedBar extends view.View implements definition.SegmentedBar {
public _addArrayFromBuilder(name: string, value: Array<any>) {
if (name === "items") {
this._setValue(SegmentedBar.itemsProperty, value);
}
}
public _adjustSelectedIndex() {
if (this.selectedIndex > this.items.length - 1) {
this._setValue(SegmentedBar.selectedIndexProperty, this.items.length - 1);
}
}
get selectedIndex(): number {
return this._getValue(SegmentedBar.selectedIndexProperty);
}
set selectedIndex(value: number) {
this._setValue(SegmentedBar.selectedIndexProperty, value);
}
get items(): Array<definition.SegmentedBarEntry> {
return this._getValue(SegmentedBar.itemsProperty);
}
set items(value: Array<definition.SegmentedBarEntry>) {
this._setValue(SegmentedBar.itemsProperty, value);
}
public static selectedIndexProperty = new dependencyObservable.Property("selectedIndex", "SegmentedBar", new proxy.PropertyMetadata(0))
public static itemsProperty = new dependencyObservable.Property("items", "SegmentedBar", new proxy.PropertyMetadata(undefined))
}