@cicada/render
Advanced tools
Comparing version 1.1.8-alpha1 to 1.1.8-alpha10
@@ -97,3 +97,3 @@ 'use strict'; | ||
})); | ||
expect(container.html()).toEqual('<div class="cls1 cls2"></div>'); | ||
expect(container.html()).toEqual('<div data-cicada-cls1="" data-cicada-cls2=""></div>'); | ||
}); | ||
@@ -131,4 +131,6 @@ | ||
expect(container.html()).toEqual('<div><div></div><div></div></div>'); | ||
stateTree.set('demo.value', 'hide'); | ||
expect(container.html()).toEqual('<div><div>hide</div><div class="hide"></div></div>'); | ||
stateTree.set('demo.value', 'cls1 cls2 hide'); | ||
expect(container.html()).toEqual('<div><div>cls1 cls2 hide</div><div data-cicada-cls1="" data-cicada-cls2="" data-cicada-hide=""></div></div>'); | ||
stateTree.set('demo.value', 'cls1 show'); | ||
expect(container.html()).toEqual('<div><div>cls1 show</div><div data-cicada-cls1="" data-cicada-show=""></div></div>'); | ||
}); |
@@ -55,3 +55,4 @@ 'use strict'; | ||
var DISPLAY_NONE = '' + _createAppearance.STYLE_SHEET_PREFIX + _createAppearance.DISPLAY_NONE; | ||
// const DISPLAY_NONE = `${STYLE_SHEET_PREFIX}${DISPLAY_NONE_NAME}` | ||
var DISPLAY_NONE = '' + _createAppearance.DISPLAY_NONE; | ||
@@ -221,3 +222,3 @@ function createButton() { | ||
expect(container.instance().appearance.isVisibleById(stateId)).toBe(false); | ||
expect(container.html()).toEqual('<div class="' + DISPLAY_NONE + '"></div>'); | ||
expect(container.html()).toEqual('<div data-cicada-' + DISPLAY_NONE + '=""></div>'); | ||
}); | ||
@@ -224,0 +225,0 @@ }); |
@@ -78,2 +78,25 @@ 'use strict'; | ||
test('style as string', function () { | ||
var container = (0, _enzyme.mount)(_react2.default.createElement(_Render2.default, { | ||
stateTree: stateTree, | ||
appearance: appearance, | ||
components: { Demo: (0, _connect2.default)(DemoComponent, 'Demo') }, | ||
background: (0, _createBackground2.default)({ | ||
jobs: { | ||
style: styleJob | ||
}, | ||
utilities: { | ||
stateTree: stateTreeUtility | ||
} | ||
}, stateTree, appearance), | ||
config: { | ||
bind: 'demo', | ||
type: 'Demo', | ||
style: '\n backgroundColor: \'#ccc\',\n fontSize: \'14px\',\n ' | ||
} | ||
})); | ||
// const styleId = container.html().match(/class="(.+)"/)[1] | ||
expect(container.html()).toEqual('<div data-cicada-css-0=""></div>'); | ||
}); | ||
test('style as object', function () { | ||
@@ -101,4 +124,4 @@ var container = (0, _enzyme.mount)(_react2.default.createElement(_Render2.default, { | ||
})); | ||
var styleId = container.html().match(/class="(.+)"/)[1]; | ||
expect(document.getElementById(styleId).innerText).toEqual('.' + styleId + ' { background-color: #ccc; font-size: 14px }'); | ||
// const styleId = container.html().match(/class="(.+)"/)[1] | ||
expect(container.html()).toEqual('<div data-cicada-css-0=""></div>'); | ||
}); | ||
@@ -134,5 +157,6 @@ | ||
})); | ||
var styleId = container.html().match(/class="(.+)"/)[1]; | ||
stateTree.set('demo.value', 'background-color: red'); | ||
expect(document.getElementById(styleId).innerText).toEqual('.' + styleId + ' { background-color: red }'); | ||
// const styleId = container.html().match(/class="(.+)"/)[1] | ||
expect(container.html()).toEqual('<div><div></div><div></div></div>'); | ||
stateTree.set('demo.value', 'background-color: \'red\''); | ||
expect(container.html()).toEqual('<div><div>background-color: \'red\'</div><div data-cicada-css-0=""></div></div>'); | ||
}); |
@@ -69,3 +69,4 @@ 'use strict'; | ||
var DISPLAY_NONE = '' + _createAppearance.STYLE_SHEET_PREFIX + _createAppearance.DISPLAY_NONE; /* eslint-disable react/no-multi-comp */ | ||
// const DISPLAY_NONE = `${STYLE_SHEET_PREFIX}${DISPLAY_NONE_NAME}` | ||
var DISPLAY_NONE = '' + _createAppearance.DISPLAY_NONE; /* eslint-disable react/no-multi-comp */ | ||
/* eslint-disable newline-per-chained-call */ | ||
@@ -171,4 +172,5 @@ | ||
})); | ||
expect(container.html()).toEqual('<div class="' + DISPLAY_NONE + '"></div>'); | ||
expect(container.html()).toEqual('<div data-cicada-' + DISPLAY_NONE + '=""></div>'); | ||
}); | ||
test('basic set and reset', function () { | ||
@@ -181,3 +183,3 @@ var _checkComponentDispla = checkComponentDisplay({ render: function render() { | ||
); | ||
} }, '<div class="other ' + DISPLAY_NONE + '">content</div>'), | ||
} }, '<div class="other" data-cicada-' + DISPLAY_NONE + '="">content</div>'), | ||
container = _checkComponentDispla.container, | ||
@@ -197,3 +199,3 @@ stateId = _checkComponentDispla.stateId; | ||
return _react2.default.createElement(Inner, null); | ||
} }, '<div class="' + DISPLAY_NONE + '">inner</div>'); | ||
} }, '<div data-cicada-' + DISPLAY_NONE + '="">inner</div>'); | ||
}); | ||
@@ -204,3 +206,3 @@ // 嵌套多层 | ||
return _react2.default.createElement(NestedInner, null); | ||
} }, '<div class="' + DISPLAY_NONE + '">inner</div>'); | ||
} }, '<div data-cicada-' + DISPLAY_NONE + '="">inner</div>'); | ||
}); | ||
@@ -217,3 +219,3 @@ test('stateless set', function () { | ||
return _react2.default.createElement(Stateless, null); | ||
} }, '<div class="' + DISPLAY_NONE + '">stateless</div>'); | ||
} }, '<div data-cicada-' + DISPLAY_NONE + '="">stateless</div>'); | ||
}); | ||
@@ -255,3 +257,3 @@ }); | ||
expect(appearance.isVisibleById(stateId)).toBe(false); | ||
expect(container.html()).toEqual('<div><div>hide</div><div class="' + DISPLAY_NONE + '"></div></div>'); | ||
expect(container.html()).toEqual('<div><div>hide</div><div data-cicada-' + DISPLAY_NONE + '=""></div></div>'); | ||
}); | ||
@@ -295,3 +297,3 @@ | ||
expect(appearance.isVisibleById(stateId)).toBe(false); | ||
expect(container.html()).toEqual('<div><div>hide</div><div class="' + DISPLAY_NONE + '"></div></div>'); | ||
expect(container.html()).toEqual('<div><div>hide</div><div data-cicada-' + DISPLAY_NONE + '=""></div></div>'); | ||
}); | ||
@@ -329,3 +331,3 @@ | ||
stateTree.set('demo', { value: 'hide' }); | ||
expect(container.html()).toEqual('<div><div>hide</div><h3 class="' + DISPLAY_NONE + '"></h3></div>'); | ||
expect(container.html()).toEqual('<div><div>hide</div><h3 data-cicada-' + DISPLAY_NONE + '=""></h3></div>'); | ||
}); |
@@ -20,2 +20,4 @@ 'use strict'; | ||
var _util = require('../../util'); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
@@ -49,3 +51,19 @@ | ||
}); | ||
appearance.addStyleById.apply(appearance, [stateId].concat((0, _toConsumableArray3.default)(classNames))); | ||
// className job 采用覆盖机制,因为统一调用 addStyleById 接口 | ||
// 这里需要摒弃已在dom上存在的重复的 className | ||
var oldClassNames = appearance.getStyleById(stateId); | ||
if (oldClassNames.length) { | ||
var discard = []; | ||
(0, _util.each)(oldClassNames, function (cls) { | ||
if (!classNames.includes(cls)) { | ||
discard.push(cls); | ||
} | ||
}); | ||
appearance.replaceStyleById(stateId, oldClassNames.filter(function (cls) { | ||
return !discard.includes(cls); | ||
})); | ||
} | ||
if (classNames.length) { | ||
appearance.addStyleById.apply(appearance, [stateId].concat((0, _toConsumableArray3.default)(classNames))); | ||
} | ||
} | ||
@@ -52,0 +70,0 @@ |
@@ -63,3 +63,3 @@ 'use strict'; | ||
return mapBackgroundToState !== undefined && mapBackgroundToState.length !== 0; | ||
return mapBackgroundToState !== undefined && Array.isArray(mapBackgroundToState) && mapBackgroundToState.length !== 0; | ||
} |
@@ -20,18 +20,4 @@ 'use strict'; | ||
var _util = require('../../util'); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
function toLowerCaseKey(key) { | ||
return key.replace(/[A-Z]/g, function (k, i) { | ||
return i === 0 ? k.toLowerCase() : '-' + k.toLowerCase(); | ||
}); | ||
} | ||
function styleToString(style) { | ||
var content = (0, _util.reduce)(style, function (arr, o, key) { | ||
return arr.concat(toLowerCaseKey(key) + ': ' + o); | ||
}, []).join('; '); | ||
return '{ ' + content + ' }'; | ||
} | ||
function initialize(utilInstances, stateTree, appearance) { | ||
@@ -44,5 +30,3 @@ var stateIdToStyleFns = {}; | ||
var styleName = appearance.createStylesheet(stateId, '{ }'); | ||
stateIdToStyleFns[stateId] = { | ||
styleName: styleName, | ||
getStatePath: getStatePath, | ||
@@ -53,3 +37,2 @@ fn: typeof style === 'function' ? style : function () { | ||
}; | ||
appearance.addStyleById(stateId, styleName); | ||
} | ||
@@ -65,5 +48,6 @@ | ||
function handle(stateId, result) { | ||
var styleName = stateIdToStyleFns[stateId].styleName; | ||
appearance.replaceStylesheet(styleName, typeof result === 'string' ? '{ ' + result + ' }' : styleToString(result)); | ||
if (result) { | ||
var rule = appearance.insertCSSRuleById(result); | ||
appearance.addStyleById(stateId, rule); | ||
} | ||
} | ||
@@ -70,0 +54,0 @@ |
@@ -57,3 +57,3 @@ 'use strict'; | ||
return visible !== undefined && visible.length !== 0; | ||
return visible !== undefined && Array.isArray(visible) && visible.length !== 0; | ||
} |
@@ -110,2 +110,10 @@ 'use strict'; | ||
}, { | ||
key: 'back', | ||
value: function back() { | ||
var len = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1; | ||
// back方法目前只按点去分割回滚 | ||
return new StatePath(this.toString().split('.').slice(0, -len).join('.')); | ||
} | ||
}, { | ||
key: 'explode', | ||
@@ -112,0 +120,0 @@ value: function explode() { |
@@ -6,7 +6,5 @@ 'use strict'; | ||
}); | ||
var PROD = exports.PROD = 'production'; | ||
var DEBUG = exports.DEBUG = 'debug'; | ||
var DISPLAY_BLOCK = exports.DISPLAY_BLOCK = 'block'; | ||
var DISPLAY_INLINE = exports.DISPLAY_INLINE = 'inline'; | ||
var isDebug = exports.isDebug = process.env.NODE_ENV === 'development'; | ||
var PRIMITIVE_COMPONENTS = exports.PRIMITIVE_COMPONENTS = { | ||
@@ -13,0 +11,0 @@ a: DISPLAY_INLINE, |
@@ -8,6 +8,10 @@ 'use strict'; | ||
var _extends2 = require('babel-runtime/helpers/extends'); | ||
var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); | ||
var _extends3 = _interopRequireDefault(_extends2); | ||
var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); | ||
var _typeof2 = require('babel-runtime/helpers/typeof'); | ||
var _typeof3 = _interopRequireDefault(_typeof2); | ||
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
@@ -33,2 +37,8 @@ | ||
var _extends2 = require('babel-runtime/helpers/extends'); | ||
var _extends3 = _interopRequireDefault(_extends2); | ||
var _templateObject = (0, _taggedTemplateLiteral3.default)(['', ''], ['', '']); | ||
exports.default = createAppearance; | ||
@@ -44,2 +54,6 @@ | ||
var _sheet = require('./sheet'); | ||
var _sheet2 = _interopRequireDefault(_sheet); | ||
var _util = require('./util'); | ||
@@ -53,8 +67,41 @@ | ||
var _constant = require('./constant'); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
var DISPLAY_NONE = exports.DISPLAY_NONE = 'DISPLAY_NONE'; | ||
var DISPLAY_NONE = exports.DISPLAY_NONE = 'display-none'; | ||
var STYLE_SHEET_PREFIX = exports.STYLE_SHEET_PREFIX = 'CICADA_APPEAR_'; | ||
var prefixReg = new RegExp('^' + STYLE_SHEET_PREFIX); | ||
// const prefixReg = new RegExp(`^${STYLE_SHEET_PREFIX}`) | ||
var isObject = function isObject(v) { | ||
return Object.prototype.toString.apply(v) === '[object Object]'; | ||
}; | ||
// 避免state数据传入到react开发版props属性被设置为frozen导致无法set | ||
function simpleCloneWithNofrozen(state) { | ||
if (!isObject(state)) return state; | ||
return (0, _util.mapValues)(state, function (v) { | ||
return isObject(v) ? (0, _extends3.default)({}, v) : v; | ||
}); | ||
} | ||
function toLowerCaseKey(key) { | ||
return key.replace(/[A-Z]/g, function (k, i) { | ||
return i === 0 ? k.toLowerCase() : '-' + k.toLowerCase(); | ||
}); | ||
} | ||
function styleToString(style) { | ||
var content = (0, _util.reduce)(style, function (arr, o, key) { | ||
return arr.concat(toLowerCaseKey(key) + ': ' + (typeof o === 'number' ? o + 'px' : o)); | ||
}, []).join('; '); | ||
return '' + content; | ||
} | ||
function spliceOne(list, index) { | ||
for (var i = index, k = i + 1, n = list.length; k < n; i += 1, k += 1) { | ||
list[i] = list[k]; | ||
} | ||
list.pop(); | ||
} | ||
var RefProxy = function (_React$Component) { | ||
@@ -76,5 +123,21 @@ (0, _inherits3.default)(RefProxy, _React$Component); | ||
}(_react2.default.Component); | ||
/* eslint-disable no-use-before-define */ | ||
function createStylesheet(clsName, content) { | ||
clsName = '' + STYLE_SHEET_PREFIX + clsName; | ||
if (typeof document === 'undefined' || document.getElementById(clsName)) return clsName; | ||
var styleDom = document.createElement('style'); | ||
styleDom.setAttribute('id', clsName); | ||
var attrName = 'data-cicada-' + clsName; | ||
styleDom.innerText = '.' + clsName + ', [' + attrName + '] ' + content; | ||
document.head.appendChild(styleDom); | ||
return clsName; | ||
} | ||
function interleave(strings, interpolations) { | ||
return strings.reduce(function (final, str, i) { | ||
return final + str + (interpolations[i] === undefined ? '' : interpolations[i]); | ||
}, ''); | ||
} | ||
/* eslint-disable no-use-before-define */ | ||
function createAppearance(stateTree) { | ||
@@ -89,11 +152,10 @@ var externalProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; | ||
function createStylesheet(clsName, content) { | ||
clsName = '' + STYLE_SHEET_PREFIX + clsName; | ||
if (typeof document === 'undefined' || document.getElementById(clsName)) return clsName; | ||
var styleDom = document.createElement('style'); | ||
styleDom.setAttribute('id', clsName); | ||
styleDom.innerText = '.' + clsName + ' ' + content; | ||
document.head.appendChild(styleDom); | ||
return clsName; | ||
appearance.sheet = new _sheet2.default({ | ||
key: 'css' | ||
}); | ||
if (_util.isBrowser) { | ||
appearance.sheet.inject(); | ||
} | ||
function replaceStylesheet(styleName, content) { | ||
@@ -106,4 +168,5 @@ if (typeof document === 'undefined') return; | ||
} | ||
var displayNoneStyle = createStylesheet(DISPLAY_NONE, '{ display: none !important; }'); | ||
// const displayNoneStyle = createStylesheet(DISPLAY_NONE, 'display: none !important;') | ||
function updateAppearanceRef(id) { | ||
@@ -119,7 +182,32 @@ var _ref = refCache[id] || {}, | ||
var classList = visible ? styleList : styleList.concat(displayNoneStyle); | ||
var className = ref.className.split(/\s+/).filter(function (cls) { | ||
return cls && !prefixReg.test(cls); | ||
}).concat(classList).join(' '); | ||
if (ref.className !== className) ref.className = className; | ||
if (visible) { | ||
var classList = styleList; | ||
// 获取已有 data-attr | ||
var attrs = ref.attributes; | ||
var output = []; | ||
for (var i = attrs.length - 1; i >= 0; i--) { | ||
output.push(attrs[i].name); | ||
} | ||
// visible 变化 | ||
if (output.includes('data-cicada-' + DISPLAY_NONE)) { | ||
ref.removeAttribute('data-cicada-' + DISPLAY_NONE); | ||
} | ||
// className 动态变化后,如果 attr 没有 cls, 则新增 attr | ||
// 如果已有,则不用set,但是从记录中删除 | ||
(0, _util.each)(classList, function (cls) { | ||
if (!output.includes('data-cicada-' + cls)) { | ||
ref.setAttribute('data-cicada-' + cls, ''); | ||
} else { | ||
spliceOne(output, output.indexOf('data-cicada-' + cls)); | ||
} | ||
}); | ||
// 最后遍历下attr原始记录,多余的data-attr删除 | ||
(0, _util.each)(output, function (attr) { | ||
if (/^data-cicada/.test(attr)) { | ||
ref.removeAttribute(attr); | ||
} | ||
}); | ||
} else { | ||
ref.setAttribute('data-cicada-' + DISPLAY_NONE, ''); | ||
} | ||
if (children !== undefined) { | ||
@@ -140,2 +228,8 @@ // refCache[id].children = ref.innerHTML | ||
function flush() { | ||
if (_util.isBrowser) { | ||
appearance.sheet.flush(); | ||
} | ||
} | ||
function injectExternalListenerArg(id, listener, props) { | ||
@@ -179,3 +273,3 @@ return function () { | ||
componentArg.props = (0, _extends3.default)({}, componentArg.props, injectedExternalProps); | ||
componentArg.state = _constant.isDebug ? simpleCloneWithNofrozen(componentArg.state) : componentArg.state; | ||
return _react2.default.createElement( | ||
@@ -210,2 +304,26 @@ RefProxy, | ||
function insertCSSRuleById(style) { | ||
var sheet = appearance.sheet; | ||
// 简单的 css-in-js ,不能处理 nested、mediaquery | ||
// 与 antdesign 冲突,使用 data-attr 来加载样式 | ||
function css(strings) { | ||
for (var _len2 = arguments.length, interpolations = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { | ||
interpolations[_key2 - 1] = arguments[_key2]; | ||
} | ||
var styleString = interleave(strings, interpolations); | ||
var index = sheet.ctr; | ||
var id = index.toString(36); | ||
var className = 'css-' + id; | ||
var attrName = '[data-cicada-' + className + ']'; | ||
var rule = '.' + className + ', ' + attrName + ' { ' + styleString + ' }'; | ||
sheet.insert(rule); | ||
return className; | ||
} | ||
if ((typeof style === 'undefined' ? 'undefined' : (0, _typeof3.default)(style)) === 'object') { | ||
style = styleToString(style); | ||
} | ||
return css(_templateObject, style); | ||
} | ||
return { | ||
@@ -229,2 +347,3 @@ register: function register(id, _ref2, fn) { | ||
unsubscribe(); | ||
flush(); | ||
delete appearance[id]; | ||
@@ -240,2 +359,4 @@ clearAppearanceRef(id); | ||
}, | ||
insertCSSRuleById: insertCSSRuleById, | ||
isVisibleById: function isVisibleById(id) { | ||
@@ -257,13 +378,23 @@ return appearance[id].visible; | ||
subscribeById: subscribeById, | ||
getStyleById: function getStyleById(id) { | ||
return appearance[id].styleList || []; | ||
}, | ||
replaceStyleById: function replaceStyleById(id) { | ||
for (var _len3 = arguments.length, styleList = Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) { | ||
styleList[_key3 - 1] = arguments[_key3]; | ||
} | ||
appearance[id].styleList = styleList; | ||
}, | ||
addStyleById: function addStyleById(id) { | ||
for (var _len2 = arguments.length, styleList = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { | ||
styleList[_key2 - 1] = arguments[_key2]; | ||
for (var _len4 = arguments.length, styleList = Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) { | ||
styleList[_key4 - 1] = arguments[_key4]; | ||
} | ||
appearance[id].styleList = (0, _util.union)(appearance[id].styleList.concat(styleList)); | ||
appearance[id].styleList = (0, _util.union)(appearance[id].styleList, styleList); | ||
notify(id); | ||
}, | ||
removeStyleById: function removeStyleById(id) { | ||
for (var _len3 = arguments.length, styleList = Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) { | ||
styleList[_key3 - 1] = arguments[_key3]; | ||
for (var _len5 = arguments.length, styleList = Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) { | ||
styleList[_key5 - 1] = arguments[_key5]; | ||
} | ||
@@ -277,4 +408,4 @@ | ||
createStylesheet: createStylesheet, | ||
replaceStylesheet: replaceStylesheet, | ||
createStylesheet: createStylesheet, | ||
getIdsByComponentPath: function getIdsByComponentPath(pathArr) { | ||
@@ -281,0 +412,0 @@ return stateIdByComponentPath.get(pathArr.join('.')); |
@@ -54,7 +54,8 @@ 'use strict'; | ||
var children = _ref.children, | ||
props = _ref.props, | ||
_ref$props = _ref.props, | ||
props = _ref$props === undefined ? {} : _ref$props, | ||
listeners = _ref.listeners; | ||
return _react2.default.createElement( | ||
Tag, | ||
(0, _extends3.default)({}, props, listeners), | ||
(0, _extends3.default)({}, (0, _util.pick)(props, ['style', 'className']), listeners), | ||
children | ||
@@ -61,0 +62,0 @@ ); |
@@ -29,6 +29,6 @@ 'use strict'; | ||
var _errors = require('./errors'); | ||
var _constant = require('./constant'); | ||
var _errors = require('./errors'); | ||
var _common = require('./common'); | ||
@@ -53,4 +53,2 @@ | ||
*/ | ||
var ENV = typeof ENV === 'undefined' ? _constant.PROD : ENV; | ||
function createStateTree(initialStateTree) { | ||
@@ -65,3 +63,3 @@ var stateTree = (0, _cloneDeep2.default)(initialStateTree) || {}; | ||
function guardWithPathDetect(fn) { | ||
return function (statePath) { | ||
return function () { | ||
for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { | ||
@@ -71,4 +69,6 @@ rest[_key - 1] = arguments[_key]; | ||
if (ENV === _constant.DEBUG && _exist2.default.detect(stateTree, statePath) !== true) { | ||
throw new _errors.ErrorWrongStateTreePath(statePath, _exist2.default.detect(stateTree, statePath)); | ||
var statePath = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; | ||
if (_constant.isDebug && _exist2.default.detect(stateTree, statePath) !== true) { | ||
console.error('Warning: ' + new _errors.ErrorWrongStateTreePath(statePath, _exist2.default.detect(stateTree, statePath))); | ||
} | ||
@@ -133,3 +133,6 @@ | ||
function findRelativePath(parent, child) { | ||
function findRelativePath() { | ||
var parent = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; | ||
var child = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; | ||
// CAUTION 未做检测。parent.length + 1 是为了去掉中间那个 . 号 | ||
@@ -136,0 +139,0 @@ return child.slice(parent.length + 1); |
@@ -34,3 +34,3 @@ 'use strict'; | ||
/* eslint-disable no-nested-ternary*/ | ||
/* eslint-disable no-nested-ternary */ | ||
return path === '' ? isExist(obj) ? obj : defaultValue : _exist2.default.get(obj, path, defaultValue); | ||
@@ -37,0 +37,0 @@ }, |
@@ -6,3 +6,3 @@ 'use strict'; | ||
}); | ||
exports.SUPPORTED_TAGS = exports.keys = undefined; | ||
exports.isBrowser = exports.SUPPORTED_TAGS = exports.keys = undefined; | ||
@@ -463,2 +463,4 @@ var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
return !isReactComponent; | ||
} | ||
} | ||
var isBrowser = exports.isBrowser = typeof document !== 'undefined'; |
{ | ||
"name": "@cicada/render", | ||
"version": "1.1.8-alpha1", | ||
"version": "1.1.8-alpha10", | ||
"main": "./lib/index.js", | ||
@@ -77,2 +77,1 @@ "scripts": { | ||
} | ||
Environment variable access
Supply chain riskPackage accesses environment variables, which may be a sign of credential stuffing or data theft.
Found 1 instance in 1 package
375004
66
9137
2