mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-11-05 13:26:48 +08:00
163 lines
5.2 KiB
TypeScript
163 lines
5.2 KiB
TypeScript
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 { Color, Observable, PropertyChangeData, EventData } from '@nativescript/core';
|
|
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();
|
|
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<viewModule.View>) {
|
|
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 (__APPLE__) {
|
|
exports.test_set_color = function () {
|
|
var mySwitch = new switchModule.Switch();
|
|
mySwitch.color = new Color('red');
|
|
|
|
function testAction(views: Array<viewModule.View>) {
|
|
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('red');
|
|
|
|
function testAction(views: Array<viewModule.View>) {
|
|
TKUnit.assert(CGColorEqualToColor((<Color>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<viewModule.View>) {
|
|
// >> 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<viewModule.View>) {
|
|
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<viewModule.View>) {
|
|
var checkedChanged = false;
|
|
var allChanges = 0;
|
|
mySwitch.on('checkedChange', function (data: EventData) {
|
|
allChanges++;
|
|
var propertyData = <PropertyChangeData>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<viewModule.View>) {
|
|
// >> aricle-binding-checked-property
|
|
var model = new 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);
|
|
}
|
|
}
|