UNPKG

3.67 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 = exports.styles = void 0;
11
12var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
14var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
15
16var React = _interopRequireWildcard(require("react"));
17
18var _propTypes = _interopRequireDefault(require("prop-types"));
19
20var _clsx = _interopRequireDefault(require("clsx"));
21
22var _withStyles = _interopRequireDefault(require("../styles/withStyles"));
23
24var _ListContext = _interopRequireDefault(require("./ListContext"));
25
26var styles = {
27 /* Styles applied to the root element. */
28 root: {
29 listStyle: 'none',
30 margin: 0,
31 padding: 0,
32 position: 'relative'
33 },
34
35 /* Styles applied to the root element if `disablePadding={false}`. */
36 padding: {
37 paddingTop: 8,
38 paddingBottom: 8
39 },
40
41 /* Styles applied to the root element if dense. */
42 dense: {},
43
44 /* Styles applied to the root element if a `subheader` is provided. */
45 subheader: {
46 paddingTop: 0
47 }
48};
49exports.styles = styles;
50var List = /*#__PURE__*/React.forwardRef(function List(props, ref) {
51 var children = props.children,
52 classes = props.classes,
53 className = props.className,
54 _props$component = props.component,
55 Component = _props$component === void 0 ? 'ul' : _props$component,
56 _props$dense = props.dense,
57 dense = _props$dense === void 0 ? false : _props$dense,
58 _props$disablePadding = props.disablePadding,
59 disablePadding = _props$disablePadding === void 0 ? false : _props$disablePadding,
60 subheader = props.subheader,
61 other = (0, _objectWithoutProperties2.default)(props, ["children", "classes", "className", "component", "dense", "disablePadding", "subheader"]);
62 var context = React.useMemo(function () {
63 return {
64 dense: dense
65 };
66 }, [dense]);
67 return /*#__PURE__*/React.createElement(_ListContext.default.Provider, {
68 value: context
69 }, /*#__PURE__*/React.createElement(Component, (0, _extends2.default)({
70 className: (0, _clsx.default)(classes.root, className, dense && classes.dense, !disablePadding && classes.padding, subheader && classes.subheader),
71 ref: ref
72 }, other), subheader, children));
73});
74process.env.NODE_ENV !== "production" ? List.propTypes = {
75 /**
76 * The content of the component.
77 */
78 children: _propTypes.default.node,
79
80 /**
81 * Override or extend the styles applied to the component.
82 * See [CSS API](#css) below for more details.
83 */
84 classes: _propTypes.default.object.isRequired,
85
86 /**
87 * @ignore
88 */
89 className: _propTypes.default.string,
90
91 /**
92 * The component used for the root node.
93 * Either a string to use a HTML element or a component.
94 */
95 component: _propTypes.default
96 /* @typescript-to-proptypes-ignore */
97 .elementType,
98
99 /**
100 * If `true`, compact vertical padding designed for keyboard and mouse input will be used for
101 * the list and list items.
102 * The prop is available to descendant components as the `dense` context.
103 */
104 dense: _propTypes.default.bool,
105
106 /**
107 * If `true`, vertical padding will be removed from the list.
108 */
109 disablePadding: _propTypes.default.bool,
110
111 /**
112 * The content of the subheader, normally `ListSubheader`.
113 */
114 subheader: _propTypes.default.node
115} : void 0;
116
117var _default = (0, _withStyles.default)(styles, {
118 name: 'MuiList'
119})(List);
120
121exports.default = _default;
\No newline at end of file