Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

react-photo-gallery

Package Overview
Dependencies
Maintainers
1
Versions
97
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-photo-gallery - npm Package Compare versions

Comparing version 5.0.4 to 5.0.5

dist/react-photo-gallery.js

11

examples/dist/bundle.js

@@ -65,11 +65,8 @@ require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({"react-photo-gallery":[function(require,module,exports){

photoPreviewNodes = [];
if (!this.props.cols) {
cols = 3;
}
var contWidth = this.state.containerWidth - cols * 4; /* 4px for margin around each image*/
contWidth = Math.floor(contWidth - 2); // add some padding to prevent layout prob
contWidth = Math.floor(contWidth); // add some padding to prevent layout prob
var remainder = this.props.photos.length % cols;
if (remainder) {
// there are fewer than photos than cols num in last row
var lastRowWidth = Math.floor(this.state.containerWidth - remainder * 4 - 2);
// there are fewer photos than cols num in last row
var lastRowWidth = Math.floor(this.state.containerWidth / cols * remainder - remainder * 4);
var lastRowIndex = this.props.photos.length - remainder;

@@ -191,2 +188,2 @@ }

},{"react":undefined}]},{},[])
//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","/Users/octavia/dev/react-photo-gallery/src/Gallery.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","import React from 'react';\n\nclass Gallery extends React.Component{\n    constructor(){\n\tsuper();\n\tthis.state = {\n\t    containerWidth: 0\n\t};\n\tthis.handleResize = this.handleResize.bind(this);\n    }\n    componentDidMount(){\n\tthis.setState({containerWidth: Math.floor(this._gallery.clientWidth)})\n        window.addEventListener('resize', this.handleResize);\n    }\n    componentDidUpdate(){\n\tif (this._gallery.clientWidth !== this.state.containerWidth){\n\t    this.setState({containerWidth: Math.floor(this._gallery.clientWidth)});\n\t}\n    }\n    componentWillUnmount(){\n\t window.removeEventListener('resize', this.handleResize, false);\n    }\n    handleResize(e){\n        this.setState({containerWidth: Math.floor(this._gallery.clientWidth)});\n    }\n    render(){\n        var cols = this.props.cols,\n            photoPreviewNodes = [];\n\tif (!this.props.cols){\n\t   cols = 3;    \n\t}\n        var contWidth = this.state.containerWidth - (cols * 4); /* 4px for margin around each image*/\n        contWidth = Math.floor(contWidth - 2); // add some padding to prevent layout prob\n        var remainder = this.props.photos.length % cols;\n        if (remainder) { // there are fewer than photos than cols num in last row\n          var lastRowWidth = Math.floor(this.state.containerWidth - (remainder * 4) - 2);\n          var lastRowIndex = this.props.photos.length - remainder;\n        }\n        // loop thru each set of  cols num\n        // eg. if cols is 3 it will  loop thru 0,1,2, then 3,4,5 to perform calculations for the particular set\n        for (var i=0;i<this.props.photos.length;i+=cols){\n            var totalAr=0,\n            commonHeight = 0;\n\n\t    // get the total aspect ratio of the row\n            for (var j=i; j<i+cols; j++){\n                if (j == this.props.photos.length){\n                    break;\n                }\n\t\tthis.props.photos[j].aspectRatio = this.props.photos[j].width / this.props.photos[j].height;\t\n\t\ttotalAr += this.props.photos[j].aspectRatio;\n            }\n            if (i === lastRowIndex) {\n              commonHeight = lastRowWidth / totalAr;\n            } else {\n              commonHeight = contWidth / totalAr;\n            }\n            // run thru the same set of items again to give the width and common height\n            for (let k=i; k<i+cols; k++){\n                if (k == this.props.photos.length){\n                    break;\n                }\n\t\tvar src = this.props.photos[k].src;\n\t\tif (this.props.onClickPhoto){\n\t\t    photoPreviewNodes.push(\n\t\t\t <div key={k} style={style}>\n\t\t\t    <a href=\"#\" className={k} onClick={(e) => this.props.onClickPhoto(k, e)}><img src={src} style={{display:'block', border:0}} height={commonHeight} width={commonHeight * this.props.photos[k].aspectRatio} alt=\"\" /></a>\n\t\t\t </div>\n\t\t    );\n\t\t}\n\t\telse{\n\t\t    photoPreviewNodes.push(\n\t\t\t <div key={k} style={style}>\n\t\t\t    <img src={src} style={{display:'block', border:0}} height={commonHeight} width={commonHeight * this.props.photos[k].aspectRatio} alt=\"\" />\n\t\t\t </div>\n\t\t    );\n\t\t}\n            }\n        }\n\treturn(\n\t    this.renderGallery(photoPreviewNodes)\n        );\n    }\n    renderGallery(photoPreviewNodes){\n\tif (this.props.disableLightbox){\n\t    return(\n\t\t<div id=\"Gallery\" className=\"clearfix\" ref={(c) => this._gallery = c}>\n\t\t    {photoPreviewNodes}\n\t\t</div>\n\t    );\n\t}\n\telse{\n\t    return(\n\t\t<div id=\"Gallery\" className=\"clearfix\" ref={(c) => this._gallery = c}>\n\t\t    {photoPreviewNodes}\n\t\t</div>\n\t    );\n\t}\n    }\n};\nGallery.displayName = 'Gallery';\nGallery.propTypes = {\n    photos: function(props, propName, componentName){\n\treturn React.PropTypes.arrayOf(\n\t    React.PropTypes.shape({\n\t\tsrc: React.PropTypes.string.isRequired,\n\t\twidth: React.PropTypes.number.isRequired,\n\t\theight: React.PropTypes.number.isRequired,\n\t    })\n\t).isRequired.apply(this,arguments);\n    },\n    onClickPhoto: React.PropTypes.func,\n    cols: React.PropTypes.number\n};\nGallery.defaultProps = {\n    cols: 3\n}\n// Gallery image style\nconst style = {\n   display: 'block',\n   margin: 2,\n   backgroundColor:'#e3e3e3',\n   float: 'left'\n}\n\nexport default Gallery;\n"]}
//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","/Users/octavia/dev/react-photo-gallery/src/Gallery.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","import React from 'react';\n\nclass Gallery extends React.Component{\n    constructor(){\n\tsuper();\n\tthis.state = {\n\t    containerWidth: 0\n\t};\n\tthis.handleResize = this.handleResize.bind(this);\n    }\n    componentDidMount(){\n\tthis.setState({containerWidth: Math.floor(this._gallery.clientWidth)})\n        window.addEventListener('resize', this.handleResize);\n    }\n    componentDidUpdate(){\n\tif (this._gallery.clientWidth !== this.state.containerWidth){\n\t    this.setState({containerWidth: Math.floor(this._gallery.clientWidth)});\n\t}\n    }\n    componentWillUnmount(){\n\t window.removeEventListener('resize', this.handleResize, false);\n    }\n    handleResize(e){\n        this.setState({containerWidth: Math.floor(this._gallery.clientWidth)});\n    }\n    render(){\n        var cols = this.props.cols,\n            photoPreviewNodes = [];\n        var contWidth = this.state.containerWidth - (cols * 4); /* 4px for margin around each image*/\n        contWidth = Math.floor(contWidth); // add some padding to prevent layout prob\n        var remainder = this.props.photos.length % cols;\n        if (remainder) { // there are fewer photos than cols num in last row\n          var lastRowWidth = Math.floor( ((this.state.containerWidth / cols) * remainder) - (remainder * 4) );\n          var lastRowIndex = this.props.photos.length - remainder;\n        }\n        // loop thru each set of  cols num\n        // eg. if cols is 3 it will  loop thru 0,1,2, then 3,4,5 to perform calculations for the particular set\n        for (var i=0;i<this.props.photos.length;i+=cols){\n            var totalAr=0,\n            commonHeight = 0;\n\n\t    // get the total aspect ratio of the row\n            for (var j=i; j<i+cols; j++){\n                if (j == this.props.photos.length){\n                    break;\n                }\n\t\tthis.props.photos[j].aspectRatio = this.props.photos[j].width / this.props.photos[j].height;\t\n\t\ttotalAr += this.props.photos[j].aspectRatio;\n            }\n            if (i === lastRowIndex) {\n              commonHeight = lastRowWidth / totalAr;\n            } else {\n              commonHeight = contWidth / totalAr;\n            }\n            // run thru the same set of items again to give the width and common height\n            for (let k=i; k<i+cols; k++){\n                if (k == this.props.photos.length){\n                    break;\n                }\n\t\tvar src = this.props.photos[k].src;\n\t\tif (this.props.onClickPhoto){\n\t\t    photoPreviewNodes.push(\n\t\t\t <div key={k} style={style}>\n\t\t\t    <a href=\"#\" className={k} onClick={(e) => this.props.onClickPhoto(k, e)}><img src={src} style={{display:'block', border:0}} height={commonHeight} width={commonHeight * this.props.photos[k].aspectRatio} alt=\"\" /></a>\n\t\t\t </div>\n\t\t    );\n\t\t}\n\t\telse{\n\t\t    photoPreviewNodes.push(\n\t\t\t <div key={k} style={style}>\n\t\t\t    <img src={src} style={{display:'block', border:0}} height={commonHeight} width={commonHeight * this.props.photos[k].aspectRatio} alt=\"\" />\n\t\t\t </div>\n\t\t    );\n\t\t}\n            }\n        }\n\treturn(\n\t    this.renderGallery(photoPreviewNodes)\n        );\n    }\n    renderGallery(photoPreviewNodes){\n\tif (this.props.disableLightbox){\n\t    return(\n\t\t<div id=\"Gallery\" className=\"clearfix\" ref={(c) => this._gallery = c}>\n\t\t    {photoPreviewNodes}\n\t\t</div>\n\t    );\n\t}\n\telse{\n\t    return(\n\t\t<div id=\"Gallery\" className=\"clearfix\" ref={(c) => this._gallery = c}>\n\t\t    {photoPreviewNodes}\n\t\t</div>\n\t    );\n\t}\n    }\n};\nGallery.displayName = 'Gallery';\nGallery.propTypes = {\n    photos: function(props, propName, componentName){\n\treturn React.PropTypes.arrayOf(\n\t    React.PropTypes.shape({\n\t\tsrc: React.PropTypes.string.isRequired,\n\t\twidth: React.PropTypes.number.isRequired,\n\t\theight: React.PropTypes.number.isRequired,\n\t    })\n\t).isRequired.apply(this,arguments);\n    },\n    onClickPhoto: React.PropTypes.func,\n    cols: React.PropTypes.number\n};\nGallery.defaultProps = {\n    cols: 3\n}\n// Gallery image style\nconst style = {\n   display: 'block',\n   margin: 2,\n   backgroundColor:'#e3e3e3',\n   float: 'left'\n}\n\nexport default Gallery;\n"]}

