react-native 0.84.0-nightly-20251215-07bd24ed0 → 0.84.0-nightly-20251216-c16eb23a1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -29,7 +29,7 @@ export default class ReactNativeVersion {
29
29
  static major: number = 0;
30
30
  static minor: number = 84;
31
31
  static patch: number = 0;
32
- static prerelease: string | null = 'nightly-20251215-07bd24ed0';
32
+ static prerelease: string | null = 'nightly-20251216-c16eb23a1';
33
33
 
34
34
  static getVersionString(): string {
35
35
  return `${this.major}.${this.minor}.${this.patch}${this.prerelease != null ? `-${this.prerelease}` : ''}`;
@@ -24,7 +24,7 @@ NSDictionary* RCTGetReactNativeVersion(void)
24
24
  RCTVersionMajor: @(0),
25
25
  RCTVersionMinor: @(84),
26
26
  RCTVersionPatch: @(0),
27
- RCTVersionPrerelease: @"nightly-20251215-07bd24ed0",
27
+ RCTVersionPrerelease: @"nightly-20251216-c16eb23a1",
28
28
  };
29
29
  });
30
30
  return __rnVersion;
@@ -1,4 +1,4 @@
1
- VERSION_NAME=0.84.0-nightly-20251215-07bd24ed0
1
+ VERSION_NAME=0.84.0-nightly-20251216-c16eb23a1
2
2
  react.internal.publishingGroup=com.facebook.react
3
3
  react.internal.hermesPublishingGroup=com.facebook.hermes
4
4
 
@@ -11,7 +11,6 @@ import de.undercouch.gradle.tasks.download.Download
11
11
  import org.apache.tools.ant.taskdefs.condition.Os
12
12
 
13
13
  plugins {
14
- id("maven-publish")
15
14
  id("signing")
16
15
  alias(libs.plugins.android.library)
17
16
  alias(libs.plugins.download)
@@ -348,10 +347,7 @@ android {
348
347
  java.srcDirs("$hermesDir/lib/Platform/Intl/java", "$hermesDir/lib/Platform/Unicode/java")
349
348
  }
350
349
 
351
- buildFeatures {
352
- prefab = true
353
- prefabPublishing = true
354
- }
350
+ buildFeatures { prefab = true }
355
351
 
356
352
  dependencies {
357
353
  implementation(libs.fbjni)
@@ -365,13 +361,6 @@ android {
365
361
  jniLibs.excludes.add("**/libfbjni.so")
366
362
  }
367
363
 
368
- publishing {
369
- multipleVariants {
370
- withSourcesJar()
371
- allVariants()
372
- }
373
- }
374
-
375
364
  prefab { create("hermesvm") { headers = prefabHeadersDir.absolutePath } }
376
365
  }
377
366
 
@@ -15,6 +15,6 @@ public object ReactNativeVersion {
15
15
  "major" to 0,
16
16
  "minor" to 84,
17
17
  "patch" to 0,
18
- "prerelease" to "nightly-20251215-07bd24ed0"
18
+ "prerelease" to "nightly-20251216-c16eb23a1"
19
19
  )
20
20
  }
@@ -22,7 +22,7 @@ constexpr struct {
22
22
  int32_t Major = 0;
23
23
  int32_t Minor = 84;
24
24
  int32_t Patch = 0;
25
- std::string_view Prerelease = "nightly-20251215-07bd24ed0";
25
+ std::string_view Prerelease = "nightly-20251216-c16eb23a1";
26
26
  } ReactNativeVersion;
27
27
 
28
28
  } // namespace facebook::react
@@ -149,6 +149,9 @@ void packAnimatedProp(
149
149
  case WIDTH:
150
150
  case HEIGHT:
151
151
  case FLEX:
152
+ case PADDING:
153
+ case MARGIN:
154
+ case POSITION:
152
155
  throw std::runtime_error("Tried to synchronously update layout props");
153
156
  }
154
157
  }
