Skip to content
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

feat: improve webapp, improve mobile player, improve design ✨ #629

Open
wants to merge 89 commits into
base: development
Choose a base branch
from

Conversation

IEduStu
Copy link
Contributor

@IEduStu IEduStu commented Apr 17, 2024

Stremio is awesome and I use it a lot, so I wanted to add the missing features that I think would make its PWA on mobile (and on iOS and iPadOS in particular) first-class.

Changes

  • Improved the look and feel on mobile devices
  • Improved the look and feel of the mobile PWA app - it now feels much more like a native app on iOS
  • Improved the design of the mobile app and desktop app with more immersive navigation bars
  • Fixed and issue where the mobile PWA app ignored the system navigation bar and notch, which made some UI elements not easy to reach
  • On mobile, the player:
    • Shows a play/pause button on the middle of the screen and behaves like the YouTube/Netflix player
    • When double tapping on the right/left side of the screen it skips 10 seconds or goes back 10 seconds instantly
    • Swiping up on the video enter full screen, and swiping down exits full screen
    • There's a new button in the 3 dots menu to open the video stream in nPlay (on iOS only)
    • On iOS, the volume slider is hidden, as there's not way to actually change the volume of a video using a <video> tag
    • On iOS. a new Airplay button (needs fix: workaround to make Airplay work on Safari stremio-video#74 to work), and a button in the 3 dots menu to open the vidoe in nPlayer
    • On iOS, on landscape, there's a small padding in the bottom to make sure the video is not rendered under the navigation bar, and added a workaround to turn the navigation bar black on some devices (testing on a physical device is needed to add this workaround to every device, so I've made sure it only works on the devices I could test this on)
  • Various CSS bug fixes
  • Fixed a bug where the maskable icon was overwritten in the build by the regular icon
  • On the player, in the 3 dots menu, added a button to copy the video download link
  • Added dev container to the repo to make it easier to start a development environment

Live demo: https://iedustu.github.io/stremio-web/

Related pull requests I created for this effort

Devices and platforms tested with these changes

  • macOS:
    • Arc
    • Chrome
    • Firefox
    • Safari
  • Windows:
    • Chrome
    • Edge
  • iOS:
    • Safari
    • PWA (Clicking on Add to homescreen in the share menu in Safari)
    • Chrome
  • iPadOS:
    • Safari
    • PWA (Clicking on Add to homescreen in the share menu in Safari)
    • Chrome
    • Tested all of these with an external trackpad and without an external trackpad connected
  • Android:
    • Chrome
    • PWA

Screenshots

iOS web app

New mobile player design

New mobile player design on iOS

Mobile web

Desktop web

3-1
3-2
3-3
3-4
3-5
3-6
3-7


Screenshots of how it looked before (for reference)

iOS web app

Mobile player

Desktop web

old-desktop-1
old-desktop-2

@CLAassistant
Copy link

CLAassistant commented Apr 17, 2024

CLA assistant check
All committers have signed the CLA.

@tymmesyde
Copy link
Member

tymmesyde commented Apr 17, 2024

Hi, thank you for your PR
As your PR contains a lot of various things, can you please segment your changes in separate PRs?
Like one for fixes or a feature, UI changes, UX changes, etc..
This will make the review easier and there is potentially some changes that we don't want to include in the project

@IEduStu
Copy link
Contributor Author

IEduStu commented Apr 17, 2024

It wouldn't be practical to separate it into multiple PRs as all the changes affect each other and dependant on each other.
For example, the handling of the notch gaps and adaptations for the mobile webapp are intertwined across all the other changes, I'm not sure how can I separate them.

I wrote the long list to detail all the changes and make it easier to CR, but essentially there are 3 main changes:

  • Improvements to the mobile webapp to make it feel native
  • Improvements to the player on mobile to make it feel similar to YouTube/Netflix
  • Infra changes that I made to make it easier for me to develop all of this, so I left it as part of the PR

You can try the live demo of this here: https://iedustu.github.io/stremio-web/

@tymmesyde
Copy link
Member

It wouldn't be practical to separate it into multiple PRs as all the changes affect each other and dependant on each other. For example, the handling of the notch gaps and adaptations for the mobile webapp are intertwined across all the other changes, I'm not sure how can I separate them.

I wrote the long list to detail all the changes and make it easier to CR, but essentially there are 3 main changes:

* Improvements to the mobile webapp to make it feel native

* Improvements to the player on mobile to make it feel similar to YouTube/Netflix

* Infra changes that I made to make it easier for me to develop all of this, so I left it as part of the PR

You can try the live demo of this here: https://iedustu.github.io/stremio-web/

I understand that it would not be practical to separate them, we will discuss which changes we want to keep or not before you do that
All your changes are not dependent with each other
As you listed in your comment, you updated the style of the tabs, server warning, etc ..
You also made changes to the player UX by adding a new component for mobile controls, etc...
And also made various fixes
Those can be different PRs and are not related

@Viren070
Copy link

Thanks for fixing the banner.

However, the section buttons still don't highlight correctly (still Brave on Windows 11).

Brave (100% zoom) on Windows 11 (100% scaling) gives me this:

