Files
NativeScript/tns-core-modules/ui/html-view/html-view.android.ts
Hristo Hristov c18a76c93a rename:
_createNativeView to createNativeView;
_initNativeView to initNativeView
_disposeNativeView to disposeNativeView
_resetNativeView to resetNativeView
2017-03-28 18:08:59 +03:00

32 lines
1.1 KiB
TypeScript

import {
HtmlViewBase, htmlProperty
} from "./html-view-common";
export * from "./html-view-common";
export class HtmlView extends HtmlViewBase {
nativeView: android.widget.TextView;
public createNativeView() {
const textView = new android.widget.TextView(this._context);
// This makes the html <a href...> work
textView.setLinksClickable(true);
textView.setMovementMethod(android.text.method.LinkMovementMethod.getInstance());
return textView;
}
[htmlProperty.getDefault](): string {
return "";
}
[htmlProperty.setNative](value: string) {
// If the data.newValue actually has a <a...> in it; we need to disable autolink mask
// it internally disables the coloring, but then the <a> links won't work.. So to support both
// styles of links (html and just text based) we have to manually enable/disable the autolink mask
let mask = 15;
if (value.search(/<a\s/i) >= 0) {
mask = 0;
}
this.nativeView.setAutoLinkMask(mask);
this.nativeView.setText(<any>android.text.Html.fromHtml(value));
}
}