UNPKG

3.54 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
5Object.defineProperty(exports, "__esModule", {
6 value: true
7});
8exports.default = exports.styles = void 0;
9
10var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
12var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
14var _react = _interopRequireDefault(require("react"));
15
16var _propTypes = _interopRequireDefault(require("prop-types"));
17
18var _clsx = _interopRequireDefault(require("clsx"));
19
20var _withStyles = _interopRequireDefault(require("../styles/withStyles"));
21
22var _ListContext = _interopRequireDefault(require("./ListContext"));
23
24var styles = {
25 /* Styles applied to the root element. */
26 root: {
27 listStyle: 'none',
28 margin: 0,
29 padding: 0,
30 position: 'relative'
31 },
32
33 /* Styles applied to the root element if `disablePadding={false}`. */
34 padding: {
35 paddingTop: 8,
36 paddingBottom: 8
37 },
38
39 /* Styles applied to the root element if dense. */
40 dense: {},
41
42 /* Styles applied to the root element if a `subheader` is provided. */
43 subheader: {
44 paddingTop: 0
45 }
46};
47exports.styles = styles;
48
49var List = _react.default.forwardRef(function List(props, ref) {
50 var children = props.children,
51 classes = props.classes,
52 className = props.className,
53 _props$component = props.component,
54 Component = _props$component === void 0 ? 'ul' : _props$component,
55 _props$dense = props.dense,
56 dense = _props$dense === void 0 ? false : _props$dense,
57 _props$disablePadding = props.disablePadding,
58 disablePadding = _props$disablePadding === void 0 ? false : _props$disablePadding,
59 subheader = props.subheader,
60 other = (0, _objectWithoutProperties2.default)(props, ["children", "classes", "className", "component", "dense", "disablePadding", "subheader"]);
61
62 var context = _react.default.useMemo(function () {
63 return {
64 dense: dense
65 };
66 }, [dense]);
67
68 return _react.default.createElement(_ListContext.default.Provider, {
69 value: context
70 }, _react.default.createElement(Component, (0, _extends2.default)({
71 className: (0, _clsx.default)(classes.root, className, dense && classes.dense, !disablePadding && classes.padding, subheader && classes.subheader),
72 ref: ref
73 }, other), subheader, children));
74});
75
76process.env.NODE_ENV !== "production" ? List.propTypes = {
77 /**
78 * The content of the component.
79 */
80 children: _propTypes.default.node,
81
82 /**
83 * Override or extend the styles applied to the component.
84 * See [CSS API](#css) below for more details.
85 */
86 classes: _propTypes.default.object.isRequired,
87
88 /**
89 * @ignore
90 */
91 className: _propTypes.default.string,
92
93 /**
94 * The component used for the root node.
95 * Either a string to use a DOM element or a component.
96 */
97 component: _propTypes.default.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