есть функция:
                  
                  
                  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] } { // ... }
Обсуждают сегодня