Screen.Recording.2024-07-25.211246.mp4

However, if I set the browser zoom to 125% or 150% it does highlight correctly.

If I change the window size to something slightly smaller, it also highlights the correct section. Here is a video showing what I mean:

Screen.Recording.2024-07-25.212113.mp4

If you need more information please let me know. I am looking forward to this being merged.

@IEduStu
Copy link
Contributor Author

IEduStu commented Jul 25, 2024

@Viren070 I couldn't reproduce the issue now on my machine, so I've applied a fix that I think may solve this.
Can you please check now?

Also, after clicking on a section button, if the button is not focused, is scrolling down 1 pixel makes the button be focused?

If the issue still happens, can you please run this script and share with me its result?
Run this in the devtools console after clicking a section button and having the button not being focused.

console.log("innerWidth", window.innerWidth);
console.log("outerWidth", window.outerWidth);
console.log("innerHeight", window.innerHeight);
console.log("outerHeight", window.outerHeight);
console.log("devicePixelRatio", window.devicePixelRatio);
console.log("scrollTop", document.querySelector('[class^="sections-container"]')?.scrollTop);
console.log("sections", JSON.stringify(
    Array.from(document.querySelector('[class^="sections-container"]').children ?? [])
        .map((item) => ({
            className: item.className,
            offsetTop: item.offsetTop
        }))
    )
);
console.log("scrollPaddingTop", getComputedStyle(document.querySelector('[class^="sections-container"]')).scrollPaddingTop);

@Viren070
Copy link

@Viren070 I couldn't reproduce the issue now on my machine, so I've applied a fix that I think may solve this. Can you please check now?

I have tried this again and the issue still occurs

Also, after clicking on a section button, if the button is not focused, is scrolling down 1 pixel makes the button be focused?

Yes.

If the issue still happens, can you please run this script and share with me its result? Run this in the devtools console after clicking a section button and having the button not being focused.

console.log("innerWidth", window.innerWidth);
console.log("outerWidth", window.outerWidth);
console.log("innerHeight", window.innerHeight);
console.log("outerHeight", window.outerHeight);
console.log("devicePixelRatio", window.devicePixelRatio);
console.log("scrollTop", document.querySelector('[class^="sections-container"]')?.scrollTop);
console.log("sections", JSON.stringify(
    Array.from(document.querySelector('[class^="sections-container"]').children ?? [])
        .map((item) => ({
            className: item.className,
            offsetTop: item.offsetTop
        }))
    )
);
console.log("scrollPaddingTop", getComputedStyle(document.querySelector('[class^="sections-container"]')).scrollPaddingTop);

After running this, I got the following output:

innerWidth 837
outerWidth 1920
innerHeight 951
outerHeight 1032
devicePixelRatio 1
scrollTop 708
sections [{"className":"section-container-twzKQ","offsetTop":77},{"className":"section-container-twzKQ","offsetTop":309},{"className":"section-container-twzKQ","offsetTop":604},{"className":"section-container-twzKQ","offsetTop":738},{"className":"section-container-twzKQ","offsetTop":1324},{"className":"section-container-twzKQ","offsetTop":1593},{"className":"section-container-twzKQ","offsetTop":1959},{"className":"section-container-twzKQ","offsetTop":2227},{"className":"section-container-twzKQ","offsetTop":2514},{"className":"section-container-twzKQ","offsetTop":2892},{"className":"section-container-twzKQ versions-section-container-LRCVQ","offsetTop":3962}]
scrollPaddingTop 77px

@IEduStu
Copy link
Contributor Author

IEduStu commented Jul 25, 2024

@Viren070 I think I found the issue and fixed it.
Can you please check again?

@Viren070
Copy link

@IEduStu It works!

@IEduStu
Copy link
Contributor Author

IEduStu commented Jul 26, 2024

I just had to resolve another conflict now :/

@IEduStu
Copy link
Contributor Author

IEduStu commented Jul 31, 2024

@kKaskak Do you have any estimation of when will this get merged?
I just had to resolve another conflict...

@IEduStu
Copy link
Contributor Author

IEduStu commented Aug 14, 2024