@@ -66,11 +66,8 @@ (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.Gallery = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){

photoPreviewNodes = [];
if (!this.props.cols) {
cols = 3;
}
var contWidth = this.state.containerWidth - cols * 4; /* 4px for margin around each image*/
contWidth = Math.floor(contWidth - 2); // add some padding to prevent layout prob
contWidth = Math.floor(contWidth); // add some padding to prevent layout prob
var remainder = this.props.photos.length % cols;
if (remainder) {
// there are fewer than photos than cols num in last row
var lastRowWidth = Math.floor(this.state.containerWidth - remainder * 4 - 2);
// there are fewer photos than cols num in last row
var lastRowWidth = Math.floor(this.state.containerWidth / cols * remainder - remainder * 4);
var lastRowIndex = this.props.photos.length - remainder;

@@ -77,0 +74,0 @@ }

'use strict';
Object.defineProperty(exports, '__esModule', {
value: true
value: true
});

@@ -21,170 +21,137 @@

var _reactDom = require('react-dom');
var Gallery = (function (_React$Component) {
_inherits(Gallery, _React$Component);
var _reactDom2 = _interopRequireDefault(_reactDom);
function Gallery() {
_classCallCheck(this, Gallery);
var _reactImages = require('react-images');
_get(Object.getPrototypeOf(Gallery.prototype), 'constructor', this).call(this);
this.state = {
containerWidth: 0
};
this.handleResize = this.handleResize.bind(this);
}
var _reactImages2 = _interopRequireDefault(_reactImages);
_createClass(Gallery, [{
key: 'componentDidMount',
value: function componentDidMount() {
this.setState({ containerWidth: Math.floor(this._gallery.clientWidth) });
window.addEventListener('resize', this.handleResize);
}
}, {
key: 'componentDidUpdate',
value: function componentDidUpdate() {
if (this._gallery.clientWidth !== this.state.containerWidth) {
this.setState({ containerWidth: Math.floor(this._gallery.clientWidth) });
}
}
}, {
key: 'componentWillUnmount',
value: function componentWillUnmount() {
window.removeEventListener('resize', this.handleResize, false);
}
}, {
key: 'handleResize',
value: function handleResize(e) {
this.setState({ containerWidth: Math.floor(this._gallery.clientWidth) });
}
}, {
key: 'render',
value: function render() {
var _this = this;
var Gallery = (function (_React$Component) {
_inherits(Gallery, _React$Component);
var cols = this.props.cols,
photoPreviewNodes = [];
var contWidth = this.state.containerWidth - cols * 4; /* 4px for margin around each image*/
contWidth = Math.floor(contWidth); // add some padding to prevent layout prob
var remainder = this.props.photos.length % cols;
if (remainder) {
// there are fewer photos than cols num in last row
var lastRowWidth = Math.floor(this.state.containerWidth / cols * remainder - remainder * 4);
var lastRowIndex = this.props.photos.length - remainder;
}
// loop thru each set of cols num
// eg. if cols is 3 it will loop thru 0,1,2, then 3,4,5 to perform calculations for the particular set
for (var i = 0; i < this.props.photos.length; i += cols) {
var totalAr = 0,
commonHeight = 0;
function Gallery() {
_classCallCheck(this, Gallery);
// get the total aspect ratio of the row
for (var j = i; j < i + cols; j++) {
if (j == this.props.photos.length) {
break;
}
this.props.photos[j].aspectRatio = this.props.photos[j].width / this.props.photos[j].height;
totalAr += this.props.photos[j].aspectRatio;
}
if (i === lastRowIndex) {
commonHeight = lastRowWidth / totalAr;
} else {
commonHeight = contWidth / totalAr;
}
// run thru the same set of items again to give the width and common height
_get(Object.getPrototypeOf(Gallery.prototype), 'constructor', this).call(this);
this.state = {
currentImage: 0,
containerWidth: 0
};
this.handleResize = this.handleResize.bind(this);
this.closeLightbox = this.closeLightbox.bind(this);
this.gotoNext = this.gotoNext.bind(this);
this.gotoPrevious = this.gotoPrevious.bind(this);
this.openLightbox = this.openLightbox.bind(this);
}
var _loop = function (k) {
if (k == _this.props.photos.length) {
return 'break';
}
src = _this.props.photos[k].src;
_createClass(Gallery, [{
key: 'componentDidMount',
value: function componentDidMount() {
this.setState({ containerWidth: Math.floor(_reactDom2['default'].findDOMNode(this).clientWidth) });
window.addEventListener('resize', this.handleResize);
}
}, {
key: 'componentDidUpdate',
value: function componentDidUpdate() {
if (_reactDom2['default'].findDOMNode(this).clientWidth !== this.state.containerWidth) {
this.setState({ containerWidth: Math.floor(_reactDom2['default'].findDOMNode(this).clientWidth) });
}
}
}, {
key: 'componentWillUnmount',
value: function componentWillUnmount() {
window.removeEventListener('resize', this.handleResize, false);
}
}, {
key: 'handleResize',
value: function handleResize(e) {
this.setState({ containerWidth: Math.floor(_reactDom2['default'].findDOMNode(this).clientWidth) });
}
}, {
key: 'openLightbox',
value: function openLightbox(index, event) {
event.preventDefault();
this.setState({
currentImage: index,
lightboxIsOpen: true
});
}
}, {
key: 'closeLightbox',
value: function closeLightbox() {
this.setState({
currentImage: 0,
lightboxIsOpen: false
});
}
}, {
key: 'gotoPrevious',
value: function gotoPrevious() {
this.setState({
currentImage: this.state.currentImage - 1
});
}
}, {
key: 'gotoNext',
value: function gotoNext() {
this.setState({
currentImage: this.state.currentImage + 1
});
}
}, {
key: 'render',
value: function render() {
var rowLimit = 1,
photoPreviewNodes = [];
if (this.state.containerWidth >= 480) {
rowLimit = 2;
}
if (this.state.containerWidth >= 1024) {
rowLimit = 3;
}
var contWidth = this.state.containerWidth - rowLimit * 4; /* 4px for margin around each image*/
contWidth = Math.floor(contWidth - 2); // add some padding to prevent layout prob
var lightboxImages = [];
for (var i = 0; i < this.props.photos.length; i += rowLimit) {
var rowItems = [];
// loop thru each set of rowLimit num
// eg. if rowLimit is 3 it will loop thru 0,1,2, then 3,4,5 to perform calculations for the particular set
var aspectRatio = 0,
totalAr = 0,
commonHeight = 0;
for (var j = i; j < i + rowLimit; j++) {
if (j == this.props.photos.length) {
break;
}
totalAr += this.props.photos[j].aspectRatio;
}
commonHeight = contWidth / totalAr;
// run thru the same set of items again to give the common height
for (var k = i; k < i + rowLimit; k++) {
if (k == this.props.photos.length) {
break;
}
var src = this.props.photos[k].src;
if (_this.props.onClickPhoto) {
photoPreviewNodes.push(_react2['default'].createElement(
'div',
{ key: k, style: style },
_react2['default'].createElement(
'a',
{ href: '#', className: k, onClick: function (e) {
return _this.props.onClickPhoto(k, e);
} },
_react2['default'].createElement('img', { src: src, style: { display: 'block', border: 0 }, height: commonHeight, width: commonHeight * _this.props.photos[k].aspectRatio, alt: '' })
)
));
} else {
photoPreviewNodes.push(_react2['default'].createElement(
'div',
{ key: k, style: style },
_react2['default'].createElement('img', { src: src, style: { display: 'block', border: 0 }, height: commonHeight, width: commonHeight * _this.props.photos[k].aspectRatio, alt: '' })
));
}
};
if (this.props.disableLightbox) {
photoPreviewNodes.push(_react2['default'].createElement(
'div',
{ key: k, style: style },
_react2['default'].createElement('img', { src: src, style: { display: 'block', border: 0 }, height: commonHeight, width: commonHeight * this.props.photos[k].aspectRatio, alt: '' })
));
} else {
lightboxImages.push(this.props.photos[k].lightboxImage);
photoPreviewNodes.push(_react2['default'].createElement(
'div',
{ key: k, style: style },
_react2['default'].createElement(
'a',
{ href: '#', className: k, onClick: this.openLightbox.bind(this, k) },
_react2['default'].createElement('img', { src: src, style: { display: 'block', border: 0 }, height: commonHeight, width: commonHeight * this.props.photos[k].aspectRatio, alt: '' })
)
));
}
}
}
return this.renderGallery(photoPreviewNodes, lightboxImages);
}
}, {
key: 'renderGallery',
value: function renderGallery(photoPreviewNodes, lightboxImages) {
if (this.props.disableLightbox) {
return _react2['default'].createElement(
'div',
{ id: 'Gallery', className: 'clearfix' },
photoPreviewNodes
);
} else {
return _react2['default'].createElement(
'div',
{ id: 'Gallery', className: 'clearfix' },
photoPreviewNodes,
_react2['default'].createElement(_reactImages2['default'], {
currentImage: this.state.currentImage,
images: lightboxImages,
isOpen: this.state.lightboxIsOpen,
onClose: this.closeLightbox,
onClickPrev: this.gotoPrevious,
onClickNext: this.gotoNext,
width: 1600,
showImageCount: this.props.lightboxShowImageCount,
backdropClosesModal: this.props.backdropClosesModal
})
);
}
}
}]);
for (var k = i; k < i + cols; k++) {
var src;
return Gallery;
var _ret = _loop(k);
if (_ret === 'break') break;
}
}
return this.renderGallery(photoPreviewNodes);
}
}, {
key: 'renderGallery',
value: function renderGallery(photoPreviewNodes) {
var _this2 = this;
if (this.props.disableLightbox) {
return _react2['default'].createElement(
'div',
{ id: 'Gallery', className: 'clearfix', ref: function (c) {
return _this2._gallery = c;
} },
photoPreviewNodes
);
} else {
return _react2['default'].createElement(
'div',
{ id: 'Gallery', className: 'clearfix', ref: function (c) {
return _this2._gallery = c;
} },
photoPreviewNodes
);
}
}
}]);
return Gallery;
})(_react2['default'].Component);

@@ -195,28 +162,21 @@

Gallery.propTypes = {
photos: function photos(props, propName, componentName) {
var lightboxImageValidator = _react2['default'].PropTypes.object;
if (!props.disableLightbox) {
lightboxImageValidator = _react2['default'].PropTypes.object.isRequired;
}
return _react2['default'].PropTypes.arrayOf(_react2['default'].PropTypes.shape({
src: _react2['default'].PropTypes.string.isRequired,
width: _react2['default'].PropTypes.number.isRequired,
height: _react2['default'].PropTypes.number.isRequired,
aspectRatio: _react2['default'].PropTypes.number.isRequired,
lightboxImage: lightboxImageValidator
})).isRequired.apply(this, arguments);
},
disableLightbox: _react2['default'].PropTypes.bool
photos: function photos(props, propName, componentName) {
return _react2['default'].PropTypes.arrayOf(_react2['default'].PropTypes.shape({
src: _react2['default'].PropTypes.string.isRequired,
width: _react2['default'].PropTypes.number.isRequired,
height: _react2['default'].PropTypes.number.isRequired
})).isRequired.apply(this, arguments);
},
onClickPhoto: _react2['default'].PropTypes.func,
cols: _react2['default'].PropTypes.number
};
Gallery.defaultProps = {
lightboxShowImageCount: false,
backdropClosesModal: true,
disableLightbox: false
cols: 3
};
// Gallery image style
var style = {
display: 'block',
margin: 2,
backgroundColor: '#e3e3e3',
float: 'left'
display: 'block',
margin: 2,
backgroundColor: '#e3e3e3',
float: 'left'
};

@@ -223,0 +183,0 @@

{
"name": "react-photo-gallery",
"version": "5.0.4",
"version": "5.0.5",
"description": "Responsive React Photo Gallery Component",

@@ -5,0 +5,0 @@ "main": "lib/Gallery.js",

@@ -29,10 +29,7 @@ import React from 'react';

photoPreviewNodes = [];
if (!this.props.cols){
cols = 3;
}
var contWidth = this.state.containerWidth - (cols * 4); /* 4px for margin around each image*/
contWidth = Math.floor(contWidth - 2); // add some padding to prevent layout prob
contWidth = Math.floor(contWidth); // add some padding to prevent layout prob
var remainder = this.props.photos.length % cols;
if (remainder) { // there are fewer than photos than cols num in last row
var lastRowWidth = Math.floor(this.state.containerWidth - (remainder * 4) - 2);
if (remainder) { // there are fewer photos than cols num in last row
var lastRowWidth = Math.floor( ((this.state.containerWidth / cols) * remainder) - (remainder * 4) );
var lastRowIndex = this.props.photos.length - remainder;

@@ -39,0 +36,0 @@ }

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc