Fix schedule post feature according to the updated endpoint

This commit is contained in:
Furkan Kılıç 2021-01-05 00:30:25 +03:00
parent 9dd3b06647
commit 776223aa95
12 changed files with 144 additions and 126 deletions

View File

@ -315,6 +315,8 @@ PODS:
- react-native-config/App (= 1.3.3) - react-native-config/App (= 1.3.3)
- react-native-config/App (1.3.3): - react-native-config/App (1.3.3):
- React - React
- react-native-date-picker (3.2.7):
- React-Core
- react-native-matomo-sdk (0.4.1): - react-native-matomo-sdk (0.4.1):
- MatomoTracker (~> 7) - MatomoTracker (~> 7)
- React (~> 0.60) - React (~> 0.60)
@ -446,6 +448,7 @@ DEPENDENCIES:
- React-jsinspector (from `../node_modules/react-native/ReactCommon/jsinspector`) - React-jsinspector (from `../node_modules/react-native/ReactCommon/jsinspector`)
- "react-native-cameraroll (from `../node_modules/@react-native-community/cameraroll`)" - "react-native-cameraroll (from `../node_modules/@react-native-community/cameraroll`)"
- react-native-config (from `../node_modules/react-native-config`) - react-native-config (from `../node_modules/react-native-config`)
- react-native-date-picker (from `../node_modules/react-native-date-picker`)
- react-native-matomo-sdk (from `../node_modules/react-native-matomo-sdk`) - react-native-matomo-sdk (from `../node_modules/react-native-matomo-sdk`)
- "react-native-netinfo (from `../node_modules/@react-native-community/netinfo`)" - "react-native-netinfo (from `../node_modules/@react-native-community/netinfo`)"
- react-native-receive-sharing-intent (from `../node_modules/react-native-receive-sharing-intent`) - react-native-receive-sharing-intent (from `../node_modules/react-native-receive-sharing-intent`)
@ -555,6 +558,8 @@ EXTERNAL SOURCES:
:path: "../node_modules/@react-native-community/cameraroll" :path: "../node_modules/@react-native-community/cameraroll"
react-native-config: react-native-config:
:path: "../node_modules/react-native-config" :path: "../node_modules/react-native-config"
react-native-date-picker:
:path: "../node_modules/react-native-date-picker"
react-native-matomo-sdk: react-native-matomo-sdk:
:path: "../node_modules/react-native-matomo-sdk" :path: "../node_modules/react-native-matomo-sdk"
react-native-netinfo: react-native-netinfo:
@ -668,6 +673,7 @@ SPEC CHECKSUMS:
React-jsinspector: fa0ecc501688c3c4c34f28834a76302233e29dc0 React-jsinspector: fa0ecc501688c3c4c34f28834a76302233e29dc0
react-native-cameraroll: e2917a5e62da9f10c3d525e157e25e694d2d6dfa react-native-cameraroll: e2917a5e62da9f10c3d525e157e25e694d2d6dfa
react-native-config: 9a061347e0136fdb32d43a34d60999297d672361 react-native-config: 9a061347e0136fdb32d43a34d60999297d672361
react-native-date-picker: 5b66e04e7ed02478feb77a41d254ba24f120f956
react-native-matomo-sdk: 025c54f92e1e26a4d0acee7c3f28cb0fc7e4729c react-native-matomo-sdk: 025c54f92e1e26a4d0acee7c3f28cb0fc7e4729c
react-native-netinfo: a53b00d949b6456913aaf507d9dba90c4008c611 react-native-netinfo: a53b00d949b6456913aaf507d9dba90c4008c611
react-native-receive-sharing-intent: feba0a332a07977549a85aa58b496eb44368366a react-native-receive-sharing-intent: feba0a332a07977549a85aa58b496eb44368366a

View File

