-
-
Notifications
You must be signed in to change notification settings - Fork 780
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* chore: updated dependencies * refactor: updated ReText view for web * chore: added cursor for handle container * chore: updated expo version for example project * feat: added scrollable component for web * feat: added gesture and scroll handler for web * chore: added getRefNativeTag for web * feat: rewrite gesture apis with gesture handler 2 (#1126) * chore: updated dependencies * feat: rewrite the gesture api with gh2 * fix(#1119): fixed race condition between onmount and keyboard animations * fix: update ref handler for web * chore: removed unused component * chore: updated expo * fix: detached example on web
- Loading branch information
Showing
24 changed files
with
914 additions
and
112 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,121 @@ | ||
<!DOCTYPE html> | ||
<html lang="%LANG_ISO_CODE%"> | ||
<head> | ||
<meta charset="utf-8" /> | ||
<meta httpEquiv="X-UA-Compatible" content="IE=edge" /> | ||
<!-- | ||
This viewport works for phones with notches. | ||
It's optimized for gestures by disabling global zoom. | ||
--> | ||
<meta | ||
name="viewport" | ||
content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1.00001, viewport-fit=cover" | ||
/> | ||
<meta name="theme-color" content="#fff" media="(prefers-color-scheme: light)"> | ||
<meta name="theme-color" content="#000" media="(prefers-color-scheme: dark)"> | ||
<title>%WEB_TITLE%</title> | ||
<style> | ||
/** | ||
* Extend the react-native-web reset: | ||
* https://github.com/necolas/react-native-web/blob/master/packages/react-native-web/src/exports/StyleSheet/initialRules.js | ||
*/ | ||
html, | ||
body, | ||
#root { | ||
width: 100%; | ||
/* To smooth any scrolling behavior */ | ||
-webkit-overflow-scrolling: touch; | ||
margin: 0px; | ||
padding: 0px; | ||
/* Allows content to fill the viewport and go beyond the bottom */ | ||
min-height: 100%; | ||
background-color: #000; | ||
} | ||
#root { | ||
flex-shrink: 0; | ||
flex-basis: auto; | ||
flex-grow: 1; | ||
display: flex; | ||
flex: 1; | ||
background-color: #000; | ||
} | ||
|
||
html { | ||
scroll-behavior: smooth; | ||
/* Prevent text size change on orientation change https://gist.github.com/tfausak/2222823#file-ios-8-web-app-html-L138 */ | ||
-webkit-text-size-adjust: 100%; | ||
height: calc(100% + env(safe-area-inset-top)); | ||
} | ||
|
||
body { | ||
display: flex; | ||
/* Allows you to scroll below the viewport; default value is visible */ | ||
overflow-y: auto; | ||
overscroll-behavior-y: none; | ||
text-rendering: optimizeLegibility; | ||
-webkit-font-smoothing: antialiased; | ||
-moz-osx-font-smoothing: grayscale; | ||
-ms-overflow-style: scrollbar; | ||
} | ||
/* Enable for apps that support dark-theme */ | ||
/*@media (prefers-color-scheme: dark) { | ||
body { | ||
background-color: black; | ||
} | ||
}*/ | ||
</style> | ||
</head> | ||
|
||
<body> | ||
<!-- | ||
A generic no script element with a reload button and a message. | ||
Feel free to customize this however you'd like. | ||
--> | ||
<noscript> | ||
<form | ||
action="" | ||
style=" | ||
background-color: #fff; | ||
position: fixed; | ||
top: 0; | ||
left: 0; | ||
right: 0; | ||
bottom: 0; | ||
z-index: 9999; | ||
" | ||
> | ||
<div | ||
style=" | ||
font-size: 18px; | ||
font-family: Helvetica, sans-serif; | ||
line-height: 24px; | ||
margin: 10%; | ||
width: 80%; | ||
" | ||
> | ||
<p>Oh no! It looks like JavaScript is not enabled in your browser.</p> | ||
<p style="margin: 20px 0"> | ||
<button | ||
type="submit" | ||
style=" | ||
background-color: #4630eb; | ||
border-radius: 100px; | ||
border: none; | ||
box-shadow: none; | ||
color: #fff; | ||
cursor: pointer; | ||
font-weight: bold; | ||
line-height: 20px; | ||
padding: 6px 16px; | ||
" | ||
> | ||
Reload | ||
</button> | ||
</p> | ||
</div> | ||
</form> | ||
</noscript> | ||
<!-- The root element for your Expo app. --> | ||
<div id="root"></div> | ||
</body> | ||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
import React, { useRef } from 'react'; | ||
import { TextProps as RNTextProps, TextInput } from 'react-native'; | ||
import Animated, { | ||
useAnimatedReaction, | ||
useDerivedValue, | ||
} from 'react-native-reanimated'; | ||
|
||
interface TextProps { | ||
text: string; | ||
value: Animated.SharedValue<number | boolean> | number; | ||
style?: Animated.AnimateProps<RNTextProps>['style']; | ||
} | ||
|
||
const AnimatedTextInput = Animated.createAnimatedComponent(TextInput); | ||
|
||
const ReText = (props: TextProps) => { | ||
const { text, value: _providedValue, style } = { style: {}, ...props }; | ||
const textRef = useRef<TextInput>(null); | ||
|
||
const providedValue = useDerivedValue(() => { | ||
const value = | ||
typeof _providedValue === 'number' | ||
? _providedValue | ||
: typeof _providedValue.value === 'number' | ||
? _providedValue.value.toFixed(2) | ||
: _providedValue.value; | ||
|
||
return `${text}: ${value}`; | ||
}); | ||
|
||
//region effects | ||
useAnimatedReaction( | ||
() => providedValue.value, | ||
result => { | ||
textRef.current?.setNativeProps({ | ||
text: result, | ||
}); | ||
} | ||
); | ||
//endregion | ||
|
||
return ( | ||
<AnimatedTextInput | ||
ref={textRef} | ||
underlineColorAndroid="transparent" | ||
editable={false} | ||
value={providedValue.value} | ||
style={style} | ||
/> | ||
); | ||
}; | ||
|
||
export default ReText; |
Oops, something went wrong.