Skip to content

Commit

Permalink
Remove react-merge-refs dependency
Browse files Browse the repository at this point in the history
  • Loading branch information
cgero-eth committed Feb 6, 2024
1 parent d332f7e commit 52bc8cd
Show file tree
Hide file tree
Showing 9 changed files with 43 additions and 8 deletions.
3 changes: 1 addition & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -54,8 +54,7 @@
"classnames": "^2.0.0",
"react": "^18.0.0",
"react-dom": "^18.0.0",
"react-imask": "^7.3.0",
"react-merge-refs": "^2.0.0"
"react-imask": "^7.3.0"
},
"peerDependencies": {
"@tailwindcss/typography": "^0.5.0",
Expand Down
4 changes: 2 additions & 2 deletions src/components/input/inputDate/inputDate.test.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import { fireEvent, render, screen, within } from '@testing-library/react';
import React from 'react';
import * as MergeRefs from 'react-merge-refs';
import * as Utils from '../../../utils';
import { IconType } from '../../icon';
import { InputDate, type IInputDateProps } from './inputDate';

describe('<InputDate /> component', () => {
const useRefMock = jest.spyOn(React, 'useRef');
const mergeRefMock = jest.spyOn(MergeRefs, 'mergeRefs');
const mergeRefMock = jest.spyOn(Utils, 'mergeRefs');

afterEach(() => {
useRefMock.mockReset();
Expand Down
2 changes: 1 addition & 1 deletion src/components/input/inputDate/inputDate.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import classNames from 'classnames';
import { forwardRef, useRef } from 'react';
import { mergeRefs } from 'react-merge-refs';
import { mergeRefs } from '../../../utils';
import { Button } from '../../button';
import { IconType } from '../../icon';
import { useInputProps } from '../hooks';
Expand Down
4 changes: 2 additions & 2 deletions src/components/input/inputTime/inputTime.test.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import { fireEvent, render, screen, within } from '@testing-library/react';
import React from 'react';
import * as MergeRefs from 'react-merge-refs';
import * as Utils from '../../../utils';
import { IconType } from '../../icon';
import { InputTime, type IInputTimeProps } from './inputTime';

describe('<InputTime /> component', () => {
const useRefMock = jest.spyOn(React, 'useRef');
const mergeRefMock = jest.spyOn(MergeRefs, 'mergeRefs');
const mergeRefMock = jest.spyOn(Utils, 'mergeRefs');

afterEach(() => {
useRefMock.mockReset();
Expand Down
2 changes: 1 addition & 1 deletion src/components/input/inputTime/inputTime.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import classNames from 'classnames';
import { forwardRef, useRef } from 'react';
import { mergeRefs } from 'react-merge-refs';
import { mergeRefs } from '../../../utils';
import { Button } from '../../button';
import { IconType } from '../../icon';
import { useInputProps } from '../hooks';
Expand Down
1 change: 1 addition & 0 deletions src/utils/index.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
export * from './formatterUtils';
export * from './mergeRefs';
export * from './responsiveUtils';
1 change: 1 addition & 0 deletions src/utils/mergeRefs/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export { mergeRefs } from './mergeRefs';
19 changes: 19 additions & 0 deletions src/utils/mergeRefs/mergeRefs.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
import { mergeRefs } from './mergeRefs';

describe('mergeRefs util', () => {
it('correctly set value for function refs', () => {
const functionRef = jest.fn();
const value = 'test';
const refSetter = mergeRefs([functionRef]);
refSetter(value);
expect(functionRef).toHaveBeenCalledWith(value);
});

it('correctly set value for mutable ref object', () => {
const mutableRef = { current: null };
const value = 'new-value';
const refSetter = mergeRefs<string | null>([mutableRef]);
refSetter(value);
expect(mutableRef.current).toEqual(value);
});
});
15 changes: 15 additions & 0 deletions src/utils/mergeRefs/mergeRefs.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
import type { LegacyRef, MutableRefObject, RefCallback } from 'react';

export const mergeRefs = <T = unknown>(
refs: Array<MutableRefObject<T> | LegacyRef<T> | undefined | null>,
): RefCallback<T> => {
return (value) => {
refs.forEach((ref) => {
if (typeof ref === 'function') {
ref(value);
} else if (ref != null) {
(ref as MutableRefObject<T | null>).current = value;
}
});
};
};

0 comments on commit 52bc8cd

Please sign in to comment.