UNPKG

19.1 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
5var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
7Object.defineProperty(exports, "__esModule", {
8 value: true
9});
10exports["default"] = void 0;
11
12var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
14var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
15
16var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
17
18var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
19
20var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
21
22var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
23
24var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
25
26var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
27
28var _react = _interopRequireWildcard(require("react"));
29
30var _propTypes = _interopRequireDefault(require("prop-types"));
31
32var _reactImageFallback = _interopRequireDefault(require("react-image-fallback"));
33
34var _link = _interopRequireDefault(require("@lskjs/link"));
35
36function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
37
38function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
39
40function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function () { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
41
42function _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; } }
43
44// import Img from './Image.styles';
45// const textSizeRatio = 3;
46var textSizePercent = 30;
47
48var Image = /*#__PURE__*/function (_PureComponent) {
49 (0, _inherits2["default"])(Image, _PureComponent);
50
51 var _super = _createSuper(Image);
52
53 function Image() {
54 (0, _classCallCheck2["default"])(this, Image);
55 return _super.apply(this, arguments);
56 }
57
58 (0, _createClass2["default"])(Image, [{
59 key: "getInnerStyle",
60 value: function getInnerStyle() {
61 var _this$props = this.props,
62 size = _this$props.size,
63 innerStyle = _this$props.innerStyle,
64 textColor = _this$props.textColor,
65 objectFit = _this$props.objectFit;
66 var width = this.props.width || size;
67 var height = this.props.height || size;
68 var lineHeight = size;
69 var fontSize = Math.min( // Math.floor(size / textSizeRatio * textScale),
70 Math.floor(size * textSizePercent / 100), lineHeight);
71 return _objectSpread({
72 boxSizing: 'border-box',
73 maxWidth: '100%',
74 maxHeight: 500,
75 objectFit: objectFit,
76 display: 'flex',
77 justifyContent: 'center',
78 alignItems: 'center',
79 // overflow: 'hidden',
80 width: width,
81 height: height,
82 textAlign: 'center',
83 fontFamily: 'Helvetica, Arial, sans-serif',
84 fontSize: "".concat(fontSize, "px"),
85 lineHeight: "".concat(lineHeight, "px"),
86 color: textColor
87 }, innerStyle);
88 }
89 }, {
90 key: "renderAsImage",
91 value: function renderAsImage() {
92 var title = this.props.title || this.props.name;
93 var src = this.props.src || this.props.image;
94 var _this$props2 = this.props,
95 _this$props2$style = _this$props2.style,
96 style = _this$props2$style === void 0 ? {} : _this$props2$style,
97 props = (0, _objectWithoutProperties2["default"])(_this$props2, ["style"]);
98 return /*#__PURE__*/_react["default"].createElement(_reactImageFallback["default"], (0, _extends2["default"])({
99 src: src,
100 fallbackImage: this.constructor.defaultImage,
101 initialImage: this.constructor.defaultImage,
102 style: _objectSpread(_objectSpread({}, this.getInnerStyle()), style),
103 alt: title,
104 title: title
105 }, props));
106 }
107 }, {
108 key: "renderAsText",
109 value: function renderAsText() {
110 var placeholder = this.props.placeholder;
111 var placeholderLimit = this.props.placeholderLimit;
112 var title = this.props.title || this.props.name || placeholder || '';
113
114 if (!placeholder) {
115 placeholder = title.split(' ').map(function (s) {
116 return s.charAt(0);
117 }).join('').substr(0, placeholderLimit);
118 }
119
120 return /*#__PURE__*/_react["default"].createElement("div", {
121 style: this.getInnerStyle()
122 }, placeholder);
123 }
124 }, {
125 key: "render",
126 value: function render() {
127 var _this$props3 = this.props,
128 size = _this$props3.size,
129 style = _this$props3.style,
130 className = _this$props3.className,
131 children = _this$props3.children,
132 componentClass = _this$props3.componentClass; // const src = this.props.src || this.props.image;
133
134 var width = this.props.width || size;
135 var height = this.props.height || size;
136
137 var wrapperStyle = _objectSpread({
138 display: 'block',
139 position: 'relative',
140 width: width,
141 height: height
142 }, style);
143
144 var link = this.props.link || this.props.href;
145 var Component = componentClass || (link ? _link["default"] : 'div');
146 return /*#__PURE__*/_react["default"].createElement(Component, {
147 href: link,
148 className: className,
149 style: wrapperStyle
150 }, this.renderAsImage(), children);
151 }
152 }]);
153 return Image;
154}(_react.PureComponent);
155
156Image.propTypes = {
157 title: _propTypes["default"].string,
158 name: _propTypes["default"].string,
159 src: _propTypes["default"].string,
160 size: _propTypes["default"].number,
161 objectFit: _propTypes["default"].string,
162 width: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
163 height: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
164 // color: PropTypes.string,
165 textColor: _propTypes["default"].string,
166 // textScale: PropTypes.number,
167 placeholder: _propTypes["default"].string,
168 placeholderLimit: _propTypes["default"].number,
169 style: _propTypes["default"].object,
170 innerStyle: _propTypes["default"].object
171};
172Image.defaultImage = 'https://increasify.com.au/wp-content/uploads/2016/08/default-image.png';
173Image.defaultProps = {
174 title: '',
175 name: '',
176 src: null,
177 size: 64,
178 width: 'auto',
179 height: 'auto',
180 objectFit: 'cover',
181 // backgroundColor: '#838383',
182 textColor: '#d9d9d9',
183 // textScale: 1,
184 placeholder: null,
185 placeholderLimit: 3,
186 style: {},
187 innerStyle: {}
188};
189var _default = Image;
190exports["default"] = _default;
191//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Image.jsx"],"names":["textSizePercent","Image","props","size","innerStyle","textColor","objectFit","width","height","lineHeight","fontSize","Math","min","floor","boxSizing","maxWidth","maxHeight","display","justifyContent","alignItems","textAlign","fontFamily","color","title","name","src","image","style","constructor","defaultImage","getInnerStyle","placeholder","placeholderLimit","split","map","s","charAt","join","substr","className","children","componentClass","wrapperStyle","position","link","href","Component","Link","renderAsImage","PureComponent","propTypes","PropTypes","string","number","oneOfType","object","defaultProps"],"mappings":"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","sourcesContent":["import React, { PureComponent } from 'react';\nimport PropTypes from 'prop-types';\nimport ReactImageFallback from 'react-image-fallback';\nimport Link from '@lskjs/link';\n// import Img from './Image.styles';\n\n// const textSizeRatio = 3;\nconst textSizePercent = 30;\n\nclass Image extends PureComponent {\n  getInnerStyle() {\n    const {\n      size,\n      // textScale,\n      innerStyle,\n      textColor,\n      objectFit,\n      // src,\n    } = this.props;\n\n    const width = this.props.width || size;\n    const height = this.props.height || size;\n\n    const lineHeight = size;\n    const fontSize = Math.min(\n      // Math.floor(size / textSizeRatio * textScale),\n      Math.floor((size * textSizePercent) / 100),\n      lineHeight,\n    );\n\n    return {\n      boxSizing: 'border-box',\n      maxWidth: '100%',\n      maxHeight: 500,\n      objectFit,\n      display: 'flex',\n      justifyContent: 'center',\n      alignItems: 'center',\n      // overflow: 'hidden',\n      width,\n      height,\n      textAlign: 'center',\n      fontFamily: 'Helvetica, Arial, sans-serif',\n      fontSize: `${fontSize}px`,\n      lineHeight: `${lineHeight}px`,\n      color: textColor,\n      ...innerStyle,\n    };\n  }\n\n  renderAsImage() {\n    const title = this.props.title || this.props.name;\n    const src = this.props.src || this.props.image;\n    const { style = {}, ...props } = this.props;\n\n    return (\n      <ReactImageFallback\n        src={src}\n        fallbackImage={this.constructor.defaultImage}\n        initialImage={this.constructor.defaultImage}\n        style={{\n          ...this.getInnerStyle(),\n          ...style,\n        }}\n        alt={title}\n        title={title}\n        {...props}\n      />\n    );\n  }\n\n  renderAsText() {\n    let { placeholder } = this.props;\n    const { placeholderLimit } = this.props;\n    const title = this.props.title || this.props.name || placeholder || '';\n    if (!placeholder) {\n      placeholder = title\n        .split(' ')\n        .map(s => s.charAt(0))\n        .join('')\n        .substr(0, placeholderLimit);\n    }\n    return <div style={this.getInnerStyle()}>{placeholder}</div>;\n  }\n\n  render() {\n    const { size, style, className, children, componentClass } = this.props;\n\n    // const src = this.props.src || this.props.image;\n    const width = this.props.width || size;\n    const height = this.props.height || size;\n\n    const wrapperStyle = { display: 'block', position: 'relative', width, height, ...style };\n\n    const link = this.props.link || this.props.href;\n    const Component = componentClass || (link ? Link : 'div');\n\n    return (\n      <Component href={link} className={className} style={wrapperStyle}>\n        {this.renderAsImage()}\n        {children}\n      </Component>\n    );\n  }\n}\n\nImage.propTypes = {\n  title: PropTypes.string,\n  name: PropTypes.string,\n  src: PropTypes.string,\n  size: PropTypes.number,\n  objectFit: PropTypes.string,\n  width: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  height: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n  // color: PropTypes.string,\n  textColor: PropTypes.string,\n  // textScale: PropTypes.number,\n\n  placeholder: PropTypes.string,\n  placeholderLimit: PropTypes.number,\n\n  style: PropTypes.object,\n  innerStyle: PropTypes.object,\n};\nImage.defaultImage = 'https://increasify.com.au/wp-content/uploads/2016/08/default-image.png';\nImage.defaultProps = {\n  title: '',\n  name: '',\n  src: null,\n\n  size: 64,\n  width: 'auto',\n  height: 'auto',\n  objectFit: 'cover',\n\n  // backgroundColor: '#838383',\n  textColor: '#d9d9d9',\n  // textScale: 1,\n\n  placeholder: null,\n  placeholderLimit: 3,\n\n  style: {},\n  innerStyle: {},\n};\n\nexport default Image;\n"]}
192//# sourceMappingURL=Image.js.map
\No newline at end of file