Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
react-collapse
Advanced tools
Component-wrapper for collapse animation for elements with variable (and dynamic) height
The react-collapse package is a simple component for creating collapsible elements in React applications. It allows you to easily show and hide content with smooth animations.
Basic Collapse
This example demonstrates a basic usage of the react-collapse package. It includes a button that toggles the visibility of the content inside the Collapse component.
```jsx
import React, { useState } from 'react';
import { Collapse } from 'react-collapse';
const BasicCollapse = () => {
const [isOpen, setIsOpen] = useState(false);
return (
<div>
<button onClick={() => setIsOpen(!isOpen)}>
Toggle Collapse
</button>
<Collapse isOpened={isOpen}>
<div>
This content will collapse and expand.
</div>
</Collapse>
</div>
);
};
export default BasicCollapse;
```
Nested Collapse
This example shows how to use nested Collapse components. The outer Collapse contains another Collapse component, demonstrating how collapsible elements can be nested within each other.
```jsx
import React, { useState } from 'react';
import { Collapse } from 'react-collapse';
const NestedCollapse = () => {
const [isOuterOpen, setIsOuterOpen] = useState(false);
const [isInnerOpen, setIsInnerOpen] = useState(false);
return (
<div>
<button onClick={() => setIsOuterOpen(!isOuterOpen)}>
Toggle Outer Collapse
</button>
<Collapse isOpened={isOuterOpen}>
<div>
Outer content.
<button onClick={() => setIsInnerOpen(!isInnerOpen)}>
Toggle Inner Collapse
</button>
<Collapse isOpened={isInnerOpen}>
<div>
Inner content.
</div>
</Collapse>
</div>
</Collapse>
</div>
);
};
export default NestedCollapse;
```
react-collapsible is another package for creating collapsible elements in React. It offers similar functionality to react-collapse but with a slightly different API. It is more focused on providing a simple and straightforward way to create collapsible sections without additional configuration.
react-accessible-accordion is a package that provides accessible accordion components for React. While it offers similar collapsing functionality, it is more focused on accessibility and follows WAI-ARIA guidelines to ensure that the components are usable by people with disabilities.
react-bootstrap is a popular package that provides Bootstrap components for React, including collapsible elements. It offers a wide range of UI components and utilities, making it a more comprehensive solution compared to react-collapse, which is focused solely on collapsible elements.
Component-wrapper for collapse animation for elements with variable (and dynamic) height
http://nkbt.github.io/react-collapse
http://codepen.io/nkbt/pen/MarzEg
npm install --save react-collapse
yarn add react-collapse
<script src="https://unpkg.com/react/umd/react.production.min.js"></script>
<script src="https://unpkg.com/react-collapse/build/react-collapse.min.js"></script>
(Module exposed as `ReactCollapse`)
import {Collapse} from 'react-collapse';
// ...
<Collapse isOpened={true || false}>
<div>Random content</div>
</Collapse>
Use Unmount
component provided as:
import {UnmountClosed} from 'react-collapse';
// ...
<UnmountClosed isOpened={true || false}>
<div>Random content</div>
</UnmountClosed>
Example example/App/AutoUnmount.js
If you want a controlled and accessible implementation, check out this example
isOpened
: PropTypes.boolean.isRequiredExpands or collapses content.
children
: PropTypes.node.isRequiredOne or multiple children with static, variable or dynamic height.
<Collapse isOpened={true}>
<p>Paragraph of text</p>
<p>Another paragraph is also OK</p>
<p>Images and any other content are ok too</p>
<img src="nyancat.gif" />
</Collapse>
theme
: PropTypes.objectOf(PropTypes.string)It is possible to set className
for extra div
elements that ReactCollapse creates.
Example:
<Collapse theme={{collapse: 'foo', content: 'bar'}}>
<div>Customly animated container</div>
</Collapse>
Default values:
const theme = {
collapse: 'ReactCollapse--collapse',
content: 'ReactCollapse--content'
}
Which ends up in the following markup:
<div class="ReactCollapse--collapse">
<div class="ReactCollapse--content">
{children}
</div>
</div>
IMPORTANT: these are not style objects, but class names!
onRest
, onWork
: PropTypes.funcCallback functions, triggered when animation has completed (onRest
) or has just started (onWork
)
Both functions are called with argument:
const arg = {
isFullyOpened: true || false, // `true` only when Collapse reached final height
isFullyClosed: true || false, // `true` only when Collapse is fully closed and height is zero
isOpened: true || false, // `true` if Collapse has any non-zero height
containerHeight: 123, // current pixel height of Collapse container (changes until reaches `contentHeight`)
contentHeight: 123 // determined height of supplied Content
}
<Collapse onRest={console.log} onWork={console.log}>
<div>Container text</div>
</Collapse>
Example example/App/Hooks.js
initialStyle
: PropTypes.shapeinitialStyle: PropTypes.shape({
height: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
overflow: PropTypes.string
})
You may control initial element style, for example to force initial animation from 0 to height by using initialStyle={{height: '0px', overflow: 'hidden'}}
IMPORTANT Any updates to this prop will be ignored after first render.
Default value is determined based on initial isOpened
value:
initialStyle = props.isOpened
? {height: 'auto', overflow: 'initial'}
: {height: '0px', overflow: 'hidden'};
Example: example/App/ForceInitialAnimation.js
checkTimeout
: PropTypes.numberNumber in ms
.
Collapse will check height after thins timeout to determine if animation is completed, the shorter the number - the faster onRest
will be triggered and the quicker hight: auto
will be applied. The downside - more calculations.
Default value is: 50
.
IMPORTANT Collapse does not support any pass-through props, so any non-supported props will be ignored
Because we need to have control over when Collapse
component is updated and it is not possible or very hard to achieve when any random props can be passed to the component.
initially opened Collapse elements will be statically rendered with no animation. You can override this behaviour by using initialStyle
prop
due to the complexity of margins and their potentially collapsible nature, ReactCollapse
does not support (vertical) margins on their children. It might lead to the animation "jumping" to its correct height at the end of expanding. To avoid this, use padding instead of margin.
See #101 for more details
v4
to v5
v5
was another complete rewrite that happened quite a while ago, it was published as @nkbt/react-collapse
and tested in real projects for a long time and now fully ready to be used.
In the most common scenario upgrade is trivial (add CSS transition to collapse element), but if you were using a few deprecated props - there might be some extra work required.
Luckily almost every deprecated callback or prop has fully working analogue in v5
. Unfortunately not all of them could maintain full backward compatibility, so please check this migration guide below.
New Collapse does not implement animations anymore, it only determines Content
height and updates Collapse
wrapper height to match it.
Only after Collapse
height reaches Content
height (animation finished), Collapse's style is updated to have height: auto; overflow: initial
.
The implications is that you will need to update your CSS with transition:
.ReactCollapse--collapse {
transition: height 500ms;
}
IMPORTANT: without adding css transition there will be no animation and component will open/close instantly.
onRest
/onWork
callbacks (see above for full description). Though onRest
did exist previously, now it is called with arguments containing few operational params and flags.
initialStyle
you may control initial element style, for example to force initial animation from 0 to height by using initialStyle={{height: '0px', overflow: 'hidden'}}
IMPORTANT Any updates to this prop will be ignored after first render.
Default value is:
initialStyle = props.isOpened
? {height: 'auto', overflow: 'initial'}
: {height: '0px', overflow: 'hidden'};
checkTimeout
number in ms
. Collapse will check height after thins timeout to determine if animation is completed, the shorter the number - the faster onRest
will be triggered and the quicker hight: auto
will be applied. The downside - more calculations.
Default value is: 50
.
v5
)Pass-through props - any unknown props passed to Collapse
component will be ignored
hasNestedCollapse - no longer necessary, as v5 does not care if there are nested Collapse elements, see example/App/Nested.js
fixedHeight - no longer necessary, just set whatever height you need for content element and Collapse will work as expected, see example/App/VariableHeight.js
springConfig - as new Collapse relies on simple CSS transitions (or your own implementation of animation) and does not use react-collapse, springConfig is no longer necessary. You can control control animation with css like
.ReactCollapse--collapse {
transition: height 500ms;
}
forceInitialAnimation - you can use new prop initialStyle={{height: '0px', overflow: 'hidden'}}
instead, so when new height will be set after component is rendered - it should naturally animate.
onMeasure - please use onRest
and onWork
instead and pick contentHeight
from argument
<Collapse
onRest={({contentHeight}) => console.log(contentHeight)}
onWork={({contentHeight}) => console.log(contentHeight)}>
<div>content</div>
</Collapse>
onRender - since animations are fully controlled by external app (e.g. with CSS) we no draw each frame and do not actually re-render component anymore, so it is impossible to have onRender
callback
Currently is being developed and tested with the latest stable Node
on OSX
.
To run example covering all ReactCollapse
features, use yarn start
, which will compile example/Example.js
git clone git@github.com:nkbt/react-collapse.git
cd react-collapse
yarn install
yarn start
# then
open http://localhost:8080
# to run ESLint check
yarn lint
# to run tests
yarn test
MIT
FAQs
Component-wrapper for collapse animation for elements with variable (and dynamic) height
The npm package react-collapse receives a total of 122,693 weekly downloads. As such, react-collapse popularity was classified as popular.
We found that react-collapse demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.