be-components 4.5.5 → 4.5.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (131) hide show
  1. package/lib/commonjs/Bracket/api/index.js +15 -5
  2. package/lib/commonjs/Bracket/api/index.js.map +1 -1
  3. package/lib/commonjs/Bracket/components/BracketCompetitionActions.js +17 -12
  4. package/lib/commonjs/Bracket/components/BracketCompetitionActions.js.map +1 -1
  5. package/lib/commonjs/Bracket/components/BracketCompetitionCard.js +1 -0
  6. package/lib/commonjs/Bracket/components/BracketCompetitionCard.js.map +1 -1
  7. package/lib/commonjs/Bracket/components/BracketPlay/BracketRound.js +2 -0
  8. package/lib/commonjs/Bracket/components/BracketPlay/BracketRound.js.map +1 -1
  9. package/lib/commonjs/Bracket/components/BracketPlay/index.js +0 -8
  10. package/lib/commonjs/Bracket/components/BracketPlay/index.js.map +1 -1
  11. package/lib/commonjs/Bracket/components/EditPlayerBracket.js +32 -3
  12. package/lib/commonjs/Bracket/components/EditPlayerBracket.js.map +1 -1
  13. package/lib/commonjs/Bracket/components/EnteredCompetitionsModal.js +197 -0
  14. package/lib/commonjs/Bracket/components/EnteredCompetitionsModal.js.map +1 -0
  15. package/lib/commonjs/Bracket/components/JoinCompetitionCard.js +78 -3
  16. package/lib/commonjs/Bracket/components/JoinCompetitionCard.js.map +1 -1
  17. package/lib/commonjs/Bracket/components/ManageBracketCompetitionForm.js +3 -3
  18. package/lib/commonjs/Bracket/components/ManageBracketCompetitionForm.js.map +1 -1
  19. package/lib/commonjs/Bracket/components/PlayerBracketCard.js +21 -4
  20. package/lib/commonjs/Bracket/components/PlayerBracketCard.js.map +1 -1
  21. package/lib/commonjs/Bracket/components/PlayerBrackets.js +27 -4
  22. package/lib/commonjs/Bracket/components/PlayerBrackets.js.map +1 -1
  23. package/lib/commonjs/Bracket/components/RoomHome.js +436 -117
  24. package/lib/commonjs/Bracket/components/RoomHome.js.map +1 -1
  25. package/lib/commonjs/Bracket/index.js +254 -420
  26. package/lib/commonjs/Bracket/index.js.map +1 -1
  27. package/lib/commonjs/Competition/components/EnterCompetitionPrompt.js.map +1 -1
  28. package/lib/commonjs/Engage/index.js.map +1 -1
  29. package/lib/module/Bracket/api/index.js +15 -5
  30. package/lib/module/Bracket/api/index.js.map +1 -1
  31. package/lib/module/Bracket/components/BracketCompetitionActions.js +18 -13
  32. package/lib/module/Bracket/components/BracketCompetitionActions.js.map +1 -1
  33. package/lib/module/Bracket/components/BracketCompetitionCard.js +1 -0
  34. package/lib/module/Bracket/components/BracketCompetitionCard.js.map +1 -1
  35. package/lib/module/Bracket/components/BracketPlay/BracketRound.js +2 -0
  36. package/lib/module/Bracket/components/BracketPlay/BracketRound.js.map +1 -1
  37. package/lib/module/Bracket/components/BracketPlay/index.js +0 -8
  38. package/lib/module/Bracket/components/BracketPlay/index.js.map +1 -1
  39. package/lib/module/Bracket/components/EditPlayerBracket.js +33 -4
  40. package/lib/module/Bracket/components/EditPlayerBracket.js.map +1 -1
  41. package/lib/module/Bracket/components/EnteredCompetitionsModal.js +190 -0
  42. package/lib/module/Bracket/components/EnteredCompetitionsModal.js.map +1 -0
  43. package/lib/module/Bracket/components/JoinCompetitionCard.js +78 -3
  44. package/lib/module/Bracket/components/JoinCompetitionCard.js.map +1 -1
  45. package/lib/module/Bracket/components/ManageBracketCompetitionForm.js +3 -3
  46. package/lib/module/Bracket/components/ManageBracketCompetitionForm.js.map +1 -1
  47. package/lib/module/Bracket/components/PlayerBracketCard.js +21 -4
  48. package/lib/module/Bracket/components/PlayerBracketCard.js.map +1 -1
  49. package/lib/module/Bracket/components/PlayerBrackets.js +28 -5
  50. package/lib/module/Bracket/components/PlayerBrackets.js.map +1 -1
  51. package/lib/module/Bracket/components/RoomHome.js +438 -119
  52. package/lib/module/Bracket/components/RoomHome.js.map +1 -1
  53. package/lib/module/Bracket/index.js +255 -421
  54. package/lib/module/Bracket/index.js.map +1 -1
  55. package/lib/module/Competition/components/EnterCompetitionPrompt.js.map +1 -1
  56. package/lib/module/Engage/index.js.map +1 -1
  57. package/lib/typescript/lib/commonjs/Bracket/api/index.d.ts +6 -1
  58. package/lib/typescript/lib/commonjs/Bracket/api/index.d.ts.map +1 -1
  59. package/lib/typescript/lib/commonjs/Bracket/components/BracketCompetitionActions.d.ts.map +1 -1
  60. package/lib/typescript/lib/commonjs/Bracket/components/BracketCompetitionCard.d.ts.map +1 -1
  61. package/lib/typescript/lib/commonjs/Bracket/components/BracketPlay/BracketRound.d.ts.map +1 -1
  62. package/lib/typescript/lib/commonjs/Bracket/components/BracketPlay/index.d.ts +1 -2
  63. package/lib/typescript/lib/commonjs/Bracket/components/BracketPlay/index.d.ts.map +1 -1
  64. package/lib/typescript/lib/commonjs/Bracket/components/EditPlayerBracket.d.ts +3 -1
  65. package/lib/typescript/lib/commonjs/Bracket/components/EditPlayerBracket.d.ts.map +1 -1
  66. package/lib/typescript/lib/commonjs/Bracket/components/EnteredCompetitionsModal.d.ts +14 -0
  67. package/lib/typescript/lib/commonjs/Bracket/components/EnteredCompetitionsModal.d.ts.map +1 -0
  68. package/lib/typescript/lib/commonjs/Bracket/components/JoinCompetitionCard.d.ts +2 -1
  69. package/lib/typescript/lib/commonjs/Bracket/components/JoinCompetitionCard.d.ts.map +1 -1
  70. package/lib/typescript/lib/commonjs/Bracket/components/PlayerBrackets.d.ts +4 -1
  71. package/lib/typescript/lib/commonjs/Bracket/components/PlayerBrackets.d.ts.map +1 -1
  72. package/lib/typescript/lib/commonjs/Bracket/components/RoomHome.d.ts +4 -14
  73. package/lib/typescript/lib/commonjs/Bracket/components/RoomHome.d.ts.map +1 -1
  74. package/lib/typescript/lib/commonjs/Bracket/index.d.ts.map +1 -1
  75. package/lib/typescript/lib/module/Bracket/api/index.d.ts +6 -1
  76. package/lib/typescript/lib/module/Bracket/api/index.d.ts.map +1 -1
  77. package/lib/typescript/lib/module/Bracket/components/BracketCompetitionActions.d.ts.map +1 -1
  78. package/lib/typescript/lib/module/Bracket/components/BracketCompetitionCard.d.ts.map +1 -1
  79. package/lib/typescript/lib/module/Bracket/components/BracketPlay/BracketRound.d.ts.map +1 -1
  80. package/lib/typescript/lib/module/Bracket/components/BracketPlay/index.d.ts +1 -2
  81. package/lib/typescript/lib/module/Bracket/components/BracketPlay/index.d.ts.map +1 -1
  82. package/lib/typescript/lib/module/Bracket/components/EditPlayerBracket.d.ts +5 -2
  83. package/lib/typescript/lib/module/Bracket/components/EditPlayerBracket.d.ts.map +1 -1
  84. package/lib/typescript/lib/module/Bracket/components/EnteredCompetitionsModal.d.ts +15 -0
  85. package/lib/typescript/lib/module/Bracket/components/EnteredCompetitionsModal.d.ts.map +1 -0
  86. package/lib/typescript/lib/module/Bracket/components/JoinCompetitionCard.d.ts +2 -1
  87. package/lib/typescript/lib/module/Bracket/components/JoinCompetitionCard.d.ts.map +1 -1
  88. package/lib/typescript/lib/module/Bracket/components/PlayerBracketCard.d.ts +3 -1
  89. package/lib/typescript/lib/module/Bracket/components/PlayerBracketCard.d.ts.map +1 -1
  90. package/lib/typescript/lib/module/Bracket/components/PlayerBrackets.d.ts +6 -2
  91. package/lib/typescript/lib/module/Bracket/components/PlayerBrackets.d.ts.map +1 -1
  92. package/lib/typescript/lib/module/Bracket/components/RoomHome.d.ts +4 -14
  93. package/lib/typescript/lib/module/Bracket/components/RoomHome.d.ts.map +1 -1
  94. package/lib/typescript/lib/module/Bracket/index.d.ts.map +1 -1
  95. package/lib/typescript/src/Bracket/api/index.d.ts +5 -1
  96. package/lib/typescript/src/Bracket/api/index.d.ts.map +1 -1
  97. package/lib/typescript/src/Bracket/components/BracketCompetitionActions.d.ts.map +1 -1
  98. package/lib/typescript/src/Bracket/components/BracketCompetitionCard.d.ts.map +1 -1
  99. package/lib/typescript/src/Bracket/components/BracketPlay/index.d.ts +1 -2
  100. package/lib/typescript/src/Bracket/components/BracketPlay/index.d.ts.map +1 -1
  101. package/lib/typescript/src/Bracket/components/EditPlayerBracket.d.ts +8 -1
  102. package/lib/typescript/src/Bracket/components/EditPlayerBracket.d.ts.map +1 -1
  103. package/lib/typescript/src/Bracket/components/EnteredCompetitionsModal.d.ts +21 -0
  104. package/lib/typescript/src/Bracket/components/EnteredCompetitionsModal.d.ts.map +1 -0
  105. package/lib/typescript/src/Bracket/components/JoinCompetitionCard.d.ts +2 -1
  106. package/lib/typescript/src/Bracket/components/JoinCompetitionCard.d.ts.map +1 -1
  107. package/lib/typescript/src/Bracket/components/PlayerBracketCard.d.ts +3 -2
  108. package/lib/typescript/src/Bracket/components/PlayerBracketCard.d.ts.map +1 -1
  109. package/lib/typescript/src/Bracket/components/PlayerBrackets.d.ts +9 -1
  110. package/lib/typescript/src/Bracket/components/PlayerBrackets.d.ts.map +1 -1
  111. package/lib/typescript/src/Bracket/components/RoomHome.d.ts +11 -18
  112. package/lib/typescript/src/Bracket/components/RoomHome.d.ts.map +1 -1
  113. package/lib/typescript/src/Bracket/index.d.ts.map +1 -1
  114. package/lib/typescript/src/Engage/index.d.ts.map +1 -1
  115. package/package.json +1 -1
  116. package/src/Bracket/api/index.ts +10 -5
  117. package/src/Bracket/components/BracketCompetitionActions.tsx +14 -12
  118. package/src/Bracket/components/BracketCompetitionCard.tsx +1 -0
  119. package/src/Bracket/components/BracketPlay/BracketRound.tsx +2 -2
  120. package/src/Bracket/components/BracketPlay/index.tsx +13 -18
  121. package/src/Bracket/components/EditPlayerBracket.tsx +58 -42
  122. package/src/Bracket/components/EnteredCompetitionsModal.tsx +113 -0
  123. package/src/Bracket/components/JoinCompetitionCard.tsx +46 -3
  124. package/src/Bracket/components/ManageBracketCompetitionForm.tsx +3 -3
  125. package/src/Bracket/components/PlayerBracketCard.tsx +9 -4
  126. package/src/Bracket/components/PlayerBrackets.tsx +45 -33
  127. package/src/Bracket/components/RoomHome.tsx +356 -117
  128. package/src/Bracket/index.tsx +277 -402
  129. package/src/Competition/components/EnterCompetitionPrompt.tsx +1 -1
  130. package/src/Engage/index.tsx +1 -0
  131. package/src/types.d.ts +1 -0
