Theme

npm_versionnpm Paragon package page

Collapsible is an element that allows a user to toggle (view/hide) supplemental information or actions.

When to use:

  • To organize related information.
  • To shorten pages and reduce scrolling when content is not crucial to read in full.
  • When space is at a premium and long content cannot be displayed all at once.

Basic Usage

The styling prop at the top level <Collapsible /> component determines if the collapsible has basic styling, card, or card with heading.

Basic Style

Any Paragon component or export may be added to the code example.

Card Style

This is the default style if no styling prop is supplied.

Any Paragon component or export may be added to the code example.

Default Open

Any Paragon component or export may be added to the code example.

With Callbacks

Any Paragon component or export may be added to the code example.


Advanced Usage

For needs that deviate from the three styles above, use <Collapsible.Advanced />

Bare minimum

Any Paragon component or export may be added to the code example.

Card style with advanced usage

Any Paragon component or export may be added to the code example.

With a close button

Any Paragon component or export may be added to the code example.

onOpen, onClose and onToggle callbacks

See the developer console for logging.

Any Paragon component or export may be added to the code example.

Controlled usage

Any Paragon component or export may be added to the code example.

Imperative methods

If you need to open or close the Collapsible intermittently due to an event, such as loading the page or clicking a link, you can open or close an uncontrolled Collapsible by getting a ref to the component and calling collapsibleRef.open() or collapsibleRef.close(). The internal state of the component will be updated accordingly.

Theme Variables (SCSS)#

$collapsible-card-spacer-y: .5rem !default;
$collapsible-card-spacer-x: .5rem !default;
$collapsible-card-spacer-y-lg: $card-spacer-y !default;
$collapsible-card-spacer-x-lg: $card-spacer-x !default;
$collapsible-card-body-spacer-left: .75rem !default;
$collapsible-card-spacer-icon: 2.5rem !default;
$collapsible-basic-spacer-y: .5rem !default;
$collapsible-basic-spacer-x: .5rem !default;
$collapsible-basic-spacer-icon: .625rem !default;

Props API#

Collapsible Props API
  • children node Required

    Specifies contents of the component.

  • className string

    Specifies class name to append to the base element.

  • defaultOpen bool

    Specifies whether the Collapsible should be initially open.

    Defaultfalse
  • iconWhenClosed element

    Specifies icon to show when Collapsible is closed.

    Default<Icon src={ExpandMore} />
  • iconWhenOpen element

    Specifies icon to show when Collapsible is open.

    Default<Icon src={ExpandLess} />
  • onClose func

    Callback fired when Collapsible closes.

  • onOpen func

    Callback fired when Collapsible opens.

  • onToggle func

    Callback fired when Collapsible's state is toggled.

  • open bool

    Specifies whether Collapsible is open.

  • styling enum'basic' | 'card' | 'card-lg'

    Specifies style variant.

    Default'card'
  • title node Required

    Specifies title.

  • unmountOnExit bool

    Unmount the component (remove it from the DOM) when it is collapsed

    Defaulttrue
CollapsibleAdvanced Props API
  • children node

    Specifies contents of the component.

  • className string

    Specifies classname to append to the base element.

  • defaultOpen bool

    Specifies whether Collapsible should be initially open.

    Defaultfalse
  • open bool

    Specifies whether Collapsible is open.

  • onToggle func

    Callback fired when Collapsible's state is toggled.

  • onOpen func

    Callback fired when Collapsible opens.

  • onClose func

    Callback fired when Collapsible closes.

  • unmountOnExit bool

    Unmount the component (remove it from the DOM) when it is collapsed.

    Defaulttrue
CollapsibleBody Props API
  • children node

    Specifies contents of the component.

  • tag string

    Specifies content's base element.

    Default'div'
  • transitionWrapper element

    Specifies transition element.

CollapsibleTrigger Props API
  • children node

    Specifies contents of the component.

  • tag string | elementType

    Specifies base element.

    Default'div'
  • openOnly bool

    Specifies whether toggling Collapsible's state will always trigger only open action.

    Defaultfalse
  • closeOnly bool

    Specifies whether toggling Collapsible's state will always trigger only close action.

    Defaultfalse
  • onClick func

    Callback fired when element gets clicked.

  • onKeyDown func

    Callback fired when a key is pressed.

CollapsibleVisible Props API
  • children node

    Specifies contents of the component.

  • whenOpen bool

    Specifies whether the content should be visible when Collapsible is open.

    Defaultfalse
  • whenClosed bool

    Specifies whether the content should be visible when Collapsible is closed.

    Defaultfalse

Usage Insights#

Collapsible

Project NameParagon VersionInstance Count
frontend-app-account20.46.34
frontend-app-admin-portal20.46.37
frontend-app-communications20.46.22
frontend-app-course-authoring21.5.62
frontend-app-gradebook20.45.04
frontend-app-learner-portal-enterprise20.45.44
frontend-app-learner-portal-programs20.45.51
frontend-app-learning20.46.01
frontend-app-ora-grading20.46.31
frontend-app-payment20.46.21
frontend-app-program-console20.46.22
frontend-app-publisher20.46.31
frontend-component-header-edx21.5.61
frontend-component-header21.5.61
frontend-learner-portal-base12.2.01
prospectus20.46.212

CollapsibleAdvanced

Project NameParagon VersionInstance Count
frontend-app-account20.46.31
frontend-app-course-authoring21.5.64
frontend-app-discussions20.46.33
frontend-app-learner-portal-enterprise20.45.42
frontend-app-learning20.46.03
frontend-app-ora-grading20.46.31
frontend-app-publisher20.46.31
frontend-lib-content-components21.5.68
prospectus20.46.24

CollapsibleBody

Project NameParagon VersionInstance Count
frontend-app-account20.46.31
frontend-app-course-authoring21.5.63
frontend-app-discussions20.46.33
frontend-app-learner-portal-enterprise20.45.42
frontend-app-learning20.46.03
frontend-app-ora-grading20.46.31
frontend-lib-content-components21.5.67
prospectus20.46.24

CollapsibleTrigger

Project NameParagon VersionInstance Count
frontend-app-account20.46.31
frontend-app-course-authoring21.5.64
frontend-app-discussions20.46.33
frontend-app-learner-portal-enterprise20.45.42
frontend-app-learning20.46.03
frontend-app-ora-grading20.46.31
frontend-app-publisher20.46.31
frontend-lib-content-components21.5.63
prospectus20.46.22

CollapsibleVisible

Project NameParagon VersionInstance Count
frontend-app-course-authoring21.5.66
frontend-app-discussions20.46.36
frontend-app-learner-portal-enterprise20.45.44
frontend-app-learning20.46.06
frontend-app-ora-grading20.46.32
frontend-app-publisher20.46.32
frontend-lib-content-components21.5.64
prospectus20.46.28