react-resize-detector-context 0.0.0
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/LICENSE +21 -0
- package/README.md +206 -0
- package/dist/index.d.mts +85 -0
- package/dist/index.d.ts +85 -0
- package/dist/index.js +2 -0
- package/dist/index.mjs +2 -0
- package/package.json +106 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2025 Christopher Schwarz
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
|
|
2
|
+
# React Resize Detector Context
|
|
3
|
+
|
|
4
|
+

|
|
5
|
+
|
|
6
|
+
A lightweight React context that leverages [react-resize-detector](https://github.com/maslianok/react-resize-detector) to detect the current breakpoint based on an element's width. It provides utility functions and helper components to conditionally render content based on responsive breakpoints.
|
|
7
|
+
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
## Features
|
|
11
|
+
|
|
12
|
+
- Dynamically detects the current breakpoint based on element width.
|
|
13
|
+
- Supports custom breakpoint names (e.g., "XS", "SM", "MD", "LG", "XL" or any arbitrary names like "Smart", "Mini", etc.).
|
|
14
|
+
- Utility functions:
|
|
15
|
+
- `isAtLeast(breakpoint)`: Returns `true` if the current breakpoint is greater than or equal to the provided one.
|
|
16
|
+
- `isBelow(breakpoint)`: Returns `true` if the current breakpoint is less than the provided one.
|
|
17
|
+
- `valueByBreakpoint(mapping)`: Returns a value from the provided mapping based on the current breakpoint.
|
|
18
|
+
- Helper component `BreakpointConditional` for conditional rendering.
|
|
19
|
+
- Error logging for invalid configurations (e.g. duplicate values, width not set, etc.).
|
|
20
|
+
- Fully typed in TypeScript with comprehensive IDE support.
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
## Requirements
|
|
25
|
+
|
|
26
|
+
- **Node.js**: >= 18.0.0
|
|
27
|
+
- **React**: >= 17
|
|
28
|
+
- **React-DOM**: >= 17
|
|
29
|
+
|
|
30
|
+
---
|
|
31
|
+
|
|
32
|
+
## Installation
|
|
33
|
+
|
|
34
|
+
Install via npm:
|
|
35
|
+
|
|
36
|
+
```
|
|
37
|
+
npm install react-resize-detector-context
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
---
|
|
41
|
+
|
|
42
|
+
## Usage
|
|
43
|
+
|
|
44
|
+
### Basic Usage
|
|
45
|
+
|
|
46
|
+
Wrap your component tree with the `BreakpointProvider` and provide a breakpoint configuration. Then, access the current breakpoint and utility functions via the `useBreakpoint` hook.
|
|
47
|
+
|
|
48
|
+
```typescript
|
|
49
|
+
import React from 'react';
|
|
50
|
+
import { BreakpointProvider, useBreakpoint } from 'react-resize-detector-context';
|
|
51
|
+
|
|
52
|
+
const breakpoints = {
|
|
53
|
+
XS: 0,
|
|
54
|
+
SM: 500,
|
|
55
|
+
MD: 700,
|
|
56
|
+
LG: 900,
|
|
57
|
+
XL: 1100,
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
const ResponsiveComponent = () => {
|
|
61
|
+
const { width, breakpoint, isAtLeast, valueByBreakpoint } = useBreakpoint();
|
|
62
|
+
return (
|
|
63
|
+
<div>
|
|
64
|
+
<p>Current width: {width}px</p>
|
|
65
|
+
<p>Current breakpoint: {breakpoint}</p>
|
|
66
|
+
<p>Is at least MD: {isAtLeast('MD') ? '✅' : '❌'}</p>
|
|
67
|
+
<p>
|
|
68
|
+
Mapping: {valueByBreakpoint({
|
|
69
|
+
XS: 'Extra Small',
|
|
70
|
+
SM: 'Small',
|
|
71
|
+
MD: 'Medium',
|
|
72
|
+
LG: 'Large',
|
|
73
|
+
XL: 'Extra Large'
|
|
74
|
+
})}
|
|
75
|
+
</p>
|
|
76
|
+
</div>
|
|
77
|
+
);
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
const App = () => (
|
|
81
|
+
<BreakpointProvider breakpoints={breakpoints}>
|
|
82
|
+
<ResponsiveComponent />
|
|
83
|
+
</BreakpointProvider>
|
|
84
|
+
);
|
|
85
|
+
|
|
86
|
+
export default App;
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
---
|
|
90
|
+
|
|
91
|
+
### Conditional Rendering with BreakpointConditional
|
|
92
|
+
|
|
93
|
+
Use `BreakpointConditional` to render content only when certain breakpoint conditions are met.
|
|
94
|
+
|
|
95
|
+
```typescript
|
|
96
|
+
import React from 'react';
|
|
97
|
+
import { BreakpointProvider, BreakpointConditional } from 'react-resize-detector-context';
|
|
98
|
+
|
|
99
|
+
const breakpoints = {
|
|
100
|
+
XS: 0,
|
|
101
|
+
SM: 500,
|
|
102
|
+
MD: 700,
|
|
103
|
+
LG: 900,
|
|
104
|
+
XL: 1100,
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
const ConditionalComponent = () => (
|
|
108
|
+
<div>
|
|
109
|
+
<BreakpointConditional isAtLeast="MD">
|
|
110
|
+
<p>😊 This content is visible from MD and up.</p>
|
|
111
|
+
</BreakpointConditional>
|
|
112
|
+
<BreakpointConditional isBelow="LG">
|
|
113
|
+
<p>🚀 This content is visible for breakpoints below LG.</p>
|
|
114
|
+
</BreakpointConditional>
|
|
115
|
+
</div>
|
|
116
|
+
);
|
|
117
|
+
|
|
118
|
+
const App = () => (
|
|
119
|
+
<BreakpointProvider breakpoints={breakpoints}>
|
|
120
|
+
<ConditionalComponent />
|
|
121
|
+
</BreakpointProvider>
|
|
122
|
+
);
|
|
123
|
+
|
|
124
|
+
export default App;
|
|
125
|
+
```
|
|
126
|
+
|
|
127
|
+
---
|
|
128
|
+
|
|
129
|
+
### Custom Breakpoints Example
|
|
130
|
+
|
|
131
|
+
You can define your own custom breakpoints with any names. For instance, using car sizes:
|
|
132
|
+
|
|
133
|
+
```typescript
|
|
134
|
+
import React from 'react';
|
|
135
|
+
import { BreakpointProvider, useBreakpoint } from 'react-resize-detector-context';
|
|
136
|
+
|
|
137
|
+
const carBreakpoints = {
|
|
138
|
+
Smart: 0,
|
|
139
|
+
Mini: 350,
|
|
140
|
+
Sedan: 600,
|
|
141
|
+
SUV: 900,
|
|
142
|
+
Ram: 1200,
|
|
143
|
+
};
|
|
144
|
+
|
|
145
|
+
const CarComponent = () => {
|
|
146
|
+
const { width, breakpoint, valueByBreakpoint } = useBreakpoint();
|
|
147
|
+
return (
|
|
148
|
+
<div>
|
|
149
|
+
<p>Current width: {width}px</p>
|
|
150
|
+
<p>Current car size: {breakpoint}</p>
|
|
151
|
+
<p>
|
|
152
|
+
Mapping: {valueByBreakpoint({
|
|
153
|
+
Smart: '🚗 Smart',
|
|
154
|
+
Mini: '🚙 Mini',
|
|
155
|
+
Sedan: '🚘 Sedan',
|
|
156
|
+
SUV: '🚐 SUV',
|
|
157
|
+
Ram: '🚚 Ram'
|
|
158
|
+
})}
|
|
159
|
+
</p>
|
|
160
|
+
</div>
|
|
161
|
+
);
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
const App = () => (
|
|
165
|
+
<BreakpointProvider breakpoints={carBreakpoints}>
|
|
166
|
+
<CarComponent />
|
|
167
|
+
</BreakpointProvider>
|
|
168
|
+
);
|
|
169
|
+
|
|
170
|
+
export default App;
|
|
171
|
+
```
|
|
172
|
+
|
|
173
|
+
---
|
|
174
|
+
|
|
175
|
+
## Available Scripts
|
|
176
|
+
|
|
177
|
+
You can use the following scripts from your command line:
|
|
178
|
+
|
|
179
|
+
- **`npm run build`**
|
|
180
|
+
Builds the package (using [tsup](https://github.com/egoist/tsup)).
|
|
181
|
+
|
|
182
|
+
- **`npm run dev`**
|
|
183
|
+
Runs development mode concurrently with build watch, Storybook, and tests.
|
|
184
|
+
|
|
185
|
+
- **`npm run storybook`**
|
|
186
|
+
Launches Storybook for interactive component demos on port 6006.
|
|
187
|
+
|
|
188
|
+
- **`npm run test`**
|
|
189
|
+
Runs tests using Vitest.
|
|
190
|
+
|
|
191
|
+
- **`npm run test:ci`**
|
|
192
|
+
Runs tests with coverage.
|
|
193
|
+
|
|
194
|
+
- **`npm run lint`**
|
|
195
|
+
Runs biome check with auto-fix.
|
|
196
|
+
|
|
197
|
+
- **`npm run release`**
|
|
198
|
+
Builds and triggers the release process.
|
|
199
|
+
|
|
200
|
+
---
|
|
201
|
+
|
|
202
|
+
## License
|
|
203
|
+
|
|
204
|
+
This project is licensed under the MIT License.
|
|
205
|
+
|
|
206
|
+
---
|
package/dist/index.d.mts
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
type Breakpoint = string;
|
|
4
|
+
interface BreakpointContextType {
|
|
5
|
+
/** Current width of the observed element */
|
|
6
|
+
width: number;
|
|
7
|
+
/** Currently active breakpoint */
|
|
8
|
+
breakpoint: Breakpoint | null;
|
|
9
|
+
/** Defined breakpoints, e.g., { XS: 0, SM: 500, MD: 700, LG: 900, XL: 1100 } */
|
|
10
|
+
breakpoints: Record<Breakpoint, number>;
|
|
11
|
+
/**
|
|
12
|
+
* Returns `true` if the current breakpoint is greater than or equal to the provided one.
|
|
13
|
+
* E.g.: isAtLeast('MD') returns true if the current breakpoint is MD, LG, or XL.
|
|
14
|
+
*/
|
|
15
|
+
isAtLeast: (size: Breakpoint) => boolean;
|
|
16
|
+
/**
|
|
17
|
+
* Returns `true` if the current breakpoint is less than the provided one.
|
|
18
|
+
*/
|
|
19
|
+
isBelow: (size: Breakpoint) => boolean;
|
|
20
|
+
/**
|
|
21
|
+
* Returns a value from the mapping based on the current breakpoint.
|
|
22
|
+
* E.g.: valueByBreakpoint({ MD: 3, LG: 2 }) returns 3 for MD and 2 for LG.
|
|
23
|
+
*/
|
|
24
|
+
valueByBreakpoint: <T>(values: Partial<Record<Breakpoint, T>>) => T | undefined;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Instead of using React.RefObject<HTMLElement> (which is invariant),
|
|
28
|
+
* we use a structural type that accepts any object with a `current: HTMLElement | null` property.
|
|
29
|
+
*/
|
|
30
|
+
interface BreakpointProviderProps {
|
|
31
|
+
/** Defined breakpoints */
|
|
32
|
+
breakpoints: Record<Breakpoint, number>;
|
|
33
|
+
/** Child components that use the context */
|
|
34
|
+
children: React.ReactNode;
|
|
35
|
+
/**
|
|
36
|
+
* Optional: Provide a ref to the element to be observed.
|
|
37
|
+
* If not provided, an internal <div ref={...}> will be rendered.
|
|
38
|
+
*/
|
|
39
|
+
targetRef?: {
|
|
40
|
+
current: HTMLElement | null;
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* BreakpointProvider 🚀
|
|
45
|
+
*
|
|
46
|
+
* Uses react-resize-detector to measure the width of an element and determine the current breakpoint
|
|
47
|
+
* based on the provided breakpoints. Additionally, it provides utility functions (isAtLeast, isBelow)
|
|
48
|
+
* and valueByBreakpoint.
|
|
49
|
+
*
|
|
50
|
+
* ⚠️ **Edge Cases / Warnings:**
|
|
51
|
+
* - If the measured width is undefined or 0, an error is logged in the console.
|
|
52
|
+
* - If the current width is less than the smallest breakpoint (and width > 0), an error is logged.
|
|
53
|
+
* - If duplicate breakpoint values are detected, an error is logged.
|
|
54
|
+
*/
|
|
55
|
+
declare const BreakpointProvider: React.FC<BreakpointProviderProps>;
|
|
56
|
+
/**
|
|
57
|
+
* Hook for accessing the BreakpointContext.
|
|
58
|
+
* Throws an error if used outside of a BreakpointProvider. ⚠️
|
|
59
|
+
*/
|
|
60
|
+
declare const useBreakpoint: () => BreakpointContextType;
|
|
61
|
+
interface BreakpointConditionalProps {
|
|
62
|
+
/**
|
|
63
|
+
* Array of breakpoints at which the children should be displayed.
|
|
64
|
+
* E.g.: ['MD', 'LG'] renders children only if the current breakpoint is MD or LG.
|
|
65
|
+
*/
|
|
66
|
+
show?: Breakpoint[];
|
|
67
|
+
/**
|
|
68
|
+
* The children are displayed only if the current breakpoint is at least this value.
|
|
69
|
+
* E.g.: isAtLeast="MD" renders children for MD, LG, or XL.
|
|
70
|
+
*/
|
|
71
|
+
isAtLeast?: Breakpoint;
|
|
72
|
+
/**
|
|
73
|
+
* The children are displayed only if the current breakpoint is below this value.
|
|
74
|
+
*/
|
|
75
|
+
isBelow?: Breakpoint;
|
|
76
|
+
children: React.ReactNode;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* BreakpointConditional 🎨
|
|
80
|
+
*
|
|
81
|
+
* Renders its children only if all provided conditions regarding the current breakpoint are met.
|
|
82
|
+
*/
|
|
83
|
+
declare const BreakpointConditional: React.FC<BreakpointConditionalProps>;
|
|
84
|
+
|
|
85
|
+
export { type Breakpoint, BreakpointConditional, type BreakpointContextType, BreakpointProvider, type BreakpointProviderProps, useBreakpoint };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
type Breakpoint = string;
|
|
4
|
+
interface BreakpointContextType {
|
|
5
|
+
/** Current width of the observed element */
|
|
6
|
+
width: number;
|
|
7
|
+
/** Currently active breakpoint */
|
|
8
|
+
breakpoint: Breakpoint | null;
|
|
9
|
+
/** Defined breakpoints, e.g., { XS: 0, SM: 500, MD: 700, LG: 900, XL: 1100 } */
|
|
10
|
+
breakpoints: Record<Breakpoint, number>;
|
|
11
|
+
/**
|
|
12
|
+
* Returns `true` if the current breakpoint is greater than or equal to the provided one.
|
|
13
|
+
* E.g.: isAtLeast('MD') returns true if the current breakpoint is MD, LG, or XL.
|
|
14
|
+
*/
|
|
15
|
+
isAtLeast: (size: Breakpoint) => boolean;
|
|
16
|
+
/**
|
|
17
|
+
* Returns `true` if the current breakpoint is less than the provided one.
|
|
18
|
+
*/
|
|
19
|
+
isBelow: (size: Breakpoint) => boolean;
|
|
20
|
+
/**
|
|
21
|
+
* Returns a value from the mapping based on the current breakpoint.
|
|
22
|
+
* E.g.: valueByBreakpoint({ MD: 3, LG: 2 }) returns 3 for MD and 2 for LG.
|
|
23
|
+
*/
|
|
24
|
+
valueByBreakpoint: <T>(values: Partial<Record<Breakpoint, T>>) => T | undefined;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Instead of using React.RefObject<HTMLElement> (which is invariant),
|
|
28
|
+
* we use a structural type that accepts any object with a `current: HTMLElement | null` property.
|
|
29
|
+
*/
|
|
30
|
+
interface BreakpointProviderProps {
|
|
31
|
+
/** Defined breakpoints */
|
|
32
|
+
breakpoints: Record<Breakpoint, number>;
|
|
33
|
+
/** Child components that use the context */
|
|
34
|
+
children: React.ReactNode;
|
|
35
|
+
/**
|
|
36
|
+
* Optional: Provide a ref to the element to be observed.
|
|
37
|
+
* If not provided, an internal <div ref={...}> will be rendered.
|
|
38
|
+
*/
|
|
39
|
+
targetRef?: {
|
|
40
|
+
current: HTMLElement | null;
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* BreakpointProvider 🚀
|
|
45
|
+
*
|
|
46
|
+
* Uses react-resize-detector to measure the width of an element and determine the current breakpoint
|
|
47
|
+
* based on the provided breakpoints. Additionally, it provides utility functions (isAtLeast, isBelow)
|
|
48
|
+
* and valueByBreakpoint.
|
|
49
|
+
*
|
|
50
|
+
* ⚠️ **Edge Cases / Warnings:**
|
|
51
|
+
* - If the measured width is undefined or 0, an error is logged in the console.
|
|
52
|
+
* - If the current width is less than the smallest breakpoint (and width > 0), an error is logged.
|
|
53
|
+
* - If duplicate breakpoint values are detected, an error is logged.
|
|
54
|
+
*/
|
|
55
|
+
declare const BreakpointProvider: React.FC<BreakpointProviderProps>;
|
|
56
|
+
/**
|
|
57
|
+
* Hook for accessing the BreakpointContext.
|
|
58
|
+
* Throws an error if used outside of a BreakpointProvider. ⚠️
|
|
59
|
+
*/
|
|
60
|
+
declare const useBreakpoint: () => BreakpointContextType;
|
|
61
|
+
interface BreakpointConditionalProps {
|
|
62
|
+
/**
|
|
63
|
+
* Array of breakpoints at which the children should be displayed.
|
|
64
|
+
* E.g.: ['MD', 'LG'] renders children only if the current breakpoint is MD or LG.
|
|
65
|
+
*/
|
|
66
|
+
show?: Breakpoint[];
|
|
67
|
+
/**
|
|
68
|
+
* The children are displayed only if the current breakpoint is at least this value.
|
|
69
|
+
* E.g.: isAtLeast="MD" renders children for MD, LG, or XL.
|
|
70
|
+
*/
|
|
71
|
+
isAtLeast?: Breakpoint;
|
|
72
|
+
/**
|
|
73
|
+
* The children are displayed only if the current breakpoint is below this value.
|
|
74
|
+
*/
|
|
75
|
+
isBelow?: Breakpoint;
|
|
76
|
+
children: React.ReactNode;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* BreakpointConditional 🎨
|
|
80
|
+
*
|
|
81
|
+
* Renders its children only if all provided conditions regarding the current breakpoint are met.
|
|
82
|
+
*/
|
|
83
|
+
declare const BreakpointConditional: React.FC<BreakpointConditionalProps>;
|
|
84
|
+
|
|
85
|
+
export { type Breakpoint, BreakpointConditional, type BreakpointContextType, BreakpointProvider, type BreakpointProviderProps, useBreakpoint };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";var k=Object.defineProperty;var P=Object.getOwnPropertyDescriptor;var w=Object.getOwnPropertyNames;var C=Object.prototype.hasOwnProperty;var R=(e,r)=>{for(var d in r)k(e,d,{get:r[d],enumerable:!0})},T=(e,r,d,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let p of w(r))!C.call(e,p)&&p!==d&&k(e,p,{get:()=>r[p],enumerable:!(t=P(r,p))||t.enumerable});return e};var g=e=>T(k({},"__esModule",{value:!0}),e);var A={};R(A,{BreakpointConditional:()=>L,BreakpointProvider:()=>y,useBreakpoint:()=>h});module.exports=g(A);var s=require("react"),B=require("react-resize-detector"),u=require("react/jsx-runtime"),f=(0,s.createContext)(void 0),y=({breakpoints:e,children:r,targetRef:d})=>{let{width:t,ref:p}=(0,B.useResizeDetector)({targetRef:d}),n=(0,s.useMemo)(()=>Object.entries(e).map(([o,l])=>[o,l]).sort(([,o],[,l])=>o-l),[e]);(0,s.useEffect)(()=>{n.filter(([,l],c)=>n.findIndex(([,m])=>m===l)!==c).length>0&&console.error("BreakpointProvider: Duplicate breakpoint values detected. This may lead to unexpected behavior.")},[n]);let a=(0,s.useMemo)(()=>{if(t===void 0)return null;let o=null;return n.forEach(([l,c])=>{t>=c&&(o=l)}),o},[t,n]);(0,s.useEffect)(()=>{t===void 0?console.error("BreakpointProvider: width is undefined. Ensure the target element is mounted and visible."):t===0&&console.error("BreakpointProvider: width is 0. The target element might be hidden or not mounted correctly.")},[t]),(0,s.useEffect)(()=>{t!==void 0&&t>0&&a===null&&(n.length>0&&t<n[0][1]?console.error(`BreakpointProvider: The current width (${t}px) is less than the smallest breakpoint value (${n[0][1]}px). Consider including a breakpoint with a value of 0 to cover all cases.`):console.error("BreakpointProvider: No breakpoint could be determined from the provided configuration. Check your breakpoints object."))},[t,a,n]);let i=o=>n.findIndex(([l])=>l===o),v=o=>a?i(a)>=i(o):!1,b=o=>a?i(a)<i(o):!1;function x(o){if(a)return o[a]}return(0,u.jsx)(f.Provider,{value:{width:t??0,breakpoint:a,breakpoints:e,isAtLeast:v,isBelow:b,valueByBreakpoint:x},children:d?r:(0,u.jsx)("div",{ref:p,children:r})})},h=()=>{let e=(0,s.useContext)(f);if(!e)throw new Error("useBreakpoint must be used within a BreakpointProvider");return e},L=({show:e,isAtLeast:r,isBelow:d,children:t})=>{let{breakpoint:p,isAtLeast:n,isBelow:a}=h(),i=!0;return e&&p&&(i=i&&e.includes(p)),r&&(i=i&&n(r)),d&&(i=i&&a(d)),i?(0,u.jsx)(u.Fragment,{children:t}):null};0&&(module.exports={BreakpointConditional,BreakpointProvider,useBreakpoint});
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/BreakpointContext.tsx"],
  "sourcesContent": ["export * from \"./BreakpointContext\";", "import React, { createContext, useContext, useMemo, useEffect } from 'react';\nimport { useResizeDetector } from 'react-resize-detector';\n\nexport type Breakpoint = string; // Allow arbitrary breakpoint names\n\nexport interface BreakpointContextType {\n  /** Current width of the observed element */\n  width: number;\n  /** Currently active breakpoint */\n  breakpoint: Breakpoint | null;\n  /** Defined breakpoints, e.g., { XS: 0, SM: 500, MD: 700, LG: 900, XL: 1100 } */\n  breakpoints: Record<Breakpoint, number>;\n  /**\n   * Returns `true` if the current breakpoint is greater than or equal to the provided one.\n   * E.g.: isAtLeast('MD') returns true if the current breakpoint is MD, LG, or XL.\n   */\n  isAtLeast: (size: Breakpoint) => boolean;\n  /**\n   * Returns `true` if the current breakpoint is less than the provided one.\n   */\n  isBelow: (size: Breakpoint) => boolean;\n  /**\n   * Returns a value from the mapping based on the current breakpoint.\n   * E.g.: valueByBreakpoint({ MD: 3, LG: 2 }) returns 3 for MD and 2 for LG.\n   */\n  valueByBreakpoint: <T>(values: Partial<Record<Breakpoint, T>>) => T | undefined;\n}\n\nconst BreakpointContext = createContext<BreakpointContextType | undefined>(undefined);\n\n/**\n * Instead of using React.RefObject<HTMLElement> (which is invariant),\n * we use a structural type that accepts any object with a `current: HTMLElement | null` property.\n */\nexport interface BreakpointProviderProps {\n  /** Defined breakpoints */\n  breakpoints: Record<Breakpoint, number>;\n  /** Child components that use the context */\n  children: React.ReactNode;\n  /**\n   * Optional: Provide a ref to the element to be observed.\n   * If not provided, an internal <div ref={...}> will be rendered.\n   */\n  targetRef?: { current: HTMLElement | null };\n}\n\n/**\n * BreakpointProvider \uD83D\uDE80\n *\n * Uses react-resize-detector to measure the width of an element and determine the current breakpoint\n * based on the provided breakpoints. Additionally, it provides utility functions (isAtLeast, isBelow)\n * and valueByBreakpoint.\n *\n * \u26A0\uFE0F **Edge Cases / Warnings:**\n * - If the measured width is undefined or 0, an error is logged in the console.\n * - If the current width is less than the smallest breakpoint (and width > 0), an error is logged.\n * - If duplicate breakpoint values are detected, an error is logged.\n */\nexport const BreakpointProvider: React.FC<BreakpointProviderProps> = ({\n                                                                        breakpoints,\n                                                                        children,\n                                                                        targetRef,\n                                                                      }) => {\n  // If a targetRef is provided, useResizeDetector observes that element; otherwise, an internal ref is created.\n  const { width, ref } = useResizeDetector({ targetRef });\n\n  // Sort the breakpoints in ascending order based on their numeric values. \uD83D\uDD22\n  const sortedBreakpoints = useMemo(() => {\n    return Object.entries(breakpoints)\n      .map(([key, value]) => [key, value] as [Breakpoint, number])\n      .sort(([, a], [, b]) => a - b);\n  }, [breakpoints]);\n\n  // Check for duplicate breakpoint values\n  useEffect(() => {\n    const duplicates = sortedBreakpoints.filter(\n      ([, value], index) =>\n        sortedBreakpoints.findIndex(([, v]) => v === value) !== index\n    );\n    if (duplicates.length > 0) {\n      console.error(\n        'BreakpointProvider: Duplicate breakpoint values detected. This may lead to unexpected behavior.'\n      );\n    }\n  }, [sortedBreakpoints]);\n\n  // Determine the current breakpoint based on the measured width. \uD83D\uDCCF\n  const currentBreakpoint = useMemo(() => {\n    if (width === undefined) return null;\n    let active: Breakpoint | null = null;\n    sortedBreakpoints.forEach(([key, value]) => {\n      if (width >= value) {\n        active = key;\n      }\n    });\n    return active;\n  }, [width, sortedBreakpoints]);\n\n  // Log error if width is undefined or 0\n  useEffect(() => {\n    if (width === undefined) {\n      console.error(\n        'BreakpointProvider: width is undefined. Ensure the target element is mounted and visible.'\n      );\n    } else if (width === 0) {\n      console.error(\n        'BreakpointProvider: width is 0. The target element might be hidden or not mounted correctly.'\n      );\n    }\n  }, [width]);\n\n  // Log error if width > 0 but no breakpoint could be determined\n  useEffect(() => {\n    if (width !== undefined && width > 0 && currentBreakpoint === null) {\n      if (sortedBreakpoints.length > 0 && width < sortedBreakpoints[0][1]) {\n        console.error(\n          `BreakpointProvider: The current width (${width}px) is less than the smallest breakpoint value (${sortedBreakpoints[0][1]}px). Consider including a breakpoint with a value of 0 to cover all cases.`\n        );\n      } else {\n        console.error(\n          'BreakpointProvider: No breakpoint could be determined from the provided configuration. Check your breakpoints object.'\n        );\n      }\n    }\n  }, [width, currentBreakpoint, sortedBreakpoints]);\n\n  // Helper function to get the index of a breakpoint in the sorted array. \uD83D\uDD0D\n  const getBreakpointIndex = (size: Breakpoint): number => {\n    return sortedBreakpoints.findIndex(([key]) => key === size);\n  };\n\n  const isAtLeast = (size: Breakpoint): boolean => {\n    if (!currentBreakpoint) return false;\n    return getBreakpointIndex(currentBreakpoint) >= getBreakpointIndex(size);\n  };\n\n  const isBelow = (size: Breakpoint): boolean => {\n    if (!currentBreakpoint) return false;\n    return getBreakpointIndex(currentBreakpoint) < getBreakpointIndex(size);\n  };\n\n  // Define valueByBreakpoint as a function declaration to avoid JSX parsing issues in TSX files. \uD83C\uDFA8\n  function valueByBreakpoint<T>(values: Partial<Record<Breakpoint, T>>): T | undefined {\n    if (!currentBreakpoint) return undefined;\n    return values[currentBreakpoint];\n  }\n\n  return (\n    <BreakpointContext.Provider\n      value={{\n        width: width ?? 0,\n        breakpoint: currentBreakpoint,\n        breakpoints,\n        isAtLeast,\n        isBelow,\n        valueByBreakpoint,\n      }}\n    >\n      {/* If a targetRef is provided, that ref is already attached to an external element.\n          Otherwise, render a <div ref={ref}> to observe its size. \uD83D\uDCD0 */}\n      {targetRef ? children : <div ref={ref}>{children}</div>}\n    </BreakpointContext.Provider>\n  );\n};\n\n/**\n * Hook for accessing the BreakpointContext.\n * Throws an error if used outside of a BreakpointProvider. \u26A0\uFE0F\n */\nexport const useBreakpoint = (): BreakpointContextType => {\n  const context = useContext(BreakpointContext);\n  if (!context) {\n    throw new Error('useBreakpoint must be used within a BreakpointProvider');\n  }\n  return context;\n};\n\ninterface BreakpointConditionalProps {\n  /**\n   * Array of breakpoints at which the children should be displayed.\n   * E.g.: ['MD', 'LG'] renders children only if the current breakpoint is MD or LG.\n   */\n  show?: Breakpoint[];\n  /**\n   * The children are displayed only if the current breakpoint is at least this value.\n   * E.g.: isAtLeast=\"MD\" renders children for MD, LG, or XL.\n   */\n  isAtLeast?: Breakpoint;\n  /**\n   * The children are displayed only if the current breakpoint is below this value.\n   */\n  isBelow?: Breakpoint;\n  children: React.ReactNode;\n}\n\n/**\n * BreakpointConditional \uD83C\uDFA8\n *\n * Renders its children only if all provided conditions regarding the current breakpoint are met.\n */\nexport const BreakpointConditional: React.FC<BreakpointConditionalProps> = ({\n                                                                              show,\n                                                                              isAtLeast: minSize,\n                                                                              isBelow: maxSize,\n                                                                              children,\n                                                                            }) => {\n  const { breakpoint, isAtLeast: contextIsAtLeast, isBelow: contextIsBelow } = useBreakpoint();\n\n  let shouldRender = true;\n\n  if (show && breakpoint) {\n    shouldRender = shouldRender && show.includes(breakpoint);\n  }\n  if (minSize) {\n    shouldRender = shouldRender && contextIsAtLeast(minSize);\n  }\n  if (maxSize) {\n    shouldRender = shouldRender && contextIsBelow(maxSize);\n  }\n\n  return shouldRender ? <>{children}</> : null;\n};"],
  "mappings": "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",
  "names": ["index_exports", "__export", "BreakpointConditional", "BreakpointProvider", "useBreakpoint", "__toCommonJS", "import_react", "import_react_resize_detector", "import_jsx_runtime", "BreakpointContext", "BreakpointProvider", "breakpoints", "children", "targetRef", "width", "ref", "sortedBreakpoints", "key", "value", "a", "b", "index", "v", "currentBreakpoint", "active", "getBreakpointIndex", "size", "isAtLeast", "isBelow", "valueByBreakpoint", "values", "useBreakpoint", "context", "BreakpointConditional", "show", "minSize", "maxSize", "breakpoint", "contextIsAtLeast", "contextIsBelow", "shouldRender"]
}

|
package/dist/index.mjs
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{createContext as x,useContext as m,useMemo as k,useEffect as u}from"react";import{useResizeDetector as P}from"react-resize-detector";import{Fragment as C,jsx as c}from"react/jsx-runtime";var B=x(void 0),y=({breakpoints:i,children:s,targetRef:d})=>{let{width:t,ref:p}=P({targetRef:d}),r=k(()=>Object.entries(i).map(([e,a])=>[e,a]).sort(([,e],[,a])=>e-a),[i]);u(()=>{r.filter(([,a],l)=>r.findIndex(([,b])=>b===a)!==l).length>0&&console.error("BreakpointProvider: Duplicate breakpoint values detected. This may lead to unexpected behavior.")},[r]);let n=k(()=>{if(t===void 0)return null;let e=null;return r.forEach(([a,l])=>{t>=l&&(e=a)}),e},[t,r]);u(()=>{t===void 0?console.error("BreakpointProvider: width is undefined. Ensure the target element is mounted and visible."):t===0&&console.error("BreakpointProvider: width is 0. The target element might be hidden or not mounted correctly.")},[t]),u(()=>{t!==void 0&&t>0&&n===null&&(r.length>0&&t<r[0][1]?console.error(`BreakpointProvider: The current width (${t}px) is less than the smallest breakpoint value (${r[0][1]}px). Consider including a breakpoint with a value of 0 to cover all cases.`):console.error("BreakpointProvider: No breakpoint could be determined from the provided configuration. Check your breakpoints object."))},[t,n,r]);let o=e=>r.findIndex(([a])=>a===e),f=e=>n?o(n)>=o(e):!1,h=e=>n?o(n)<o(e):!1;function v(e){if(n)return e[n]}return c(B.Provider,{value:{width:t??0,breakpoint:n,breakpoints:i,isAtLeast:f,isBelow:h,valueByBreakpoint:v},children:d?s:c("div",{ref:p,children:s})})},w=()=>{let i=m(B);if(!i)throw new Error("useBreakpoint must be used within a BreakpointProvider");return i},L=({show:i,isAtLeast:s,isBelow:d,children:t})=>{let{breakpoint:p,isAtLeast:r,isBelow:n}=w(),o=!0;return i&&p&&(o=o&&i.includes(p)),s&&(o=o&&r(s)),d&&(o=o&&n(d)),o?c(C,{children:t}):null};export{L as BreakpointConditional,y as BreakpointProvider,w as useBreakpoint};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/BreakpointContext.tsx"],
  "sourcesContent": ["import React, { createContext, useContext, useMemo, useEffect } from 'react';\nimport { useResizeDetector } from 'react-resize-detector';\n\nexport type Breakpoint = string; // Allow arbitrary breakpoint names\n\nexport interface BreakpointContextType {\n  /** Current width of the observed element */\n  width: number;\n  /** Currently active breakpoint */\n  breakpoint: Breakpoint | null;\n  /** Defined breakpoints, e.g., { XS: 0, SM: 500, MD: 700, LG: 900, XL: 1100 } */\n  breakpoints: Record<Breakpoint, number>;\n  /**\n   * Returns `true` if the current breakpoint is greater than or equal to the provided one.\n   * E.g.: isAtLeast('MD') returns true if the current breakpoint is MD, LG, or XL.\n   */\n  isAtLeast: (size: Breakpoint) => boolean;\n  /**\n   * Returns `true` if the current breakpoint is less than the provided one.\n   */\n  isBelow: (size: Breakpoint) => boolean;\n  /**\n   * Returns a value from the mapping based on the current breakpoint.\n   * E.g.: valueByBreakpoint({ MD: 3, LG: 2 }) returns 3 for MD and 2 for LG.\n   */\n  valueByBreakpoint: <T>(values: Partial<Record<Breakpoint, T>>) => T | undefined;\n}\n\nconst BreakpointContext = createContext<BreakpointContextType | undefined>(undefined);\n\n/**\n * Instead of using React.RefObject<HTMLElement> (which is invariant),\n * we use a structural type that accepts any object with a `current: HTMLElement | null` property.\n */\nexport interface BreakpointProviderProps {\n  /** Defined breakpoints */\n  breakpoints: Record<Breakpoint, number>;\n  /** Child components that use the context */\n  children: React.ReactNode;\n  /**\n   * Optional: Provide a ref to the element to be observed.\n   * If not provided, an internal <div ref={...}> will be rendered.\n   */\n  targetRef?: { current: HTMLElement | null };\n}\n\n/**\n * BreakpointProvider \uD83D\uDE80\n *\n * Uses react-resize-detector to measure the width of an element and determine the current breakpoint\n * based on the provided breakpoints. Additionally, it provides utility functions (isAtLeast, isBelow)\n * and valueByBreakpoint.\n *\n * \u26A0\uFE0F **Edge Cases / Warnings:**\n * - If the measured width is undefined or 0, an error is logged in the console.\n * - If the current width is less than the smallest breakpoint (and width > 0), an error is logged.\n * - If duplicate breakpoint values are detected, an error is logged.\n */\nexport const BreakpointProvider: React.FC<BreakpointProviderProps> = ({\n                                                                        breakpoints,\n                                                                        children,\n                                                                        targetRef,\n                                                                      }) => {\n  // If a targetRef is provided, useResizeDetector observes that element; otherwise, an internal ref is created.\n  const { width, ref } = useResizeDetector({ targetRef });\n\n  // Sort the breakpoints in ascending order based on their numeric values. \uD83D\uDD22\n  const sortedBreakpoints = useMemo(() => {\n    return Object.entries(breakpoints)\n      .map(([key, value]) => [key, value] as [Breakpoint, number])\n      .sort(([, a], [, b]) => a - b);\n  }, [breakpoints]);\n\n  // Check for duplicate breakpoint values\n  useEffect(() => {\n    const duplicates = sortedBreakpoints.filter(\n      ([, value], index) =>\n        sortedBreakpoints.findIndex(([, v]) => v === value) !== index\n    );\n    if (duplicates.length > 0) {\n      console.error(\n        'BreakpointProvider: Duplicate breakpoint values detected. This may lead to unexpected behavior.'\n      );\n    }\n  }, [sortedBreakpoints]);\n\n  // Determine the current breakpoint based on the measured width. \uD83D\uDCCF\n  const currentBreakpoint = useMemo(() => {\n    if (width === undefined) return null;\n    let active: Breakpoint | null = null;\n    sortedBreakpoints.forEach(([key, value]) => {\n      if (width >= value) {\n        active = key;\n      }\n    });\n    return active;\n  }, [width, sortedBreakpoints]);\n\n  // Log error if width is undefined or 0\n  useEffect(() => {\n    if (width === undefined) {\n      console.error(\n        'BreakpointProvider: width is undefined. Ensure the target element is mounted and visible.'\n      );\n    } else if (width === 0) {\n      console.error(\n        'BreakpointProvider: width is 0. The target element might be hidden or not mounted correctly.'\n      );\n    }\n  }, [width]);\n\n  // Log error if width > 0 but no breakpoint could be determined\n  useEffect(() => {\n    if (width !== undefined && width > 0 && currentBreakpoint === null) {\n      if (sortedBreakpoints.length > 0 && width < sortedBreakpoints[0][1]) {\n        console.error(\n          `BreakpointProvider: The current width (${width}px) is less than the smallest breakpoint value (${sortedBreakpoints[0][1]}px). Consider including a breakpoint with a value of 0 to cover all cases.`\n        );\n      } else {\n        console.error(\n          'BreakpointProvider: No breakpoint could be determined from the provided configuration. Check your breakpoints object.'\n        );\n      }\n    }\n  }, [width, currentBreakpoint, sortedBreakpoints]);\n\n  // Helper function to get the index of a breakpoint in the sorted array. \uD83D\uDD0D\n  const getBreakpointIndex = (size: Breakpoint): number => {\n    return sortedBreakpoints.findIndex(([key]) => key === size);\n  };\n\n  const isAtLeast = (size: Breakpoint): boolean => {\n    if (!currentBreakpoint) return false;\n    return getBreakpointIndex(currentBreakpoint) >= getBreakpointIndex(size);\n  };\n\n  const isBelow = (size: Breakpoint): boolean => {\n    if (!currentBreakpoint) return false;\n    return getBreakpointIndex(currentBreakpoint) < getBreakpointIndex(size);\n  };\n\n  // Define valueByBreakpoint as a function declaration to avoid JSX parsing issues in TSX files. \uD83C\uDFA8\n  function valueByBreakpoint<T>(values: Partial<Record<Breakpoint, T>>): T | undefined {\n    if (!currentBreakpoint) return undefined;\n    return values[currentBreakpoint];\n  }\n\n  return (\n    <BreakpointContext.Provider\n      value={{\n        width: width ?? 0,\n        breakpoint: currentBreakpoint,\n        breakpoints,\n        isAtLeast,\n        isBelow,\n        valueByBreakpoint,\n      }}\n    >\n      {/* If a targetRef is provided, that ref is already attached to an external element.\n          Otherwise, render a <div ref={ref}> to observe its size. \uD83D\uDCD0 */}\n      {targetRef ? children : <div ref={ref}>{children}</div>}\n    </BreakpointContext.Provider>\n  );\n};\n\n/**\n * Hook for accessing the BreakpointContext.\n * Throws an error if used outside of a BreakpointProvider. \u26A0\uFE0F\n */\nexport const useBreakpoint = (): BreakpointContextType => {\n  const context = useContext(BreakpointContext);\n  if (!context) {\n    throw new Error('useBreakpoint must be used within a BreakpointProvider');\n  }\n  return context;\n};\n\ninterface BreakpointConditionalProps {\n  /**\n   * Array of breakpoints at which the children should be displayed.\n   * E.g.: ['MD', 'LG'] renders children only if the current breakpoint is MD or LG.\n   */\n  show?: Breakpoint[];\n  /**\n   * The children are displayed only if the current breakpoint is at least this value.\n   * E.g.: isAtLeast=\"MD\" renders children for MD, LG, or XL.\n   */\n  isAtLeast?: Breakpoint;\n  /**\n   * The children are displayed only if the current breakpoint is below this value.\n   */\n  isBelow?: Breakpoint;\n  children: React.ReactNode;\n}\n\n/**\n * BreakpointConditional \uD83C\uDFA8\n *\n * Renders its children only if all provided conditions regarding the current breakpoint are met.\n */\nexport const BreakpointConditional: React.FC<BreakpointConditionalProps> = ({\n                                                                              show,\n                                                                              isAtLeast: minSize,\n                                                                              isBelow: maxSize,\n                                                                              children,\n                                                                            }) => {\n  const { breakpoint, isAtLeast: contextIsAtLeast, isBelow: contextIsBelow } = useBreakpoint();\n\n  let shouldRender = true;\n\n  if (show && breakpoint) {\n    shouldRender = shouldRender && show.includes(breakpoint);\n  }\n  if (minSize) {\n    shouldRender = shouldRender && contextIsAtLeast(minSize);\n  }\n  if (maxSize) {\n    shouldRender = shouldRender && contextIsBelow(maxSize);\n  }\n\n  return shouldRender ? <>{children}</> : null;\n};"],
  "mappings": "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",
  "names": ["createContext", "useContext", "useMemo", "useEffect", "useResizeDetector", "Fragment", "jsx", "BreakpointContext", "BreakpointProvider", "breakpoints", "children", "targetRef", "width", "ref", "sortedBreakpoints", "key", "value", "a", "b", "index", "v", "currentBreakpoint", "active", "getBreakpointIndex", "size", "isAtLeast", "isBelow", "valueByBreakpoint", "values", "useBreakpoint", "context", "BreakpointConditional", "show", "minSize", "maxSize", "breakpoint", "contextIsAtLeast", "contextIsBelow", "shouldRender"]
}

|
package/package.json
ADDED
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "react-resize-detector-context",
|
|
3
|
+
"description": "",
|
|
4
|
+
"version": "0.0.0",
|
|
5
|
+
"author": "",
|
|
6
|
+
"license": "",
|
|
7
|
+
"keywords": [],
|
|
8
|
+
"repository": {
|
|
9
|
+
"type": "git",
|
|
10
|
+
"url": ""
|
|
11
|
+
},
|
|
12
|
+
"scripts": {
|
|
13
|
+
"dev": "concurrently \"pnpm build --watch\" \"pnpm storybook\" \"pnpm test\" ",
|
|
14
|
+
"build": "tsup",
|
|
15
|
+
"lint": "biome check --write --unsafe .",
|
|
16
|
+
"lint:ci": "biome check --unsafe .",
|
|
17
|
+
"test": "vitest",
|
|
18
|
+
"test:ci": "vitest run --coverage",
|
|
19
|
+
"commit": "cz",
|
|
20
|
+
"storybook": "storybook dev -p 6006",
|
|
21
|
+
"storybook:build": "storybook build",
|
|
22
|
+
"release": "pnpm build && pnpm release-it",
|
|
23
|
+
"link:self": "pnpm link --global",
|
|
24
|
+
"prepare": "lefthook install"
|
|
25
|
+
},
|
|
26
|
+
"types": "./dist/index.d.ts",
|
|
27
|
+
"exports": {
|
|
28
|
+
".": {
|
|
29
|
+
"require": "./dist/index.js",
|
|
30
|
+
"import": "./dist/index.mjs"
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
"files": [
|
|
34
|
+
"dist"
|
|
35
|
+
],
|
|
36
|
+
"config": {
|
|
37
|
+
"commitizen": {
|
|
38
|
+
"path": "./node_modules/@ryansonshine/cz-conventional-changelog"
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
"release-it": {
|
|
42
|
+
"git": {
|
|
43
|
+
"commitMessage": "chore(release): v${version}"
|
|
44
|
+
},
|
|
45
|
+
"github": {
|
|
46
|
+
"release": true
|
|
47
|
+
},
|
|
48
|
+
"npm": {
|
|
49
|
+
"publish": false
|
|
50
|
+
}
|
|
51
|
+
},
|
|
52
|
+
"engines": {
|
|
53
|
+
"node": ">=18.0.0"
|
|
54
|
+
},
|
|
55
|
+
"devDependencies": {
|
|
56
|
+
"@biomejs/biome": "1.9.4",
|
|
57
|
+
"@mui/material": "^6.4.3",
|
|
58
|
+
"@ryansonshine/commitizen": "4.2.8",
|
|
59
|
+
"@ryansonshine/cz-conventional-changelog": "3.3.4",
|
|
60
|
+
"@storybook/addon-essentials": "8.4.7",
|
|
61
|
+
"@storybook/addon-interactions": "8.4.7",
|
|
62
|
+
"@storybook/addon-links": "8.4.7",
|
|
63
|
+
"@storybook/addon-webpack5-compiler-swc": "2.0.0",
|
|
64
|
+
"@storybook/blocks": "8.4.7",
|
|
65
|
+
"@storybook/react": "8.4.7",
|
|
66
|
+
"@storybook/react-webpack5": "8.4.7",
|
|
67
|
+
"@storybook/test": "8.4.7",
|
|
68
|
+
"@testing-library/jest-dom": "6.6.3",
|
|
69
|
+
"@testing-library/react": "^16.1.0",
|
|
70
|
+
"@types/node": "22.10.5",
|
|
71
|
+
"@types/react": "18.3.13",
|
|
72
|
+
"@types/react-dom": "18.3.1",
|
|
73
|
+
"@types/react-test-renderer": "18.3.0",
|
|
74
|
+
"@types/testing-library__jest-dom": "^5.14.9",
|
|
75
|
+
"@vitest/coverage-v8": "2.1.8",
|
|
76
|
+
"concurrently": "9.1.2",
|
|
77
|
+
"jsdom": "25.0.1",
|
|
78
|
+
"lefthook": "1.10.1",
|
|
79
|
+
"prop-types": "15.8.1",
|
|
80
|
+
"react": "18.3.1",
|
|
81
|
+
"react-dom": "18.3.1",
|
|
82
|
+
"react-test-renderer": "18.3.1",
|
|
83
|
+
"release-it": "17.11.0",
|
|
84
|
+
"storybook": "8.4.7",
|
|
85
|
+
"ts-node": "10.9.2",
|
|
86
|
+
"tsconfig-paths": "4.2.0",
|
|
87
|
+
"tsup": "8.3.5",
|
|
88
|
+
"tsx": "4.19.2",
|
|
89
|
+
"typescript": "5.7.2",
|
|
90
|
+
"vitest": "^2.1.8",
|
|
91
|
+
"@emotion/styled": "^11.14.0"
|
|
92
|
+
},
|
|
93
|
+
"peerDependencies": {
|
|
94
|
+
"react": ">=17",
|
|
95
|
+
"react-dom": ">=17"
|
|
96
|
+
},
|
|
97
|
+
"pnpm": {
|
|
98
|
+
"overrides": {
|
|
99
|
+
"micromatch@<4.0.8": ">=4.0.8"
|
|
100
|
+
}
|
|
101
|
+
},
|
|
102
|
+
"dependencies": {
|
|
103
|
+
"@emotion/styled": "^11.14.0",
|
|
104
|
+
"react-resize-detector": "^12.0.2"
|
|
105
|
+
}
|
|
106
|
+
}
|