Styling in style.ts, minor refactor

This commit is contained in:
Imbus 2023-12-14 20:21:57 +01:00
parent f97c22f6e0
commit ce7888667d
4 changed files with 37 additions and 41 deletions

18
App.tsx
View file

@ -1,23 +1,15 @@
import { StatusBar } from 'expo-status-bar';
import { StyleSheet, Text, View } from 'react-native';
import { StatusBar } from "expo-status-bar";
import { Text, View } from "react-native";
import { style } from "./src/util/style";
import { PostsContainer } from './src/components/PostsContainer';
import { PostsContainer } from "./src/components/PostsContainer";
export default function App(): JSX.Element {
return (
<View style={styles.container}>
<View style={style.app}>
<Text>Open up App.tsx to start working on your app!</Text>
<StatusBar style="auto" />
<PostsContainer />
</View>
);
}
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: '#fff', // For the "entire" app
alignItems: 'center',
justifyContent: 'center',
},
});

View file

@ -1,7 +1,7 @@
import React from "react";
import { View, Text } from "react-native";
import { Post } from "../util/api";
import { StyleSheet } from "react-native";
import { style } from "../util/style";
/**
* This is the component that holds a single Post
@ -15,19 +15,8 @@ export function PostView({ post }: { post: Post }): JSX.Element {
const [thisPost, setThisPost] = React.useState<Post>(post);
return (
<View style={style.container}>
<Text style={style.font} >{thisPost.content}</Text>
<View style={style.postView}>
<Text style={style.postFont} >{thisPost.content}</Text>
</View>
);
}
const style = StyleSheet.create({
container: {
flexDirection: "row",
backgroundColor: '#fff',
paddingVertical: 5,
},
font: {
color: "#000",
}
});

View file

@ -2,7 +2,7 @@ import React from "react";
import { View, Text } from "react-native";
import { getPosts, Post } from "../util/api";
import { PostView } from "./PostView";
import { StyleSheet } from "react-native";
import { style } from "../util/style";
export function PostsContainer(): JSX.Element {
const [posts, setPosts] = React.useState<Post[]>([]);
@ -16,22 +16,11 @@ export function PostsContainer(): JSX.Element {
}, []);
return (
<View style={style.container}>
<View style={style.postsContainer}>
<Text>Hello World!</Text>
{posts.map((post) => (
<PostView key={post.id} post={post} />
))}
</View>
);
}
const style = StyleSheet.create({
container: {
height: '100%',
padding: 5,
flex: 1,
alignItems: 'center',
justifyContent: 'flex-start',
backgroundColor: '#fff', // For the container holding the posts
},
});
}

26
src/util/style.ts Normal file
View file

@ -0,0 +1,26 @@
import { StyleSheet } from 'react-native';
export const style = StyleSheet.create({
app: { // Outermost container
flex: 1,
backgroundColor: '#fff', // For the "entire" app
alignItems: 'center',
justifyContent: 'center',
},
postsContainer: {
height: '100%',
padding: 5,
flex: 1,
alignItems: 'center',
justifyContent: 'flex-start',
backgroundColor: '#fff', // For the container holding the posts
},
postView: {
flexDirection: "row",
backgroundColor: '#fff',
paddingVertical: 5,
},
postFont: {
color: "#000",
},
});