https://github.com/megazazik/react-context-refs
  
  
    Functions for getting refs of elements via context 
    https://github.com/megazazik/react-context-refs
  
        Last synced: 6 months ago 
        JSON representation
    
Functions for getting refs of elements via context
- Host: GitHub
- URL: https://github.com/megazazik/react-context-refs
- Owner: megazazik
- License: mit
- Created: 2019-09-24T20:06:15.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-08-14T15:08:49.000Z (about 1 year ago)
- Last Synced: 2025-04-18T02:38:36.847Z (6 months ago)
- Language: TypeScript
- Homepage:
- Size: 235 KB
- Stars: 21
- Watchers: 2
- Forks: 3
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
 
Awesome Lists containing this project
- fucking-awesome-react-hooks - `react-context-refs`
- awesome-react-hooks-cn - `react-context-refs`
- awesome-react-hooks - `react-context-refs`
- awesome-react-hooks - `react-context-refs`
README
          # react-context-refs
[](https://badge.fury.io/js/react-context-refs)
Library to get react refs via context. For example it can be useful when you need to scroll or set focus to some field after form validation and you have a deep nested components hierarchy.
## Fields focus example
First, you should add `RefProvider`.
main.js
```jsx
import * as React from "react";
import { render } from "ract-dom";
import { RefProvider } from "react-context-refs";
import Page from "./form";
// ...
render(
  
    
  ,
  element
);
```
Then you need to add each field to context refs storage. You can add some metadata to your refs. In this example we add `hasError` property to refs.
someField.js
```jsx
import * as React from "react";
import { useContextRef } from "react-context-refs";
export default ({ value, onChange, hasError }) => {
  const setRef = useContextRef({ hasError });
  return (
    
  );
};
```
And then in some root component you can get all refs and set focus to any of them.
```jsx
import * as React from "react";
import { useRefs } from "react-context-refs";
import { compareOrder } from "sort-nodes";
// ...
export default props => {
  // ...
  const refs = useRefs();
  const onSubmit = () => {
    if (!isFormValid()) {
      const firstFieldWithError = refs
        // remove fields without errors
        .filter(ref => ref.meta.hasError)
        // get current value of refs
        .map(ref => ref.current)
        // sort by order in dom tree
        .sort(compareOrder)[0];
      firstFieldWithError.focus();
      return;
    }
    // ...
  };
  return ;
};
```
## API
### RefProvider
This provider creates a storage of refs and let you use other methods of `react-context-refs`.
A storage contains an array of refs and two additional fields for each ref: `type` and `meta`.
### useRefs
`useRefs` returns an array of refs from the storage. Each ref has the following fields:
- _current_ - value of ref
- _type_ - string to determine type of ref if there are several types of ref in the storage
- _meta_ - any additional data
You can use `useRefs` without parameters or you can pass a string to `useRefs` and it will return only refs of the corresponding type.
```js
import { useRefs } from "react-context-refs";
// ...
const myInputs = useRefs("my-input");
```
### useContextRef
This hook returns a method to set ref.
You add pass a metadata to ref or a metadata and type.
The first form of `useContextRef` has the only parameter - `meta`.
The second has two parameters:
- `type` _string_
- `meta` _any_
```js
import { useContextRef } from "react-context-refs";
// ...
const setRef = useContextRef("my-ref-type", { additionalValue: true });
```
### Typings (typescript)
If you want to add strong types to your refs you can set type of `current` and `meta` for each `type`.
You can do it with this code:
```ts
declare module ReactContextRefs {
  export interface Refs {
    myInput: { current: HTMLInputElement; meta: { hasError: boolean } };
  }
}
```
Here we has set types of `current` and `meta` for each ref which has type `myInput`.
```ts
import { useRefs } from "react-context-refs";
// now myInputs has type an array of
// {
// 	type: "myInput",
// 	current: HTMLInputElement,
// 	meta: {hasError: boolean},
// }
const myInputs = useRefs("myInput");
```