@warp-drive-mirror/ember 5.4.0-alpha.151 → 5.4.0-alpha.153

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -674,6 +674,7 @@ function getPromiseState(promise) {
674
674
  /**
675
675
  * @module @warp-drive-mirror/ember
676
676
  */
677
+
677
678
  const and = (x, y) => Boolean(x && y);
678
679
  /**
679
680
  * The `<Throw />` component is used to throw an error in a template.
@@ -761,6 +762,7 @@ class Await extends Component {
761
762
  /**
762
763
  * @module @warp-drive-mirror/ember
763
764
  */
765
+
764
766
  function notNull(x) {
765
767
  macroCondition(getGlobalConfig().WarpDriveMirror.env.DEBUG) ? (test => {
766
768
  if (!test) {
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../node_modules/.pnpm/decorat_e3cbd74f60cbc6601d9238bdf69fcbb4/node_modules/decorator-transforms/dist/runtime-BPCpkOf1.js","../src/-private/request-state.ts","../src/-private/promise-state.ts","../src/-private/await.gts","../src/-private/request.gts"],"sourcesContent":["const deferred = /* @__PURE__ */ new WeakMap();\nfunction deferDecorator(proto, prop, desc) {\n let map = deferred.get(proto);\n if (!map) {\n map = /* @__PURE__ */ new Map();\n deferred.set(proto, map);\n }\n map.set(prop, desc);\n}\nfunction findDeferredDecorator(target, prop) {\n var _a;\n let cursor = target.prototype;\n while (cursor) {\n let desc = (_a = deferred.get(cursor)) == null ? void 0 : _a.get(prop);\n if (desc) {\n return desc;\n }\n cursor = cursor.prototype;\n }\n}\nfunction decorateFieldV1(target, prop, decorators, initializer) {\n return decorateFieldV2(target.prototype, prop, decorators, initializer);\n}\nfunction decorateFieldV2(prototype, prop, decorators, initializer) {\n let desc = {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n };\n if (initializer) {\n desc.initializer = initializer;\n }\n for (let decorator of decorators) {\n desc = decorator(prototype, prop, desc) || desc;\n }\n if (desc.initializer === void 0) {\n Object.defineProperty(prototype, prop, desc);\n } else {\n deferDecorator(prototype, prop, desc);\n }\n}\nfunction decorateMethodV1({ prototype }, prop, decorators) {\n return decorateMethodV2(prototype, prop, decorators);\n}\nfunction decorateMethodV2(prototype, prop, decorators) {\n const origDesc = Object.getOwnPropertyDescriptor(prototype, prop);\n let desc = { ...origDesc };\n for (let decorator of decorators) {\n desc = decorator(prototype, prop, desc) || desc;\n }\n if (desc.initializer !== void 0) {\n desc.value = desc.initializer ? desc.initializer.call(prototype) : void 0;\n desc.initializer = void 0;\n }\n Object.defineProperty(prototype, prop, desc);\n}\nfunction initializeDeferredDecorator(target, prop) {\n let desc = findDeferredDecorator(target.constructor, prop);\n if (desc) {\n Object.defineProperty(target, prop, {\n enumerable: desc.enumerable,\n configurable: desc.configurable,\n writable: desc.writable,\n value: desc.initializer ? desc.initializer.call(target) : void 0\n });\n }\n}\nfunction decorateClass(target, decorators) {\n return decorators.reduce(\n (accum, decorator) => decorator(accum) || accum,\n target\n );\n}\nfunction decoratePOJO(pojo, decorated) {\n for (let [type, prop, decorators] of decorated) {\n if (type === \"field\") {\n decoratePojoField(pojo, prop, decorators);\n } else {\n decorateMethodV2(pojo, prop, decorators);\n }\n }\n return pojo;\n}\nfunction decoratePojoField(pojo, prop, decorators) {\n let desc = {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: () => {\n var _a;\n return (_a = Object.getOwnPropertyDescriptor(pojo, prop)) == null ? void 0 : _a.value;\n }\n };\n for (let decorator of decorators) {\n desc = decorator(pojo, prop, desc) || desc;\n }\n if (desc.initializer) {\n desc.value = desc.initializer.call(pojo);\n delete desc.initializer;\n }\n Object.defineProperty(pojo, prop, desc);\n}\nconst runtime = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n c: decorateClass,\n f: decorateFieldV1,\n g: decorateFieldV2,\n i: initializeDeferredDecorator,\n m: decorateMethodV1,\n n: decorateMethodV2,\n p: decoratePOJO\n}, Symbol.toStringTag, { value: \"Module\" }));\nexport {\n decorateFieldV2 as a,\n decorateMethodV1 as b,\n decorateMethodV2 as c,\n decorateFieldV1 as d,\n decorateClass as e,\n decoratePOJO as f,\n initializeDeferredDecorator as i,\n runtime as r\n};\n//# sourceMappingURL=runtime-BPCpkOf1.js.map\n","/**\n * @module @warp-drive-mirror/ember\n */\nimport { tracked } from '@glimmer/tracking';\n\nimport type {\n Future,\n ImmutableRequestInfo,\n ResponseInfo,\n StructuredDocument,\n StructuredErrorDocument,\n} from '@ember-data-mirror/request';\nimport { getPromiseResult, setPromiseResult } from '@ember-data-mirror/request';\n\nconst RequestCache = new WeakMap<Future<unknown>, RequestState>();\n\nfunction isAbortError(error: unknown): boolean {\n return error instanceof DOMException && error.name === 'AbortError';\n}\n\nasync function watchStream(stream: ReadableStream<Uint8Array>, state: RequestLoadingState): Promise<void> {\n const reader = stream.getReader();\n let bytesLoaded = 0;\n let shouldForward = state._stream !== null && state._stream.readable.locked;\n let isForwarding = shouldForward;\n let writer = state._stream?.writable.getWriter();\n const buffer = [];\n\n state._isPending = false;\n state._isStarted = true;\n state._startTime = performance.now();\n\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n break;\n }\n bytesLoaded += value.byteLength;\n state._bytesLoaded = bytesLoaded;\n state._lastPacketTime = performance.now();\n\n shouldForward = shouldForward || (state._stream !== null && state._stream.readable.locked);\n\n if (shouldForward) {\n if (!isForwarding) {\n isForwarding = true;\n writer = state._stream!.writable.getWriter();\n for (const item of buffer) {\n await writer.ready;\n await writer.write(item);\n }\n buffer.length = 0;\n }\n await writer!.ready;\n await writer!.write(value);\n } else {\n buffer.push(value);\n }\n }\n\n // if we are still forwarding, we need to close the writer\n if (isForwarding) {\n await writer!.ready;\n await writer!.close();\n } else if (state._stream) {\n // if we are not forwarding, we need to cancel the stream\n await state._stream.readable.cancel('The Stream Has Already Ended');\n state._stream = null;\n }\n\n const endTime = performance.now();\n state._endTime = endTime;\n state._isComplete = true;\n state._isStarted = false;\n}\n\n/**\n * Lazily consumes the stream of a request, providing a number of\n * reactive properties that can be used to build UIs that respond\n * to the progress of a request.\n *\n * @class RequestLoadingState\n * @public\n */\nexport class RequestLoadingState {\n _stream: TransformStream | null = null;\n _future: Future<unknown>;\n _triggered = false;\n _trigger() {\n if (this._triggered) {\n return;\n }\n this._triggered = true;\n const future = this._future;\n const promise: Promise<ReadableStream<Uint8Array> | null> & { sizeHint?: number } = future.getStream();\n if (promise.sizeHint) {\n this._sizeHint = promise.sizeHint;\n }\n this.promise = promise.then(\n (stream) => {\n if (!stream) {\n this._isPending = false;\n this._isComplete = true;\n return;\n }\n return watchStream(stream, this);\n },\n (error: Error) => {\n this._isPending = false;\n this._isStarted = false;\n if (isAbortError(error)) {\n this._isCancelled = true;\n this._isComplete = true;\n }\n this._isErrored = true;\n this._error = error;\n }\n );\n }\n\n promise: Promise<void> | null = null;\n @tracked _sizeHint = 0;\n @tracked _bytesLoaded = 0;\n\n @tracked _startTime = 0;\n @tracked _endTime = 0;\n @tracked _lastPacketTime = 0;\n\n @tracked _isPending = true;\n @tracked _isStarted = false;\n @tracked _isComplete = false;\n @tracked _isCancelled = false;\n @tracked _isErrored = false;\n @tracked _error: Error | null = null;\n\n get isPending(): boolean {\n this._trigger();\n return this._isPending;\n }\n\n get sizeHint(): number {\n this._trigger();\n return this._sizeHint;\n }\n\n get stream(): ReadableStream | null {\n this._trigger();\n if (!this._stream) {\n if (this._isComplete || this._isCancelled || this._isErrored) {\n return null;\n }\n this._stream = new TransformStream();\n }\n return this._stream.readable;\n }\n\n get isStarted(): boolean {\n this._trigger();\n return this._isStarted;\n }\n\n get bytesLoaded(): number {\n this._trigger();\n return this._bytesLoaded;\n }\n\n get startTime(): number {\n this._trigger();\n return this._startTime;\n }\n\n get endTime(): number {\n this._trigger();\n return this._endTime;\n }\n\n get lastPacketTime(): number {\n this._trigger();\n return this._lastPacketTime;\n }\n\n get isComplete(): boolean {\n this._trigger();\n return this._isComplete;\n }\n\n get isCancelled(): boolean {\n this._trigger();\n return this._isCancelled;\n }\n\n get isErrored(): boolean {\n this._trigger();\n return this._isErrored;\n }\n\n get error(): Error | null {\n this._trigger();\n return this._error;\n }\n\n get elapsedTime(): number {\n return (this.endTime || this.lastPacketTime) - this.startTime;\n }\n\n get completedRatio(): number {\n return this.sizeHint ? this.bytesLoaded / this.sizeHint : 0;\n }\n\n get remainingRatio(): number {\n return 1 - this.completedRatio;\n }\n\n get duration(): number {\n return this.endTime - this.startTime;\n }\n\n get speed(): number {\n // bytes per second\n return this.bytesLoaded / (this.elapsedTime / 1000);\n }\n\n constructor(future: Future<unknown>) {\n this._future = future;\n }\n\n abort = (): void => {\n this._future.abort();\n };\n}\n\n/**\n * RequestState extends the concept of PromiseState to provide a reactive\n * wrapper for a request `Future` which allows you write declarative code\n * around a Future's control flow.\n *\n * It is useful in both Template and JavaScript contexts, allowing you\n * to quickly derive behaviors and data from pending, error and success\n * states.\n *\n * The key difference between a Promise and a Future is that Futures provide\n * access to a stream of their content, the identity of the request (if any)\n * as well as the ability to attempt to abort the request.\n *\n * ```ts\n * interface Future<T> extends Promise<T>> {\n * getStream(): Promise<ReadableStream>;\n * abort(): void;\n * lid: StableDocumentIdentifier | null;\n * }\n * ```\n *\n * These additional APIs allow us to craft even richer state experiences.\n *\n * To get the state of a request, use `getRequestState`.\n *\n * @class RequestState\n * @public\n */\nexport class RequestState<T = unknown, RT = unknown> {\n #request: Future<RT>;\n #loadingState: RequestLoadingState | null = null;\n\n @tracked result: RT | null = null;\n @tracked error: StructuredErrorDocument | null = null;\n @tracked isLoading = true;\n @tracked isSuccess = false;\n @tracked isError = false;\n @tracked request: ImmutableRequestInfo<T, RT> | null = null;\n @tracked response: Response | ResponseInfo | null = null;\n\n get isCancelled(): boolean {\n return this.isError && isAbortError(this.error);\n }\n\n get loadingState() {\n if (!this.#loadingState) {\n this.#loadingState = new RequestLoadingState(this.#request);\n }\n\n return this.#loadingState;\n }\n\n constructor(future: Future<RT>) {\n this.#request = future;\n const state = getPromiseResult<StructuredDocument<RT>, StructuredErrorDocument>(future);\n\n if (state) {\n this.request = state.result.request as ImmutableRequestInfo<T, RT>;\n this.response = state.result.response;\n this.isLoading = false;\n\n if (state.isError) {\n this.error = state.result;\n this.isError = true;\n } else {\n this.result = state.result.content!;\n this.isSuccess = true;\n }\n } else {\n void future.then(\n (result) => {\n setPromiseResult(future, { isError: false, result });\n this.result = result.content;\n this.isSuccess = true;\n this.isLoading = false;\n this.request = result.request as ImmutableRequestInfo<T, RT>;\n this.response = result.response;\n },\n (error: StructuredErrorDocument) => {\n setPromiseResult(future, { isError: true, result: error });\n this.error = error;\n this.isError = true;\n this.isLoading = false;\n this.request = error.request as ImmutableRequestInfo<T, RT>;\n this.response = error.response;\n }\n );\n }\n }\n}\n\n/**\n *\n *\n * `getRequestState` can be used in both JavaScript and Template contexts.\n *\n * ```ts\n * import { getRequestState } from '@warp-drive-mirror/ember';\n *\n * const state = getRequestState(future);\n * ```\n *\n * For instance, we could write a getter on a component that updates whenever\n * the request state advances or the future changes, by combining the function\n * with the use of `@cached`\n *\n * ```ts\n * class Component {\n * @cached\n * get title() {\n * const state = getRequestState(this.args.request);\n * if (state.isPending) {\n * return 'loading...';\n * }\n * if (state.isError) { return null; }\n * return state.result.title;\n * }\n * }\n * ```\n *\n * Or in a template as a helper:\n *\n * ```gjs\n * import { getRequestState } from '@warp-drive-mirror/ember';\n *\n * <template>\n * {{#let (getRequestState @request) as |state|}}\n * {{#if state.isPending}}\n * <Spinner />\n * {{else if state.isError}}\n * <ErrorForm @error={{state.error}} />\n * {{else}}\n * <h1>{{state.result.title}}</h1>\n * {{/if}}\n * {{/let}}\n * </template>\n * ```\n *\n * If looking to use in a template, consider also the `<Request />` component\n * which offers a numbe of additional capabilities for requests *beyond* what\n * `RequestState` provides.\n *\n * @method getRequestState\n * @for @warp-drive-mirror/ember\n * @static\n * @public\n * @param future\n * @return {RequestState}\n */\nexport function getRequestState<RT, T>(future: Future<RT>): RequestState<T, RT> {\n let state = RequestCache.get(future) as RequestState<T, RT> | undefined;\n\n if (!state) {\n state = new RequestState(future);\n RequestCache.set(future, state);\n }\n\n return state;\n}\n","/**\n * @module @warp-drive-mirror/ember\n */\nimport { tracked } from '@glimmer/tracking';\n\nimport type { Awaitable } from '@ember-data-mirror/request';\nimport { getPromiseResult, setPromiseResult } from '@ember-data-mirror/request';\n\nconst PromiseCache = new WeakMap<Awaitable, PromiseState>();\n\n/**\n * PromiseState provides a reactive wrapper for a promise which allows you write declarative\n * code around a promise's control flow. It is useful in both Template and JavaScript contexts,\n * allowing you to quickly derive behaviors and data from pending, error and success states.\n *\n * ```ts\n * interface PromiseState<T = unknown, E = unknown> {\n * isPending: boolean;\n * isSuccess: boolean;\n * isError: boolean;\n * result: T | null;\n * error: E | null;\n * }\n * ```\n *\n * To get the state of a promise, use `getPromiseState`.\n *\n * @class PromiseState\n * @public\n */\nexport class PromiseState<T = unknown, E = unknown> {\n @tracked result: T | null = null;\n @tracked error: E | null = null;\n @tracked isPending = true;\n @tracked isSuccess = false;\n @tracked isError = false;\n\n constructor(promise: Promise<T> | Awaitable<T, E>) {\n const state = getPromiseResult<T, E>(promise);\n\n if (state) {\n if (state.isError) {\n this.error = state.result;\n this.isError = true;\n this.isPending = false;\n } else {\n this.result = state.result;\n this.isSuccess = true;\n this.isPending = false;\n }\n } else {\n void promise.then(\n (result) => {\n setPromiseResult(promise, { isError: false, result });\n this.result = result;\n this.isSuccess = true;\n this.isPending = false;\n },\n (error: E) => {\n setPromiseResult(promise, { isError: true, result: error });\n this.error = error;\n this.isError = true;\n this.isPending = false;\n }\n );\n }\n }\n}\n\nconst LegacyPromiseProxy = Symbol.for('LegacyPromiseProxy');\ntype LegacyAwaitable<T, E> = { promise: Promise<T> | Awaitable<T, E>; [LegacyPromiseProxy]: true };\n\nfunction isLegacyAwaitable<T, E>(promise: object): promise is LegacyAwaitable<T, E> {\n return LegacyPromiseProxy in promise && 'promise' in promise && promise[LegacyPromiseProxy] === true;\n}\n\nfunction getPromise<T, E>(promise: Promise<T> | Awaitable<T, E> | LegacyAwaitable<T, E>): Promise<T> | Awaitable<T, E> {\n return isLegacyAwaitable(promise) ? promise.promise : promise;\n}\n\n/**\n * Returns a reactive state-machine for the provided promise or awaitable.\n *\n * Repeat calls to `getPromiseState` with the same promise will return the same state object\n * making is safe and easy to use in templates and JavaScript code to produce reactive\n * behaviors around promises.\n *\n * `getPromiseState` can be used in both JavaScript and Template contexts.\n *\n * ```ts\n * import { getPromiseState } from '@warp-drive-mirror/ember';\n *\n * const state = getPromiseState(promise);\n * ```\n *\n * For instance, we could write a getter on a component that updates whenever\n * the promise state advances or the promise changes, by combining the function\n * with the use of `@cached`\n *\n * ```ts\n * class Component {\n * @cached\n * get title() {\n * const state = getPromiseState(this.args.request);\n * if (state.isPending) {\n * return 'loading...';\n * }\n * if (state.isError) { return null; }\n * return state.result.title;\n * }\n * }\n * ```\n *\n * Or in a template as a helper:\n *\n * ```gjs\n * import { getPromiseState } from '@warp-drive-mirror/ember';\n *\n * <template>\n * {{#let (getPromiseState @request) as |state|}}\n * {{#if state.isPending}} <Spinner />\n * {{else if state.isError}} <ErrorForm @error={{state.error}} />\n * {{else}}\n * <h1>{{state.result.title}}</h1>\n * {{/if}}\n * {{/let}}\n * </template>\n * ```\n *\n * If looking to use in a template, consider also the `<Await />` component.\n *\n * @method getPromiseState\n * @for @warp-drive-mirror/ember\n * @static\n * @public\n * @param {Promise<T> | Awaitable<T, E>} promise\n * @return {PromiseState<T, E>}\n */\nexport function getPromiseState<T = unknown, E = unknown>(promise: Promise<T> | Awaitable<T, E>): PromiseState<T, E> {\n const _promise = getPromise(promise);\n let state = PromiseCache.get(_promise) as PromiseState<T, E> | undefined;\n\n if (!state) {\n state = new PromiseState(_promise);\n PromiseCache.set(_promise, state);\n }\n\n return state;\n}\n","/**\n * @module @warp-drive-mirror/ember\n */\nimport Component from '@glimmer/component';\n\nimport type { Awaitable } from '@ember-data-mirror/request';\n\nimport { getPromiseState } from './promise-state.ts';\n\nexport const and = (x: unknown, y: unknown) => Boolean(x && y);\ninterface ThrowSignature<E = Error | string | object> {\n Args: {\n error: E;\n };\n}\n\n/**\n * The `<Throw />` component is used to throw an error in a template.\n *\n * That's all it does. So don't use it unless the application should\n * throw an error if it reaches this point in the template.\n *\n * ```hbs\n * <Throw @error={{anError}} />\n * ```\n *\n * @class <Throw />\n * @public\n */\nexport class Throw<T> extends Component<ThrowSignature<T>> {\n constructor(owner: unknown, args: ThrowSignature<T>['Args']) {\n super(owner, args);\n // this error is opaque (user supplied) so we don't validate it\n // as an Error instance.\n // eslint-disable-next-line @typescript-eslint/no-throw-literal\n throw this.args.error;\n }\n <template></template>\n}\n\ninterface AwaitSignature<T, E = Error | string | object> {\n Args: {\n promise: Promise<T> | Awaitable<T, E>;\n };\n Blocks: {\n pending: [];\n error: [error: E];\n success: [value: T];\n };\n}\n\n/**\n * The <Await /> component allow you to utilize reactive control flow\n * for asynchronous states in your application.\n *\n * Await is ideal for handling \"boundaries\", outside which some state is\n * still allowed to be unresolved and within which it MUST be resolved.\n *\n * ```gjs\n * import { Await } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Await @promise={{@request}}>\n * <:pending>\n * <Spinner />\n * </:pending>\n *\n * <:error as |error|>\n * <ErrorForm @error={{error}} />\n * </:error>\n *\n * <:success as |result|>\n * <h1>{{result.title}}</h1>\n * </:success>\n * </Await>\n * </template>\n * ```\n *\n * The <Await /> component requires that error states are properly handled.\n *\n * If no error block is provided and the promise rejects, the error will\n * be thrown.\n *\n * @class <Await />\n * @public\n */\nexport class Await<T, E> extends Component<AwaitSignature<T, E>> {\n get state() {\n return getPromiseState<T, E>(this.args.promise);\n }\n\n get error() {\n return this.state.error as E;\n }\n\n get result() {\n return this.state.result as T;\n }\n\n <template>\n {{#if this.state.isPending}}\n {{yield to=\"pending\"}}\n {{else if (and this.state.isError (has-block \"error\"))}}\n {{yield this.error to=\"error\"}}\n {{else if this.state.isSuccess}}\n {{yield this.result to=\"success\"}}\n {{else}}\n <Throw @error={{this.error}} />\n {{/if}}\n </template>\n}\n","/**\n * @module @warp-drive-mirror/ember\n */\nimport { service } from '@ember/service';\nimport Component from '@glimmer/component';\nimport { cached, tracked } from '@glimmer/tracking';\n\nimport { importSync, macroCondition, moduleExists } from '@embroider/macros';\n\nimport type { Future, StructuredErrorDocument } from '@ember-data-mirror/request';\nimport type { StoreRequestInput } from '@ember-data-mirror/store';\nimport type Store from '@ember-data-mirror/store';\nimport { assert } from '@warp-drive-mirror/build-config/macros';\nimport type { StableDocumentIdentifier } from '@warp-drive-mirror/core-types/identifier.js';\nimport { EnableHydration, type RequestInfo } from '@warp-drive-mirror/core-types/request';\n\nimport { and, Throw } from './await.gts';\nimport type { RequestLoadingState, RequestState } from './request-state.ts';\nimport { getRequestState } from './request-state.ts';\n\nfunction notNull(x: null): never;\nfunction notNull<T>(x: T): Exclude<T, null>;\nfunction notNull<T>(x: T | null) {\n assert('Expected a non-null value, but got null', x !== null);\n return x;\n}\n\nconst not = (x: unknown) => !x;\n// default to 30 seconds unavailable before we refresh\nconst DEFAULT_DEADLINE = 30_000;\nconst IdleBlockMissingError = new Error(\n 'No idle block provided for <Request> component, and no query or request was provided.'\n);\n\nlet consume = service;\nif (macroCondition(moduleExists('ember-provide-consume-context'))) {\n const { consume: contextConsume } = importSync('ember-provide-consume-context') as { consume: typeof service };\n consume = contextConsume;\n}\n\nfunction isNeverString(val: never): string {\n return val;\n}\n\ntype AutorefreshBehaviorType = 'online' | 'interval' | 'invalid';\ntype AutorefreshBehaviorCombos =\n | boolean\n | AutorefreshBehaviorType\n | `${AutorefreshBehaviorType},${AutorefreshBehaviorType}`\n | `${AutorefreshBehaviorType},${AutorefreshBehaviorType},${AutorefreshBehaviorType}`;\n\ntype ContentFeatures<RT> = {\n isOnline: boolean;\n isHidden: boolean;\n isRefreshing: boolean;\n refresh: () => Promise<void>;\n reload: () => Promise<void>;\n abort?: () => void;\n latestRequest?: Future<RT>;\n};\n\ninterface RequestSignature<T, RT> {\n Args: {\n /**\n * The request to monitor. This should be a `Future` instance returned\n * by either the `store.request` or `store.requestManager.request` methods.\n *\n * @typedoc\n */\n request?: Future<RT>;\n\n /**\n * A query to use for the request. This should be an object that can be\n * passed to `store.request`. Use this in place of `@request` if you would\n * like the component to also initiate the request.\n *\n * @typedoc\n */\n query?: StoreRequestInput<T, RT>;\n\n /**\n * The store instance to use for making requests. If contexts are available,\n * the component will default to using the `store` on the context.\n *\n * This is required if the store is not available via context or should be\n * different from the store provided via context.\n *\n * @typedoc\n */\n store?: Store;\n\n /**\n * The autorefresh behavior for the request. This can be a boolean, or any\n * combination of the following values: `'online'`, `'interval'`, `'invalid'`.\n *\n * - `'online'`: Refresh the request when the browser comes back online\n * - `'interval'`: Refresh the request at a specified interval\n * - `'invalid'`: Refresh the request when the store emits an invalidation\n *\n * If `true`, this is equivalent to `'online,invalid'`.\n *\n * Defaults to `false`.\n *\n * @typedoc\n */\n autorefresh?: AutorefreshBehaviorCombos;\n\n /**\n * The number of milliseconds to wait before refreshing the request when the\n * browser comes back online or the network becomes available.\n *\n * This also controls the interval at which the request will be refreshed if\n * the `interval` autorefresh type is enabled.\n *\n * Defaults to `30_000` (30 seconds).\n *\n * @typedoc\n */\n autorefreshThreshold?: number;\n\n /**\n * The behavior of the request initiated by autorefresh. This can be one of\n * the following values:\n *\n * - `'refresh'`: Refresh the request in the background\n * - `'reload'`: Force a reload of the request\n * - `'policy'` (**default**): Let the store's configured CachePolicy decide whether to\n * reload, refresh, or do nothing.\n *\n * Defaults to `'policy'`.\n *\n * @typedoc\n */\n autorefreshBehavior?: 'refresh' | 'reload' | 'policy';\n };\n Blocks: {\n /**\n * The block to render when the component is idle and waiting to be given a request.\n *\n * @typedoc\n */\n idle: [];\n\n /**\n * The block to render when the request is loading.\n *\n * @typedoc\n */\n loading: [state: RequestLoadingState];\n\n /**\n * The block to render when the request was cancelled.\n *\n * @typedoc\n */\n cancelled: [\n error: StructuredErrorDocument,\n features: { isOnline: boolean; isHidden: boolean; retry: () => Promise<void> },\n ];\n\n /**\n * The block to render when the request failed. If this block is not provided,\n * the error will be rethrown.\n *\n * Thus it is required to provide an error block and proper error handling if\n * you do not want the error to crash the application.\n *\n * @typedoc\n */\n error: [\n error: StructuredErrorDocument,\n features: { isOnline: boolean; isHidden: boolean; retry: () => Promise<void> },\n ];\n\n /**\n * The block to render when the request succeeded.\n *\n * @typedoc\n */\n content: [value: RT, features: ContentFeatures<RT>];\n always: [state: RequestState<T, RT>];\n };\n}\n\n/**\n * The `<Request />` component is a powerful tool for managing data fetching and\n * state in your Ember application. It provides a declarative approach to reactive\n * control-flow for managing requests and state in your application.\n *\n * The `<Request />` component is ideal for handling \"boundaries\", outside which some\n * state is still allowed to be unresolved and within which it MUST be resolved.\n *\n * ## Request States\n *\n * `<Request />` has five states, only one of which will be active and rendered at a time.\n *\n * - `idle`: The component is waiting to be given a request to monitor\n * - `loading`: The request is in progress\n * - `error`: The request failed\n * - `content`: The request succeeded\n * - `cancelled`: The request was cancelled\n *\n * Additionally, the `content` state has a `refresh` method that can be used to\n * refresh the request in the background, which is available as a sub-state of\n * the `content` state.\n *\n * As with the `<Await />` component, if no error block is provided and the request\n * rejects, the error will be thrown. Cancellation errors are swallowed instead of\n * rethrown if no error block or cancellation block is present.\n *\n * ```gts\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:loading as |state|>\n * <Spinner @percentDone={{state.completedRatio}} />\n * <button {{on \"click\" state.abort}}>Cancel</button>\n * </:loading>\n *\n * <:error as |error state|>\n * <ErrorForm @error={{error}} />\n * <button {{on \"click\" state.retry}}>Retry</button>\n * </:error>\n *\n * <:content as |data state|>\n * <h1>{{data.title}}</h1>\n * {{#if state.isBackgroundReloading}}\n * <SmallSpinner />\n * <button {{on \"click\" state.abort}}>Cancel</button>\n * {{else}}\n * <button {{on \"click\" state.refresh}}>Refresh</button>\n * {{/if}}\n * </:content>\n *\n * <:cancelled as |error state|>\n * <h2>The Request was cancelled</h2>\n * <button {{on \"click\" state.retry}}>Retry</button>\n * </:cancelled>\n *\n * <:idle>\n * <button {{on \"click\" @kickOffRequest}}>Load Preview?</button>\n * </:idle>\n *\n * </Request>\n * </template>\n * ```\n *\n * ## Streaming Data\n *\n * The loading state exposes the download `ReadableStream` instance for consumption\n *\n * ```gjs\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:loading as |state|>\n * <Video @stream={{state.stream}} />\n * </:loading>\n *\n * <:error as |error|>\n * <ErrorForm @error={{error}} />\n * </:error>\n * </Request>\n * </template>\n * ```\n *\n * ## Retry\n *\n * Cancelled and error'd requests may be retried by calling the `retry` method.\n *\n * Retry will restart the state progression, using the loading, error, cancelled,\n * and content blocks as appropriate.\n *\n * ## Reloading\n *\n * The `reload` method will force the request to be fully re-executed, bypassing\n * cache and restarting the state progression through the loading, error, and\n * content blocks as appropriate.\n *\n * Background reload (refresh) is a special substate of the content state that\n * allows you to refresh the request in the background. This is useful for when\n * you want to update the data in the background without blocking the UI.\n *\n * Reload and refresh are available as methods on the `content` state.\n *\n * ```gjs\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:content as |data state|>\n * <h1>{{data.title}}</h1>\n * {{#if state.isBackgroundReloading}}\n * <SmallSpinner />\n * <button {{on \"click\" state.abort}}>Cancel</button>\n * {{/if}}\n *\n * <button {{on \"click\" state.refresh}}>Refresh</button>\n * <button {{on \"click\" state.reload}}>Reload</button>\n * </:content>\n * </Request>\n * </template>\n * ```\n *\n * ## Advanced Reloading\n *\n * We can nest our usage of `<Request />` to handle more advanced\n * reloading scenarios.\n *\n * ```gjs\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:cancelled>\n * <h2>The Request Cancelled</h2>\n * </:cancelled>\n *\n * <:error as |error|>\n * <ErrorForm @error={{error}} />\n * </:error>\n *\n * <:content as |result state|>\n * <Request @request={{state.latestRequest}}>\n * <!-- Handle Background Request -->\n * </Request>\n *\n * <h1>{{result.title}}</h1>\n *\n * <button {{on \"click\" state.refresh}}>Refresh</button>\n * </:content>\n * </Request>\n * </template>\n * ```\n *\n * ## Autorefresh\n *\n * `<Request />` supports automatic refresh and reload under certain conditions.\n *\n * - `online`: This occurs when a browser window or tab comes back to the foreground\n * after being backgrounded or when the network reports as being online after\n * having been offline.\n * - `interval`: This occurs when a specified amount of time has passed.\n * - `invalid`: This occurs when the store emits a notification that the request\n * has become invalid.\n *\n * You can specify when autorefresh should occur by setting the `autorefresh` arg\n * to `true` or a comma-separated list of the above values.\n *\n * A value of `true` is equivalent to `'online,invalid'`.\n *\n * By default, an autorefresh will only occur if the browser was backgrounded or\n * offline for more than 30s before coming back available. This amount of time can\n * be tweaked by setting the number of milliseconds via `@autorefreshThreshold`.\n *\n * This arg also controls the interval at which the request will be refreshed\n * if the `interval` autorefresh type is enabled.\n *\n * Finally, the behavior of the request initiated by autorefresh can be adjusted\n * by setting the `autorefreshBehavior` arg to `'refresh'`, `'reload'`, or `'policy'`.\n *\n * - `'refresh'`: Refresh the request in the background\n * - `'reload'`: Force a reload of the request\n * - `'policy'` (**default**): Let the store's configured CachePolicy decide whether to\n * reload, refresh, or do nothing.\n *\n * More advanced refresh and reload behaviors can be created by passing the reload and\n * refresh actions into another component. For instance, refresh could be set up on a\n * timer or on a websocket subscription.\n *\n *\n * ```gjs\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:content as |result state|>\n * <h1>{{result.title}}</h1>\n *\n * <Interval @period={{30_000}} @fn={{state.refresh}} />\n * <Subscribe @channel={{@someValue}} @fn={{state.refresh}} />\n * </:content>\n * </Request>\n * </template>\n * ```\n *\n * If a matching request is refreshed or reloaded by any other component,\n * the `Request` component will react accordingly.\n *\n * ## Deduping\n *\n * The store dedupes requests by identity. If a request is made for the same identity\n * from multiple `<Request />` components, even if the request is not referentially the\n * same, only one actual request will be made.\n *\n *\n * @class <Request />\n * @public\n */\nexport class Request<T, RT> extends Component<RequestSignature<T, RT>> {\n /**\n * The store instance to use for making requests. If contexts are available, this\n * will be the `store` on the context, else it will be the store service.\n *\n * @internal\n */\n @consume('store') declare _store: Store;\n\n /**\n * Whether the browser reports that the network is online.\n *\n * @internal\n */\n @tracked isOnline = true;\n\n /**\n * Whether the browser reports that the tab is hidden.\n *\n * @internal\n */\n @tracked isHidden = true;\n\n /**\n * Whether the component is currently refreshing the request.\n *\n * @internal\n */\n @tracked isRefreshing = false;\n\n /**\n * The most recent blocking request that was made, typically\n * the result of a reload.\n *\n * This will never be the original request passed as an arg to\n * the component.\n *\n * @internal\n */\n @tracked _localRequest: Future<RT> | undefined;\n\n /**\n * The most recent request that was made, typically due to either a\n * reload or a refresh.\n *\n * This will never be the original request passed as an arg to\n * the component.\n *\n * @internal\n */\n @tracked _latestRequest: Future<RT> | undefined;\n\n /**\n * The time at which the network was reported as offline.\n *\n * @internal\n */\n declare unavailableStart: number | null;\n declare intervalStart: number | null;\n declare nextInterval: number | null;\n declare invalidated: boolean;\n declare isUpdating: boolean;\n\n /**\n * The event listener for network status changes,\n * cached to use the reference for removal.\n *\n * @internal\n */\n declare onlineChanged: (event: Event) => void;\n\n /**\n * The event listener for visibility status changes,\n * cached to use the reference for removal.\n *\n * @internal\n */\n declare backgroundChanged: (event: Event) => void;\n\n /**\n * The last request passed as an arg to the component,\n * cached for comparison.\n *\n * @internal\n */\n declare _originalRequest: Future<RT> | undefined;\n\n /**\n * The last query passed as an arg to the component,\n * cached for comparison.\n *\n * @internal\n */\n declare _originalQuery: StoreRequestInput<T, RT> | undefined;\n\n declare _subscription: object | null;\n declare _subscribedTo: object | null;\n\n constructor(owner: unknown, args: RequestSignature<T, RT>['Args']) {\n super(owner, args);\n this._subscribedTo = null;\n this._subscription = null;\n this.intervalStart = null;\n this.invalidated = false;\n this.nextInterval = null;\n\n this.installListeners();\n void this.beginPolling();\n }\n\n async beginPolling() {\n // await the initial request\n try {\n await this.request;\n } catch {\n // ignore errors here, we just want to wait for the request to finish\n } finally {\n if (!this.isDestroyed) {\n void this.scheduleInterval();\n }\n }\n }\n\n @cached\n get isIdle() {\n const { request, query } = this.args;\n\n return Boolean(!request && !query);\n }\n\n @cached\n get autorefreshTypes(): Set<AutorefreshBehaviorType> {\n const { autorefresh } = this.args;\n let types: AutorefreshBehaviorType[];\n\n if (autorefresh === true) {\n types = ['online', 'invalid'];\n } else if (typeof autorefresh === 'string') {\n types = autorefresh.split(',') as AutorefreshBehaviorType[];\n } else {\n types = [];\n }\n\n return new Set(types);\n }\n\n // we only run this function on component creation\n // and when an update is triggered, so it does not\n // react to changes in the autorefreshThreshold\n // or autorefresh args.\n //\n // if we need to react to those changes, we can\n // use a modifier or internal component or some\n // such to trigger a re-run of this function.\n async scheduleInterval() {\n const { autorefreshThreshold } = this.args;\n const hasValidThreshold = typeof autorefreshThreshold === 'number' && autorefreshThreshold > 0;\n if (\n // dont schedule in SSR\n typeof window === 'undefined' ||\n // dont schedule without a threshold\n !hasValidThreshold ||\n // dont schedule if we weren't told to\n !this.autorefreshTypes.has('interval') ||\n // dont schedule if we're already scheduled\n this.intervalStart !== null\n ) {\n return;\n }\n\n // if we have a current request, wait for it to finish\n // before scheduling the next one\n if (this._latestRequest) {\n try {\n await this._latestRequest;\n } catch {\n // ignore errors here, we just want to wait for the request to finish\n }\n\n if (this.isDestroyed) {\n return;\n }\n }\n\n // setup the next interval\n this.intervalStart = Date.now();\n this.nextInterval = setTimeout(() => {\n this.maybeUpdate();\n }, autorefreshThreshold);\n }\n\n clearInterval() {\n if (this.nextInterval) {\n clearTimeout(this.nextInterval);\n this.intervalStart = null;\n }\n }\n\n updateSubscriptions() {\n if (this.isIdle) {\n return;\n }\n const requestId = this._request.lid;\n\n // if we're already subscribed to this request, we don't need to do anything\n if (this._subscribedTo === requestId) {\n return;\n }\n\n // if we're subscribed to a different request, we need to unsubscribe\n this.removeSubscriptions();\n\n // if we have a request, we need to subscribe to it\n if (requestId) {\n this._subscribedTo = requestId;\n this._subscription = this.store.notifications.subscribe(\n requestId,\n (_id: StableDocumentIdentifier, op: 'invalidated' | 'state' | 'added' | 'updated' | 'removed') => {\n // ignore subscription events that occur while our own component's request\n // is ocurring\n if (this.isUpdating) {\n return;\n }\n switch (op) {\n case 'invalidated': {\n // if we're subscribed to invalidations, we need to update\n if (this.autorefreshTypes.has('invalid')) {\n this.invalidated = true;\n this.maybeUpdate();\n }\n break;\n }\n case 'state': {\n const latest = this.store.requestManager._deduped.get(requestId);\n const priority = latest?.priority;\n const state = this.reqState;\n if (!priority) {\n // if there is no priority, we have completed whatever request\n // was occurring and so we are no longer refreshing (if we were)\n this.isRefreshing = false;\n } else if (priority.blocking && !state.isLoading) {\n // if we are blocking, there is an active request for this identity\n // that MUST be fulfilled from network (not cache).\n // Thus this is not \"refreshing\" because we should clear out and\n // block on this request.\n //\n // we receive state notifications when either a request initiates\n // or completes.\n //\n // In the completes case: we may receive the state notification\n // slightly before the request is finalized because the NotificationManager\n // may sync flush it (and thus deliver it before the microtask completes)\n //\n // In the initiates case: we aren't supposed to receive one unless there\n // is no other request in flight for this identity.\n //\n // However, there is a race condition here where the completed\n // notification can trigger an update that generates a new request\n // thus giving us an initiated notification before the older request\n // finalizes.\n //\n // When this occurs, if the triggered update happens to have caused\n // a new request to be made for the same identity AND that request\n // is the one passed into this component as the @request arg, then\n // getRequestState will return the state of the new request.\n // We can detect this by checking if the request state is \"loading\"\n // as outside of this case we would have a completed request.\n //\n // That is the reason for the `&& !state.isLoading` check above.\n\n // TODO should we just treat this as refreshing?\n this.isRefreshing = false;\n this.maybeUpdate('policy', true);\n } else {\n this.isRefreshing = true;\n }\n }\n }\n }\n );\n }\n }\n\n removeSubscriptions() {\n if (this._subscription) {\n this.store.notifications.unsubscribe(this._subscription);\n this._subscribedTo = null;\n this._subscription = null;\n }\n }\n\n /**\n * Install the event listeners for network and visibility changes.\n * This is only done in browser environments with a global `window`.\n *\n * @internal\n */\n installListeners() {\n if (typeof window === 'undefined') {\n return;\n }\n\n this.isOnline = window.navigator.onLine;\n this.unavailableStart = this.isOnline ? null : Date.now();\n this.isHidden = document.visibilityState === 'hidden';\n\n this.onlineChanged = (event: Event) => {\n this.isOnline = event.type === 'online';\n if (event.type === 'offline' && this.unavailableStart === null) {\n this.unavailableStart = Date.now();\n }\n this.maybeUpdate();\n };\n this.backgroundChanged = () => {\n const isHidden = document.visibilityState === 'hidden';\n this.isHidden = isHidden;\n\n if (isHidden && this.unavailableStart === null) {\n this.unavailableStart = Date.now();\n }\n\n this.maybeUpdate();\n };\n\n window.addEventListener('online', this.onlineChanged, { passive: true, capture: true });\n window.addEventListener('offline', this.onlineChanged, { passive: true, capture: true });\n document.addEventListener('visibilitychange', this.backgroundChanged, { passive: true, capture: true });\n }\n\n /**\n * If the network is online and the tab is visible, either reload or refresh the request\n * based on the component's configuration and the requested update mode.\n *\n * Valid modes are:\n *\n * - `'reload'`: Force a reload of the request.\n * - `'refresh'`: Refresh the request in the background.\n * - `'policy'`: Make the request, letting the store's configured CachePolicy decide whether to reload, refresh, or do nothing.\n * - `undefined`: Make the request using the component's autorefreshBehavior setting if the autorefreshThreshold has passed.\n *\n * @internal\n */\n maybeUpdate(mode?: 'reload' | 'refresh' | 'policy' | 'invalidated', silent?: boolean): void {\n if (this.isIdle) {\n return;\n }\n const canAttempt = Boolean(this.isOnline && !this.isHidden && (mode || this.autorefreshTypes.size));\n\n if (!canAttempt) {\n if (!silent && mode && mode !== 'invalidated') {\n throw new Error(`Reload not available: the network is not online or the tab is hidden`);\n }\n\n return;\n }\n\n const { autorefreshTypes } = this;\n let shouldAttempt = this.invalidated || Boolean(mode);\n\n if (!shouldAttempt && autorefreshTypes.has('online')) {\n const { unavailableStart } = this;\n const { autorefreshThreshold } = this.args;\n const deadline = typeof autorefreshThreshold === 'number' ? autorefreshThreshold : DEFAULT_DEADLINE;\n shouldAttempt = Boolean(unavailableStart && Date.now() - unavailableStart > deadline);\n }\n\n if (!shouldAttempt && autorefreshTypes.has('interval')) {\n const { intervalStart } = this;\n const { autorefreshThreshold } = this.args;\n\n if (intervalStart && typeof autorefreshThreshold === 'number' && autorefreshThreshold > 0) {\n shouldAttempt = Boolean(Date.now() - intervalStart >= autorefreshThreshold);\n }\n }\n\n this.unavailableStart = null;\n this.invalidated = false;\n\n if (shouldAttempt) {\n this.clearInterval();\n const request = Object.assign({}, this.reqState.request as unknown as RequestInfo<T, RT>);\n const realMode = mode === 'invalidated' ? null : mode;\n const val = realMode ?? this.args.autorefreshBehavior ?? 'policy';\n switch (val) {\n case 'reload':\n request.cacheOptions = Object.assign({}, request.cacheOptions, { reload: true });\n break;\n case 'refresh':\n request.cacheOptions = Object.assign({}, request.cacheOptions, { backgroundReload: true });\n break;\n case 'policy':\n break;\n default:\n throw new Error(\n `Invalid ${mode ? 'update mode' : '@autorefreshBehavior'} for <Request />: ${isNeverString(val)}`\n );\n }\n\n const wasStoreRequest = request[EnableHydration] === true;\n assert(\n `Cannot supply a different store via context than was used to create the request`,\n !request.store || request.store === this.store\n );\n\n this.isUpdating = true;\n this._latestRequest = wasStoreRequest ? this.store.request(request) : this.store.requestManager.request(request);\n\n if (val !== 'refresh') {\n this._localRequest = this._latestRequest;\n }\n\n void this.scheduleInterval();\n void this._latestRequest.finally(() => {\n this.isUpdating = false;\n });\n } else {\n // TODO probably want this\n // void this.scheduleInterval();\n }\n }\n\n /**\n * Retry the request, reloading it from the server.\n *\n * @internal\n */\n retry = async () => {\n this.maybeUpdate('reload');\n await this._localRequest;\n };\n\n /**\n * Refresh the request, updating it in the background.\n *\n * @internal\n */\n refresh = async () => {\n this.maybeUpdate('refresh');\n await this._latestRequest;\n };\n\n @cached\n get errorFeatures() {\n return {\n isHidden: this.isHidden,\n isOnline: this.isOnline,\n retry: this.retry,\n };\n }\n\n @cached\n get contentFeatures() {\n const feat: ContentFeatures<RT> = {\n isHidden: this.isHidden,\n isOnline: this.isOnline,\n reload: this.retry,\n refresh: this.refresh,\n isRefreshing: this.isRefreshing,\n latestRequest: this._latestRequest,\n };\n\n if (feat.isRefreshing) {\n feat.abort = () => {\n this._latestRequest?.abort();\n };\n }\n\n return feat;\n }\n\n willDestroy() {\n this.removeSubscriptions();\n\n if (typeof window === 'undefined') {\n return;\n }\n\n this.clearInterval();\n\n window.removeEventListener('online', this.onlineChanged, { passive: true, capture: true } as unknown as boolean);\n window.removeEventListener('offline', this.onlineChanged, { passive: true, capture: true } as unknown as boolean);\n document.removeEventListener('visibilitychange', this.backgroundChanged, {\n passive: true,\n capture: true,\n } as unknown as boolean);\n }\n\n @cached\n get _request(): Future<RT> {\n const { request, query } = this.args;\n assert(`Cannot use both @request and @query args with the <Request> component`, !request || !query);\n const { _localRequest, _originalRequest, _originalQuery } = this;\n const isOriginalRequest = request === _originalRequest && query === _originalQuery;\n\n if (_localRequest && isOriginalRequest) {\n return _localRequest;\n }\n\n // update state checks for the next time\n this._originalQuery = query;\n this._originalRequest = request;\n\n if (request) {\n return request;\n }\n assert(`You must provide either @request or an @query arg with the <Request> component`, query);\n return this.store.request<RT, T>(query);\n }\n\n @cached\n get request(): Future<RT> {\n const request = this._request;\n this.updateSubscriptions();\n return request;\n }\n\n get store(): Store {\n const store = this.args.store || this._store;\n assert(\n moduleExists('ember-provide-consume-context')\n ? `No store was provided to the <Request> component. Either provide a store via the @store arg or via the context API provided by ember-provide-consume-context.`\n : `No store was provided to the <Request> component. Either provide a store via the @store arg or by registering a store service.`,\n store\n );\n return store;\n }\n\n get reqState() {\n return getRequestState<RT, T>(this.request);\n }\n\n get result() {\n return this.reqState.result as RT;\n }\n\n <template>\n {{#if (and this.isIdle (has-block \"idle\"))}}\n {{yield to=\"idle\"}}\n {{else if this.isIdle}}\n <Throw @error={{IdleBlockMissingError}} />\n {{else if this.reqState.isLoading}}\n {{yield this.reqState.loadingState to=\"loading\"}}\n {{else if (and this.reqState.isCancelled (has-block \"cancelled\"))}}\n {{yield (notNull this.reqState.error) this.errorFeatures to=\"cancelled\"}}\n {{else if (and this.reqState.isError (has-block \"error\"))}}\n {{yield (notNull this.reqState.error) this.errorFeatures to=\"error\"}}\n {{else if this.reqState.isSuccess}}\n {{yield this.result this.contentFeatures to=\"content\"}}\n {{else if (not this.reqState.isCancelled)}}\n <Throw @error={{(notNull this.reqState.error)}} />\n {{/if}}\n {{yield this.reqState to=\"always\"}}\n </template>\n}\n"],"names":["deferred","WeakMap","deferDecorator","proto","prop","desc","map","get","Map","set","findDeferredDecorator","target","_a","cursor","prototype","decorateFieldV2","decorators","initializer","configurable","enumerable","writable","decorator","Object","defineProperty","decorateMethodV2","origDesc","getOwnPropertyDescriptor","value","call","initializeDeferredDecorator","constructor","RequestCache","isAbortError","error","DOMException","name","watchStream","stream","state","reader","getReader","bytesLoaded","shouldForward","_stream","readable","locked","isForwarding","writer","getWriter","buffer","_isPending","_isStarted","_startTime","performance","now","done","read","byteLength","_bytesLoaded","_lastPacketTime","item","ready","write","length","push","close","cancel","endTime","_endTime","_isComplete","RequestLoadingState","_future","_triggered","_trigger","future","promise","getStream","sizeHint","_sizeHint","then","_isCancelled","_isErrored","_error","g","tracked","i","void 0","isPending","TransformStream","isStarted","startTime","lastPacketTime","isComplete","isCancelled","isErrored","elapsedTime","completedRatio","remainingRatio","duration","speed","abort","RequestState","isError","loadingState","getPromiseResult","request","result","response","isLoading","content","isSuccess","setPromiseResult","getRequestState","PromiseCache","PromiseState","LegacyPromiseProxy","Symbol","for","isLegacyAwaitable","getPromise","getPromiseState","_promise","and","x","y","Boolean","Throw","Component","owner","args","setComponentTemplate","precompileTemplate","strictMode","Await","scope","notNull","macroCondition","getGlobalConfig","WarpDrive","env","DEBUG","test","Error","not","DEFAULT_DEADLINE","IdleBlockMissingError","consume","service","moduleExists","contextConsume","importSync","isNeverString","val","Request","unavailableStart","intervalStart","nextInterval","invalidated","isUpdating","onlineChanged","backgroundChanged","_originalRequest","_originalQuery","_subscription","_subscribedTo","installListeners","beginPolling","isDestroyed","scheduleInterval","isIdle","query","n","cached","autorefreshTypes","autorefresh","types","split","Set","autorefreshThreshold","hasValidThreshold","window","has","_latestRequest","Date","setTimeout","maybeUpdate","clearInterval","clearTimeout","updateSubscriptions","requestId","_request","lid","removeSubscriptions","store","notifications","subscribe","_id","op","latest","requestManager","_deduped","priority","reqState","isRefreshing","blocking","unsubscribe","isOnline","navigator","onLine","isHidden","document","visibilityState","event","type","addEventListener","passive","capture","mode","silent","canAttempt","size","shouldAttempt","deadline","assign","realMode","autorefreshBehavior","cacheOptions","reload","backgroundReload","wasStoreRequest","EnableHydration","_localRequest","finally","retry","refresh","errorFeatures","contentFeatures","feat","latestRequest","willDestroy","removeEventListener","isOriginalRequest","_store"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"index.js","sources":["../../../node_modules/.pnpm/decorat_bfe8edbefc8aced6f61ce140cd72ecf2/node_modules/decorator-transforms/dist/runtime-BPCpkOf1.js","../src/-private/request-state.ts","../src/-private/promise-state.ts","../src/-private/await.gts","../src/-private/request.gts"],"sourcesContent":["const deferred = /* @__PURE__ */ new WeakMap();\nfunction deferDecorator(proto, prop, desc) {\n let map = deferred.get(proto);\n if (!map) {\n map = /* @__PURE__ */ new Map();\n deferred.set(proto, map);\n }\n map.set(prop, desc);\n}\nfunction findDeferredDecorator(target, prop) {\n var _a;\n let cursor = target.prototype;\n while (cursor) {\n let desc = (_a = deferred.get(cursor)) == null ? void 0 : _a.get(prop);\n if (desc) {\n return desc;\n }\n cursor = cursor.prototype;\n }\n}\nfunction decorateFieldV1(target, prop, decorators, initializer) {\n return decorateFieldV2(target.prototype, prop, decorators, initializer);\n}\nfunction decorateFieldV2(prototype, prop, decorators, initializer) {\n let desc = {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n };\n if (initializer) {\n desc.initializer = initializer;\n }\n for (let decorator of decorators) {\n desc = decorator(prototype, prop, desc) || desc;\n }\n if (desc.initializer === void 0) {\n Object.defineProperty(prototype, prop, desc);\n } else {\n deferDecorator(prototype, prop, desc);\n }\n}\nfunction decorateMethodV1({ prototype }, prop, decorators) {\n return decorateMethodV2(prototype, prop, decorators);\n}\nfunction decorateMethodV2(prototype, prop, decorators) {\n const origDesc = Object.getOwnPropertyDescriptor(prototype, prop);\n let desc = { ...origDesc };\n for (let decorator of decorators) {\n desc = decorator(prototype, prop, desc) || desc;\n }\n if (desc.initializer !== void 0) {\n desc.value = desc.initializer ? desc.initializer.call(prototype) : void 0;\n desc.initializer = void 0;\n }\n Object.defineProperty(prototype, prop, desc);\n}\nfunction initializeDeferredDecorator(target, prop) {\n let desc = findDeferredDecorator(target.constructor, prop);\n if (desc) {\n Object.defineProperty(target, prop, {\n enumerable: desc.enumerable,\n configurable: desc.configurable,\n writable: desc.writable,\n value: desc.initializer ? desc.initializer.call(target) : void 0\n });\n }\n}\nfunction decorateClass(target, decorators) {\n return decorators.reduce(\n (accum, decorator) => decorator(accum) || accum,\n target\n );\n}\nfunction decoratePOJO(pojo, decorated) {\n for (let [type, prop, decorators] of decorated) {\n if (type === \"field\") {\n decoratePojoField(pojo, prop, decorators);\n } else {\n decorateMethodV2(pojo, prop, decorators);\n }\n }\n return pojo;\n}\nfunction decoratePojoField(pojo, prop, decorators) {\n let desc = {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: () => {\n var _a;\n return (_a = Object.getOwnPropertyDescriptor(pojo, prop)) == null ? void 0 : _a.value;\n }\n };\n for (let decorator of decorators) {\n desc = decorator(pojo, prop, desc) || desc;\n }\n if (desc.initializer) {\n desc.value = desc.initializer.call(pojo);\n delete desc.initializer;\n }\n Object.defineProperty(pojo, prop, desc);\n}\nconst runtime = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n c: decorateClass,\n f: decorateFieldV1,\n g: decorateFieldV2,\n i: initializeDeferredDecorator,\n m: decorateMethodV1,\n n: decorateMethodV2,\n p: decoratePOJO\n}, Symbol.toStringTag, { value: \"Module\" }));\nexport {\n decorateFieldV2 as a,\n decorateMethodV1 as b,\n decorateMethodV2 as c,\n decorateFieldV1 as d,\n decorateClass as e,\n decoratePOJO as f,\n initializeDeferredDecorator as i,\n runtime as r\n};\n//# sourceMappingURL=runtime-BPCpkOf1.js.map\n","/**\n * @module @warp-drive-mirror/ember\n */\nimport { tracked } from '@glimmer/tracking';\n\nimport type {\n Future,\n ImmutableRequestInfo,\n ResponseInfo,\n StructuredDocument,\n StructuredErrorDocument,\n} from '@ember-data-mirror/request';\nimport { getPromiseResult, setPromiseResult } from '@ember-data-mirror/request';\n\nconst RequestCache = new WeakMap<Future<unknown>, RequestState>();\n\nfunction isAbortError(error: unknown): boolean {\n return error instanceof DOMException && error.name === 'AbortError';\n}\n\nasync function watchStream(stream: ReadableStream<Uint8Array>, state: RequestLoadingState): Promise<void> {\n const reader = stream.getReader();\n let bytesLoaded = 0;\n let shouldForward = state._stream !== null && state._stream.readable.locked;\n let isForwarding = shouldForward;\n let writer = state._stream?.writable.getWriter();\n const buffer = [];\n\n state._isPending = false;\n state._isStarted = true;\n state._startTime = performance.now();\n\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n break;\n }\n bytesLoaded += value.byteLength;\n state._bytesLoaded = bytesLoaded;\n state._lastPacketTime = performance.now();\n\n shouldForward = shouldForward || (state._stream !== null && state._stream.readable.locked);\n\n if (shouldForward) {\n if (!isForwarding) {\n isForwarding = true;\n writer = state._stream!.writable.getWriter();\n for (const item of buffer) {\n await writer.ready;\n await writer.write(item);\n }\n buffer.length = 0;\n }\n await writer!.ready;\n await writer!.write(value);\n } else {\n buffer.push(value);\n }\n }\n\n // if we are still forwarding, we need to close the writer\n if (isForwarding) {\n await writer!.ready;\n await writer!.close();\n } else if (state._stream) {\n // if we are not forwarding, we need to cancel the stream\n await state._stream.readable.cancel('The Stream Has Already Ended');\n state._stream = null;\n }\n\n const endTime = performance.now();\n state._endTime = endTime;\n state._isComplete = true;\n state._isStarted = false;\n}\n\n/**\n * Lazily consumes the stream of a request, providing a number of\n * reactive properties that can be used to build UIs that respond\n * to the progress of a request.\n *\n * @class RequestLoadingState\n * @public\n */\nexport class RequestLoadingState {\n _stream: TransformStream | null = null;\n _future: Future<unknown>;\n _triggered = false;\n _trigger() {\n if (this._triggered) {\n return;\n }\n this._triggered = true;\n const future = this._future;\n const promise: Promise<ReadableStream<Uint8Array> | null> & { sizeHint?: number } = future.getStream();\n if (promise.sizeHint) {\n this._sizeHint = promise.sizeHint;\n }\n this.promise = promise.then(\n (stream) => {\n if (!stream) {\n this._isPending = false;\n this._isComplete = true;\n return;\n }\n return watchStream(stream, this);\n },\n (error: Error) => {\n this._isPending = false;\n this._isStarted = false;\n if (isAbortError(error)) {\n this._isCancelled = true;\n this._isComplete = true;\n }\n this._isErrored = true;\n this._error = error;\n }\n );\n }\n\n promise: Promise<void> | null = null;\n @tracked _sizeHint = 0;\n @tracked _bytesLoaded = 0;\n\n @tracked _startTime = 0;\n @tracked _endTime = 0;\n @tracked _lastPacketTime = 0;\n\n @tracked _isPending = true;\n @tracked _isStarted = false;\n @tracked _isComplete = false;\n @tracked _isCancelled = false;\n @tracked _isErrored = false;\n @tracked _error: Error | null = null;\n\n get isPending(): boolean {\n this._trigger();\n return this._isPending;\n }\n\n get sizeHint(): number {\n this._trigger();\n return this._sizeHint;\n }\n\n get stream(): ReadableStream | null {\n this._trigger();\n if (!this._stream) {\n if (this._isComplete || this._isCancelled || this._isErrored) {\n return null;\n }\n this._stream = new TransformStream();\n }\n return this._stream.readable;\n }\n\n get isStarted(): boolean {\n this._trigger();\n return this._isStarted;\n }\n\n get bytesLoaded(): number {\n this._trigger();\n return this._bytesLoaded;\n }\n\n get startTime(): number {\n this._trigger();\n return this._startTime;\n }\n\n get endTime(): number {\n this._trigger();\n return this._endTime;\n }\n\n get lastPacketTime(): number {\n this._trigger();\n return this._lastPacketTime;\n }\n\n get isComplete(): boolean {\n this._trigger();\n return this._isComplete;\n }\n\n get isCancelled(): boolean {\n this._trigger();\n return this._isCancelled;\n }\n\n get isErrored(): boolean {\n this._trigger();\n return this._isErrored;\n }\n\n get error(): Error | null {\n this._trigger();\n return this._error;\n }\n\n get elapsedTime(): number {\n return (this.endTime || this.lastPacketTime) - this.startTime;\n }\n\n get completedRatio(): number {\n return this.sizeHint ? this.bytesLoaded / this.sizeHint : 0;\n }\n\n get remainingRatio(): number {\n return 1 - this.completedRatio;\n }\n\n get duration(): number {\n return this.endTime - this.startTime;\n }\n\n get speed(): number {\n // bytes per second\n return this.bytesLoaded / (this.elapsedTime / 1000);\n }\n\n constructor(future: Future<unknown>) {\n this._future = future;\n }\n\n abort = (): void => {\n this._future.abort();\n };\n}\n\n/**\n * RequestState extends the concept of PromiseState to provide a reactive\n * wrapper for a request `Future` which allows you write declarative code\n * around a Future's control flow.\n *\n * It is useful in both Template and JavaScript contexts, allowing you\n * to quickly derive behaviors and data from pending, error and success\n * states.\n *\n * The key difference between a Promise and a Future is that Futures provide\n * access to a stream of their content, the identity of the request (if any)\n * as well as the ability to attempt to abort the request.\n *\n * ```ts\n * interface Future<T> extends Promise<T>> {\n * getStream(): Promise<ReadableStream>;\n * abort(): void;\n * lid: StableDocumentIdentifier | null;\n * }\n * ```\n *\n * These additional APIs allow us to craft even richer state experiences.\n *\n * To get the state of a request, use `getRequestState`.\n *\n * @class RequestState\n * @public\n */\nexport class RequestState<T = unknown, RT = unknown> {\n #request: Future<RT>;\n #loadingState: RequestLoadingState | null = null;\n\n @tracked result: RT | null = null;\n @tracked error: StructuredErrorDocument | null = null;\n @tracked isLoading = true;\n @tracked isSuccess = false;\n @tracked isError = false;\n @tracked request: ImmutableRequestInfo<T, RT> | null = null;\n @tracked response: Response | ResponseInfo | null = null;\n\n get isCancelled(): boolean {\n return this.isError && isAbortError(this.error);\n }\n\n get loadingState() {\n if (!this.#loadingState) {\n this.#loadingState = new RequestLoadingState(this.#request);\n }\n\n return this.#loadingState;\n }\n\n constructor(future: Future<RT>) {\n this.#request = future;\n const state = getPromiseResult<StructuredDocument<RT>, StructuredErrorDocument>(future);\n\n if (state) {\n this.request = state.result.request as ImmutableRequestInfo<T, RT>;\n this.response = state.result.response;\n this.isLoading = false;\n\n if (state.isError) {\n this.error = state.result;\n this.isError = true;\n } else {\n this.result = state.result.content!;\n this.isSuccess = true;\n }\n } else {\n void future.then(\n (result) => {\n setPromiseResult(future, { isError: false, result });\n this.result = result.content;\n this.isSuccess = true;\n this.isLoading = false;\n this.request = result.request as ImmutableRequestInfo<T, RT>;\n this.response = result.response;\n },\n (error: StructuredErrorDocument) => {\n setPromiseResult(future, { isError: true, result: error });\n this.error = error;\n this.isError = true;\n this.isLoading = false;\n this.request = error.request as ImmutableRequestInfo<T, RT>;\n this.response = error.response;\n }\n );\n }\n }\n}\n\n/**\n *\n *\n * `getRequestState` can be used in both JavaScript and Template contexts.\n *\n * ```ts\n * import { getRequestState } from '@warp-drive-mirror/ember';\n *\n * const state = getRequestState(future);\n * ```\n *\n * For instance, we could write a getter on a component that updates whenever\n * the request state advances or the future changes, by combining the function\n * with the use of `@cached`\n *\n * ```ts\n * class Component {\n * @cached\n * get title() {\n * const state = getRequestState(this.args.request);\n * if (state.isPending) {\n * return 'loading...';\n * }\n * if (state.isError) { return null; }\n * return state.result.title;\n * }\n * }\n * ```\n *\n * Or in a template as a helper:\n *\n * ```gjs\n * import { getRequestState } from '@warp-drive-mirror/ember';\n *\n * <template>\n * {{#let (getRequestState @request) as |state|}}\n * {{#if state.isPending}}\n * <Spinner />\n * {{else if state.isError}}\n * <ErrorForm @error={{state.error}} />\n * {{else}}\n * <h1>{{state.result.title}}</h1>\n * {{/if}}\n * {{/let}}\n * </template>\n * ```\n *\n * If looking to use in a template, consider also the `<Request />` component\n * which offers a numbe of additional capabilities for requests *beyond* what\n * `RequestState` provides.\n *\n * @method getRequestState\n * @for @warp-drive-mirror/ember\n * @static\n * @public\n * @param future\n * @return {RequestState}\n */\nexport function getRequestState<RT, T>(future: Future<RT>): RequestState<T, RT> {\n let state = RequestCache.get(future) as RequestState<T, RT> | undefined;\n\n if (!state) {\n state = new RequestState(future);\n RequestCache.set(future, state);\n }\n\n return state;\n}\n","/**\n * @module @warp-drive-mirror/ember\n */\nimport { tracked } from '@glimmer/tracking';\n\nimport type { Awaitable } from '@ember-data-mirror/request';\nimport { getPromiseResult, setPromiseResult } from '@ember-data-mirror/request';\n\nconst PromiseCache = new WeakMap<Awaitable, PromiseState>();\n\n/**\n * PromiseState provides a reactive wrapper for a promise which allows you write declarative\n * code around a promise's control flow. It is useful in both Template and JavaScript contexts,\n * allowing you to quickly derive behaviors and data from pending, error and success states.\n *\n * ```ts\n * interface PromiseState<T = unknown, E = unknown> {\n * isPending: boolean;\n * isSuccess: boolean;\n * isError: boolean;\n * result: T | null;\n * error: E | null;\n * }\n * ```\n *\n * To get the state of a promise, use `getPromiseState`.\n *\n * @class PromiseState\n * @public\n */\nexport class PromiseState<T = unknown, E = unknown> {\n @tracked result: T | null = null;\n @tracked error: E | null = null;\n @tracked isPending = true;\n @tracked isSuccess = false;\n @tracked isError = false;\n\n constructor(promise: Promise<T> | Awaitable<T, E>) {\n const state = getPromiseResult<T, E>(promise);\n\n if (state) {\n if (state.isError) {\n this.error = state.result;\n this.isError = true;\n this.isPending = false;\n } else {\n this.result = state.result;\n this.isSuccess = true;\n this.isPending = false;\n }\n } else {\n void promise.then(\n (result) => {\n setPromiseResult(promise, { isError: false, result });\n this.result = result;\n this.isSuccess = true;\n this.isPending = false;\n },\n (error: E) => {\n setPromiseResult(promise, { isError: true, result: error });\n this.error = error;\n this.isError = true;\n this.isPending = false;\n }\n );\n }\n }\n}\n\nconst LegacyPromiseProxy = Symbol.for('LegacyPromiseProxy');\ntype LegacyAwaitable<T, E> = { promise: Promise<T> | Awaitable<T, E>; [LegacyPromiseProxy]: true };\n\nfunction isLegacyAwaitable<T, E>(promise: object): promise is LegacyAwaitable<T, E> {\n return LegacyPromiseProxy in promise && 'promise' in promise && promise[LegacyPromiseProxy] === true;\n}\n\nfunction getPromise<T, E>(promise: Promise<T> | Awaitable<T, E> | LegacyAwaitable<T, E>): Promise<T> | Awaitable<T, E> {\n return isLegacyAwaitable(promise) ? promise.promise : promise;\n}\n\n/**\n * Returns a reactive state-machine for the provided promise or awaitable.\n *\n * Repeat calls to `getPromiseState` with the same promise will return the same state object\n * making is safe and easy to use in templates and JavaScript code to produce reactive\n * behaviors around promises.\n *\n * `getPromiseState` can be used in both JavaScript and Template contexts.\n *\n * ```ts\n * import { getPromiseState } from '@warp-drive-mirror/ember';\n *\n * const state = getPromiseState(promise);\n * ```\n *\n * For instance, we could write a getter on a component that updates whenever\n * the promise state advances or the promise changes, by combining the function\n * with the use of `@cached`\n *\n * ```ts\n * class Component {\n * @cached\n * get title() {\n * const state = getPromiseState(this.args.request);\n * if (state.isPending) {\n * return 'loading...';\n * }\n * if (state.isError) { return null; }\n * return state.result.title;\n * }\n * }\n * ```\n *\n * Or in a template as a helper:\n *\n * ```gjs\n * import { getPromiseState } from '@warp-drive-mirror/ember';\n *\n * <template>\n * {{#let (getPromiseState @request) as |state|}}\n * {{#if state.isPending}} <Spinner />\n * {{else if state.isError}} <ErrorForm @error={{state.error}} />\n * {{else}}\n * <h1>{{state.result.title}}</h1>\n * {{/if}}\n * {{/let}}\n * </template>\n * ```\n *\n * If looking to use in a template, consider also the `<Await />` component.\n *\n * @method getPromiseState\n * @for @warp-drive-mirror/ember\n * @static\n * @public\n * @param {Promise<T> | Awaitable<T, E>} promise\n * @return {PromiseState<T, E>}\n */\nexport function getPromiseState<T = unknown, E = unknown>(promise: Promise<T> | Awaitable<T, E>): PromiseState<T, E> {\n const _promise = getPromise(promise);\n let state = PromiseCache.get(_promise) as PromiseState<T, E> | undefined;\n\n if (!state) {\n state = new PromiseState(_promise);\n PromiseCache.set(_promise, state);\n }\n\n return state;\n}\n","/**\n * @module @warp-drive-mirror/ember\n */\nimport type Owner from '@ember/owner';\nimport Component from '@glimmer/component';\n\nimport type { Awaitable } from '@ember-data-mirror/request';\n\nimport { getPromiseState } from './promise-state.ts';\n\nexport const and = (x: unknown, y: unknown) => Boolean(x && y);\ninterface ThrowSignature<E = Error | string | object> {\n Args: {\n error: E;\n };\n}\n\n/**\n * The `<Throw />` component is used to throw an error in a template.\n *\n * That's all it does. So don't use it unless the application should\n * throw an error if it reaches this point in the template.\n *\n * ```hbs\n * <Throw @error={{anError}} />\n * ```\n *\n * @class <Throw />\n * @public\n */\nexport class Throw<T> extends Component<ThrowSignature<T>> {\n constructor(owner: Owner, args: ThrowSignature<T>['Args']) {\n super(owner, args);\n // this error is opaque (user supplied) so we don't validate it\n // as an Error instance.\n // eslint-disable-next-line @typescript-eslint/no-throw-literal\n throw this.args.error;\n }\n <template></template>\n}\n\ninterface AwaitSignature<T, E = Error | string | object> {\n Args: {\n promise: Promise<T> | Awaitable<T, E>;\n };\n Blocks: {\n pending: [];\n error: [error: E];\n success: [value: T];\n };\n}\n\n/**\n * The <Await /> component allow you to utilize reactive control flow\n * for asynchronous states in your application.\n *\n * Await is ideal for handling \"boundaries\", outside which some state is\n * still allowed to be unresolved and within which it MUST be resolved.\n *\n * ```gjs\n * import { Await } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Await @promise={{@request}}>\n * <:pending>\n * <Spinner />\n * </:pending>\n *\n * <:error as |error|>\n * <ErrorForm @error={{error}} />\n * </:error>\n *\n * <:success as |result|>\n * <h1>{{result.title}}</h1>\n * </:success>\n * </Await>\n * </template>\n * ```\n *\n * The <Await /> component requires that error states are properly handled.\n *\n * If no error block is provided and the promise rejects, the error will\n * be thrown.\n *\n * @class <Await />\n * @public\n */\nexport class Await<T, E> extends Component<AwaitSignature<T, E>> {\n get state() {\n return getPromiseState<T, E>(this.args.promise);\n }\n\n get error() {\n return this.state.error as E;\n }\n\n get result() {\n return this.state.result as T;\n }\n\n <template>\n {{#if this.state.isPending}}\n {{yield to=\"pending\"}}\n {{else if (and this.state.isError (has-block \"error\"))}}\n {{yield this.error to=\"error\"}}\n {{else if this.state.isSuccess}}\n {{yield this.result to=\"success\"}}\n {{else}}\n <Throw @error={{this.error}} />\n {{/if}}\n </template>\n}\n","/**\n * @module @warp-drive-mirror/ember\n */\nimport type Owner from '@ember/owner';\nimport { service } from '@ember/service';\nimport Component from '@glimmer/component';\nimport { cached, tracked } from '@glimmer/tracking';\n\nimport { importSync, macroCondition, moduleExists } from '@embroider/macros';\n\nimport type { Future, StructuredErrorDocument } from '@ember-data-mirror/request';\nimport type { StoreRequestInput } from '@ember-data-mirror/store';\nimport type Store from '@ember-data-mirror/store';\nimport { assert } from '@warp-drive-mirror/build-config/macros';\nimport type { StableDocumentIdentifier } from '@warp-drive-mirror/core-types/identifier.js';\nimport { EnableHydration, type RequestInfo } from '@warp-drive-mirror/core-types/request';\n\nimport { and, Throw } from './await.gts';\nimport type { RequestLoadingState, RequestState } from './request-state.ts';\nimport { getRequestState } from './request-state.ts';\n\nfunction notNull(x: null): never;\nfunction notNull<T>(x: T): Exclude<T, null>;\nfunction notNull<T>(x: T | null) {\n assert('Expected a non-null value, but got null', x !== null);\n return x;\n}\n\nconst not = (x: unknown) => !x;\n// default to 30 seconds unavailable before we refresh\nconst DEFAULT_DEADLINE = 30_000;\nconst IdleBlockMissingError = new Error(\n 'No idle block provided for <Request> component, and no query or request was provided.'\n);\n\nlet consume = service;\nif (macroCondition(moduleExists('ember-provide-consume-context'))) {\n const { consume: contextConsume } = importSync('ember-provide-consume-context') as { consume: typeof service };\n consume = contextConsume;\n}\n\nfunction isNeverString(val: never): string {\n return val;\n}\n\ntype AutorefreshBehaviorType = 'online' | 'interval' | 'invalid';\ntype AutorefreshBehaviorCombos =\n | boolean\n | AutorefreshBehaviorType\n | `${AutorefreshBehaviorType},${AutorefreshBehaviorType}`\n | `${AutorefreshBehaviorType},${AutorefreshBehaviorType},${AutorefreshBehaviorType}`;\n\ntype ContentFeatures<RT> = {\n isOnline: boolean;\n isHidden: boolean;\n isRefreshing: boolean;\n refresh: () => Promise<void>;\n reload: () => Promise<void>;\n abort?: () => void;\n latestRequest?: Future<RT>;\n};\n\ninterface RequestSignature<T, RT> {\n Args: {\n /**\n * The request to monitor. This should be a `Future` instance returned\n * by either the `store.request` or `store.requestManager.request` methods.\n *\n * @typedoc\n */\n request?: Future<RT>;\n\n /**\n * A query to use for the request. This should be an object that can be\n * passed to `store.request`. Use this in place of `@request` if you would\n * like the component to also initiate the request.\n *\n * @typedoc\n */\n query?: StoreRequestInput<T, RT>;\n\n /**\n * The store instance to use for making requests. If contexts are available,\n * the component will default to using the `store` on the context.\n *\n * This is required if the store is not available via context or should be\n * different from the store provided via context.\n *\n * @typedoc\n */\n store?: Store;\n\n /**\n * The autorefresh behavior for the request. This can be a boolean, or any\n * combination of the following values: `'online'`, `'interval'`, `'invalid'`.\n *\n * - `'online'`: Refresh the request when the browser comes back online\n * - `'interval'`: Refresh the request at a specified interval\n * - `'invalid'`: Refresh the request when the store emits an invalidation\n *\n * If `true`, this is equivalent to `'online,invalid'`.\n *\n * Defaults to `false`.\n *\n * @typedoc\n */\n autorefresh?: AutorefreshBehaviorCombos;\n\n /**\n * The number of milliseconds to wait before refreshing the request when the\n * browser comes back online or the network becomes available.\n *\n * This also controls the interval at which the request will be refreshed if\n * the `interval` autorefresh type is enabled.\n *\n * Defaults to `30_000` (30 seconds).\n *\n * @typedoc\n */\n autorefreshThreshold?: number;\n\n /**\n * The behavior of the request initiated by autorefresh. This can be one of\n * the following values:\n *\n * - `'refresh'`: Refresh the request in the background\n * - `'reload'`: Force a reload of the request\n * - `'policy'` (**default**): Let the store's configured CachePolicy decide whether to\n * reload, refresh, or do nothing.\n *\n * Defaults to `'policy'`.\n *\n * @typedoc\n */\n autorefreshBehavior?: 'refresh' | 'reload' | 'policy';\n };\n Blocks: {\n /**\n * The block to render when the component is idle and waiting to be given a request.\n *\n * @typedoc\n */\n idle: [];\n\n /**\n * The block to render when the request is loading.\n *\n * @typedoc\n */\n loading: [state: RequestLoadingState];\n\n /**\n * The block to render when the request was cancelled.\n *\n * @typedoc\n */\n cancelled: [\n error: StructuredErrorDocument,\n features: { isOnline: boolean; isHidden: boolean; retry: () => Promise<void> },\n ];\n\n /**\n * The block to render when the request failed. If this block is not provided,\n * the error will be rethrown.\n *\n * Thus it is required to provide an error block and proper error handling if\n * you do not want the error to crash the application.\n *\n * @typedoc\n */\n error: [\n error: StructuredErrorDocument,\n features: { isOnline: boolean; isHidden: boolean; retry: () => Promise<void> },\n ];\n\n /**\n * The block to render when the request succeeded.\n *\n * @typedoc\n */\n content: [value: RT, features: ContentFeatures<RT>];\n always: [state: RequestState<T, RT>];\n };\n}\n\n/**\n * The `<Request />` component is a powerful tool for managing data fetching and\n * state in your Ember application. It provides a declarative approach to reactive\n * control-flow for managing requests and state in your application.\n *\n * The `<Request />` component is ideal for handling \"boundaries\", outside which some\n * state is still allowed to be unresolved and within which it MUST be resolved.\n *\n * ## Request States\n *\n * `<Request />` has five states, only one of which will be active and rendered at a time.\n *\n * - `idle`: The component is waiting to be given a request to monitor\n * - `loading`: The request is in progress\n * - `error`: The request failed\n * - `content`: The request succeeded\n * - `cancelled`: The request was cancelled\n *\n * Additionally, the `content` state has a `refresh` method that can be used to\n * refresh the request in the background, which is available as a sub-state of\n * the `content` state.\n *\n * As with the `<Await />` component, if no error block is provided and the request\n * rejects, the error will be thrown. Cancellation errors are swallowed instead of\n * rethrown if no error block or cancellation block is present.\n *\n * ```gts\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:loading as |state|>\n * <Spinner @percentDone={{state.completedRatio}} />\n * <button {{on \"click\" state.abort}}>Cancel</button>\n * </:loading>\n *\n * <:error as |error state|>\n * <ErrorForm @error={{error}} />\n * <button {{on \"click\" state.retry}}>Retry</button>\n * </:error>\n *\n * <:content as |data state|>\n * <h1>{{data.title}}</h1>\n * {{#if state.isBackgroundReloading}}\n * <SmallSpinner />\n * <button {{on \"click\" state.abort}}>Cancel</button>\n * {{else}}\n * <button {{on \"click\" state.refresh}}>Refresh</button>\n * {{/if}}\n * </:content>\n *\n * <:cancelled as |error state|>\n * <h2>The Request was cancelled</h2>\n * <button {{on \"click\" state.retry}}>Retry</button>\n * </:cancelled>\n *\n * <:idle>\n * <button {{on \"click\" @kickOffRequest}}>Load Preview?</button>\n * </:idle>\n *\n * </Request>\n * </template>\n * ```\n *\n * ## Streaming Data\n *\n * The loading state exposes the download `ReadableStream` instance for consumption\n *\n * ```gjs\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:loading as |state|>\n * <Video @stream={{state.stream}} />\n * </:loading>\n *\n * <:error as |error|>\n * <ErrorForm @error={{error}} />\n * </:error>\n * </Request>\n * </template>\n * ```\n *\n * ## Retry\n *\n * Cancelled and error'd requests may be retried by calling the `retry` method.\n *\n * Retry will restart the state progression, using the loading, error, cancelled,\n * and content blocks as appropriate.\n *\n * ## Reloading\n *\n * The `reload` method will force the request to be fully re-executed, bypassing\n * cache and restarting the state progression through the loading, error, and\n * content blocks as appropriate.\n *\n * Background reload (refresh) is a special substate of the content state that\n * allows you to refresh the request in the background. This is useful for when\n * you want to update the data in the background without blocking the UI.\n *\n * Reload and refresh are available as methods on the `content` state.\n *\n * ```gjs\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:content as |data state|>\n * <h1>{{data.title}}</h1>\n * {{#if state.isBackgroundReloading}}\n * <SmallSpinner />\n * <button {{on \"click\" state.abort}}>Cancel</button>\n * {{/if}}\n *\n * <button {{on \"click\" state.refresh}}>Refresh</button>\n * <button {{on \"click\" state.reload}}>Reload</button>\n * </:content>\n * </Request>\n * </template>\n * ```\n *\n * ## Advanced Reloading\n *\n * We can nest our usage of `<Request />` to handle more advanced\n * reloading scenarios.\n *\n * ```gjs\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:cancelled>\n * <h2>The Request Cancelled</h2>\n * </:cancelled>\n *\n * <:error as |error|>\n * <ErrorForm @error={{error}} />\n * </:error>\n *\n * <:content as |result state|>\n * <Request @request={{state.latestRequest}}>\n * <!-- Handle Background Request -->\n * </Request>\n *\n * <h1>{{result.title}}</h1>\n *\n * <button {{on \"click\" state.refresh}}>Refresh</button>\n * </:content>\n * </Request>\n * </template>\n * ```\n *\n * ## Autorefresh\n *\n * `<Request />` supports automatic refresh and reload under certain conditions.\n *\n * - `online`: This occurs when a browser window or tab comes back to the foreground\n * after being backgrounded or when the network reports as being online after\n * having been offline.\n * - `interval`: This occurs when a specified amount of time has passed.\n * - `invalid`: This occurs when the store emits a notification that the request\n * has become invalid.\n *\n * You can specify when autorefresh should occur by setting the `autorefresh` arg\n * to `true` or a comma-separated list of the above values.\n *\n * A value of `true` is equivalent to `'online,invalid'`.\n *\n * By default, an autorefresh will only occur if the browser was backgrounded or\n * offline for more than 30s before coming back available. This amount of time can\n * be tweaked by setting the number of milliseconds via `@autorefreshThreshold`.\n *\n * This arg also controls the interval at which the request will be refreshed\n * if the `interval` autorefresh type is enabled.\n *\n * Finally, the behavior of the request initiated by autorefresh can be adjusted\n * by setting the `autorefreshBehavior` arg to `'refresh'`, `'reload'`, or `'policy'`.\n *\n * - `'refresh'`: Refresh the request in the background\n * - `'reload'`: Force a reload of the request\n * - `'policy'` (**default**): Let the store's configured CachePolicy decide whether to\n * reload, refresh, or do nothing.\n *\n * More advanced refresh and reload behaviors can be created by passing the reload and\n * refresh actions into another component. For instance, refresh could be set up on a\n * timer or on a websocket subscription.\n *\n *\n * ```gjs\n * import { Request } from '@warp-drive-mirror/ember';\n *\n * <template>\n * <Request @request={{@request}}>\n * <:content as |result state|>\n * <h1>{{result.title}}</h1>\n *\n * <Interval @period={{30_000}} @fn={{state.refresh}} />\n * <Subscribe @channel={{@someValue}} @fn={{state.refresh}} />\n * </:content>\n * </Request>\n * </template>\n * ```\n *\n * If a matching request is refreshed or reloaded by any other component,\n * the `Request` component will react accordingly.\n *\n * ## Deduping\n *\n * The store dedupes requests by identity. If a request is made for the same identity\n * from multiple `<Request />` components, even if the request is not referentially the\n * same, only one actual request will be made.\n *\n *\n * @class <Request />\n * @public\n */\nexport class Request<T, RT> extends Component<RequestSignature<T, RT>> {\n /**\n * The store instance to use for making requests. If contexts are available, this\n * will be the `store` on the context, else it will be the store service.\n *\n * @internal\n */\n @consume('store') declare _store: Store;\n\n /**\n * Whether the browser reports that the network is online.\n *\n * @internal\n */\n @tracked isOnline = true;\n\n /**\n * Whether the browser reports that the tab is hidden.\n *\n * @internal\n */\n @tracked isHidden = true;\n\n /**\n * Whether the component is currently refreshing the request.\n *\n * @internal\n */\n @tracked isRefreshing = false;\n\n /**\n * The most recent blocking request that was made, typically\n * the result of a reload.\n *\n * This will never be the original request passed as an arg to\n * the component.\n *\n * @internal\n */\n @tracked _localRequest: Future<RT> | undefined;\n\n /**\n * The most recent request that was made, typically due to either a\n * reload or a refresh.\n *\n * This will never be the original request passed as an arg to\n * the component.\n *\n * @internal\n */\n @tracked _latestRequest: Future<RT> | undefined;\n\n /**\n * The time at which the network was reported as offline.\n *\n * @internal\n */\n declare unavailableStart: number | null;\n declare intervalStart: number | null;\n declare nextInterval: number | null;\n declare invalidated: boolean;\n declare isUpdating: boolean;\n\n /**\n * The event listener for network status changes,\n * cached to use the reference for removal.\n *\n * @internal\n */\n declare onlineChanged: (event: Event) => void;\n\n /**\n * The event listener for visibility status changes,\n * cached to use the reference for removal.\n *\n * @internal\n */\n declare backgroundChanged: (event: Event) => void;\n\n /**\n * The last request passed as an arg to the component,\n * cached for comparison.\n *\n * @internal\n */\n declare _originalRequest: Future<RT> | undefined;\n\n /**\n * The last query passed as an arg to the component,\n * cached for comparison.\n *\n * @internal\n */\n declare _originalQuery: StoreRequestInput<T, RT> | undefined;\n\n declare _subscription: object | null;\n declare _subscribedTo: object | null;\n\n constructor(owner: Owner, args: RequestSignature<T, RT>['Args']) {\n super(owner, args);\n this._subscribedTo = null;\n this._subscription = null;\n this.intervalStart = null;\n this.invalidated = false;\n this.nextInterval = null;\n\n this.installListeners();\n void this.beginPolling();\n }\n\n async beginPolling() {\n // await the initial request\n try {\n await this.request;\n } catch {\n // ignore errors here, we just want to wait for the request to finish\n } finally {\n if (!this.isDestroyed) {\n void this.scheduleInterval();\n }\n }\n }\n\n @cached\n get isIdle() {\n const { request, query } = this.args;\n\n return Boolean(!request && !query);\n }\n\n @cached\n get autorefreshTypes(): Set<AutorefreshBehaviorType> {\n const { autorefresh } = this.args;\n let types: AutorefreshBehaviorType[];\n\n if (autorefresh === true) {\n types = ['online', 'invalid'];\n } else if (typeof autorefresh === 'string') {\n types = autorefresh.split(',') as AutorefreshBehaviorType[];\n } else {\n types = [];\n }\n\n return new Set(types);\n }\n\n // we only run this function on component creation\n // and when an update is triggered, so it does not\n // react to changes in the autorefreshThreshold\n // or autorefresh args.\n //\n // if we need to react to those changes, we can\n // use a modifier or internal component or some\n // such to trigger a re-run of this function.\n async scheduleInterval() {\n const { autorefreshThreshold } = this.args;\n const hasValidThreshold = typeof autorefreshThreshold === 'number' && autorefreshThreshold > 0;\n if (\n // dont schedule in SSR\n typeof window === 'undefined' ||\n // dont schedule without a threshold\n !hasValidThreshold ||\n // dont schedule if we weren't told to\n !this.autorefreshTypes.has('interval') ||\n // dont schedule if we're already scheduled\n this.intervalStart !== null\n ) {\n return;\n }\n\n // if we have a current request, wait for it to finish\n // before scheduling the next one\n if (this._latestRequest) {\n try {\n await this._latestRequest;\n } catch {\n // ignore errors here, we just want to wait for the request to finish\n }\n\n if (this.isDestroyed) {\n return;\n }\n }\n\n // setup the next interval\n this.intervalStart = Date.now();\n this.nextInterval = setTimeout(() => {\n this.maybeUpdate();\n }, autorefreshThreshold) as unknown as number;\n }\n\n clearInterval() {\n if (this.nextInterval) {\n clearTimeout(this.nextInterval);\n this.intervalStart = null;\n }\n }\n\n updateSubscriptions() {\n if (this.isIdle) {\n return;\n }\n const requestId = this._request.lid;\n\n // if we're already subscribed to this request, we don't need to do anything\n if (this._subscribedTo === requestId) {\n return;\n }\n\n // if we're subscribed to a different request, we need to unsubscribe\n this.removeSubscriptions();\n\n // if we have a request, we need to subscribe to it\n if (requestId) {\n this._subscribedTo = requestId;\n this._subscription = this.store.notifications.subscribe(\n requestId,\n (_id: StableDocumentIdentifier, op: 'invalidated' | 'state' | 'added' | 'updated' | 'removed') => {\n // ignore subscription events that occur while our own component's request\n // is ocurring\n if (this.isUpdating) {\n return;\n }\n switch (op) {\n case 'invalidated': {\n // if we're subscribed to invalidations, we need to update\n if (this.autorefreshTypes.has('invalid')) {\n this.invalidated = true;\n this.maybeUpdate();\n }\n break;\n }\n case 'state': {\n const latest = this.store.requestManager._deduped.get(requestId);\n const priority = latest?.priority;\n const state = this.reqState;\n if (!priority) {\n // if there is no priority, we have completed whatever request\n // was occurring and so we are no longer refreshing (if we were)\n this.isRefreshing = false;\n } else if (priority.blocking && !state.isLoading) {\n // if we are blocking, there is an active request for this identity\n // that MUST be fulfilled from network (not cache).\n // Thus this is not \"refreshing\" because we should clear out and\n // block on this request.\n //\n // we receive state notifications when either a request initiates\n // or completes.\n //\n // In the completes case: we may receive the state notification\n // slightly before the request is finalized because the NotificationManager\n // may sync flush it (and thus deliver it before the microtask completes)\n //\n // In the initiates case: we aren't supposed to receive one unless there\n // is no other request in flight for this identity.\n //\n // However, there is a race condition here where the completed\n // notification can trigger an update that generates a new request\n // thus giving us an initiated notification before the older request\n // finalizes.\n //\n // When this occurs, if the triggered update happens to have caused\n // a new request to be made for the same identity AND that request\n // is the one passed into this component as the @request arg, then\n // getRequestState will return the state of the new request.\n // We can detect this by checking if the request state is \"loading\"\n // as outside of this case we would have a completed request.\n //\n // That is the reason for the `&& !state.isLoading` check above.\n\n // TODO should we just treat this as refreshing?\n this.isRefreshing = false;\n this.maybeUpdate('policy', true);\n } else {\n this.isRefreshing = true;\n }\n }\n }\n }\n );\n }\n }\n\n removeSubscriptions() {\n if (this._subscription) {\n this.store.notifications.unsubscribe(this._subscription);\n this._subscribedTo = null;\n this._subscription = null;\n }\n }\n\n /**\n * Install the event listeners for network and visibility changes.\n * This is only done in browser environments with a global `window`.\n *\n * @internal\n */\n installListeners() {\n if (typeof window === 'undefined') {\n return;\n }\n\n this.isOnline = window.navigator.onLine;\n this.unavailableStart = this.isOnline ? null : Date.now();\n this.isHidden = document.visibilityState === 'hidden';\n\n this.onlineChanged = (event: Event) => {\n this.isOnline = event.type === 'online';\n if (event.type === 'offline' && this.unavailableStart === null) {\n this.unavailableStart = Date.now();\n }\n this.maybeUpdate();\n };\n this.backgroundChanged = () => {\n const isHidden = document.visibilityState === 'hidden';\n this.isHidden = isHidden;\n\n if (isHidden && this.unavailableStart === null) {\n this.unavailableStart = Date.now();\n }\n\n this.maybeUpdate();\n };\n\n window.addEventListener('online', this.onlineChanged, { passive: true, capture: true });\n window.addEventListener('offline', this.onlineChanged, { passive: true, capture: true });\n document.addEventListener('visibilitychange', this.backgroundChanged, { passive: true, capture: true });\n }\n\n /**\n * If the network is online and the tab is visible, either reload or refresh the request\n * based on the component's configuration and the requested update mode.\n *\n * Valid modes are:\n *\n * - `'reload'`: Force a reload of the request.\n * - `'refresh'`: Refresh the request in the background.\n * - `'policy'`: Make the request, letting the store's configured CachePolicy decide whether to reload, refresh, or do nothing.\n * - `undefined`: Make the request using the component's autorefreshBehavior setting if the autorefreshThreshold has passed.\n *\n * @internal\n */\n maybeUpdate(mode?: 'reload' | 'refresh' | 'policy' | 'invalidated', silent?: boolean): void {\n if (this.isIdle) {\n return;\n }\n const canAttempt = Boolean(this.isOnline && !this.isHidden && (mode || this.autorefreshTypes.size));\n\n if (!canAttempt) {\n if (!silent && mode && mode !== 'invalidated') {\n throw new Error(`Reload not available: the network is not online or the tab is hidden`);\n }\n\n return;\n }\n\n const { autorefreshTypes } = this;\n let shouldAttempt = this.invalidated || Boolean(mode);\n\n if (!shouldAttempt && autorefreshTypes.has('online')) {\n const { unavailableStart } = this;\n const { autorefreshThreshold } = this.args;\n const deadline = typeof autorefreshThreshold === 'number' ? autorefreshThreshold : DEFAULT_DEADLINE;\n shouldAttempt = Boolean(unavailableStart && Date.now() - unavailableStart > deadline);\n }\n\n if (!shouldAttempt && autorefreshTypes.has('interval')) {\n const { intervalStart } = this;\n const { autorefreshThreshold } = this.args;\n\n if (intervalStart && typeof autorefreshThreshold === 'number' && autorefreshThreshold > 0) {\n shouldAttempt = Boolean(Date.now() - intervalStart >= autorefreshThreshold);\n }\n }\n\n this.unavailableStart = null;\n this.invalidated = false;\n\n if (shouldAttempt) {\n this.clearInterval();\n const request = Object.assign({}, this.reqState.request as unknown as RequestInfo<T, RT>);\n const realMode = mode === 'invalidated' ? null : mode;\n const val = realMode ?? this.args.autorefreshBehavior ?? 'policy';\n switch (val) {\n case 'reload':\n request.cacheOptions = Object.assign({}, request.cacheOptions, { reload: true });\n break;\n case 'refresh':\n request.cacheOptions = Object.assign({}, request.cacheOptions, { backgroundReload: true });\n break;\n case 'policy':\n break;\n default:\n throw new Error(\n `Invalid ${mode ? 'update mode' : '@autorefreshBehavior'} for <Request />: ${isNeverString(val)}`\n );\n }\n\n const wasStoreRequest = request[EnableHydration] === true;\n assert(\n `Cannot supply a different store via context than was used to create the request`,\n !request.store || request.store === this.store\n );\n\n this.isUpdating = true;\n this._latestRequest = wasStoreRequest ? this.store.request(request) : this.store.requestManager.request(request);\n\n if (val !== 'refresh') {\n this._localRequest = this._latestRequest;\n }\n\n void this.scheduleInterval();\n void this._latestRequest.finally(() => {\n this.isUpdating = false;\n });\n } else {\n // TODO probably want this\n // void this.scheduleInterval();\n }\n }\n\n /**\n * Retry the request, reloading it from the server.\n *\n * @internal\n */\n retry = async () => {\n this.maybeUpdate('reload');\n await this._localRequest;\n };\n\n /**\n * Refresh the request, updating it in the background.\n *\n * @internal\n */\n refresh = async () => {\n this.maybeUpdate('refresh');\n await this._latestRequest;\n };\n\n @cached\n get errorFeatures() {\n return {\n isHidden: this.isHidden,\n isOnline: this.isOnline,\n retry: this.retry,\n };\n }\n\n @cached\n get contentFeatures() {\n const feat: ContentFeatures<RT> = {\n isHidden: this.isHidden,\n isOnline: this.isOnline,\n reload: this.retry,\n refresh: this.refresh,\n isRefreshing: this.isRefreshing,\n latestRequest: this._latestRequest,\n };\n\n if (feat.isRefreshing) {\n feat.abort = () => {\n this._latestRequest?.abort();\n };\n }\n\n return feat;\n }\n\n willDestroy() {\n this.removeSubscriptions();\n\n if (typeof window === 'undefined') {\n return;\n }\n\n this.clearInterval();\n\n window.removeEventListener('online', this.onlineChanged, { passive: true, capture: true } as unknown as boolean);\n window.removeEventListener('offline', this.onlineChanged, { passive: true, capture: true } as unknown as boolean);\n document.removeEventListener('visibilitychange', this.backgroundChanged, {\n passive: true,\n capture: true,\n } as unknown as boolean);\n }\n\n @cached\n get _request(): Future<RT> {\n const { request, query } = this.args;\n assert(`Cannot use both @request and @query args with the <Request> component`, !request || !query);\n const { _localRequest, _originalRequest, _originalQuery } = this;\n const isOriginalRequest = request === _originalRequest && query === _originalQuery;\n\n if (_localRequest && isOriginalRequest) {\n return _localRequest;\n }\n\n // update state checks for the next time\n this._originalQuery = query;\n this._originalRequest = request;\n\n if (request) {\n return request;\n }\n assert(`You must provide either @request or an @query arg with the <Request> component`, query);\n return this.store.request<RT, T>(query);\n }\n\n @cached\n get request(): Future<RT> {\n const request = this._request;\n this.updateSubscriptions();\n return request;\n }\n\n get store(): Store {\n const store = this.args.store || this._store;\n assert(\n moduleExists('ember-provide-consume-context')\n ? `No store was provided to the <Request> component. Either provide a store via the @store arg or via the context API provided by ember-provide-consume-context.`\n : `No store was provided to the <Request> component. Either provide a store via the @store arg or by registering a store service.`,\n store\n );\n return store;\n }\n\n get reqState() {\n return getRequestState<RT, T>(this.request);\n }\n\n get result() {\n return this.reqState.result as RT;\n }\n\n <template>\n {{#if (and this.isIdle (has-block \"idle\"))}}\n {{yield to=\"idle\"}}\n {{else if this.isIdle}}\n <Throw @error={{IdleBlockMissingError}} />\n {{else if this.reqState.isLoading}}\n {{yield this.reqState.loadingState to=\"loading\"}}\n {{else if (and this.reqState.isCancelled (has-block \"cancelled\"))}}\n {{yield (notNull this.reqState.error) this.errorFeatures to=\"cancelled\"}}\n {{else if (and this.reqState.isError (has-block \"error\"))}}\n {{yield (notNull this.reqState.error) this.errorFeatures to=\"error\"}}\n {{else if this.reqState.isSuccess}}\n {{yield this.result this.contentFeatures to=\"content\"}}\n {{else if (not this.reqState.isCancelled)}}\n <Throw @error={{(notNull this.reqState.error)}} />\n {{/if}}\n {{yield this.reqState to=\"always\"}}\n </template>\n}\n"],"names":["deferred","WeakMap","deferDecorator","proto","prop","desc","map","get","Map","set","findDeferredDecorator","target","_a","cursor","prototype","decorateFieldV2","decorators","initializer","configurable","enumerable","writable","decorator","Object","defineProperty","decorateMethodV2","origDesc","getOwnPropertyDescriptor","value","call","initializeDeferredDecorator","constructor","RequestCache","isAbortError","error","DOMException","name","watchStream","stream","state","reader","getReader","bytesLoaded","shouldForward","_stream","readable","locked","isForwarding","writer","getWriter","buffer","_isPending","_isStarted","_startTime","performance","now","done","read","byteLength","_bytesLoaded","_lastPacketTime","item","ready","write","length","push","close","cancel","endTime","_endTime","_isComplete","RequestLoadingState","_future","_triggered","_trigger","future","promise","getStream","sizeHint","_sizeHint","then","_isCancelled","_isErrored","_error","g","tracked","i","void 0","isPending","TransformStream","isStarted","startTime","lastPacketTime","isComplete","isCancelled","isErrored","elapsedTime","completedRatio","remainingRatio","duration","speed","abort","RequestState","isError","loadingState","getPromiseResult","request","result","response","isLoading","content","isSuccess","setPromiseResult","getRequestState","PromiseCache","PromiseState","LegacyPromiseProxy","Symbol","for","isLegacyAwaitable","getPromise","getPromiseState","_promise","and","x","y","Boolean","Throw","Component","owner","args","setComponentTemplate","precompileTemplate","strictMode","Await","scope","notNull","macroCondition","getGlobalConfig","WarpDrive","env","DEBUG","test","Error","not","DEFAULT_DEADLINE","IdleBlockMissingError","consume","service","moduleExists","contextConsume","importSync","isNeverString","val","Request","unavailableStart","intervalStart","nextInterval","invalidated","isUpdating","onlineChanged","backgroundChanged","_originalRequest","_originalQuery","_subscription","_subscribedTo","installListeners","beginPolling","isDestroyed","scheduleInterval","isIdle","query","n","cached","autorefreshTypes","autorefresh","types","split","Set","autorefreshThreshold","hasValidThreshold","window","has","_latestRequest","Date","setTimeout","maybeUpdate","clearInterval","clearTimeout","updateSubscriptions","requestId","_request","lid","removeSubscriptions","store","notifications","subscribe","_id","op","latest","requestManager","_deduped","priority","reqState","isRefreshing","blocking","unsubscribe","isOnline","navigator","onLine","isHidden","document","visibilityState","event","type","addEventListener","passive","capture","mode","silent","canAttempt","size","shouldAttempt","deadline","assign","realMode","autorefreshBehavior","cacheOptions","reload","backgroundReload","wasStoreRequest","EnableHydration","_localRequest","finally","retry","refresh","errorFeatures","contentFeatures","feat","latestRequest","willDestroy","removeEventListener","isOriginalRequest","_store"],"mappings":"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","x_google_ignoreList":[0]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@warp-drive-mirror/ember",
3
3
  "description": "Data bindings and utilities for Ember applications using WarpDrive",
4
- "version": "5.4.0-alpha.151",
4
+ "version": "5.4.0-alpha.153",
5
5
  "license": "MIT",
6
6
  "author": "Chris Thoburn <runspired@users.noreply.github.com>",
7
7
  "repository": {
@@ -35,17 +35,17 @@
35
35
  },
36
36
  "peerDependencies": {
37
37
  "ember-source": "3.28.12 || ^4.0.4 || ^5.0.0 || ^6.0.0",
38
- "@ember-data-mirror/store": "5.4.0-alpha.151",
39
- "@ember-data-mirror/request": "5.4.0-alpha.151",
40
- "@ember-data-mirror/request-utils": "5.4.0-alpha.151",
41
- "@warp-drive-mirror/core-types": "5.4.0-alpha.151",
38
+ "@ember-data-mirror/store": "5.4.0-alpha.153",
39
+ "@ember-data-mirror/request": "5.4.0-alpha.153",
40
+ "@ember-data-mirror/request-utils": "5.4.0-alpha.153",
41
+ "@warp-drive-mirror/core-types": "5.4.0-alpha.153",
42
42
  "ember-provide-consume-context": "^0.7.0",
43
- "@ember-data-mirror/tracking": "5.4.0-alpha.151"
43
+ "@ember-data-mirror/tracking": "5.4.0-alpha.153"
44
44
  },
45
45
  "dependencies": {
46
46
  "@ember/test-waiters": "^3.1.0 || ^4.0.0",
47
- "@embroider/macros": "^1.16.11",
48
- "@warp-drive-mirror/build-config": "5.4.0-alpha.151"
47
+ "@embroider/macros": "^1.16.12",
48
+ "@warp-drive-mirror/build-config": "5.4.0-alpha.153"
49
49
  },
50
50
  "peerDependenciesMeta": {
51
51
  "ember-provide-consume-context": {
@@ -53,33 +53,33 @@
53
53
  }
54
54
  },
55
55
  "devDependencies": {
56
- "@babel/core": "^7.26.9",
57
- "@babel/plugin-transform-typescript": "^7.26.8",
56
+ "@babel/core": "^7.26.10",
57
+ "@babel/plugin-transform-typescript": "^7.27.0",
58
58
  "@babel/preset-env": "^7.26.9",
59
- "@babel/preset-typescript": "^7.26.0",
60
- "@babel/runtime": "^7.26.9",
61
- "@glimmer/component": "^1.1.2",
59
+ "@babel/preset-typescript": "^7.27.0",
60
+ "@babel/runtime": "^7.27.0",
61
+ "@glimmer/component": "^2.0.0",
62
62
  "@glimmer/tracking": "^1.1.2",
63
- "@glimmer/validator": "^0.94.6",
63
+ "@glimmer/validator": "^0.94.8",
64
64
  "@glint/core": "1.5.2",
65
65
  "@glint/environment-ember-loose": "1.5.2",
66
66
  "@glint/environment-ember-template-imports": "1.5.2",
67
67
  "@glint/template": "1.5.2",
68
68
  "decorator-transforms": "^2.3.0",
69
- "@embroider/addon-dev": "^7.1.1",
70
- "@ember-data-mirror/request": "5.4.0-alpha.151",
71
- "@ember-data-mirror/request-utils": "5.4.0-alpha.151",
72
- "@ember-data-mirror/store": "5.4.0-alpha.151",
73
- "@ember-data-mirror/tracking": "5.4.0-alpha.151",
74
- "@ember/test-helpers": "5.1.0",
75
- "@warp-drive-mirror/core-types": "5.4.0-alpha.151",
76
- "@warp-drive/internal-config": "5.4.0-alpha.151",
77
- "babel-plugin-ember-template-compilation": "^2.3.0",
69
+ "@embroider/addon-dev": "^7.1.3",
70
+ "@ember-data-mirror/request": "5.4.0-alpha.153",
71
+ "@ember-data-mirror/request-utils": "5.4.0-alpha.153",
72
+ "@ember-data-mirror/store": "5.4.0-alpha.153",
73
+ "@ember-data-mirror/tracking": "5.4.0-alpha.153",
74
+ "@ember/test-helpers": "5.2.0",
75
+ "@warp-drive-mirror/core-types": "5.4.0-alpha.153",
76
+ "@warp-drive/internal-config": "5.4.0-alpha.153",
77
+ "babel-plugin-ember-template-compilation": "^2.4.1",
78
78
  "ember-template-imports": "^4.3.0",
79
- "ember-source": "~5.12.0",
80
- "rollup": "^4.34.9",
79
+ "ember-source": "~6.3.0",
80
+ "rollup": "^4.37.0",
81
81
  "typescript": "^5.8.2",
82
- "vite": "^5.4.14",
82
+ "vite": "^5.4.15",
83
83
  "ember-provide-consume-context": "^0.7.0"
84
84
  },
85
85
  "engines": {
@@ -2,6 +2,7 @@ declare module '@warp-drive-mirror/ember/-private/await' {
2
2
  /**
3
3
  * @module @warp-drive-mirror/ember
4
4
  */
5
+ import type Owner from '@ember/owner';
5
6
  import Component from '@glimmer/component';
6
7
  import type { Awaitable } from '@ember-data-mirror/request';
7
8
  export const and: (x: unknown, y: unknown) => boolean;
@@ -24,7 +25,7 @@ declare module '@warp-drive-mirror/ember/-private/await' {
24
25
  * @public
25
26
  */
26
27
  export class Throw<T> extends Component<ThrowSignature<T>> {
27
- constructor(owner: unknown, args: ThrowSignature<T>['Args']);
28
+ constructor(owner: Owner, args: ThrowSignature<T>['Args']);
28
29
  }
29
30
  interface AwaitSignature<T, E = Error | string | object> {
30
31
  Args: {
@@ -1 +1 @@
1
- {"version":3,"file":"await.d.ts","sourceRoot":"","sources":["../../src/-private/await.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,SAAS,MAAM,oBAAoB,CAAC;AAE3C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAIrD,eAAO,MAAM,GAAG,GAAI,GAAG,OAAO,EAAE,GAAG,OAAO,YAAoB,CAAC;AAC/D,UAAU,cAAc,CAAC,CAAC,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM;IAClD,IAAI,EAAE;QACJ,KAAK,EAAE,CAAC,CAAC;KACV,CAAC;CACH;AAED;;;;;;;;;;;;GAYG;AACH,qBAAa,KAAK,CAAC,CAAC,CAAE,SAAQ,SAAS,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;gBAC5C,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;CAU5D;AAED,UAAU,cAAc,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM;IACrD,IAAI,EAAE;QACJ,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;KACvC,CAAC;IACF,MAAM,EAAE;QACN,OAAO,EAAE,EAAE,CAAC;QACZ,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAClB,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;KACrB,CAAC;CACH;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AACH,qBAAa,KAAK,CAAC,CAAC,EAAE,CAAC,CAAE,SAAQ,SAAS,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC9D,IAAI,KAAK,oDAER;IAED,IAAI,KAAK,IACoB,CAAC,CAC7B;IAED,IAAI,MAAM,IACoB,CAAC,CAC9B;CAqBF"}
1
+ {"version":3,"file":"await.d.ts","sourceRoot":"","sources":["../../src/-private/await.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,SAAS,MAAM,oBAAoB,CAAC;AAE3C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAIrD,eAAO,MAAM,GAAG,GAAI,GAAG,OAAO,EAAE,GAAG,OAAO,YAAoB,CAAC;AAC/D,UAAU,cAAc,CAAC,CAAC,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM;IAClD,IAAI,EAAE;QACJ,KAAK,EAAE,CAAC,CAAC;KACV,CAAC;CACH;AAED;;;;;;;;;;;;GAYG;AACH,qBAAa,KAAK,CAAC,CAAC,CAAE,SAAQ,SAAS,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;gBAC5C,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;CAU1D;AAED,UAAU,cAAc,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM;IACrD,IAAI,EAAE;QACJ,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;KACvC,CAAC;IACF,MAAM,EAAE;QACN,OAAO,EAAE,EAAE,CAAC;QACZ,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAClB,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;KACrB,CAAC;CACH;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AACH,qBAAa,KAAK,CAAC,CAAC,EAAE,CAAC,CAAE,SAAQ,SAAS,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC9D,IAAI,KAAK,oDAER;IAED,IAAI,KAAK,IACoB,CAAC,CAC7B;IAED,IAAI,MAAM,IACoB,CAAC,CAC9B;CAqBF"}
@@ -1,4 +1,8 @@
1
1
  declare module '@warp-drive-mirror/ember/-private/request' {
2
+ /**
3
+ * @module @warp-drive-mirror/ember
4
+ */
5
+ import type Owner from '@ember/owner';
2
6
  import Component from '@glimmer/component';
3
7
  import type { Future, StructuredErrorDocument } from '@ember-data-mirror/request';
4
8
  import type { StoreRequestInput } from '@ember-data-mirror/store';
@@ -439,7 +443,7 @@ declare module '@warp-drive-mirror/ember/-private/request' {
439
443
  _originalQuery: StoreRequestInput<T, RT> | undefined;
440
444
  _subscription: object | null;
441
445
  _subscribedTo: object | null;
442
- constructor(owner: unknown, args: RequestSignature<T, RT>['Args']);
446
+ constructor(owner: Owner, args: RequestSignature<T, RT>['Args']);
443
447
  beginPolling(): Promise<void>;
444
448
  get isIdle(): boolean;
445
449
  get autorefreshTypes(): Set<AutorefreshBehaviorType>;
@@ -1 +1 @@
1
- {"version":3,"file":"request.d.ts","sourceRoot":"","sources":["../../src/-private/request.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"request.d.ts","sourceRoot":"","sources":["../../src/-private/request.ts"],"names":[],"mappings":"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"}