mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-16 03:31:45 +08:00

- Use relative imports in place of most of our absolute ones. - Add "private" ambient modules for modules that we need to import using an absolute path (e.g. when app/.../test-something.ts needs to import ui/styling/style-scope)
48 lines
1.3 KiB
TypeScript
48 lines
1.3 KiB
TypeScript
import common = require("./button-common");
|
|
import stateChanged = require("ui/core/control-state-change");
|
|
|
|
class TapHandlerImpl extends NSObject {
|
|
static new(): TapHandlerImpl {
|
|
return <TapHandlerImpl>super.new();
|
|
}
|
|
|
|
private _owner: Button;
|
|
|
|
public initWithOwner(owner: Button): TapHandlerImpl {
|
|
this._owner = owner;
|
|
return this;
|
|
}
|
|
|
|
public tap(args) {
|
|
this._owner._emit(common.Button.tapEvent);
|
|
}
|
|
|
|
public static ObjCExposedMethods = {
|
|
"tap": { returns: interop.types.void, params: [interop.types.id] }
|
|
};
|
|
}
|
|
|
|
global.moduleMerge(common, exports);
|
|
|
|
export class Button extends common.Button {
|
|
private _ios: UIButton;
|
|
private _tapHandler: NSObject;
|
|
private _stateChangedHandler: stateChanged.ControlStateChangeListener;
|
|
|
|
constructor() {
|
|
super();
|
|
this._ios = UIButton.buttonWithType(UIButtonType.UIButtonTypeSystem);
|
|
|
|
this._tapHandler = TapHandlerImpl.new().initWithOwner(this);
|
|
this._ios.addTargetActionForControlEvents(this._tapHandler, "tap", UIControlEvents.UIControlEventTouchUpInside);
|
|
|
|
this._stateChangedHandler = new stateChanged.ControlStateChangeListener(this._ios, (s: string) => {
|
|
this._goToVisualState(s);
|
|
});
|
|
}
|
|
|
|
get ios(): UIButton {
|
|
return this._ios;
|
|
}
|
|
}
|