react-query
Version:
Hooks for managing, caching and syncing asynchronous and remote data in React
185 lines (164 loc) • 5.89 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
exports.__esModule = true;
exports.Value = exports.SubEntries = exports.LabelButton = exports.Label = exports.Info = exports.Expander = exports.Entry = exports.DefaultRenderer = void 0;
exports.chunkArray = chunkArray;
exports.default = Explorer;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _react = _interopRequireDefault(require("react"));
var _utils = require("./utils");
const Entry = (0, _utils.styled)('div', {
fontFamily: 'Menlo, monospace',
fontSize: '1em',
lineHeight: '1.7',
outline: 'none',
wordBreak: 'break-word'
});
exports.Entry = Entry;
const Label = (0, _utils.styled)('span', {
color: 'white'
});
exports.Label = Label;
const LabelButton = (0, _utils.styled)('button', {
cursor: 'pointer',
color: 'white'
});
exports.LabelButton = LabelButton;
const Value = (0, _utils.styled)('span', (_props, theme) => ({
color: theme.danger
}));
exports.Value = Value;
const SubEntries = (0, _utils.styled)('div', {
marginLeft: '.1em',
paddingLeft: '1em',
borderLeft: '2px solid rgba(0,0,0,.15)'
});
exports.SubEntries = SubEntries;
const Info = (0, _utils.styled)('span', {
color: 'grey',
fontSize: '.7em'
});
exports.Info = Info;
const Expander = ({
expanded,
style = {}
}) => /*#__PURE__*/_react.default.createElement("span", {
style: {
display: 'inline-block',
transition: 'all .1s ease',
transform: "rotate(" + (expanded ? 90 : 0) + "deg) " + (style.transform || ''),
...style
}
}, "\u25B6");
exports.Expander = Expander;
/**
* Chunk elements in the array by size
*
* when the array cannot be chunked evenly by size, the last chunk will be
* filled with the remaining elements
*
* @example
* chunkArray(['a','b', 'c', 'd', 'e'], 2) // returns [['a','b'], ['c', 'd'], ['e']]
*/
function chunkArray(array, size) {
if (size < 1) return [];
let i = 0;
const result = [];
while (i < array.length) {
result.push(array.slice(i, i + size));
i = i + size;
}
return result;
}
const DefaultRenderer = ({
HandleEntry,
label,
value,
subEntries = [],
subEntryPages = [],
type,
expanded = false,
toggleExpanded,
pageSize
}) => {
const [expandedPages, setExpandedPages] = _react.default.useState([]);
return /*#__PURE__*/_react.default.createElement(Entry, {
key: label
}, subEntryPages.length ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("button", {
onClick: () => toggleExpanded()
}, /*#__PURE__*/_react.default.createElement(Expander, {
expanded: expanded
}), " ", label, ' ', /*#__PURE__*/_react.default.createElement(Info, null, String(type).toLowerCase() === 'iterable' ? '(Iterable) ' : '', subEntries.length, " ", subEntries.length > 1 ? "items" : "item")), expanded ? subEntryPages.length === 1 ? /*#__PURE__*/_react.default.createElement(SubEntries, null, subEntries.map(entry => /*#__PURE__*/_react.default.createElement(HandleEntry, {
key: entry.label,
entry: entry
}))) : /*#__PURE__*/_react.default.createElement(SubEntries, null, subEntryPages.map((entries, index) => /*#__PURE__*/_react.default.createElement("div", {
key: index
}, /*#__PURE__*/_react.default.createElement(Entry, null, /*#__PURE__*/_react.default.createElement(LabelButton, {
onClick: () => setExpandedPages(old => old.includes(index) ? old.filter(d => d !== index) : [...old, index])
}, /*#__PURE__*/_react.default.createElement(Expander, {
expanded: expanded
}), " [", index * pageSize, " ...", ' ', index * pageSize + pageSize - 1, "]"), expandedPages.includes(index) ? /*#__PURE__*/_react.default.createElement(SubEntries, null, entries.map(entry => /*#__PURE__*/_react.default.createElement(HandleEntry, {
key: entry.label,
entry: entry
}))) : null)))) : null) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(Label, null, label, ":"), " ", /*#__PURE__*/_react.default.createElement(Value, null, (0, _utils.displayValue)(value))));
};
exports.DefaultRenderer = DefaultRenderer;
function isIterable(x) {
return Symbol.iterator in x;
}
function Explorer({
value,
defaultExpanded,
renderer = DefaultRenderer,
pageSize = 100,
...rest
}) {
const [expanded, setExpanded] = _react.default.useState(Boolean(defaultExpanded));
const toggleExpanded = _react.default.useCallback(() => setExpanded(old => !old), []);
let type = typeof value;
let subEntries = [];
const makeProperty = sub => {
const subDefaultExpanded = defaultExpanded === true ? {
[sub.label]: true
} : defaultExpanded == null ? void 0 : defaultExpanded[sub.label];
return { ...sub,
defaultExpanded: subDefaultExpanded
};
};
if (Array.isArray(value)) {
type = 'array';
subEntries = value.map((d, i) => makeProperty({
label: i.toString(),
value: d
}));
} else if (value !== null && typeof value === 'object' && isIterable(value) && typeof value[Symbol.iterator] === 'function') {
type = 'Iterable';
subEntries = Array.from(value, (val, i) => makeProperty({
label: i.toString(),
value: val
}));
} else if (typeof value === 'object' && value !== null) {
type = 'object';
subEntries = Object.entries(value).map(([key, val]) => makeProperty({
label: key,
value: val
}));
}
const subEntryPages = chunkArray(subEntries, pageSize);
return renderer({
HandleEntry: ({
entry
}) => /*#__PURE__*/_react.default.createElement(Explorer, (0, _extends2.default)({
value: value,
renderer: renderer
}, rest, entry)),
type,
subEntries,
subEntryPages,
value,
expanded,
toggleExpanded,
pageSize,
...rest
});
}
;