@randy.tarampi/jsx
Version:
Some common JSX components for www.randytarampi.ca
233 lines (189 loc) • 12.2 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.ProgressiveImageWrappedPhotoComponent = exports.computeTargetWidthForPhotoComponent = exports.computeScaledHeightForPhotoComponent = exports.PhotoComponent = 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 _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 _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
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 PhotoComponent = /*#__PURE__*/function (_PostComponent) {
_inherits(PhotoComponent, _PostComponent);
var _super = _createSuper(PhotoComponent);
function PhotoComponent() {
_classCallCheck(this, PhotoComponent);
return _super.apply(this, arguments);
}
_createClass(PhotoComponent, [{
key: "render",
value: function render() {
var _this$props = this.props,
post = _this$props.post,
isLoading = _this$props.isLoading,
source = _this$props.source,
placeholder = _this$props.placeholder;
var rowClassName = ["post post--photo"];
if (isLoading) {
rowClassName.push("post--loading");
}
var rowStyle = {};
if (this.props.containerWidth >= _util.WINDOW_LARGE_BREAKPOINT) {
rowStyle.backgroundImage = "linear-gradient(to top right,rgba(0,0,0,0.67),rgba(0,0,0,0.33)),url(".concat(placeholder, ")");
}
return /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Row, {
className: rowClassName.join(" "),
id: post.uid,
style: rowStyle
}, /*#__PURE__*/_react["default"].createElement(_schemaDotOrgJsonLdComponents["default"], {
markup: post.toSchema()
}), this.props.containerWidth >= _util.WINDOW_LARGE_BREAKPOINT ? /*#__PURE__*/_react["default"].createElement(_react.Fragment, null, /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Col, {
className: "post-metadata hide-on-med-and-down",
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 hide-on-med-and-down",
l: 8,
style: {
backgroundImage: "url(".concat(source, ")"),
height: this.scaledHeight
}
})) : /*#__PURE__*/_react["default"].createElement(_react.Fragment, null, /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Col, {
className: "post-metadata hide-on-med-and-up",
s: 12,
style: {
backgroundImage: "url(".concat(source, ")"),
height: this.scaledHeight
}
}, /*#__PURE__*/_react["default"].createElement(_post.PostTitleComponent, {
post: post,
title: this.title
})), /*#__PURE__*/_react["default"].createElement(_reactMaterialize.Col, {
className: "post-metadata hide-on-small-only",
m: 12,
style: {
backgroundImage: "url(".concat(source, ")"),
height: this.scaledHeight
}
}, /*#__PURE__*/_react["default"].createElement(_post.PostTitleComponent, {
post: post,
title: this.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
}))));
}
}, {
key: "selected",
get: function get() {
return this.props.post.getSizedPhotoForDisplay(this.targetWidth);
}
}, {
key: "scaledHeight",
get: function get() {
return computeScaledHeightForPhotoComponent({
containerWidth: this.props.containerWidth,
photoHeight: this.selected.height,
photoWidth: this.selected.width,
postHtmlId: this.props.post.uid
});
}
}, {
key: "targetWidth",
get: function get() {
return computeTargetWidthForPhotoComponent(this.props);
}
}]);
return PhotoComponent;
}(_post.PostComponent);
exports.PhotoComponent = PhotoComponent;
PhotoComponent.propTypes = {
post: _propTypes["default"].instanceOf(_js.Photo).isRequired,
source: _propTypes["default"].string.isRequired,
placeholder: _propTypes["default"].string.isRequired,
isLoading: _propTypes["default"].bool.isRequired
};
var computeScaledHeightForPhotoComponent = function computeScaledHeightForPhotoComponent(_ref) {
var containerWidth = _ref.containerWidth,
photoHeight = _ref.photoHeight,
photoWidth = _ref.photoWidth,
postHtmlId = _ref.postHtmlId;
var scaledHeight = containerWidth * photoHeight / photoWidth;
if (containerWidth >= _util.WINDOW_LARGE_BREAKPOINT) {
var photoElement = document.getElementById(postHtmlId);
if (photoElement) {
var metadataColumnElement = photoElement.querySelector(".post-metadata.l4");
scaledHeight = Math.max(scaledHeight * _util.WINDOW_LARGE_PHOTO_SCALE, photoElement && metadataColumnElement ? metadataColumnElement.clientHeight : 0);
}
}
return Math.round(scaledHeight);
};
exports.computeScaledHeightForPhotoComponent = computeScaledHeightForPhotoComponent;
var computeTargetWidthForPhotoComponent = function computeTargetWidthForPhotoComponent(_ref2) {
var containerWidth = _ref2.containerWidth;
return (0, _util.scalePixelValueForWindowDevicePixelRatio)(containerWidth);
};
exports.computeTargetWidthForPhotoComponent = computeTargetWidthForPhotoComponent;
var ProgressiveImageWrappedPhotoComponent = function ProgressiveImageWrappedPhotoComponent(props) {
var targetWidth = computeTargetWidthForPhotoComponent(props);
var placeholder = props.post.getSizedPhotoForLoading(targetWidth);
var selected = props.post.getSizedPhotoForDisplay(targetWidth);
return /*#__PURE__*/_react["default"].createElement(_reactProgressiveImage["default"], {
src: selected.url,
placeholder: placeholder.url
}, function (source, isLoading) {
return /*#__PURE__*/_react["default"].createElement(PhotoComponent, _extends({}, props, {
source: source,
placeholder: placeholder.url,
isLoading: isLoading
}));
});
};
exports.ProgressiveImageWrappedPhotoComponent = ProgressiveImageWrappedPhotoComponent;
ProgressiveImageWrappedPhotoComponent.propTypes = {
containerWidth: _propTypes["default"].number.isRequired,
post: _propTypes["default"].instanceOf(_js.Photo).isRequired
};
var _default = ProgressiveImageWrappedPhotoComponent;
exports["default"] = _default;