(target, promise)
| 1 | import { lazy } from 'react'; |
| 2 | |
| 3 | export const asyncDecorator = (target, promise) => { |
| 4 | let resolve; |
| 5 | const isReady = new Promise(r => { |
| 6 | resolve = r; |
| 7 | }); |
| 8 | |
| 9 | const state = { |
| 10 | isReady, |
| 11 | get: lazy(() => { |
| 12 | return Promise.resolve(promise()).then(res => { |
| 13 | setTimeout(async () => { |
| 14 | await resolve(true); |
| 15 | state.isReady = true; |
| 16 | }, 0); |
| 17 | |
| 18 | return res; |
| 19 | }); |
| 20 | }), |
| 21 | }; |
| 22 | |
| 23 | Object.defineProperty(target, '_dashprivate_isLazyComponentReady', { |
| 24 | get: () => state.isReady |
| 25 | }); |
| 26 | |
| 27 | return state.get; |
| 28 | }; |
| 29 | |
| 30 | export const inheritAsyncDecorator = (target, source) => { |
| 31 | Object.defineProperty(target, '_dashprivate_isLazyComponentReady', { |
no test coverage detected
searching dependent graphs…