Skip to content

Commit

Permalink
Fixed #46
Browse files Browse the repository at this point in the history
  • Loading branch information
mertsincan committed Jul 10, 2017
1 parent 5e4d6bc commit 40fdd1c
Show file tree
Hide file tree
Showing 6 changed files with 538 additions and 0 deletions.
1 change: 1 addition & 0 deletions src/App.js
Original file line number Diff line number Diff line change
Expand Up @@ -207,6 +207,7 @@ class AppMenu extends Component {
<div className={classNames({ 'submenu-hidden': this.state.activeMenu !== 4, 'submenu-visible': this.state.activeMenu === 4 })}>
<Link to="/dialog">&#9679; Dialog</Link>
<Link to="/overlaypanel">&#9679; OverlayPanel</Link>
<Link to="/lightbox">&#9679; Lightbox</Link>
</div>

<a href="#" onClick={(event) => this.openMenu(event, 5)} className={classNames({ 'active-menuitem': this.state.activeMenu === 5 })}>
Expand Down
60 changes: 60 additions & 0 deletions src/components/lightbox/Lightbox.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
.ui-lightbox {
position: fixed;
}

.ui-lightbox-content-wrapper {
position: relative;
}

.ui-lightbox-content {
position: relative;
margin: 0;
padding: 0;
background-color: #000000;
}

.ui-lightbox-nav-right, .ui-lightbox-nav-left {
position: absolute;
top: 50%;
cursor: pointer;
}

.ui-lightbox-nav-left {
left: 0;
}

.ui-lightbox-nav-right {
right: 0;
}

.ui-lightbox-loading {
background: url("./images/loading.gif") #000000 center center no-repeat;
}

.ui-lightbox-caption {
padding: 0.2em 0.4em;
display: none;
}

.ui-lightbox-caption-text {
margin: 0.3em 0 0.1em 0;
float:left;
}

.ui-lightbox-close {
float:right;
margin: 0;
padding: .125em;
}

.ui-lightbox-close.ui-state-hover {
padding: 0;
}

.ui-lightbox-nav-left, .ui-lightbox-nav-right {
opacity: .5;
}

.ui-lightbox-nav-left:hover, .ui-lightbox-nav-right:hover{
opacity: 1;
}
213 changes: 213 additions & 0 deletions src/components/lightbox/Lightbox.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,213 @@
import React, {Component} from 'react';
import PropTypes from 'prop-types';
import DomHandler from '../utils/DomHandler';
import classNames from 'classnames';

export class Lightbox extends Component {

static defaultProps = {
images:null,
type:'images',
style:null,
styleClass:null,
easing:'ease-out',
effectDuration:'500ms'
};

static propTypes = {
images:PropTypes.array,
type:PropTypes.string,
style:PropTypes.object,
styleClass:PropTypes.string,
easing:PropTypes.string,
effectDuration:PropTypes.string
};

constructor() {
super();
this.state = {visible:false,currentImage:null};
}

componentDidMount() {
document.addEventListener('click', (event)=>{
if(!this.preventDocumentClickListener && this.state.visible) {
this.hide(event);
}
this.preventDocumentClickListener = false;
});

}

onImageClick(event,image,i) {
this.index=i;
this.setState({loading:true});
this.content.style.width = 32 + 'px';
this.content.style.height = 32 + 'px';
this.show();
this.displayImage(image);
this.preventDocumentClickListener = true;
event.preventDefault();
}

onLinkClick(event){
this.show();
this.preventDocumentClickListener = true;
event.preventDefault();
}

show(){
this.mask=document.createElement('div');
this.mask.style.zIndex=DomHandler.getZindex();
DomHandler.addMultipleClasses(this.mask, 'ui-widget-overlay ui-dialog-mask');
document.body.appendChild(this.mask);
this.zindex=DomHandler.getZindex();
this.center();
this.setState({visible:true});
}

center() {
let elementWidth = DomHandler.getOuterWidth(this.panel);
let elementHeight = DomHandler.getOuterHeight(this.panel);
let x,y;
if(elementWidth === 0 && elementHeight === 0) {
this.panel.style.visibility = 'hidden';
this.panel.style.display = 'block';
elementWidth = DomHandler.getOuterWidth(this.panel);
elementHeight = DomHandler.getOuterHeight(this.panel);
this.panel.style.display = 'none';
this.panel.style.visibility = 'visible';
}
let viewport = DomHandler.getViewport();
x = (viewport.width - elementWidth) / 2;
y = (viewport.height - elementHeight) / 2;

this.panel.style.left = x + 'px';
this.panel.style.top = y + 'px';
}

hide(event){
this.setState({captionText:null});
this.index = null;
this.setState({currentImage:null})
this.panel.style.left = 'auto';
this.panel.style.top = 'auto';

if(this.mask) {
document.body.removeChild(this.mask);
this.mask = null;
}

event.preventDefault();
this.setState({visible:false})
}

displayImage(image){
setTimeout(() => {
this.setState({currentImage: image});
this.setState({captionText:image.title});
}, 1000);
}

prev() {
this.setState({loading:true});
this.setState({captionText:null});
if(this.index > 0) {
this.displayImage(this.props.images[--this.index]);
}
}

next() {
this.setState({loading:true});
this.setState({captionText:null});
if(this.index <= (this.props.images.length - 1)) {
this.displayImage(this.props.images[++this.index]);
}
}

onImageLoad(event){
let image = event.target;
image.style.visibility = 'hidden';
image.style.display = 'block';
let imageWidth = DomHandler.getOuterWidth(image);
let imageHeight = DomHandler.getOuterHeight(image);
image.style.display = 'none';
image.style.visibility = 'visible';

this.content.style.width = imageWidth + 'px';
this.content.style.height = imageHeight + 'px';
this.panel.style.left = parseInt(this.panel.style.left,10) + (DomHandler.getOuterWidth(this.panel) - imageWidth) / 2 + 'px';
this.panel.style.top = parseInt(this.panel.style.top,10) + (DomHandler.getOuterHeight(this.panel) - imageHeight) / 2 + 'px';

setTimeout(() => {
DomHandler.fadeIn(image, 500);
image.style.display = 'block';
this.setState({loading:false});
}, parseInt(this.props.effectDuration,10));
}

render() {
var images;
var contentText,contentFrame;

var leftButton=classNames('ui-state-default ui-lightbox-nav-left ui-corner-right',
{'ui-helper-hidden':!(this.props.images && this.props.images.length && this.index !== 0 && this.state.currentImage)} );
var rightButton=classNames('ui-state-default ui-lightbox-nav-right ui-corner-left',
{'ui-helper-hidden':!(this.props.images && this.props.images.length && this.index < (this.props.images.length - 1) && this.state.currentImage)} );
var contentClass=classNames('ui-lightbox-content ui-corner-all',{'ui-lightbox-loading':this.state.loading})

if(this.props.type==='images'){
images=<div style={this.props.style} className={this.props.styleClass}>{
this.props.images && this.props.images.map((image,index)=>{
var imageItem=
<a href={image.source} onClick={event=>this.onImageClick(event,image,index)} key={index} ref={el=>this.image=el} style={{marginLeft:4}}>
<img src={image.thumbnail} title={image.title} alt={image.alt}/>
</a>
;
return imageItem;
})}</div>
}
if(this.props.type==='content'){
contentText=this.props.children && this.props.children.map((child,index)=>
child.type==='a'&&<span style={this.props.style} className={this.props.styleClass}
onClick={this.onLinkClick.bind(this)} key={index}>
{child}
</span>)
contentFrame=this.props.children && this.props.children.map((child,index)=>
child.type!=='a'&&<span key={index}>
{child}
</span>
)
}
return (<div>
{images}
{contentText}
<div className="ui-lightbox ui-widget ui-helper-hidden ui-corner-all ui-shadow"
style={{transitionProperty:'all',transitionDuration:this.props.effectDuration, transitionTimingFunction:this.props.easing, display:this.state.visible?'block':'none',
zIndex:this.zindex }} ref={el=>this.panel=el } onClick={()=>this.preventDocumentClickListener = true}>
<div className="ui-lightbox-content-wrapper">
<a className={leftButton} style={{zIndex:this.zindex?this.zindex+1:null}} onClick={this.prev.bind(this)}>
<span className="fa fa-fw fa-caret-left"></span>
</a>
<div className={contentClass} ref={el=>this.content=el}
style={{transitionProperty:"'width,height'",transitionDuration:this.props.effectDuration, transitionTimingFunction:this.props.easing}}>
<img ref={el=>this.img=el} src={this.state.currentImage ? this.state.currentImage.source : ''}
onLoad={this.onImageLoad.bind(this)} alt=""/>
{contentFrame}
</div>

<a className={rightButton} style={{zIndex:this.zindex?this.zindex+1:null}} onClick={this.next.bind(this)}>
<span className="fa fa-fw fa-caret-right"></span>
</a>
</div>
<div className="ui-lightbox-caption ui-widget-header" style={{display:this.state.captionText ? 'block' : 'none'}}>
<span className="ui-lightbox-caption-text">{this.state.captionText}</span>
<a className="ui-lightbox-close ui-corner-all" href="#" onClick={event=>this.hide(event)}>
<span className="fa fa-fw fa-close"></span>
</a>
<div style={{clear:'both'}}></div>
</div>
</div>
</div>
);
}
}
Binary file added src/components/lightbox/images/loading.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 2 additions & 0 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ import {PasswordDemo} from './showcase/password/PasswordDemo';
import {SetupPage} from './showcase/setup/SetupPage';
import {RatingDemo} from './showcase/rating/RatingDemo';
import {ToolbarDemo} from './showcase/toolbar/ToolbarDemo';
import {LightboxDemo} from './showcase/lightbox/LightboxDemo';
import {DataScrollerDemo} from './showcase/datascroller/DataScrollerDemo';
import {DataScrollerInlineDemo} from './showcase/datascroller/DataScrollerInlineDemo';
import {DataScrollerLoaderDemo} from './showcase/datascroller/DataScrollerLoaderDemo';
Expand Down Expand Up @@ -110,6 +111,7 @@ ReactDOM.render(
<Route path="/colorpicker" component={ColorPickerDemo} />
<Route path="/password" component={PasswordDemo} />
<Route path="/toolbar" component={ToolbarDemo} />
<Route path="/lightbox" component={LightboxDemo} />
<Route path="/rating" component={RatingDemo} />
<Route path="/datascroller" component={DataScrollerDemo} />
<Route path="/datascroller/inline" component={DataScrollerInlineDemo} />
Expand Down
Loading

0 comments on commit 40fdd1c

Please sign in to comment.