diff --git a/CrossPlatformModules.csproj b/CrossPlatformModules.csproj index 8fe407600..59019d963 100644 --- a/CrossPlatformModules.csproj +++ b/CrossPlatformModules.csproj @@ -151,6 +151,9 @@ + + + time-picker-tests-native.d.ts diff --git a/apps/tests/ui/border/border-tests-native.android.ts b/apps/tests/ui/border/border-tests-native.android.ts new file mode 100644 index 000000000..6500c4b74 --- /dev/null +++ b/apps/tests/ui/border/border-tests-native.android.ts @@ -0,0 +1,34 @@ +import borderModule = require("ui/border"); +import utils = require("utils/utils"); + +var density = utils.layout.getDisplayDensity(); + +export function getNativeBorderWidth(border: borderModule.Border): number { + var bkg = (border.android).getBackground(); + + return bkg && bkg.getStroke ? bkg.getStroke() / density : -1; +} + +export function getNativeCornerRadius(border: borderModule.Border): number { + var bkg = (border.android).getBackground(); + + return bkg && bkg.getCornerRadius ? bkg.getCornerRadius() / density : -1; +} + +export function checkNativeBorderColor(border: borderModule.Border): boolean { + var bkg = (border.android).getBackground(); + + return border.borderColor && bkg && bkg.getBorderColor && bkg.getBorderColor() === border.borderColor.android; +} + +export function checkNativeBackgroundColor(border: borderModule.Border): boolean { + var bkg = (border.android).getBackground(); + + return border.backgroundColor && bkg && bkg.getBackgroundColor && bkg.getBackgroundColor() === border.backgroundColor.android; +} + +export function checkNativeBackgroundImage(border: borderModule.Border): boolean { + var bkg = (border.android).getBackground(); + + return bkg && bkg.getBitmap && bkg.getBitmap() !== undefined; +} \ No newline at end of file diff --git a/apps/tests/ui/border/border-tests-native.d.ts b/apps/tests/ui/border/border-tests-native.d.ts new file mode 100644 index 000000000..867230193 --- /dev/null +++ b/apps/tests/ui/border/border-tests-native.d.ts @@ -0,0 +1,12 @@ +//@private +import borderModule = require("ui/border"); + +export declare function getNativeBorderWidth(border: borderModule.Border): number; + +export declare function getNativeCornerRadius(border: borderModule.Border): number; + +export declare function checkNativeBorderColor(border: borderModule.Border): boolean + +export declare function checkNativeBackgroundColor(border: borderModule.Border): boolean; + +export declare function checkNativeBackgroundImage(border: borderModule.Border): boolean \ No newline at end of file diff --git a/apps/tests/ui/border/border-tests-native.ios.ts b/apps/tests/ui/border/border-tests-native.ios.ts new file mode 100644 index 000000000..ecd54ae0c --- /dev/null +++ b/apps/tests/ui/border/border-tests-native.ios.ts @@ -0,0 +1,21 @@ +import borderModule = require("ui/border"); + +export function getNativeBorderWidth(border: borderModule.Border): number { + return (border.ios).layer.borderWidth; +} + +export function getNativeCornerRadius(border: borderModule.Border): number { + return (border.ios).layer.cornerRadius; +} + +export function checkNativeBorderColor(border: borderModule.Border): boolean { + return border.borderColor && (border.ios).layer.borderColor === border.borderColor.ios.CGColor; +} + +export function checkNativeBackgroundColor(border: borderModule.Border): boolean { + return border.backgroundColor && (border.ios).backgroundColor.isEqual(border.backgroundColor.ios); +} + +export function checkNativeBackgroundImage(border: borderModule.Border): boolean { + return (border.ios).backgroundColor !== undefined; +} \ No newline at end of file diff --git a/apps/tests/ui/border/border-tests.ts b/apps/tests/ui/border/border-tests.ts index 9aeb0fc9f..1302ac755 100644 --- a/apps/tests/ui/border/border-tests.ts +++ b/apps/tests/ui/border/border-tests.ts @@ -1,5 +1,10 @@ import buttonModule = require("ui/button"); import colorModule = require("color"); +import TKUnit = require("../../TKUnit"); +import helper = require("../helper"); +import viewModule = require("ui/core/view"); +import borderTestsNative = require("./border-tests-native"); +import pageModule = require("ui/page"); //  // # Border @@ -18,7 +23,7 @@ import borderModule = require("ui/border"); //``` //  -export function test_DummyTestForCodeSnippet() { +function _createBorder(): borderModule.Border { // // ### Creating a Border programmatically // ``` JavaScript @@ -27,10 +32,56 @@ export function test_DummyTestForCodeSnippet() { var border = new borderModule.Border(); border.cornerRadius = 10; - border.borderWidth = 1; + border.borderWidth = 2; border.borderColor = new colorModule.Color("#FF0000"); + border.backgroundColor = new colorModule.Color("#FFFF00"); border.content = button; // ``` // + + return border; +} + +export var testBorderWidth = function () { + helper.buildUIAndRunTest(_createBorder(), function (views: Array) { + var border = views[0]; + var expectedValue = border.borderWidth; + var actualValue = borderTestsNative.getNativeBorderWidth(border); + TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue); + }); +} + +export var testCornerRadius = function () { + helper.buildUIAndRunTest(_createBorder(), function (views: Array) { + var border = views[0]; + var expectedValue = border.cornerRadius; + var actualValue = borderTestsNative.getNativeCornerRadius(border); + TKUnit.assert(actualValue === expectedValue, "Actual: " + actualValue + "; Expected: " + expectedValue); + }); +} + +export var testBorderColor = function () { + helper.buildUIAndRunTest(_createBorder(), function (views: Array) { + var border = views[0]; + TKUnit.assert(borderTestsNative.checkNativeBorderColor(border), "BorderColor not applied correctly!"); + }); +} + +export var testBackgroundColor = function () { + helper.buildUIAndRunTest(_createBorder(), function (views: Array) { + var border = views[0]; + TKUnit.assert(borderTestsNative.checkNativeBackgroundColor(border), "BackgroundColor not applied correctly!"); + }); +} + +export var testBackgroundImage = function () { + var border = _createBorder(); + + helper.buildUIAndRunTest(border, function (views: Array) { + var page = views[1]; + page.css = "Border { background-image: url(';') }"; + + TKUnit.assert(borderTestsNative.checkNativeBackgroundImage(border), "Style background-image not loaded correctly from data URI."); + }); } \ No newline at end of file diff --git a/ui/border/border.android.ts b/ui/border/border.android.ts index bbb4cd244..576be53f8 100644 --- a/ui/border/border.android.ts +++ b/ui/border/border.android.ts @@ -33,6 +33,9 @@ export class Border extends borderCommon.Border { class BorderGradientDrawable extends android.graphics.drawable.GradientDrawable { private paint: android.graphics.Paint; private stroke: number; + private cornerRadius: number; + private backgroundColor: number; + private borderColor: number; private bitmap: android.graphics.Bitmap constructor(borderWidth: number, borderColor: number, backgroundColor: number, cornerRadius: number, bitmap?: android.graphics.Bitmap) { @@ -43,19 +46,42 @@ class BorderGradientDrawable extends android.graphics.drawable.GradientDrawable if (bitmap) { this.paint = new android.graphics.Paint(); } else { + this.backgroundColor = backgroundColor; this.setColor(backgroundColor); } var density = utils.layout.getDisplayDensity(); this.stroke = borderWidth * density; - this.setStroke(this.stroke, borderColor); + this.borderColor = borderColor; + this.setStroke(this.stroke, this.borderColor); - this.setCornerRadius(cornerRadius * density); + this.cornerRadius = cornerRadius * density; + this.setCornerRadius(this.cornerRadius); return global.__native(this); } + public getStroke(): number { + return this.stroke; + } + + public getCornerRadius(): number { + return this.cornerRadius; + } + + public getBackgroundColor(): number { + return this.backgroundColor; + } + + public getBorderColor(): number { + return this.borderColor; + } + + public getBitmap(): android.graphics.Bitmap { + return this.bitmap; + } + public draw(canvas: android.graphics.Canvas): void { if (this.paint) { canvas.drawBitmap(this.bitmap, this.stroke, this.stroke, this.paint);