related-ui-components 3.1.1 → 3.1.3
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.
- package/lib/module/app.js +10 -3
- package/lib/module/app.js.map +1 -1
- package/lib/module/components/ScratchCard/ScratchCard.js +45 -53
- package/lib/module/components/ScratchCard/ScratchCard.js.map +1 -1
- package/lib/module/index.js +2 -2
- package/lib/typescript/src/components/ScratchCard/ScratchCard.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/app.tsx +2 -2
- package/src/components/ScratchCard/ScratchCard.tsx +56 -53
- package/src/index.ts +2 -2
package/lib/module/app.js
CHANGED
|
@@ -6,6 +6,7 @@ import { SafeAreaView, StyleSheet, StatusBar } from "react-native";
|
|
|
6
6
|
import { GestureHandlerRootView } from "react-native-gesture-handler";
|
|
7
7
|
import { lightTheme, RelatedProvider, useTheme } from "./theme/index.js";
|
|
8
8
|
import CircularProgressBar from "./components/ProgressBar/CircularProgressBar.js";
|
|
9
|
+
import PhoneInput from "./components/Input/PhoneInput.js";
|
|
9
10
|
import { BottomSheetStackProvider } from "./contexts/index.js";
|
|
10
11
|
import { SafeAreaProvider } from "react-native-safe-area-context";
|
|
11
12
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
@@ -40,9 +41,9 @@ const App = () => {
|
|
|
40
41
|
children: /*#__PURE__*/_jsxs(BottomSheetStackProvider, {
|
|
41
42
|
children: [/*#__PURE__*/_jsx(StatusBar, {
|
|
42
43
|
barStyle: "light-content"
|
|
43
|
-
}), /*#__PURE__*/
|
|
44
|
+
}), /*#__PURE__*/_jsxs(SafeAreaView, {
|
|
44
45
|
style: styles.appContainer,
|
|
45
|
-
children: /*#__PURE__*/_jsx(CircularProgressBar, {
|
|
46
|
+
children: [/*#__PURE__*/_jsx(CircularProgressBar, {
|
|
46
47
|
variant: "steps",
|
|
47
48
|
totalSteps: 4,
|
|
48
49
|
currentStep: 1,
|
|
@@ -50,7 +51,13 @@ const App = () => {
|
|
|
50
51
|
fontSize: 14,
|
|
51
52
|
strokeWidth: 2,
|
|
52
53
|
progressColor: "blue"
|
|
53
|
-
})
|
|
54
|
+
}), /*#__PURE__*/_jsx(PhoneInput, {
|
|
55
|
+
value: "",
|
|
56
|
+
onChangeText: () => {},
|
|
57
|
+
inputContainerStyle: {
|
|
58
|
+
height: 55
|
|
59
|
+
}
|
|
60
|
+
})]
|
|
54
61
|
})]
|
|
55
62
|
})
|
|
56
63
|
})
|
package/lib/module/app.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useState","SafeAreaView","StyleSheet","StatusBar","GestureHandlerRootView","lightTheme","RelatedProvider","useTheme","CircularProgressBar","BottomSheetStackProvider","SafeAreaProvider","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","DUMMY_DATA","Array","from","length","_","i","id","image","title","App","theme","departureDate","setDepartureDate","undefined","returnDate","setReturnDate","progress","setProgress","handleAnimate","newProgress","Math","floor","random","children","style","flex","barStyle","styles","appContainer","variant","totalSteps","currentStep","size","fontSize","strokeWidth","progressColor","create","backgroundColor","justifyContent","alignItems"],"sourceRoot":"..\\..\\src","sources":["app.tsx"],"mappings":";;AAAA,OAAOA,KAAK,IAAeC,QAAQ,QAAQ,OAAO;AAClD,SAASC,YAAY,EAAEC,UAAU,EAAEC,SAAS,QAAkC,cAAc;AACV;AAClF,SAASC,sBAAsB,QAAQ,8BAA8B;AAarE,SAAoBC,UAAU,EAAEC,eAAe,EAAEC,QAAQ,QAAQ,kBAAS;AAC1E,OAAOC,mBAAmB,MAAM,iDAA8C;
|
|
1
|
+
{"version":3,"names":["React","useState","SafeAreaView","StyleSheet","StatusBar","GestureHandlerRootView","lightTheme","RelatedProvider","useTheme","CircularProgressBar","PhoneInput","BottomSheetStackProvider","SafeAreaProvider","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","DUMMY_DATA","Array","from","length","_","i","id","image","title","App","theme","departureDate","setDepartureDate","undefined","returnDate","setReturnDate","progress","setProgress","handleAnimate","newProgress","Math","floor","random","children","style","flex","barStyle","styles","appContainer","variant","totalSteps","currentStep","size","fontSize","strokeWidth","progressColor","value","onChangeText","inputContainerStyle","height","create","backgroundColor","justifyContent","alignItems"],"sourceRoot":"..\\..\\src","sources":["app.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,13 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import React, { useState, useEffect, useCallback
|
|
4
|
-
} from "react";
|
|
5
|
-
import { Canvas, Group, Image, Mask, Path, Rect, Skia, useImage, Text, useFont, notifyChange
|
|
6
|
-
// Import SkPath type
|
|
7
|
-
// Import SkFont type
|
|
8
|
-
,
|
|
9
|
-
// Import SkImage type
|
|
10
|
-
LinearGradient } from "@shopify/react-native-skia";
|
|
3
|
+
import React, { useState, useEffect, useCallback } from "react";
|
|
4
|
+
import { Canvas, Group, Image, Mask, Path, Rect, Skia, useImage, Text, useFont, notifyChange, LinearGradient } from "@shopify/react-native-skia";
|
|
11
5
|
import { View, StyleSheet } from "react-native";
|
|
12
6
|
import { runOnJS, useSharedValue } from "react-native-reanimated";
|
|
13
7
|
import { Gesture, GestureDetector, GestureHandlerRootView } from "react-native-gesture-handler";
|
|
@@ -109,6 +103,48 @@ const ScratchCard = ({
|
|
|
109
103
|
return null;
|
|
110
104
|
}, [loadedFont, text, areaWidth, areaHeight]);
|
|
111
105
|
const canRenderCanvas = isLayoutReady && areaWidth > 0 && areaHeight > 0;
|
|
106
|
+
|
|
107
|
+
// Render the scratch layer content
|
|
108
|
+
const renderScratchContent = () => {
|
|
109
|
+
return /*#__PURE__*/_jsxs(Group, {
|
|
110
|
+
children: [gradient ? /*#__PURE__*/_jsx(Rect, {
|
|
111
|
+
x: 0,
|
|
112
|
+
y: 0,
|
|
113
|
+
width: areaWidth,
|
|
114
|
+
height: areaHeight,
|
|
115
|
+
children: /*#__PURE__*/_jsx(LinearGradient, {
|
|
116
|
+
start: gradient.start ?? {
|
|
117
|
+
x: 0,
|
|
118
|
+
y: 0
|
|
119
|
+
},
|
|
120
|
+
end: gradient.end ?? {
|
|
121
|
+
x: areaWidth,
|
|
122
|
+
y: areaHeight
|
|
123
|
+
},
|
|
124
|
+
colors: gradient.colors
|
|
125
|
+
})
|
|
126
|
+
}) : /*#__PURE__*/_jsx(Rect, {
|
|
127
|
+
x: 0,
|
|
128
|
+
y: 0,
|
|
129
|
+
width: areaWidth,
|
|
130
|
+
height: areaHeight,
|
|
131
|
+
color: backgroundColor
|
|
132
|
+
}), loadedImg && /*#__PURE__*/_jsx(Image, {
|
|
133
|
+
image: loadedImg,
|
|
134
|
+
fit: "contain",
|
|
135
|
+
x: 0,
|
|
136
|
+
y: 0,
|
|
137
|
+
width: areaWidth,
|
|
138
|
+
height: areaHeight
|
|
139
|
+
}), loadedFont && textMetrics && text && /*#__PURE__*/_jsx(Text, {
|
|
140
|
+
x: textMetrics.x,
|
|
141
|
+
y: textMetrics.y,
|
|
142
|
+
text: text,
|
|
143
|
+
color: textFontColor,
|
|
144
|
+
font: loadedFont
|
|
145
|
+
})]
|
|
146
|
+
});
|
|
147
|
+
};
|
|
112
148
|
return /*#__PURE__*/_jsx(GestureHandlerRootView, {
|
|
113
149
|
style: {
|
|
114
150
|
justifyContent: "center",
|
|
@@ -145,51 +181,7 @@ const ScratchCard = ({
|
|
|
145
181
|
strokeWidth: brushStrokeWidth
|
|
146
182
|
})]
|
|
147
183
|
}),
|
|
148
|
-
children:
|
|
149
|
-
image: loadedImg,
|
|
150
|
-
fit: "cover",
|
|
151
|
-
x: 0,
|
|
152
|
-
y: 0,
|
|
153
|
-
width: areaWidth,
|
|
154
|
-
height: areaHeight
|
|
155
|
-
}) : gradient ? /*#__PURE__*/_jsxs(Group, {
|
|
156
|
-
children: [/*#__PURE__*/_jsx(LinearGradient, {
|
|
157
|
-
start: gradient.start ?? {
|
|
158
|
-
x: 0,
|
|
159
|
-
y: 0
|
|
160
|
-
},
|
|
161
|
-
end: gradient.end ?? {
|
|
162
|
-
x: areaWidth,
|
|
163
|
-
y: areaHeight
|
|
164
|
-
},
|
|
165
|
-
colors: gradient.colors
|
|
166
|
-
}), /*#__PURE__*/_jsx(Rect, {
|
|
167
|
-
x: 0,
|
|
168
|
-
y: 0,
|
|
169
|
-
width: areaWidth,
|
|
170
|
-
height: areaHeight
|
|
171
|
-
}), loadedFont && textMetrics && text ? /*#__PURE__*/_jsx(Text, {
|
|
172
|
-
x: textMetrics.x,
|
|
173
|
-
y: textMetrics.y,
|
|
174
|
-
text: text,
|
|
175
|
-
color: textFontColor,
|
|
176
|
-
font: loadedFont
|
|
177
|
-
}) : null]
|
|
178
|
-
}) : /*#__PURE__*/_jsxs(Group, {
|
|
179
|
-
children: [/*#__PURE__*/_jsx(Rect, {
|
|
180
|
-
x: 0,
|
|
181
|
-
y: 0,
|
|
182
|
-
width: areaWidth,
|
|
183
|
-
height: areaHeight,
|
|
184
|
-
color: backgroundColor
|
|
185
|
-
}), loadedFont && textMetrics && text ? /*#__PURE__*/_jsx(Text, {
|
|
186
|
-
x: textMetrics.x,
|
|
187
|
-
y: textMetrics.y,
|
|
188
|
-
text: text,
|
|
189
|
-
color: textFontColor,
|
|
190
|
-
font: loadedFont
|
|
191
|
-
}) : null]
|
|
192
|
-
})
|
|
184
|
+
children: renderScratchContent()
|
|
193
185
|
})
|
|
194
186
|
})
|
|
195
187
|
})]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useState","useEffect","useCallback","Canvas","Group","Image","Mask","Path","Rect","Skia","useImage","Text","useFont","notifyChange","LinearGradient","View","StyleSheet","runOnJS","useSharedValue","Gesture","GestureDetector","GestureHandlerRootView","jsx","_jsx","jsxs","_jsxs","ScratchCard","style","children","image","brushStrokeWidth","revealThreshold","width","height","backgroundColor","text","textFont","textFontColor","textFontSize","onScratched","gradient","loadedImg","loadedFont","areaWidth","areaHeight","setSize","isScratched","setScratched","isLayoutReady","setLayoutReady","isThresholdReached","path","Make","value","handleLayout","event","newWidth","newHeight","nativeEvent","layout","revealCardOnJS","pan","Pan","averageTouches","maxPointers","onBegin","e","newPath","copy","moveTo","x","y","lineTo","error","console","onChange","bounds","getBounds","scratchedArea","totalArea","textMetrics","useMemo","metrics","measureText","textX","textY","canRenderCanvas","
|
|
1
|
+
{"version":3,"names":["React","useState","useEffect","useCallback","Canvas","Group","Image","Mask","Path","Rect","Skia","useImage","Text","useFont","notifyChange","LinearGradient","View","StyleSheet","runOnJS","useSharedValue","Gesture","GestureDetector","GestureHandlerRootView","jsx","_jsx","jsxs","_jsxs","ScratchCard","style","children","image","brushStrokeWidth","revealThreshold","width","height","backgroundColor","text","textFont","textFontColor","textFontSize","onScratched","gradient","loadedImg","loadedFont","areaWidth","areaHeight","setSize","isScratched","setScratched","isLayoutReady","setLayoutReady","isThresholdReached","path","Make","value","handleLayout","event","newWidth","newHeight","nativeEvent","layout","revealCardOnJS","pan","Pan","averageTouches","maxPointers","onBegin","e","newPath","copy","moveTo","x","y","lineTo","error","console","onChange","bounds","getBounds","scratchedArea","totalArea","textMetrics","useMemo","metrics","measureText","textX","textY","canRenderCanvas","renderScratchContent","start","end","colors","color","fit","font","justifyContent","alignContent","onLayout","styles","container","content","gesture","canvas","mode","mask","strokeJoin","strokeCap","strokeWidth","create","position","overflow","top","left","zIndex"],"sourceRoot":"..\\..\\..\\..\\src","sources":["components/ScratchCard/ScratchCard.tsx"],"mappings":"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","ignoreList":[]}
|
package/lib/module/index.js
CHANGED
|
@@ -5,8 +5,8 @@
|
|
|
5
5
|
|
|
6
6
|
// import App from "./app";
|
|
7
7
|
// import { I18nManager } from "react-native";
|
|
8
|
-
// I18nManager.allowRTL(
|
|
9
|
-
// I18nManager.forceRTL(
|
|
8
|
+
// I18nManager.allowRTL(true);
|
|
9
|
+
// I18nManager.forceRTL(true);
|
|
10
10
|
// registerRootComponent(App);
|
|
11
11
|
|
|
12
12
|
export * from "./theme/index.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ScratchCard.d.ts","sourceRoot":"","sources":["../../../../../src/components/ScratchCard/ScratchCard.tsx"],"names":[],"mappings":"AAAA,OAAO,KAKN,MAAM,OAAO,CAAC;AAkBf,OAAO,EACL,SAAS,EAET,SAAS,EAET,kBAAkB,EAEnB,MAAM,cAAc,CAAC;AAQtB,KAAK,gBAAgB,GAAG;IACtB,KAAK,CAAC,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC;IAC7B,KAAK,CAAC,EAAE,kBAAkB,CAAC;IAC3B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,kBAAkB,CAAC;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,IAAI,CAAC;IACzB,QAAQ,CAAC,EAAE;QACT,MAAM,EAAE,MAAM,EAAE,CAAC;QACjB,KAAK,CAAC,EAAE;YAAE,CAAC,EAAE,MAAM,CAAC;YAAC,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC;QACjC,GAAG,CAAC,EAAE;YAAE,CAAC,EAAE,MAAM,CAAC;YAAC,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC;KAChC,CAAC;CACH,CAAC;AAEF,QAAA,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,
|
|
1
|
+
{"version":3,"file":"ScratchCard.d.ts","sourceRoot":"","sources":["../../../../../src/components/ScratchCard/ScratchCard.tsx"],"names":[],"mappings":"AAAA,OAAO,KAKN,MAAM,OAAO,CAAC;AAkBf,OAAO,EACL,SAAS,EAET,SAAS,EAET,kBAAkB,EAEnB,MAAM,cAAc,CAAC;AAQtB,KAAK,gBAAgB,GAAG;IACtB,KAAK,CAAC,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC;IAC7B,KAAK,CAAC,EAAE,kBAAkB,CAAC;IAC3B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,kBAAkB,CAAC;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,IAAI,CAAC;IACzB,QAAQ,CAAC,EAAE;QACT,MAAM,EAAE,MAAM,EAAE,CAAC;QACjB,KAAK,CAAC,EAAE;YAAE,CAAC,EAAE,MAAM,CAAC;YAAC,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC;QACjC,GAAG,CAAC,EAAE;YAAE,CAAC,EAAE,MAAM,CAAC;YAAC,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC;KAChC,CAAC;CACH,CAAC;AAEF,QAAA,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAgN3C,CAAC;AAyBF,eAAe,WAAW,CAAC"}
|
package/package.json
CHANGED
package/src/app.tsx
CHANGED
|
@@ -108,11 +108,11 @@ const App = () => {
|
|
|
108
108
|
{/* <CarouselCardStack data={DUMMY_DATA} /> */}
|
|
109
109
|
<CircularProgressBar variant="steps" totalSteps={4} currentStep={1} size={43} fontSize={14} strokeWidth={2} progressColor="blue"></CircularProgressBar>
|
|
110
110
|
{/* <RangeSlider initialMinValue={0} initialMaxValue={100} min={0} max={500} sliderWidth={300} onValueChange={console.log}></RangeSlider> */}
|
|
111
|
-
|
|
111
|
+
<PhoneInput
|
|
112
112
|
value=""
|
|
113
113
|
onChangeText={() => {}}
|
|
114
114
|
inputContainerStyle={{ height: 55 }}
|
|
115
|
-
></PhoneInput>
|
|
115
|
+
></PhoneInput>
|
|
116
116
|
|
|
117
117
|
{/* <SelaDealCard
|
|
118
118
|
variant="horizontal"
|
|
@@ -2,7 +2,7 @@ import React, {
|
|
|
2
2
|
useRef,
|
|
3
3
|
useState,
|
|
4
4
|
useEffect,
|
|
5
|
-
useCallback,
|
|
5
|
+
useCallback,
|
|
6
6
|
} from "react";
|
|
7
7
|
import {
|
|
8
8
|
Canvas,
|
|
@@ -16,9 +16,9 @@ import {
|
|
|
16
16
|
Text,
|
|
17
17
|
useFont,
|
|
18
18
|
notifyChange,
|
|
19
|
-
SkPath,
|
|
20
|
-
SkFont,
|
|
21
|
-
SkImage,
|
|
19
|
+
SkPath,
|
|
20
|
+
SkFont,
|
|
21
|
+
SkImage,
|
|
22
22
|
LinearGradient,
|
|
23
23
|
} from "@shopify/react-native-skia";
|
|
24
24
|
import {
|
|
@@ -41,7 +41,7 @@ type ScratchCardProps = {
|
|
|
41
41
|
image?: ImageRequireSource;
|
|
42
42
|
children?: React.ReactNode;
|
|
43
43
|
brushStrokeWidth?: number;
|
|
44
|
-
revealThreshold?: number;
|
|
44
|
+
revealThreshold?: number;
|
|
45
45
|
width?: number;
|
|
46
46
|
height?: number;
|
|
47
47
|
backgroundColor?: string;
|
|
@@ -173,6 +173,55 @@ const ScratchCard: React.FC<ScratchCardProps> = ({
|
|
|
173
173
|
|
|
174
174
|
const canRenderCanvas = isLayoutReady && areaWidth > 0 && areaHeight > 0;
|
|
175
175
|
|
|
176
|
+
// Render the scratch layer content
|
|
177
|
+
const renderScratchContent = () => {
|
|
178
|
+
return (
|
|
179
|
+
<Group>
|
|
180
|
+
{/* Background layer - always render if gradient or backgroundColor */}
|
|
181
|
+
{gradient ? (
|
|
182
|
+
<Rect x={0} y={0} width={areaWidth} height={areaHeight}>
|
|
183
|
+
<LinearGradient
|
|
184
|
+
start={gradient.start ?? { x: 0, y: 0 }}
|
|
185
|
+
end={gradient.end ?? { x: areaWidth, y: areaHeight }}
|
|
186
|
+
colors={gradient.colors}
|
|
187
|
+
/>
|
|
188
|
+
</Rect>
|
|
189
|
+
) : (
|
|
190
|
+
<Rect
|
|
191
|
+
x={0}
|
|
192
|
+
y={0}
|
|
193
|
+
width={areaWidth}
|
|
194
|
+
height={areaHeight}
|
|
195
|
+
color={backgroundColor}
|
|
196
|
+
/>
|
|
197
|
+
)}
|
|
198
|
+
|
|
199
|
+
{/* Image layer - render on top of background if exists */}
|
|
200
|
+
{loadedImg && (
|
|
201
|
+
<Image
|
|
202
|
+
image={loadedImg}
|
|
203
|
+
fit="contain"
|
|
204
|
+
x={0}
|
|
205
|
+
y={0}
|
|
206
|
+
width={areaWidth}
|
|
207
|
+
height={areaHeight}
|
|
208
|
+
/>
|
|
209
|
+
)}
|
|
210
|
+
|
|
211
|
+
{/* Text layer - always on top */}
|
|
212
|
+
{loadedFont && textMetrics && text && (
|
|
213
|
+
<Text
|
|
214
|
+
x={textMetrics.x}
|
|
215
|
+
y={textMetrics.y}
|
|
216
|
+
text={text}
|
|
217
|
+
color={textFontColor}
|
|
218
|
+
font={loadedFont}
|
|
219
|
+
/>
|
|
220
|
+
)}
|
|
221
|
+
</Group>
|
|
222
|
+
);
|
|
223
|
+
};
|
|
224
|
+
|
|
176
225
|
return (
|
|
177
226
|
<GestureHandlerRootView
|
|
178
227
|
style={{ justifyContent: "center", alignContent: "center" }}
|
|
@@ -208,53 +257,7 @@ const ScratchCard: React.FC<ScratchCardProps> = ({
|
|
|
208
257
|
</Group>
|
|
209
258
|
}
|
|
210
259
|
>
|
|
211
|
-
{
|
|
212
|
-
<Image
|
|
213
|
-
image={loadedImg}
|
|
214
|
-
fit="cover"
|
|
215
|
-
x={0}
|
|
216
|
-
y={0}
|
|
217
|
-
width={areaWidth}
|
|
218
|
-
height={areaHeight}
|
|
219
|
-
/>
|
|
220
|
-
) : gradient ? (
|
|
221
|
-
<Group>
|
|
222
|
-
<LinearGradient
|
|
223
|
-
start={gradient.start ?? { x: 0, y: 0 }}
|
|
224
|
-
end={gradient.end ?? { x: areaWidth, y: areaHeight }}
|
|
225
|
-
colors={gradient.colors}
|
|
226
|
-
></LinearGradient>
|
|
227
|
-
<Rect x={0} y={0} width={areaWidth} height={areaHeight} />
|
|
228
|
-
{loadedFont && textMetrics && text ? (
|
|
229
|
-
<Text
|
|
230
|
-
x={textMetrics.x}
|
|
231
|
-
y={textMetrics.y}
|
|
232
|
-
text={text}
|
|
233
|
-
color={textFontColor}
|
|
234
|
-
font={loadedFont}
|
|
235
|
-
/>
|
|
236
|
-
) : null}
|
|
237
|
-
</Group>
|
|
238
|
-
) : (
|
|
239
|
-
<Group>
|
|
240
|
-
<Rect
|
|
241
|
-
x={0}
|
|
242
|
-
y={0}
|
|
243
|
-
width={areaWidth}
|
|
244
|
-
height={areaHeight}
|
|
245
|
-
color={backgroundColor}
|
|
246
|
-
/>
|
|
247
|
-
{loadedFont && textMetrics && text ? (
|
|
248
|
-
<Text
|
|
249
|
-
x={textMetrics.x}
|
|
250
|
-
y={textMetrics.y}
|
|
251
|
-
text={text}
|
|
252
|
-
color={textFontColor}
|
|
253
|
-
font={loadedFont}
|
|
254
|
-
/>
|
|
255
|
-
) : null}
|
|
256
|
-
</Group>
|
|
257
|
-
)}
|
|
260
|
+
{renderScratchContent()}
|
|
258
261
|
</Mask>
|
|
259
262
|
</Canvas>
|
|
260
263
|
</GestureDetector>
|
|
@@ -287,4 +290,4 @@ const styles = StyleSheet.create({
|
|
|
287
290
|
},
|
|
288
291
|
});
|
|
289
292
|
|
|
290
|
-
export default ScratchCard;
|
|
293
|
+
export default ScratchCard;
|
package/src/index.ts
CHANGED
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
|
|
4
4
|
// import App from "./app";
|
|
5
5
|
// import { I18nManager } from "react-native";
|
|
6
|
-
// I18nManager.allowRTL(
|
|
7
|
-
// I18nManager.forceRTL(
|
|
6
|
+
// I18nManager.allowRTL(true);
|
|
7
|
+
// I18nManager.forceRTL(true);
|
|
8
8
|
// registerRootComponent(App);
|
|
9
9
|
|
|
10
10
|
export * from "./theme";
|