Merge pull request #2094 from ecency/nt/native-post

WIP - Nt/native post
This commit is contained in:
Feruz M 2021-11-17 21:07:02 +05:00 committed by GitHub
commit 00685cc91a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 233 additions and 187 deletions

View File

@ -24,6 +24,7 @@ import VideoPlayerSheet from './videoPlayerSheet';
import { OptionsModal } from '../../../atoms';
import { isCommunity } from '../../../../utils/communityValidation';
import { GLOBAL_POST_FILTERS_VALUE } from '../../../../constants/options/filters';
import { PostHtmlRenderer } from '../../..';
const WIDTH = Dimensions.get('window').width;
@ -44,6 +45,7 @@ const PostBody = ({
const [selectedLink, setSelectedLink] = useState(null);
const [html, setHtml] = useState('');
const [youtubeVideoId, setYoutubeVideoId] = useState(null);
const [videoUrl, setVideoUrl] = useState(null);
const intl = useIntl();
const actionImage = useRef(null);
@ -56,76 +58,76 @@ const PostBody = ({
}
}, [body]);
const _handleOnLinkPress = (event) => {
if ((!event && !get(event, 'nativeEvent.data'), false)) {
return;
}
// 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 = {};
}
// 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;
// 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;
// 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) {}
};
// default:
// break;
// }
// } catch (error) {}
// };
const _handleYoutubePress = (embedUrl) => {
const videoId = getYoutubeId(embedUrl);
@ -135,6 +137,13 @@ const PostBody = ({
}
};
const _handleVideoPress = (embedUrl) => {
if (embedUrl && youtubePlayerRef.current) {
setVideoUrl(embedUrl);
youtubePlayerRef.current.setModalVisible(true);
}
};
const handleImagePress = (ind) => {
if (ind === 1) {
//open gallery mode
@ -329,129 +338,147 @@ 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;
// 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-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;
}
// -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%);
// }
.phishy {
display: inline;
color: red;
}
// iframe {
// width: 100%;
// height: 240px;
// }
.text-justify {
text-align: justify;
}
// .phishy {
// display: inline;
// color: red;
// }
.pull-left {
margin-right: 10px;
padding-right: 10px;
float: left;
}
// .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);
setPostImages(postImages);
}
};
const _handleSetSelectedLink = (link) => {
setSelectedLink(link);
actionLink.current.show();
};
const _handleSetSelectedImage = (imageLink) => {
setSelectedImage(imageLink);
actionImage.current.show();
};
.pull-right {
margin-right: 10px;
padding-right: 10px;
float: right;
}
`;
return (
<Fragment>
<Modal visible={isImageModalOpen} transparent={true}>
@ -471,9 +498,10 @@ const PostBody = ({
indicatorColor={EStyleSheet.value('$primaryWhiteLightBackground')}
onClose={() => {
setYoutubeVideoId(null);
setVideoUrl(null);
}}
>
<VideoPlayerSheet youtubeVideoId={youtubeVideoId} />
<VideoPlayerSheet youtubeVideoId={youtubeVideoId} videoUrl={videoUrl} />
</ActionSheetView>
<OptionsModal
@ -505,7 +533,7 @@ const PostBody = ({
/>
{/* {isLoading && (isComment ? <CommentPlaceHolder /> : <PostPlaceHolder />)} */}
<AutoHeightWebView
{/* <AutoHeightWebView
source={{ html }}
allowsFullscreenVideo={true}
style={{
@ -522,7 +550,22 @@ const PostBody = ({
zoomable={false}
onLoadEnd={_handleLoadEnd}
mediaPlaybackRequiresUserAction={true}
/>
/> */}
<View>
<PostHtmlRenderer
body={html}
contentWidth={WIDTH - 32}
onLoaded={_handleLoadEnd}
onElementIsImage={_onElementIsImage}
setSelectedImage={_handleSetSelectedImage}
setSelectedLink={_handleSetSelectedLink}
handleOnPostPress={_handleOnPostPress}
handleOnUserPress={_handleOnUserPress}
handleTagPress={_handleTagPress}
handleVideoPress={_handleVideoPress}
handleYoutubePress={_handleYoutubePress}
/>
</View>
</Fragment>
);
};

View File

@ -8,6 +8,7 @@ import VideoThumb from "./videoThumb";
interface PostHtmlRendererProps {
contentWidth:number;
body:string;
onLoaded:()=>void;
setSelectedImage:(imgUrl:string)=>void;
setSelectedLink:(url:string)=>void;
onElementIsImage:(imgUrl:string)=>void;
@ -21,6 +22,7 @@ interface PostHtmlRendererProps {
export const PostHtmlRenderer = memo(({
contentWidth,
body,
onLoaded,
setSelectedImage,
setSelectedLink,
onElementIsImage,
@ -32,7 +34,7 @@ export const PostHtmlRenderer = memo(({
}:PostHtmlRendererProps) => {
//new renderer functions
body = body.replace('<center>', '<div class="text-center">').replace('</center>','</div>');
body = body.replace(/<center>/g, '<div class="text-center">').replace(/<\/center>/g,'</div>');
console.log("Comment body:", body);
@ -200,6 +202,7 @@ export const PostHtmlRenderer = memo(({
img:_imageRenderer,
a:_anchorRenderer,
}}
onHTMLLoaded={onLoaded && onLoaded}
/>
)