mirror of
https://github.com/ecency/ecency-mobile.git
synced 2024-12-23 21:35:04 +03:00
Merge pull request #2094 from ecency/nt/native-post
WIP - Nt/native post
This commit is contained in:
commit
00685cc91a
@ -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>
|
||||
);
|
||||
};
|
||||
|
@ -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}
|
||||
|
||||
/>
|
||||
)
|
||||
|
Loading…
Reference in New Issue
Block a user