Panel React Component
Panel React component represents Side Panels component.
Panel Components
There are following components included:
- Panel- Panel element
Panel Properties
| Prop | Type | Default | Description | 
|---|---|---|---|
| side | string | Panel side. Could be leftorright | |
| left | boolean | Shortcut prop for side="left" | |
| right | boolean | Shortcut prop for side="right" | |
| effect | string | Panel effect. Can be cover,revealorpush | |
| cover | boolean | Shortcut prop for effect="cover" | |
| reveal | boolean | Shortcut prop for effect="reveal" | |
| push | boolean | Shortcut prop for effect="push" | |
| visibleBreakpoint | number | Minimal app width (in px) when left panel becomes always visible | |
| collapsedBreakpoint | number | Minimal app width (in px) when left panel becomes partially visible (collapsed) | |
| swipe | boolean | false | Enable if you want to enable ability to open/close panel with swipe | 
| swipeNoFollow | boolean | false | Fallback option for potentially better performance on old/slow devices. If you enable it, then swipe panel will not follow your finger during touch move, it will be automatically opened/closed on swipe left/right. | 
| swipeActiveArea | number | 0 | Width (in px) of invisible edge from the screen that triggers panel swipe | 
| swipeOnlyClose | boolean | false | This parameter allows to close (but not open) panel with swipes. ( swipeshould be also enabled) | 
| swipeThreshold | number | 0 | Panel will not move with swipe if "touch distance" will be less than this value (in px). | 
| backdrop | boolean | true | Enables Panel backdrop (dark semi transparent layer behind) | 
| backdropEl | HTMLElement string | HTML element or string CSS selector of custom backdrop element | |
| closeByBackdropClick | boolean | true | Enable/disable ability to close panel by clicking outside of panel | 
| resizable | boolean | false | Enables/disables resizable panel | 
| containerEl | HTMLElement string | Element to mount panel to (default to app root element) | |
| opened | boolean | Allows to open/close panel and set its initial state | 
Panel Events
| Event | Description | 
|---|---|
| panelOpen | Event will be triggered when Panel starts its opening animation | 
| panelOpened | Event will be triggered after Panel completes its opening animation | 
| panelClose | Event will be triggered when Panel starts its closing animation | 
| panelClosed | Event will be triggered after Panel completes its closing animation | 
| panelBackdropClick | Event will be triggered when the panel backdrop is clicked | 
| panelSwipe | Event will be triggered for swipe panels during touch swipe action | 
| panelSwipeOpen | Event will be triggered in the very beginning of opening it with swipe | 
| panelCollapsedBreakpoint | Event will be triggered when it becomes visible/hidden when app width matches its collapsedBreakpoint | 
| panelBreakpoint | Event will be triggered when it becomes visible/hidden when app width matches its visibleBreakpoint | 
Open And Close Panel
You can control panel state, open and closing it:
- using Panel API
- by passing trueorfalseto itsopenedprop
- by clicking on Link or Button with relevant panelOpenproperty (to open it) andpanelCloseproperty to close it
Examples
import React from 'react';
import { App, Panel, View, Page, Block, Navbar, Row, Col, Button, Link } from 'framework7-react';
import './panel.css';
export default () => (
  <App>
    <Panel resizable left reveal>
      <View>
        <Page>
          <Block>Left panel content</Block>
        </Page>
      </View>
    </Panel>
    <Panel resizable right dark>
      <View>
        <Page>
          <Block>Right panel content</Block>
        </Page>
      </View>
    </Panel>
    <View main>
      <Page id="panel-page">
        <Navbar title="Panel"></Navbar>
        <Panel left cover dark containerEl="#panel-page" id="panel-nested">
          <Page>
            <Block strong>
              <p>This is page-nested Panel.</p>
              <p>
                <Link panelClose>Close me</Link>
              </p>
            </Block>
          </Page>
        </Panel>
        <Block>
          <Row tag="p">
            <Col tag="span">
              <Button raised fill panelOpen="left">
                Open left panel
              </Button>
            </Col>
            <Col tag="span">
              <Button raised fill panelOpen="right">
                Open right panel
              </Button>
            </Col>
          </Row>
          <Row tag="p">
            <Col tag="span">
              <Button raised fill panelOpen="#panel-nested">
                Open nested panel
              </Button>
            </Col>
          </Row>
        </Block>
      </Page>
    </View>
  </App>
);
/* panel.css */
.panel {
  min-width: 100px;
  max-width: 90vw;
}




