mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-17 21:01:34 +08:00

* enable recycling of nativeView * backgroundInternal is reset if setting new value leads to background.isEmpty() == true. * android background.getDefault always return copy of the background. Now all controls that mutate the background can be reset to initial state (e.g. Button & ActionBar) passing resources to copied background so it respect density. fix properties initNativeView * reset padding when backgroundInternal is reset. * Fix text reset Fix padding reset * fix tsc errors * fix ugly text rendering. * Add unit tests for recycling native views Fix several issues that came from the above tests Fix maxLength property missing a converter callback Remove old files * Remove old files * Revert backgroundInternal setter * change the order of tests so that appium can work again * Remove suggestion on every TextView & TextField init (strangely it is enabled after view is recycled....) * Fix function to get parent layout if specified * Button stateListAnimator restored when button is recycled zIndex defaultValue is now undefined instead of NaN * revert zIndex.setNative to always clear stateListAnimator because it was breaking one UI test (setting value=0 was returning the previous stateListAnimator) * fix search-bar backgound-color recycling * Fix alignments setters * Fix imageView recycling Fix button recycling Fix edit-text recycling resetNativeView is called only if recycleNativeView flag is true * Fix incorrect merge * Fix text-view & text-field textTransform * Fix EditText text reset * Fix runtime crash on ARM emulator API 21 * Fix text-base minHeight. maxHeight reset Fix reset of isUserInteractionEnabled
142 lines
5.0 KiB
TypeScript
142 lines
5.0 KiB
TypeScript
import {
|
|
ButtonBase, PseudoClassHandler,
|
|
paddingLeftProperty, paddingTopProperty, paddingRightProperty, paddingBottomProperty,
|
|
Length, zIndexProperty, textAlignmentProperty, TextAlignment
|
|
} from "./button-common";
|
|
import { profile } from "../../profiling";
|
|
import { TouchGestureEventData, GestureTypes, TouchAction } from "../gestures";
|
|
|
|
export * from "./button-common";
|
|
|
|
interface ClickListener {
|
|
new (owner: Button): android.view.View.OnClickListener;
|
|
}
|
|
|
|
let ClickListener: ClickListener;
|
|
let APILEVEL: number;
|
|
let AndroidButton: typeof android.widget.Button;
|
|
|
|
function initializeClickListener(): void {
|
|
if (ClickListener) {
|
|
return;
|
|
}
|
|
|
|
@Interfaces([android.view.View.OnClickListener])
|
|
class ClickListenerImpl extends java.lang.Object implements android.view.View.OnClickListener {
|
|
constructor(public owner: Button) {
|
|
super();
|
|
return global.__native(this);
|
|
}
|
|
|
|
public onClick(v: android.view.View): void {
|
|
this.owner._emit(ButtonBase.tapEvent);
|
|
}
|
|
}
|
|
|
|
ClickListener = ClickListenerImpl;
|
|
APILEVEL = android.os.Build.VERSION.SDK_INT;
|
|
AndroidButton = android.widget.Button;
|
|
}
|
|
|
|
export class Button extends ButtonBase {
|
|
nativeView: android.widget.Button;
|
|
|
|
private _stateListAnimator: any;
|
|
private _highlightedHandler: (args: TouchGestureEventData) => void;
|
|
|
|
@profile
|
|
public createNativeView() {
|
|
initializeClickListener();
|
|
const button = new AndroidButton(this._context);
|
|
const clickListener = new ClickListener(this);
|
|
button.setOnClickListener(clickListener);
|
|
(<any>button).clickListener = clickListener;
|
|
return button;
|
|
}
|
|
|
|
public initNativeView(): void {
|
|
const nativeView = this.nativeView;
|
|
(<any>nativeView).clickListener.owner = this;
|
|
super.initNativeView();
|
|
}
|
|
|
|
public disposeNativeView() {
|
|
(<any>this.nativeView).clickListener.owner = null;
|
|
super.disposeNativeView();
|
|
}
|
|
|
|
public resetNativeView(): void {
|
|
super.resetNativeView();
|
|
|
|
if (this._stateListAnimator && APILEVEL >= 21) {
|
|
(<any>this.nativeView).setStateListAnimator(this._stateListAnimator);
|
|
this._stateListAnimator = undefined;
|
|
}
|
|
}
|
|
|
|
@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);
|
|
}
|
|
}
|
|
|
|
[paddingTopProperty.getDefault](): Length {
|
|
return { value: this._defaultPaddingTop, unit: "px" }
|
|
}
|
|
[paddingTopProperty.setNative](value: Length) {
|
|
org.nativescript.widgets.ViewHelper.setPaddingTop(this.nativeView, Length.toDevicePixels(value, 0) + Length.toDevicePixels(this.style.borderTopWidth, 0));
|
|
}
|
|
|
|
[paddingRightProperty.getDefault](): Length {
|
|
return { value: this._defaultPaddingRight, unit: "px" }
|
|
}
|
|
[paddingRightProperty.setNative](value: Length) {
|
|
org.nativescript.widgets.ViewHelper.setPaddingRight(this.nativeView, Length.toDevicePixels(value, 0) + Length.toDevicePixels(this.style.borderRightWidth, 0));
|
|
}
|
|
|
|
[paddingBottomProperty.getDefault](): Length {
|
|
return { value: this._defaultPaddingBottom, unit: "px" }
|
|
}
|
|
[paddingBottomProperty.setNative](value: Length) {
|
|
org.nativescript.widgets.ViewHelper.setPaddingBottom(this.nativeView, Length.toDevicePixels(value, 0) + Length.toDevicePixels(this.style.borderBottomWidth, 0));
|
|
}
|
|
|
|
[paddingLeftProperty.getDefault](): Length {
|
|
return { value: this._defaultPaddingLeft, unit: "px" }
|
|
}
|
|
[paddingLeftProperty.setNative](value: Length) {
|
|
org.nativescript.widgets.ViewHelper.setPaddingLeft(this.nativeView, Length.toDevicePixels(value, 0) + Length.toDevicePixels(this.style.borderLeftWidth, 0));
|
|
}
|
|
|
|
[zIndexProperty.setNative](value: number) {
|
|
// API >= 21
|
|
if (APILEVEL >= 21) {
|
|
const nativeView = this.nativeView;
|
|
if (!this._stateListAnimator) {
|
|
this._stateListAnimator = (<any>nativeView).getStateListAnimator();
|
|
}
|
|
(<any>nativeView).setStateListAnimator(null);
|
|
}
|
|
|
|
org.nativescript.widgets.ViewHelper.setZIndex(this.nativeView, value);
|
|
}
|
|
|
|
[textAlignmentProperty.setNative](value: TextAlignment) {
|
|
// Button initial value is center.
|
|
const newValue = value === "initial" ? "center" : value;
|
|
super[textAlignmentProperty.setNative](newValue);
|
|
}
|
|
} |