mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-16 11:42:04 +08:00

* chore: move tns-core-modules to nativescript-core * chore: preparing compat generate script * chore: add missing definitions * chore: no need for http-request to be private * chore: packages chore * test: generate tests for tns-core-modules * chore: add anroid module for consistency * chore: add .npmignore * chore: added privateModulesWhitelist * chore(webpack): added bundle-entry-points * chore: scripts * chore: tests changed to use @ns/core * test: add scoped-packages test project * test: fix types * test: update test project * chore: build scripts * chore: update build script * chore: npm scripts cleanup * chore: make the compat pgk work with old wp config * test: generate diff friendly tests * chore: create barrel exports * chore: move files after rebase * chore: typedoc config * chore: compat mode * chore: review of barrels * chore: remove tns-core-modules import after rebase * chore: dev workflow setup * chore: update developer-workflow * docs: experiment with API extractor * chore: api-extractor and barrel exports * chore: api-extractor configs * chore: generate d.ts rollup with api-extractor * refactor: move methods inside Frame * chore: fic tests to use Frame static methods * refactor: create Builder class * refactor: use Builder class in tests * refactor: include Style in ui barrel * chore: separate compat build script * chore: fix tslint errors * chore: update NATIVESCRIPT_CORE_ARGS * chore: fix compat pack * chore: fix ui-test-app build with linked modules * chore: Application, ApplicationSettings, Connectivity and Http * chore: export Trace, Profiling and Utils * refactor: Static create methods for ImageSource * chore: fix deprecated usages of ImageSource * chore: move Span and FormattedString to ui * chore: add events-args and ImageSource to index files * chore: check for CLI >= 6.2 when building for IOS * chore: update travis build * chore: copy Pod file to compat package * chore: update error msg ui-tests-app * refactor: Apply suggestions from code review Co-Authored-By: Martin Yankov <m.i.yankov@gmail.com> * chore: typings and refs * chore: add missing d.ts files for public API * chore: adress code review FB * chore: update api-report * chore: dev-workflow for other apps * chore: api update * chore: update api-report
165 lines
5.8 KiB
TypeScript
165 lines
5.8 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 * 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<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 (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<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.Color("red");
|
|
|
|
function testAction(views: Array<viewModule.View>) {
|
|
TKUnit.assert(CGColorEqualToColor((<color.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: observable.EventData) {
|
|
allChanges++;
|
|
var propertyData = <observable.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.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);
|
|
}
|
|
}
|