mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-18 22:01:42 +08:00
113 lines
3.7 KiB
TypeScript
113 lines
3.7 KiB
TypeScript
import { ListPickerBase, Color, selectedIndexProperty, itemsProperty, backgroundColorProperty, colorProperty } from "./list-picker-common";
|
|
import { ItemsSource } from "ui/list-picker";
|
|
|
|
export * from "./list-picker-common";
|
|
|
|
export class ListPicker extends ListPickerBase {
|
|
private _ios: UIPickerView;
|
|
private _dataSource: ListPickerDataSource;
|
|
private _delegate: ListPickerDelegateImpl;
|
|
|
|
constructor() {
|
|
super();
|
|
|
|
this._ios = UIPickerView.new();
|
|
this._ios.dataSource = this._dataSource = ListPickerDataSource.initWithOwner(new WeakRef(this));
|
|
this._delegate = ListPickerDelegateImpl.initWithOwner(new WeakRef(this));
|
|
|
|
this.nativeView = this._ios;
|
|
}
|
|
|
|
public onLoaded() {
|
|
super.onLoaded();
|
|
this._ios.delegate = this._delegate;
|
|
}
|
|
|
|
public onUnloaded() {
|
|
this._ios.delegate = null;
|
|
super.onUnloaded();
|
|
}
|
|
|
|
get ios(): UIPickerView {
|
|
return this._ios;
|
|
}
|
|
|
|
get [selectedIndexProperty.native](): number {
|
|
return -1;
|
|
}
|
|
set [selectedIndexProperty.native](value: number) {
|
|
if (value >= 0) {
|
|
this.ios.selectRowInComponentAnimated(value, 0, false);
|
|
}
|
|
}
|
|
|
|
get [itemsProperty.native](): any[] {
|
|
return null;
|
|
}
|
|
set [itemsProperty.native](value: any[] | ItemsSource) {
|
|
this.ios.reloadAllComponents();
|
|
}
|
|
|
|
get [backgroundColorProperty.native](): UIColor {
|
|
return this._ios.backgroundColor;
|
|
}
|
|
set [backgroundColorProperty.native](value: UIColor | Color) {
|
|
this._ios.backgroundColor = value instanceof Color ? value.ios : value;
|
|
}
|
|
|
|
get [colorProperty.native](): UIColor {
|
|
return this._ios.tintColor;
|
|
}
|
|
set [colorProperty.native](value: UIColor | Color) {
|
|
this._ios.tintColor = value instanceof Color ? value.ios : value;
|
|
}
|
|
}
|
|
|
|
class ListPickerDataSource extends NSObject implements UIPickerViewDataSource {
|
|
public static ObjCProtocols = [UIPickerViewDataSource];
|
|
|
|
private _owner: WeakRef<ListPicker>;
|
|
|
|
public static initWithOwner(owner: WeakRef<ListPicker>): ListPickerDataSource {
|
|
let dataSource = <ListPickerDataSource>ListPickerDataSource.new();
|
|
dataSource._owner = owner;
|
|
return dataSource;
|
|
}
|
|
|
|
public numberOfComponentsInPickerView(pickerView: UIPickerView) {
|
|
return 1;
|
|
}
|
|
|
|
public pickerViewNumberOfRowsInComponent(pickerView: UIPickerView, component: number) {
|
|
let owner = this._owner.get();
|
|
return (owner && owner.items) ? owner.items.length : 0;
|
|
}
|
|
}
|
|
|
|
class ListPickerDelegateImpl extends NSObject implements UIPickerViewDelegate {
|
|
public static ObjCProtocols = [UIPickerViewDelegate];
|
|
|
|
private _owner: WeakRef<ListPicker>;
|
|
|
|
public static initWithOwner(owner: WeakRef<ListPicker>): ListPickerDelegateImpl {
|
|
let delegate = <ListPickerDelegateImpl>ListPickerDelegateImpl.new();
|
|
delegate._owner = owner;
|
|
return delegate;
|
|
}
|
|
|
|
public pickerViewAttributedTitleForRowForComponent(pickerView: UIPickerView, row: number, component: number): NSAttributedString {
|
|
let owner = this._owner.get();
|
|
if (owner) {
|
|
let title = NSAttributedString.alloc().initWithStringAttributes(owner._getItemAsString(row), <any>{ [NSForegroundColorAttributeName]: pickerView.tintColor });
|
|
return title;
|
|
}
|
|
return NSAttributedString.alloc().initWithStringAttributes(row.toString(), <any>{ [NSForegroundColorAttributeName]: pickerView.tintColor });
|
|
}
|
|
|
|
public pickerViewDidSelectRowInComponent(pickerView: UIPickerView, row: number, component: number): void {
|
|
let owner = this._owner.get();
|
|
if (owner) {
|
|
selectedIndexProperty.nativeValueChange(owner, row);
|
|
}
|
|
}
|
|
} |