Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[#157929923] add-badge-messages #979

Merged
merged 20 commits into from
May 20, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
4fa82d7
[#157929923] add-badge-messages
matgentili Apr 24, 2019
2c986b9
[#157929923]-add-badge-messages
matgentili Apr 24, 2019
1f775c1
[#157929923]-add-badge-messages
matgentili Apr 24, 2019
4f7653e
[#157929923] add-badge-messages
matgentili Apr 29, 2019
cc4db3a
[#157929923]-add-badge-message-tab
matgentili May 3, 2019
740cf3d
[#157929923]-add-badge-message-tab
matgentili May 13, 2019
3c3eee9
Merge branch 'master' into #157929923]-add-badge-message-tab
matgentili May 13, 2019
c6076fa
[#157929923]-add-badge-message-tab
matgentili May 13, 2019
d6c5379
Merge branch '#157929923]-add-badge-message-tab' of https://github.co…
matgentili May 13, 2019
c1c8ff7
[#157929923] add badge message tab
matgentili May 15, 2019
1e29f4f
[#157929923] add badge message tab
matgentili May 15, 2019
b5163eb
Merge branch 'master' into #157929923]-add-badge-message-tab
matgentili May 16, 2019
1715e8d
[#157929923] Add badge messages
matgentili May 20, 2019
99c794d
Merge branch 'master' into #157929923]-add-badge-message-tab
matgentili May 20, 2019
571cefb
[#157929923] Add badge messages tab
matgentili May 20, 2019
0e75fd4
Merge branch 'master' into #157929923]-add-badge-message-tab
matgentili May 20, 2019
31e64be
[#157929923] Add badge messages tab
matgentili May 20, 2019
cb0706a
Merge branch '#157929923]-add-badge-message-tab' of https://github.co…
matgentili May 20, 2019
c6c1a47
Merge branch 'master' into #157929923]-add-badge-message-tab
matgentili May 20, 2019
15f204f
Merge branch 'master' into #157929923]-add-badge-message-tab
francescopersico May 20, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
75 changes: 75 additions & 0 deletions ts/components/MessagesTabIcon.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
import { Badge, View } from "native-base";
import React from "react";
import { Platform, StyleSheet, Text } from "react-native";
import { connect } from "react-redux";
import { messagesUnreadSelector } from "../store/reducers/entities/messages";
import { GlobalState } from "../store/reducers/types";
import variables from "../theme/variables";
import IconFont from "./ui/IconFont";

type OwnProps = {
color?: string;
};
const MAX_BADGE_VALUE = 99;
const styles = StyleSheet.create({
textBadgeStyle: {
fontSize: 10,
fontFamily: "Titillium Web",
fontWeight: "bold",
color: "white",
flex: 1,
position: "absolute",
height: 19,
width: 19,
textAlign: "center",
paddingRight: 3,
top: Platform.OS === "ios" ? 0 : undefined
},
badgeStyle: {
backgroundColor: variables.brandPrimary,
borderColor: "white",
borderWidth: 2,
position: "absolute",
elevation: 0.1,
shadowColor: "white",
height: 19,
width: 19,
left: 12,
bottom: 10
}
});

type Props = OwnProps & ReturnType<typeof mapStateToProps>;

/**
* Message icon add badge.
*/
class MessagesTabIcon extends React.PureComponent<Props> {
public render() {
const { color, badgeValue } = this.props;
return (
<View>
<IconFont
name={"io-messaggi"}
size={variables.iconSize3}
color={color}
/>
{badgeValue > 0 ? (
<Badge style={styles.badgeStyle}>
<Text style={[styles.textBadgeStyle]}>{badgeValue}</Text>
</Badge>
) : null}
</View>
);
}
}

function mapStateToProps(state: GlobalState) {
const messagesUnread = messagesUnreadSelector(state);
return {
badgeValue:
messagesUnread < MAX_BADGE_VALUE ? messagesUnread : MAX_BADGE_VALUE
};
}

export default connect(mapStateToProps)(MessagesTabIcon);
3 changes: 0 additions & 3 deletions ts/components/messages/MessageListComponent.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ import {
StyleSheet,
View
} from "react-native";

import { NavigationEvents } from "react-navigation";
import { MessageState } from "../../store/reducers/entities/messages/messagesById";
import { PaymentByRptIdState } from "../../store/reducers/entities/payments";
Expand Down Expand Up @@ -42,7 +41,6 @@ const keyExtractor = (_: MessageState) => _.meta.id;
class MessageListComponent extends React.Component<Props> {
private renderItem = (info: ListRenderItemInfo<MessageState>) => {
const { meta } = info.item;

const service = this.props.servicesById[meta.sender_service_id];

return (
Expand Down Expand Up @@ -76,7 +74,6 @@ class MessageListComponent extends React.Component<Props> {
paymentByRptId,
ListEmptyComponent
} = this.props;

const refreshControl = (
<RefreshControl refreshing={refreshing} onRefresh={onRefresh} />
);
Expand Down
27 changes: 16 additions & 11 deletions ts/navigation/MainNavigator.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import {
NavigationState,
StackActions
} from "react-navigation";

import MessagesTabIcon from "../components/MessagesTabIcon";
import ProfileTabIcon from "../components/ProfileTabIcon";
import IconFont from "../components/ui/IconFont";
import I18n from "../i18n";
Expand All @@ -25,7 +25,6 @@ import PreferencesNavigator from "./PreferencesNavigator";
import ProfileNavigator from "./ProfileNavigator";
import ROUTES from "./routes";
import WalletNavigator from "./WalletNavigator";

type Routes = keyof typeof ROUTES;

type RouteLabelMap = { [key in Routes]?: string };
Expand Down Expand Up @@ -113,7 +112,6 @@ const getTabBarVisibility = (
if (NoTabBarRoutes.indexOf(routeName) !== -1) {
return false;
}

return true;
};

Expand Down Expand Up @@ -166,22 +164,29 @@ const navigation = createBottomTabNavigator(
tabBarIcon: (options: { tintColor: string | null; focused: boolean }) => {
const { routeName } = nav.state;
const iconName: string = getIcon(routeName);

if (routeName === ROUTES.MESSAGES_NAVIGATOR) {
return (
<MessagesTabIcon
color={options.tintColor === null ? undefined : options.tintColor}
/>
);
}
if (iconName === ROUTE_ICON.PROFILE_NAVIGATOR) {
return (
<ProfileTabIcon
size={variables.iconSize3}
color={options.tintColor === null ? undefined : options.tintColor}
/>
);
} else {
return (
<IconFont
name={iconName}
size={variables.iconSize3}
color={options.tintColor === null ? undefined : options.tintColor}
/>
);
}
return (
<IconFont
name={iconName}
size={variables.iconSize3}
color={options.tintColor === null ? undefined : options.tintColor}
/>
);
},
tabBarOnPress: options => {
if (options.navigation.state.index > 0) {
Expand Down
2 changes: 0 additions & 2 deletions ts/screens/messages/MessageDetailScreen.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import * as React from "react";
import { ActivityIndicator, Image, StyleSheet } from "react-native";
import { NavigationScreenProps } from "react-navigation";
import { connect } from "react-redux";

import { CreatedMessageWithoutContent } from "../../../definitions/backend/CreatedMessageWithoutContent";
import { ServiceId } from "../../../definitions/backend/ServiceId";
import { ServicePublic } from "../../../definitions/backend/ServicePublic";
Expand Down Expand Up @@ -281,7 +280,6 @@ export class MessageDetailScreen extends React.PureComponent<Props, never> {

const mapStateToProps = (state: GlobalState, ownProps: OwnProps) => {
const messageId = ownProps.navigation.getParam("messageId");

const maybeMessageState = fromNullable(
messageStateByIdSelector(messageId)(state)
);
Expand Down
6 changes: 3 additions & 3 deletions ts/screens/messages/MessagesHomeScreen.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ import * as React from "react";
import { StyleSheet } from "react-native";
import { NavigationScreenProps } from "react-navigation";
import { connect } from "react-redux";

import MessagesArchive from "../../components/messages/MessagesArchive";
import MessagesDeadlines from "../../components/messages/MessagesDeadlines";
import MessagesInbox from "../../components/messages/MessagesInbox";
Expand All @@ -37,7 +36,6 @@ import customVariables from "../../theme/variables";

// Used to disable the Deadlines tab
const DEADLINES_TAB_ENABLED = false;

type Props = NavigationScreenProps &
ReturnType<typeof mapStateToProps> &
ReturnType<typeof mapDispatchToProps>;
Expand Down Expand Up @@ -310,7 +308,9 @@ const mapStateToProps = (state: GlobalState) => ({
});

const mapDispatchToProps = (dispatch: Dispatch) => ({
refreshMessages: () => dispatch(loadMessages.request()),
refreshMessages: () => {
dispatch(loadMessages.request());
},
navigateToMessageDetail: (messageId: string) =>
dispatch(navigateToMessageDetailScreenAction({ messageId })),
updateMessagesArchivedState: (
Expand Down
14 changes: 13 additions & 1 deletion ts/store/reducers/entities/messages/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import messagesAllIdsReducer, {
messagesAllIdsSelector,
MessagesAllIdsState
} from "./messagesAllIds";

import messagesByIdReducer, {
messagesStateByIdSelector,
MessageStateById
Expand All @@ -34,7 +35,7 @@ const reducer = combineReducers<MessagesState, Action>({

// Selectors

/**
/**-
* Returns array of messages IDs inversely lexically ordered.
*/
export const lexicallyOrderedMessagesIds = createSelector(
Expand All @@ -59,4 +60,15 @@ export const lexicallyOrderedMessagesStateSelector = createSelector(
)
);

export const messagesUnreadSelector = createSelector(
lexicallyOrderedMessagesStateSelector,
potMessagesState =>
pot.getOrElse(
pot.map(potMessagesState, _ =>
_.filter(messageState => !messageState.isRead)
),
[]
).length
);

export default reducer;