mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-16 03:31:45 +08:00
141 lines
5.5 KiB
TypeScript
141 lines
5.5 KiB
TypeScript
import common = require("./button-common");
|
|
import utils = require("utils/utils")
|
|
import dependencyObservable = require("ui/core/dependency-observable");
|
|
import style = require("ui/styling/style");
|
|
import { TextBaseStyler as TBS } from "ui/text-base/text-base-styler";
|
|
import {device} from "platform";
|
|
import {GestureTypes, TouchGestureEventData, TouchAction} from "ui/gestures";
|
|
import {PseudoClassHandler} from "ui/core/view";
|
|
|
|
let styleHandlersInitialized: boolean;
|
|
|
|
global.moduleMerge(common, exports);
|
|
|
|
export class Button extends common.Button {
|
|
private _android: android.widget.Button;
|
|
private _isPressed: boolean;
|
|
private _highlightedHandler: (args: TouchGestureEventData) => void;
|
|
|
|
constructor() {
|
|
super();
|
|
|
|
this._isPressed = false;
|
|
if(!styleHandlersInitialized) {
|
|
styleHandlersInitialized = true;
|
|
ButtonStyler.registerHandlers();
|
|
}
|
|
}
|
|
|
|
get android(): android.widget.Button {
|
|
return this._android;
|
|
}
|
|
|
|
public _createUI() {
|
|
|
|
var that = new WeakRef(this);
|
|
|
|
this._android = new android.widget.Button(this._context);
|
|
|
|
this._android.setOnClickListener(new android.view.View.OnClickListener(
|
|
<utils.Owned & android.view.View.IOnClickListener>{
|
|
get owner() {
|
|
return that.get();
|
|
},
|
|
|
|
onClick: function (v) {
|
|
if (this.owner) {
|
|
this.owner._emit(common.Button.tapEvent);
|
|
}
|
|
}
|
|
}));
|
|
}
|
|
|
|
public _onTextPropertyChanged(data: dependencyObservable.PropertyChangeData) {
|
|
if (this.android) {
|
|
this.android.setText(data.newValue + "");
|
|
}
|
|
}
|
|
|
|
private _transformationMethod;
|
|
public _setFormattedTextPropertyToNative(value) {
|
|
var newText = value ? value._formattedText : null;
|
|
if (this.android) {
|
|
if (newText) {
|
|
if (!this._transformationMethod) {
|
|
this._transformationMethod = this.android.getTransformationMethod();
|
|
}
|
|
this.android.setTransformationMethod(null);
|
|
} else {
|
|
if (this._transformationMethod && !this.android.getTransformationMethod()) {
|
|
this.android.setTransformationMethod(this._transformationMethod);
|
|
}
|
|
}
|
|
|
|
this.android.setText(newText);
|
|
}
|
|
}
|
|
|
|
@PseudoClassHandler("normal", "highlighted", "pressed", "active")
|
|
_updateHandler(subscribe: boolean) {
|
|
if (subscribe) {
|
|
this._highlightedHandler = this._highlightedHandler || ((args: TouchGestureEventData) => {
|
|
switch(args.action) {
|
|
case TouchAction.up:
|
|
this._goToVisualState("normal");
|
|
break;
|
|
case TouchAction.down:
|
|
this._goToVisualState("highlighted");
|
|
break;
|
|
}
|
|
});
|
|
this.on(GestureTypes.touch, this._highlightedHandler);
|
|
} else {
|
|
this.off(GestureTypes.touch, this._highlightedHandler);
|
|
}
|
|
}
|
|
}
|
|
|
|
export class ButtonStyler implements style.Styler {
|
|
public static registerHandlers() {
|
|
// !!! IMPORTANT !!! This was moved here because of the following bug: https://github.com/NativeScript/NativeScript/issues/1902
|
|
// If there is no TextBase on the Page, the TextBaseStyler.registerHandlers
|
|
// method was never called because the file it is called from was never required.
|
|
|
|
// Register the same stylers for Button.
|
|
// It also derives from TextView but is not under TextBase in our View hierarchy.
|
|
var TextBaseStyler = <any>TBS;
|
|
style.registerHandler(style.colorProperty, new style.StylePropertyChangedHandler(
|
|
TextBaseStyler.setColorProperty,
|
|
TextBaseStyler.resetColorProperty,
|
|
TextBaseStyler.getNativeColorValue), "Button");
|
|
|
|
style.registerHandler(style.fontInternalProperty, new style.StylePropertyChangedHandler(
|
|
TextBaseStyler.setFontInternalProperty,
|
|
TextBaseStyler.resetFontInternalProperty,
|
|
TextBaseStyler.getNativeFontInternalValue), "Button");
|
|
|
|
style.registerHandler(style.textAlignmentProperty, new style.StylePropertyChangedHandler(
|
|
TextBaseStyler.setTextAlignmentProperty,
|
|
TextBaseStyler.resetTextAlignmentProperty,
|
|
TextBaseStyler.getNativeTextAlignmentValue), "Button");
|
|
|
|
style.registerHandler(style.textDecorationProperty, new style.StylePropertyChangedHandler(
|
|
TextBaseStyler.setTextDecorationProperty,
|
|
TextBaseStyler.resetTextDecorationProperty), "Button");
|
|
|
|
style.registerHandler(style.textTransformProperty, new style.StylePropertyChangedHandler(
|
|
TextBaseStyler.setTextTransformProperty,
|
|
TextBaseStyler.resetTextTransformProperty), "Button");
|
|
|
|
style.registerHandler(style.whiteSpaceProperty, new style.StylePropertyChangedHandler(
|
|
TextBaseStyler.setWhiteSpaceProperty,
|
|
TextBaseStyler.resetWhiteSpaceProperty), "Button");
|
|
|
|
if (parseInt(device.sdkVersion, 10) >= 21) {
|
|
style.registerHandler(style.letterSpacingProperty, new style.StylePropertyChangedHandler(
|
|
TextBaseStyler.setLetterSpacingProperty,
|
|
TextBaseStyler.resetLetterSpacingProperty,
|
|
TextBaseStyler.getLetterSpacingProperty), "Button");
|
|
}
|
|
}
|
|
} |