Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
wip
Browse files Browse the repository at this point in the history
NullVoxPopuli committed Oct 11, 2024
1 parent 81a90ce commit 735f543
Showing 6 changed files with 14 additions and 8 deletions.
1 change: 1 addition & 0 deletions ember-resources/package.json
Original file line number Diff line number Diff line change
@@ -38,6 +38,7 @@
"start": "pnpm vite build --watch",
"build": "pnpm vite build",
"lint": "concurrently 'npm:lint:*(!fix)' --names 'lint:'",
"lint:types": "tsc --noEmit",
"lint:fix": "concurrently 'npm:lint:*:fix' --names 'fix:'",
"lint:js": "eslint . --cache",
"lint:prettier": "prettier --check '**/*.{js,ts}'",
10 changes: 5 additions & 5 deletions ember-resources/src/function-based/resource.ts
Original file line number Diff line number Diff line change
@@ -7,7 +7,7 @@ import { ResourceManagerFactory } from './manager.ts';
import { INTERNAL } from './types.ts';
import { wrapForPlainUsage } from './utils.ts';

import type { InternalFunctionResourceConfig, ResourceFn, ResourceFunction } from './types.ts';
import type { InternalFunctionResourceConfig, Resource, ResourceFunction } from './types.ts';

const TYPE = 'function-based';

@@ -111,7 +111,7 @@ registerUsable(TYPE, (context: object, config: InternalFunctionResourceConfig) =
* </template>
* ```
*/
export function resource<Value>(setup: ResourceFunction<Value>): Value;
export function resource<Value>(setup: ResourceFunction<Value>): Resource<Value>;

/**
* `resource` is an alternative API to the class-based `Resource`.
@@ -167,14 +167,14 @@ export function resource<Value>(setup: ResourceFunction<Value>): Value;
* }
* ```
*/
export function resource<Value>(context: object, setup: ResourceFunction<Value>): Value;
export function resource<Value>(context: object, setup: ResourceFunction<Value>): Resource<Value>;

/**
*/
export function resource<Value>(
context: object | ResourceFunction<Value>,
setup?: ResourceFunction<Value>,
): Value | InternalFunctionResourceConfig<Value> | ResourceFn<Value> {
): Value | InternalFunctionResourceConfig<Value> | Resource<Value> {
if (!setup) {
assert(
`When using \`resource\` with @use, ` +
@@ -205,7 +205,7 @@ export function resource<Value>(
* using vanilla functions as resources without the resource wrapper
*
*/
return internalConfig as unknown as ResourceFn<Value>;
return internalConfig as unknown as Resource<Value>;
}

assert(
6 changes: 5 additions & 1 deletion ember-resources/src/function-based/types.ts
Original file line number Diff line number Diff line change
@@ -131,7 +131,11 @@ export type ResourceFunction<Value = unknown> = (hooks: ResourceAPI) => Value |
* of the resource is the result of the collapsed functions
* passed to `resource`
*/
export type ResourceFn<Value = unknown> = Value & ((hooks: ResourceAPI) => Value);
export interface Invokable<Value = unknown> extends Reactive<Value> {
(hooks: ResourceAPI): Value;
}

export type Resource<Value = unknown> = Value & Invokable<Value>;

export type Destructor = () => void;
export type Cache = object;
2 changes: 1 addition & 1 deletion ember-resources/src/index.ts
Original file line number Diff line number Diff line change
@@ -5,4 +5,4 @@ export { registerUsable, use } from './use.ts';

// Public Type Utilities
export type { ResourceAPI } from './function-based/index.ts';
export type { Reactive } from './function-based/types.ts';
export type { Reactive, Resource } from './function-based/types.ts';
1 change: 1 addition & 0 deletions test-app/package.json
Original file line number Diff line number Diff line change
@@ -12,6 +12,7 @@
},
"scripts": {
"lint": "concurrently 'npm:lint:*(!fix)' --names 'lint:'",
"lint:types": "glint",
"lint:fix": "concurrently 'npm:lint:*:fix' --names 'fix:'",
"lint:hbs": "ember-template-lint . --no-error-on-unmatched-pattern",
"lint:js": "eslint . --cache",
2 changes: 1 addition & 1 deletion test-app/tests/type-tests/function-based.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { resource } from 'ember-resources';
import { type Resource, resource } from 'ember-resources';
import { expectTypeOf } from 'expect-type';
import { expectType } from 'ts-expect';

0 comments on commit 735f543

Please sign in to comment.