@rocapine/react-native-onboarding-ui 1.11.1 → 1.12.0

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.
@@ -1 +1 @@
1
- {"version":3,"file":"Renderer.d.ts","sourceRoot":"","sources":["../../../../src/UI/Pages/ComposableScreen/Renderer.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,wBAAwB,EAA6C,MAAM,SAAS,CAAC;AAQ9F,KAAK,YAAY,GAAG;IAClB,IAAI,EAAE,wBAAwB,CAAC;IAC/B,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB,CAAC;AA2CF,eAAO,MAAM,wBAAwB;;;CAAsE,CAAC"}
1
+ {"version":3,"file":"Renderer.d.ts","sourceRoot":"","sources":["../../../../src/UI/Pages/ComposableScreen/Renderer.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,wBAAwB,EAA6C,MAAM,SAAS,CAAC;AAQ9F,KAAK,YAAY,GAAG;IAClB,IAAI,EAAE,wBAAwB,CAAC;IAC/B,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB,CAAC;AAoDF,eAAO,MAAM,wBAAwB;;;CAAsE,CAAC"}
@@ -4,6 +4,7 @@ exports.ComposableScreenRenderer = void 0;
4
4
  const jsx_runtime_1 = require("react/jsx-runtime");
5
5
  const react_1 = require("react");
6
6
  const react_native_1 = require("react-native");
7
+ const react_native_onboarding_1 = require("@rocapine/react-native-onboarding");
7
8
  const types_1 = require("./types");
8
9
  const ErrorBoundary_1 = require("../../ErrorBoundary");
9
10
  const OnboardingTemplate_1 = require("../../Templates/OnboardingTemplate");
@@ -15,11 +16,16 @@ const ComposableScreenRendererBase = ({ step, onContinue }) => {
15
16
  const validatedData = (0, react_1.useMemo)(() => types_1.ComposableScreenStepTypeSchema.parse(step), [step]);
16
17
  const { elements } = validatedData.payload;
17
18
  const { composableVariables, setComposableVariable } = (0, react_1.useContext)(OnboardingProgressProvider_1.OnboardingProgressContext);
19
+ const { setVariable: setHeadlessVariable } = (0, react_1.useContext)(react_native_onboarding_1.OnboardingProgressContext);
20
+ const setVariableAndSync = (0, react_1.useCallback)((key, entry) => {
21
+ setComposableVariable(key, entry);
22
+ setHeadlessVariable(key, entry.value);
23
+ }, [setComposableVariable, setHeadlessVariable]);
18
24
  const renderChildren = (children, parentType) => children.map((child) => (0, renderElement_1.renderElement)(child, ctx, parentType));
19
25
  const ctx = {
20
26
  theme,
21
27
  variables: composableVariables,
22
- setVariable: setComposableVariable,
28
+ setVariable: setVariableAndSync,
23
29
  onContinue,
24
30
  renderChildren,
25
31
  };
@@ -1 +1 @@
1
- {"version":3,"file":"Renderer.js","sourceRoot":"","sources":["../../../../src/UI/Pages/ComposableScreen/Renderer.tsx"],"names":[],"mappings":";;;;AAAA,iCAA4C;AAC5C,+CAAsD;AACtD,mCAA8F;AAC9F,uDAAwD;AACxD,2EAAwE;AACxE,0FAAsF;AACtF,mDAAgD;AAEhD,4DAAyD;AAOzD,MAAM,4BAA4B,GAAG,CAAC,EAAE,IAAI,EAAE,UAAU,EAAgB,EAAE,EAAE;IAC1E,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,mBAAQ,GAAE,CAAC;IAC7B,MAAM,aAAa,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,sCAA8B,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IACxF,MAAM,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC,OAAO,CAAC;IAC3C,MAAM,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,GAAG,IAAA,kBAAU,EAAC,sDAAyB,CAAC,CAAC;IAE7F,MAAM,cAAc,GAAG,CAAC,QAAqB,EAAE,UAA+B,EAAE,EAAE,CAChF,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAA,6BAAa,EAAC,KAAK,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC,CAAC;IAEjE,MAAM,GAAG,GAAkB;QACzB,KAAK;QACL,SAAS,EAAE,mBAAmB;QAC9B,WAAW,EAAE,qBAAqB;QAClC,UAAU;QACV,cAAc;KACf,CAAC;IAEF,OAAO,CACL,uBAAC,uCAAkB,IACjB,IAAI,EAAE,aAAa,EACnB,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,KAAK,YAEZ,uBAAC,yBAAU,IACT,qBAAqB,EAAE,MAAM,CAAC,aAAa,EAC3C,4BAA4B,EAAE,KAAK,EACnC,oBAAoB,EAAE,KAAK,EAC3B,yBAAyB,EAAC,SAAS,YAElC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAA,6BAAa,EAAC,OAAO,EAAE,GAAG,CAAC,CAAC,GAC5C,GACM,CACtB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,yBAAU,CAAC,MAAM,CAAC;IAC/B,aAAa,EAAE;QACb,QAAQ,EAAE,CAAC;KACZ;CACF,CAAC,CAAC;AAEU,QAAA,wBAAwB,GAAG,IAAA,iCAAiB,EAAC,4BAA4B,EAAE,kBAAkB,CAAC,CAAC"}
1
+ {"version":3,"file":"Renderer.js","sourceRoot":"","sources":["../../../../src/UI/Pages/ComposableScreen/Renderer.tsx"],"names":[],"mappings":";;;;AAAA,iCAAyD;AACzD,+CAAsD;AACtD,+EAAyG;AACzG,mCAA8F;AAC9F,uDAAwD;AACxD,2EAAwE;AACxE,0FAA+G;AAC/G,mDAAgD;AAEhD,4DAAyD;AAOzD,MAAM,4BAA4B,GAAG,CAAC,EAAE,IAAI,EAAE,UAAU,EAAgB,EAAE,EAAE;IAC1E,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,mBAAQ,GAAE,CAAC;IAC7B,MAAM,aAAa,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,sCAA8B,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IACxF,MAAM,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC,OAAO,CAAC;IAC3C,MAAM,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,GAAG,IAAA,kBAAU,EAAC,sDAAyB,CAAC,CAAC;IAC7F,MAAM,EAAE,WAAW,EAAE,mBAAmB,EAAE,GAAG,IAAA,kBAAU,EAAC,mDAAuB,CAAC,CAAC;IAEjF,MAAM,kBAAkB,GAAG,IAAA,mBAAW,EACpC,CAAC,GAAW,EAAE,KAA8B,EAAE,EAAE;QAC9C,qBAAqB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAClC,mBAAmB,CAAC,GAAG,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC,EACD,CAAC,qBAAqB,EAAE,mBAAmB,CAAC,CAC7C,CAAC;IAEF,MAAM,cAAc,GAAG,CAAC,QAAqB,EAAE,UAA+B,EAAE,EAAE,CAChF,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAA,6BAAa,EAAC,KAAK,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC,CAAC;IAEjE,MAAM,GAAG,GAAkB;QACzB,KAAK;QACL,SAAS,EAAE,mBAAmB;QAC9B,WAAW,EAAE,kBAAkB;QAC/B,UAAU;QACV,cAAc;KACf,CAAC;IAEF,OAAO,CACL,uBAAC,uCAAkB,IACjB,IAAI,EAAE,aAAa,EACnB,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,KAAK,YAEZ,uBAAC,yBAAU,IACT,qBAAqB,EAAE,MAAM,CAAC,aAAa,EAC3C,4BAA4B,EAAE,KAAK,EACnC,oBAAoB,EAAE,KAAK,EAC3B,yBAAyB,EAAC,SAAS,YAElC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAA,6BAAa,EAAC,OAAO,EAAE,GAAG,CAAC,CAAC,GAC5C,GACM,CACtB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,yBAAU,CAAC,MAAM,CAAC;IAC/B,aAAa,EAAE;QACb,QAAQ,EAAE,CAAC;KACZ;CACF,CAAC,CAAC;AAEU,QAAA,wBAAwB,GAAG,IAAA,iCAAiB,EAAC,4BAA4B,EAAE,kBAAkB,CAAC,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rocapine/react-native-onboarding-ui",
3
- "version": "1.11.1",
3
+ "version": "1.12.0",
4
4
  "description": "UI components and renderers for Rocapine Onboarding Studio - Built on top of the headless SDK",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -1,9 +1,10 @@
1
- import { useContext, useMemo } from "react";
1
+ import { useCallback, useContext, useMemo } from "react";
2
2
  import { ScrollView, StyleSheet } from "react-native";
3
+ import { OnboardingProgressContext as HeadlessProgressContext } from "@rocapine/react-native-onboarding";
3
4
  import { ComposableScreenStepType, ComposableScreenStepTypeSchema, UIElement } from "./types";
4
5
  import { withErrorBoundary } from "../../ErrorBoundary";
5
6
  import { OnboardingTemplate } from "../../Templates/OnboardingTemplate";
6
- import { OnboardingProgressContext } from "../../Provider/OnboardingProgressProvider";
7
+ import { OnboardingProgressContext, ComposableVariableEntry } from "../../Provider/OnboardingProgressProvider";
7
8
  import { useTheme } from "../../Theme/useTheme";
8
9
  import { RenderContext } from "./elements/shared";
9
10
  import { renderElement } from "./elements/renderElement";
@@ -18,6 +19,15 @@ const ComposableScreenRendererBase = ({ step, onContinue }: ContentProps) => {
18
19
  const validatedData = useMemo(() => ComposableScreenStepTypeSchema.parse(step), [step]);
19
20
  const { elements } = validatedData.payload;
20
21
  const { composableVariables, setComposableVariable } = useContext(OnboardingProgressContext);
22
+ const { setVariable: setHeadlessVariable } = useContext(HeadlessProgressContext);
23
+
24
+ const setVariableAndSync = useCallback(
25
+ (key: string, entry: ComposableVariableEntry) => {
26
+ setComposableVariable(key, entry);
27
+ setHeadlessVariable(key, entry.value);
28
+ },
29
+ [setComposableVariable, setHeadlessVariable]
30
+ );
21
31
 
22
32
  const renderChildren = (children: UIElement[], parentType: "XStack" | "YStack") =>
23
33
  children.map((child) => renderElement(child, ctx, parentType));
@@ -25,7 +35,7 @@ const ComposableScreenRendererBase = ({ step, onContinue }: ContentProps) => {
25
35
  const ctx: RenderContext = {
26
36
  theme,
27
37
  variables: composableVariables,
28
- setVariable: setComposableVariable,
38
+ setVariable: setVariableAndSync,
29
39
  onContinue,
30
40
  renderChildren,
31
41
  };