mirror of
https://github.com/ecency/ecency-mobile.git
synced 2024-12-22 21:01:31 +03:00
try post renderer on comments
This commit is contained in:
parent
f88b3bd50f
commit
0b04684199
@ -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}
|
||||
/>
|
||||
);
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user