diff --git a/src/config/locales/en-US.json b/src/config/locales/en-US.json
index 6656bf34f..4ff2ebc33 100644
--- a/src/config/locales/en-US.json
+++ b/src/config/locales/en-US.json
@@ -65,6 +65,7 @@
"pincode": "PIN code",
"reset": "Reset",
"nsfw_content": "NSFW Content",
+ "default_footer": "Default Footer",
"nsfw": {
"always_show": "Always show",
"always_hide": "Always hide",
diff --git a/src/realm/realm.js b/src/realm/realm.js
index 93a67d04d..5313b38df 100644
--- a/src/realm/realm.js
+++ b/src/realm/realm.js
@@ -45,13 +45,14 @@ const draftSchema = {
const settingsSchema = {
name: SETTINGS_SCHEMA,
properties: {
- language: { type: 'string', default: null },
- isDarkTheme: { type: 'bool', default: false },
currency: { type: 'string', default: null },
+ isDarkTheme: { type: 'bool', default: false },
+ isDefaultFooter: { type: 'bool', default: true },
+ language: { type: 'string', default: null },
notification: { type: 'bool', default: true },
+ nsfw: { type: 'string', default: null },
server: { type: 'string', default: null },
upvotePercent: { type: 'string', default: null },
- nsfw: { type: 'string', default: null },
},
};
@@ -344,6 +345,17 @@ export const setTheme = isDarkTheme => new Promise((resolve, reject) => {
}
});
+export const setDefaultFooter = isDefaultFooter => new Promise((resolve, reject) => {
+ try {
+ realm.write(() => {
+ settings[0].isDefaultFooter = isDefaultFooter;
+ resolve(true);
+ });
+ } catch (error) {
+ reject(error);
+ }
+});
+
export const setUpvotePercent = percent => new Promise((resolve, reject) => {
try {
realm.write(() => {
diff --git a/src/redux/actions/applicationActions.js b/src/redux/actions/applicationActions.js
index b539dce52..a70389e87 100644
--- a/src/redux/actions/applicationActions.js
+++ b/src/redux/actions/applicationActions.js
@@ -5,6 +5,7 @@ import {
CLOSE_PIN_CODE_MODAL,
IS_CONNECTED,
IS_DARK_THEME,
+ IS_DEFAULT_FOOTER,
IS_LOGIN_DONE,
IS_NOTIFICATION_OPEN,
LOGIN,
@@ -14,8 +15,8 @@ import {
SET_API,
SET_CURRENCY,
SET_LANGUAGE,
- SET_UPVOTE_PERCENT,
SET_NSFW,
+ SET_UPVOTE_PERCENT,
} from '../constants/constants';
export const login = payload => ({
@@ -83,6 +84,11 @@ export const setNsfw = payload => ({
type: SET_NSFW,
});
+export const isDefaultFooter = payload => ({
+ payload,
+ type: IS_DEFAULT_FOOTER,
+});
+
/**
* MW
*/
diff --git a/src/redux/constants/constants.js b/src/redux/constants/constants.js
index 17015c5ba..5d196d439 100644
--- a/src/redux/constants/constants.js
+++ b/src/redux/constants/constants.js
@@ -11,6 +11,7 @@ export const IS_DARK_THEME = 'IS_DARK_THEME';
export const IS_LOGGED_IN = 'IS_LOGGED_IN';
export const IS_LOGIN_DONE = 'IS_LOGIN_DONE';
export const IS_NOTIFICATION_OPEN = 'IS_NOTIFICATION_OPEN';
+export const IS_DEFAULT_FOOTER = 'IS_DEFAULT_FOOTER';
export const LOGIN = 'LOGIN';
export const LOGOUT = 'LOGOUT';
export const LOGOUT_DONE = 'LOGOUT_DONE';
diff --git a/src/redux/reducers/applicationReducer.js b/src/redux/reducers/applicationReducer.js
index bb60404cd..f20cd0c30 100644
--- a/src/redux/reducers/applicationReducer.js
+++ b/src/redux/reducers/applicationReducer.js
@@ -3,6 +3,7 @@ import {
CLOSE_PIN_CODE_MODAL,
IS_CONNECTED,
IS_DARK_THEME,
+ IS_DEFAULT_FOOTER,
IS_LOGIN_DONE,
IS_NOTIFICATION_OPEN,
LOGIN,
@@ -12,8 +13,8 @@ import {
SET_API,
SET_CURRENCY,
SET_LANGUAGE,
- SET_UPVOTE_PERCENT,
SET_NSFW,
+ SET_UPVOTE_PERCENT,
} from '../constants/constants';
const initialState = {
@@ -26,6 +27,7 @@ const initialState = {
isActive: false,
isConnected: true, // internet connectivity
isDarkTheme: false,
+ isDefaultFooter: true,
isLoggedIn: false, // Has any logged in user.
isLoginDone: false,
isLogingOut: false,
@@ -107,6 +109,10 @@ export default function (state = initialState, action) {
return Object.assign({}, state, {
nsfw: action.payload,
});
+ case IS_DEFAULT_FOOTER:
+ return Object.assign({}, state, {
+ isDefaultFooter: action.payload,
+ });
default:
return state;
}
diff --git a/src/screens/application/container/applicationContainer.js b/src/screens/application/container/applicationContainer.js
index 665536a6e..ccdb6159f 100644
--- a/src/screens/application/container/applicationContainer.js
+++ b/src/screens/application/container/applicationContainer.js
@@ -39,6 +39,7 @@ import {
setAuthStatus,
removeSCAccount,
setExistUser,
+ setDefaultFooter,
} from '../../../realm/realm';
import { getUser } from '../../../providers/steem/dsteem';
import { setPushToken } from '../../../providers/esteem/esteem';
@@ -247,6 +248,7 @@ class ApplicationContainer extends Component {
if (response.language !== '') dispatch(setLanguage(response.language));
if (response.server !== '') dispatch(setApi(response.server));
if (response.upvotePercent !== '') dispatch(setUpvotePercent(Number(response.upvotePercent)));
+ if (response.isDefaultFooter !== '') dispatch(setDefaultFooter(response.isDefaultFooter));
if (response.notification !== '') {
dispatch(isNotificationOpen(response.notification));
Push.setEnabled(response.notification);
diff --git a/src/screens/editor/container/editorContainer.js b/src/screens/editor/container/editorContainer.js
index d31fd9de8..59f18f08b 100644
--- a/src/screens/editor/container/editorContainer.js
+++ b/src/screens/editor/container/editorContainer.js
@@ -293,7 +293,7 @@ class EditorContainer extends Component {
_submitPost = async (fields) => {
const {
- navigation, currentAccount, pinCode, intl,
+ navigation, currentAccount, pinCode, intl, isDefaultFooter,
} = this.props;
if (currentAccount) {
@@ -533,9 +533,10 @@ class EditorContainer extends Component {
}
const mapStateToProps = state => ({
+ currentAccount: state.account.currentAccount,
+ isDefaultFooter: state.account.isDefaultFooter,
isLoggedIn: state.application.isLoggedIn,
pinCode: state.account.pin,
- currentAccount: state.account.currentAccount,
});
export default connect(mapStateToProps)(injectIntl(EditorContainer));
diff --git a/src/screens/settings/container/settingsContainer.js b/src/screens/settings/container/settingsContainer.js
index 4996886a5..bcc6beff4 100644
--- a/src/screens/settings/container/settingsContainer.js
+++ b/src/screens/settings/container/settingsContainer.js
@@ -7,23 +7,25 @@ import { Client } from 'dsteem';
// Realm
import {
- setTheme,
- setLanguage as setLanguage2DB,
- setCurrency as setCurrency2DB,
- setServer,
- setNotificationIsOpen,
getExistUser,
+ setCurrency as setCurrency2DB,
+ setDefaultFooter,
+ setLanguage as setLanguage2DB,
+ setNotificationIsOpen,
setNsfw as setNsfw2DB,
+ setServer,
+ setTheme,
} from '../../../realm/realm';
// Services and Actions
import {
- setLanguage,
- isNotificationOpen,
- setCurrency,
- setApi,
isDarkTheme,
+ isDefaultFooter,
+ isNotificationOpen,
openPinCodeModal,
+ setApi,
+ setCurrency,
+ setLanguage,
setNsfw,
} from '../../../redux/actions/applicationActions';
import { toastNotification } from '../../../redux/actions/uiAction';
@@ -150,6 +152,11 @@ class SettingsContainer extends Component {
dispatch(isDarkTheme(action));
setTheme(action);
break;
+
+ case 'default_footer':
+ dispatch(isDefaultFooter(action));
+ // setDefaultFooter(action);
+ break;
default:
break;
}
@@ -231,14 +238,15 @@ class SettingsContainer extends Component {
}
const mapStateToProps = state => ({
- selectedLanguage: state.application.language,
+ isDarkTheme: state.application.isDarkTheme,
+ isDefaultFooter: state.application.isDefaultFooter,
+ isLoggedIn: state.application.isLoggedIn,
+ isNotificationSettingsOpen: state.application.isNotificationOpen,
+ nsfw: state.application.nsfw,
selectedApi: state.application.api,
selectedCurrency: state.application.currency,
- isDarkTheme: state.application.isDarkTheme,
- isNotificationSettingsOpen: state.application.isNotificationOpen,
- isLoggedIn: state.application.isLoggedIn,
+ selectedLanguage: state.application.language,
username: state.account.currentAccount && state.account.currentAccount.name,
- nsfw: state.application.nsfw,
});
export default connect(mapStateToProps)(SettingsContainer);
diff --git a/src/screens/settings/screen/settingsScreen.js b/src/screens/settings/screen/settingsScreen.js
index 4bda6243b..f9aa1f6d4 100644
--- a/src/screens/settings/screen/settingsScreen.js
+++ b/src/screens/settings/screen/settingsScreen.js
@@ -1,4 +1,4 @@
-import React, { PureComponent } from 'react';
+import React, { PureComponent, Fragment } from 'react';
import { ScrollView, View } from 'react-native';
import { injectIntl } from 'react-intl';
@@ -36,13 +36,14 @@ class SettingsScreen extends PureComponent {
handleOnChange,
intl,
isDarkTheme,
+ isDefaultFooter,
isLoggedIn,
isNotificationSettingsOpen,
+ nsfw,
selectedApi,
selectedCurrency,
selectedLanguage,
serverList,
- nsfw,
} = this.props;
return (
@@ -116,17 +117,28 @@ class SettingsScreen extends PureComponent {
handleOnChange={handleOnChange}
/>
{!!isLoggedIn && (
-
+
+
+
+
)}