@randy.tarampi/jsx
Version:
Some common JSX components for www.randytarampi.ca
249 lines (210 loc) • 12.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.GalleryComponent = void 0;
var _js = require("@randy.tarampi/js");
var _schemaDotOrgJsonLdComponents = _interopRequireDefault(require("@randy.tarampi/schema-dot-org-json-ld-components"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireWildcard(require("react"));
var _reactMaterialize = require("react-materialize");
var _reactProgressiveImage = _interopRequireDefault(require("react-progressive-image"));
var _util = require("../util");
var _photo = require("./photo");
var _post = require("./post");
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
var GalleryComponent = /*#__PURE__*/function (_PhotoComponent) {
_inherits(GalleryComponent, _PhotoComponent);
var _super = _createSuper(GalleryComponent);
function GalleryComponent() {
_classCallCheck(this, GalleryComponent);
return _super.apply(this, arguments);
}
_createClass(GalleryComponent, [{
key: "render",
value: function render() {
return this.props.containerWidth >= _util.WINDOW_LARGE_BREAKPOINT ? this._renderLarge() : this._renderSmall();
}
}, {
key: "_renderSmall",
value: function _renderSmall() {
var _this = this;
var post = this.props.post;
var rowClassName = ["post post--gallery"];
return /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Row, {
className: rowClassName.join(" "),
id: post.uid
}, /*#__PURE__*/_react["default"].createElement(_schemaDotOrgJsonLdComponents["default"], {
markup: post.toSchema()
}), /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Carousel, {
options: {
fullWidth: true,
indicators: true,
dist: 0
},
carouselId: this.carouselId
}, post.photos.map(function (photo, index) {
var placeholder = photo.getSizedPhotoForLoading(_this.targetWidth);
var selected = photo.getSizedPhotoForDisplay(_this.targetWidth);
var title = "".concat(_this.title, " (").concat(index + 1, "/").concat(post.photos.size, ")"); // NOTE-RT: Needs to be a `div` otherwise `react-materialize` can't cling onto these carousel items
return /*#__PURE__*/_react["default"].createElement("div", {
key: "".concat(post.uid, "-").concat(index)
}, /*#__PURE__*/_react["default"].createElement(_reactProgressiveImage["default"], {
src: selected.url,
placeholder: placeholder.url
}, function (source, isLoading) {
var columnClassName = ["post-metadata"];
if (isLoading) {
columnClassName.push("post--loading");
}
return /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Col, {
className: columnClassName.join(" "),
s: 12,
style: {
backgroundImage: "url(".concat(source, ")"),
height: _this.scaledHeight
}
}, index === 0 ? /*#__PURE__*/_react["default"].createElement(_react.Fragment, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "post-metadata hide-on-med-and-up"
}, /*#__PURE__*/_react["default"].createElement(_post.PostTitleComponent, {
post: post,
title: title
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "post-metadata hide-on-small-only hide-on-large-only"
}, /*#__PURE__*/_react["default"].createElement(_post.PostTitleComponent, {
post: post,
title: title
}), /*#__PURE__*/_react["default"].createElement(_post.PostDatePublishedComponent, {
post: post
}), /*#__PURE__*/_react["default"].createElement(_post.PostDateCreatedComponent, {
post: post,
label: "Taken:"
}), /*#__PURE__*/_react["default"].createElement(_post.PostLocationComponent, {
post: post
}), /*#__PURE__*/_react["default"].createElement(_post.PostBodyAsStringComponent, {
post: post
}), /*#__PURE__*/_react["default"].createElement(_post.PostBodyAsArrayComponent, {
post: post
}))) : /*#__PURE__*/_react["default"].createElement("div", {
className: "post-metadata"
}, /*#__PURE__*/_react["default"].createElement(_post.PostTitleComponent, {
post: post,
title: title
})));
}));
})));
}
}, {
key: "_renderLarge",
value: function _renderLarge() {
var _this2 = this;
var post = this.props.post;
var placeholder = post.largestPhoto.getSizedPhotoForLoading(this.targetWidth).url;
var rowClassName = ["post post--gallery"];
return /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Row, {
className: rowClassName.join(" "),
id: post.uid,
style: {
backgroundImage: "linear-gradient(to top right,rgba(0,0,0,0.67),rgba(0,0,0,0.33)),url(".concat(placeholder, ")")
}
}, /*#__PURE__*/_react["default"].createElement(_schemaDotOrgJsonLdComponents["default"], {
markup: post.toSchema()
}), /*#__PURE__*/_react["default"].createElement(_react.Fragment, null, /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Col, {
className: "post-metadata",
l: 4
}, /*#__PURE__*/_react["default"].createElement(_post.PostTitleComponent, {
post: post,
title: this.title
}), /*#__PURE__*/_react["default"].createElement(_post.PostBodyAsStringComponent, {
post: post
}), /*#__PURE__*/_react["default"].createElement(_post.PostBodyAsArrayComponent, {
post: post
}), /*#__PURE__*/_react["default"].createElement(_post.PostDatePublishedComponent, {
post: post
}), /*#__PURE__*/_react["default"].createElement(_post.PostDateCreatedComponent, {
post: post,
label: "Taken:"
}), /*#__PURE__*/_react["default"].createElement(_post.PostLocationComponent, {
post: post
}), /*#__PURE__*/_react["default"].createElement(_post.PostTagsComponent, {
post: post
})), /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Col, {
className: "post-content",
l: 8
}, /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Carousel, {
options: {
fullWidth: true,
indicators: true,
dist: 0
},
carouselId: this.carouselId
}, post.photos.map(function (photo, index) {
var placeholder = photo.getSizedPhotoForLoading(_this2.targetWidth);
var selected = photo.getSizedPhotoForDisplay(_this2.targetWidth); // NOTE-RT: Needs to be a `div` otherwise `react-materialize` can't cling onto these carousel items
return /*#__PURE__*/_react["default"].createElement("div", {
key: "".concat(post.uid, "-").concat(index)
}, /*#__PURE__*/_react["default"].createElement(_reactProgressiveImage["default"], {
src: selected.url,
placeholder: placeholder.url
}, function (source, isLoading) {
return /*#__PURE__*/_react["default"].createElement("img", {
className: isLoading ? "post--loading" : "",
src: source,
style: {
height: _this2.scaledHeight
}
});
}));
})))));
}
}, {
key: "resizeCarouselHeight",
value: function resizeCarouselHeight() {
var carouselElement = document.getElementById(this.carouselId); // NOTE-RT: `react-materialize` won't let me pass a `style` prop to `Carousel`, so we need to manually set this ourselves...
var expectedCarouselElementHeight = "".concat(this.scaledHeight, "px");
if (carouselElement && carouselElement.style.height !== expectedCarouselElementHeight) {
carouselElement.style.height = "".concat(this.scaledHeight, "px");
}
}
}, {
key: "componentDidMount",
value: function componentDidMount() {
this.resizeCarouselHeight();
}
}, {
key: "componentDidUpdate",
value: function componentDidUpdate() {
this.resizeCarouselHeight();
}
}, {
key: "selected",
get: function get() {
return this.props.post.largestPhoto.getSizedPhotoForDisplay(this.targetWidth);
}
}, {
key: "carouselId",
get: function get() {
return "".concat(this.props.post.uid, "-carousel");
}
}]);
return GalleryComponent;
}(_photo.PhotoComponent);
exports.GalleryComponent = GalleryComponent;
GalleryComponent.propTypes = {
post: _propTypes["default"].instanceOf(_js.Gallery).isRequired
};
var _default = GalleryComponent;
exports["default"] = _default;