try post renderer on comments

This commit is contained in:
feruz 2020-01-10 08:49:47 +02:00
parent f88b3bd50f
commit 0b04684199

View File

@ -1,13 +1,20 @@
import React from 'react';
import { Dimensions, Linking, Alert, TouchableOpacity, Text } from 'react-native';
import { Dimensions, Linking, Alert, TouchableOpacity, Text, View } from 'react-native';
import { useIntl } from 'react-intl';
import HTML from '@esteemapp/react-native-render-html';
import { getParentsTagsRecursively } from '@esteemapp/react-native-render-html/src/HTMLUtils';
import AutoHeightWebView from 'react-native-autoheight-webview';
import EStyleSheet from 'react-native-extended-stylesheet';
import get from 'lodash/get';
import { navigate } from '../../../../navigation/service';
// Constants
import { default as ROUTES } from '../../../../constants/routeNames';
import DEFAULT_IMAGE from '../../../../assets/no_image.png';
import { CommentPlaceHolder } from '../../../basicUIElements';
import script from './config';
// Styles
import styles from './postBodyStyles';
@ -19,6 +26,7 @@ const CommentBody = ({
handleOnUserPress,
handleOnPostPress,
created,
commentDepth,
}) => {
const intl = useIntl();
@ -146,6 +154,22 @@ const CommentBody = ({
</Text>
);
}
if (passProps.parentWrapper === 'View') {
return (
<AutoHeightWebView
key={passProps.key}
source={{
html: passProps.html,
}}
allowsFullscreenVideo={true}
style={{ width: WIDTH - (32 + 29 * 1) }}
customScript={script.toString()}
startInLoadingState={true}
onShouldStartLoadWithRequest={false}
scrollEnabled={false}
/>
);
}
return (
<TouchableOpacity
key={passProps.key}
@ -163,8 +187,112 @@ const CommentBody = ({
const _initialDimensions = { width: WIDTH - 50, height: 80 };
const customStyle = `
* {
color: ${EStyleSheet.value('$primaryBlack')};
font-family: Roboto, sans-serif;
max-width: 100%;
}
body {
color: ${EStyleSheet.value('$primaryBlack')};
}
a {
color: ${EStyleSheet.value('$primaryBlue')};
cursor: pointer;
text-decoration: underline;
}
img {
align-self: 'center';
max-width: 100%;
}
center {
text-align: 'center';
align-items: 'center';
justify-content: 'center';
}
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')};
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;
}
.pull-right {
float: right;
}
.pull-left {
float: left;
}
.pull-left,
.pull-right {
max-width: calc(50% - 10px);
padding-left: 10px;
margin-bottom: 10px;
box-sizing: border-box;
}
.phishy {
display: inline;
color: red;
}
.text-justify {
text-align: justify;
text-justify: inter-word;
letter-spacing: 0px;
}
`;
return (
<HTML
/*<HTML
html={body}
onLinkPress={(evt, href, hrefAtr) => _handleOnLinkPress(evt, href, hrefAtr)}
containerStyle={styles.commentContainer}
@ -179,6 +307,20 @@ const CommentBody = ({
alterNode={_alterNode}
alterData={_alterData}
renderers={_customRenderer}
/>*/
<AutoHeightWebView
key={created.toString()}
source={{
html: body,
}}
allowsFullscreenVideo={true}
style={{ width: WIDTH - (32 + 29 * commentDepth) }}
customStyle={customStyle}
renderLoading={() => <CommentPlaceHolder />}
customScript={script.toString()}
startInLoadingState={true}
onShouldStartLoadWithRequest={false}
scrollEnabled={false}
/>
);
};