Skip to content

Commit

Permalink
Merge branch 'main' into feature/quick-task-screen-frontend
Browse files Browse the repository at this point in the history
  • Loading branch information
patela22 authored Mar 16, 2024
2 parents e5edb04 + 7eaf35f commit 05ddcc9
Show file tree
Hide file tree
Showing 11 changed files with 276 additions and 5 deletions.
2 changes: 0 additions & 2 deletions backend/schema/tasks/task_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -264,8 +264,6 @@ func TestTaskGroup(t *testing.T) {
},
}

fmt.Println("Expected: ", expectedTasks)
fmt.Println("Response: ", responseTasks)
if !reflect.DeepEqual(expectedTasks, responseTasks) {
t.Error("Result was not correct")
}
Expand Down
1 change: 0 additions & 1 deletion backend/schema/tasks/transactions.go
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,6 @@ func GetTasksByAssignedFromDB(pool *pgx.Conn, userIDs []string) ([]models.Task,
print(err, "error scanning task ID")
return nil, err
}
fmt.Println(task_id)
task_ids = append(task_ids, task_id)
}
}
Expand Down
4 changes: 4 additions & 0 deletions client/assets/back-arrow.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
4 changes: 4 additions & 0 deletions client/assets/close.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
6 changes: 5 additions & 1 deletion client/babel.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,10 @@ module.exports = function (api) {

return {
presets: ['babel-preset-expo'],
plugins: ['react-native-paper/babel', 'nativewind/babel']
plugins: [
'react-native-paper/babel',
'nativewind/babel',
'react-native-reanimated/plugin'
]
};
};
20 changes: 20 additions & 0 deletions client/components/TaskType/BackButton.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import React from 'react';

import { useNavigation } from '@react-navigation/native';
import { IconButton } from 'react-native-paper';

import BackArrow from '../../assets/back-arrow.svg';
import { AppStackNavigation } from '../../navigation/AppNavigation';

export function BackButton() {
const navigation = useNavigation<AppStackNavigation>();

return (
<IconButton
className="align-center m-2 flex h-[50px] w-[52px] justify-center rounded-xl bg-carewallet-gray"
mode="contained"
icon={({ color }) => <BackArrow fill={color} />}
onPress={() => navigation.goBack()}
/>
);
}
16 changes: 16 additions & 0 deletions client/components/TaskType/CloseButton.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import React from 'react';

import { IconButton } from 'react-native-paper';

import Close from '../../assets/close.svg';

export function CloseButton({ onPress }: { onPress: () => void }) {
return (
<IconButton
className="align-center m-2 flex h-[50px] w-[52px] justify-center rounded-xl bg-carewallet-gray"
mode="contained"
icon={Close}
onPress={onPress}
/>
);
}
7 changes: 7 additions & 0 deletions client/navigation/AppNavigation.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,15 @@ import { NavigationProp } from '@react-navigation/native';
import { createNativeStackNavigator } from '@react-navigation/native-stack';

import LoginPage from '../screens/LoginPage';
import { TaskType } from '../screens/TaskType';
import { AppStackBottomTabNavigator } from './AppStackBottomTabNavigator';

export type AppStackParamList = {
Main: undefined;
Home: undefined;
Login: undefined;
Profile: undefined;
TaskType: undefined;
};

