mirror of
https://github.com/ecency/ecency-mobile.git
synced 2024-12-23 13:22:02 +03:00
Merge pull request #2096 from ecency/nt/native-post-render
WIP - Nt/native post render
This commit is contained in:
commit
cb0e40cbc8
@ -3,15 +3,11 @@ import { Dimensions, Linking, Modal, PermissionsAndroid, Platform, View } from '
|
||||
import CameraRoll from '@react-native-community/cameraroll';
|
||||
import { withNavigation } from 'react-navigation';
|
||||
import { useIntl, injectIntl } from 'react-intl';
|
||||
import AutoHeightWebView from 'react-native-autoheight-webview';
|
||||
import EStyleSheet from 'react-native-extended-stylesheet';
|
||||
import get from 'lodash/get';
|
||||
import ImageViewer from 'react-native-image-zoom-viewer';
|
||||
import RNFetchBlob from 'rn-fetch-blob';
|
||||
import ActionSheetView from 'react-native-actions-sheet';
|
||||
import { connect } from 'react-redux';
|
||||
import { customBodyScript } from './config';
|
||||
import { PostPlaceHolder, CommentPlaceHolder } from '../../../basicUIElements';
|
||||
|
||||
// Services and Actions
|
||||
import { writeToClipboard } from '../../../../utils/clipboard';
|
||||
@ -28,16 +24,7 @@ import { PostHtmlRenderer } from '../../..';
|
||||
|
||||
const WIDTH = Dimensions.get('window').width;
|
||||
|
||||
const PostBody = ({
|
||||
navigation,
|
||||
body,
|
||||
commentDepth,
|
||||
isComment,
|
||||
handleOnUserPress,
|
||||
handleOnPostPress,
|
||||
dispatch,
|
||||
onLoadEnd,
|
||||
}) => {
|
||||
const PostBody = ({ navigation, body, dispatch, onLoadEnd }) => {
|
||||
const [isImageModalOpen, setIsImageModalOpen] = useState(false);
|
||||
|
||||
const [postImages, setPostImages] = useState([]);
|
||||
@ -58,77 +45,6 @@ const PostBody = ({
|
||||
}
|
||||
}, [body]);
|
||||
|
||||
// const _handleOnLinkPress = (event) => {
|
||||
// if ((!event && !get(event, 'nativeEvent.data'), false)) {
|
||||
// return;
|
||||
// }
|
||||
|
||||
// try {
|
||||
// let data = {};
|
||||
// try {
|
||||
// data = JSON.parse(get(event, 'nativeEvent.data'));
|
||||
// } catch (error) {
|
||||
// data = {};
|
||||
// }
|
||||
|
||||
// const {
|
||||
// type,
|
||||
// href,
|
||||
// images,
|
||||
// image,
|
||||
// author,
|
||||
// category,
|
||||
// permlink,
|
||||
// tag,
|
||||
// filter,
|
||||
// proposal,
|
||||
// videoHref,
|
||||
// } = data;
|
||||
|
||||
// switch (type) {
|
||||
// case '_external':
|
||||
// case 'markdown-external-link':
|
||||
// setSelectedLink(href);
|
||||
// actionLink.current.show();
|
||||
// break;
|
||||
// case 'markdown-author-link':
|
||||
// if (!handleOnUserPress) {
|
||||
// _handleOnUserPress(author);
|
||||
// } else {
|
||||
// handleOnUserPress(author);
|
||||
// }
|
||||
// break;
|
||||
// case 'markdown-post-link':
|
||||
// if (!handleOnPostPress) {
|
||||
// _handleOnPostPress(permlink, author);
|
||||
// } else {
|
||||
// handleOnPostPress(permlink, author);
|
||||
// }
|
||||
// break;
|
||||
// case 'markdown-tag-link':
|
||||
// _handleTagPress(tag, filter);
|
||||
// break;
|
||||
// case 'markdown-witnesses-link':
|
||||
// break;
|
||||
// case 'markdown-proposal-link':
|
||||
// break;
|
||||
// case 'markdown-video-link-youtube':
|
||||
// _handleYoutubePress(tag);
|
||||
// break;
|
||||
// case 'markdown-video-link':
|
||||
// break;
|
||||
// case 'image':
|
||||
// setPostImages(images);
|
||||
// setSelectedImage(image);
|
||||
// actionImage.current.show();
|
||||
// break;
|
||||
|
||||
// default:
|
||||
// break;
|
||||
// }
|
||||
// } catch (error) {}
|
||||
// };
|
||||
|
||||
const _handleYoutubePress = (embedUrl) => {
|
||||
const videoId = getYoutubeId(embedUrl);
|
||||
if (videoId && youtubePlayerRef.current) {
|
||||
@ -338,130 +254,6 @@ const PostBody = ({
|
||||
}
|
||||
};
|
||||
|
||||
// const customStyle = `
|
||||
// * {
|
||||
// color: ${EStyleSheet.value('$primaryBlack')};
|
||||
// font-family: Roboto, sans-serif;
|
||||
// max-width: 100%;
|
||||
// line-height: 140%;
|
||||
// overflow-wrap: break-word;
|
||||
// word-wrap: break-word;
|
||||
|
||||
// -ms-word-break: break-all;
|
||||
// word-break: break-all;
|
||||
// word-break: break-word;
|
||||
|
||||
// -ms-hyphens: auto;
|
||||
// -moz-hyphens: auto;
|
||||
// -webkit-hyphens: auto;
|
||||
// hyphens: auto;
|
||||
// }
|
||||
// body {
|
||||
// color: ${EStyleSheet.value('$primaryBlack')};
|
||||
// font-size: 17;
|
||||
// }
|
||||
// h1 {
|
||||
// font-size: 20;
|
||||
// }
|
||||
// a {
|
||||
// color: ${EStyleSheet.value('$primaryBlue')};
|
||||
// cursor: pointer;
|
||||
// margin-right: 5;
|
||||
// }
|
||||
// img {
|
||||
// align-self: 'center';
|
||||
// max-width: 100%;
|
||||
// }
|
||||
// center {
|
||||
// text-align: 'center';
|
||||
// align-items: 'center';
|
||||
// justify-content: 'center';
|
||||
// }
|
||||
// table {
|
||||
// table-layout: fixed;
|
||||
// width: 100%;
|
||||
// }
|
||||
// th {
|
||||
// flex: 1;
|
||||
// justify-content: 'center';
|
||||
// font-weight: 'bold';
|
||||
// color: ${EStyleSheet.value('$primaryBlack')};
|
||||
// font-size: 14;
|
||||
// padding: 5;
|
||||
// }
|
||||
// tr {
|
||||
// background-color: ${EStyleSheet.value('$darkIconColor')};
|
||||
// flex-direction: 'row';
|
||||
// }
|
||||
// td {
|
||||
// border-width: 0.5;
|
||||
// border-color: ${EStyleSheet.value('$tableBorderColor')};
|
||||
// flex: 1;
|
||||
// padding: 10;
|
||||
// background-color: ${EStyleSheet.value('$tableTrColor')};
|
||||
// }
|
||||
// blockquote {
|
||||
// border-left-width: 5;
|
||||
// border-left-style: solid;
|
||||
// border-color: ${EStyleSheet.value('$darkIconColor')};
|
||||
// margin-left: 5;
|
||||
// padding-left: 5;
|
||||
// }
|
||||
// code {
|
||||
// background-color: ${EStyleSheet.value('$darkIconColor')};
|
||||
// font-family: ${EStyleSheet.value('$editorFont')};
|
||||
// }
|
||||
// center {
|
||||
// text-align: 'center';
|
||||
// align-items: 'center';
|
||||
// justify-content: 'center';
|
||||
// }
|
||||
// .markdown-video-link {
|
||||
// max-width: 100%;
|
||||
// position: relative;
|
||||
// }
|
||||
// .markdown-video-play {
|
||||
// position: absolute;
|
||||
// width: 100px;
|
||||
// height: 100px;
|
||||
// background: url('') no-repeat center center;
|
||||
// z-index: 20;
|
||||
// opacity: 0.9;
|
||||
// left: 50%;
|
||||
// top: 50%;
|
||||
// margin-top: -100px;
|
||||
// transform: translateX(-50%) translateY(-50%);
|
||||
// -webkit-transform: translateX(-50%) translateY(-50%);
|
||||
// -moz-transform: translateX(-50%) translateY(-50%);
|
||||
// }
|
||||
|
||||
// iframe {
|
||||
// width: 100%;
|
||||
// height: 240px;
|
||||
// }
|
||||
|
||||
// .phishy {
|
||||
// display: inline;
|
||||
// color: red;
|
||||
// }
|
||||
|
||||
// .text-justify {
|
||||
// text-align: justify;
|
||||
// }
|
||||
|
||||
// .pull-left {
|
||||
// margin-right: 10px;
|
||||
// padding-right: 10px;
|
||||
// float: left;
|
||||
// }
|
||||
|
||||
// .pull-right {
|
||||
// margin-right: 10px;
|
||||
// padding-right: 10px;
|
||||
// float: right;
|
||||
// }
|
||||
// `;
|
||||
|
||||
const _onElementIsImage = (imgUrl) => {
|
||||
if (postImages.indexOf(imgUrl) == -1) {
|
||||
postImages.push(imgUrl);
|
||||
@ -483,7 +275,7 @@ const PostBody = ({
|
||||
<Fragment>
|
||||
<Modal visible={isImageModalOpen} transparent={true}>
|
||||
<ImageViewer
|
||||
imageUrls={postImages}
|
||||
imageUrls={postImages.map((url) => ({ url }))}
|
||||
enableSwipeDown
|
||||
onCancel={() => setIsImageModalOpen(false)}
|
||||
onClick={() => setIsImageModalOpen(false)}
|
||||
@ -531,26 +323,6 @@ const PostBody = ({
|
||||
handleLinkPress(index);
|
||||
}}
|
||||
/>
|
||||
|
||||
{/* {isLoading && (isComment ? <CommentPlaceHolder /> : <PostPlaceHolder />)} */}
|
||||
{/* <AutoHeightWebView
|
||||
source={{ html }}
|
||||
allowsFullscreenVideo={true}
|
||||
style={{
|
||||
width: isComment ? WIDTH - (32 + 34 * (commentDepth % 6)) : WIDTH - 32,
|
||||
}}
|
||||
customStyle={customStyle}
|
||||
onMessage={_handleOnLinkPress}
|
||||
customScript={customBodyScript}
|
||||
startInLoadingState={true}
|
||||
renderLoading={() => (isComment ? <CommentPlaceHolder /> : <PostPlaceHolder />)}
|
||||
onShouldStartLoadWithRequest={false}
|
||||
scrollEnabled={false}
|
||||
scalesPageToFit={false}
|
||||
zoomable={false}
|
||||
onLoadEnd={_handleLoadEnd}
|
||||
mediaPlaybackRequiresUserAction={true}
|
||||
/> */}
|
||||
<View>
|
||||
<PostHtmlRenderer
|
||||
body={html}
|
||||
|
@ -178,6 +178,30 @@ export const PostHtmlRenderer = memo(({
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* the para renderer is designd to remove margins from para
|
||||
* if it's a direct child of li tag as the added margin causes
|
||||
* a weired misalignment of bullet and content
|
||||
* @returns Default Renderer
|
||||
*/
|
||||
const _paraRenderer = ({
|
||||
TDefaultRenderer,
|
||||
...props
|
||||
}:CustomRendererProps<TNode>) => {
|
||||
|
||||
props.style = props.tnode.parent.tagName === 'li'
|
||||
? styles.pLi
|
||||
: styles.p
|
||||
|
||||
return (
|
||||
<TDefaultRenderer
|
||||
{...props}
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
return (
|
||||
<RenderHTML
|
||||
@ -194,10 +218,11 @@ export const PostHtmlRenderer = memo(({
|
||||
a:styles.a,
|
||||
img:styles.img,
|
||||
th:styles.th,
|
||||
tr:styles.tr,
|
||||
tr:{...styles.tr, width:contentWidth}, //center tag causes tr to have 0 width if not exclusivly set, contentWidth help avoid that
|
||||
td:styles.td,
|
||||
blockquote:styles.blockquote,
|
||||
code:styles.code,
|
||||
li:styles.li,
|
||||
p:styles.p,
|
||||
table:styles.table,
|
||||
}}
|
||||
@ -207,6 +232,7 @@ export const PostHtmlRenderer = memo(({
|
||||
renderers={{
|
||||
img:_imageRenderer,
|
||||
a:_anchorRenderer,
|
||||
p:_paraRenderer
|
||||
}}
|
||||
onHTMLLoaded={onLoaded && onLoaded}
|
||||
defaultTextProps={{
|
||||
|
@ -14,7 +14,16 @@ export default EStyleSheet.create({
|
||||
} as TextStyle,
|
||||
p:{
|
||||
marginTop:6,
|
||||
marginBottom:6
|
||||
marginBottom:6,
|
||||
flexDirection:'row',
|
||||
alignItems:'center',
|
||||
justifyContent:'center',
|
||||
flexWrap:'wrap'
|
||||
|
||||
} as TextStyle,
|
||||
pLi:{
|
||||
marginTop:0,
|
||||
marginBottom:0
|
||||
} as TextStyle,
|
||||
a:{
|
||||
color: '$primaryBlue'
|
||||
@ -37,7 +46,6 @@ export default EStyleSheet.create({
|
||||
tr:{
|
||||
backgroundColor:'$darkIconColor',
|
||||
flexDirection:'row',
|
||||
|
||||
} as ViewStyle,
|
||||
td:{
|
||||
flex:1,
|
||||
@ -50,6 +58,9 @@ export default EStyleSheet.create({
|
||||
table:{
|
||||
width: '100%',
|
||||
} as ViewStyle,
|
||||
li:{
|
||||
marginBottom:12
|
||||
} as ViewStyle,
|
||||
blockquote: {
|
||||
borderLeftWidth: 5,
|
||||
borderStyle:'solid',
|
||||
|
@ -235,7 +235,6 @@ const PostDisplayView = ({
|
||||
<Text style={styles.footerName}>{` ${author || post.author} `}</Text>
|
||||
{formatedTime}
|
||||
</Text>
|
||||
{/* {isPostEnd && this._getTabBar()} */}
|
||||
</View>
|
||||
)}
|
||||
</View>
|
||||
|
Loading…
Reference in New Issue
Block a user