diff --git a/src/components/postElements/body/view/postBodyView.js b/src/components/postElements/body/view/postBodyView.js
index ba4b7c97a..46416a559 100644
--- a/src/components/postElements/body/view/postBodyView.js
+++ b/src/components/postElements/body/view/postBodyView.js
@@ -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 (