export type AppStackNavigation = NavigationProp<AppStackParamList>;
Expand All @@ -30,6 +32,11 @@ export function AppNavigation() {
options={{ headerShown: false }}
component={AppStackBottomTabNavigator}
/>
<AppStack.Screen
name="TaskType"
options={{ headerShown: false }}
component={TaskType}
/>
</AppStack.Navigator>
);
}
4 changes: 3 additions & 1 deletion client/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,14 +24,15 @@
"@types/react": "^18.2.55",
"axios": "^1.6.4",
"clsx": "^2.1.0",
"expo": "50.0.6",
"expo": "^50.0.11",
"expo-document-picker": "~11.10.1",
"expo-file-system": "~16.0.6",
"expo-status-bar": "~1.11.1",
"firebase": "^10.7.2",
"nativewind": "^2.0.11",
"react": "18.2.0",
"react-native": "0.73.4",
"react-native-dropdown-picker": "^5.4.6",
"react-native-gesture-handler": "~2.14.0",
"react-native-paper": "^5.12.3",
"react-native-reanimated": "~3.6.2",
Expand All @@ -42,6 +43,7 @@
"devDependencies": {
"@babel/core": "^7.20.0",
"@trivago/prettier-plugin-sort-imports": "^4.3.0",
"@types/react-native": "^0.73.0",
"@typescript-eslint/eslint-plugin": "^6.21.0",
"@typescript-eslint/parser": "6.18.0",
"eslint": "^8.56.0",
Expand Down
151 changes: 151 additions & 0 deletions client/screens/TaskType.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,151 @@
import React, {
useCallback,
useEffect,
useMemo,
useRef,
useState
} from 'react';
import { FlatList, View } from 'react-native';

import BottomSheet, {
BottomSheetBackdrop,
TouchableOpacity
} from '@gorhom/bottom-sheet';
import { BottomSheetDefaultBackdropProps } from '@gorhom/bottom-sheet/lib/typescript/components/bottomSheetBackdrop/types';
import { useNavigation } from '@react-navigation/native';
import DropDownPicker from 'react-native-dropdown-picker';
import { GestureHandlerRootView } from 'react-native-gesture-handler';
import { Button, Text } from 'react-native-paper';

import { BackButton } from '../components/TaskType/BackButton';
import { CloseButton } from '../components/TaskType/CloseButton';
import { AppStackNavigation } from '../navigation/AppNavigation';
import { Category, categoryToTypeMap, TypeOfTask } from '../types/type';

export function TaskType() {
const navigation = useNavigation<AppStackNavigation>();

const [open, setOpen] = useState(false);
const [selectedCategory, setSelectedCategory] = useState<null | Category>(
null
);
const [selectedTypes, setSelectedTypes] = useState<TypeOfTask[]>(
Object.values(TypeOfTask)
);

useEffect(() => {
setSelectedTypes(
selectedCategory
? categoryToTypeMap[selectedCategory]
: Object.values(TypeOfTask)
);
}, [selectedCategory]);

const filters = Object.values(Category).map((filter) => ({
label: filter,
value: filter
}));

const bottomSheetSnapPoints = useMemo(() => ['60%'], []);

const bottomSheetRef = useRef<BottomSheet>(null);

const closeBottomSheet = () => {
if (bottomSheetRef.current) {
bottomSheetRef.current.close(); // Close the BottomSheet
}
};

const snapToIndex = (index: number) =>
bottomSheetRef.current?.snapToIndex(index);

const renderBackdrop = useCallback(
(props: BottomSheetDefaultBackdropProps) => (
<BottomSheetBackdrop
appearsOnIndex={0}
disappearsOnIndex={-1}
{...props}
/>
),
[]
);

return (
<GestureHandlerRootView className="mt-10">
<View className="flex w-full flex-row items-center justify-center">
<View className="mr-[95px]">
<BackButton />
</View>
<Text className="mr-auto self-center text-center text-carewallet-gray">
Step 1 of 2
</Text>
</View>

<Text className="text-center text-2xl font-bold">Type of Task</Text>
<View className="mr-2 flex flex-row justify-end">
<Button
className="h-[40px] items-center justify-center rounded-xl text-sm"
textColor="black"
mode="outlined"
onPress={() => snapToIndex(0)}
>
Filter
</Button>
</View>

<FlatList
className="h-full"
data={selectedTypes}
renderItem={({ item }) => (
<TouchableOpacity
className="m-2 h-[50px] overflow-hidden rounded-xl"
onPress={() => navigation.navigate('New ' + item + ' Task')}
>
<Button
className="m-2 h-[50px] items-center justify-center rounded-xl"
textColor="black"
mode="outlined"
>
{item}
</Button>
</TouchableOpacity>
)}
/>

<BottomSheet
ref={bottomSheetRef}
index={-1}
snapPoints={bottomSheetSnapPoints}
enablePanDownToClose={true}
backdropComponent={renderBackdrop}
>
<View>
<View className="flex flex-row justify-between">
<Text className="m-5 text-2xl font-bold">Filter</Text>
<CloseButton onPress={closeBottomSheet} />
</View>

<DropDownPicker
open={open}
value={selectedCategory}
items={filters}
setOpen={setOpen}
setValue={setSelectedCategory}
placeholder="Category"
onSelectItem={() => {
closeBottomSheet();
}}
style={{
width: '95%',
marginLeft: 'auto',
marginRight: 'auto',
borderRadius: 0,
borderColor: 'transparent',
borderBottomColor: 'black'
}}
/>
</View>
</BottomSheet>
</GestureHandlerRootView>
);
}
66 changes: 66 additions & 0 deletions client/types/type.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
export enum TypeOfTask {
MEDICATION = 'Medication Management',
APPOINTMENT = 'Physician Appointment',
// LABS = 'Labs & Outpatient Services',
// REHAB = 'Rehab & Home Therapies',
// TRANSITIONAL = 'Transitional Care',
GROOMING = 'Grooming',
CONVERSATIONS = 'Family Conversations',
// TRANSPORTATION = 'Transportation',
// RESPITE = 'Respite',
ERRANDS = 'Groceries, Shopping, & Errands',
BILLS = 'Pay Bills',
// PRESCRIPTION = 'Prescription Management',
// SAFETY = 'Home Safety',
DIET = 'Diet & Nutrition',
ACTIVITIES = 'Activities',
INSURANCE = 'Health Insurance',
// FINANCIAL = 'Financial',
// LEGAL = 'Legal',
OTHER = 'Other'
}

export enum Category {
ALL = '',
HEALTH = 'Health & Medical',
PERSONAL = 'Personal',
HOME = 'Home & Lifestyle',
FINANCIAL = 'Financial & Legal',
OTHER = 'Other'
}

export const categoryToTypeMap: Record<Category, TypeOfTask[]> = {
[Category.ALL]: [],
[Category.HEALTH]: [
TypeOfTask.MEDICATION,
TypeOfTask.APPOINTMENT,
// TypeOfTask.LABS,
// TypeOfTask.REHAB,
// TypeOfTask.TRANSITIONAL,
TypeOfTask.GROOMING,
// TypeOfTask.PRESCRIPTION,
TypeOfTask.DIET
],
[Category.PERSONAL]: [
TypeOfTask.GROOMING,
TypeOfTask.CONVERSATIONS,
// TypeOfTask.TRANSPORTATION,
// TypeOfTask.RESPITE,
TypeOfTask.ERRANDS,
// TypeOfTask.SAFETY,
TypeOfTask.BILLS
],
[Category.HOME]: [
// TypeOfTask.REHAB,
// TypeOfTask.SAFETY,
TypeOfTask.DIET,
TypeOfTask.ACTIVITIES
],
[Category.FINANCIAL]: [
TypeOfTask.BILLS,
TypeOfTask.INSURANCE
// TypeOfTask.FINANCIAL,
// TypeOfTask.LEGAL
],
[Category.OTHER]: [TypeOfTask.OTHER]
};

0 comments on commit 05ddcc9

Please sign in to comment.