import TKUnit = require("../../TKUnit");
import helper = require("../helper");
import viewModule = require("ui/core/view");
import bindable = require("ui/core/bindable");
import observable = require("data/observable");
//
// # Switch
// Using a switch requires the Switch module.
// ``` JavaScript
import switchModule = require("ui/switch");
// ```
// ### Binding the Switch checked property and Button isEanbled property to a observable view-model property.
//```XML
//
//
// {%raw%}
// {%endraw%}
//
//
//```
//```JS
// function pageLoaded(args) {
// var page = args.object;
// var obj = new observable.Observable();
// obj.set("someProperty", false);
// page.bindingContext = obj;
// }
// exports.pageLoaded = pageLoaded;
//```
//
export function test_default_TNS_values() {
//
// ### Creating a switch
// ``` JavaScript
var mySwitch = new switchModule.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);
}
export function test_set_TNS_checked_updates_native_checked() {
var mySwitch = new switchModule.Switch();
function testAction(views: Array) {
//
// ### Setting the checked property of a switch
// ``` JavaScript
mySwitch.checked = true;
// ```
//
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(observable.knownEvents.propertyChange, function (data: observable.EventData) {
allChanges++;
var propertyData = data;
if (propertyData && propertyData.propertyName === "checked" && propertyData.value === true) {
checkedChanged = true;
}
});
setNativeValue(mySwitch, true);
mySwitch.off(observable.knownEvents.propertyChange);
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) {
//
// ### Binding checked property to a model
// ``` JavaScript
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
//
TKUnit.assertEqual(mySwitch.checked, true, "mySwitch.checked");
//
model.set("enabled", false);
//// mySwitch.checked is now false
//
TKUnit.assertEqual(mySwitch.checked, false, "mySwitch.checked");
//
// ```
//
}
helper.buildUIAndRunTest(mySwitch, testAction);
}
function getNativeValue(mySwitch: switchModule.Switch): boolean {
if (mySwitch.android) {
return mySwitch.android.isChecked();
}
else if (mySwitch.ios) {
return mySwitch.ios.on;
}
}
function setNativeValue(mySwitch: switchModule.Switch, value: boolean) {
if (mySwitch.android) {
mySwitch.android.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.UIControlEventValueChanged);
}
}