@@ -13,6 +13,8 @@ var _Components = require("../../Components");
13
13
  var _useColors = require("../../constants/useColors");
14
14
  var _momentMini = _interopRequireDefault(require("moment-mini"));
15
15
  var _api = require("../api");
16
+ var _EditPlayerBracket = _interopRequireDefault(require("./EditPlayerBracket"));
17
+ var _EnteredCompetitionsModal = _interopRequireDefault(require("./EnteredCompetitionsModal"));
16
18
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
17
19
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
18
20
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
@@ -28,79 +30,248 @@ const calcCardWidth = (width, margin) => {
28
30
  };
29
31
  const sections = ['toggle', 'active_brackets', 'past_brackets', 'tournaments', 'admin_competitions', 'competitions'];
30
32
  const RoomHome = ({
33
+ view_mode,
31
34
  visible,
32
35
  width,
36
+ onRequestAuthenticate,
33
37
  player,
34
38
  leagues,
35
- active_brackets,
36
- public_competitions,
37
- admin_competitions,
38
- onMoreAdmin,
39
- admin_offset,
39
+ insets,
40
40
  onManageCompetition,
41
41
  onCreateNewCompetition,
42
42
  onView,
43
- onUpdatePlayerBracket,
44
- onEditPlayerBracket,
45
- onFocusPosition,
46
- brackets,
47
- player_brackets,
48
- bracket_competitions,
49
- competition_player_brackets,
50
- athletes,
51
- teams
43
+ onFocusPosition
52
44
  }) => {
53
45
  const Colors = (0, _useColors.useColors)();
46
+ const [active_toggle, setActiveToggle] = (0, _react.useState)('my_brackets');
47
+ const [show_comps, setShowComps] = (0, _react.useState)({
48
+ entered_brackets: [],
49
+ entered_competitions: []
50
+ });
51
+ const [editing_player_bracket, setEditingPlayerBracket] = (0, _react.useState)(undefined);
52
+ const [admin_data, setAdminData] = (0, _react.useState)({
53
+ admin_loading: false,
54
+ admin_brackets: [],
55
+ admin_competitions: [],
56
+ admin_offset: 0
57
+ });
58
+ const {
59
+ admin_competitions,
60
+ admin_offset
61
+ } = admin_data;
62
+ const [competitions_data, setCompetitionsData] = (0, _react.useState)({
63
+ competitions_loading: false,
64
+ competitions_loaded: false,
65
+ public_competitions: [],
66
+ competition_brackets: []
67
+ });
68
+ const {
69
+ public_competitions,
70
+ competition_brackets
71
+ } = competitions_data;
72
+ const [comp_search, setCompSearch] = (0, _react.useState)({
73
+ visible: false,
74
+ value: ''
75
+ });
76
+ let visisble_comps = [...public_competitions];
77
+ if (comp_search.visible) {
78
+ visisble_comps = visisble_comps.filter(c => `${c.competition_name} ${c.competition_description}`.toLowerCase().includes(comp_search.value.toLowerCase()));
79
+ }
80
+ const unique_competition_leagues = [...new Set(competition_brackets.filter(b => visisble_comps.map(c => c.bracket_id.toString()).includes(b.bracket_id.toString())).map(b => b.league_id))];
81
+ const [tournaments_data, setTournamentsData] = (0, _react.useState)({
82
+ tournaments_loading: false,
83
+ tournament_brackets: []
84
+ });
85
+ const {
86
+ tournament_brackets
87
+ } = tournaments_data;
88
+ let visisble_tourney_brackets = [...tournament_brackets];
89
+ const [selected_league, setSelectedLeague] = (0, _react.useState)(undefined);
90
+ if (selected_league) {
91
+ visisble_tourney_brackets = visisble_tourney_brackets.filter(b => b.league_id == selected_league);
92
+ }
93
+ const [tourney_search, setTourneySearch] = (0, _react.useState)({
94
+ visible: false,
95
+ value: ''
96
+ });
97
+ if (tourney_search.visible) {
98
+ visisble_tourney_brackets = visisble_tourney_brackets.filter(b => `${b.bracket_name}`.toLowerCase().includes(tourney_search.value.toLowerCase()));
99
+ }
100
+ const unique_tournament_leagues = [...new Set(visisble_tourney_brackets.map(b => b.league_id))];
101
+ const [my_brackets_data, setMyBrackets] = (0, _react.useState)({
102
+ my_brackets_loading: false,
103
+ my_brackets_loaded: false,
104
+ competition_player_brackets: [],
105
+ my_brackets: [],
106
+ champion_athletes: [],
107
+ champion_teams: [],
108
+ my_competitions: [],
109
+ player_brackets: []
110
+ });
111
+ const {
112
+ my_brackets_loaded,
113
+ my_brackets_loading,
114
+ my_brackets,
115
+ my_competitions,
116
+ competition_player_brackets,
117
+ player_brackets,
118
+ champion_athletes,
119
+ champion_teams
120
+ } = my_brackets_data;
121
+ const active_brackets = player_brackets.filter(pb => pb.status == 'active');
122
+ const closed_brackets = player_brackets.filter(pb => pb.status == 'closed');
123
+ const [past_search, setPastSearch] = (0, _react.useState)({
124
+ visible: false,
125
+ value: ''
126
+ });
127
+ let closed_bracket_ids = [...new Set(closed_brackets.map(b => b.bracket_id))].slice(0, 10);
128
+ if (past_search.visible) {
129
+ let filtered_brackets = [...closed_brackets].filter(b => `${b.bracket_name}`.toLowerCase().includes(past_search.value.toLowerCase()));
130
+ closed_bracket_ids = [...new Set(filtered_brackets.map(b => b.bracket_id))].slice(0, 10);
131
+ }
132
+ const [active_search, setActiveSearch] = (0, _react.useState)({
133
+ visible: false,
134
+ value: ''
135
+ });
136
+ let active_bracket_ids = [...new Set(active_brackets.map(b => b.bracket_id))];
137
+ if (active_search.visible) {
138
+ let filtered_a_brackets = [...active_brackets].filter(b => `${b.bracket_name}`.toLowerCase().includes(active_search.value.toLowerCase()));
139
+ active_bracket_ids = [...new Set(filtered_a_brackets.map(b => b.bracket_id))].slice(0, 10);
140
+ }
54
141
  const [action_loading, setActionLoading] = (0, _react.useState)(undefined); //This will be a bracket id
55
- const [active_toggle, setActiveToggle] = (0, _react.useState)('competitions');
56
- const [past_search, setPastSearch] = (0, _react.useState)('');
57
- const [show_active_search, setShowActiveSearch] = (0, _react.useState)(false);
58
142
  const [expanded_brackets, setExpandedBrackets] = (0, _react.useState)([]);
59
143
  const [expanded_leagues, setExpandedLeagues] = (0, _react.useState)([]);
60
144
  const [expanded_c_leagues, setExpandedCLeagues] = (0, _react.useState)([]);
61
- const [active_search, setActiveSearch] = (0, _react.useState)('');
62
- const [show_past_search, setShowPastSearch] = (0, _react.useState)(false);
63
- const [show_brackets_search, setShowBracketsSearch] = (0, _react.useState)(false);
64
- const [selected_league, setSelectedLeague] = (0, _react.useState)(undefined);
65
- const [brackets_search, setBracketsSearch] = (0, _react.useState)('');
66
- console.log(brackets_search);
67
- const [competition_search, setCompetitionSearch] = (0, _react.useState)('');
68
- console.log(competition_search);
69
- const [show_competition_search, setShowCompetitionSearch] = (0, _react.useState)(false);
70
- let visible_active_brackets = [...active_brackets];
71
- const unique_leages = [...new Set(visible_active_brackets.map(b => b.league_id))];
72
- if (selected_league) {
73
- visible_active_brackets = visible_active_brackets.filter(b => b.league_id == selected_league);
74
- }
75
- //const inprogress_bracket_ids = [ ...new Set(visible_active_brackets.map(b => b.bracket_id)) ];
145
+ (0, _react.useEffect)(() => {
146
+ if (!visible) {
147
+ return;
148
+ }
149
+ getData(active_toggle);
150
+ }, [visible, active_toggle]);
151
+ const getData = async toggle => {
152
+ switch (toggle) {
153
+ case 'my_brackets':
154
+ getMyBrackets();
155
+ return;
156
+ case 'tournaments':
157
+ getTournaments();
158
+ return;
159
+ case 'competitions':
160
+ getCompetitions();
161
+ return;
162
+ default:
163
+ return;
164
+ }
165
+ };
166
+ const getCompetitions = async () => {
167
+ setCompetitionsData({
168
+ ...competitions_data,
169
+ competitions_loading: true
170
+ });
171
+ const pub_comps = await _api.BracketComeptitionApi.getActivePublicBrackets();
172
+ const unique_brackets = [...new Set(pub_comps.map(c => c.bracket_id))];
173
+ const comp_brackets = await _api.BracketApi.getBracketsByIds(unique_brackets);
174
+ setCompetitionsData({
175
+ ...competitions_data,
176
+ public_competitions: pub_comps,
177
+ competitions_loaded: true,
178
+ competition_brackets: comp_brackets,
179
+ competitions_loading: false
180
+ });
181
+ getAdminComps(0);
182
+ };
183
+ const getAdminComps = async offset => {
184
+ if (!player) {
185
+ return;
186
+ }
187
+ const admin_comps = await _api.BracketComeptitionApi.getMyAdminCompetitions(offset);
188
+ setAdminData({
189
+ admin_loading: false,
190
+ admin_brackets: [],
191
+ admin_competitions: admin_comps,
192
+ admin_offset: offset
193
+ });
194
+ };
195
+ const getTournaments = async () => {
196
+ setTournamentsData({
197
+ ...tournaments_data,
198
+ tournaments_loading: true
199
+ });
200
+ const tourney_brackets = await _api.BracketApi.getActiveBrackets();
201
+ setTournamentsData({
202
+ ...tournaments_data,
203
+ tournaments_loading: false,
204
+ tournament_brackets: tourney_brackets
205
+ });
206
+ };
207
+ const getMyBrackets = async () => {
208
+ if (!player) {
209
+ return;
210
+ }
211
+ setMyBrackets({
212
+ ...my_brackets_data,
213
+ my_brackets_loading: true
214
+ });
215
+ const my_response = await _api.BracketComeptitionApi.getMyPlayerBrackets();
216
+ const bracket_ids = [...new Set(my_response.player_brackets.map(pb => pb.bracket_id))];
217
+ let brackets = await _api.BracketApi.getBracketsByIds(bracket_ids);
218
+ let champ_team_ids = my_response.player_brackets.filter(pb => pb.champion_id_type == 'team').map(b => b.champion_id ?? '');
219
+ const champ_teams = await _api.BracketApi.getTeamsByIds(champ_team_ids);
220
+ let champ_athlete_ids = my_response.player_brackets.filter(pb => pb.champion_id_type == 'athlete').map(b => b.champion_id ?? '');
221
+ const champ_athletes = await _api.BracketApi.getAthletesByIds(champ_athlete_ids);
222
+ //Filter to active and closed
223
+ setMyBrackets({
224
+ ...my_brackets_data,
225
+ my_brackets_loading: false,
226
+ my_brackets_loaded: true,
227
+ champion_athletes: champ_athletes,
228
+ champion_teams: champ_teams,
229
+ my_brackets: brackets,
230
+ player_brackets: my_response.player_brackets,
231
+ competition_player_brackets: my_response.competition_player_brackets,
232
+ my_competitions: my_response.bracket_competitions
233
+ });
234
+ };
235
+ const handleView = async (bracket_id, player_bracket_id, bracket_competition) => {
236
+ if (bracket_id && player_bracket_id && bracket_competition) {
237
+ return onView(bracket_id, player_bracket_id, bracket_competition);
238
+ }
239
+ //Ok! Now - what if we do not have a player_bracket
240
+ let init_pb_id = player_bracket_id;
241
+ if (!init_pb_id) {
242
+ //Lets try and find one!
243
+ init_pb_id = player_brackets.find(pb => pb.bracket_id == bracket_id && pb.status != 'deleted')?.player_bracket_id;
244
+ if (!init_pb_id && !my_brackets_loaded) {
245
+ //Lets try and get the plyaers brackets and see!
246
+ const my_pbs = await _api.BracketComeptitionApi.getMyPlayerBrackets();
247
+ init_pb_id = my_pbs.player_brackets.find(pb => pb.bracket_id == bracket_id && pb.status != 'deleted')?.player_bracket_id;
248
+ }
249
+ }
76
250
 
77
- const filterPlayerBrackets = (bs, pbs, status, search) => {
78
- let init_pbs = pbs.filter(pb => pb.status == status);
79
- if (!search || search == '') {
80
- return init_pbs;
251
+ //Ok! Now - what if we do not have a bracket competition!
252
+ let init_bc = bracket_competition;
253
+ if (!init_bc) {
254
+ //First check if my competitions has any!
255
+ init_bc = my_competitions.find(c => c.bracket_id == bracket_id);
256
+ if (!init_bc) {
257
+ init_bc = public_competitions.find(pc => pc.bracket_id == bracket_id);
258
+ }
259
+ if (!init_bc) {
260
+ //Lets try and get one from the server
261
+ const comps_bc = await _api.BracketComeptitionApi.getBracketCompetitionsByBracketId(bracket_id);
262
+ init_bc = comps_bc.find(bc => bc.bracket_id == bracket_id && !bc.invite_only);
263
+ }
81
264
  }
82
- let brackets = bs.filter(b => `${b.bracket_name.toLowerCase()}`.includes(search.toLowerCase()));
83
- return init_pbs.filter(pb => brackets.map(b => b.bracket_id.toString()).includes(pb.bracket_id.toString()));
265
+ return onView(bracket_id, init_pb_id, init_bc);
84
266
  };
85
- let visible_player_brackets = (0, _react.useMemo)(() => {
86
- return filterPlayerBrackets(brackets, player_brackets, 'active', active_search);
87
- }, [brackets.length, player_brackets.length, active_search]);
88
- const active_bracket_ids = [...new Set(visible_player_brackets.map(pb => pb.bracket_id))];
89
- let past_player_brackets = (0, _react.useMemo)(() => {
90
- return filterPlayerBrackets(brackets, player_brackets, 'closed', past_search);
91
- }, [brackets.length, player_brackets.length, past_search]);
92
- const past_bracket_ids = [...new Set(past_player_brackets.map(pb => pb.bracket_id))];
93
- const competition_bracket_ids = [...new Set(public_competitions.map(bc => bc.bracket_id))];
94
- const competition_brackets = brackets.filter(b => competition_bracket_ids.includes(b.bracket_id));
95
- const competition_league_ids = [...new Set(competition_brackets.map(cb => cb.league_id))];
96
267
  const pb_width = calcCardWidth(width, 6);
97
268
  const renderBrackets = data => {
98
- const bracket = brackets.find(b => b.bracket_id == data.item);
269
+ const bracket = my_brackets.find(b => b.bracket_id == data.item);
99
270
  if (!bracket) {
100
271
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
101
272
  }
102
273
  const expanded = expanded_brackets.includes(data.item) ? true : false;
103
- let my_player_brackets = player_brackets.filter(pb => pb.bracket_id == data.item);
274
+ let my_player_brackets = player_brackets.filter(pb => pb.bracket_id == data.item && pb.status != 'deleted');
104
275
  let additional = my_player_brackets.length - 1;
105
276
  if (!expanded) {
106
277
  my_player_brackets = my_player_brackets.slice(0, 1);
@@ -108,6 +279,7 @@ const RoomHome = ({
108
279
  const league = leagues.find(l => l.league_id == bracket.league_id);
109
280
  const act_loading = action_loading == data.item ? true : false;
110
281
  return /*#__PURE__*/_react.default.createElement(_Themed.View, {
282
+ key: `${data.item}_${data.index}_bracket`,
111
283
  float: true,
112
284
  style: {
113
285
  margin: 5,
@@ -118,7 +290,9 @@ const RoomHome = ({
118
290
  style: {
119
291
  flexDirection: 'row',
120
292
  alignItems: 'center',
121
- padding: 10
293
+ padding: 10,
294
+ borderTopRightRadius: 8,
295
+ borderTopLeftRadius: 8
122
296
  }
123
297
  }, league ? /*#__PURE__*/_react.default.createElement(_reactNative.Image, {
124
298
  style: {
@@ -183,11 +357,14 @@ const RoomHome = ({
183
357
  completion_status: 'inprogress',
184
358
  status: 'active'
185
359
  });
186
- onUpdatePlayerBracket(new_pb);
187
360
  setActionLoading(undefined);
188
361
  if (!expanded) {
189
362
  setExpandedBrackets(expanded_brackets.concat(data.item));
190
363
  }
364
+ setMyBrackets({
365
+ ...my_brackets_data,
366
+ player_brackets: player_brackets.filter(pb => pb.player_bracket_id != new_pb.player_bracket_id).concat(new_pb)
367
+ });
191
368
  }
192
369
  }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)), /*#__PURE__*/_react.default.createElement(_Themed.View, {
193
370
  style: {
@@ -224,7 +401,7 @@ const RoomHome = ({
224
401
  borderBottomWidth: 1,
225
402
  borderColor: Colors.borders.light
226
403
  },
227
- onPress: () => onView(data.item.bracket_id, player_brackets.find(pb => pb.bracket_id == data.item.bracket_id)?.player_bracket_id, data.item.bracket_competition_id)
404
+ onPress: () => handleView(data.item.bracket_id, undefined, data.item)
228
405
  }, /*#__PURE__*/_react.default.createElement(_Themed.View, {
229
406
  transparent: true
230
407
  }, /*#__PURE__*/_react.default.createElement(_reactNative.Image, {
@@ -302,7 +479,9 @@ const RoomHome = ({
302
479
  })), /*#__PURE__*/_react.default.createElement(_Themed.View, {
303
480
  type: "footer",
304
481
  style: {
305
- padding: 8
482
+ padding: 8,
483
+ borderBottomLeftRadius: 8,
484
+ borderBottomRightRadius: 8
306
485
  }
307
486
  }, /*#__PURE__*/_react.default.createElement(_Themed.Button, {
308
487
  type: "action",
@@ -313,16 +492,24 @@ const RoomHome = ({
313
492
  onPress: () => onManageCompetition(data.item.bracket_competition_id)
314
493
  })));
315
494
  };
316
- const renderPlayerBrackets = (0, _react.useCallback)(data => {
495
+ const handleSearchPrivate = async code => {
496
+ const bc = await _api.BracketComeptitionApi.getBracketcompetitionByCode(code);
497
+ if (!bc) {
498
+ return alert('Unable to find private competition by that code');
499
+ }
500
+ let pb_response = await _api.BracketComeptitionApi.getMyPlayerBrackets(bc.bracket_id);
501
+ return handleView(bc.bracket_id, pb_response.player_brackets[0]?.player_bracket_id, bc);
502
+ };
503
+ const renderPlayerBrackets = data => {
317
504
  const cpbs = competition_player_brackets.filter(cpb => cpb.status != 'deleted' && cpb.player_bracket_id == data.item.player_bracket_id);
318
- const comps = bracket_competitions.filter(bc => cpbs.map(cpb => cpb.bracket_competition_id.toString()).includes(bc.bracket_competition_id.toString()));
319
- const bracket = brackets.find(b => b.bracket_id == data.item.bracket_id);
505
+ const comps = my_competitions.filter(bc => cpbs.map(cpb => cpb.bracket_competition_id.toString()).includes(bc.bracket_competition_id.toString()));
506
+ const bracket = my_brackets.find(b => b.bracket_id == data.item.bracket_id);
320
507
  if (!bracket) {
321
508
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
322
509
  }
323
510
  const league = leagues.find(l => l.league_id == bracket.league_id);
324
- const champion_team = teams.find(t => data.item.champion_id_type == 'team' && t.team_id == data.item.champion_id);
325
- const champion_athlete = athletes.find(t => data.item.champion_id_type == 'athlete' && t.athlete_id == data.item.champion_id);
511
+ const champion_team = champion_teams.find(t => data.item.champion_id_type == 'team' && t.team_id == data.item.champion_id);
512
+ const champion_athlete = champion_athletes.find(t => data.item.champion_id_type == 'athlete' && t.athlete_id == data.item.champion_id);
326
513
  return /*#__PURE__*/_react.default.createElement(_Themed.View, {
327
514
  style: {
328
515
  borderBottomWidth: 1,
@@ -337,10 +524,17 @@ const RoomHome = ({
337
524
  competition_player_brackets: cpbs,
338
525
  bracket: bracket,
339
526
  bracket_competitions: comps,
340
- onView: onView,
341
- onEdit: onEditPlayerBracket
527
+ onView: (bracket_id, player_bracket_id) => handleView(bracket_id, player_bracket_id),
528
+ onEdit: () => setEditingPlayerBracket(data.item),
529
+ onShowCompetitions: () => setShowComps({
530
+ player_bracket: data.item,
531
+ entered_competitions: comps,
532
+ entered_brackets: cpbs,
533
+ champion_team,
534
+ champion_athlete
535
+ })
342
536
  }));
343
- }, [JSON.stringify(player_brackets)]);
537
+ };
344
538
  const renderLeagueFilters = data => {
345
539
  const league = leagues.find(l => l.league_id == data.item);
346
540
  if (!league) {
@@ -356,7 +550,8 @@ const RoomHome = ({
356
550
  paddingRight: 10,
357
551
  paddingLeft: 10,
358
552
  borderRadius: 100,
359
- margin: 5
553
+ margin: 5,
554
+ backgroundColor: selected ? Colors.text.highlight : undefined
360
555
  },
361
556
  onPress: () => selected ? setSelectedLeague(undefined) : setSelectedLeague(data.item)
362
557
  }, /*#__PURE__*/_react.default.createElement(_reactNative.Image, {
@@ -383,7 +578,7 @@ const RoomHome = ({
383
578
  borderBottomWidth: 1,
384
579
  borderColor: Colors.borders.light
385
580
  },
386
- onPress: () => onView(data.item.bracket_id, player_brackets.find(pb => pb.bracket_id == data.item.bracket_id)?.player_bracket_id, undefined)
581
+ onPress: () => handleView(data.item.bracket_id)
387
582
  }, /*#__PURE__*/_react.default.createElement(_Components.Icons.BracketIcon, {
388
583
  size: 18,
389
584
  color: Colors.text.h1
@@ -415,7 +610,7 @@ const RoomHome = ({
415
610
  }
416
611
  const expanded = expanded_c_leagues.includes(data.item) ? true : false;
417
612
  //Find all the brackets for this league
418
- let league_brackets = active_brackets.filter(b => b.league_id == data.item);
613
+ let league_brackets = competition_brackets.filter(b => b.league_id == data.item);
419
614
  let league_competitions = public_competitions.filter(bc => league_brackets.map(lb => lb.bracket_id.toString()).includes(bc.bracket_id.toString()));
420
615
  const num_comps = league_competitions.length;
421
616
  let additional = league_competitions.length - 1;
@@ -503,7 +698,7 @@ const RoomHome = ({
503
698
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
504
699
  }
505
700
  const expanded = expanded_leagues.includes(data.item) ? true : false;
506
- let league_brackets = active_brackets.filter(b => b.league_id == data.item);
701
+ let league_brackets = tournament_brackets.filter(b => b.league_id == data.item);
507
702
  let additional = league_brackets.length - 1;
508
703
  if (!expanded) {
509
704
  league_brackets = league_brackets.slice(0, 1);
@@ -588,19 +783,11 @@ const RoomHome = ({
588
783
  case 'toggle':
589
784
  return /*#__PURE__*/_react.default.createElement(_Themed.View, {
590
785
  style: {
591
- margin: 5
786
+ margin: 10,
787
+ marginTop: 18
592
788
  }
593
789
  }, /*#__PURE__*/_react.default.createElement(_Components.Toggle, {
594
- options: [{
595
- key: 'my_brackets',
596
- label: 'My Brackets'
597
- }, {
598
- key: 'tournaments',
599
- label: 'Tournaments'
600
- }, {
601
- key: 'competitions',
602
- label: 'Competitions'
603
- }],
790
+ options: _api.BracketCompetitionHelpers.getToggleOptions(),
604
791
  selected_option: active_toggle,
605
792
  onSelectOption: key => setActiveToggle(key)
606
793
  }));
@@ -608,14 +795,32 @@ const RoomHome = ({
608
795
  if (active_toggle != 'my_brackets') {
609
796
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
610
797
  }
798
+ if (!player) {
799
+ return /*#__PURE__*/_react.default.createElement(_Themed.View, {
800
+ style: {
801
+ padding: 40,
802
+ justifyContent: 'center',
803
+ alignItems: 'center'
804
+ }
805
+ }, /*#__PURE__*/_react.default.createElement(_Themed.Button, {
806
+ float: true,
807
+ type: "success",
808
+ title: "GET STARTED",
809
+ onPress: () => onRequestAuthenticate()
810
+ }));
811
+ }
611
812
  return /*#__PURE__*/_react.default.createElement(_Themed.View, {
612
- nativeID: "my_competitions"
813
+ nativeID: "my_competitions",
814
+ style: {
815
+ marginTop: 18
816
+ }
613
817
  }, /*#__PURE__*/_react.default.createElement(_Themed.View, {
614
- type: "header",
615
818
  style: {
616
- padding: 10,
819
+ padding: 18,
617
820
  flexDirection: 'row',
618
- alignItems: 'center'
821
+ alignItems: 'center',
822
+ borderBottomWidth: 1,
823
+ borderColor: Colors.borders.light
619
824
  }
620
825
  }, /*#__PURE__*/_react.default.createElement(_Themed.View, {
621
826
  transparent: true,
@@ -638,22 +843,28 @@ const RoomHome = ({
638
843
  justifyContent: 'center',
639
844
  alignItems: 'center'
640
845
  },
641
- onPress: () => setShowActiveSearch(!show_active_search)
642
- }, show_active_search ? /*#__PURE__*/_react.default.createElement(_Components.Icons.CloseIcon, {
846
+ onPress: () => setActiveSearch({
847
+ visible: !active_search.visible,
848
+ value: ''
849
+ })
850
+ }, active_search.visible ? /*#__PURE__*/_react.default.createElement(_Components.Icons.CloseIcon, {
643
851
  size: 14,
644
852
  color: Colors.text.error
645
853
  }) : /*#__PURE__*/_react.default.createElement(_Components.Icons.SearchIcon, {
646
854
  size: 14,
647
855
  color: Colors.text.action
648
- }))), show_active_search ? /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
649
- onChange: text => setActiveSearch(text),
856
+ }))), active_search.visible ? /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
857
+ onChange: text => setActiveSearch({
858
+ ...active_search,
859
+ value: text
860
+ }),
650
861
  hide_search_button: true,
651
862
  placeholder: "Search Active Brackets",
652
863
  onFocusPosition: onFocusPosition
653
864
  }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement(_Themed.View, {
654
- type: "body",
865
+ type: "header",
655
866
  style: {
656
- marginBottom: 10,
867
+ padding: 10,
657
868
  flexDirection: 'row',
658
869
  flexWrap: 'wrap',
659
870
  justifyContent: 'center'
@@ -696,25 +907,31 @@ const RoomHome = ({
696
907
  justifyContent: 'center',
697
908
  alignItems: 'center'
698
909
  },
699
- onPress: () => setShowBracketsSearch(!show_brackets_search)
700
- }, show_brackets_search ? /*#__PURE__*/_react.default.createElement(_Components.Icons.CloseIcon, {
910
+ onPress: () => setTourneySearch({
911
+ visible: !tourney_search.visible,
912
+ value: ''
913
+ })
914
+ }, tourney_search.visible ? /*#__PURE__*/_react.default.createElement(_Components.Icons.CloseIcon, {
701
915
  size: 14,
702
916
  color: Colors.text.error
703
917
  }) : /*#__PURE__*/_react.default.createElement(_Components.Icons.SearchIcon, {
704
918
  size: 14,
705
919
  color: Colors.text.action
706
- }))), show_brackets_search ? /*#__PURE__*/_react.default.createElement(_Themed.View, {
920
+ }))), tourney_search.visible ? /*#__PURE__*/_react.default.createElement(_Themed.View, {
707
921
  style: {
708
922
  padding: 5
709
923
  }
710
924
  }, /*#__PURE__*/_react.default.createElement(_reactNative.FlatList, {
711
925
  key: "unique_leagues",
712
926
  keyExtractor: item => item,
713
- data: unique_leages,
927
+ data: unique_tournament_leagues,
714
928
  renderItem: renderLeagueFilters,
715
929
  horizontal: true
716
- })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), show_brackets_search ? /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
717
- onChange: text => setBracketsSearch(text),
930
+ })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), tourney_search.visible ? /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
931
+ onChange: text => setTourneySearch({
932
+ ...tourney_search,
933
+ value: text
934
+ }),
718
935
  hide_search_button: true,
719
936
  placeholder: "Search Active Tournaments",
720
937
  onFocusPosition: onFocusPosition
@@ -727,7 +944,7 @@ const RoomHome = ({
727
944
  flexWrap: 'wrap',
728
945
  justifyContent: 'center'
729
946
  }
730
- }, unique_leages.map((id, index) => {
947
+ }, unique_tournament_leagues.map((id, index) => {
731
948
  return renderLeagues({
732
949
  item: id,
733
950
  index
@@ -737,14 +954,21 @@ const RoomHome = ({
737
954
  if (active_toggle != 'my_brackets') {
738
955
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
739
956
  }
957
+ if (!player) {
958
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
959
+ }
740
960
  return /*#__PURE__*/_react.default.createElement(_Themed.View, {
741
- nativeID: "past_brackets"
961
+ nativeID: "past_brackets",
962
+ style: {
963
+ marginTop: 18
964
+ }
742
965
  }, /*#__PURE__*/_react.default.createElement(_Themed.View, {
743
- type: "header",
744
966
  style: {
745
- padding: 10,
967
+ padding: 18,
746
968
  flexDirection: 'row',
747
- alignItems: 'center'
969
+ alignItems: 'center',
970
+ borderBottomWidth: 1,
971
+ borderColor: Colors.borders.light
748
972
  }
749
973
  }, /*#__PURE__*/_react.default.createElement(_Themed.View, {
750
974
  transparent: true,
@@ -754,7 +978,7 @@ const RoomHome = ({
754
978
  }
755
979
  }, /*#__PURE__*/_react.default.createElement(_Themed.Text, {
756
980
  theme: "h1"
757
- }, "MY PAST BRACKETS"), /*#__PURE__*/_react.default.createElement(_Themed.Text, {
981
+ }, "My Past Brackets"), /*#__PURE__*/_react.default.createElement(_Themed.Text, {
758
982
  style: {
759
983
  marginTop: 4
760
984
  }
@@ -767,27 +991,33 @@ const RoomHome = ({
767
991
  justifyContent: 'center',
768
992
  alignItems: 'center'
769
993
  },
770
- onPress: () => setShowPastSearch(!show_past_search)
771
- }, show_past_search ? /*#__PURE__*/_react.default.createElement(_Components.Icons.CloseIcon, {
994
+ onPress: () => setPastSearch({
995
+ visible: !past_search.visible,
996
+ value: ''
997
+ })
998
+ }, past_search.visible ? /*#__PURE__*/_react.default.createElement(_Components.Icons.CloseIcon, {
772
999
  size: 14,
773
1000
  color: Colors.text.error
774
1001
  }) : /*#__PURE__*/_react.default.createElement(_Components.Icons.SearchIcon, {
775
1002
  size: 14,
776
1003
  color: Colors.text.action
777
- }))), show_past_search ? /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
778
- onChange: text => setPastSearch(text),
1004
+ }))), past_search.visible ? /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
1005
+ onChange: text => setPastSearch({
1006
+ ...past_search,
1007
+ value: text
1008
+ }),
779
1009
  hide_search_button: true,
780
1010
  placeholder: "Search Past Brackets",
781
1011
  onFocusPosition: onFocusPosition
782
1012
  }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement(_Themed.View, {
783
- type: "body",
1013
+ type: "header",
784
1014
  style: {
785
- marginBottom: 10,
1015
+ padding: 10,
786
1016
  flexDirection: 'row',
787
1017
  flexWrap: 'wrap',
788
1018
  justifyContent: 'center'
789
1019
  }
790
- }, past_bracket_ids.map((id, index) => {
1020
+ }, closed_bracket_ids.map((id, index) => {
791
1021
  return renderBrackets({
792
1022
  item: id,
793
1023
  index
@@ -797,6 +1027,9 @@ const RoomHome = ({
797
1027
  if (active_toggle != 'competitions') {
798
1028
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
799
1029
  }
1030
+ if (!player) {
1031
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
1032
+ }
800
1033
  return /*#__PURE__*/_react.default.createElement(_Themed.View, null, /*#__PURE__*/_react.default.createElement(_Themed.View, {
801
1034
  type: "header",
802
1035
  style: {
@@ -823,24 +1056,72 @@ const RoomHome = ({
823
1056
  padding: 0,
824
1057
  marginRight: 10
825
1058
  },
826
- onPress: () => onMoreAdmin(admin_offset - 1)
1059
+ onPress: () => getAdminComps(admin_offset - 1)
827
1060
  }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement(_Themed.Button, {
828
1061
  title: "MORE",
829
1062
  type: "text",
830
1063
  style: {
831
1064
  padding: 0
832
1065
  },
833
- onPress: () => onMoreAdmin(admin_offset + 1)
1066
+ onPress: () => getAdminComps(admin_offset + 1)
834
1067
  })), /*#__PURE__*/_react.default.createElement(_Themed.View, {
835
1068
  style: {
836
1069
  padding: 10
837
1070
  }
838
- }, /*#__PURE__*/_react.default.createElement(_reactNative.FlatList, {
1071
+ }, /*#__PURE__*/_react.default.createElement(_Themed.View, {
1072
+ style: {
1073
+ flexDirection: 'row'
1074
+ }
1075
+ }, onCreateNewCompetition ? /*#__PURE__*/_react.default.createElement(_Themed.View, {
1076
+ float: true,
1077
+ style: {
1078
+ width: 100,
1079
+ margin: 5,
1080
+ borderWidth: 1,
1081
+ borderColor: Colors.text.success
1082
+ }
1083
+ }, /*#__PURE__*/_react.default.createElement(_Themed.View, {
1084
+ type: "header",
1085
+ style: {
1086
+ borderTopRightRadius: 8,
1087
+ borderTopLeftRadius: 8,
1088
+ padding: 5
1089
+ }
1090
+ }, /*#__PURE__*/_react.default.createElement(_Themed.Text, {
1091
+ style: {
1092
+ padding: 5
1093
+ },
1094
+ theme: "description",
1095
+ textAlign: "center"
1096
+ }, "NEW")), /*#__PURE__*/_react.default.createElement(_Themed.View, {
1097
+ style: {
1098
+ flex: 1,
1099
+ justifyContent: 'center',
1100
+ alignItems: 'center'
1101
+ }
1102
+ }, /*#__PURE__*/_react.default.createElement(_Components.Icons.BracketIcon, {
1103
+ size: 40,
1104
+ color: Colors.text.h1
1105
+ })), /*#__PURE__*/_react.default.createElement(_Themed.View, {
1106
+ type: "footer",
1107
+ style: {
1108
+ padding: 8,
1109
+ borderBottomLeftRadius: 8,
1110
+ borderBottomRightRadius: 8
1111
+ }
1112
+ }, /*#__PURE__*/_react.default.createElement(_Themed.Button, {
1113
+ title: "CREATE",
1114
+ type: "success",
1115
+ style: {
1116
+ padding: 5
1117
+ },
1118
+ onPress: () => onCreateNewCompetition()
1119
+ }))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement(_reactNative.FlatList, {
839
1120
  data: admin_competitions,
840
1121
  renderItem: renderAdminCompetitions,
841
1122
  keyExtractor: item => `admin_${item.bracket_competition_id.toString()}`,
842
1123
  horizontal: true
843
- })));
1124
+ }))));
844
1125
  case 'competitions':
845
1126
  if (active_toggle != 'competitions') {
846
1127
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
@@ -875,8 +1156,11 @@ const RoomHome = ({
875
1156
  justifyContent: 'center',
876
1157
  alignItems: 'center'
877
1158
  },
878
- onPress: () => setShowCompetitionSearch(!show_competition_search)
879
- }, show_competition_search ? /*#__PURE__*/_react.default.createElement(_Components.Icons.CloseIcon, {
1159
+ onPress: () => setCompSearch({
1160
+ visible: !comp_search.visible,
1161
+ value: ''
1162
+ })
1163
+ }, comp_search.visible ? /*#__PURE__*/_react.default.createElement(_Components.Icons.CloseIcon, {
880
1164
  size: 12,
881
1165
  color: Colors.text.error
882
1166
  }) : /*#__PURE__*/_react.default.createElement(_Components.Icons.SearchIcon, {
@@ -900,9 +1184,12 @@ const RoomHome = ({
900
1184
  }, "+"), /*#__PURE__*/_react.default.createElement(_Components.Icons.TrophyIcon, {
901
1185
  color: Colors.text.white,
902
1186
  size: 14
903
- })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)), show_competition_search ? /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
904
- onChange: text => setCompetitionSearch(text),
905
- onSearch: text => console.log(text),
1187
+ })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)), comp_search.visible ? /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
1188
+ onChange: text => setCompSearch({
1189
+ ...comp_search,
1190
+ value: text
1191
+ }),
1192
+ onSearch: text => handleSearchPrivate(text),
906
1193
  placeholder: "Search or Enter Private Code",
907
1194
  onFocusPosition: onFocusPosition
908
1195
  }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement(_Themed.View, {
@@ -914,7 +1201,7 @@ const RoomHome = ({
914
1201
  flexWrap: 'wrap',
915
1202
  justifyContent: 'center'
916
1203
  }
917
- }, competition_league_ids.map((id, index) => {
1204
+ }, unique_competition_leagues.map((id, index) => {
918
1205
  return renderLeaguesForCompetitions({
919
1206
  item: id,
920
1207
  index
@@ -934,8 +1221,40 @@ const RoomHome = ({
934
1221
  }, /*#__PURE__*/_react.default.createElement(_reactNative.FlatList, {
935
1222
  data: sections,
936
1223
  key: "room_sections",
1224
+ refreshing: my_brackets_loading,
937
1225
  keyExtractor: item => item,
938
1226
  renderItem: renderSections
1227
+ }), /*#__PURE__*/_react.default.createElement(_EditPlayerBracket.default, {
1228
+ player_bracket: editing_player_bracket,
1229
+ view_mode: view_mode,
1230
+ insets: insets,
1231
+ onClose: () => setEditingPlayerBracket(undefined),
1232
+ onFocusPosition: onFocusPosition,
1233
+ onUpdatePlayerBracket: new_pb => {
1234
+ setEditingPlayerBracket(undefined);
1235
+ setMyBrackets({
1236
+ ...my_brackets_data,
1237
+ player_brackets: player_brackets.filter(pb => pb.player_bracket_id != new_pb.player_bracket_id).concat(new_pb)
1238
+ });
1239
+ }
1240
+ }), /*#__PURE__*/_react.default.createElement(_EnteredCompetitionsModal.default, {
1241
+ player_bracket: show_comps.player_bracket,
1242
+ onSelectCompetition: bc => {
1243
+ if (!show_comps.player_bracket) {
1244
+ return;
1245
+ }
1246
+ onView(show_comps.player_bracket.bracket_id, show_comps.player_bracket.player_bracket_id, bc);
1247
+ },
1248
+ insets: insets,
1249
+ champion_team: show_comps.champion_team,
1250
+ champion_athlete: show_comps.champion_athlete,
1251
+ onClose: () => setShowComps({
1252
+ entered_brackets: [],
1253
+ entered_competitions: []
1254
+ }),
1255
+ entered_brackets: show_comps.entered_brackets,
1256
+ entered_competitions: show_comps.entered_competitions,
1257
+ view_mode: view_mode
939
1258
  }));
940
1259
  };
941
1260
  var _default = exports.default = RoomHome;