New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@cicada/render

Package Overview
Dependencies
Maintainers
6
Versions
107
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@cicada/render - npm Package Compare versions

Comparing version 1.1.8-alpha1 to 1.1.8-alpha10

lib/__test__/scope.test.js

8

lib/__test__/integration/className.test.js

@@ -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": {

}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc