Standard timers - fix for #4384 (#4389)

Specifications define timers capable of accepting optional parameters.
https://www.w3.org/TR/2011/WD-html5-20110525/timers.html#timers

This PR goal is to standardize such behavior in NativeScript too.
This commit is contained in:
Andrea Giammarchi
2017-06-15 21:19:49 +01:00
committed by Alexander Vakrilov
parent 9866350559
commit 7e39bfb9d4
4 changed files with 51 additions and 10 deletions

View File

@@ -14,9 +14,10 @@ function createHandlerAndGetId(): number {
return timerId;
}
export function setTimeout(callback: Function, milliseconds = 0): number {
export function setTimeout(callback: Function, milliseconds = 0, ...args): number {
const id = createHandlerAndGetId();
const zoneBound = zonedCallback(callback);
const invoke = () => callback(...args);
const zoneBound = zonedCallback(invoke);
var runnable = new java.lang.Runnable({
run: () => {
@@ -45,10 +46,11 @@ export function clearTimeout(id: number): void {
}
}
export function setInterval(callback: Function, milliseconds = 0): number {
export function setInterval(callback: Function, milliseconds = 0, ...args): number {
const id = createHandlerAndGetId();
const handler = timeoutHandler;
const zoneBound = zonedCallback(callback);
const invoke = () => callback(...args);
const zoneBound = zonedCallback(invoke);
var runnable = new java.lang.Runnable({
run: () => {

View File

@@ -7,8 +7,9 @@
* Calls a function after a specified delay.
* @param callback The function to be called.
* @param milliseconds The time to wait before the function is called. Defaults to 0.
* @param args One or more parameter to use once the function is called. Defaults to no parameters.
*/
export function setTimeout(callback: Function, milliseconds?: number): number;
export function setTimeout(callback: Function, milliseconds?: number, ...args: any[]): number;
/**
* Clears the delay set by a call to the setTimeout function.
@@ -20,8 +21,9 @@ export function clearTimeout(id: number): void;
* Calls a function repeatedly with a delay between each call.
* @param callback The function to be called.
* @param milliseconds The delay between each function call.
* @param args One or more parameter to use once the function is called. Defaults to no parameters.
*/
export function setInterval(callback: Function, milliseconds?: number): number;
export function setInterval(callback: Function, milliseconds?: number, ...args: any[]): number;
/**
* Clears repeated function which was set up by calling setInterval().

View File

@@ -63,8 +63,9 @@ function createTimerAndGetId(callback: Function, milliseconds: number, shouldRep
return id;
}
export function setTimeout(callback: Function, milliseconds = 0): number {
return createTimerAndGetId(zonedCallback(callback), milliseconds, false);
export function setTimeout(callback: Function, milliseconds = 0, ...args): number {
let invoke = () => callback(...args);
return createTimerAndGetId(zonedCallback(invoke), milliseconds, false);
}
export function clearTimeout(id: number): void {
@@ -74,8 +75,9 @@ export function clearTimeout(id: number): void {
}
}
export function setInterval(callback: Function, milliseconds = 0): number {
return createTimerAndGetId(zonedCallback(callback), milliseconds, true);
export function setInterval(callback: Function, milliseconds = 0, ...args): number {
let invoke = () => callback(...args);
return createTimerAndGetId(zonedCallback(invoke), milliseconds, true);
}
export var clearInterval = clearTimeout;