@ -69,7 +69,7 @@
"react-native-autoheight-webview": "^1.5.2", "react-native-autoheight-webview": "^1.5.2",
"react-native-config": "luggit/react-native-config#master", "react-native-config": "luggit/react-native-config#master",
"react-native-dark-mode": "^0.2.2", "react-native-dark-mode": "^0.2.2",
"react-native-datepicker": "ecency/react-native-datepicker", "react-native-date-picker": "^3.2.7",
"react-native-extended-stylesheet": "^0.10.0", "react-native-extended-stylesheet": "^0.10.0",
"react-native-fast-image": "^8.3.2", "react-native-fast-image": "^8.3.2",
"react-native-gesture-handler": "^1.4.1", "react-native-gesture-handler": "^1.4.1",

View File

@ -80,4 +80,8 @@ export default EStyleSheet.create({
fontWeight: '500', fontWeight: '500',
width: '$deviceWidth / 1.4', width: '$deviceWidth / 1.4',
}, },
dateTimeModal: {
backgroundColor: '$primaryBackgroundColor',
alignItems: 'center',
},
}); });

View File

@ -3,6 +3,7 @@ import { View, Text, ActivityIndicator, SafeAreaView } from 'react-native';
import { injectIntl } from 'react-intl'; import { injectIntl } from 'react-intl';
import ActionSheet from 'react-native-actionsheet'; import ActionSheet from 'react-native-actionsheet';
import { useSelector } from 'react-redux'; import { useSelector } from 'react-redux';
import moment from 'moment';
// Components // Components
import { TextButton, Modal, BeneficiaryModal } from '../..'; import { TextButton, Modal, BeneficiaryModal } from '../..';
@ -48,6 +49,8 @@ const BasicHeaderView = ({
}) => { }) => {
const [isInputVisible, setIsInputVisible] = useState(false); const [isInputVisible, setIsInputVisible] = useState(false);
const [beneficiaryModal, setBeneficiaryModal] = useState(false); const [beneficiaryModal, setBeneficiaryModal] = useState(false);
const [showScheduleModal, setShowScheduleModal] = useState(false);
const [scheduledDate, setScheduledDate] = useState('');
const username = useSelector((state) => state.account.currentAccount.name); const username = useSelector((state) => state.account.currentAccount.name);
@ -78,7 +81,7 @@ const BasicHeaderView = ({
const _handleSettingMenuSelect = (index) => { const _handleSettingMenuSelect = (index) => {
switch (index) { switch (index) {
case 0: case 0:
scheduleRef.current.onPressDate(); setShowScheduleModal(true);
break; break;
case 1: case 1:
rewardMenuRef.current.show(); rewardMenuRef.current.show();
@ -123,9 +126,19 @@ const BasicHeaderView = ({
}; };
const _handleDatePickerChange = (datePickerValue) => { const _handleDatePickerChange = (datePickerValue) => {
if (handleDatePickerChange) { setScheduledDate(datePickerValue);
handleDatePickerChange(datePickerValue); };
const _onPressDone = () => {
let dateString = scheduledDate;
if (dateString === '') {
dateString = moment().format();
} }
setScheduledDate('');
handleDatePickerChange(dateString);
setShowScheduleModal(false);
}; };
return ( return (
@ -149,18 +162,11 @@ const BasicHeaderView = ({
disabled={disabled} disabled={disabled}
/> />
)} )}
<DateTimePicker
type="date-time"
onSubmit={_handleDatePickerChange}
disabled={!isFormValid}
ref={scheduleRef}
/>
{!isInputVisible && ( {!isInputVisible && (
<Text style={[title && styles.title, quickTitle && styles.quickTitle]}> <Text style={[title && styles.title, quickTitle && styles.quickTitle]}>
{quickTitle || title} {quickTitle || title}
</Text> </Text>
)} )}
{isHasDropdown && ( {isHasDropdown && (
<View> <View>
{dropdownComponent ? ( {dropdownComponent ? (
@ -264,6 +270,28 @@ const BasicHeaderView = ({
handleOnSaveBeneficiaries={_handleOnSaveBeneficiaries} handleOnSaveBeneficiaries={_handleOnSaveBeneficiaries}
/> />
</Modal> </Modal>
<Modal
isFullScreen={false}
isOpen={showScheduleModal}
isBottomModal
isTransparent
isRadius
coverScreen={false}
title={intl.formatMessage({ id: 'editor.schedule_modal_title' })}
hasRightText
rightText="Done"
onPressRightText={_onPressDone}
onBackdropPress={() => setShowScheduleModal(false)}
>
<SafeAreaView style={styles.dateTimeModal}>
<DateTimePicker
type="datetime"
onChanged={_handleDatePickerChange}
disabled={!isFormValid}
ref={scheduleRef}
/>
</SafeAreaView>
</Modal>
<ActionSheet <ActionSheet
ref={settingMenuRef} ref={settingMenuRef}
options={[ options={[

View File

@ -34,7 +34,7 @@ export default EStyleSheet.create({
alignSelf: 'center', alignSelf: 'center',
}, },
picker: { picker: {
width: 0, width: '$deviceWidth',
// marginLeft: 20, // marginLeft: 20,
}, },
}); });

View File

@ -1,7 +1,8 @@
import React, { useState, useRef, forwardRef } from 'react'; import React, { useState, useRef, forwardRef } from 'react';
import DatePicker from 'react-native-datepicker'; import { Platform } from 'react-native';
import DatePicker from 'react-native-date-picker';
import moment from 'moment'; import moment from 'moment';
import { useIntl } from 'react-intl'; import { FormattedDate, useIntl } from 'react-intl';
import useCombinedRefs from '../../../customHooks/useCombinedRefs'; import useCombinedRefs from '../../../customHooks/useCombinedRefs';
@ -11,89 +12,31 @@ import { Icon } from '../../icon';
// Styles // Styles
import styles from './dateTimePickerStyles'; import styles from './dateTimePickerStyles';
const DateTimePickerView = React.forwardRef(({ type, iconName, disabled, onSubmit }, ref) => { const DateTimePickerView = React.forwardRef(({ type, iconName, disabled, onChanged }, ref) => {
const [date, setDate] = useState(''); const [androidDate, setAndroidDate] = useState(moment(Date.now()));
const [time, setTime] = useState('');
let _type;
let _format;
let _minDate;
const intl = useIntl(); const _setDate = (date) => {
const innerRef = useRef(null); if (date) {
const datePickerRef = useCombinedRefs(ref, innerRef); if (Platform.OS === 'android') {
setAndroidDate(date);
if (type === 'date-time') {
_type = date ? 'time' : 'date';
_format = date ? 'HH:mm' : 'YYYY-MM-DD';
_minDate = date ? null : moment().format('YYYY-MM-DD');
} else {
_type = type;
_format = type === 'date' ? 'YYYY-MM-DD' : 'HH:mm';
_minDate = type === 'date' ? moment().format('YYYY-MM-DD') : null;
} }
const _initState = () => { const formattedDate = moment(date).format();
setDate('');
setTime('');
};
const _setValue = (setFunc, value) => { onChanged(formattedDate);
const _value = value === 'Invalid date' ? moment().format('HH:mm:ss') : value;
setFunc(_value);
let timePickerTimeout;
if (!time && !date) {
timePickerTimeout = setTimeout(() => {
datePickerRef.onPressDate();
}, 500);
} else {
clearTimeout(timePickerTimeout);
}
if (date && _value) {
const formatedDateTime = moment(`${date} ${_value}`, 'YYYY-MM-DD HH:mm').toISOString();
onSubmit(formatedDateTime);
_initState();
} }
}; };
return ( return (
<DatePicker <DatePicker
date={Platform.OS === 'android' && androidDate}
onDateChange={_setDate}
style={styles.picker} style={styles.picker}
mode={_type} minimumDate={Platform.OS === 'ios' ? new Date() : moment(Date.now())}
format={_format} androidVariant="iosClone"
minDate={_minDate} is24hourSource="device"
confirmBtnText={intl.formatMessage({
id: 'alert.confirm',
})}
cancelBtnText={intl.formatMessage({
id: 'alert.cancel',
})}
onDateChange={(_datePickerValue) => _setValue(!date ? setDate : setTime, _datePickerValue)}
hideText
is24Hour
ref={datePickerRef}
disabled={disabled}
customStyles={{
...styles,
}}
showIcon={false}
// iconComponent={
// // eslint-disable-next-line react/jsx-wrap-multilines
// <Icon
// style={{ ...styles.iconButton, ...styles.scheduleIcon }}
// size={20}
// iconType="MaterialIcons"
// name={iconName}
// />
// }
/> />
); );
}); });
DateTimePickerView.defaultProps = {
iconName: 'timer',
type: 'date',
};
export default DateTimePickerView; export default DateTimePickerView;

View File

@ -18,6 +18,7 @@ export default EStyleSheet.create({
flexDirection: 'row', flexDirection: 'row',
padding: 16, padding: 16,
justifyContent: 'center', justifyContent: 'center',
alignItems: 'center',
}, },
headerTitle: { headerTitle: {
color: '$primaryBlack', color: '$primaryBlack',
@ -41,4 +42,8 @@ export default EStyleSheet.create({
margin: 0, margin: 0,
backgroundColor: 'rgba(0,0,0,0.35)', backgroundColor: 'rgba(0,0,0,0.35)',
}, },
rightText: {
color: '$primaryBlack',
padding: 10,
},
}); });

View File

@ -1,5 +1,5 @@
import React, { PureComponent } from 'react'; import React, { PureComponent } from 'react';
import { View, Text, SafeAreaView } from 'react-native'; import { View, Text, TouchableOpacity } from 'react-native';
import ModalBox from 'react-native-modal'; import ModalBox from 'react-native-modal';
import { IconButton } from '../../iconButton'; import { IconButton } from '../../iconButton';
import styles from './modalStyles'; import styles from './modalStyles';
@ -50,6 +50,9 @@ export default class Modal extends PureComponent {
animationType = 'fade', animationType = 'fade',
isCloseButton, isCloseButton,
isBottomModal = false, isBottomModal = false,
hasRightText = false,
rightText,
onPressRightText,
} = this.props; } = this.props;
return ( return (
<ModalBox <ModalBox
@ -68,7 +71,11 @@ export default class Modal extends PureComponent {
> >
{title && ( {title && (
<View style={styles.modalHeader}> <View style={styles.modalHeader}>
<Text style={[styles.headerTitle, isCloseButton && { marginLeft: 50 }]}>{title}</Text> <Text
style={[styles.headerTitle, (isCloseButton || hasRightText) && { marginLeft: 50 }]}
>
{title}
</Text>
{isCloseButton && ( {isCloseButton && (
<IconButton <IconButton
style={styles.closeButton} style={styles.closeButton}
@ -78,6 +85,11 @@ export default class Modal extends PureComponent {
onPress={() => this._handleOnClose()} onPress={() => this._handleOnClose()}
/> />
)} )}
{hasRightText && (
<TouchableOpacity onPress={onPressRightText}>
<Text style={styles.rightText}>{rightText}</Text>
</TouchableOpacity>
)}
</View> </View>
)} )}
{children} {children}

View File

@ -297,7 +297,8 @@
"options": "Options", "options": "Options",
"my_blog": "My Blog", "my_blog": "My Blog",
"my_communities": "My Communities", "my_communities": "My Communities",
"top_communities": "Top Communities" "top_communities": "Top Communities",
"schedule_modal_title": "Schedule Post"
}, },
"pincode": { "pincode": {
"enter_text": "Enter PIN to unlock", "enter_text": "Enter PIN to unlock",

View File

@ -307,20 +307,18 @@ export const schedule = (
operationType, operationType,
upvote, upvote,
scheduleDate, scheduleDate,
options = null,
) => ) =>
api api
.post('/schedules', { .post('/schedules', {
username: user, username: user,
category: tags[0],
title, title,
permlink, permlink,
json: jsonStringify(json), meta: json,
tags,
body, body,
post_type: operationType,
upvote_this: upvote,
schedule: scheduleDate, schedule: scheduleDate,
chain: 'hive', options,
reblog: 0,
}) })
.then((resp) => resp.data); .then((resp) => resp.data);

View File

@ -336,6 +336,7 @@ class EditorContainer extends Component {
permlink, permlink,
fields, fields,
scheduleDate, scheduleDate,
jsonMeta,
}); });
} else { } else {
await postContent( await postContent(
@ -595,6 +596,17 @@ class EditorContainer extends Component {
_handleDatePickerChange = async (datePickerValue, fields) => { _handleDatePickerChange = async (datePickerValue, fields) => {
const { currentAccount, pinCode, intl } = this.props; const { currentAccount, pinCode, intl } = this.props;
if (fields.title === '' && fields.body === '') {
const timer = setTimeout(() => {
Alert.alert(
intl.formatMessage({
id: 'alert.fail',
}),
'Title and body can not be empty',
);
clearTimeout(timer);
}, 100);
} else {
const json = get(currentAccount, 'posting_json_metadata', ''); const json = get(currentAccount, 'posting_json_metadata', '');
let hasPostingPerm = false; let hasPostingPerm = false;
@ -620,21 +632,31 @@ class EditorContainer extends Component {
); );
}); });
} }
}
}; };
_setScheduledPost = (data) => { _setScheduledPost = (data) => {
const { dispatch, intl, currentAccount, navigation } = this.props; const { dispatch, intl, currentAccount, navigation } = this.props;
const { rewardType, beneficiaries } = this.state;
const options = makeOptions({
author: data.author,
permlink: data.permlink,
operationType: rewardType,
beneficiaries: beneficiaries,
});
schedule( schedule(
data.author, data.author,
data.fields.title, data.fields.title,
data.permlink, data.permlink,
'', data.jsonMeta,
data.fields.tags, data.fields.tags,
data.fields.body, data.fields.body,
'', '',
'', '',
data.scheduleDate, data.scheduleDate,
options,
) )
.then(() => { .then(() => {
this.setState({ this.setState({
@ -662,7 +684,7 @@ class EditorContainer extends Component {
}); });
}, 3000); }, 3000);
}) })
.catch(() => { .catch((err) => {
this.setState({ this.setState({
isPostSending: false, isPostSending: false,
}); });

View File

@ -6440,7 +6440,7 @@ mkdirp@~1.0.3:
resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e"
integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==
moment@^2.22.0, moment@^2.22.2: moment@^2.22.2:
version "2.27.0" version "2.27.0"
resolved "https://registry.yarnpkg.com/moment/-/moment-2.27.0.tgz#8bff4e3e26a236220dfe3e36de756b6ebaa0105d" resolved "https://registry.yarnpkg.com/moment/-/moment-2.27.0.tgz#8bff4e3e26a236220dfe3e36de756b6ebaa0105d"
integrity sha512-al0MUK7cpIcglMv3YF13qSgdAIqxHTO7brRtaz3DlSULbqfazqkc5kEjNrLDOM7fsjshoFIihnU8snrP7zUvhQ== integrity sha512-al0MUK7cpIcglMv3YF13qSgdAIqxHTO7brRtaz3DlSULbqfazqkc5kEjNrLDOM7fsjshoFIihnU8snrP7zUvhQ==
@ -7493,11 +7493,10 @@ react-native-dark-mode@^0.2.2:
events "^3.0.0" events "^3.0.0"
toolkit.ts "^0.0.2" toolkit.ts "^0.0.2"
react-native-datepicker@ecency/react-native-datepicker: react-native-date-picker@^3.2.7:
version "1.7.2" version "3.2.7"
resolved "https://codeload.github.com/ecency/react-native-datepicker/tar.gz/844955f20ede921e6a8b83d95c58167970f9279b" resolved "https://registry.yarnpkg.com/react-native-date-picker/-/react-native-date-picker-3.2.7.tgz#1708c2fc712c09ce6eaca007635a036dba4ca107"
dependencies: integrity sha512-7JXwnEF4TxST6+yKYzscCxx8BWQLBpNVxUmVYbaXkhdLSTO1QlypukVeQMZ9QtuRAhf4zs3NDiYqZDu9JdeGAA==
moment "^2.22.0"
react-native-extended-stylesheet@^0.10.0: react-native-extended-stylesheet@^0.10.0:
version "0.10.0" version "0.10.0"