Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for channel tabs #951
Add support for channel tabs #951
Changes from 26 commits
ed4559d
8b4b431
18e3758
78bbbd4
9a9fae9
667ab2a
57865e2
aed685e
53e772c
e6907ca
04c7e46
edaaaac
1253773
94523ad
a592c96
f3b064a
0a458d8
856584f
7ec6a44
f71fdac
73c182f
abf0473
8a3545c
7dba12b
f6d8652
2245de1
8d3bc2b
f7e3b71
ffd02a4
c156c40
d2c2aca
8446e20
9cebcf7
5b63a3e
76052de
8ecee87
8cd6439
c6ee2f3
97d7ee5
f306db0
e57d43f
750f158
e278a2d
c3651be
12ca6a2
294ffab
bad1238
6e0ffaf
308fc43
6b627f8
2ad496f
0c5fdac
6a38811
d47d0f9
417b797
0e28f2b
0583515
a3f6a7e
d868746
2adc2ca
e8fab3b
b1f8905
66d8038
6c5a225
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You are using strings for channel tabs names, however this open the door to several
NullPointerException
s in your code. You should make sure that they are avoided as much as possible. Using an enum would have been a great idea, like described in the conversation beyond #951 (comment), but as it has been decided to not do so, don't change anything here.I think a dedicated base (abstract) structure should be created for tabs, and this structure should be implemented in services, because different services may have different tab names for the same type of contents.
This structure should allow getting its name, what it contains (streams, playlists, channels, [...] or multiple type of contents) and maybe the service ID and/or more.
But as you rely on content and sort filters, which are currently strings, this is out of the scope of this PR. These filters should be refactored too (made in #904).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a specific reason why this is not an enum?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I used an enum in the initial version, but decided to use the existing LinkHandlers which take strings for content filtering. The search function works the same.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can't you use an enum and call
.name()
on it?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, that is an option. But I dont see an advantage in that. We wont get the type safety of an enum and it would make the code longer.
There arent any enums used for search filters, either.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Well, sure, but we can check that they're valid by iterating over
Enum.values()
. It's more to keep the code than actual type safety clean I would say.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Mmmh, I agree with @FireMasterK that
Enum.values()
can be useful