Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TypeScript: Convert factory utils in data package to TS #67667

Merged
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion packages/core-data/src/private-selectors.ts
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ export function getEntityRecordPermissions(
name: string,
id: string
) {
return getEntityRecordsPermissions( state, kind, name, id )[ 0 ];
return getEntityRecordsPermissions( state, kind, name, [ id ] )[ 0 ];
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need to update the getEntityRecordsPermissions types instead of changing the passed argument. It accepts string|string[].

I know it's a bit odd, but that's due to the limitations of memoized selectors. Current change regresses #64091.

Screenshot

CleanShot 2024-12-09 at 21 37 59

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I had done exactly that here #67667 (comment)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But it was reverted in 9a5a859, causing the regression.

Also, I'm not sure if I fully understand the reason for reverting. These are private selectors; they can only be consumed in the core.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'll create a follow up PR to address that. Thanks.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you, @manzoorwanijk!

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

}

/**
Expand Down
17 changes: 4 additions & 13 deletions packages/data/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -418,11 +418,11 @@ When registering a control created with `createRegistryControl` with a store, th

_Parameters_

- _registryControl_ `Function`: Function receiving a registry object and returning a control.
- _registryControl_ `T & { isRegistryControl?: boolean; }`: Function receiving a registry object and returning a control.

_Returns_

- `Function`: Registry control that can be registered with a store.
- Registry control that can be registered with a store.

### createRegistrySelector

Expand Down Expand Up @@ -471,11 +471,11 @@ with a store.

_Parameters_

- _registrySelector_ `Function`: Function receiving a registry `select` function and returning a state selector.
- _registrySelector_ `( select: ) => Selector`: Function receiving a registry `select` function and returning a state selector.

_Returns_

- `Function`: Registry selector that can be registered with a store.
- `Selector`: Registry selector that can be registered with a store.

### createSelector

Expand All @@ -485,15 +485,6 @@ _Related_

- The documentation for the `rememo` package from which the `createSelector` function is reexported.

_Parameters_

- _selector_ `Function`: Selector function that calculates a value from state and parameters.
- _getDependants_ `Function`: Function that returns an array of "dependant" objects.

_Returns_

- `Function`: A memoized version of `selector` that caches the calculated return values.

### dispatch

Given a store descriptor, returns an object of the store's action creators. Calling an action creator will cause it to be dispatched, updating the state value accordingly.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,5 @@
* and the selector parameters, and recomputes the values only when any of them changes.
*
* @see The documentation for the `rememo` package from which the `createSelector` function is reexported.
*
* @param {Function} selector Selector function that calculates a value from state and parameters.
* @param {Function} getDependants Function that returns an array of "dependant" objects.
* @return {Function} A memoized version of `selector` that caches the calculated return values.
*/
export { default as createSelector } from 'rememo';
35 changes: 24 additions & 11 deletions packages/data/src/factory.js → packages/data/src/factory.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
/**
* Internal dependencies
*/
import type { select as globalSelect } from './select';

/**
* Creates a selector function that takes additional curried argument with the
* registry `select` function. While a regular selector has signature
Expand Down Expand Up @@ -33,17 +38,25 @@
* registry as argument. The registry binding happens automatically when registering the selector
* with a store.
*
* @param {Function} registrySelector Function receiving a registry `select`
* function and returning a state selector.
* @param registrySelector Function receiving a registry `select`
* function and returning a state selector.
*
* @return {Function} Registry selector that can be registered with a store.
* @return Registry selector that can be registered with a store.
*/
export function createRegistrySelector( registrySelector ) {
export function createRegistrySelector<
Selector extends ( ...args: any[] ) => any,
>( registrySelector: ( select: typeof globalSelect ) => Selector ): Selector {
type WrappedSelector = {
manzoorwanijk marked this conversation as resolved.
Show resolved Hide resolved
( ...args: Parameters< Selector > ): ReturnType< Selector >;
isRegistrySelector: boolean;
registry?: any;
};

const selectorsByRegistry = new WeakMap();
// Create a selector function that is bound to the registry referenced by `selector.registry`
// and that has the same API as a regular selector. Binding it in such a way makes it
// possible to call the selector directly from another selector.
const wrappedSelector = ( ...args ) => {
const wrappedSelector: WrappedSelector = ( ...args ) => {
let selector = selectorsByRegistry.get( wrappedSelector.registry );
// We want to make sure the cache persists even when new registry
// instances are created. For example patterns create their own editors
Expand All @@ -60,12 +73,10 @@ export function createRegistrySelector( registrySelector ) {
* Flag indicating that the selector is a registry selector that needs the correct registry
* reference to be assigned to `selector.registry` to make it work correctly.
* be mapped as a registry selector.
*
* @type {boolean}
*/
wrappedSelector.isRegistrySelector = true;

return wrappedSelector;
return wrappedSelector as unknown as Selector;
manzoorwanijk marked this conversation as resolved.
Show resolved Hide resolved
}

/**
Expand All @@ -84,11 +95,13 @@ export function createRegistrySelector( registrySelector ) {
* When registering a control created with `createRegistryControl` with a store, the store
* knows which calling convention to use when executing the control.
*
* @param {Function} registryControl Function receiving a registry object and returning a control.
* @param registryControl Function receiving a registry object and returning a control.
*
* @return {Function} Registry control that can be registered with a store.
* @return Registry control that can be registered with a store.
*/
export function createRegistryControl( registryControl ) {
export function createRegistryControl< T extends ( ...args: any ) => any >(
registryControl: T & { isRegistryControl?: boolean }
) {
registryControl.isRegistryControl = true;

return registryControl;
Expand Down
Loading