@kKaskak It seems that using a streaming server stopped working on this branch and also on the development branch (via https://stremio.github.io/stremio-web/development).
I couldn't find any recent changes that might have caused this on the development branch.

Do you have an idea of why it happens?
The main website (https://web.stremio.com) seems to work fine though.

@kKaskak
Copy link
Member

kKaskak commented Aug 19, 2024

@kKaskak It seems that using a streaming server stopped working on this branch and also on the development branch (via https://stremio.github.io/stremio-web/development).

I couldn't find any recent changes that might have caused this on the development branch.

Do you have an idea of why it happens?

The main website (https://web.stremio.com) seems to work fine though.

It should be working the same as it did before

@tsaridas
Copy link

@kKaskak It seems that using a streaming server stopped working on this branch and also on the development branch (via https://stremio.github.io/stremio-web/development). I couldn't find any recent changes that might have caused this on the development branch.

Do you have an idea of why it happens? The main website (https://web.stremio.com) seems to work fine though.

try adding

"proxyStreamsEnabled": false

to your server-settings.json

@@ -40,6 +40,8 @@
--modal-background-color: rgba(15, 13, 32, 1);
--outer-glow: 0px 0px 30px rgba(123, 91, 245, 0.37);
--border-radius: 0.75rem;

background-color: #161523;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you use one of the existing variables instead of creating a new one?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If I understood correctly, this used to change the "apple-mobile-web-app-status-bar" style?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I copied this value from the WebpackPwaManifest config in webpack.config.js, so since it has to be hard-coded there, I thought it'd make sense to do the same here.
I've added a comment about that to make it more clear.

This ensures the title bar color is consistence across devices and browsers, instead of fallbacking to each browser's behavior which are inconsistent.

src/common/useFullscreen.js Outdated Show resolved Hide resolved
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here you can use variables like this at the start of the file:

@selectable-inputs-assumed-height: 84px;
@top-overlay-size: @@selectable-inputs-assumed-height;
@bottom-vertical-nav-bar-size: 0px;
@bottom-overlay-size: var(@bottom-vertical-nav-bar-size);
@overlap-size: 6rem;
@transparency-grandient-pad: 3rem;

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This will clear up the code of all the vars you will just use

@variable

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I used CSS variables here since I change them on some scopes based on media queries and other parameters, and it affects all the other dependant calculations.
This is impossible to do using preprocessor variables.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some of the variables are static, though, so I can extract some of them to the top of the file using preprocessor variables like you suggested, but I think it would make it more cumbersome to read when some of the variables are CSS variables and some are preprocessor variables.

Should I change only the static ones to be preprocessor variables?

height: 100%;
background-color: transparent;

.discover-content {
--selectable-inputs-assumed-height: 84px;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You can do the same here too, use @variable at the start of the file and define a value for it.
Then reuse as

@variable

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same issue here with some variables having to be CSS variables.
Let me know what you think I should do in the other comment (#629 (comment)).

src/routes/MetaDetails/MetaDetails.js Outdated Show resolved Hide resolved
padding-right: var(--safe-area-inset-right, 0px);
box-sizing: border-box;

--navbar-assumed-height: 84px;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same here

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here the variables are indeed all static, but I think that for consistency with the other files it may make sense to keep them css vars.
Let me know if you agree or want me to change it to preprocessor variables anyway.

@IEduStu
Copy link
Contributor Author

IEduStu commented Sep 17, 2024

@kKaskak It seems that using a streaming server stopped working on this branch and also on the development branch (via https://stremio.github.io/stremio-web/development).
I couldn't find any recent changes that might have caused this on the development branch.
Do you have an idea of why it happens?
The main website (https://web.stremio.com) seems to work fine though.

It should be working the same as it did before

I found the cause for this - the latest version of @stremio/stremio-core-web (0.47.7) is broken and causes the connection to the streaming server to fail.
I reverted it to 0.47.6 on this PR and it now works.
Try using the development branch and notice that if fails to connect to the streaming server, while this PR works (refresh the page opening it, since the cache from previous load it used by default).

This seems to be the commit that caused this issue: 69a1a8b

@IEduStu
Copy link
Contributor Author

IEduStu commented Sep 18, 2024

@kKaskak I see that you now fixed the issue with @stremio/stremio-core-web that I mentioned.
update: I see that @elpiel fixed it. Thanks @elpiel :)

This PR just accrued another conflict that I had to solve...
This PR is open for months now, I fixed all the bugs a long time ago, and since then it just accrued a conflict after conflict, which I solved every time like you asked so you can finally merge it.

At this point, I think you can just merge it and make all the changes you want afterwards, since small formatting changes shouldn't be the reason to wait for another 2 months before reviewing this PR again, which by then I'll have to solve many more conflicts.

I don't mean to be rude, but if you don't plan to merge this then please just let me know so I can stop wasting time resolving conflicts...

@IEduStu IEduStu changed the title feat: improve webapp, improve mobile player, improve design feat: improve webapp, improve mobile player, improve design ✨ Sep 25, 2024
@tymmesyde
Copy link
Member

tymmesyde commented Sep 28, 2024

@IEduStu Hi, we need you to split your changes into multiple PRs so we can review and merge them
Can you start by making a PR for the mobile player changes?

@IEduStu
Copy link
Contributor Author

IEduStu commented Sep 28, 2024

@tymmesyde The mobile player depends on the style changes that make the app feel more native, since it goes to great lengths to ensure that the entire screen is used when the website is installed as PWA (including the status bar and the navigation bar areas), and the mobile player heavily depends on that.
I can extract a PR with only the changes to the style of the app without the mobile player first, and after that is merged, then open a new PR with the mobile player changes.
Does it sound good?

I'd also like to have some sort of estimation of a timeline for that to be reviewed and merged since I don't want to work again on something and end up waiting again for another 5 months in which I have to maintain it and merge conflicts with the main branch all the time.

@kKaskak
Copy link
Member

kKaskak commented Jan 6, 2025

I will add all of the PR with changes that were cherrypicked from this PR in this comment for future reference:

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants