react-native-unistyles 3.0.0-alpha.10 → 3.0.0-alpha.11
Sign up to get free protection for your applications and to get access to all the features.
- package/cxx/core/Unistyle.h +7 -4
- package/cxx/core/UnistyleWrapper.h +19 -1
- package/cxx/core/UnistylesRegistry.cpp +18 -35
- package/cxx/core/UnistylesRegistry.h +1 -4
- package/cxx/hybridObjects/HybridShadowRegistry.cpp +7 -7
- package/cxx/parser/Parser.cpp +33 -39
- package/cxx/parser/Parser.h +1 -1
- package/cxx/shadowTree/ShadowLeafUpdate.h +1 -1
- package/cxx/shadowTree/ShadowTreeManager.cpp +3 -8
- package/lib/commonjs/specs/ShadowRegistry/index.js +1 -1
- package/lib/commonjs/specs/ShadowRegistry/index.js.map +1 -1
- package/lib/module/specs/ShadowRegistry/index.js +1 -1
- package/lib/module/specs/ShadowRegistry/index.js.map +1 -1
- package/lib/typescript/src/specs/ShadowRegistry/index.d.ts +1 -1
- package/lib/typescript/src/specs/ShadowRegistry/index.d.ts.map +1 -1
- package/package.json +1 -1
- package/plugin/__tests__/dependencies.spec.js +15 -5
- package/plugin/__tests__/ref.spec.js +209 -30
- package/plugin/__tests__/stylesheet.spec.js +27 -9
- package/plugin/index.js +38 -3
- package/plugin/ref.js +41 -11
- package/plugin/style.js +45 -1
- package/src/specs/ShadowRegistry/index.ts +2 -2
package/cxx/core/Unistyle.h
CHANGED
@@ -7,6 +7,8 @@
|
|
7
7
|
|
8
8
|
namespace margelo::nitro::unistyles::core {
|
9
9
|
|
10
|
+
class StyleSheet;
|
11
|
+
|
10
12
|
using namespace facebook;
|
11
13
|
|
12
14
|
enum class UnistyleType {
|
@@ -17,8 +19,8 @@ enum class UnistyleType {
|
|
17
19
|
struct Unistyle {
|
18
20
|
using Shared = std::shared_ptr<Unistyle>;
|
19
21
|
|
20
|
-
Unistyle(UnistyleType type, std::string styleKey, jsi::Object& rawObject)
|
21
|
-
: styleKey{styleKey}, type{type}, rawValue{std::move(rawObject)} {}
|
22
|
+
Unistyle(UnistyleType type, std::string styleKey, jsi::Object& rawObject, std::shared_ptr<StyleSheet> styleSheet)
|
23
|
+
: styleKey{styleKey}, type{type}, rawValue{std::move(rawObject)}, parent{styleSheet} {}
|
22
24
|
virtual ~Unistyle() = default;
|
23
25
|
|
24
26
|
Unistyle(const Unistyle&) = delete;
|
@@ -29,6 +31,7 @@ struct Unistyle {
|
|
29
31
|
jsi::Object rawValue;
|
30
32
|
std::optional<jsi::Object> parsedStyle;
|
31
33
|
std::vector<UnistyleDependency> dependencies{};
|
34
|
+
std::shared_ptr<StyleSheet> parent;
|
32
35
|
|
33
36
|
inline void addDependency(UnistyleDependency dependency) {
|
34
37
|
// we can't add dependencies if unistyle is sealed
|
@@ -62,8 +65,8 @@ struct UnistyleDynamicFunction: public Unistyle {
|
|
62
65
|
// unprocessedValue <- object generated after calling proxy and user's original function
|
63
66
|
// parsedStyle <- parsed with Unistyle's parser
|
64
67
|
|
65
|
-
UnistyleDynamicFunction(UnistyleType type, std::string styleKey, jsi::Object& rawObject)
|
66
|
-
: Unistyle(type, styleKey, rawObject) {}
|
68
|
+
UnistyleDynamicFunction(UnistyleType type, std::string styleKey, jsi::Object& rawObject, std::shared_ptr<StyleSheet> styleSheet)
|
69
|
+
: Unistyle(type, styleKey, rawObject, styleSheet) {}
|
67
70
|
|
68
71
|
UnistyleDynamicFunction(const UnistyleDynamicFunction&) = delete;
|
69
72
|
UnistyleDynamicFunction(UnistyleDynamicFunction&& other) = delete;
|
@@ -21,7 +21,25 @@ inline static Unistyle::Shared unistyleFromValue(jsi::Runtime& rt, const jsi::Va
|
|
21
21
|
return nullptr;
|
22
22
|
}
|
23
23
|
|
24
|
-
|
24
|
+
auto obj = value.getObject(rt);
|
25
|
+
|
26
|
+
if (!obj.hasNativeState(rt)) {
|
27
|
+
throw jsi::JSError(rt, R"(Unistyles: Style is not bound!
|
28
|
+
|
29
|
+
Potential reasons:
|
30
|
+
- You likely used the spread operator on a Unistyle style outside of a JSX component
|
31
|
+
- You're mixing React Native's StyleSheet styles with Unistyles styles
|
32
|
+
|
33
|
+
If you need to merge styles, do it within the style prop of your JSX component:
|
34
|
+
|
35
|
+
style={{...styles.container, ...styles.otherProp}} or style={[styles.container, styles.otherProp]}
|
36
|
+
|
37
|
+
Copying a Unistyle style outside of a JSX element will remove its internal C++ state, leading to unexpected behavior.
|
38
|
+
|
39
|
+
If you're mixing React Native and Unistyle StyleSheet styles, move your static styles into Unistyles to avoid conflicts.)");
|
40
|
+
}
|
41
|
+
|
42
|
+
return obj.getNativeState<UnistyleWrapper>(rt)->unistyle;
|
25
43
|
}
|
26
44
|
|
27
45
|
inline static jsi::Value valueFromUnistyle(jsi::Runtime& rt, Unistyle::Shared unistyle) {
|
@@ -104,57 +104,40 @@ std::shared_ptr<core::StyleSheet> core::UnistylesRegistry::addStyleSheet(jsi::Ru
|
|
104
104
|
core::DependencyMap core::UnistylesRegistry::buildDependencyMap(jsi::Runtime& rt, std::vector<UnistyleDependency>& deps) {
|
105
105
|
DependencyMap dependencyMap;
|
106
106
|
std::set<UnistyleDependency> uniqueDependencies(deps.begin(), deps.end());
|
107
|
-
|
108
|
-
for (const auto& [
|
109
|
-
for (const auto&
|
110
|
-
// check if in the given stylesheet we have unistyle
|
111
|
-
// that depends on something affected
|
107
|
+
|
108
|
+
for (const auto& [family, unistyles] : this->_shadowRegistry) {
|
109
|
+
for (const auto& unistyleData : unistyles) {
|
112
110
|
bool hasAnyOfDependencies = std::any_of(
|
113
|
-
unistyle->dependencies.begin(),
|
114
|
-
unistyle->dependencies.end(),
|
111
|
+
unistyleData->unistyle->dependencies.begin(),
|
112
|
+
unistyleData->unistyle->dependencies.end(),
|
115
113
|
[&uniqueDependencies](UnistyleDependency dep) {
|
116
114
|
return std::find(uniqueDependencies.begin(), uniqueDependencies.end(), dep) != uniqueDependencies.end();
|
117
115
|
}
|
118
116
|
);
|
119
|
-
|
117
|
+
|
120
118
|
if (!hasAnyOfDependencies) {
|
121
119
|
continue;
|
122
120
|
}
|
123
|
-
|
124
|
-
//
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
for (const auto& unistyleData : unistyles) {
|
129
|
-
if (unistyle != unistyleData->unistyle) {
|
130
|
-
continue;
|
131
|
-
}
|
132
|
-
|
133
|
-
dependencyMap[styleSheet][family].emplace_back(unistyleData);
|
134
|
-
}
|
121
|
+
|
122
|
+
// we need to take in count all unistyles from the shadowNode
|
123
|
+
// as user might be using spreads and not all of them may have dependencies
|
124
|
+
for (const auto& unistyleData : unistyles) {
|
125
|
+
dependencyMap[family].emplace_back(unistyleData);
|
135
126
|
}
|
127
|
+
|
128
|
+
break;
|
136
129
|
}
|
137
130
|
}
|
138
|
-
|
131
|
+
|
139
132
|
return dependencyMap;
|
140
133
|
}
|
141
134
|
|
142
135
|
core::DependencyMap core::UnistylesRegistry::buildDependencyMap(jsi::Runtime& rt) {
|
143
136
|
DependencyMap dependencyMap;
|
144
|
-
|
145
|
-
for (const auto& [
|
146
|
-
for (const auto&
|
147
|
-
|
148
|
-
const auto& [family, unistyles] = pair;
|
149
|
-
|
150
|
-
for (const auto& unistyleData : unistyles) {
|
151
|
-
if (unistyle != unistyleData->unistyle) {
|
152
|
-
continue;
|
153
|
-
}
|
154
|
-
|
155
|
-
dependencyMap[styleSheet][family].emplace_back(unistyleData);
|
156
|
-
}
|
157
|
-
}
|
137
|
+
|
138
|
+
for (const auto& [family, unistyles] : this->_shadowRegistry) {
|
139
|
+
for (const auto& unistyleData : unistyles) {
|
140
|
+
dependencyMap[family].emplace_back(unistyleData);
|
158
141
|
}
|
159
142
|
}
|
160
143
|
|
@@ -19,10 +19,7 @@ struct UnistylesState;
|
|
19
19
|
using namespace facebook;
|
20
20
|
using namespace facebook::react;
|
21
21
|
|
22
|
-
using DependencyMap = std::unordered_map<
|
23
|
-
std::shared_ptr<core::StyleSheet>,
|
24
|
-
std::unordered_map<const ShadowNodeFamily*, std::vector<std::shared_ptr<UnistyleData>>>
|
25
|
-
>;
|
22
|
+
using DependencyMap = std::unordered_map<const ShadowNodeFamily*, std::vector<std::shared_ptr<UnistyleData>>>;
|
26
23
|
|
27
24
|
struct UnistylesRegistry: public StyleSheetRegistry {
|
28
25
|
static UnistylesRegistry& get();
|
@@ -5,29 +5,29 @@ using namespace facebook::react;
|
|
5
5
|
|
6
6
|
jsi::Value HybridShadowRegistry::link(jsi::Runtime &rt, const jsi::Value &thisValue, const jsi::Value *args, size_t count) {
|
7
7
|
helpers::assertThat(rt, count == 4, "Unistyles: Invalid babel transform 'ShadowRegistry link' expected 4 arguments.");
|
8
|
-
|
8
|
+
|
9
9
|
ShadowNode::Shared shadowNodeWrapper = shadowNodeFromValue(rt, args[0]);
|
10
10
|
core::Unistyle::Shared unistyleWrapper = core::unistyleFromValue(rt, args[1]);
|
11
11
|
core::Variants variants = helpers::variantsToPairs(rt, args[2].asObject(rt));
|
12
12
|
auto rawArguments = args[3].asObject(rt).asArray(rt);
|
13
13
|
std::vector<folly::dynamic> arguments = helpers::parseDynamicFunctionArguments(rt, rawArguments);
|
14
|
-
|
14
|
+
|
15
15
|
auto& registry = core::UnistylesRegistry::get();
|
16
|
-
|
16
|
+
|
17
17
|
registry.linkShadowNodeWithUnistyle(&shadowNodeWrapper->getFamily(), unistyleWrapper, variants, arguments);
|
18
|
-
|
18
|
+
|
19
19
|
return jsi::Value::undefined();
|
20
20
|
}
|
21
21
|
|
22
22
|
jsi::Value HybridShadowRegistry::unlink(jsi::Runtime &rt, const jsi::Value &thisValue, const jsi::Value *args, size_t count) {
|
23
23
|
helpers::assertThat(rt, count == 2, "Unistyles: Invalid babel transform 'ShadowRegistry unlink' expected 2 arguments.");
|
24
|
-
|
24
|
+
|
25
25
|
ShadowNode::Shared shadowNodeWrapper = shadowNodeFromValue(rt, args[0]);
|
26
26
|
core::Unistyle::Shared unistyleWrapper = core::unistyleFromValue(rt, args[1]);
|
27
|
-
|
27
|
+
|
28
28
|
auto& registry = core::UnistylesRegistry::get();
|
29
29
|
|
30
30
|
registry.unlinkShadowNodeWithUnistyle(&shadowNodeWrapper->getFamily(), unistyleWrapper);
|
31
|
-
|
31
|
+
|
32
32
|
return jsi::Value::undefined();
|
33
33
|
}
|
package/cxx/parser/Parser.cpp
CHANGED
@@ -20,7 +20,8 @@ void parser::Parser::buildUnistyles(jsi::Runtime& rt, std::shared_ptr<StyleSheet
|
|
20
20
|
styleSheet->unistyles[styleKey] = std::make_shared<UnistyleDynamicFunction>(
|
21
21
|
UnistyleType::DynamicFunction,
|
22
22
|
styleKey,
|
23
|
-
styleValue
|
23
|
+
styleValue,
|
24
|
+
styleSheet
|
24
25
|
);
|
25
26
|
|
26
27
|
return;
|
@@ -29,7 +30,8 @@ void parser::Parser::buildUnistyles(jsi::Runtime& rt, std::shared_ptr<StyleSheet
|
|
29
30
|
styleSheet->unistyles[styleKey] = std::make_shared<Unistyle>(
|
30
31
|
UnistyleType::Object,
|
31
32
|
styleKey,
|
32
|
-
styleValue
|
33
|
+
styleValue,
|
34
|
+
styleSheet
|
33
35
|
);
|
34
36
|
});
|
35
37
|
}
|
@@ -98,22 +100,22 @@ void parser::Parser::rebuildUnistylesWithVariants(jsi::Runtime& rt, std::shared_
|
|
98
100
|
|
99
101
|
// rebuild all unistyles that are affected by platform event
|
100
102
|
void parser::Parser::rebuildUnistylesInDependencyMap(jsi::Runtime& rt, DependencyMap& dependencyMap) {
|
101
|
-
for (auto& [
|
103
|
+
for (auto& [shadowNode, unistyles] : dependencyMap) {
|
104
|
+
auto styleSheet = unistyles.begin()->get()->unistyle->parent;
|
105
|
+
|
102
106
|
jsi::Object unwrappedStyleSheet = this->unwrapStyleSheet(rt, styleSheet);
|
103
107
|
|
104
|
-
for (auto&
|
105
|
-
|
106
|
-
auto& unistyle = unistyleData->unistyle;
|
108
|
+
for (auto& unistyleData : unistyles) {
|
109
|
+
auto& unistyle = unistyleData->unistyle;
|
107
110
|
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
}
|
112
|
-
|
113
|
-
unistyle->rawValue = unwrappedStyleSheet.getProperty(rt, unistyle->styleKey.c_str()).asObject(rt);
|
114
|
-
this->rebuildUnistyle(rt, styleSheet, unistyle, unistyleData->variants, unistyleData->dynamicFunctionMetadata);
|
115
|
-
unistyleData->parsedStyle = jsi::Value(rt, unistyle->parsedStyle.value()).asObject(rt);
|
111
|
+
// StyleSheet might have styles that are not affected
|
112
|
+
if (!unwrappedStyleSheet.hasProperty(rt, unistyle->styleKey.c_str())) {
|
113
|
+
continue;
|
116
114
|
}
|
115
|
+
|
116
|
+
unistyle->rawValue = unwrappedStyleSheet.getProperty(rt, unistyle->styleKey.c_str()).asObject(rt);
|
117
|
+
this->rebuildUnistyle(rt, styleSheet, unistyle, unistyleData->variants, unistyleData->dynamicFunctionMetadata);
|
118
|
+
unistyleData->parsedStyle = jsi::Value(rt, unistyle->parsedStyle.value()).asObject(rt);
|
117
119
|
}
|
118
120
|
}
|
119
121
|
}
|
@@ -148,7 +150,7 @@ void parser::Parser::rebuildUnistyle(jsi::Runtime& rt, std::shared_ptr<StyleShee
|
|
148
150
|
// call cached function with memoized arguments
|
149
151
|
auto functionResult = unistyleFn->rawValue
|
150
152
|
.asFunction(rt)
|
151
|
-
.
|
153
|
+
.call(rt, argStart, dynamicFunctionMetadata.size())
|
152
154
|
.asObject(rt);
|
153
155
|
|
154
156
|
unistyleFn->unprocessedValue = std::move(functionResult);
|
@@ -160,21 +162,11 @@ void parser::Parser::rebuildUnistyle(jsi::Runtime& rt, std::shared_ptr<StyleShee
|
|
160
162
|
shadow::ShadowLeafUpdates parser::Parser::dependencyMapToShadowLeafUpdates(core::DependencyMap& dependencyMap) {
|
161
163
|
shadow::ShadowLeafUpdates updates;
|
162
164
|
auto& rt = this->_unistylesRuntime->getRuntime();
|
163
|
-
|
164
|
-
for (const auto& [
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
if (updates.contains(shadowNode)) {
|
170
|
-
updates[shadowNode].emplace_back(std::move(rawProps));
|
171
|
-
|
172
|
-
continue;
|
173
|
-
}
|
174
|
-
|
175
|
-
updates.emplace(shadowNode, std::vector<RawProps>{std::move(rawProps)});
|
176
|
-
}
|
177
|
-
}
|
165
|
+
|
166
|
+
for (const auto& [shadowNode, unistyles] : dependencyMap) {
|
167
|
+
auto rawProps = this->parseStylesToShadowTreeStyles(rt, unistyles);
|
168
|
+
|
169
|
+
updates.emplace(shadowNode, std::move(rawProps));
|
178
170
|
}
|
179
171
|
|
180
172
|
return updates;
|
@@ -617,18 +609,20 @@ jsi::Value parser::Parser::parseSecondLevel(jsi::Runtime &rt, Unistyle::Shared u
|
|
617
609
|
return parsedStyle;
|
618
610
|
}
|
619
611
|
|
620
|
-
// convert
|
621
|
-
RawProps parser::Parser::parseStylesToShadowTreeStyles(jsi::Runtime& rt, const
|
612
|
+
// convert unistyles to RawValue with int colors
|
613
|
+
RawProps parser::Parser::parseStylesToShadowTreeStyles(jsi::Runtime& rt, const std::vector<std::shared_ptr<UnistyleData>>& unistyles) {
|
622
614
|
jsi::Object convertedStyles = jsi::Object(rt);
|
623
615
|
auto& state = core::UnistylesRegistry::get().getState(rt);
|
616
|
+
|
617
|
+
for (const auto& unistyleData : unistyles) {
|
618
|
+
helpers::enumerateJSIObject(rt, unistyleData->parsedStyle.value(), [&](const std::string& propertyName, jsi::Value& propertyValue){
|
619
|
+
if (this->isColor(propertyName)) {
|
620
|
+
return convertedStyles.setProperty(rt, propertyName.c_str(), jsi::Value(state.parseColor(propertyValue)));
|
621
|
+
}
|
624
622
|
|
625
|
-
|
626
|
-
|
627
|
-
|
628
|
-
}
|
629
|
-
|
630
|
-
convertedStyles.setProperty(rt, propertyName.c_str(), propertyValue);
|
631
|
-
});
|
623
|
+
convertedStyles.setProperty(rt, propertyName.c_str(), propertyValue);
|
624
|
+
});
|
625
|
+
}
|
632
626
|
|
633
627
|
return RawProps(rt, std::move(convertedStyles));
|
634
628
|
}
|
package/cxx/parser/Parser.h
CHANGED
@@ -40,7 +40,7 @@ private:
|
|
40
40
|
jsi::Value getStylesForVariant(jsi::Runtime& rt, const std::string groupName, jsi::Object&& groupValue, std::optional<std::string> selectedVariant, Variants& variants);
|
41
41
|
jsi::Object parseCompoundVariants(jsi::Runtime& rt, Unistyle::Shared unistyle, jsi::Object& obj, Variants& variants);
|
42
42
|
bool shouldApplyCompoundVariants(jsi::Runtime& rt, const Variants& variants, jsi::Object& compoundVariant);
|
43
|
-
RawProps parseStylesToShadowTreeStyles(jsi::Runtime& rt, const
|
43
|
+
RawProps parseStylesToShadowTreeStyles(jsi::Runtime& rt, const std::vector<std::shared_ptr<UnistyleData>>& unistyles);
|
44
44
|
bool isColor(const std::string& propertyName);
|
45
45
|
|
46
46
|
std::shared_ptr<HybridUnistylesRuntime> _unistylesRuntime;
|
@@ -8,6 +8,6 @@ namespace margelo::nitro::unistyles::shadow {
|
|
8
8
|
using namespace facebook;
|
9
9
|
using namespace facebook::react;
|
10
10
|
|
11
|
-
using ShadowLeafUpdates = std::unordered_map<const ShadowNodeFamily*,
|
11
|
+
using ShadowLeafUpdates = std::unordered_map<const ShadowNodeFamily*, RawProps>;
|
12
12
|
|
13
13
|
}
|
@@ -106,14 +106,9 @@ ShadowNode::Unshared shadow::ShadowTreeManager::cloneShadowTree(jsi::Runtime& rt
|
|
106
106
|
*shadowNode.getContextContainer()
|
107
107
|
};
|
108
108
|
|
109
|
-
updatedProps = shadowNode
|
110
|
-
|
111
|
-
|
112
|
-
for (const auto& props: rawPropsIt->second) {
|
113
|
-
updatedProps = shadowNode
|
114
|
-
.getComponentDescriptor()
|
115
|
-
.cloneProps(propsParserContext, updatedProps, RawProps(props));
|
116
|
-
}
|
109
|
+
updatedProps = shadowNode
|
110
|
+
.getComponentDescriptor()
|
111
|
+
.cloneProps(propsParserContext, shadowNode.getProps(), RawProps(rawPropsIt->second));
|
117
112
|
}
|
118
113
|
|
119
114
|
return shadowNode.clone({
|
@@ -15,7 +15,7 @@ const findShadowNodeForHandle = handle => {
|
|
15
15
|
return node;
|
16
16
|
};
|
17
17
|
HybridShadowRegistry.add = (handle, style, variants, args) => {
|
18
|
-
if (!handle
|
18
|
+
if (!handle) {
|
19
19
|
return;
|
20
20
|
}
|
21
21
|
HybridShadowRegistry.link(findShadowNodeForHandle(handle), style, variants ?? {}, args ?? []);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["_reactNativeNitroModules","require","HybridShadowRegistry","NitroModules","createHybridObject","findShadowNodeForHandle","handle","node","__internalInstanceHandle","stateNode","getScrollResponder","getNativeScrollRef","Error","add","style","variants","args","
|
1
|
+
{"version":3,"names":["_reactNativeNitroModules","require","HybridShadowRegistry","NitroModules","createHybridObject","findShadowNodeForHandle","handle","node","__internalInstanceHandle","stateNode","getScrollResponder","getNativeScrollRef","Error","add","style","variants","args","link","remove","__unid","unlink","UnistylesShadowRegistry","exports"],"sourceRoot":"../../../../src","sources":["specs/ShadowRegistry/index.ts"],"mappings":";;;;;;AAAA,IAAAA,wBAAA,GAAAC,OAAA;AAaA,MAAMC,oBAAoB,GAAGC,qCAAY,CAACC,kBAAkB,CAAiB,yBAAyB,CAAC;AAEvG,MAAMC,uBAAuB,GAAIC,MAAkB,IAAK;EACpD,MAAMC,IAAI,GAAGD,MAAM,EAAEE,wBAAwB,EAAEC,SAAS,EAAEF,IAAI,IACvDD,MAAM,EAAEI,kBAAkB,GAAG,CAAC,EAAEC,kBAAkB,GAAG,CAAC,EAAEH,wBAAwB,EAAEC,SAAS,EAAEF,IAAI,IACjGD,MAAM,EAAEK,kBAAkB,GAAG,CAAC,EAAEH,wBAAwB,EAAEC,SAAS,EAAEF,IAAI;EAEhF,IAAI,CAACA,IAAI,EAAE;IACP;IACA,MAAM,IAAIK,KAAK,CAAC,uDAAuD,CAAC;EAC5E;EAEA,OAAOL,IAAI;AACf,CAAC;AAEDL,oBAAoB,CAACW,GAAG,GAAG,CAACP,MAAM,EAAEQ,KAAK,EAAEC,QAAQ,EAAEC,IAAI,KAAK;EAC1D,IAAI,CAACV,MAAM,EAAE;IACT;EACJ;EAEAJ,oBAAoB,CAACe,IAAI,CAACZ,uBAAuB,CAACC,MAAM,CAAC,EAAEQ,KAAK,EAAEC,QAAQ,IAAI,CAAC,CAAC,EAAEC,IAAI,IAAI,EAAE,CAAC;AACjG,CAAC;AAEDd,oBAAoB,CAACgB,MAAM,GAAG,CAACZ,MAAM,EAAEQ,KAAK,KAAK;EAC7C,IAAI,CAACR,MAAM,IAAI,CAACQ,KAAK,EAAEK,MAAM,EAAE;IAC3B;EACJ;EAEAjB,oBAAoB,CAACkB,MAAM,CAACf,uBAAuB,CAACC,MAAM,CAAC,EAAEQ,KAAK,CAAC;AACvE,CAAC;AAQM,MAAMO,uBAAuB,GAAAC,OAAA,CAAAD,uBAAA,GAAGnB,oBAA4D","ignoreList":[]}
|
@@ -11,7 +11,7 @@ const findShadowNodeForHandle = handle => {
|
|
11
11
|
return node;
|
12
12
|
};
|
13
13
|
HybridShadowRegistry.add = (handle, style, variants, args) => {
|
14
|
-
if (!handle
|
14
|
+
if (!handle) {
|
15
15
|
return;
|
16
16
|
}
|
17
17
|
HybridShadowRegistry.link(findShadowNodeForHandle(handle), style, variants ?? {}, args ?? []);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["NitroModules","HybridShadowRegistry","createHybridObject","findShadowNodeForHandle","handle","node","__internalInstanceHandle","stateNode","getScrollResponder","getNativeScrollRef","Error","add","style","variants","args","
|
1
|
+
{"version":3,"names":["NitroModules","HybridShadowRegistry","createHybridObject","findShadowNodeForHandle","handle","node","__internalInstanceHandle","stateNode","getScrollResponder","getNativeScrollRef","Error","add","style","variants","args","link","remove","__unid","unlink","UnistylesShadowRegistry"],"sourceRoot":"../../../../src","sources":["specs/ShadowRegistry/index.ts"],"mappings":";;AAAA,SAASA,YAAY,QAAQ,4BAA4B;AAazD,MAAMC,oBAAoB,GAAGD,YAAY,CAACE,kBAAkB,CAAiB,yBAAyB,CAAC;AAEvG,MAAMC,uBAAuB,GAAIC,MAAkB,IAAK;EACpD,MAAMC,IAAI,GAAGD,MAAM,EAAEE,wBAAwB,EAAEC,SAAS,EAAEF,IAAI,IACvDD,MAAM,EAAEI,kBAAkB,GAAG,CAAC,EAAEC,kBAAkB,GAAG,CAAC,EAAEH,wBAAwB,EAAEC,SAAS,EAAEF,IAAI,IACjGD,MAAM,EAAEK,kBAAkB,GAAG,CAAC,EAAEH,wBAAwB,EAAEC,SAAS,EAAEF,IAAI;EAEhF,IAAI,CAACA,IAAI,EAAE;IACP;IACA,MAAM,IAAIK,KAAK,CAAC,uDAAuD,CAAC;EAC5E;EAEA,OAAOL,IAAI;AACf,CAAC;AAEDJ,oBAAoB,CAACU,GAAG,GAAG,CAACP,MAAM,EAAEQ,KAAK,EAAEC,QAAQ,EAAEC,IAAI,KAAK;EAC1D,IAAI,CAACV,MAAM,EAAE;IACT;EACJ;EAEAH,oBAAoB,CAACc,IAAI,CAACZ,uBAAuB,CAACC,MAAM,CAAC,EAAEQ,KAAK,EAAEC,QAAQ,IAAI,CAAC,CAAC,EAAEC,IAAI,IAAI,EAAE,CAAC;AACjG,CAAC;AAEDb,oBAAoB,CAACe,MAAM,GAAG,CAACZ,MAAM,EAAEQ,KAAK,KAAK;EAC7C,IAAI,CAACR,MAAM,IAAI,CAACQ,KAAK,EAAEK,MAAM,EAAE;IAC3B;EACJ;EAEAhB,oBAAoB,CAACiB,MAAM,CAACf,uBAAuB,CAACC,MAAM,CAAC,EAAEQ,KAAK,CAAC;AACvE,CAAC;AAQD,OAAO,MAAMO,uBAAuB,GAAGlB,oBAA4D","ignoreList":[]}
|
@@ -3,7 +3,7 @@ import type { ShadowNode, Unistyle, ViewHandle } from './types';
|
|
3
3
|
interface ShadowRegistry extends UnistylesShadowRegistrySpec {
|
4
4
|
add(handle?: ViewHandle, style?: Unistyle, variants?: Record<string, string | boolean>, args?: Array<any>): void;
|
5
5
|
remove(handle?: ViewHandle, style?: Unistyle): void;
|
6
|
-
link(node: ShadowNode, style
|
6
|
+
link(node: ShadowNode, style?: Unistyle, variants?: Record<string, string | boolean>, args?: Array<any>): void;
|
7
7
|
unlink(node: ShadowNode, style: Unistyle): void;
|
8
8
|
}
|
9
9
|
type PrivateMethods = 'add' | 'remove' | 'link' | 'unlink';
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/specs/ShadowRegistry/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,uBAAuB,IAAI,2BAA2B,EAAE,MAAM,wBAAwB,CAAA;AACpG,OAAO,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAE/D,UAAU,cAAe,SAAQ,2BAA2B;IAExD,GAAG,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;IACjH,MAAM,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,QAAQ,GAAG,IAAI,CAAC;IAEpD,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/specs/ShadowRegistry/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,uBAAuB,IAAI,2BAA2B,EAAE,MAAM,wBAAwB,CAAA;AACpG,OAAO,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAE/D,UAAU,cAAe,SAAQ,2BAA2B;IAExD,GAAG,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;IACjH,MAAM,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,QAAQ,GAAG,IAAI,CAAC;IAEpD,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;IAC/G,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,GAAG,IAAI,CAAA;CAClD;AAiCD,KAAK,cAAc,GACb,KAAK,GACL,QAAQ,GACR,MAAM,GACN,QAAQ,CAAA;AAEd,eAAO,MAAM,uBAAuB,EAA2B,IAAI,CAAC,cAAc,EAAE,cAAc,CAAC,CAAA"}
|
package/package.json
CHANGED
@@ -16,6 +16,7 @@ pluginTester({
|
|
16
16
|
{
|
17
17
|
title: 'Should detect dependencies in variants',
|
18
18
|
code: `
|
19
|
+
import { View, Text } from 'react-native'
|
19
20
|
import { StyleSheet } from 'react-native-unistyles'
|
20
21
|
|
21
22
|
export const Example = () => {
|
@@ -44,12 +45,13 @@ pluginTester({
|
|
44
45
|
`,
|
45
46
|
output: `
|
46
47
|
import { UnistylesShadowRegistry } from 'react-native-unistyles'
|
48
|
+
import { View, Text } from 'react-native'
|
47
49
|
import { StyleSheet } from 'react-native-unistyles'
|
48
50
|
|
49
51
|
export const Example = () => {
|
50
52
|
return (
|
51
53
|
<View
|
52
|
-
style={styles.container}
|
54
|
+
style={[styles.container]}
|
53
55
|
ref={ref => {
|
54
56
|
UnistylesShadowRegistry.add(ref, styles.container, undefined, undefined)
|
55
57
|
return () => UnistylesShadowRegistry.remove(ref, styles.container)
|
@@ -82,6 +84,7 @@ pluginTester({
|
|
82
84
|
{
|
83
85
|
title: 'Should detect dependencies in breakpoints',
|
84
86
|
code: `
|
87
|
+
import { View, Text } from 'react-native'
|
85
88
|
import { StyleSheet } from 'react-native-unistyles'
|
86
89
|
|
87
90
|
export const Example = () => {
|
@@ -105,12 +108,13 @@ pluginTester({
|
|
105
108
|
`,
|
106
109
|
output: `
|
107
110
|
import { UnistylesShadowRegistry } from 'react-native-unistyles'
|
111
|
+
import { View, Text } from 'react-native'
|
108
112
|
import { StyleSheet } from 'react-native-unistyles'
|
109
113
|
|
110
114
|
export const Example = () => {
|
111
115
|
return (
|
112
116
|
<View
|
113
|
-
style={styles.container}
|
117
|
+
style={[styles.container]}
|
114
118
|
ref={ref => {
|
115
119
|
UnistylesShadowRegistry.add(ref, styles.container, undefined, undefined)
|
116
120
|
return () => UnistylesShadowRegistry.remove(ref, styles.container)
|
@@ -140,6 +144,7 @@ pluginTester({
|
|
140
144
|
{
|
141
145
|
title: 'Should detect dependencies in calculations',
|
142
146
|
code: `
|
147
|
+
import { View, Text } from 'react-native'
|
143
148
|
import { StyleSheet } from 'react-native-unistyles'
|
144
149
|
|
145
150
|
export const Example = () => {
|
@@ -160,12 +165,13 @@ pluginTester({
|
|
160
165
|
`,
|
161
166
|
output: `
|
162
167
|
import { UnistylesShadowRegistry } from 'react-native-unistyles'
|
168
|
+
import { View, Text } from 'react-native'
|
163
169
|
import { StyleSheet } from 'react-native-unistyles'
|
164
170
|
|
165
171
|
export const Example = () => {
|
166
172
|
return (
|
167
173
|
<View
|
168
|
-
style={styles.container}
|
174
|
+
style={[styles.container]}
|
169
175
|
ref={ref => {
|
170
176
|
UnistylesShadowRegistry.add(ref, styles.container, undefined, undefined)
|
171
177
|
return () => UnistylesShadowRegistry.remove(ref, styles.container)
|
@@ -192,6 +198,7 @@ pluginTester({
|
|
192
198
|
{
|
193
199
|
title: 'Should detect dependencies in _web',
|
194
200
|
code: `
|
201
|
+
import { View, Text } from 'react-native'
|
195
202
|
import { StyleSheet } from 'react-native-unistyles'
|
196
203
|
|
197
204
|
export const Example = () => {
|
@@ -273,12 +280,13 @@ pluginTester({
|
|
273
280
|
`,
|
274
281
|
output: `
|
275
282
|
import { UnistylesShadowRegistry } from 'react-native-unistyles'
|
283
|
+
import { View, Text } from 'react-native'
|
276
284
|
import { StyleSheet } from 'react-native-unistyles'
|
277
285
|
|
278
286
|
export const Example = () => {
|
279
287
|
return (
|
280
288
|
<View
|
281
|
-
style={styles.container}
|
289
|
+
style={[styles.container]}
|
282
290
|
ref={ref => {
|
283
291
|
UnistylesShadowRegistry.add(ref, styles.container, undefined, undefined)
|
284
292
|
return () => UnistylesShadowRegistry.remove(ref, styles.container)
|
@@ -371,6 +379,7 @@ pluginTester({
|
|
371
379
|
{
|
372
380
|
title: 'Should allow user to use arrow functions with body for dynamic functions',
|
373
381
|
code: `
|
382
|
+
import { View, Text } from 'react-native'
|
374
383
|
import { StyleSheet } from 'react-native-unistyles'
|
375
384
|
|
376
385
|
export const Example = () => {
|
@@ -398,12 +407,13 @@ pluginTester({
|
|
398
407
|
`,
|
399
408
|
output: `
|
400
409
|
import { UnistylesShadowRegistry } from 'react-native-unistyles'
|
410
|
+
import { View, Text } from 'react-native'
|
401
411
|
import { StyleSheet } from 'react-native-unistyles'
|
402
412
|
|
403
413
|
export const Example = () => {
|
404
414
|
return (
|
405
415
|
<View
|
406
|
-
style={styles.container}
|
416
|
+
style={[styles.container]}
|
407
417
|
ref={ref => {
|
408
418
|
UnistylesShadowRegistry.add(ref, styles.container, undefined, undefined)
|
409
419
|
return () => UnistylesShadowRegistry.remove(ref, styles.container)
|