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

fix(entry): added battery level check #851

Merged
merged 23 commits into from
Apr 21, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
643d417
fix(entry): added battery level check
ThornWalli Sep 11, 2023
b107660
Merge pull request #852 from GrabarzUndPartner/feature/module-improve…
ThornWalli Sep 12, 2023
bfef734
Merge pull request #853 from GrabarzUndPartner/next
ThornWalli Sep 12, 2023
2bf6714
chore(update): update from next
ThornWalli Sep 13, 2023
2b9206c
fix(entry): added video check (ios)
ThornWalli Sep 13, 2023
5d5332e
Merge commit '712347b0966ea473b86c33b62dabd91185fbe2e7' into feature/…
ThornWalli Sep 13, 2023
54ceb68
fix(entry): added ignore object
ThornWalli Sep 13, 2023
a3b9487
fix(entry): remove slient catches
ThornWalli Sep 21, 2023
2ac023e
fix(entry): remove try catch
ThornWalli Oct 10, 2023
a6f10fc
Merge branch 'next' into feature/entry-battery-level-check
ThornWalli Nov 13, 2023
9054d5b
fix(entry): added catch for video play
ThornWalli Nov 13, 2023
90a2f66
fix(entry): `hasBatteryPerformanceIssue` modified
ThornWalli Nov 14, 2023
565125b
fix(entry): reduce `isBatteryLow`
ThornWalli Nov 14, 2023
8da3062
Merge branch 'next' into feature/entry-battery-level-check
ThornWalli Nov 15, 2023
b2d7037
Merge branch 'next' into feature/entry-battery-level-check
ThornWalli Nov 18, 2023
74d6ae9
chore(update): update
ThornWalli Dec 24, 2023
6d47219
Merge branch 'next' into feature/entry-battery-level-check
ThornWalli Dec 27, 2023
388bfd8
Merge branch 'feature/renaming' into feature/entry-battery-level-check
ThornWalli Jan 12, 2024
a1f014f
Merge branch 'feature/renaming' into feature/entry-battery-level-check
ThornWalli Jan 12, 2024
2b3a45d
Merge branch 'feature/renaming' into feature/entry-battery-level-check
ThornWalli Feb 10, 2024
65c27a5
Merge branch 'feature/renaming' into feature/entry-battery-level-check
ThornWalli Apr 5, 2024
bcc5821
Merge branch 'feature/renaming' into feature/entry-battery-level-check
ThornWalli Apr 19, 2024
df17692
Merge branch 'main' into feature/entry-battery-level-check
ThornWalli Apr 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions src/runtime/tmpl/entry.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,9 @@ function client () {
await hasBatteryPerformanceIssue(videoBlob)
}
} catch (error) {

console.warn(error)

triggerRunCallback(false);

if (!!layerEl) {
Expand All @@ -71,6 +74,9 @@ function client () {
deferred.resolve();

} catch (error) {

console.warn(error)

triggerRunCallback(false);

if (!!layerEl) {
Expand Down
22 changes: 4 additions & 18 deletions src/runtime/utils/entry.mjs
Copy link
Collaborator

Choose a reason for hiding this comment

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

can we implement a generalistic solution. so it also works on ios and in desktop browsers (laptop)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Copy link
Collaborator

Choose a reason for hiding this comment

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

Please use the silent catch to switch to video detection.

Original file line number Diff line number Diff line change
Expand Up @@ -72,14 +72,9 @@ export async function hasBatteryPerformanceIssue(videoBlob) {
**/
async function isBatteryLow() {
const MIN_BATTERY_LEVEL = 0.2;

try {
const battery = await window.navigator.getBattery();
if (!battery.charging && battery.level <= MIN_BATTERY_LEVEL) {
throw new Error('Battery is low.');
}
} catch (error) {
// Ignore Check
const battery = await window.navigator.getBattery();
if (!battery.charging && battery.level <= MIN_BATTERY_LEVEL) {
throw new Error('Battery is low.');
}
}

Expand All @@ -90,23 +85,14 @@ async function isBatteryLow() {
* In this case no video will be played automatically.
*/
export async function canVideoPlay(blob) {
const VIDEO_TIMEOUT = 250;

const video = document.createElement('video');
video.muted = true;
Copy link
Collaborator

Choose a reason for hiding this comment

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

do we need that. it seems to be a duplicate -> next line

Copy link
Contributor Author

Choose a reason for hiding this comment

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

All setAttribute have been removed and replaced with set properties.

video.setAttribute('muted', 'muted');
video.setAttribute('playsinline', 'playsinline');
video.playsinline = true;
video.src = URL.createObjectURL(blob);

const timeout = setTimeout(() => {
throw new Error('Video playback not possible. Reason: timeout');
}, VIDEO_TIMEOUT);

try {
await video.play();
Copy link
Collaborator

Choose a reason for hiding this comment

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

explain me, what should happen here in combination with the timeout.
i think we should wait for the playing event? and perhaps there is another event we can use to detect it is not playing cause of weak battery

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Video timeout was removed.

Now only the reject from the video play() is caught.

https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/play

clearTimeout(timeout);
} catch (error) {
clearTimeout(timeout);
throw new Error("Video playback not possible. Reason: can't play video");
Copy link
Collaborator

Choose a reason for hiding this comment

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

please consign a meaningful error message

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Then there is alternatively only the possibility to forward the video error.

No separate text for an error that we can not guess when a video does not play.

}
}