@@ -17,6 +17,9 @@ enum PropName {
17
17
  WIDTH,
18
18
  HEIGHT,
19
19
  BORDER_RADII,
20
+ MARGIN,
21
+ PADDING,
22
+ POSITION,
20
23
  FLEX,
21
24
  TRANSFORM,
22
25
  BACKGROUND_COLOR,
@@ -75,6 +78,102 @@ inline void cloneProp(BaseViewProps &viewProps, const AnimatedPropBase &animated
75
78
  viewProps.borderRadii = get<CascadedBorderRadii>(animatedProp);
76
79
  break;
77
80
 
81
+ case MARGIN: {
82
+ const auto &margins = get<CascadedRectangleEdges<yoga::StyleLength>>(animatedProp);
83
+ if (margins.left.has_value()) {
84
+ viewProps.yogaStyle.setMargin(yoga::Edge::Left, margins.left.value());
85
+ }
86
+ if (margins.top.has_value()) {
87
+ viewProps.yogaStyle.setMargin(yoga::Edge::Top, margins.top.value());
88
+ }
89
+ if (margins.right.has_value()) {
90
+ viewProps.yogaStyle.setMargin(yoga::Edge::Right, margins.right.value());
91
+ }
92
+ if (margins.bottom.has_value()) {
93
+ viewProps.yogaStyle.setMargin(yoga::Edge::Bottom, margins.bottom.value());
94
+ }
95
+ if (margins.start.has_value()) {
96
+ viewProps.yogaStyle.setMargin(yoga::Edge::Start, margins.start.value());
97
+ }
98
+ if (margins.end.has_value()) {
99
+ viewProps.yogaStyle.setMargin(yoga::Edge::End, margins.end.value());
100
+ }
101
+ if (margins.horizontal.has_value()) {
102
+ viewProps.yogaStyle.setMargin(yoga::Edge::Horizontal, margins.horizontal.value());
103
+ }
104
+ if (margins.vertical.has_value()) {
105
+ viewProps.yogaStyle.setMargin(yoga::Edge::Vertical, margins.vertical.value());
106
+ }
107
+ if (margins.all.has_value()) {
108
+ viewProps.yogaStyle.setMargin(yoga::Edge::All, margins.all.value());
109
+ }
110
+ break;
111
+ }
112
+
113
+ case PADDING: {
114
+ const auto &paddings = get<CascadedRectangleEdges<yoga::StyleLength>>(animatedProp);
115
+ if (paddings.left.has_value()) {
116
+ viewProps.yogaStyle.setPadding(yoga::Edge::Left, paddings.left.value());
117
+ }
118
+ if (paddings.top.has_value()) {
119
+ viewProps.yogaStyle.setPadding(yoga::Edge::Top, paddings.top.value());
120
+ }
121
+ if (paddings.right.has_value()) {
122
+ viewProps.yogaStyle.setPadding(yoga::Edge::Right, paddings.right.value());
123
+ }
124
+ if (paddings.bottom.has_value()) {
125
+ viewProps.yogaStyle.setPadding(yoga::Edge::Bottom, paddings.bottom.value());
126
+ }
127
+ if (paddings.start.has_value()) {
128
+ viewProps.yogaStyle.setPadding(yoga::Edge::Start, paddings.start.value());
129
+ }
130
+ if (paddings.end.has_value()) {
131
+ viewProps.yogaStyle.setPadding(yoga::Edge::End, paddings.end.value());
132
+ }
133
+ if (paddings.horizontal.has_value()) {
134
+ viewProps.yogaStyle.setPadding(yoga::Edge::Horizontal, paddings.horizontal.value());
135
+ }
136
+ if (paddings.vertical.has_value()) {
137
+ viewProps.yogaStyle.setPadding(yoga::Edge::Vertical, paddings.vertical.value());
138
+ }
139
+ if (paddings.all.has_value()) {
140
+ viewProps.yogaStyle.setPadding(yoga::Edge::All, paddings.all.value());
141
+ }
142
+ break;
143
+ }
144
+
145
+ case POSITION: {
146
+ const auto &positions = get<CascadedRectangleEdges<yoga::StyleLength>>(animatedProp);
147
+ if (positions.left.has_value()) {
148
+ viewProps.yogaStyle.setPosition(yoga::Edge::Left, positions.left.value());
149
+ }
150
+ if (positions.top.has_value()) {
151
+ viewProps.yogaStyle.setPosition(yoga::Edge::Top, positions.top.value());
152
+ }
153
+ if (positions.right.has_value()) {
154
+ viewProps.yogaStyle.setPosition(yoga::Edge::Right, positions.right.value());
155
+ }
156
+ if (positions.bottom.has_value()) {
157
+ viewProps.yogaStyle.setPosition(yoga::Edge::Bottom, positions.bottom.value());
158
+ }
159
+ if (positions.start.has_value()) {
160
+ viewProps.yogaStyle.setPosition(yoga::Edge::Start, positions.start.value());
161
+ }
162
+ if (positions.end.has_value()) {
163
+ viewProps.yogaStyle.setPosition(yoga::Edge::End, positions.end.value());
164
+ }
165
+ if (positions.horizontal.has_value()) {
166
+ viewProps.yogaStyle.setPosition(yoga::Edge::Horizontal, positions.horizontal.value());
167
+ }
168
+ if (positions.vertical.has_value()) {
169
+ viewProps.yogaStyle.setPosition(yoga::Edge::Vertical, positions.vertical.value());
170
+ }
171
+ if (positions.all.has_value()) {
172
+ viewProps.yogaStyle.setPosition(yoga::Edge::All, positions.all.value());
173
+ }
174
+ break;
175
+ }
176
+
78
177
  case FLEX:
79
178
  viewProps.yogaStyle.setFlex(get<yoga::FloatOptional>(animatedProp));
80
179
  break;
@@ -31,6 +31,18 @@ struct AnimatedPropsBuilder {
31
31
  {
32
32
  props.push_back(std::make_unique<AnimatedProp<CascadedBorderRadii>>(BORDER_RADII, value));
33
33
  }
34
+ void setMargin(CascadedRectangleEdges<yoga::StyleLength> &value)
35
+ {
36
+ props.push_back(std::make_unique<AnimatedProp<CascadedRectangleEdges<yoga::StyleLength>>>(MARGIN, value));
37
+ }
38
+ void setPadding(CascadedRectangleEdges<yoga::StyleLength> &value)
39
+ {
40
+ props.push_back(std::make_unique<AnimatedProp<CascadedRectangleEdges<yoga::StyleLength>>>(PADDING, value));
41
+ }
42
+ void setPosition(CascadedRectangleEdges<yoga::StyleLength> &value)
43
+ {
44
+ props.push_back(std::make_unique<AnimatedProp<CascadedRectangleEdges<yoga::StyleLength>>>(POSITION, value));
45
+ }
34
46
  void setTransform(Transform &t)
35
47
  {
36
48
  props.push_back(std::make_unique<AnimatedProp<Transform>>(TRANSFORM, std::move(t)));
@@ -93,6 +93,40 @@ inline void updateProp(const PropName propName, BaseViewProps &viewProps, const
93
93
  case SHADOW_RADIUS:
94
94
  viewProps.shadowRadius = snapshot.props.shadowRadius;
95
95
  break;
96
+
97
+ case MARGIN:
98
+ viewProps.yogaStyle.setMargin(yoga::Edge::Left, snapshot.props.yogaStyle.margin(yoga::Edge::Left));
99
+ viewProps.yogaStyle.setMargin(yoga::Edge::Right, snapshot.props.yogaStyle.margin(yoga::Edge::Right));
100
+ viewProps.yogaStyle.setMargin(yoga::Edge::Top, snapshot.props.yogaStyle.margin(yoga::Edge::Top));
101
+ viewProps.yogaStyle.setMargin(yoga::Edge::Bottom, snapshot.props.yogaStyle.margin(yoga::Edge::Bottom));
102
+ viewProps.yogaStyle.setMargin(yoga::Edge::Start, snapshot.props.yogaStyle.margin(yoga::Edge::Start));
103
+ viewProps.yogaStyle.setMargin(yoga::Edge::End, snapshot.props.yogaStyle.margin(yoga::Edge::End));
104
+ viewProps.yogaStyle.setMargin(yoga::Edge::Horizontal, snapshot.props.yogaStyle.margin(yoga::Edge::Horizontal));
105
+ viewProps.yogaStyle.setMargin(yoga::Edge::Vertical, snapshot.props.yogaStyle.margin(yoga::Edge::Vertical));
106
+ break;
107
+
108
+ case PADDING:
109
+ viewProps.yogaStyle.setPadding(yoga::Edge::Left, snapshot.props.yogaStyle.padding(yoga::Edge::Left));
110
+ viewProps.yogaStyle.setPadding(yoga::Edge::Right, snapshot.props.yogaStyle.padding(yoga::Edge::Right));
111
+ viewProps.yogaStyle.setPadding(yoga::Edge::Top, snapshot.props.yogaStyle.padding(yoga::Edge::Top));
112
+ viewProps.yogaStyle.setPadding(yoga::Edge::Bottom, snapshot.props.yogaStyle.padding(yoga::Edge::Bottom));
113
+ viewProps.yogaStyle.setPadding(yoga::Edge::Start, snapshot.props.yogaStyle.padding(yoga::Edge::Start));
114
+ viewProps.yogaStyle.setPadding(yoga::Edge::End, snapshot.props.yogaStyle.padding(yoga::Edge::End));
115
+ viewProps.yogaStyle.setPadding(yoga::Edge::Horizontal, snapshot.props.yogaStyle.padding(yoga::Edge::Horizontal));
116
+ viewProps.yogaStyle.setPadding(yoga::Edge::Vertical, snapshot.props.yogaStyle.padding(yoga::Edge::Vertical));
117
+ break;
118
+
119
+ case POSITION:
120
+ viewProps.yogaStyle.setPosition(yoga::Edge::Left, snapshot.props.yogaStyle.position(yoga::Edge::Left));
121
+ viewProps.yogaStyle.setPosition(yoga::Edge::Right, snapshot.props.yogaStyle.position(yoga::Edge::Right));
122
+ viewProps.yogaStyle.setPosition(yoga::Edge::Top, snapshot.props.yogaStyle.position(yoga::Edge::Top));
123
+ viewProps.yogaStyle.setPosition(yoga::Edge::Bottom, snapshot.props.yogaStyle.position(yoga::Edge::Bottom));
124
+ viewProps.yogaStyle.setPosition(yoga::Edge::Start, snapshot.props.yogaStyle.position(yoga::Edge::Start));
125
+ viewProps.yogaStyle.setPosition(yoga::Edge::End, snapshot.props.yogaStyle.position(yoga::Edge::End));
126
+ viewProps.yogaStyle.setPosition(
127
+ yoga::Edge::Horizontal, snapshot.props.yogaStyle.position(yoga::Edge::Horizontal));
128
+ viewProps.yogaStyle.setPosition(yoga::Edge::Vertical, snapshot.props.yogaStyle.position(yoga::Edge::Vertical));
129
+ break;
96
130
  }
97
131
  }
98
132
 
@@ -54,7 +54,9 @@ static inline bool mutationHasLayoutUpdates(
54
54
  for (auto& animatedProp : mutation.props.props) {
55
55
  // TODO: there should also be a check for the dynamic part
56
56
  if (animatedProp->propName == WIDTH || animatedProp->propName == HEIGHT ||
57
- animatedProp->propName == FLEX) {
57
+ animatedProp->propName == FLEX || animatedProp->propName == MARGIN ||
58
+ animatedProp->propName == PADDING ||
59
+ animatedProp->propName == POSITION) {
58
60
  return true;
59
61
  }
60
62
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-native",
3
- "version": "0.84.0-nightly-20251215-07bd24ed0",
3
+ "version": "0.84.0-nightly-20251216-c16eb23a1",
4
4
  "description": "A framework for building native apps using React",
5
5
  "license": "MIT",
6
6
  "repository": {
@@ -160,13 +160,13 @@
160
160
  },
161
161
  "dependencies": {
162
162
  "@jest/create-cache-key-function": "^29.7.0",
163
- "@react-native/assets-registry": "0.84.0-nightly-20251215-07bd24ed0",
164
- "@react-native/codegen": "0.84.0-nightly-20251215-07bd24ed0",
165
- "@react-native/community-cli-plugin": "0.84.0-nightly-20251215-07bd24ed0",
166
- "@react-native/gradle-plugin": "0.84.0-nightly-20251215-07bd24ed0",
167
- "@react-native/js-polyfills": "0.84.0-nightly-20251215-07bd24ed0",
168
- "@react-native/normalize-colors": "0.84.0-nightly-20251215-07bd24ed0",
169
- "@react-native/virtualized-lists": "0.84.0-nightly-20251215-07bd24ed0",
163
+ "@react-native/assets-registry": "0.84.0-nightly-20251216-c16eb23a1",
164
+ "@react-native/codegen": "0.84.0-nightly-20251216-c16eb23a1",
165
+ "@react-native/community-cli-plugin": "0.84.0-nightly-20251216-c16eb23a1",
166
+ "@react-native/gradle-plugin": "0.84.0-nightly-20251216-c16eb23a1",
167
+ "@react-native/js-polyfills": "0.84.0-nightly-20251216-c16eb23a1",
168
+ "@react-native/normalize-colors": "0.84.0-nightly-20251216-c16eb23a1",
169
+ "@react-native/virtualized-lists": "0.84.0-nightly-20251216-c16eb23a1",
170
170
  "abort-controller": "^3.0.0",
171
171
  "anser": "^1.4.9",
172
172
  "ansi-regex": "^5.0.0",
@@ -28,6 +28,14 @@ else
28
28
  version = versionProperties['HERMES_VERSION_NAME']
29
29
  end
30
30
 
31
+ # Local monorepo build
32
+ if package['version'] == "1000.0.0" then
33
+ hermesCompilerVersion = package['dependencies']['hermes-compiler']
34
+ if hermesCompilerVersion != "0.0.0" then
35
+ version = hermesCompilerVersion
36
+ end
37
+ end
38
+
31
39
  source_type = hermes_source_type(version, react_native_path)
32
40
  source = podspec_source(source_type, version, react_native_path)
33
41