Sidebar with variation animation in React Sidebar component
30 Jan 202316 minutes to read
In the following example, the sidebar is rendered with custom animation effects. Click the buttons available in the main content area to check how the custom animations works with sidebar.
Sidebar will automatically adjust expanding animation to match any custom size specified in CSS
styles.
import * as React from 'react';
import './index.css';
import { ButtonComponent } from '@syncfusion/ej2-react-buttons';
import { SidebarComponent } from '@syncfusion/ej2-react-navigations';
function App() {
let sidebarObj;
let btnObj;
let showBackdrop = true;
function onCreate() {
sidebarObj.element.style.visibility = '';
}
// Zoom Sidebar
function zoom() {
sidebarObj.show();
sidebarObj.element.classList.add("w3-animate-zoom");
}
// Open Door
function open_door() {
sidebarObj.show();
const sidebar = document.getElementsByClassName("e-sidebar-overlay")[0];
sidebar.classList.add("move");
}
// Bottom to Top
function bottom_top() {
sidebarObj.show();
sidebarObj.element.classList.add("w3-animate-bottom");
}
// Rotate
function rotate() {
sidebarObj.show();
sidebarObj.element.classList.add("rotate");
}
// Rotate 3D Effect
function rotate_3d() {
sidebarObj.show();
sidebarObj.element.classList.add("rotate_3d");
}
// Reverse Slide Out
function reverse() {
sidebarObj.show();
sidebarObj.element.classList.add("reverse_slide_out");
}
// Close Sidebar Element
function close() {
sidebarObj.element.classList.remove("sidebar");
sidebarObj.element.classList.remove("rotate");
sidebarObj.element.classList.remove("w3-animate-zoom");
sidebarObj.element.classList.remove("w3-animate-bottom");
sidebarObj.element.classList.remove("rotate_3d");
sidebarObj.element.classList.remove("reverse_slide_out");
sidebarObj.hide();
}
return (
// Declaration of Sidebar Element
<div className="control-section">
<SidebarComponent id="sidebar-element" className="sidebar" ref={Sidebar => sidebarObj = Sidebar} showBackdrop={showBackdrop} style={{ visibility: "hidden" }} created={onCreate} width="280px">
<div className="title"> Sidebar content</div>
<div className="sub-title">
* Sidebar is rendered with animation effect
</div>
<div className="center-align">
{/* Close Button Declaration*/}
<ButtonComponent onClick={close} id="close" className="e-btn close-btn">Close Sidebar</ButtonComponent>
</div>
</SidebarComponent>
{/*End of Sidebar Element Declaration*/}
{/* Main Content Declaration*/}
<div className="content">
<div className="title">Sidebar Transitions</div>
<div className="sub-title"> * Click the below button to render the Sidebar with animation effect.</div>
<div className="center-align">
{/*Button Declaaration */}
<ButtonComponent onClick={zoom} id="zoom" className="e-btn e-info">Zoom Sidebar</ButtonComponent>
<ButtonComponent onClick={open_door} id="open_door" className="e-btn e-info">Open Door</ButtonComponent>
<ButtonComponent onClick={bottom_top} id="bottom_top" className="e-btn e-info">Bottom to Top </ButtonComponent>
</div>
<div className="center-align">
<ButtonComponent onClick={rotate} id="rotate" className="e-btn e-info">Rotate</ButtonComponent>
<ButtonComponent onClick={rotate_3d} id="rotate_3d" className="e-btn e-info">Rotate 3D</ButtonComponent>
<ButtonComponent onClick={reverse} id="reverse" className="e-btn e-info">Reverse Slide Out </ButtonComponent>
</div>
</div>
</div>);
}
export default App;
import * as React from 'react';
import { ButtonComponent } from '@syncfusion/ej2-react-buttons';
import { SidebarComponent, SidebarType } from '@syncfusion/ej2-react-navigations';
import { enableRipple } from '@syncfusion/ej2-base';
function App() {
let sidebarObj: SidebarComponent;
let btnObj: ButtonComponent;
let showBackdrop: boolean = true;
function onCreate():void {
sidebarObj.element.style.visibility='';
}
// Zoom Sidebar
function zoom():void {
sidebarObj.show();
sidebarObj.element.classList.add("w3-animate-zoom");
}
// Open Door
function open_door():void {
sidebarObj.show();
const sidebar: Element =document.getElementsByClassName("e-sidebar-overlay")[0];
sidebar.classList.add("move");
}
// Bottom to Top
function bottom_top(): void {
sidebarObj.show();
sidebarObj.element.classList.add("w3-animate-bottom");
}
// Rotate
function rotate(): void {
sidebarObj.show();
sidebarObj.element.classList.add("rotate");
}
// Rotate 3D Effect
function rotate_3d(): void {
sidebarObj.show();
sidebarObj.element.classList.add("rotate_3d");
}
// Reverse Slide Out
function reverse(): void {
sidebarObj.show();
sidebarObj.element.classList.add("reverse_slide_out");
}
// Close Sidebar Element
function close(): void {
sidebarObj.element.classList.remove("sidebar");
sidebarObj.element.classList.remove("rotate");
sidebarObj.element.classList.remove("w3-animate-zoom");
sidebarObj.element.classList.remove("w3-animate-bottom");
sidebarObj.element.classList.remove("rotate_3d");
sidebarObj.element.classList.remove("reverse_slide_out");
sidebarObj.hide();
}
return (
// Declaration of Sidebar Element
<div className="control-section">
<SidebarComponent id="sidebar-element" className="sidebar" ref={Sidebar => sidebarObj = Sidebar as SidebarComponent} showBackdrop={showBackdrop} style={{visibility:"hidden"}} created={onCreate} width="280px">
<div className="title"> Sidebar content</div>
<div className="sub-title">
* Sidebar is rendered with animation effect
</div>
<div className="center-align">
{/* Close Button Declaration*/}
<ButtonComponent onClick={close} id="close" className="e-btn close-btn">Close Sidebar</ButtonComponent>
</div>
</SidebarComponent>
{/*End of Sidebar Element Declaration*/}
{/* Main Content Declaration*/}
<div className="content">
<div className="title">Sidebar Transitions</div>
<div className="sub-title"> * Click the below button to render the Sidebar with animation effect.</div>
<div className="center-align">
{/*Button Declaaration */}
<ButtonComponent onClick={zoom} id="zoom" className="e-btn e-info">Zoom Sidebar</ButtonComponent>
<ButtonComponent onClick={open_door} id="open_door" className="e-btn e-info">Open Door</ButtonComponent>
<ButtonComponent onClick={bottom_top} id="bottom_top" className="e-btn e-info">Bottom to Top </ButtonComponent>
</div>
<div className="center-align">
<ButtonComponent onClick={rotate} id="rotate" className="e-btn e-info">Rotate</ButtonComponent>
<ButtonComponent onClick={rotate_3d} id="rotate_3d" className="e-btn e-info">Rotate 3D</ButtonComponent>
<ButtonComponent onClick={reverse} id="reverse" className="e-btn e-info">Reverse Slide Out </ButtonComponent>
</div>
</div>
</div>
)
}
export default App;
import * as React from 'react';
import * as ReactDOM from 'react-dom';
import App from './App';
ReactDOM.render(<App />, document.getElementById('sample'));
import * as React from 'react';
import * as ReactDOM from 'react-dom';
import App from './App';
ReactDOM.render(<App />, document.getElementById('sample'));