aboutsummaryrefslogtreecommitdiff
path: root/src/services/ExploreService.ts
blob: 07af91ad2054cea2fff391bd9aca5671717be44c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
import AsyncStorage from '@react-native-community/async-storage';
import {
  ALL_USERS_ENDPOINT,
  DISCOVER_ENDPOINT,
  SEARCH_BUTTONS_ENDPOPINT,
} from '../constants';
import {EMPTY_PROFILE_PREVIEW_LIST} from '../store/initialStates';
import {
  ExploreSectionType,
  ProfilePreviewType,
  SearchCategoryType,
} from '../types';

export const getAllTaggUsers = async (token: string) => {
  try {
    const response = await fetch(ALL_USERS_ENDPOINT, {
      method: 'GET',
      headers: {
        Authorization: 'Token ' + token,
      },
    });
    const status = response.status;
    if (status === 200) {
      const response_data = await response.json();
      return response_data;
    } else {
      console.log(
        'Something went wrong! 😭',
        'Not able to retrieve tagg users list',
      );
    }
  } catch (error) {
    console.log(
      'Something went wrong! 😭',
      'Not able to retrieve tagg users list',
      error,
    );
  }
};

export const getAllExploreSections = async () => {
  try {
    const token = await AsyncStorage.getItem('token');
    const response = await fetch(DISCOVER_ENDPOINT, {
      method: 'GET',
      headers: {
        Authorization: 'Token ' + token,
      },
    });
    if (response.status !== 200) {
      return EMPTY_PROFILE_PREVIEW_LIST;
    }
    const data = await response.json();
    // TODO (if we return to original explore format): get keys from backend API
    const exploreSections: Record<ExploreSectionType, ProfilePreviewType[]> = {
      'New to Tagg': data.categories.new_to_tagg,
      'People You May Know': data.categories.people_you_may_know,
      'Trending on Tagg': data.categories.trending_on_tagg,
      "Brown '21": data.categories.brown_21,
      "Brown '22": data.categories.brown_22,
      "Brown '23": data.categories.brown_23,
      "Brown '24": data.categories.brown_24,
    };

    return exploreSections;
  } catch (error) {
    console.log('Unable to fetch explore data');
  }
};

export const getDiscoverUsers = async (categoryName: string) => {
  try {
    const token = await AsyncStorage.getItem('token');
    const url = `${DISCOVER_ENDPOINT}get_users/?category=${categoryName}`;
    const response = await fetch(url, {
      method: 'GET',
      headers: {
        Authorization: 'Token ' + token,
      },
    });
    if (response.status !== 200) {
      return undefined;
    }
    const users: ProfilePreviewType[] = await response.json();
    return users;
  } catch (error) {
    console.log('Error fetching SP user data');
    console.log(error);
    return undefined;
  }
};

export const getSuggestedSearchBubbleSuggestions = async () => {
  try {
    const token = await AsyncStorage.getItem('token');
    const response = await fetch(SEARCH_BUTTONS_ENDPOPINT, {
      method: 'GET',
      headers: {
        Authorization: 'Token ' + token,
      },
    });

    if (response.status !== 200) {
      return undefined;
    }

    const data: SearchCategoryType[] = await response.json();
    return data;
  } catch (error) {
    console.log('Error fetching suggested search bubble suggestions');
    console.log(error);
    return undefined;
  }
};