есть функция:
function delay<T, A extends any[]>(fn: (...args: A) => T, t: number) : (...args:A) => Promise<T> {
return (...args) => new Promise(resolve => setTimeout(resolve(fn(...args)), t))
}
то есть принимает функцию, возвращает другую с теми же аргументами, но результат обернут в промис, который резолвится по таймауту. с этим я справился, типы вроде везде сохраняются.
теперь я хочу сделать вот это:
function delayAll(fns, t:number) {
const res = {}
Object.keys(fns).forEach(k => {
res[k] = delay(fns[k], t)
})
return res;
}
то есть получаем объект {ключ: функция}, возвращаем объект с теми же ключами, но все функции пропущены через delay
вопрос: как сделать, чтобы для результирующего объекта типы тоже сохранились?
Что-то типа такого? function delayAll<T extends Object, K extends keyof T>(all: T): { [key in K]: T[K] } { // ... }
Обсуждают сегодня