import * as TKUnit from "../../tk-unit"; import * as helper from "../../ui-helper"; import * as viewModule from "@nativescript/core/ui/core/view"; import * as bindable from "@nativescript/core/ui/core/bindable"; import * as observable from "@nativescript/core/data/observable"; import * as color from "@nativescript/core/color"; import * as platform from "@nativescript/core/platform"; // >> article-require-switch import * as switchModule from "@nativescript/core/ui/switch"; // << article-require-switch // ### Binding the Switch checked property and Button isEanbled property to a observable view-model property. // >> article-binding-switch-property function pageLoaded(args) { var page = args.object; var obj = new observable.Observable(); obj.set("someProperty", false); page.bindingContext = obj; } exports.pageLoaded = pageLoaded; // << article-binding-switch-property export function test_recycling() { helper.nativeView_recycling_test(() => new switchModule.Switch()); } export function test_default_TNS_values() { // >> article-create-switch var mySwitch = new switchModule.Switch(); // << article-create-switch TKUnit.assertEqual(mySwitch.checked, false, "Default switch.checked"); } export function test_default_native_values() { var mySwitch = new switchModule.Switch(); function testAction(views: Array) { TKUnit.assertEqual(getNativeValue(mySwitch), false, "Default native switch.checked"); } helper.buildUIAndRunTest(mySwitch, testAction); } // Uncomment this when find way to check android Drawable color set by setColorFilter() method. if (platform.device.os === platform.platformNames.ios) { exports.test_set_color = function () { var mySwitch = new switchModule.Switch(); mySwitch.color = new color.Color("red"); function testAction(views: Array) { TKUnit.assert(mySwitch.color.ios.isEqual(mySwitch.ios.thumbTintColor), "mySwitch.color"); } helper.buildUIAndRunTest(mySwitch, testAction); }; exports.test_set_backgroundColor = function () { var mySwitch = new switchModule.Switch(); mySwitch.backgroundColor = new color.Color("red"); function testAction(views: Array) { TKUnit.assert(CGColorEqualToColor((mySwitch.backgroundColor).ios.CGColor, mySwitch.ios.onTintColor.CGColor), "mySwitch.color"); } helper.buildUIAndRunTest(mySwitch, testAction); }; } export function test_set_TNS_checked_updates_native_checked() { var mySwitch = new switchModule.Switch(); function testAction(views: Array) { // >> article-setting-checked-property mySwitch.checked = true; // << article-setting-checked-property TKUnit.assertEqual(getNativeValue(mySwitch), true, "Native checked is different from TNS checked."); } helper.buildUIAndRunTest(mySwitch, testAction); } export function test_set_native_checked_updates_TNS_checked() { var mySwitch = new switchModule.Switch(); function testAction(views: Array) { setNativeValue(mySwitch, true); TKUnit.assertEqual(mySwitch.checked, true, "Native checked is different from TNS checked."); } helper.buildUIAndRunTest(mySwitch, testAction); } export function test_set_native_checked_triggers_propertyChanged() { var mySwitch = new switchModule.Switch(); function testAction(views: Array) { var checkedChanged = false; var allChanges = 0; mySwitch.on("checkedChange", function (data: observable.EventData) { allChanges++; var propertyData = data; if (propertyData && propertyData.propertyName === "checked" && propertyData.value === true) { checkedChanged = true; } }); setNativeValue(mySwitch, true); mySwitch.off("checkedChange"); TKUnit.assert(checkedChanged, "Property changed for checked not called."); TKUnit.assertEqual(allChanges, 1, "Property changed callbacks."); } helper.buildUIAndRunTest(mySwitch, testAction); } export function test_binding_value_to_model() { var mySwitch = new switchModule.Switch(); function testAction(views: Array) { // >> aricle-binding-checked-property var model = new observable.Observable(); model.set("enabled", true); var options: bindable.BindingOptions = { sourceProperty: "enabled", targetProperty: "checked" }; mySwitch.bind(options, model); // mySwitch.checked is now true // >> (hide) TKUnit.assertEqual(mySwitch.checked, true, "mySwitch.checked"); // << (hide) model.set("enabled", false); // mySwitch.checked is now false // >> (hide) TKUnit.assertEqual(mySwitch.checked, false, "mySwitch.checked"); // << (hide) // << aricle-binding-checked-property } helper.buildUIAndRunTest(mySwitch, testAction); } function getNativeValue(mySwitch: switchModule.Switch): boolean { if (platform.isAndroid) { const nativeView: android.widget.Switch = mySwitch.nativeViewProtected; return nativeView.isChecked(); } else if (mySwitch.ios) { return mySwitch.ios.on; } } function setNativeValue(mySwitch: switchModule.Switch, value: boolean) { if (platform.isAndroid) { const nativeView: android.widget.Switch = mySwitch.nativeViewProtected; nativeView.setChecked(value); } else if (mySwitch.ios) { mySwitch.ios.on = value; // setting value trough code does not send notification, so simulate that manually. mySwitch.ios.sendActionsForControlEvents(UIControlEvents.ValueChanged); } }