Skip to content

Commit

Permalink
Merge pull request #265 from dabapps/collapse-fixes
Browse files Browse the repository at this point in the history
Collapse fixes
  • Loading branch information
JakeSidSmith authored Aug 9, 2018
2 parents a20627d + 962c780 commit 6fc12e3
Show file tree
Hide file tree
Showing 5 changed files with 203 additions and 51 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@dabapps/roe",
"version": "0.8.36",
"version": "0.8.37",
"description": "A Collection of React Components for Project Development",
"main": "dist/js/index.js",
"types": "dist/js/index.d.ts",
Expand Down
99 changes: 99 additions & 0 deletions src/ts/components/collapse.examples.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
#### Examples

With lots of content:

```js
class CollapseExample extends React.Component {
constructor (props) {
Expand Down Expand Up @@ -45,3 +47,100 @@ class CollapseExample extends React.Component {

<CollapseExample />
```

With small content:

```js
class CollapseExample extends React.Component {
constructor (props) {
super(props);

this.state = {
open: false
};

this.onClickToggleCollapse = this.onClickToggleCollapse.bind(this);
}

onClickToggleCollapse () {
const { open } = this.state;

this.setState({
open: !open
});
}

render () {
const { open } = this.state;

return (
<div>
<Collapse
open={open}
maxCollapsedHeight={100}
fadeOut
fadeColor="#FFF"
fadeHeight={50}
animationDuration={200}
>
<DabIpsum count={1} />
</Collapse>
<Button className="primary margin-top-base" onClick={this.onClickToggleCollapse}>
{open ? 'Collapse' : 'Expand'}
</Button>
</div>
);
}
}

<CollapseExample />
```

With minimum height:

```js
class CollapseExample extends React.Component {
constructor (props) {
super(props);

this.state = {
open: false
};

this.onClickToggleCollapse = this.onClickToggleCollapse.bind(this);
}

onClickToggleCollapse () {
const { open } = this.state;

this.setState({
open: !open
});
}

render () {
const { open } = this.state;

return (
<div>
<Collapse
open={open}
maxCollapsedHeight={200}
minHeight={100}
fadeOut
fadeColor="#FFF"
fadeHeight={50}
animationDuration={200}
>
<DabIpsum count={1} />
</Collapse>
<Button className="primary margin-top-base" onClick={this.onClickToggleCollapse}>
{open ? 'Collapse' : 'Expand'}
</Button>
</div>
);
}
}

<CollapseExample />
```
15 changes: 11 additions & 4 deletions src/ts/components/collapse.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,12 @@ export interface CollapseProps extends ComponentProps, React.HTMLAttributes<HTML
* Maximum height when collapsed
* @default 0
*/
maxCollapsedHeight?: number;
maxCollapsedHeight?: number | string;
/**
* Minimum height
* @default auto
*/
minHeight?: number | string;
/**
* Whether to fade out the content
* @default false
Expand All @@ -43,7 +48,7 @@ export interface CollapseProps extends ComponentProps, React.HTMLAttributes<HTML
}

export interface CollapseState { // tslint:disable-line:no-unused-variable
height: number;
height: number | string;
opened: boolean;
opening: boolean;
}
Expand Down Expand Up @@ -117,6 +122,7 @@ export class Collapse extends PureComponent<CollapseProps, CollapseState> {
fadeHeight = DEFAULT_FADE_HEIGHT,
open,
maxCollapsedHeight,
minHeight = 'auto',
animationDuration = DEFAULT_DURATION,
component: Component = 'div',
...remainingProps
Expand All @@ -125,10 +131,11 @@ export class Collapse extends PureComponent<CollapseProps, CollapseState> {
const { opening, opened, height } = this.state;

const collapseStyle = {
height: opened ? 'auto' : height,
minHeight,
maxHeight: opened ? 'auto' : height,
position: 'relative' as 'relative',
overflow: 'hidden' as 'hidden',
transition: `ease-in-out ${animationDuration}ms height`
transition: `ease-in-out ${animationDuration}ms max-height`
};

const fadeStyle = {
Expand Down
Loading

0 comments on commit 6fc12e3

Please sign in to comment.