redux-devtools/packages/redux-devtools-inspector/src/tabs/getItemString.js

84 lines
2.0 KiB
JavaScript
Raw Normal View History

import React from 'react';
import { Iterable } from 'immutable';
import isIterable from '../utils/isIterable';
const IS_IMMUTABLE_KEY = '@@__IS_IMMUTABLE__@@';
function isImmutable(value) {
2019-01-10 21:51:14 +03:00
return (
Iterable.isKeyed(value) ||
Iterable.isIndexed(value) ||
Iterable.isIterable(value)
);
}
function getShortTypeString(val, diff) {
if (diff && Array.isArray(val)) {
val = val[val.length === 2 ? 1 : 0];
}
if (isIterable(val) && !isImmutable(val)) {
return '(…)';
} else if (Array.isArray(val)) {
return val.length > 0 ? '[…]' : '[]';
} else if (val === null) {
return 'null';
} else if (val === undefined) {
return 'undef';
} else if (typeof val === 'object') {
return Object.keys(val).length > 0 ? '{…}' : '{}';
} else if (typeof val === 'function') {
return 'fn';
} else if (typeof val === 'string') {
2019-01-10 21:51:14 +03:00
return `"${val.substr(0, 10) + (val.length > 10 ? '…' : '')}"`;
} else if (typeof val === 'symbol') {
2019-01-10 21:51:14 +03:00
return 'symbol';
} else {
return val;
}
}
function getText(type, data, isWideLayout, isDiff) {
if (type === 'Object') {
const keys = Object.keys(data);
if (!isWideLayout) return keys.length ? '{…}' : '{}';
const str = keys
.slice(0, 3)
.map((key) => `${key}: ${getShortTypeString(data[key], isDiff)}`)
.concat(keys.length > 3 ? ['…'] : [])
.join(', ');
return `{ ${str} }`;
} else if (type === 'Array') {
if (!isWideLayout) return data.length ? '[…]' : '[]';
const str = data
.slice(0, 4)
.map((val) => getShortTypeString(val, isDiff))
2019-01-10 21:51:14 +03:00
.concat(data.length > 4 ? ['…'] : [])
.join(', ');
return `[${str}]`;
} else {
return type;
}
}
2019-01-10 21:51:14 +03:00
const getItemString = (
styling,
type,
data,
dataTypeKey,
isWideLayout,
isDiff
) => (
<span {...styling('treeItemHint')}>
{data[IS_IMMUTABLE_KEY] ? 'Immutable' : ''}
{dataTypeKey && data[dataTypeKey] ? data[dataTypeKey] + ' ' : ''}
{getText(type, data, isWideLayout, isDiff)}
2019-01-10 21:51:14 +03:00
</span>
);
export default getItemString;