@salesforce/design-system-react
Version:
Salesforce Lightning Design System for React
158 lines (126 loc) • 7.3 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _checkProps = _interopRequireDefault(require("./check-props"));
var _classNames = _interopRequireDefault(require("../../utilities/class-names"));
var _svg = _interopRequireDefault(require("../utilities/utility-icon/svg"));
var _constants = require("../../utilities/constants");
var _component = _interopRequireDefault(require("./component.json"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function 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; }
function _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) { _defineProperty(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; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
/**
* An illustration is an image and inline text that work in tandem to communicate a state in a more friendly way.
*/
var Illustration = function Illustration(_ref) {
var className = _ref.className,
illustration = _ref.illustration,
heading = _ref.heading,
messageBody = _ref.messageBody,
name = _ref.name,
path = _ref.path,
_ref$internalIllustra = _ref.internalIllustration,
internalIllustration = _ref$internalIllustra === void 0 ? true : _ref$internalIllustra,
_ref$size = _ref.size,
size = _ref$size === void 0 ? 'small' : _ref$size,
_ref$style = _ref.style,
style = _ref$style === void 0 ? {} : _ref$style,
rest = _objectWithoutProperties(_ref, ["className", "illustration", "heading", "messageBody", "name", "path", "internalIllustration", "size", "style"]);
(0, _checkProps.default)('Illustration', _objectSpread({
className: className,
illustration: illustration,
heading: heading,
messageBody: messageBody,
name: name,
path: path,
size: size,
style: style,
internalIllustration: internalIllustration
}, rest), _component.default);
var kababCaseName = name ? name.replace(/_| /g, '-').toLowerCase() : '';
var styles = _objectSpread({}, style);
var illustrationSvg; // large illustration svg should have a default height of 400px if not already specified
if (size === 'large' && !styles.height) {
styles.height = '400px';
}
if (illustration) {
// Use SVG data passed in with `illustration` prop
illustrationSvg = /*#__PURE__*/_react.default.createElement(_svg.default, {
className: "slds-illustration__svg",
"aria-hidden": "true",
data: illustration,
name: kababCaseName,
style: styles
});
} else if (path) {
illustrationSvg = /*#__PURE__*/_react.default.createElement("svg", {
className: "slds-illustration__svg",
"aria-hidden": "true",
name: kababCaseName,
style: styles
}, /*#__PURE__*/_react.default.createElement("use", {
xlinkHref: path
}));
}
return /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classNames.default)(className, 'slds-illustration', {
'slds-illustration_small': size === 'small',
'slds-illustration_large': size === 'large'
})
}, illustrationSvg, /*#__PURE__*/_react.default.createElement("div", {
className: "slds-text-longform"
}, heading ? /*#__PURE__*/_react.default.createElement("h3", {
className: "slds-text-heading_medium"
}, heading) : null, messageBody ? /*#__PURE__*/_react.default.createElement("p", {
className: "slds-text-body_regular"
}, messageBody) : null));
}; // ### Display Name
// Always use the canonical component name as the React display name.
Illustration.displayName = _constants.ILLUSTRATION; // ### Prop Types
Illustration.propTypes = {
/**
* CSS classes that are applied to the SVG. _Tested with Mocha testing._
*/
className: _propTypes.default.oneOfType([_propTypes.default.array, _propTypes.default.object, _propTypes.default.string]),
/**
* A heading text. It is required if illustration is present. _Tested with snapshot testing._ _Tested with Mocha testing._
*/
heading: _propTypes.default.string,
/**
* A custom SVG object to use instead of the supplied SLDS illustrations, look in `design-system-react/icons` for examples and syntax. _Tested with snapshot testing._ _Tested with Mocha testing._
*/
illustration: _propTypes.default.object,
/**
* Indicates whether the illustration SVGs are from the design-system-react repo. If yes, set to true.
*/
internalIllustration: _propTypes.default.bool,
/**
* A message body below the heading to further communicate the state of the component. _Tested with snapshot testing._ _Tested with Mocha testing._
*/
messageBody: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.node]),
/**
* Name of the illustration. Visit <a href='https://lightningdesignsystem.com/components/illustration/'>Lightning Design System Illustration</a> to reference illustration names. _Tested with snapshot testing._ _Tested with Mocha testing._
*/
name: _propTypes.default.string,
/**
* Path to the illustration SVG image. _Tested with snapshot testing._
*/
path: _propTypes.default.string,
/**
* Size of the illustration. _Tested with snapshot testing._ _Tested with Mocha testing._
*/
size: _propTypes.default.oneOf(['small', 'large']),
/**
* Custom styles to be passed to the illustration SVG. _Tested with Mocha testing._
*/
style: _propTypes.default.object
};
var _default = Illustration;
exports.default = _default;