diff --git a/__tests__/__snapshots__/RoomItem.js.snap b/__tests__/__snapshots__/RoomItem.js.snap
index c2fcbe4b..e99a1c50 100644
--- a/__tests__/__snapshots__/RoomItem.js.snap
+++ b/__tests__/__snapshots__/RoomItem.js.snap
@@ -20,13 +20,10 @@ exports[`render channel 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -39,11 +36,13 @@ exports[`render channel 1`] = `
},
Object {
"backgroundColor": "#00BCD4",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -55,7 +54,7 @@ exports[`render channel 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -69,7 +68,6 @@ exports[`render channel 1`] = `
Object {
"flex": 1,
"height": "100%",
- "marginLeft": 16,
"marginRight": 4,
}
}
@@ -78,46 +76,46 @@ exports[`render channel 1`] = `
style={
Object {
"alignItems": "center",
- "flex": 1,
"flexDirection": "row",
"justifyContent": "center",
+ "marginTop": 5,
"width": "100%",
}
}
>
-
-
-
+ />
+
+
+
+
+
+
+
@@ -178,13 +216,10 @@ exports[`render no icon 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -197,11 +232,13 @@ exports[`render no icon 1`] = `
},
Object {
"backgroundColor": "#3F51B5",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -213,7 +250,7 @@ exports[`render no icon 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -227,7 +264,6 @@ exports[`render no icon 1`] = `
Object {
"flex": 1,
"height": "100%",
- "marginLeft": 16,
"marginRight": 4,
}
}
@@ -236,46 +272,46 @@ exports[`render no icon 1`] = `
style={
Object {
"alignItems": "center",
- "flex": 1,
"flexDirection": "row",
"justifyContent": "center",
+ "marginTop": 5,
"width": "100%",
}
}
>
-
-
-
+ />
+
+
+
+
+
+
+
@@ -336,13 +412,10 @@ exports[`render private group 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -355,11 +428,13 @@ exports[`render private group 1`] = `
},
Object {
"backgroundColor": "#FF9800",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -371,7 +446,7 @@ exports[`render private group 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -385,7 +460,6 @@ exports[`render private group 1`] = `
Object {
"flex": 1,
"height": "100%",
- "marginLeft": 16,
"marginRight": 4,
}
}
@@ -394,46 +468,46 @@ exports[`render private group 1`] = `
style={
Object {
"alignItems": "center",
- "flex": 1,
"flexDirection": "row",
"justifyContent": "center",
+ "marginTop": 5,
"width": "100%",
}
}
>
-
-
-
+ />
+
+
+
+
+
+
+
@@ -495,13 +609,10 @@ exports[`render unread +999 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -514,11 +625,13 @@ exports[`render unread +999 1`] = `
},
Object {
"backgroundColor": "#3F51B5",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -530,7 +643,7 @@ exports[`render unread +999 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -546,9 +659,9 @@ exports[`render unread +999 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -576,37 +689,12 @@ exports[`render unread +999 1`] = `
}
/>
-
-
-
-
+ />
- 999+
+
+
+
+ 999+
+
+
+
+
+
@@ -735,13 +872,10 @@ exports[`render unread 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -754,11 +888,13 @@ exports[`render unread 1`] = `
},
Object {
"backgroundColor": "#3F51B5",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -770,7 +906,7 @@ exports[`render unread 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -786,9 +922,9 @@ exports[`render unread 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -816,37 +952,12 @@ exports[`render unread 1`] = `
}
/>
-
-
-
-
+ />
- 1
+
+
+
+ 1
+
+
+
+
+
@@ -975,13 +1135,10 @@ exports[`renders correctly 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -994,11 +1151,13 @@ exports[`renders correctly 1`] = `
},
Object {
"backgroundColor": "#3F51B5",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -1010,7 +1169,7 @@ exports[`renders correctly 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -1026,9 +1185,9 @@ exports[`renders correctly 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -1056,37 +1215,12 @@ exports[`renders correctly 1`] = `
}
/>
-
-
-
-
+ />
+
+
+
+
+
+
+
diff --git a/__tests__/__snapshots__/Storyshots.test.js.snap b/__tests__/__snapshots__/Storyshots.test.js.snap
index 43564cf5..2d8a2d06 100644
--- a/__tests__/__snapshots__/Storyshots.test.js.snap
+++ b/__tests__/__snapshots__/Storyshots.test.js.snap
@@ -12,7 +12,7 @@ exports[`Storyshots Avatar avatar 1`] = `
},
Object {
"backgroundColor": "#3F51B5",
- "borderRadius": 2,
+ "borderRadius": 4,
"height": 25,
"width": 25,
},
@@ -44,7 +44,7 @@ exports[`Storyshots Avatar avatar 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
+ "borderRadius": 4,
"height": 25,
"width": 25,
},
@@ -84,7 +84,7 @@ exports[`Storyshots Avatar avatar 1`] = `
},
Object {
"backgroundColor": "#9C27B0",
- "borderRadius": 2,
+ "borderRadius": 4,
"height": 40,
"width": 40,
},
@@ -116,7 +116,7 @@ exports[`Storyshots Avatar avatar 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
+ "borderRadius": 4,
"height": 40,
"width": 40,
},
@@ -156,7 +156,7 @@ exports[`Storyshots Avatar avatar 1`] = `
},
Object {
"backgroundColor": "#9C27B0",
- "borderRadius": 2,
+ "borderRadius": 4,
"height": 30,
"width": 30,
},
@@ -188,7 +188,7 @@ exports[`Storyshots Avatar avatar 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
+ "borderRadius": 4,
"height": 30,
"width": 30,
},
@@ -316,13 +316,10 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -335,11 +332,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#8BC34A",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -351,7 +350,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -367,9 +366,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -397,37 +396,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
+
+
+
+
+
+
+
@@ -531,13 +548,10 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -550,11 +564,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#8BC34A",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -566,7 +582,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -582,9 +598,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -612,37 +628,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
+
+
+
+
+
+
+
@@ -750,13 +784,10 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -769,11 +800,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#8BC34A",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -785,7 +818,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -801,9 +834,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -831,37 +864,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
- 1
+
+
+
+ 1
+
+
+
+
+
@@ -1004,11 +1058,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#795548",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -1020,7 +1076,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -1036,9 +1092,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -1066,37 +1122,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
- 9
+
+
+
+ 9
+
+
+
+
+
@@ -1243,11 +1320,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#795548",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -1259,7 +1338,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -1275,9 +1354,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -1305,37 +1384,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
- 99
+
+
+
+ 99
+
+
+
+
+
@@ -1478,11 +1578,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#795548",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -1494,7 +1596,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -1510,9 +1612,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -1540,37 +1642,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
- 100
+
+
+
+ 100
+
+
+
+
+
@@ -1713,11 +1836,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#795548",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -1729,7 +1854,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -1745,9 +1870,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -1775,37 +1900,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
- 999+
+
+
+
+ 999+
+
+
+
+
+
@@ -1948,11 +2094,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#795548",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -1964,7 +2112,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -1980,9 +2128,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -2010,37 +2158,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
- @ 999+
+
+
+
+ @ 999+
+
+
+
+
+
@@ -2183,11 +2352,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#E91E63",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -2199,7 +2370,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -2215,9 +2386,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -2245,37 +2416,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
+
+
+
+
+
+
+
@@ -2379,13 +2568,10 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -2398,11 +2584,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": "#9C27B0",
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -2414,7 +2602,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -2430,9 +2618,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -2460,37 +2648,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
+
+
+
+
+
+
+
@@ -2594,13 +2800,10 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
Array [
Object {
"alignItems": "center",
- "borderBottomColor": "#ddd",
- "borderBottomWidth": 0.5,
"flexDirection": "row",
- "paddingHorizontal": 16,
- "paddingVertical": 12,
},
undefined,
+ undefined,
]
}
>
@@ -2613,11 +2816,13 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
},
Object {
"backgroundColor": undefined,
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
+ },
+ Object {
+ "marginHorizontal": 15,
},
- undefined,
]
}
>
@@ -2629,7 +2834,7 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"color": "#ffffff",
},
Object {
- "fontSize": 28.75,
+ "fontSize": 30,
"fontWeight": "800",
},
]
@@ -2645,9 +2850,9 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
"position": "absolute",
},
Object {
- "borderRadius": 2,
- "height": 46,
- "width": 46,
+ "borderRadius": 4,
+ "height": 48,
+ "width": 48,
},
],
Object {
@@ -2675,37 +2880,12 @@ exports[`Storyshots Channel Cell Direct Messages 1`] = `
}
/>
-
-
-
-
+ />
+
+
+
+
+
+
+
diff --git a/android/app/build.gradle b/android/app/build.gradle
index 56fdfe8b..6cdb6551 100644
--- a/android/app/build.gradle
+++ b/android/app/build.gradle
@@ -201,7 +201,7 @@ dependencies {
implementation project(':reactnativenotifications')
implementation fileTree(dir: "libs", include: ["*.jar"])
implementation "com.android.support:appcompat-v7:27.1.0"
- implementation "com.android.support:support-v4:27.1.0"
+ implementation "com.android.support:support-v4:27.1.+"
implementation 'com.android.support:customtabs:27.1.0'
implementation 'com.android.support:design:27.1.0'
implementation "com.facebook.react:react-native:+" // From node_modules
diff --git a/android/app/src/main/res/drawable-hdpi/back.png b/android/app/src/main/res/drawable-hdpi/back.png
new file mode 100644
index 00000000..581100a6
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/back.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/check.png b/android/app/src/main/res/drawable-hdpi/check.png
new file mode 100644
index 00000000..8c00ca8c
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/check.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/disclosure_indicator.png b/android/app/src/main/res/drawable-hdpi/disclosure_indicator.png
new file mode 100644
index 00000000..9f6fd1da
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/disclosure_indicator.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/disclosure_indicator_server.png b/android/app/src/main/res/drawable-hdpi/disclosure_indicator_server.png
new file mode 100644
index 00000000..287976ba
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/disclosure_indicator_server.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/group_favorites.png b/android/app/src/main/res/drawable-hdpi/group_favorites.png
new file mode 100644
index 00000000..bebd96c4
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/group_favorites.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/group_type.png b/android/app/src/main/res/drawable-hdpi/group_type.png
new file mode 100644
index 00000000..2018ed7d
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/group_type.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/group_unread.png b/android/app/src/main/res/drawable-hdpi/group_unread.png
new file mode 100644
index 00000000..1e191b20
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/group_unread.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/launch_screen.png b/android/app/src/main/res/drawable-hdpi/launch_screen.png
deleted file mode 100644
index f2dee792..00000000
Binary files a/android/app/src/main/res/drawable-hdpi/launch_screen.png and /dev/null differ
diff --git a/android/app/src/main/res/drawable-hdpi/logo.png b/android/app/src/main/res/drawable-hdpi/logo.png
new file mode 100644
index 00000000..4a98ac06
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/logo.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/new_channel.png b/android/app/src/main/res/drawable-hdpi/new_channel.png
new file mode 100644
index 00000000..707f021c
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/new_channel.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/search.png b/android/app/src/main/res/drawable-hdpi/search.png
new file mode 100644
index 00000000..65995582
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/search.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/settings.png b/android/app/src/main/res/drawable-hdpi/settings.png
new file mode 100644
index 00000000..d537c71b
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/settings.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/sort_activity.png b/android/app/src/main/res/drawable-hdpi/sort_activity.png
new file mode 100644
index 00000000..2be5be12
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/sort_activity.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/sort_alphabetically.png b/android/app/src/main/res/drawable-hdpi/sort_alphabetically.png
new file mode 100644
index 00000000..8fee9c2a
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/sort_alphabetically.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/subscription_hashtag.png b/android/app/src/main/res/drawable-hdpi/subscription_hashtag.png
new file mode 100644
index 00000000..76cf0a34
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/subscription_hashtag.png differ
diff --git a/android/app/src/main/res/drawable-hdpi/subscription_lock.png b/android/app/src/main/res/drawable-hdpi/subscription_lock.png
new file mode 100644
index 00000000..71ec7462
Binary files /dev/null and b/android/app/src/main/res/drawable-hdpi/subscription_lock.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/app_images_logo.png b/android/app/src/main/res/drawable-mdpi/app_images_logo.png
deleted file mode 100644
index 57a423a6..00000000
Binary files a/android/app/src/main/res/drawable-mdpi/app_images_logo.png and /dev/null differ
diff --git a/android/app/src/main/res/drawable-mdpi/back.png b/android/app/src/main/res/drawable-mdpi/back.png
new file mode 100644
index 00000000..f4e8e91f
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/back.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/check.png b/android/app/src/main/res/drawable-mdpi/check.png
new file mode 100644
index 00000000..b0278500
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/check.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/disclosure_indicator.png b/android/app/src/main/res/drawable-mdpi/disclosure_indicator.png
new file mode 100644
index 00000000..42caa067
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/disclosure_indicator.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/disclosure_indicator_server.png b/android/app/src/main/res/drawable-mdpi/disclosure_indicator_server.png
new file mode 100644
index 00000000..87923b2f
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/disclosure_indicator_server.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/group_favorites.png b/android/app/src/main/res/drawable-mdpi/group_favorites.png
new file mode 100644
index 00000000..d139ea4d
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/group_favorites.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/group_type.png b/android/app/src/main/res/drawable-mdpi/group_type.png
new file mode 100644
index 00000000..f1be38bc
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/group_type.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/group_unread.png b/android/app/src/main/res/drawable-mdpi/group_unread.png
new file mode 100644
index 00000000..5ea6d0f3
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/group_unread.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/launch_screen.png b/android/app/src/main/res/drawable-mdpi/launch_screen.png
deleted file mode 100644
index 1b796740..00000000
Binary files a/android/app/src/main/res/drawable-mdpi/launch_screen.png and /dev/null differ
diff --git a/android/app/src/main/res/drawable-mdpi/logo.png b/android/app/src/main/res/drawable-mdpi/logo.png
new file mode 100644
index 00000000..6928d7b8
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/logo.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/new_channel.png b/android/app/src/main/res/drawable-mdpi/new_channel.png
new file mode 100644
index 00000000..62d1ce59
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/new_channel.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/search.png b/android/app/src/main/res/drawable-mdpi/search.png
new file mode 100644
index 00000000..8482814b
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/search.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/settings.png b/android/app/src/main/res/drawable-mdpi/settings.png
new file mode 100644
index 00000000..912ab962
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/settings.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/sort_activity.png b/android/app/src/main/res/drawable-mdpi/sort_activity.png
new file mode 100644
index 00000000..e64f442e
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/sort_activity.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/sort_alphabetically.png b/android/app/src/main/res/drawable-mdpi/sort_alphabetically.png
new file mode 100644
index 00000000..362ad237
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/sort_alphabetically.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/subscription_hashtag.png b/android/app/src/main/res/drawable-mdpi/subscription_hashtag.png
new file mode 100644
index 00000000..d3719dad
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/subscription_hashtag.png differ
diff --git a/android/app/src/main/res/drawable-mdpi/subscription_lock.png b/android/app/src/main/res/drawable-mdpi/subscription_lock.png
new file mode 100644
index 00000000..e345bfdd
Binary files /dev/null and b/android/app/src/main/res/drawable-mdpi/subscription_lock.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/back.png b/android/app/src/main/res/drawable-xhdpi/back.png
new file mode 100644
index 00000000..5485fab8
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/back.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/check.png b/android/app/src/main/res/drawable-xhdpi/check.png
new file mode 100644
index 00000000..6f20b37a
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/check.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/disclosure_indicator.png b/android/app/src/main/res/drawable-xhdpi/disclosure_indicator.png
new file mode 100644
index 00000000..585d4a79
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/disclosure_indicator.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/disclosure_indicator_server.png b/android/app/src/main/res/drawable-xhdpi/disclosure_indicator_server.png
new file mode 100644
index 00000000..bed48962
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/disclosure_indicator_server.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/group_favorites.png b/android/app/src/main/res/drawable-xhdpi/group_favorites.png
new file mode 100644
index 00000000..359973c8
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/group_favorites.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/group_type.png b/android/app/src/main/res/drawable-xhdpi/group_type.png
new file mode 100644
index 00000000..c0acc012
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/group_type.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/group_unread.png b/android/app/src/main/res/drawable-xhdpi/group_unread.png
new file mode 100644
index 00000000..899c2863
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/group_unread.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/launch_screen.png b/android/app/src/main/res/drawable-xhdpi/launch_screen.png
deleted file mode 100644
index 1c0eef01..00000000
Binary files a/android/app/src/main/res/drawable-xhdpi/launch_screen.png and /dev/null differ
diff --git a/android/app/src/main/res/drawable-xhdpi/logo.png b/android/app/src/main/res/drawable-xhdpi/logo.png
new file mode 100644
index 00000000..e4502f69
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/logo.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/new_channel.png b/android/app/src/main/res/drawable-xhdpi/new_channel.png
new file mode 100644
index 00000000..14da6769
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/new_channel.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/search.png b/android/app/src/main/res/drawable-xhdpi/search.png
new file mode 100644
index 00000000..a2966e0c
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/search.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/settings.png b/android/app/src/main/res/drawable-xhdpi/settings.png
new file mode 100644
index 00000000..1dd8592d
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/settings.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/sort_activity.png b/android/app/src/main/res/drawable-xhdpi/sort_activity.png
new file mode 100644
index 00000000..533d1aa6
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/sort_activity.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/sort_alphabetically.png b/android/app/src/main/res/drawable-xhdpi/sort_alphabetically.png
new file mode 100644
index 00000000..36756311
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/sort_alphabetically.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/subscription_hashtag.png b/android/app/src/main/res/drawable-xhdpi/subscription_hashtag.png
new file mode 100644
index 00000000..e4a79ec3
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/subscription_hashtag.png differ
diff --git a/android/app/src/main/res/drawable-xhdpi/subscription_lock.png b/android/app/src/main/res/drawable-xhdpi/subscription_lock.png
new file mode 100644
index 00000000..a87c4495
Binary files /dev/null and b/android/app/src/main/res/drawable-xhdpi/subscription_lock.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/back.png b/android/app/src/main/res/drawable-xxhdpi/back.png
new file mode 100644
index 00000000..8459f0d6
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/back.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/check.png b/android/app/src/main/res/drawable-xxhdpi/check.png
new file mode 100644
index 00000000..83186d0b
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/check.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/disclosure_indicator.png b/android/app/src/main/res/drawable-xxhdpi/disclosure_indicator.png
new file mode 100644
index 00000000..3c863464
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/disclosure_indicator.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/disclosure_indicator_server.png b/android/app/src/main/res/drawable-xxhdpi/disclosure_indicator_server.png
new file mode 100644
index 00000000..c0f6074d
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/disclosure_indicator_server.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/group_favorites.png b/android/app/src/main/res/drawable-xxhdpi/group_favorites.png
new file mode 100644
index 00000000..748eadcc
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/group_favorites.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/group_type.png b/android/app/src/main/res/drawable-xxhdpi/group_type.png
new file mode 100644
index 00000000..d92d228d
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/group_type.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/group_unread.png b/android/app/src/main/res/drawable-xxhdpi/group_unread.png
new file mode 100644
index 00000000..e84f81f6
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/group_unread.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/launch_screen.png b/android/app/src/main/res/drawable-xxhdpi/launch_screen.png
deleted file mode 100644
index b9a85b34..00000000
Binary files a/android/app/src/main/res/drawable-xxhdpi/launch_screen.png and /dev/null differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/logo.png b/android/app/src/main/res/drawable-xxhdpi/logo.png
new file mode 100644
index 00000000..159d7d4a
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/logo.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/new_channel.png b/android/app/src/main/res/drawable-xxhdpi/new_channel.png
new file mode 100644
index 00000000..82d882ea
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/new_channel.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/search.png b/android/app/src/main/res/drawable-xxhdpi/search.png
new file mode 100644
index 00000000..1d380f01
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/search.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/settings.png b/android/app/src/main/res/drawable-xxhdpi/settings.png
new file mode 100644
index 00000000..501b6a4b
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/settings.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/sort_activity.png b/android/app/src/main/res/drawable-xxhdpi/sort_activity.png
new file mode 100644
index 00000000..dac1d40e
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/sort_activity.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/sort_alphabetically.png b/android/app/src/main/res/drawable-xxhdpi/sort_alphabetically.png
new file mode 100644
index 00000000..2da108f0
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/sort_alphabetically.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/subscription_hashtag.png b/android/app/src/main/res/drawable-xxhdpi/subscription_hashtag.png
new file mode 100644
index 00000000..5d4be58c
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/subscription_hashtag.png differ
diff --git a/android/app/src/main/res/drawable-xxhdpi/subscription_lock.png b/android/app/src/main/res/drawable-xxhdpi/subscription_lock.png
new file mode 100644
index 00000000..68537368
Binary files /dev/null and b/android/app/src/main/res/drawable-xxhdpi/subscription_lock.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/back.png b/android/app/src/main/res/drawable-xxxhdpi/back.png
new file mode 100644
index 00000000..8278d1b3
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/back.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/check.png b/android/app/src/main/res/drawable-xxxhdpi/check.png
new file mode 100644
index 00000000..94fcdd0e
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/check.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/disclosure_indicator.png b/android/app/src/main/res/drawable-xxxhdpi/disclosure_indicator.png
new file mode 100644
index 00000000..d9a8f907
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/disclosure_indicator.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/disclosure_indicator_server.png b/android/app/src/main/res/drawable-xxxhdpi/disclosure_indicator_server.png
new file mode 100644
index 00000000..fa6f1db5
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/disclosure_indicator_server.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/group_favorites.png b/android/app/src/main/res/drawable-xxxhdpi/group_favorites.png
new file mode 100644
index 00000000..111ff514
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/group_favorites.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/group_type.png b/android/app/src/main/res/drawable-xxxhdpi/group_type.png
new file mode 100644
index 00000000..20f07727
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/group_type.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/group_unread.png b/android/app/src/main/res/drawable-xxxhdpi/group_unread.png
new file mode 100644
index 00000000..f2e41f0b
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/group_unread.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/launch_screen.png b/android/app/src/main/res/drawable-xxxhdpi/launch_screen.png
deleted file mode 100644
index 603e7c1f..00000000
Binary files a/android/app/src/main/res/drawable-xxxhdpi/launch_screen.png and /dev/null differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/logo.png b/android/app/src/main/res/drawable-xxxhdpi/logo.png
new file mode 100644
index 00000000..c1bd0fe3
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/logo.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/new_channel.png b/android/app/src/main/res/drawable-xxxhdpi/new_channel.png
new file mode 100644
index 00000000..7086e713
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/new_channel.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/search.png b/android/app/src/main/res/drawable-xxxhdpi/search.png
new file mode 100644
index 00000000..16e8b3b5
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/search.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/settings.png b/android/app/src/main/res/drawable-xxxhdpi/settings.png
new file mode 100644
index 00000000..cca523a1
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/settings.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/sort_activity.png b/android/app/src/main/res/drawable-xxxhdpi/sort_activity.png
new file mode 100644
index 00000000..1a8c7612
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/sort_activity.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/sort_alphabetically.png b/android/app/src/main/res/drawable-xxxhdpi/sort_alphabetically.png
new file mode 100644
index 00000000..db4dbc58
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/sort_alphabetically.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/subscription_hashtag.png b/android/app/src/main/res/drawable-xxxhdpi/subscription_hashtag.png
new file mode 100644
index 00000000..d76738e3
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/subscription_hashtag.png differ
diff --git a/android/app/src/main/res/drawable-xxxhdpi/subscription_lock.png b/android/app/src/main/res/drawable-xxxhdpi/subscription_lock.png
new file mode 100644
index 00000000..ba072523
Binary files /dev/null and b/android/app/src/main/res/drawable-xxxhdpi/subscription_lock.png differ
diff --git a/app/actions/actionsTypes.js b/app/actions/actionsTypes.js
index eb56da9e..49bd9cea 100644
--- a/app/actions/actionsTypes.js
+++ b/app/actions/actionsTypes.js
@@ -24,14 +24,22 @@ export const LOGIN = createRequestTypes('LOGIN', [
'OPEN',
'CLOSE',
'SET_SERVICES',
- 'REMOVE_SERVICES'
+ 'REMOVE_SERVICES',
+ 'SET_PREFERENCE'
]);
export const FORGOT_PASSWORD = createRequestTypes('FORGOT_PASSWORD', [
...defaultTypes,
'INIT'
]);
export const USER = createRequestTypes('USER', ['SET']);
-export const ROOMS = createRequestTypes('ROOMS', [...defaultTypes, 'SET_SEARCH']);
+export const ROOMS = createRequestTypes('ROOMS', [
+ ...defaultTypes,
+ 'SET_SEARCH',
+ 'CLOSE_SERVER_DROPDOWN',
+ 'TOGGLE_SERVER_DROPDOWN',
+ 'CLOSE_SORT_DROPDOWN',
+ 'TOGGLE_SORT_DROPDOWN'
+]);
export const ROOM = createRequestTypes('ROOM', [
'ADD_USER_TYPING',
'REMOVE_USER_TYPING',
diff --git a/app/actions/login.js b/app/actions/login.js
index e9e332b3..529039ce 100644
--- a/app/actions/login.js
+++ b/app/actions/login.js
@@ -151,3 +151,10 @@ export function removeLoginServices() {
type: types.LOGIN.REMOVE_SERVICES
};
}
+
+export function setPreference(preference) {
+ return {
+ type: types.LOGIN.SET_PREFERENCE,
+ preference
+ };
+}
diff --git a/app/actions/rooms.js b/app/actions/rooms.js
index 1555a8c8..84308ef9 100644
--- a/app/actions/rooms.js
+++ b/app/actions/rooms.js
@@ -26,3 +26,27 @@ export function setSearch(searchText) {
searchText
};
}
+
+export function closeServerDropdown() {
+ return {
+ type: types.ROOMS.CLOSE_SERVER_DROPDOWN
+ };
+}
+
+export function toggleServerDropdown() {
+ return {
+ type: types.ROOMS.TOGGLE_SERVER_DROPDOWN
+ };
+}
+
+export function closeSortDropdown() {
+ return {
+ type: types.ROOMS.CLOSE_SORT_DROPDOWN
+ };
+}
+
+export function toggleSortDropdown() {
+ return {
+ type: types.ROOMS.TOGGLE_SORT_DROPDOWN
+ };
+}
diff --git a/app/constants/settings.js b/app/constants/settings.js
index 048aa00d..7206e0ec 100644
--- a/app/constants/settings.js
+++ b/app/constants/settings.js
@@ -71,6 +71,9 @@ export default {
Message_TimeFormat: {
type: 'valueAsString'
},
+ Site_Name: {
+ type: 'valueAsString'
+ },
Site_Url: {
type: 'valueAsString'
},
diff --git a/app/containers/Avatar.js b/app/containers/Avatar.js
index b25d0f7a..cf357c2b 100644
--- a/app/containers/Avatar.js
+++ b/app/containers/Avatar.js
@@ -38,7 +38,7 @@ export default class Avatar extends React.PureComponent {
text: '',
size: 25,
type: 'd',
- borderRadius: 2,
+ borderRadius: 4,
forceInitials: false
};
state = { showInitials: true };
diff --git a/app/containers/RoomTypeIcon.js b/app/containers/RoomTypeIcon.js
index 269d4294..0d843eef 100644
--- a/app/containers/RoomTypeIcon.js
+++ b/app/containers/RoomTypeIcon.js
@@ -1,36 +1,33 @@
import React from 'react';
-import { StyleSheet } from 'react-native';
+import { Image, StyleSheet } from 'react-native';
import PropTypes from 'prop-types';
-import Icon from 'react-native-vector-icons/MaterialCommunityIcons';
const styles = StyleSheet.create({
- type: {
- marginRight: 5,
+ style: {
+ marginRight: 7,
marginTop: 3
}
});
-const RoomTypeIcon = ({ type, size }) => {
+const RoomTypeIcon = ({ type, size, style }) => {
if (!type) {
return null;
}
- const icon = {
- c: 'pound',
- p: 'lock',
- l: 'account',
- d: 'at'
- }[type];
- return ;
+ if (type === 'c') {
+ return ;
+ }
+ return ;
};
RoomTypeIcon.propTypes = {
type: PropTypes.string,
- size: PropTypes.number
+ size: PropTypes.number,
+ style: PropTypes.object
};
RoomTypeIcon.defaultProps = {
- size: 15
+ size: 10
};
export default RoomTypeIcon;
diff --git a/app/containers/message/Markdown.js b/app/containers/message/Markdown.js
index 29d7e4f7..da54d141 100644
--- a/app/containers/message/Markdown.js
+++ b/app/containers/message/Markdown.js
@@ -68,7 +68,6 @@ export default class Markdown extends React.Component {
hardbreak: () => null,
blocklink: () => null,
image: node => (
- // TODO: should use Image component
),
...rules
diff --git a/app/i18n/locales/en.js b/app/i18n/locales/en.js
index cdb64afe..44261479 100644
--- a/app/i18n/locales/en.js
+++ b/app/i18n/locales/en.js
@@ -76,6 +76,8 @@ export default {
'error-user-registration-secret': 'User registration is only allowed via Secret URL',
'error-you-are-last-owner': 'You are the last owner. Please set new owner before leaving the room.',
Actions: 'Actions',
+ activity: 'activity',
+ Activity: 'Activity',
Add_Reaction: 'Add Reaction',
Add_Server: 'Add Server',
Add_user: 'Add user',
@@ -85,6 +87,7 @@ export default {
All_users_in_the_channel_can_write_new_messages: 'All users in the channel can write new messages',
All: 'All',
Allow_Reactions: 'Allow Reactions',
+ Alphabetical: 'Alphabetical',
and_more: 'and more',
and: 'and',
announcement: 'announcement',
@@ -108,6 +111,7 @@ export default {
Cancel: 'Cancel',
changing_avatar: 'changing avatar',
Channel_Name: 'Channel Name',
+ Channels: 'Channels',
Chats: 'Chats',
Close: 'Close',
Close_emoji_selector: 'Close emoji selector',
@@ -133,6 +137,7 @@ export default {
description: 'description',
Description: 'Description',
Disable_notifications: 'Disable notifications',
+ Direct_Messages: 'Direct Messages',
Do_you_really_want_to_key_this_room_question_mark: 'Do you really want to {{key}} this room?',
edit: 'edit',
Edit: 'Edit',
@@ -141,6 +146,7 @@ export default {
Enable_notifications: 'Enable notifications',
Everyone_can_access_this_channel: 'Everyone can access this channel',
Error_uploading: 'Error uploading',
+ Favorites: 'Favorites',
Files: 'Files',
Finish_recording: 'Finish recording',
For_your_security_you_must_enter_your_current_password_to_continue: 'For your security, you must enter your current password to continue',
@@ -148,6 +154,8 @@ export default {
Forgot_password_If_this_email_is_registered: 'If this email is registered, we\'ll send instructions on how to reset your password. If you do not receive an email shortly, please come back and try again.',
Forgot_password: 'Forgot password',
Forgot_Password: 'Forgot Password',
+ Group_by_favorites: 'Group by favorites',
+ Group_by_type: 'Group by type',
Has_joined_the_channel: 'Has joined the channel',
Has_left_the_channel: 'Has left the channel',
I_have_an_account: 'I have an account',
@@ -161,6 +169,7 @@ export default {
last_message: 'last message',
Leave_channel: 'Leave channel',
leave: 'leave',
+ Livechat: 'Livechat',
Loading_messages_ellipsis: 'Loading messages...',
Login: 'Login',
Logout: 'Logout',
@@ -180,6 +189,7 @@ export default {
My_servers: 'My servers',
N_online_members: '{{n}} online members',
N_person_reacted: '{{n}} people reacted',
+ name: 'name',
Name: 'Name',
New_in_RocketChat_question_mark: 'New in Rocket.Chat?',
New_Message: 'New Message',
@@ -216,6 +226,7 @@ export default {
Preferences_saved: 'Preferences saved!',
Privacy_Policy: ' Privacy Policy',
Private_Channel: 'Private Channel',
+ Private_Groups: 'Private Groups',
Private: 'Private',
Profile_saved_successfully: 'Profile saved successfully!',
Profile: 'Profile',
@@ -257,6 +268,7 @@ export default {
Send: 'Send',
Send_audio_message: 'Send audio message',
Send_message: 'Send message',
+ Server: 'Server',
Servers: 'Servers',
Settings: 'Settings',
Settings_succesfully_changed: 'Settings succesfully changed!',
@@ -268,6 +280,7 @@ export default {
snippeted: 'snippeted',
Snippets: 'Snippets',
Some_field_is_invalid_or_empty: 'Some field is invalid or empty',
+ Sorting_by: 'Sorting by {{key}}',
Star_room: 'Star room',
Star: 'Star',
Starred_Messages: 'Starred Messages',
@@ -296,6 +309,8 @@ export default {
unmuted: 'unmuted',
Unpin: 'Unpin',
unread_messages: 'unread messages',
+ Unread: 'Unread',
+ Unread_on_top: 'Unread on top',
Unstar: 'Unstar',
Uploading: 'Uploading',
User_added_by: 'User {{userAdded}} added by {{userBy}}',
diff --git a/app/lib/methods/getSettings.js b/app/lib/methods/getSettings.js
index ae4fc63e..f1ec9c5f 100644
--- a/app/lib/methods/getSettings.js
+++ b/app/lib/methods/getSettings.js
@@ -11,18 +11,36 @@ const getLastUpdate = () => {
return setting && setting._updatedAt;
};
+function updateServer(param) {
+ database.databases.serversDB.write(() => {
+ database.databases.serversDB.create('servers', { id: this.ddp.url, ...param }, true);
+ });
+}
+
export default async function() {
try {
const lastUpdate = getLastUpdate();
const result = await (!lastUpdate ? this.ddp.call('public-settings/get') : this.ddp.call('public-settings/get', new Date(lastUpdate)));
+ const data = result.update || result || [];
- const filteredSettings = this._prepareSettings(this._filterSettings(result.update || result));
+ const filteredSettings = this._prepareSettings(this._filterSettings(data));
InteractionManager.runAfterInteractions(() =>
database.write(() =>
- filteredSettings.forEach(setting =>
- database.create('settings', { ...setting, _updatedAt: new Date() }, true))));
+ filteredSettings.forEach((setting) => {
+ database.create('settings', { ...setting, _updatedAt: new Date() }, true);
+
+ if (setting._id === 'Site_Name') {
+ updateServer.call(this, { name: setting.valueAsString });
+ }
+ })));
reduxStore.dispatch(actions.addSettings(this.parseSettings(filteredSettings)));
+
+ const iconSetting = data.find(item => item._id === 'Assets_favicon_512');
+ if (iconSetting) {
+ const iconURL = `${ this.ddp.url }/${ iconSetting.value.url || iconSetting.value.defaultUrl }`;
+ updateServer.call(this, { iconURL });
+ }
} catch (e) {
log('getSettings', e);
}
diff --git a/app/lib/realm.js b/app/lib/realm.js
index f4677b03..e4f68f40 100644
--- a/app/lib/realm.js
+++ b/app/lib/realm.js
@@ -9,6 +9,8 @@ const serversSchema = {
primaryKey: 'id',
properties: {
id: 'string',
+ name: { type: 'string', optional: true },
+ iconURL: { type: 'string', optional: true },
current: 'bool'
}
};
diff --git a/app/lib/rocketchat.js b/app/lib/rocketchat.js
index fa792cfa..ed2b0289 100644
--- a/app/lib/rocketchat.js
+++ b/app/lib/rocketchat.js
@@ -140,7 +140,8 @@ const RocketChat = {
user = { ...user, ...userInfo.user };
}
RocketChat.registerPushToken(user.id);
- return reduxStore.dispatch(loginSuccess(user));
+ reduxStore.dispatch(loginSuccess(user));
+ this.ddp.subscribe('userData');
} catch (e) {
log('rocketchat.loginSuccess', e);
}
@@ -468,7 +469,7 @@ const RocketChat = {
log('rocketchat.logout', e);
}
}
- database.deleteAll();
+ // database.deleteAll();
AsyncStorage.removeItem(TOKEN_KEY);
AsyncStorage.removeItem(`${ TOKEN_KEY }-${ server }`);
},
diff --git a/app/presentation/RoomItem.js b/app/presentation/RoomItem.js
index df5ef013..82e72d2e 100644
--- a/app/presentation/RoomItem.js
+++ b/app/presentation/RoomItem.js
@@ -1,91 +1,101 @@
import React from 'react';
import moment from 'moment';
import PropTypes from 'prop-types';
-import { View, Text, StyleSheet, ViewPropTypes } from 'react-native';
-import Icon from 'react-native-vector-icons/MaterialCommunityIcons';
+import { View, Text, StyleSheet, Image, Platform } from 'react-native';
import { connect } from 'react-redux';
+import { emojify } from 'react-emojione';
import Avatar from '../containers/Avatar';
import Status from '../containers/status';
import Touch from '../utils/touch/index'; //eslint-disable-line
-import Markdown from '../containers/message/Markdown';
import RoomTypeIcon from '../containers/RoomTypeIcon';
import I18n from '../i18n';
const styles = StyleSheet.create({
container: {
flexDirection: 'row',
- paddingHorizontal: 16,
- paddingVertical: 12,
- alignItems: 'center',
- borderBottomWidth: StyleSheet.hairlineWidth,
- borderBottomColor: '#ddd'
+ alignItems: 'center'
},
- number: {
- minWidth: 25,
+ centerContainer: {
+ flex: 1,
+ height: '100%',
+ marginRight: 4
+ },
+ title: {
+ flex: 1,
+ fontSize: 18,
+ color: '#0C0D0F',
+ fontWeight: '400',
+ marginRight: 5,
+ paddingTop: 0,
+ paddingBottom: 0
+ },
+ alert: {
+ fontWeight: '600'
+ },
+ row: {
+ flex: 1,
+ flexDirection: 'row',
+ alignItems: 'flex-start'
+ },
+ titleContainer: {
+ width: '100%',
+ marginTop: Platform.OS === 'ios' ? 5 : 2,
+ flexDirection: 'row',
+ alignItems: 'center',
+ justifyContent: 'center'
+ },
+ date: {
+ fontSize: 14,
+ color: '#9EA2A8',
+ fontWeight: 'normal',
+ paddingTop: 0,
+ paddingBottom: 0
+ },
+ updateAlert: {
+ color: '#1D74F5'
+ },
+ unreadNumberContainer: {
+ minWidth: 23,
+ padding: 3,
borderRadius: 4,
- backgroundColor: '#1d74f5',
+ backgroundColor: '#1D74F5',
+ alignItems: 'center',
+ justifyContent: 'center'
+ },
+ unreadNumberText: {
color: '#fff',
overflow: 'hidden',
fontSize: 14,
- paddingVertical: 4,
- paddingHorizontal: 5,
-
- textAlign: 'center',
- alignItems: 'center',
- justifyContent: 'center'
- },
- roomNameView: {
- flex: 1,
- height: '100%',
- marginLeft: 16,
- marginRight: 4
- },
- roomName: {
- flex: 1,
- fontSize: 18,
- color: '#444',
- marginRight: 8
- },
- alert: {
- fontWeight: 'bold'
- },
- favorite: {
- // backgroundColor: '#eee'
- },
- row: {
- // width: '100%',
- flex: 1,
- flexDirection: 'row',
- alignItems: 'center'
- // justifyContent: 'flex-end'
- },
- firstRow: {
- width: '100%',
- flex: 1,
- flexDirection: 'row',
- alignItems: 'center',
- justifyContent: 'center'
- },
- update: {
- fontSize: 10,
- color: '#888',
- alignItems: 'center',
- justifyContent: 'center'
- },
- updateAlert: {
- color: '#1d74f5'
+ fontWeight: '500',
+ letterSpacing: 0.56
},
status: {
- position: 'absolute',
- bottom: -3,
- right: -3,
- borderWidth: 3,
- borderColor: '#fff'
- },
- type: {
- marginRight: 5,
+ borderRadius: 10,
+ width: 10,
+ height: 10,
+ marginRight: 7,
marginTop: 3
+ },
+ disclosureContainer: {
+ height: '100%',
+ marginLeft: 6,
+ marginRight: 9,
+ alignItems: 'center',
+ justifyContent: 'center'
+ },
+ disclosureIndicator: {
+ width: 20,
+ height: 20
+ },
+ emptyDisclosureAndroid: {
+ width: 15
+ },
+ markdownText: {
+ flex: 1,
+ color: '#9EA2A8',
+ fontSize: 15,
+ fontWeight: 'normal'
}
});
@@ -103,9 +113,9 @@ const renderNumber = (unread, userMentions) => {
}
return (
-
- { unread }
-
+
+ { unread }
+
);
};
@@ -131,13 +141,13 @@ export default class RoomItem extends React.Component {
onLongPress: PropTypes.func,
username: PropTypes.string,
avatarSize: PropTypes.number,
- statusStyle: ViewPropTypes.style,
- testID: PropTypes.string
+ testID: PropTypes.string,
+ height: PropTypes.number
}
static defaultProps = {
showLastMessage: true,
- avatarSize: 46
+ avatarSize: 48
}
shouldComponentUpdate(nextProps) {
const oldlastMessage = this.props.lastMessage;
@@ -151,11 +161,9 @@ export default class RoomItem extends React.Component {
}
return attrs.some(key => nextProps[key] !== this.props[key]);
}
- get icon() {
- const {
- type, name, id, avatarSize, statusStyle
- } = this.props;
- return ({type === 'd' ? : null });
+ get avatar() {
+ const { type, name, avatarSize } = this.props;
+ return ;
}
get lastMessage() {
@@ -178,19 +186,17 @@ export default class RoomItem extends React.Component {
prefix = `${ lastMessage.u.username }: `;
}
- const msg = `${ prefix }${ lastMessage.msg.replace(/[\n\t\r]/igm, '') }`;
- const maxChars = 35;
- return `${ msg.slice(0, maxChars) }${ msg.replace(/:[a-z0-9]+:/gi, ':::').length > maxChars ? '...' : '' }`;
+ let msg = `${ prefix }${ lastMessage.msg.replace(/[\n\t\r]/igm, '') }`;
+ msg = emojify(msg, { output: 'unicode' });
+ return msg;
}
get type() {
- const icon = {
- c: 'pound',
- p: 'lock',
- l: 'account',
- d: 'at'
- }[this.props.type];
- return ;
+ const { type, id } = this.props;
+ if (type === 'd') {
+ return ;
+ }
+ return ;
}
formatDate = date => moment(date).calendar(null, {
@@ -200,9 +206,20 @@ export default class RoomItem extends React.Component {
sameElse: 'MMM D'
})
+ renderDisclosureIndicator = () => {
+ if (Platform.OS === 'ios') {
+ return (
+
+
+
+ );
+ }
+ return ;
+ }
+
render() {
const {
- favorite, unread, userMentions, name, _updatedAt, alert, type, testID
+ favorite, unread, userMentions, name, _updatedAt, alert, testID, height
} = this.props;
const date = this.formatDate(_updatedAt);
@@ -232,43 +249,22 @@ export default class RoomItem extends React.Component {
accessibilityTraits='selected'
testID={testID}
>
-
- {this.icon}
-
-
-
- { name }
- {_updatedAt ? { date } : null}
+
+ {this.avatar}
+
+
+ {this.type}
+ { name }
+ {_updatedAt ? { date } : null}
- (
-
- @{node.content}
-
- ),
- hashtag: node => (
-
- #{node.content}
-
- ),
- link: (node, children) => (
-
- {children}
-
- )
- }}
- />
+
+ {this.lastMessage}
+
{renderNumber(unread, userMentions)}
+ {this.renderDisclosureIndicator()}
);
diff --git a/app/presentation/UserItem.js b/app/presentation/UserItem.js
new file mode 100644
index 00000000..cf8c07de
--- /dev/null
+++ b/app/presentation/UserItem.js
@@ -0,0 +1,57 @@
+import React from 'react';
+import { Text, View, StyleSheet, Platform } from 'react-native';
+import PropTypes from 'prop-types';
+
+import Avatar from '../containers/Avatar';
+import Touch from '../utils/touch';
+
+const styles = StyleSheet.create({
+ button: {
+ height: 54
+ },
+ container: {
+ flexDirection: 'row'
+ },
+ avatar: {
+ marginHorizontal: 15,
+ marginVertical: 12
+ },
+ textContainer: {
+ flex: 1,
+ flexDirection: 'column'
+ },
+ name: {
+ fontSize: 18,
+ color: '#0C0D0F',
+ marginTop: Platform.OS === 'ios' ? 6 : 3,
+ marginBottom: 1
+ },
+ username: {
+ fontSize: 14,
+ color: '#9EA2A8'
+ }
+});
+
+const UserItem = ({
+ name, username, onPress, testID, onLongPress
+}) => (
+
+
+
+
+ {name}
+ @{username}
+
+
+
+);
+
+UserItem.propTypes = {
+ name: PropTypes.string.isRequired,
+ username: PropTypes.string.isRequired,
+ onPress: PropTypes.func.isRequired,
+ testID: PropTypes.string.isRequired,
+ onLongPress: PropTypes.func
+};
+
+export default UserItem;
diff --git a/app/push.js_ b/app/push.js_
deleted file mode 100644
index 2b898a22..00000000
--- a/app/push.js_
+++ /dev/null
@@ -1,48 +0,0 @@
-import PushNotification from 'react-native-push-notification';
-import { AsyncStorage } from 'react-native';
-import EJSON from 'ejson';
-
-import { NavigationActions } from './Navigation';
-
-const handleNotification = (notification) => {
- if (notification.userInteraction) {
- const {
- rid, name, sender, type
- } = EJSON.parse(notification.ejson || notification.data.ejson);
- NavigationActions.push({
- screen: 'RoomView',
- passProps: { rid, name: type === 'd' ? sender.username : name }
- });
- }
-};
-PushNotification.configure({
-
- // (optional) Called when Token is generated (iOS and Android)
- async onRegister({ token }) {
- AsyncStorage.setItem('pushId', token);
- },
-
- // (required) Called when a remote or local notification is opened or received
- onNotification: handleNotification,
-
- // ANDROID ONLY: GCM Sender ID (optional - not required for local notifications, but is need to receive remote push notifications)
- senderID: '673693445664',
-
- // IOS ONLY (optional): default: all - Permissions to register.
- permissions: {
- alert: true,
- badge: true,
- sound: true
- },
-
- // Should the initial notification be popped automatically
- // default: true
- popInitialNotification: true,
-
- /**
- * (optional) default: true
- * - Specified if permissions (ios) and token (android and ios) will requested or not,
- * - if not, you must call PushNotificationsHandler.requestPermissions() later
- */
- requestPermissions: true
-});
diff --git a/app/reducers/login.js b/app/reducers/login.js
index 7f735a0d..cf4d2ff7 100644
--- a/app/reducers/login.js
+++ b/app/reducers/login.js
@@ -28,7 +28,10 @@ export default function login(state = initialState, action) {
...state,
isFetching: false,
isAuthenticated: true,
- user: { ...state.user, ...action.user },
+ user: {
+ ...state.user,
+ ...action.user
+ },
token: action.user.token,
failure: false,
error: ''
@@ -130,6 +133,20 @@ export default function login(state = initialState, action) {
...state,
services: {}
};
+ case types.LOGIN.SET_PREFERENCE:
+ return {
+ ...state,
+ user: {
+ ...state.user,
+ settings: {
+ ...state.user.settings,
+ preferences: {
+ ...state.user.settings.preferences,
+ ...action.preference
+ }
+ }
+ }
+ };
default:
return state;
}
diff --git a/app/reducers/rooms.js b/app/reducers/rooms.js
index 0565dc80..09506865 100644
--- a/app/reducers/rooms.js
+++ b/app/reducers/rooms.js
@@ -3,7 +3,10 @@ import * as types from '../actions/actionsTypes';
const initialState = {
isFetching: false,
failure: false,
- searchText: ''
+ searchText: '',
+ showServerDropdown: false,
+ closeServerDropdown: false,
+ showSortDropdown: false
};
export default function login(state = initialState, action) {
@@ -30,6 +33,26 @@ export default function login(state = initialState, action) {
...state,
searchText: action.searchText
};
+ case types.ROOMS.CLOSE_SERVER_DROPDOWN:
+ return {
+ ...state,
+ closeServerDropdown: !state.closeServerDropdown
+ };
+ case types.ROOMS.TOGGLE_SERVER_DROPDOWN:
+ return {
+ ...state,
+ showServerDropdown: !state.showServerDropdown
+ };
+ case types.ROOMS.CLOSE_SORT_DROPDOWN:
+ return {
+ ...state,
+ closeSortDropdown: !state.closeSortDropdown
+ };
+ case types.ROOMS.TOGGLE_SORT_DROPDOWN:
+ return {
+ ...state,
+ showSortDropdown: !state.showSortDropdown
+ };
default:
return state;
}
diff --git a/app/sagas/login.js b/app/sagas/login.js
index cf7732a1..12f1b01e 100644
--- a/app/sagas/login.js
+++ b/app/sagas/login.js
@@ -17,8 +17,7 @@ import {
setUsernameRequest,
setUsernameSuccess,
forgotPasswordSuccess,
- forgotPasswordFailure,
- setUser
+ forgotPasswordFailure
} from '../actions/login';
import RocketChat from '../lib/rocketchat';
import log from '../utils/log';
@@ -40,7 +39,6 @@ const handleLoginSuccess = function* handleLoginSuccess() {
try {
const user = yield select(getUser);
yield AsyncStorage.setItem(RocketChat.TOKEN_KEY, user.token);
- yield put(setUser(user));
if (!user.username || user.isRegistering) {
yield put(registerIncomplete());
} else {
@@ -96,7 +94,7 @@ const handleLogout = function* handleLogout() {
if (server) {
try {
yield put(appStart('outside'));
- yield delay(300);
+ // yield delay(300);
yield call(logoutCall, { server });
} catch (e) {
log('handleLogout', e);
@@ -137,10 +135,11 @@ const watchLoginOpen = function* watchLoginOpen() {
};
const handleSetUser = function* handleSetUser() {
+ yield delay(2000);
const [server, user] = yield all([select(getServer), select(getUser)]);
if (user) {
// TODO: temporary... remove in future releases
- delete user.user;
+ // delete user.user;
if (user.language) {
I18n.locale = user.language;
}
diff --git a/app/static/images/disclosureIndicator.png b/app/static/images/disclosureIndicator.png
deleted file mode 100644
index ad75c1fb..00000000
Binary files a/app/static/images/disclosureIndicator.png and /dev/null differ
diff --git a/app/static/images/disclosureIndicator@2x.png b/app/static/images/disclosureIndicator@2x.png
deleted file mode 100644
index b3e96310..00000000
Binary files a/app/static/images/disclosureIndicator@2x.png and /dev/null differ
diff --git a/app/static/images/disclosureIndicator@3x.png b/app/static/images/disclosureIndicator@3x.png
deleted file mode 100644
index 788e682e..00000000
Binary files a/app/static/images/disclosureIndicator@3x.png and /dev/null differ
diff --git a/app/static/images/logo.png b/app/static/images/logo.png
index 57a423a6..ed46c847 100644
Binary files a/app/static/images/logo.png and b/app/static/images/logo.png differ
diff --git a/app/utils/touch/index.android.js b/app/utils/touch/index.android.js
index ba409595..9eb368a4 100644
--- a/app/utils/touch/index.android.js
+++ b/app/utils/touch/index.android.js
@@ -1,3 +1,24 @@
-import { TouchableNativeFeedback } from 'react-native';
+import React from 'react';
+import { TouchableNativeFeedback, View } from 'react-native';
+import PropTypes from 'prop-types';
-export default TouchableNativeFeedback;
+const Touch = ({
+ children, style, onPress, ...props
+}) => (
+
+
+ {children}
+
+
+);
+
+Touch.propTypes = {
+ children: PropTypes.node.isRequired,
+ style: PropTypes.any,
+ onPress: PropTypes.func.isRequired
+};
+
+export default Touch;
diff --git a/app/utils/touch/index.ios.js b/app/utils/touch/index.ios.js
index 1832befa..5928032e 100644
--- a/app/utils/touch/index.ios.js
+++ b/app/utils/touch/index.ios.js
@@ -1,3 +1,21 @@
+import React from 'react';
import { TouchableHighlight } from 'react-native';
+import PropTypes from 'prop-types';
-export default TouchableHighlight;
+const Touch = ({ children, onPress, ...props }) => (
+
+ {children}
+
+);
+
+Touch.propTypes = {
+ children: PropTypes.node.isRequired,
+ onPress: PropTypes.func.isRequired
+};
+
+export default Touch;
diff --git a/app/views/NewServerView.js b/app/views/NewServerView.js
index e3d35ce9..66e14a7b 100644
--- a/app/views/NewServerView.js
+++ b/app/views/NewServerView.js
@@ -47,7 +47,7 @@ const defaultServer = 'https://open.rocket.chat';
failure: state.server.failure,
currentServer: state.server.server
}), dispatch => ({
- connectServer: (url, adding) => dispatch(serverRequest(url, adding))
+ connectServer: url => dispatch(serverRequest(url))
}))
/** @extends React.Component */
export default class NewServerView extends LoggedView {
diff --git a/app/views/OnboardingView/Button.js b/app/views/OnboardingView/Button.js
index e3c3e83f..59877313 100644
--- a/app/views/OnboardingView/Button.js
+++ b/app/views/OnboardingView/Button.js
@@ -45,7 +45,7 @@ export default class Button extends React.PureComponent {
{title}
{subtitle ? {subtitle} : null}
- {type === 'secondary' ? : null}
+ {type === 'secondary' ? : null}
);
diff --git a/app/views/OnboardingView/styles.js b/app/views/OnboardingView/styles.js
index 81ed89c5..41229106 100644
--- a/app/views/OnboardingView/styles.js
+++ b/app/views/OnboardingView/styles.js
@@ -76,7 +76,9 @@ export default StyleSheet.create({
justifyContent: 'center'
},
buttonIcon: {
- marginHorizontal: scale(20)
+ marginHorizontal: scale(10),
+ width: 20,
+ height: 20
},
buttonActive: {
opacity: 0.5
diff --git a/app/views/PrivacyPolicyView.js b/app/views/PrivacyPolicyView.js
index aea3ef37..f86868b4 100644
--- a/app/views/PrivacyPolicyView.js
+++ b/app/views/PrivacyPolicyView.js
@@ -4,15 +4,21 @@ import { WebView, SafeAreaView } from 'react-native';
import { connect } from 'react-redux';
import styles from './Styles';
+import LoggedView from './View';
@connect(state => ({
privacyPolicy: state.settings.Layout_Privacy_Policy
}))
-export default class PrivacyPolicyView extends React.PureComponent {
+/** @extends React.Component */
+export default class PrivacyPolicyView extends LoggedView {
static propTypes = {
privacyPolicy: PropTypes.string
}
+ constructor(props) {
+ super('PrivacyPolicyView', props);
+ }
+
render() {
return (
diff --git a/app/views/ProfileView/index.js b/app/views/ProfileView/index.js
index 3c5fb4ca..0b2fb65e 100644
--- a/app/views/ProfileView/index.js
+++ b/app/views/ProfileView/index.js
@@ -1,6 +1,6 @@
import React from 'react';
import PropTypes from 'prop-types';
-import { View, ScrollView, SafeAreaView, Keyboard, Platform } from 'react-native';
+import { View, ScrollView, SafeAreaView, Keyboard, Platform, Dimensions } from 'react-native';
import { connect } from 'react-redux';
import Dialog from 'react-native-dialog';
import SHA256 from 'js-sha256';
@@ -22,7 +22,6 @@ import I18n from '../../i18n';
import Button from '../../containers/Button';
import Avatar from '../../containers/Avatar';
import Touch from '../../utils/touch';
-import { iconsMap } from '../../Icons';
@connect(state => ({
user: {
@@ -63,7 +62,7 @@ export default class ProfileView extends LoggedView {
this.props.navigator.setButtons({
leftButtons: [{
id: 'sideMenu',
- icon: Platform.OS === 'ios' ? iconsMap.menu : undefined
+ icon: { uri: 'settings', scale: Dimensions.get('window').scale }
}]
});
}
@@ -94,9 +93,7 @@ export default class ProfileView extends LoggedView {
if (event.type === 'NavBarButtonPress') {
if (event.id === 'sideMenu' && Platform.OS === 'ios') {
this.props.navigator.toggleDrawer({
- side: 'left',
- animated: true,
- to: 'missing'
+ side: 'left'
});
}
}
diff --git a/app/views/RoomActionsView/index.js b/app/views/RoomActionsView/index.js
index 0af3cd38..93af3e2b 100644
--- a/app/views/RoomActionsView/index.js
+++ b/app/views/RoomActionsView/index.js
@@ -20,7 +20,6 @@ import I18n from '../../i18n';
import scrollPersistTaps from '../../utils/scrollPersistTaps';
const renderSeparator = () => ;
-const getRoomTitle = room => (room.t === 'd' ? {room.fname} : {room.name});
@connect(state => ({
userId: state.login.user && state.login.user.id,
@@ -347,7 +346,13 @@ export default class RoomActionsView extends LoggedView {
{t === 'd' ? : null }
,
- { getRoomTitle(room) }
+ {room.t === 'd' ?
+ {room.fname} :
+
+
+ {room.name}
+
+ }
{t === 'd' ? `@${ name }` : topic}
,
diff --git a/app/views/RoomActionsView/styles.js b/app/views/RoomActionsView/styles.js
index 50182bee..70cd2789 100644
--- a/app/views/RoomActionsView/styles.js
+++ b/app/views/RoomActionsView/styles.js
@@ -51,5 +51,9 @@ export default StyleSheet.create({
roomDescription: {
fontSize: 12,
color: '#ccc'
+ },
+ roomTitleRow: {
+ flexDirection: 'row',
+ alignItems: 'center'
}
});
diff --git a/app/views/RoomInfoView/index.js b/app/views/RoomInfoView/index.js
index 11a72da6..69343c69 100644
--- a/app/views/RoomInfoView/index.js
+++ b/app/views/RoomInfoView/index.js
@@ -23,8 +23,10 @@ const camelize = str => str.replace(/^(.)/, (match, chr) => chr.toUpperCase());
const getRoomTitle = room => (room.t === 'd' ?
{room.fname} :
[
- ,
- {room.name}
+
+
+ {room.name}
+
]
);
diff --git a/app/views/RoomInfoView/styles.js b/app/views/RoomInfoView/styles.js
index 6e0c81dd..bd2e8e42 100644
--- a/app/views/RoomInfoView/styles.js
+++ b/app/views/RoomInfoView/styles.js
@@ -38,6 +38,10 @@ export default StyleSheet.create({
color: '#ccc',
paddingTop: 10
},
+ roomTitleRow: {
+ flexDirection: 'row',
+ alignItems: 'center'
+ },
status: {
borderRadius: 24,
width: 24,
diff --git a/app/views/RoomMembersView/index.js b/app/views/RoomMembersView/index.js
index 5c6ce2f6..65e8a235 100644
--- a/app/views/RoomMembersView/index.js
+++ b/app/views/RoomMembersView/index.js
@@ -1,12 +1,11 @@
import React from 'react';
import PropTypes from 'prop-types';
import { FlatList, View, TextInput, Vibration, SafeAreaView } from 'react-native';
-import { connect } from 'react-redux';
import ActionSheet from 'react-native-actionsheet';
import LoggedView from '../View';
import styles from './styles';
-import RoomItem from '../../presentation/RoomItem';
+import UserItem from '../../presentation/UserItem';
import scrollPersistTaps from '../../utils/scrollPersistTaps';
import RocketChat from '../../lib/rocketchat';
import database from '../../lib/realm';
@@ -14,10 +13,6 @@ import { showToast } from '../../utils/info';
import log from '../../utils/log';
import I18n from '../../i18n';
-
-@connect(state => ({
- baseUrl: state.settings.Site_Url || state.server ? state.server.server : ''
-}))
/** @extends React.Component */
export default class RoomMembersView extends LoggedView {
static navigatorButtons = {
@@ -31,8 +26,7 @@ export default class RoomMembersView extends LoggedView {
static propTypes = {
navigator: PropTypes.object,
rid: PropTypes.string,
- members: PropTypes.array,
- baseUrl: PropTypes.string
+ members: PropTypes.array
}
constructor(props) {
@@ -187,16 +181,11 @@ export default class RoomMembersView extends LoggedView {
renderSeparator = () => ;
renderItem = ({ item }) => (
- this.onPressUser(item)}
onLongPress={() => this.onLongPressUser(item)}
- id={item._id}
- showLastMessage={false}
- avatarSize={30}
- statusStyle={styles.status}
testID={`room-members-view-item-${ item.username }`}
/>
)
diff --git a/app/views/RoomMembersView/styles.js b/app/views/RoomMembersView/styles.js
index 07e5c1e5..9c09f02c 100644
--- a/app/views/RoomMembersView/styles.js
+++ b/app/views/RoomMembersView/styles.js
@@ -24,7 +24,8 @@ export default StyleSheet.create({
},
separator: {
height: StyleSheet.hairlineWidth,
- backgroundColor: '#ddd'
+ backgroundColor: '#E1E5E8',
+ marginLeft: 60
},
username: {
flex: 1,
diff --git a/app/views/RoomsListView/Header/Header.android.js b/app/views/RoomsListView/Header/Header.android.js
new file mode 100644
index 00000000..40c2169a
--- /dev/null
+++ b/app/views/RoomsListView/Header/Header.android.js
@@ -0,0 +1,50 @@
+import React from 'react';
+import { Text, View, TouchableOpacity, Image, StyleSheet } from 'react-native';
+import PropTypes from 'prop-types';
+
+const styles = StyleSheet.create({
+ container: {
+ flex: 1,
+ justifyContent: 'center'
+ },
+ button: {
+ flexDirection: 'row',
+ alignItems: 'center'
+ },
+ server: {
+ fontSize: 20,
+ color: '#FFF'
+ },
+ disclosure: {
+ marginLeft: 9,
+ marginTop: 1,
+ width: 10,
+ height: 5
+ },
+ upsideDown: {
+ transform: [{ scaleY: -1 }]
+ }
+});
+
+const Header = ({ onPress, serverName, showServerDropdown }) => (
+
+
+
+ {serverName}
+
+
+
+
+);
+
+Header.propTypes = {
+ onPress: PropTypes.func.isRequired,
+ serverName: PropTypes.string,
+ showServerDropdown: PropTypes.bool.isRequired
+};
+
+Header.defaultProps = {
+ serverName: 'Rocket.Chat'
+};
+
+export default Header;
diff --git a/app/views/RoomsListView/Header/Header.ios.js b/app/views/RoomsListView/Header/Header.ios.js
new file mode 100644
index 00000000..c9594f0f
--- /dev/null
+++ b/app/views/RoomsListView/Header/Header.ios.js
@@ -0,0 +1,56 @@
+import React from 'react';
+import { Text, View, TouchableOpacity, Image, StyleSheet } from 'react-native';
+import PropTypes from 'prop-types';
+
+import I18n from '../../../i18n';
+
+const styles = StyleSheet.create({
+ container: {
+ flex: 1,
+ alignItems: 'center'
+ },
+ button: {
+ flexDirection: 'row'
+ },
+ title: {
+ fontSize: 14,
+ color: '#0C0D0F'
+ },
+ server: {
+ fontSize: 12,
+ color: '#1D74F5'
+ },
+ disclosure: {
+ marginLeft: 3,
+ marginTop: 2,
+ width: 12,
+ height: 9
+ },
+ upsideDown: {
+ transform: [{ scaleY: -1 }]
+ }
+});
+
+const Header = ({ onPress, serverName, showServerDropdown }) => (
+
+ {I18n.t('Messages')}
+
+
+ {serverName}
+
+
+
+
+);
+
+Header.propTypes = {
+ onPress: PropTypes.func.isRequired,
+ serverName: PropTypes.string,
+ showServerDropdown: PropTypes.bool.isRequired
+};
+
+Header.defaultProps = {
+ serverName: 'Rocket.Chat'
+};
+
+export default Header;
diff --git a/app/views/RoomsListView/Header/index.js b/app/views/RoomsListView/Header/index.js
new file mode 100644
index 00000000..b00ef959
--- /dev/null
+++ b/app/views/RoomsListView/Header/index.js
@@ -0,0 +1,53 @@
+import React, { Component } from 'react';
+import PropTypes from 'prop-types';
+import { connect } from 'react-redux';
+
+import { toggleServerDropdown, closeServerDropdown, closeSortDropdown } from '../../../actions/rooms';
+import Header from './Header';
+
+@connect(state => ({
+ showServerDropdown: state.rooms.showServerDropdown,
+ showSortDropdown: state.rooms.showSortDropdown,
+ serverName: state.settings.Site_Name
+}), dispatch => ({
+ close: () => dispatch(closeServerDropdown()),
+ open: () => dispatch(toggleServerDropdown()),
+ closeSort: () => dispatch(closeSortDropdown())
+}))
+export default class RoomsListHeaderView extends Component {
+ static propTypes = {
+ showServerDropdown: PropTypes.bool,
+ showSortDropdown: PropTypes.bool,
+ serverName: PropTypes.string,
+ open: PropTypes.func,
+ close: PropTypes.func,
+ closeSort: PropTypes.func
+ }
+
+ onPress = () => {
+ const {
+ showServerDropdown, showSortDropdown, close, open, closeSort
+ } = this.props;
+ if (showServerDropdown) {
+ close();
+ } else if (showSortDropdown) {
+ closeSort();
+ setTimeout(() => {
+ open();
+ }, 300);
+ } else {
+ open();
+ }
+ }
+
+ render() {
+ const { serverName, showServerDropdown } = this.props;
+ return (
+
+ );
+ }
+}
diff --git a/app/views/RoomsListView/Search/index.js b/app/views/RoomsListView/Search/index.js
index cd69be4d..8d71c85e 100644
--- a/app/views/RoomsListView/Search/index.js
+++ b/app/views/RoomsListView/Search/index.js
@@ -33,6 +33,7 @@ export default class RoomsListSearchView extends React.Component {
onChangeText={text => this.onSearchChangeText(text)}
returnKeyType='search'
placeholder={I18n.t('Search')}
+ placeholderTextColor='#eee'
clearButtonMode='while-editing'
blurOnSubmit
autoCorrect={false}
diff --git a/app/views/RoomsListView/Search/styles.js b/app/views/RoomsListView/Search/styles.js
index 3a4b29c6..4d35f2ea 100644
--- a/app/views/RoomsListView/Search/styles.js
+++ b/app/views/RoomsListView/Search/styles.js
@@ -10,6 +10,6 @@ export default StyleSheet.create({
inputSearch: {
flex: 1,
fontSize: 18,
- color: '#444'
+ color: '#fff'
}
});
diff --git a/app/views/RoomsListView/ServerDropdown.js b/app/views/RoomsListView/ServerDropdown.js
new file mode 100644
index 00000000..b399780e
--- /dev/null
+++ b/app/views/RoomsListView/ServerDropdown.js
@@ -0,0 +1,169 @@
+import React, { Component } from 'react';
+import { View, Text, Animated, Easing, TouchableWithoutFeedback, TouchableOpacity, FlatList, Image, AsyncStorage } from 'react-native';
+import PropTypes from 'prop-types';
+import { connect } from 'react-redux';
+
+import styles from './styles';
+import { toggleServerDropdown } from '../../actions/rooms';
+import { selectServerRequest } from '../../actions/server';
+import { appStart } from '../../actions';
+import database from '../../lib/realm';
+import Touch from '../../utils/touch';
+import RocketChat from '../../lib/rocketchat';
+import I18n from '../../i18n';
+
+const ROW_HEIGHT = 68;
+const ANIMATION_DURATION = 200;
+
+@connect(state => ({
+ closeServerDropdown: state.rooms.closeServerDropdown,
+ server: state.server.server
+}), dispatch => ({
+ toggleServerDropdown: () => dispatch(toggleServerDropdown()),
+ selectServerRequest: server => dispatch(selectServerRequest(server)),
+ appStart: () => dispatch(appStart('outside'))
+}))
+export default class ServerDropdown extends Component {
+ static propTypes = {
+ navigator: PropTypes.object,
+ closeServerDropdown: PropTypes.bool,
+ server: PropTypes.string,
+ toggleServerDropdown: PropTypes.func,
+ selectServerRequest: PropTypes.func,
+ appStart: PropTypes.func
+ }
+
+ constructor(props) {
+ super(props);
+ this.state = {
+ servers: []
+ };
+ this.animatedValue = new Animated.Value(0);
+ }
+
+ componentDidMount() {
+ Animated.timing(
+ this.animatedValue,
+ {
+ toValue: 1,
+ duration: ANIMATION_DURATION,
+ easing: Easing.ease,
+ useNativeDriver: true
+ },
+ ).start();
+ this.servers = database.databases.serversDB.objects('servers');
+ this.servers.addListener(this.updateState);
+ }
+
+ componentDidUpdate(prevProps) {
+ if (prevProps.closeServerDropdown !== this.props.closeServerDropdown) {
+ this.close();
+ }
+ }
+
+ updateState = () => {
+ const { servers } = this;
+ this.setState({ servers });
+ }
+
+ close = () => {
+ Animated.timing(
+ this.animatedValue,
+ {
+ toValue: 0,
+ duration: ANIMATION_DURATION,
+ easing: Easing.ease,
+ useNativeDriver: true
+ }
+ ).start(() => this.props.toggleServerDropdown());
+ }
+
+ addServer = () => {
+ this.close();
+ setTimeout(() => {
+ this.props.navigator.showModal({
+ screen: 'NewServerView',
+ title: I18n.t('Add_Server'),
+ passProps: {
+ previousServer: this.props.server
+ }
+ });
+ }, ANIMATION_DURATION);
+ }
+
+ select = async(server) => {
+ this.close();
+ if (this.props.server !== server) {
+ this.props.selectServerRequest(server);
+ const token = await AsyncStorage.getItem(`${ RocketChat.TOKEN_KEY }-${ server }`);
+ if (!token) {
+ this.props.appStart();
+ setTimeout(() => {
+ this.props.navigator.push({
+ screen: 'NewServerView',
+ passProps: {
+ server
+ },
+ navigatorStyle: {
+ navBarHidden: true
+ }
+ });
+ }, 1000);
+ }
+ }
+ }
+
+ renderSeparator = () => ;
+
+ renderServer = ({ item }) => (
+ this.select(item.id)} style={styles.serverItem} testID={`rooms-list-header-server-${ item.id }`}>
+
+
+
+ {item.name || item.id}
+ {item.id}
+
+ {item.id === this.props.server ? : null}
+
+
+ )
+
+ render() {
+ const maxRows = 4;
+ const initialTop = 41 + (Math.min(this.state.servers.length, maxRows) * ROW_HEIGHT);
+ const translateY = this.animatedValue.interpolate({
+ inputRange: [0, 1],
+ outputRange: [-initialTop, 0]
+ });
+ const backdropOpacity = this.animatedValue.interpolate({
+ inputRange: [0, 1],
+ outputRange: [0, 0.3]
+ });
+ return (
+ [
+
+
+ ,
+
+
+ {I18n.t('Server')}
+
+ {I18n.t('Add_Server')}
+
+
+ item.id}
+ renderItem={this.renderServer}
+ ItemSeparatorComponent={this.renderSeparator}
+ />
+
+ ]
+ );
+ }
+}
diff --git a/app/views/RoomsListView/SortDropdown.js b/app/views/RoomsListView/SortDropdown.js
new file mode 100644
index 00000000..5ecc37c9
--- /dev/null
+++ b/app/views/RoomsListView/SortDropdown.js
@@ -0,0 +1,166 @@
+import React, { Component } from 'react';
+import { View, Text, Animated, Easing, Image, TouchableWithoutFeedback } from 'react-native';
+import PropTypes from 'prop-types';
+import { connect } from 'react-redux';
+
+import Touch from '../../utils/touch';
+import styles from './styles';
+import RocketChat from '../../lib/rocketchat';
+import { setPreference } from '../../actions/login';
+import log from '../../utils/log';
+import I18n from '../../i18n';
+
+const ANIMATION_DURATION = 200;
+
+@connect(state => ({
+ closeSortDropdown: state.rooms.closeSortDropdown
+}), dispatch => ({
+ setPreference: preference => dispatch(setPreference(preference))
+}))
+export default class Sort extends Component {
+ static propTypes = {
+ closeSortDropdown: PropTypes.bool,
+ close: PropTypes.func,
+ sidebarSortby: PropTypes.string,
+ sidebarGroupByType: PropTypes.bool,
+ sidebarShowFavorites: PropTypes.bool,
+ sidebarShowUnread: PropTypes.bool,
+ setPreference: PropTypes.func
+ }
+
+ constructor(props) {
+ super(props);
+ this.animatedValue = new Animated.Value(0);
+ }
+
+ componentDidMount() {
+ Animated.timing(
+ this.animatedValue,
+ {
+ toValue: 1,
+ duration: ANIMATION_DURATION,
+ easing: Easing.ease,
+ useNativeDriver: true
+ },
+ ).start();
+ }
+
+ componentDidUpdate(prevProps) {
+ if (prevProps.closeSortDropdown !== this.props.closeSortDropdown) {
+ this.close();
+ }
+ }
+
+ saveUserPreference = async(param) => {
+ try {
+ this.props.setPreference(param);
+ await RocketChat.saveUserPreferences(param);
+ } catch (e) {
+ log('RoomsListView.saveUserPreference', e);
+ }
+ }
+
+ sortByName = () => {
+ this.saveUserPreference({ sidebarSortby: 'alphabetical' });
+ }
+
+ sortByActivity = () => {
+ this.saveUserPreference({ sidebarSortby: 'activity' });
+ }
+
+ toggleGroupByType = () => {
+ this.saveUserPreference({ sidebarGroupByType: !this.props.sidebarGroupByType });
+ }
+
+ toggleGroupByFavorites = () => {
+ this.saveUserPreference({ sidebarShowFavorites: !this.props.sidebarShowFavorites });
+ }
+
+ toggleUnread = () => {
+ this.saveUserPreference({ sidebarShowUnread: !this.props.sidebarShowUnread });
+ }
+
+ close = () => {
+ Animated.timing(
+ this.animatedValue,
+ {
+ toValue: 0,
+ duration: ANIMATION_DURATION,
+ easing: Easing.ease,
+ useNativeDriver: true
+ },
+ ).start(() => this.props.close());
+ }
+
+ render() {
+ const translateY = this.animatedValue.interpolate({
+ inputRange: [0, 1],
+ outputRange: [-245, 41]
+ });
+ const backdropOpacity = this.animatedValue.interpolate({
+ inputRange: [0, 1],
+ outputRange: [0, 0.3]
+ });
+ const {
+ sidebarSortby, sidebarGroupByType, sidebarShowFavorites, sidebarShowUnread
+ } = this.props;
+ return (
+ [
+
+
+ ,
+
+
+
+
+ {I18n.t('Alphabetical')}
+ {sidebarSortby === 'alphabetical' ? : null}
+
+
+
+
+
+ {I18n.t('Activity')}
+ {sidebarSortby === 'activity' ? : null}
+
+
+
+
+
+
+ {I18n.t('Group_by_type')}
+ {sidebarGroupByType ? : null}
+
+
+
+
+
+ {I18n.t('Group_by_favorites')}
+ {sidebarShowFavorites ? : null}
+
+
+
+
+
+ {I18n.t('Unread_on_top')}
+ {sidebarShowUnread ? : null}
+
+
+ ,
+
+
+ {I18n.t('Sorting_by', { key: I18n.t(this.props.sidebarSortby === 'alphabetical' ? 'name' : 'activity') })}
+
+
+
+ ]
+ );
+ }
+}
diff --git a/app/views/RoomsListView/index.js b/app/views/RoomsListView/index.js
index de7daa4d..f82dd681 100644
--- a/app/views/RoomsListView/index.js
+++ b/app/views/RoomsListView/index.js
@@ -1,36 +1,99 @@
import React from 'react';
import PropTypes from 'prop-types';
-import { Platform, View, TextInput, FlatList, BackHandler, ActivityIndicator, SafeAreaView } from 'react-native';
+import { Platform, View, TextInput, FlatList, BackHandler, ActivityIndicator, SafeAreaView, Text, Image, Dimensions, ScrollView, Keyboard } from 'react-native';
import { connect } from 'react-redux';
+import { isEqual } from 'lodash';
-import { iconsMap } from '../../Icons';
import database from '../../lib/realm';
import RocketChat from '../../lib/rocketchat';
import RoomItem from '../../presentation/RoomItem';
import styles from './styles';
-import debounce from '../../utils/debounce';
import LoggedView from '../View';
import log from '../../utils/log';
import I18n from '../../i18n';
+import SortDropdown from './SortDropdown';
+import ServerDropdown from './ServerDropdown';
+import Touch from '../../utils/touch';
+import { toggleSortDropdown } from '../../actions/rooms';
-const ROW_HEIGHT = 70.5;
+const ROW_HEIGHT = 70;
-@connect(state => ({
- userId: state.login.user && state.login.user.id,
- server: state.server.server,
- Site_Url: state.settings.Site_Url,
- searchText: state.rooms.searchText,
- loadingServer: state.server.loading
+const isAndroid = () => Platform.OS === 'android';
+const getItemLayout = (data, index) => ({ length: ROW_HEIGHT, offset: ROW_HEIGHT * index, index });
+const leftButtons = [{
+ id: 'settings',
+ icon: { uri: 'settings', scale: Dimensions.get('window').scale },
+ testID: 'rooms-list-view-sidebar'
+}];
+const rightButtons = [{
+ id: 'createChannel',
+ icon: { uri: 'new_channel', scale: Dimensions.get('window').scale },
+ testID: 'rooms-list-view-create-channel'
+}];
+
+if (Platform.OS === 'android') {
+ rightButtons.push({
+ id: 'search',
+ icon: { uri: 'search', scale: Dimensions.get('window').scale }
+ });
+}
+
+
+@connect((state) => {
+ let result = {
+ userId: state.login.user && state.login.user.id,
+ server: state.server.server,
+ Site_Url: state.settings.Site_Url,
+ searchText: state.rooms.searchText,
+ loadingServer: state.server.loading,
+ showServerDropdown: state.rooms.showServerDropdown,
+ showSortDropdown: state.rooms.showSortDropdown,
+ sidebarSortby: null,
+ sidebarGroupByType: null,
+ sidebarShowFavorites: null,
+ sidebarShowUnread: null
+ };
+ if (state.login && state.login.user && state.login.user.settings && state.login.user.settings.preferences) {
+ result = {
+ ...result,
+ sidebarSortby: state.login.user.settings.preferences.sidebarSortby,
+ sidebarGroupByType: state.login.user.settings.preferences.sidebarGroupByType,
+ sidebarShowFavorites: state.login.user.settings.preferences.sidebarShowFavorites,
+ sidebarShowUnread: state.login.user.settings.preferences.sidebarShowUnread
+ };
+ }
+ return result;
+}, dispatch => ({
+ toggleSortDropdown: () => dispatch(toggleSortDropdown())
}))
/** @extends React.Component */
export default class RoomsListView extends LoggedView {
+ static navigatorButtons = {
+ leftButtons, rightButtons
+ }
+
+ static navigatorStyle = {
+ navBarCustomView: 'RoomsListHeaderView',
+ navBarComponentAlignment: 'fill',
+ navBarBackgroundColor: isAndroid() ? '#2F343D' : undefined,
+ navBarTextColor: isAndroid() ? '#FFF' : undefined,
+ navBarButtonColor: isAndroid() ? '#FFF' : undefined
+ }
+
static propTypes = {
navigator: PropTypes.object,
userId: PropTypes.string,
Site_Url: PropTypes.string,
server: PropTypes.string,
searchText: PropTypes.string,
- loadingServer: PropTypes.bool
+ loadingServer: PropTypes.bool,
+ showServerDropdown: PropTypes.bool,
+ showSortDropdown: PropTypes.bool,
+ sidebarSortby: PropTypes.string,
+ sidebarGroupByType: PropTypes.bool,
+ sidebarShowFavorites: PropTypes.bool,
+ sidebarShowUnread: PropTypes.bool,
+ toggleSortDropdown: PropTypes.func
}
constructor(props) {
@@ -38,13 +101,19 @@ export default class RoomsListView extends LoggedView {
this.state = {
search: [],
- rooms: [],
- loading: true
+ loading: true,
+ chats: [],
+ unread: [],
+ favorites: [],
+ channels: [],
+ privateGroup: [],
+ direct: [],
+ livechat: []
};
props.navigator.setOnNavigatorEvent(this.onNavigatorEvent.bind(this));
}
- async componentWillMount() {
+ componentWillMount() {
this.initDefaultHeader();
}
@@ -52,21 +121,42 @@ export default class RoomsListView extends LoggedView {
this.getSubscriptions();
}
- componentWillReceiveProps(props) {
- if (props.server && props.loadingServer) {
- this.setState({ loading: true });
- } else if (props.server && !props.loadingServer) {
+ componentWillReceiveProps(nextProps) {
+ if (nextProps.server && this.props.loadingServer !== nextProps.loadingServer) {
+ if (nextProps.loadingServer) {
+ this.setState({ loading: true });
+ } else {
+ this.getSubscriptions();
+ }
+ } else if (this.props.searchText !== nextProps.searchText) {
+ this.search(nextProps.searchText);
+ }
+ }
+
+ shouldComponentUpdate(nextProps, nextState) {
+ return !(isEqual(this.props, nextProps) && isEqual(this.state, nextState));
+ }
+
+ componentDidUpdate(prevProps) {
+ if (!(
+ (prevProps.sidebarSortby === this.props.sidebarSortby) &&
+ (prevProps.sidebarGroupByType === this.props.sidebarGroupByType) &&
+ (prevProps.sidebarShowFavorites === this.props.sidebarShowFavorites) &&
+ (prevProps.sidebarShowUnread === this.props.sidebarShowUnread)
+ )) {
this.getSubscriptions();
- } else if (this.props.searchText !== props.searchText) {
- this.search(props.searchText);
}
}
componentWillUnmount() {
- this.updateState.stop();
- if (this.data) {
- this.data.removeAllListeners();
- }
+ this.removeListener(this.data);
+ this.removeListener(this.unread);
+ this.removeListener(this.favorites);
+ this.removeListener(this.channels);
+ this.removeListener(this.privateGroup);
+ this.removeListener(this.direct);
+ this.removeListener(this.livechat);
+
if (this.timeout) {
clearTimeout(this.timeout);
}
@@ -76,26 +166,24 @@ export default class RoomsListView extends LoggedView {
const { navigator } = this.props;
if (event.type === 'NavBarButtonPress') {
if (event.id === 'createChannel') {
- navigator.push({
+ this.props.navigator.push({
screen: 'SelectedUsersView',
title: I18n.t('Select_Users'),
passProps: {
nextAction: 'CREATE_CHANNEL'
}
});
- } else if (event.id === 'sideMenu' && Platform.OS === 'ios') {
+ } else if (event.id === 'settings') {
navigator.toggleDrawer({
- side: 'left',
- animated: true,
- to: 'missing'
+ side: 'left'
});
} else if (event.id === 'search') {
this.initSearchingAndroid();
- } else if (event.id === 'cancelSearch') {
+ } else if (event.id === 'cancelSearch' || event.id === 'back') {
this.cancelSearchingAndroid();
}
} else if (event.type === 'ScreenChangedEvent' && event.id === 'didAppear') {
- this.props.navigator.setDrawerEnabled({
+ navigator.setDrawerEnabled({
side: 'left',
enabled: true
});
@@ -107,40 +195,100 @@ export default class RoomsListView extends LoggedView {
}
getSubscriptions = () => {
- if (this.data && this.data.removeListener) {
- this.data.removeListener(this.updateState);
- }
if (this.props.server && this.hasActiveDB()) {
- this.data = database.objects('subscriptions').filtered('archived != true && open == true').sorted('roomUpdatedAt', true);
- this.data.addListener(this.updateState);
+ if (this.props.sidebarSortby === 'alphabetical') {
+ this.data = database.objects('subscriptions').filtered('archived != true && open == true').sorted('name', false);
+ } else {
+ this.data = database.objects('subscriptions').filtered('archived != true && open == true').sorted('roomUpdatedAt', true);
+ }
+
+ let chats = [];
+ let unread = [];
+ let favorites = [];
+ let channels = [];
+ let privateGroup = [];
+ let direct = [];
+ let livechat = [];
+
+ // unread
+ if (this.props.sidebarShowUnread) {
+ this.unread = this.data.filtered('archived != true && open == true').sorted('name', false).filtered('(unread > 0 || alert == true)');
+ unread = this.unread.slice();
+ setTimeout(() => {
+ this.unread.addListener(() => this.setState({ unread: this.unread.slice() }));
+ });
+ } else {
+ this.removeListener(unread);
+ }
+ // favorites
+ if (this.props.sidebarShowFavorites) {
+ this.favorites = this.data.filtered('f == true');
+ favorites = this.favorites.slice();
+ setTimeout(() => {
+ this.favorites.addListener(() => this.setState({ favorites: this.favorites.slice() }));
+ });
+ } else {
+ this.removeListener(favorites);
+ }
+ // type
+ if (this.props.sidebarGroupByType) {
+ // channels
+ this.channels = this.data.filtered('t == $0', 'c');
+ channels = this.channels.slice();
+ // private
+ this.privateGroup = this.data.filtered('t == $0', 'p');
+ privateGroup = this.privateGroup.slice();
+ // direct
+ this.direct = this.data.filtered('t == $0', 'd');
+ direct = this.direct.slice();
+ // livechat
+ this.livechat = this.data.filtered('t == $0', 'l');
+ livechat = this.livechat.slice();
+ setTimeout(() => {
+ this.channels.addListener(() => this.setState({ channels: this.channels.slice() }));
+ this.privateGroup.addListener(() => this.setState({ privateGroup: this.privateGroup.slice() }));
+ this.direct.addListener(() => this.setState({ direct: this.direct.slice() }));
+ this.livechat.addListener(() => this.setState({ livechat: this.livechat.slice() }));
+ });
+ this.removeListener(this.chats);
+ } else {
+ // chats
+ this.chats = this.data.filtered('(unread == 0 && alert == false)');
+ chats = this.chats.slice();
+ setTimeout(() => {
+ this.chats.addListener(() => this.setState({ chats: this.chats.slice() }));
+ });
+ this.removeListener(this.channels);
+ this.removeListener(this.privateGroup);
+ this.removeListener(this.direct);
+ this.removeListener(this.livechat);
+ }
+
+ // setState
+ this.setState({
+ chats, unread, favorites, channels, privateGroup, direct, livechat
+ });
}
this.timeout = setTimeout(() => {
this.setState({ loading: false });
}, 200);
}
+ removeListener = (data) => {
+ if (data && data.removeAllListeners) {
+ data.removeAllListeners();
+ }
+ }
+
initDefaultHeader = () => {
const { navigator } = this.props;
- const rightButtons = [{
- id: 'createChannel',
- icon: iconsMap.add,
- testID: 'rooms-list-view-create-channel'
- }];
-
- if (Platform.OS === 'android') {
- rightButtons.push({
- id: 'search',
- icon: iconsMap.search
- });
- }
-
- navigator.setButtons({
- leftButtons: [{
- id: 'sideMenu',
- icon: Platform.OS === 'ios' ? iconsMap.menu : undefined,
- testID: 'rooms-list-view-sidebar'
- }],
- rightButtons
+ navigator.setButtons({ leftButtons, rightButtons });
+ navigator.setStyle({
+ navBarCustomView: 'RoomsListHeaderView',
+ navBarComponentAlignment: 'fill',
+ navBarBackgroundColor: isAndroid() ? '#2F343D' : undefined,
+ navBarTextColor: isAndroid() ? '#FFF' : undefined,
+ navBarButtonColor: isAndroid() ? '#FFF' : undefined
});
}
@@ -149,7 +297,7 @@ export default class RoomsListView extends LoggedView {
navigator.setButtons({
leftButtons: [{
id: 'cancelSearch',
- icon: iconsMap['md-arrow-back']
+ icon: { uri: 'back', scale: Dimensions.get('window').scale }
}],
rightButtons: []
});
@@ -165,11 +313,9 @@ export default class RoomsListView extends LoggedView {
cancelSearchingAndroid = () => {
if (Platform.OS === 'android') {
- this.props.navigator.setStyle({
- navBarCustomView: ''
- });
this.setState({ search: [] });
this.initDefaultHeader();
+ Keyboard.dismiss();
BackHandler.removeEventListener('hardwareBackPress', this.handleBackPress);
}
}
@@ -179,9 +325,7 @@ export default class RoomsListView extends LoggedView {
return true;
}
- updateState = debounce(() => {
- this.setState({ rooms: this.data.slice() });
- })
+ _isUnread = item => item.unread > 0 || item.alert
async search(text) {
const searchText = text.trim();
@@ -262,22 +406,47 @@ export default class RoomsListView extends LoggedView {
}
}
- renderSearchBar = () => (
-
- this.onSearchChangeText(text)}
- returnKeyType='search'
- placeholder={I18n.t('Search')}
- clearButtonMode='while-editing'
- blurOnSubmit
- autoCorrect={false}
- autoCapitalize='none'
- testID='rooms-list-view-search'
- />
-
- );
+ toggleSort = () => this.props.toggleSortDropdown();
+
+ renderHeader = () => {
+ if (this.state.search.length > 0) {
+ return null;
+ }
+ return this.renderSort();
+ }
+
+ renderSort = () => (
+
+
+ {I18n.t('Sorting_by', { key: I18n.t(this.props.sidebarSortby === 'alphabetical' ? 'name' : 'activity') })}
+
+
+
+ )
+
+ renderSearchBar = () => {
+ if (Platform.OS === 'ios') {
+ return (
+
+ this.onSearchChangeText(text)}
+ returnKeyType='search'
+ placeholder={I18n.t('Search')}
+ clearButtonMode='while-editing'
+ blurOnSubmit
+ autoCorrect={false}
+ autoCapitalize='none'
+ testID='rooms-list-view-search'
+ />
+
+ );
+ }
+ }
renderItem = ({ item }) => {
const id = item.rid.replace(this.props.userId, '').trim();
@@ -295,34 +464,109 @@ export default class RoomsListView extends LoggedView {
baseUrl={this.props.Site_Url}
onPress={() => this._onPressItem(item)}
testID={`rooms-list-view-item-${ item.name }`}
+ height={ROW_HEIGHT}
/>);
}
- renderList = () => {
- if (this.state.loading) {
- return ;
+ renderSeparator = () => ;
+
+ renderSection = (data, header) => {
+ if (data.length > 0) {
+ return (
+ item.rid}
+ style={styles.list}
+ renderItem={this.renderItem}
+ ItemSeparatorComponent={this.renderSeparator}
+ ListHeaderComponent={() => (
+
+ {I18n.t(header)}
+
+ )}
+ getItemLayout={getItemLayout}
+ enableEmptySections
+ removeClippedSubviews
+ keyboardShouldPersistTaps='always'
+ />
+ );
}
+ return null;
+ }
+
+ renderList = () => {
+ const {
+ search, chats, unread, favorites, channels, direct, privateGroup, livechat
+ } = this.state;
+
+ if (search.length > 0) {
+ return (
+ item.rid}
+ style={styles.list}
+ renderItem={this.renderItem}
+ ItemSeparatorComponent={this.renderSeparator}
+ getItemLayout={getItemLayout}
+ enableEmptySections
+ removeClippedSubviews
+ keyboardShouldPersistTaps='always'
+ />
+ );
+ }
+
return (
- 0 ? this.state.search : this.state.rooms}
- extraData={this.state.search.length > 0 ? this.state.search : this.state.rooms}
- keyExtractor={item => item.rid}
- style={styles.list}
- renderItem={this.renderItem}
- ListHeaderComponent={Platform.OS === 'ios' ? this.renderSearchBar : null}
- contentOffset={Platform.OS === 'ios' ? { x: 0, y: 38 } : {}}
- getItemLayout={(data, index) => ({ length: ROW_HEIGHT, offset: ROW_HEIGHT * index, index })}
- enableEmptySections
- removeClippedSubviews
- keyboardShouldPersistTaps='always'
- testID='rooms-list-view-list'
- />
+
+ {this.renderSection(unread, 'Unread')}
+ {this.renderSection(favorites, 'Favorites')}
+ {this.renderSection(channels, 'Channels')}
+ {this.renderSection(direct, 'Direct_Messages')}
+ {this.renderSection(privateGroup, 'Private_Groups')}
+ {this.renderSection(livechat, 'Livechat')}
+ {this.renderSection(chats, 'Chats')}
+
);
}
- render = () => (
-
- {this.renderList()}
-
- )
+ renderScroll = () => {
+ if (this.state.loading) {
+ return ;
+ }
+
+ return (
+
+ {this.renderSearchBar()}
+ {this.renderHeader()}
+ {this.renderList()}
+
+ );
+ }
+
+ render = () => {
+ const {
+ sidebarSortby, sidebarGroupByType, sidebarShowFavorites, sidebarShowUnread, showServerDropdown, showSortDropdown
+ } = this.props;
+
+ return (
+
+ {this.renderScroll()}
+ {showSortDropdown ?
+ :
+ null}
+ {showServerDropdown ? : null}
+
+ );
+ }
}
diff --git a/app/views/RoomsListView/styles.js b/app/views/RoomsListView/styles.js
index 9f7d8dfd..1f5afa5e 100644
--- a/app/views/RoomsListView/styles.js
+++ b/app/views/RoomsListView/styles.js
@@ -1,12 +1,16 @@
-import { StyleSheet } from 'react-native';
+import { StyleSheet, Platform } from 'react-native';
+
+const isIOS = () => Platform.OS === 'ios';
export default StyleSheet.create({
container: {
- flex: 1
+ flex: 1,
+ backgroundColor: isIOS() ? '#FFF' : '#E1E5E8'
},
separator: {
- height: 1,
- backgroundColor: '#E7E7E7'
+ height: StyleSheet.hairlineWidth,
+ backgroundColor: '#E1E5E8',
+ marginLeft: 78
},
list: {
width: '100%',
@@ -40,5 +44,129 @@ export default StyleSheet.create({
},
loading: {
flex: 1
+ },
+ dropdownContainerHeader: {
+ height: 41,
+ borderBottomWidth: StyleSheet.hairlineWidth,
+ borderColor: '#E1E5E8',
+ alignItems: 'center',
+ backgroundColor: isIOS() ? '#fff' : '#54585E',
+ flexDirection: 'row'
+ },
+ sortToggleContainerClose: {
+ position: 'absolute',
+ top: 0,
+ width: '100%'
+ },
+ sortToggleText: {
+ color: '#9EA2A8',
+ fontSize: 15,
+ fontWeight: 'normal',
+ flex: 1,
+ marginLeft: 15
+ },
+ dropdownContainer: {
+ backgroundColor: '#fff',
+ width: '100%',
+ position: 'absolute',
+ top: 0
+ },
+ sortItemButton: {
+ height: 57,
+ justifyContent: 'center'
+ },
+ sortItemContainer: {
+ flexDirection: 'row',
+ alignItems: 'center'
+ },
+ sortItemText: {
+ color: '#54585E',
+ fontSize: 18,
+ fontWeight: 'normal',
+ flex: 1
+ },
+ backdrop: {
+ ...StyleSheet.absoluteFill,
+ backgroundColor: '#000000'
+ },
+ sortSeparator: {
+ height: StyleSheet.hairlineWidth,
+ backgroundColor: '#CBCED1',
+ marginHorizontal: 15,
+ flex: 1
+ },
+ sortIcon: {
+ width: 20,
+ height: 20,
+ marginHorizontal: 15,
+ resizeMode: 'contain',
+ justifyContent: 'center'
+ },
+ groupTitleContainer: {
+ paddingHorizontal: 15,
+ paddingTop: 17,
+ paddingBottom: 10,
+ backgroundColor: isIOS() ? '#fff' : '#E1E5E8'
+ },
+ groupTitle: {
+ color: isIOS() ? '#2F343D' : '#54585E',
+ fontSize: isIOS() ? 22 : 15,
+ fontWeight: 'bold',
+ letterSpacing: 0.27,
+ flex: 1,
+ lineHeight: isIOS() ? 41 : 24
+ },
+ serverHeader: {
+ justifyContent: 'space-between'
+ },
+ serverHeaderText: {
+ color: '#9EA2A8',
+ fontSize: 15,
+ fontWeight: 'normal',
+ marginLeft: 15
+ },
+ serverHeaderAdd: {
+ color: isIOS() ? '#1D74F5' : '#FFF',
+ fontSize: 15,
+ fontWeight: 'normal',
+ marginRight: 15
+ },
+ serverItem: {
+ height: 68
+ },
+ serverItemContainer: {
+ flexDirection: 'row',
+ alignItems: 'center'
+ },
+ serverIcon: {
+ width: 42,
+ height: 42,
+ marginHorizontal: 15,
+ marginVertical: 13,
+ borderRadius: 4,
+ resizeMode: 'contain'
+ },
+ serverTextContainer: {
+ flex: 1,
+ flexDirection: 'column',
+ justifyContent: 'center'
+ },
+ serverName: {
+ fontSize: 18, fontWeight: '600', color: '#0C0D0F'
+ },
+ serverUrl: {
+ fontSize: 15,
+ color: '#9EA2A8'
+ },
+ checkIcon: {
+ width: 20,
+ height: 20,
+ marginHorizontal: 15,
+ resizeMode: 'contain'
+ },
+ serverSeparator: {
+ height: StyleSheet.hairlineWidth,
+ backgroundColor: '#E1E5E8',
+ marginLeft: 72
}
});
diff --git a/app/views/SelectedUsersView.js b/app/views/SelectedUsersView.js
index 4aca98c5..beb94b16 100644
--- a/app/views/SelectedUsersView.js
+++ b/app/views/SelectedUsersView.js
@@ -6,7 +6,7 @@ import { connect } from 'react-redux';
import { addUser, removeUser, reset, setLoading } from '../actions/selectedUsers';
import database from '../lib/realm';
import RocketChat from '../lib/rocketchat';
-import RoomItem from '../presentation/RoomItem';
+import UserItem from '../presentation/UserItem';
import Avatar from '../containers/Avatar';
import Loading from '../containers/Loading';
import debounce from '../utils/debounce';
@@ -48,19 +48,14 @@ const styles = StyleSheet.create({
justifyContent: 'center',
alignItems: 'center'
},
- status: {
- bottom: -2,
- right: -2,
- borderWidth: 2,
- borderRadius: 12,
- width: 12,
- height: 12
+ separator: {
+ height: StyleSheet.hairlineWidth,
+ backgroundColor: '#E1E5E8',
+ marginLeft: 60
}
});
@connect(state => ({
- userId: state.login.user && state.login.user.id,
- Site_Url: state.settings.Site_Url,
users: state.selectedUsers.users,
loading: state.selectedUsers.loading
}), dispatch => ({
@@ -75,8 +70,6 @@ export default class SelectedUsersView extends LoggedView {
navigator: PropTypes.object,
rid: PropTypes.string,
nextAction: PropTypes.string.isRequired,
- userId: PropTypes.string,
- Site_Url: PropTypes.string,
addUser: PropTypes.func.isRequired,
removeUser: PropTypes.func.isRequired,
reset: PropTypes.func.isRequired,
@@ -270,20 +263,18 @@ export default class SelectedUsersView extends LoggedView {
);
+
+ renderSeparator = () => ;
+
renderItem = ({ item }) => (
- this._onPressItem(item._id, item)}
- id={item.rid.replace(this.props.userId, '').trim()}
- showLastMessage={false}
- avatarSize={30}
- statusStyle={styles.status}
testID={`select-users-view-item-${ item.name }`}
/>
- );
+ )
+
renderList = () => (
0 ? this.state.search : this.data}
@@ -292,6 +283,7 @@ export default class SelectedUsersView extends LoggedView {
style={styles.list}
renderItem={this.renderItem}
ListHeaderComponent={this.renderHeader}
+ ItemSeparatorComponent={this.renderSeparator}
enableEmptySections
keyboardShouldPersistTaps='always'
/>
diff --git a/app/views/SettingsView/index.js b/app/views/SettingsView/index.js
index e0afa28b..bf3b0691 100644
--- a/app/views/SettingsView/index.js
+++ b/app/views/SettingsView/index.js
@@ -1,6 +1,6 @@
import React from 'react';
import PropTypes from 'prop-types';
-import { View, ScrollView, SafeAreaView, Platform } from 'react-native';
+import { View, ScrollView, SafeAreaView, Platform, Dimensions } from 'react-native';
import RNPickerSelect from 'react-native-picker-select';
import { connect } from 'react-redux';
@@ -16,7 +16,6 @@ import Loading from '../../containers/Loading';
import { showErrorAlert, showToast } from '../../utils/info';
import log from '../../utils/log';
import { setUser } from '../../actions/login';
-import { iconsMap } from '../../Icons';
@connect(state => ({
userLanguage: state.login.user && state.login.user.language
@@ -52,7 +51,7 @@ export default class SettingsView extends LoggedView {
this.props.navigator.setButtons({
leftButtons: [{
id: 'sideMenu',
- icon: Platform.OS === 'ios' ? iconsMap.menu : undefined
+ icon: { uri: 'settings', scale: Dimensions.get('window').scale }
}]
});
}
@@ -68,9 +67,7 @@ export default class SettingsView extends LoggedView {
if (event.type === 'NavBarButtonPress') {
if (event.id === 'sideMenu' && Platform.OS === 'ios') {
this.props.navigator.toggleDrawer({
- side: 'left',
- animated: true,
- to: 'missing'
+ side: 'left'
});
}
}
diff --git a/app/views/TermsServiceView.js b/app/views/TermsServiceView.js
index aa906de6..1b7f1e6b 100644
--- a/app/views/TermsServiceView.js
+++ b/app/views/TermsServiceView.js
@@ -4,15 +4,21 @@ import { WebView, SafeAreaView } from 'react-native';
import { connect } from 'react-redux';
import styles from './Styles';
+import LoggedView from './View';
@connect(state => ({
termsService: state.settings.Layout_Terms_of_Service
}))
-export default class TermsServiceView extends React.PureComponent {
+/** @extends React.Component */
+export default class TermsServiceView extends LoggedView {
static propTypes = {
termsService: PropTypes.string
}
+ constructor(props) {
+ super('TermsServiceView', props);
+ }
+
render() {
return (
diff --git a/app/views/View.js b/app/views/View.js
index 34920d22..ae0a0449 100644
--- a/app/views/View.js
+++ b/app/views/View.js
@@ -1,10 +1,18 @@
import React from 'react';
+import { Platform } from 'react-native';
import PropTypes from 'prop-types';
import { Answers } from 'react-native-fabric';
import { NavigationActions } from '../Navigation';
+const isAndroid = () => Platform.OS === 'android';
+
/** @extends React.Component */
export default class extends React.Component {
+ static navigatorStyle = {
+ navBarBackgroundColor: isAndroid() ? '#2F343D' : undefined,
+ navBarTextColor: isAndroid() ? '#FFF' : undefined,
+ navBarButtonColor: isAndroid() ? '#FFF' : undefined
+ }
static propTypes = {
navigator: PropTypes.object
}
diff --git a/app/views/index.js b/app/views/index.js
index 1370a01d..1b47ee6c 100644
--- a/app/views/index.js
+++ b/app/views/index.js
@@ -18,6 +18,7 @@ import RoomFilesView from './RoomFilesView';
import RoomInfoEditView from './RoomInfoEditView';
import RoomInfoView from './RoomInfoView';
import RoomMembersView from './RoomMembersView';
+import RoomsListHeaderView from './RoomsListView/Header';
import RoomsListSearchView from './RoomsListView/Search';
import RoomsListView from './RoomsListView';
import RoomView from './RoomView';
@@ -47,6 +48,7 @@ export const registerScreens = (store) => {
Navigation.registerComponent('RoomInfoEditView', () => RoomInfoEditView, store, Provider);
Navigation.registerComponent('RoomInfoView', () => RoomInfoView, store, Provider);
Navigation.registerComponent('RoomMembersView', () => RoomMembersView, store, Provider);
+ Navigation.registerComponent('RoomsListHeaderView', () => RoomsListHeaderView, store, Provider);
Navigation.registerComponent('RoomsListSearchView', () => RoomsListSearchView, store, Provider);
Navigation.registerComponent('RoomsListView', () => RoomsListView, store, Provider);
Navigation.registerComponent('RoomView', () => RoomView, store, Provider);
diff --git a/e2e/05-roomslist.spec.js b/e2e/05-roomslist.spec.js
index c0281d4b..645e3593 100644
--- a/e2e/05-roomslist.spec.js
+++ b/e2e/05-roomslist.spec.js
@@ -6,10 +6,6 @@ const { login, navigateToLogin, tapBack } = require('./helpers/app');
const data = require('./data');
describe('Rooms list screen', () => {
- // before(async() => {
- // await device.reloadReactNative(); // TODO: remove this after fix logout subscription
- // });
-
describe('Render', async() => {
it('should have rooms list screen', async() => {
await expect(element(by.id('rooms-list-view'))).toBeVisible();
@@ -64,11 +60,11 @@ describe('Rooms list screen', () => {
// Usage - Sidebar
describe('Sidebar', async() => {
it('should navigate to add server', async() => {
- await element(by.id('rooms-list-view-sidebar')).tap();
- await waitFor(element(by.id('sidebar'))).toBeVisible().withTimeout(2000);
- await element(by.id('sidebar-toggle-server')).tap();
- await waitFor(element(by.id('sidebar-add-server'))).toBeVisible().withTimeout(2000);
- await element(by.id('sidebar-add-server')).tap();
+ await element(by.id('rooms-list-header-server-dropdown-button')).tap();
+ await waitFor(element(by.id('rooms-list-header-server-dropdown'))).toBeVisible().withTimeout(2000);
+ await expect(element(by.id('rooms-list-header-server-dropdown'))).toBeVisible();
+ await expect(element(by.id('rooms-list-header-server-add'))).toBeVisible();
+ await element(by.id('rooms-list-header-server-add')).tap();
await waitFor(element(by.id('new-server-view'))).toBeVisible().withTimeout(2000);
await expect(element(by.id('new-server-view'))).toBeVisible();
await element(by.text('Close')).tap();
@@ -93,6 +89,6 @@ describe('Rooms list screen', () => {
after(async() => {
await navigateToLogin();
await login();
- })
+ });
});
});
diff --git a/e2e/06-createroom.spec.js b/e2e/06-createroom.spec.js
index ffa510e3..19d15354 100644
--- a/e2e/06-createroom.spec.js
+++ b/e2e/06-createroom.spec.js
@@ -7,7 +7,6 @@ const { tapBack } = require('./helpers/app');
describe('Create room screen', () => {
before(async() => {
- // await device.reloadReactNative(); // TODO: remove this after fix logout subscription
await element(by.id('rooms-list-view-create-channel')).tap();
await waitFor(element(by.id('select-users-view'))).toBeVisible().withTimeout(2000);
});
diff --git a/e2e/10-changeserver.spec.js b/e2e/10-changeserver.spec.js
index fd13d61c..5368cc61 100644
--- a/e2e/10-changeserver.spec.js
+++ b/e2e/10-changeserver.spec.js
@@ -12,11 +12,9 @@ describe('Change server', () => {
it('should add server and create new user', async() => {
// Navigate to add server
- await element(by.id('rooms-list-view-sidebar')).tap();
- await waitFor(element(by.id('sidebar'))).toBeVisible().withTimeout(2000);
- await element(by.id('sidebar-toggle-server')).tap();
- await waitFor(element(by.id('sidebar-add-server'))).toBeVisible().withTimeout(2000);
- await element(by.id('sidebar-add-server')).tap();
+ await element(by.id('rooms-list-header-server-dropdown-button')).tap();
+ await waitFor(element(by.id('rooms-list-header-server-dropdown'))).toBeVisible().withTimeout(2000);
+ await element(by.id('rooms-list-header-server-add')).tap();
// Add server
await waitFor(element(by.id('new-server-view'))).toBeVisible().withTimeout(60000);
await element(by.id('new-server-view-input')).replaceText(data.alternateServer);
@@ -43,15 +41,10 @@ describe('Change server', () => {
});
it('should change server', async() => {
- await element(by.id('rooms-list-view-sidebar')).tap();
- await waitFor(element(by.id('sidebar'))).toBeVisible().withTimeout(2000);
- await element(by.id('sidebar-toggle-server')).tap();
- await waitFor(element(by.id(`sidebar-${ data.server }`))).toBeVisible().withTimeout(2000);
- // await expect(element(by.id(`sidebar-${ data.server }`))).toBeVisible();
- await element(by.id(`sidebar-${ data.server }`)).tap();
+ await element(by.id('rooms-list-header-server-dropdown-button')).tap();
+ await waitFor(element(by.id('rooms-list-header-server-dropdown'))).toBeVisible().withTimeout(2000);
+ await element(by.id(`rooms-list-header-server-${ data.server }`)).tap();
await waitFor(element(by.id('rooms-list-view'))).toBeVisible().withTimeout(10000);
- // await waitFor(element(by.id('rooms-list-view-sidebar').and(by.label(`Connected to ${ data.server }. Tap to view servers list.`)))).toBeVisible().withTimeout(60000);
- // await expect(element(by.id('rooms-list-view-sidebar'))).toHaveLabel(`Connected to ${ data.server }. Tap to view servers list.`);
// For a sanity test, to make sure roomslist is showing correct rooms
// app MUST show public room created on previous tests
await waitFor(element(by.id(`rooms-list-view-item-public${ data.random }`))).toBeVisible().withTimeout(60000);
diff --git a/e2e/11-broadcast.spec.js b/e2e/11-broadcast.spec.js
index bdc93d7f..d959e539 100644
--- a/e2e/11-broadcast.spec.js
+++ b/e2e/11-broadcast.spec.js
@@ -60,7 +60,7 @@ describe('Broadcast room', () => {
await element(by.id('login-view-password')).replaceText(data.alternateUserPassword);
await element(by.id('login-view-submit')).tap();
await waitFor(element(by.id('rooms-list-view'))).toBeVisible().withTimeout(10000);
- await device.reloadReactNative(); // remove after fix logout
+ // await device.reloadReactNative(); // remove after fix logout
await waitFor(element(by.id('rooms-list-view'))).toBeVisible().withTimeout(10000);
await waitFor(element(by.id(`rooms-list-view-item-broadcast${ data.random }`))).toBeVisible().withTimeout(60000);
await expect(element(by.id(`rooms-list-view-item-broadcast${ data.random }`))).toBeVisible();
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/Contents.json
new file mode 100644
index 00000000..da4a164c
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/Contents.json
@@ -0,0 +1,6 @@
+{
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/Contents.json
new file mode 100644
index 00000000..4e73a419
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "check.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "check@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "check@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check.png b/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check.png
new file mode 100644
index 00000000..b0278500
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check@2x.png
new file mode 100644
index 00000000..6f20b37a
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check@3x.png
new file mode 100644
index 00000000..83186d0b
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/check.imageset/check@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/Contents.json
new file mode 100644
index 00000000..b5adb786
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "disclosure_indicator.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "disclosure_indicator@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "disclosure_indicator@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator.png b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator.png
new file mode 100644
index 00000000..42caa067
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator@2x.png
new file mode 100644
index 00000000..585d4a79
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator@3x.png
new file mode 100644
index 00000000..3c863464
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator.imageset/disclosure_indicator@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/Contents.json
new file mode 100644
index 00000000..4443a947
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "disclosure_indicator_server.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "disclosure_indicator_server@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "disclosure_indicator_server@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server.png b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server.png
new file mode 100644
index 00000000..82612918
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server@2x.png
new file mode 100644
index 00000000..d46f9df0
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server@3x.png
new file mode 100644
index 00000000..4e3a017d
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/disclosure_indicator_server.imageset/disclosure_indicator_server@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/Contents.json
new file mode 100644
index 00000000..af5c4f28
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "group_favorites.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "group_favorites@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "group_favorites@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites.png b/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites.png
new file mode 100644
index 00000000..d139ea4d
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites@2x.png
new file mode 100644
index 00000000..359973c8
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites@3x.png
new file mode 100644
index 00000000..748eadcc
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_favorites.imageset/group_favorites@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/Contents.json
new file mode 100644
index 00000000..0fb47c7b
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "group_type.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "group_type@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "group_type@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type.png b/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type.png
new file mode 100644
index 00000000..f1be38bc
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type@2x.png
new file mode 100644
index 00000000..c0acc012
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type@3x.png
new file mode 100644
index 00000000..d92d228d
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_type.imageset/group_type@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/Contents.json
new file mode 100644
index 00000000..06fa3de2
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "group_unread.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "group_unread@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "group_unread@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread.png b/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread.png
new file mode 100644
index 00000000..5ea6d0f3
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread@2x.png
new file mode 100644
index 00000000..899c2863
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread@3x.png
new file mode 100644
index 00000000..e84f81f6
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/group_unread.imageset/group_unread@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/Contents.json
new file mode 100644
index 00000000..7d84a377
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "logo@1x.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "logo@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "logo@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@1x.png b/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@1x.png
new file mode 100644
index 00000000..6928d7b8
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@1x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@2x.png
new file mode 100644
index 00000000..e4502f69
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@3x.png
new file mode 100644
index 00000000..159d7d4a
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/logo@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/Contents.json
new file mode 100644
index 00000000..bc09b68e
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "new_channel.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "new_channel@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "new_channel@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel.png b/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel.png
new file mode 100644
index 00000000..13de9017
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel@2x.png
new file mode 100644
index 00000000..59c53df8
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel@3x.png
new file mode 100644
index 00000000..bb31860c
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/new_channel.imageset/new_channel@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/Contents.json
new file mode 100644
index 00000000..a683f09c
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "settings.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "settings@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "settings@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings.png b/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings.png
new file mode 100644
index 00000000..bdd68a2c
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings@2x.png
new file mode 100644
index 00000000..310f465e
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings@3x.png
new file mode 100644
index 00000000..c045eade
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/settings.imageset/settings@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/Contents.json
new file mode 100644
index 00000000..0409a6ff
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "sort_activity.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "sort_activity@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "sort_activity@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity.png b/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity.png
new file mode 100644
index 00000000..e64f442e
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity@2x.png
new file mode 100644
index 00000000..533d1aa6
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity@3x.png
new file mode 100644
index 00000000..dac1d40e
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/sort_activity.imageset/sort_activity@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/Contents.json
new file mode 100644
index 00000000..deac3a31
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "sort_alphabetically.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "sort_alphabetically@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "sort_alphabetically@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically.png b/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically.png
new file mode 100644
index 00000000..362ad237
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically@2x.png
new file mode 100644
index 00000000..36756311
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically@3x.png
new file mode 100644
index 00000000..2da108f0
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/sort_alphabetically.imageset/sort_alphabetically@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag.png b/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag.png
new file mode 100644
index 00000000..74953405
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag@2x.png
new file mode 100644
index 00000000..56e7b8cb
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag@3x.png
new file mode 100644
index 00000000..59983e22
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Cell Subscription Hashtag@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Contents.json
new file mode 100644
index 00000000..eac29d3f
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/subscription_hashtag.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "Cell Subscription Hashtag.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "Cell Subscription Hashtag@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "Cell Subscription Hashtag@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock.png b/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock.png
new file mode 100644
index 00000000..95368bae
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock@2x.png b/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock@2x.png
new file mode 100644
index 00000000..7a0dd92c
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock@2x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock@3x.png b/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock@3x.png
new file mode 100644
index 00000000..060a2b03
Binary files /dev/null and b/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Cell Subscription Lock@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Contents.json
new file mode 100644
index 00000000..148a6e73
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/Icons/subscription_lock.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "filename" : "Cell Subscription Lock.png",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "Cell Subscription Lock@2x.png",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "universal",
+ "filename" : "Cell Subscription Lock@3x.png",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/package-lock.json b/package-lock.json
index a0f3e543..7158b588 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -15999,9 +15999,8 @@
}
},
"react-native-navigation": {
- "version": "1.1.479",
- "resolved": "https://registry.npmjs.org/react-native-navigation/-/react-native-navigation-1.1.479.tgz",
- "integrity": "sha512-0Qdr8ybkSbwr2RhaTWfonNMCbIyky0zDTJaN5RTr3y2uz4wFAySDANB64wK/8xNz7uscE8mObDC3gLHTMRdb2Q==",
+ "version": "git+https://github.com/RocketChat/react-native-navigation.git#1a428f14ddda77511676d0c6d863083ce6225e32",
+ "from": "git+https://github.com/RocketChat/react-native-navigation.git",
"requires": {
"lodash": "4.x.x"
}
diff --git a/package.json b/package.json
index d75fbdf0..ffc2fed1 100644
--- a/package.json
+++ b/package.json
@@ -53,7 +53,7 @@
"react-native-markdown-renderer": "^3.2.8",
"react-native-meteor": "^1.4.0",
"react-native-modal": "^6.5.0",
- "react-native-navigation": "^1.1.479",
+ "react-native-navigation": "git+https://github.com/RocketChat/react-native-navigation.git",
"react-native-notifications": "git+https://github.com/RocketChat/react-native-notifications.git",
"react-native-optimized-flatlist": "^1.0.4",
"react-native-picker-select": "^4.2.0",