react-resize-detector-context 0.1.0 → 0.1.2

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/README.md CHANGED
@@ -53,7 +53,7 @@ responsive breakpoints – all fully typed in TypeScript for excellent IDE suppo
53
53
  Install via npm:
54
54
 
55
55
  ``` bash
56
- npm install my-breakpoint-package
56
+ npm install react-resize-detector-context
57
57
  ```
58
58
 
59
59
  ---
@@ -307,7 +307,7 @@ The following scripts are available in this package:
307
307
  Runs tests with coverage.
308
308
 
309
309
  - **`npm run lint`**
310
- Runs biome to check (and optionally fix) your code style.
310
+ Runs lint to check (and optionally fix) your code style.
311
311
 
312
312
  - **`npm run release`**
313
313
  Builds the package and triggers the release process.
package/dist/index.d.mts CHANGED
@@ -10,7 +10,8 @@ interface BreakpointContextType {
10
10
  breakpoints: Record<Breakpoint, number>;
11
11
  /**
12
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.
13
+ * E.g.: isAtLeast('MD') returns true if the current breakpoint is MD,
14
+ * LG, or XL.
14
15
  */
15
16
  isAtLeast: (size: Breakpoint) => boolean;
16
17
  /**
package/dist/index.d.ts CHANGED
@@ -10,7 +10,8 @@ interface BreakpointContextType {
10
10
  breakpoints: Record<Breakpoint, number>;
11
11
  /**
12
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.
13
+ * E.g.: isAtLeast('MD') returns true if the current breakpoint is MD,
14
+ * LG, or XL.
14
15
  */
15
16
  isAtLeast: (size: Breakpoint) => boolean;
16
17
  /**
package/dist/index.js CHANGED
@@ -1,2 +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": ["src_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"]
}

1
+ "use strict";var k=Object.defineProperty;var P=Object.getOwnPropertyDescriptor;var w=Object.getOwnPropertyNames;var C=Object.prototype.hasOwnProperty;var R=(e,t)=>{for(var s in t)k(e,s,{get:t[s],enumerable:!0})},T=(e,t,s,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let p of w(t))!C.call(e,p)&&p!==s&&k(e,p,{get:()=>t[p],enumerable:!(o=P(t,p))||o.enumerable});return e};var y=e=>T(k({},"__esModule",{value:!0}),e);var A={};R(A,{BreakpointConditional:()=>g,BreakpointProvider:()=>L,useBreakpoint:()=>b});module.exports=y(A);var d=require("react"),B=require("react-resize-detector"),u=require("react/jsx-runtime"),f=(0,d.createContext)(void 0),L=({breakpoints:e,children:t,targetRef:s})=>{let{width:o,ref:p}=(0,B.useResizeDetector)({targetRef:s}),n=(0,d.useMemo)(()=>Object.entries(e).map(([r,l])=>[r,l]).sort(([,r],[,l])=>r-l),[e]);(0,d.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,d.useMemo)(()=>{if(o===void 0)return null;let r=null;return n.forEach(([l,c])=>{o>=c&&(r=l)}),r},[o,n]);(0,d.useEffect)(()=>{o!==void 0&&o>0&&a===null&&(n.length>0&&o<n[0][1]?console.error(`BreakpointProvider: The current width (${o}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."))},[o,a,n]);let i=r=>n.findIndex(([l])=>l===r),v=r=>a?i(a)>=i(r):!1,x=r=>a?i(a)<i(r):!1;function h(r){if(a)return r[a]}return(0,u.jsx)(f.Provider,{value:{width:o??0,breakpoint:a,breakpoints:e,isAtLeast:v,isBelow:x,valueByBreakpoint:h},children:s?t:(0,u.jsx)("div",{ref:p,children:t})})},b=()=>{let e=(0,d.useContext)(f);if(!e)throw new Error("useBreakpoint must be used within a BreakpointProvider");return e},g=({show:e,isAtLeast:t,isBelow:s,children:o})=>{let{breakpoint:p,isAtLeast:n,isBelow:a}=b(),i=!0;return e&&p&&(i=i&&e.includes(p)),t&&(i=i&&n(t)),s&&(i=i&&a(s)),i?(0,u.jsx)(u.Fragment,{children:o}):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';\n", "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,\n   * 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> = ({ breakpoints, children, targetRef }) => {\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) => sortedBreakpoints.findIndex(([, v]) => v === value) !== index\n    );\n    if (duplicates.length > 0) {\n      console.error('BreakpointProvider: Duplicate breakpoint values detected. This may lead to unexpected behavior.');\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 > 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": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,2BAAAE,EAAA,uBAAAC,EAAA,kBAAAC,IAAA,eAAAC,EAAAL,GCAA,IAAAM,EAAqE,iBACrEC,EAAkC,iCA4IJC,EAAA,6BAhHxBC,KAAoB,iBAAiD,MAAS,EA8BvEC,EAAwD,CAAC,CAAE,YAAAC,EAAa,SAAAC,EAAU,UAAAC,CAAU,IAAM,CAE7G,GAAM,CAAE,MAAAC,EAAO,IAAAC,CAAI,KAAI,qBAAkB,CAAE,UAAAF,CAAU,CAAC,EAGhDG,KAAoB,WAAQ,IACzB,OAAO,QAAQL,CAAW,EAC9B,IAAI,CAAC,CAACM,EAAKC,CAAK,IAAM,CAACD,EAAKC,CAAK,CAAyB,EAC1D,KAAK,CAAC,CAAC,CAAEC,CAAC,EAAG,CAAC,CAAEC,CAAC,IAAMD,EAAIC,CAAC,EAC9B,CAACT,CAAW,CAAC,KAGhB,aAAU,IAAM,CACKK,EAAkB,OACnC,CAAC,CAAC,CAAEE,CAAK,EAAGG,IAAUL,EAAkB,UAAU,CAAC,CAAC,CAAEM,CAAC,IAAMA,IAAMJ,CAAK,IAAMG,CAChF,EACe,OAAS,GACtB,QAAQ,MAAM,iGAAiG,CAEnH,EAAG,CAACL,CAAiB,CAAC,EAGtB,IAAMO,KAAoB,WAAQ,IAAM,CACtC,GAAIT,IAAU,OAAW,OAAO,KAChC,IAAIU,EAA4B,KAChC,OAAAR,EAAkB,QAAQ,CAAC,CAACC,EAAKC,CAAK,IAAM,CACtCJ,GAASI,IACXM,EAASP,EAEb,CAAC,EACMO,CACT,EAAG,CAACV,EAAOE,CAAiB,CAAC,KAG7B,aAAU,IAAM,CACVF,IAAU,QAAaA,EAAQ,GAAKS,IAAsB,OACxDP,EAAkB,OAAS,GAAKF,EAAQE,EAAkB,CAAC,EAAE,CAAC,EAChE,QAAQ,MACN,0CAA0CF,CAAK,mDAAmDE,EAAkB,CAAC,EAAE,CAAC,CAAC,4EAC3H,EAEA,QAAQ,MACN,uHACF,EAGN,EAAG,CAACF,EAAOS,EAAmBP,CAAiB,CAAC,EAGhD,IAAMS,EAAsBC,GACnBV,EAAkB,UAAU,CAAC,CAACC,CAAG,IAAMA,IAAQS,CAAI,EAGtDC,EAAaD,GACZH,EACEE,EAAmBF,CAAiB,GAAKE,EAAmBC,CAAI,EADxC,GAI3BE,EAAWF,GACVH,EACEE,EAAmBF,CAAiB,EAAIE,EAAmBC,CAAI,EADvC,GAKjC,SAASG,EAAqBC,EAAuD,CACnF,GAAKP,EACL,OAAOO,EAAOP,CAAiB,CACjC,CAEA,SACE,OAACd,EAAkB,SAAlB,CACC,MAAO,CACL,MAAOK,GAAS,EAChB,WAAYS,EACZ,YAAAZ,EACA,UAAAgB,EACA,QAAAC,EACA,kBAAAC,CACF,EAIC,SAAAhB,EAAYD,KAAW,OAAC,OAAI,IAAKG,EAAM,SAAAH,EAAS,EACnD,CAEJ,EAMamB,EAAgB,IAA6B,CACxD,IAAMC,KAAU,cAAWvB,CAAiB,EAC5C,GAAI,CAACuB,EACH,MAAM,IAAI,MAAM,wDAAwD,EAE1E,OAAOA,CACT,EAyBaC,EAA8D,CAAC,CAC1E,KAAAC,EACA,UAAWC,EACX,QAASC,EACT,SAAAxB,CACF,IAAM,CACJ,GAAM,CAAE,WAAAyB,EAAY,UAAWC,EAAkB,QAASC,CAAe,EAAIR,EAAc,EAEvFS,EAAe,GAEnB,OAAIN,GAAQG,IACVG,EAAeA,GAAgBN,EAAK,SAASG,CAAU,GAErDF,IACFK,EAAeA,GAAgBF,EAAiBH,CAAO,GAErDC,IACFI,EAAeA,GAAgBD,EAAeH,CAAO,GAGhDI,KAAe,mBAAG,SAAA5B,EAAS,EAAM,IAC1C",
  "names": ["src_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 CHANGED
@@ -1,2 +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"]
}

1
+ import{createContext as h,useContext as m,useMemo as c,useEffect as k}from"react";import{useResizeDetector as P}from"react-resize-detector";import{Fragment as C,jsx as u}from"react/jsx-runtime";var B=h(void 0),L=({breakpoints:i,children:s,targetRef:p})=>{let{width:o,ref:d}=P({targetRef:p}),t=c(()=>Object.entries(i).map(([e,a])=>[e,a]).sort(([,e],[,a])=>e-a),[i]);k(()=>{t.filter(([,a],l)=>t.findIndex(([,x])=>x===a)!==l).length>0&&console.error("BreakpointProvider: Duplicate breakpoint values detected. This may lead to unexpected behavior.")},[t]);let n=c(()=>{if(o===void 0)return null;let e=null;return t.forEach(([a,l])=>{o>=l&&(e=a)}),e},[o,t]);k(()=>{o!==void 0&&o>0&&n===null&&(t.length>0&&o<t[0][1]?console.error(`BreakpointProvider: The current width (${o}px) is less than the smallest breakpoint value (${t[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."))},[o,n,t]);let r=e=>t.findIndex(([a])=>a===e),f=e=>n?r(n)>=r(e):!1,b=e=>n?r(n)<r(e):!1;function v(e){if(n)return e[n]}return u(B.Provider,{value:{width:o??0,breakpoint:n,breakpoints:i,isAtLeast:f,isBelow:b,valueByBreakpoint:v},children:p?s:u("div",{ref:d,children:s})})},w=()=>{let i=m(B);if(!i)throw new Error("useBreakpoint must be used within a BreakpointProvider");return i},g=({show:i,isAtLeast:s,isBelow:p,children:o})=>{let{breakpoint:d,isAtLeast:t,isBelow:n}=w(),r=!0;return i&&d&&(r=r&&i.includes(d)),s&&(r=r&&t(s)),p&&(r=r&&n(p)),r?u(C,{children:o}):null};export{g as BreakpointConditional,L 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,\n   * 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> = ({ breakpoints, children, targetRef }) => {\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) => sortedBreakpoints.findIndex(([, v]) => v === value) !== index\n    );\n    if (duplicates.length > 0) {\n      console.error('BreakpointProvider: Duplicate breakpoint values detected. This may lead to unexpected behavior.');\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 > 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": "AAAA,OAAgB,iBAAAA,EAAe,cAAAC,EAAY,WAAAC,EAAS,aAAAC,MAAiB,QACrE,OAAS,qBAAAC,MAAyB,wBA4IJ,OA4DN,YAAAC,EA5DM,OAAAC,MAAA,oBAhH9B,IAAMC,EAAoBP,EAAiD,MAAS,EA8BvEQ,EAAwD,CAAC,CAAE,YAAAC,EAAa,SAAAC,EAAU,UAAAC,CAAU,IAAM,CAE7G,GAAM,CAAE,MAAAC,EAAO,IAAAC,CAAI,EAAIT,EAAkB,CAAE,UAAAO,CAAU,CAAC,EAGhDG,EAAoBZ,EAAQ,IACzB,OAAO,QAAQO,CAAW,EAC9B,IAAI,CAAC,CAACM,EAAKC,CAAK,IAAM,CAACD,EAAKC,CAAK,CAAyB,EAC1D,KAAK,CAAC,CAAC,CAAEC,CAAC,EAAG,CAAC,CAAEC,CAAC,IAAMD,EAAIC,CAAC,EAC9B,CAACT,CAAW,CAAC,EAGhBN,EAAU,IAAM,CACKW,EAAkB,OACnC,CAAC,CAAC,CAAEE,CAAK,EAAGG,IAAUL,EAAkB,UAAU,CAAC,CAAC,CAAEM,CAAC,IAAMA,IAAMJ,CAAK,IAAMG,CAChF,EACe,OAAS,GACtB,QAAQ,MAAM,iGAAiG,CAEnH,EAAG,CAACL,CAAiB,CAAC,EAGtB,IAAMO,EAAoBnB,EAAQ,IAAM,CACtC,GAAIU,IAAU,OAAW,OAAO,KAChC,IAAIU,EAA4B,KAChC,OAAAR,EAAkB,QAAQ,CAAC,CAACC,EAAKC,CAAK,IAAM,CACtCJ,GAASI,IACXM,EAASP,EAEb,CAAC,EACMO,CACT,EAAG,CAACV,EAAOE,CAAiB,CAAC,EAG7BX,EAAU,IAAM,CACVS,IAAU,QAAaA,EAAQ,GAAKS,IAAsB,OACxDP,EAAkB,OAAS,GAAKF,EAAQE,EAAkB,CAAC,EAAE,CAAC,EAChE,QAAQ,MACN,0CAA0CF,CAAK,mDAAmDE,EAAkB,CAAC,EAAE,CAAC,CAAC,4EAC3H,EAEA,QAAQ,MACN,uHACF,EAGN,EAAG,CAACF,EAAOS,EAAmBP,CAAiB,CAAC,EAGhD,IAAMS,EAAsBC,GACnBV,EAAkB,UAAU,CAAC,CAACC,CAAG,IAAMA,IAAQS,CAAI,EAGtDC,EAAaD,GACZH,EACEE,EAAmBF,CAAiB,GAAKE,EAAmBC,CAAI,EADxC,GAI3BE,EAAWF,GACVH,EACEE,EAAmBF,CAAiB,EAAIE,EAAmBC,CAAI,EADvC,GAKjC,SAASG,EAAqBC,EAAuD,CACnF,GAAKP,EACL,OAAOO,EAAOP,CAAiB,CACjC,CAEA,OACEf,EAACC,EAAkB,SAAlB,CACC,MAAO,CACL,MAAOK,GAAS,EAChB,WAAYS,EACZ,YAAAZ,EACA,UAAAgB,EACA,QAAAC,EACA,kBAAAC,CACF,EAIC,SAAAhB,EAAYD,EAAWJ,EAAC,OAAI,IAAKO,EAAM,SAAAH,EAAS,EACnD,CAEJ,EAMamB,EAAgB,IAA6B,CACxD,IAAMC,EAAU7B,EAAWM,CAAiB,EAC5C,GAAI,CAACuB,EACH,MAAM,IAAI,MAAM,wDAAwD,EAE1E,OAAOA,CACT,EAyBaC,EAA8D,CAAC,CAC1E,KAAAC,EACA,UAAWC,EACX,QAASC,EACT,SAAAxB,CACF,IAAM,CACJ,GAAM,CAAE,WAAAyB,EAAY,UAAWC,EAAkB,QAASC,CAAe,EAAIR,EAAc,EAEvFS,EAAe,GAEnB,OAAIN,GAAQG,IACVG,EAAeA,GAAgBN,EAAK,SAASG,CAAU,GAErDF,IACFK,EAAeA,GAAgBF,EAAiBH,CAAO,GAErDC,IACFI,EAAeA,GAAgBD,EAAeH,CAAO,GAGhDI,EAAehC,EAAAD,EAAA,CAAG,SAAAK,EAAS,EAAM,IAC1C",
  "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 CHANGED
@@ -1,104 +1,120 @@
1
1
  {
2
- "name": "react-resize-detector-context",
3
- "description": "",
4
- "version": "0.1.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": ["dist"],
34
- "config": {
35
- "commitizen": {
36
- "path": "./node_modules/@ryansonshine/cz-conventional-changelog"
37
- }
38
- },
39
- "release-it": {
40
- "git": {
41
- "commitMessage": "chore(release): v${version}"
42
- },
43
- "github": {
44
- "release": true
45
- },
46
- "npm": {
47
- "publish": false
48
- }
49
- },
50
- "engines": {
51
- "node": ">=18.0.0"
52
- },
53
- "devDependencies": {
54
- "@biomejs/biome": "1.9.4",
55
- "@mui/material": "^6.4.3",
56
- "@ryansonshine/commitizen": "4.2.8",
57
- "@ryansonshine/cz-conventional-changelog": "3.3.4",
58
- "@storybook/addon-essentials": "8.4.7",
59
- "@storybook/addon-interactions": "8.4.7",
60
- "@storybook/addon-links": "8.4.7",
61
- "@storybook/addon-webpack5-compiler-swc": "2.0.0",
62
- "@storybook/blocks": "8.4.7",
63
- "@storybook/react": "8.4.7",
64
- "@storybook/react-webpack5": "8.4.7",
65
- "@storybook/test": "8.4.7",
66
- "@testing-library/jest-dom": "6.6.3",
67
- "@testing-library/react": "^16.1.0",
68
- "@types/node": "22.10.5",
69
- "@types/react": "18.3.13",
70
- "@types/react-dom": "18.3.1",
71
- "@types/react-test-renderer": "18.3.0",
72
- "@types/testing-library__jest-dom": "^5.14.9",
73
- "@vitest/coverage-v8": "2.1.8",
74
- "concurrently": "9.1.2",
75
- "jsdom": "25.0.1",
76
- "lefthook": "1.10.1",
77
- "prop-types": "15.8.1",
78
- "react": "18.3.1",
79
- "react-dom": "18.3.1",
80
- "react-test-renderer": "18.3.1",
81
- "release-it": "17.11.0",
82
- "storybook": "8.4.7",
83
- "ts-node": "10.9.2",
84
- "tsconfig-paths": "4.2.0",
85
- "tsup": "8.3.5",
86
- "tsx": "4.19.2",
87
- "typescript": "5.7.2",
88
- "vitest": "^2.1.8",
89
- "@emotion/styled": "^11.14.0"
90
- },
91
- "peerDependencies": {
92
- "react": ">=17",
93
- "react-dom": ">=17"
94
- },
95
- "pnpm": {
96
- "overrides": {
97
- "micromatch@<4.0.8": ">=4.0.8"
98
- }
99
- },
100
- "dependencies": {
101
- "@emotion/styled": "^11.14.0",
102
- "react-resize-detector": "^12.0.2"
103
- }
104
- }
2
+ "name": "react-resize-detector-context",
3
+ "description": "",
4
+ "version": "0.1.2",
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": "eslint src --fix",
16
+ "lint:ci": "eslint src --debug",
17
+ "format": "prettier --write src",
18
+ "test": "vitest",
19
+ "test:ci": "vitest run --coverage",
20
+ "commit": "cz",
21
+ "storybook": "storybook dev -p 6006",
22
+ "storybook:build": "storybook build",
23
+ "release": "pnpm build && pnpm release-it",
24
+ "link:self": "pnpm link --global",
25
+ "prepare": "lefthook install"
26
+ },
27
+ "types": "./dist/index.d.ts",
28
+ "exports": {
29
+ ".": {
30
+ "require": "./dist/index.js",
31
+ "import": "./dist/index.mjs"
32
+ }
33
+ },
34
+ "files": [
35
+ "dist"
36
+ ],
37
+ "config": {
38
+ "commitizen": {
39
+ "path": "./node_modules/@ryansonshine/cz-conventional-changelog"
40
+ }
41
+ },
42
+ "lint-staged": {
43
+ "src/**/*.{js,jsx,ts,tsx,json,md}": [
44
+ "prettier --write",
45
+ "eslint --fix"
46
+ ]
47
+ },
48
+ "release-it": {
49
+ "git": {
50
+ "commitMessage": "chore(release): v${version}"
51
+ },
52
+ "github": {
53
+ "release": true
54
+ },
55
+ "npm": {
56
+ "publish": false
57
+ }
58
+ },
59
+ "engines": {
60
+ "node": ">=18.0.0"
61
+ },
62
+ "devDependencies": {
63
+ "@emotion/styled": "^11.14.0",
64
+ "@eslint/js": "^9.20.0",
65
+ "@mui/material": "^6.4.3",
66
+ "@ryansonshine/commitizen": "4.2.8",
67
+ "@ryansonshine/cz-conventional-changelog": "3.3.4",
68
+ "@storybook/addon-essentials": "8.4.7",
69
+ "@storybook/addon-interactions": "8.4.7",
70
+ "@storybook/addon-links": "8.4.7",
71
+ "@storybook/addon-webpack5-compiler-swc": "2.0.0",
72
+ "@storybook/blocks": "8.4.7",
73
+ "@storybook/react": "8.4.7",
74
+ "@storybook/react-webpack5": "8.4.7",
75
+ "@storybook/test": "8.4.7",
76
+ "@testing-library/jest-dom": "6.6.3",
77
+ "@testing-library/react": "^16.1.0",
78
+ "@types/node": "22.10.5",
79
+ "@types/react": "18.3.13",
80
+ "@types/react-dom": "18.3.1",
81
+ "@types/react-test-renderer": "18.3.0",
82
+ "@types/testing-library__jest-dom": "^5.14.9",
83
+ "@vitest/coverage-v8": "2.1.8",
84
+ "concurrently": "9.1.2",
85
+ "eslint": "^9.20.0",
86
+ "eslint-plugin-react": "^7.37.4",
87
+ "globals": "^15.14.0",
88
+ "husky": "^9.1.7",
89
+ "jsdom": "25.0.1",
90
+ "lefthook": "1.10.1",
91
+ "lint-staged": "^15.4.3",
92
+ "prettier": "^3.5.0",
93
+ "prop-types": "15.8.1",
94
+ "react": "18.3.1",
95
+ "react-dom": "18.3.1",
96
+ "react-test-renderer": "18.3.1",
97
+ "release-it": "17.11.0",
98
+ "storybook": "8.4.7",
99
+ "ts-node": "10.9.2",
100
+ "tsconfig-paths": "4.2.0",
101
+ "tsup": "8.3.5",
102
+ "tsx": "4.19.2",
103
+ "typescript": "5.7.2",
104
+ "typescript-eslint": "^8.23.0",
105
+ "vitest": "^2.1.8"
106
+ },
107
+ "peerDependencies": {
108
+ "react": ">=17",
109
+ "react-dom": ">=17"
110
+ },
111
+ "pnpm": {
112
+ "overrides": {
113
+ "micromatch@<4.0.8": ">=4.0.8"
114
+ }
115
+ },
116
+ "dependencies": {
117
+ "@emotion/styled": "^11.14.0",
118
+ "react-resize-detector": "^12.0.2"
119
+ }
120
+ }