Commit Graph

379 Commits (1f12323ee6ee35c90a9c9b145195b26c35b6321c)

Author SHA1 Message Date
Féry Mathieu (Mathius) 9979a1b910
Add currentTimestamp in shared url by videojs-share
Féry Mathieu (Mathius) 1e3f4ed398
Lint player.js
Follow lint indications :
- https://github.com/iv-org/invidious/pull/2895#discussion_r809461103
- https://github.com/iv-org/invidious/pull/2895#discussion_r809461622
Féry Mathieu (Mathius) 7048193f00
Move store of modification in Cookie instead of localStorage
Féry Mathieu (Mathius) 17ae2648ed
Modify use of module (Only if video settings are default)
Following remark at https://github.com/iv-org/invidious/pull/2895#issuecomment-1037279953
Féry Mathieu (Mathius) c952754c8c
Add videojs-persist plugin
Samantaz Fox 53d349a648
Inline a few JS functions
Helps sending less bytes to the client.
Samantaz Fox b344e1aadb
handlers.js: fix TypeError on document.activeElement.type
Samantaz Fox 3c882cff6e
player shortcuts: ignore numpad
Dimitris Apostolou 7e4690e43c
Fix typos
Samantaz Fox 2289f98c1e
Merge pull request from iv-org/SamantazFox-fix-search-focus-js
Ignore "/" key handling if search box is focused
Samantaz Fox 15c66e2b01
Ignore "/" key handling if search box is focused
Fixes a side effect of https://github.com/iv-org/invidious/pull/2814
See: https://github.com/iv-org/invidious/issues/2791#issuecomment-1018264144
Émilien Devos f013a6b1d7
rename hls to vhs in the player
hls method is deprecated: https://github.com/videojs/http-streaming#how-to-use
Samantaz Fox eba311baa9
Merge pull request from syeopite/dep-manager-for-videojs-stuff
Add dependency manager script for videojs stuff
Samantaz Fox 8aed1e11c3
Add JS to focus search box on '/'
Samantaz Fox 3bb7fbb2f1
Merge pull request from SamantazFox/batch-minor-fixes
Multiple minor fixes
Samantaz Fox 6c8a5a1e7f
Fix leading spaces being collapsed in descriptions
Fixes 
Samantaz Fox 68cbc11810
Fix the search box
Fix  : autoselect search field
Fix : no spell checking/auto-correct on search field
Samantaz Fox edcc155482
Merge pull request from tirz/feature-fix_null_ptr_for_localStorage
fix: null ptr while retaining video time
11Tuvork28 d59323a601
Add check to avoid saving player pos to the
length of the given video by saving a minimum of 15 at the end
Théo Gaillard 73a142fd9b
fix: null ptr while loading/switching theme
Théo Gaillard 0453d08eed
fix: null ptr while retaining time
bbielsa ed6476b5ea Allow the t parameter to override the stored video playback position
bbielsa 5abe7fe123 Rename 'remember_position' to 'save_player_pos' for clarity
bbielsa b6792cf02e Added default value for get_video_time() which was causing a bug in safari
bbielsa 1261323c66 Remove console.log debugging
bbielsa 2a45b4eba0 Save and load the position for the video using a local storage object, the object is a dictionary, where the key is the video ID, and the value is the time at which the user last left off watching the video. If the user deselected the 'remember video position' checkbox in the preferences this dictionary is cleared
syeopite a65b9b2b53
Merge pull request from TechnicalSuwako/fix-non-js-player
fix non-JS player 
diogo f13fb80b42
scroll the nextVideo into the top
tuvork f5e7fe34a5
Added border radius to channel-profile ()
Samantaz Fox adc12addfa
Add config option to display source code URL in footer ()
syeopite 92b04a30f3
Prevent indexing of Invidious instances ()
Closes 
syeopite 0323202a03
Revert to iv-org fork of silvermine-videojs-quality-selector
Upstream requires at least two additional sources. Whereas Invidious needs it to be
able to display a single additional source for normal (dashless)
qualites. Aka medium and hd720.
syeopite 6699c80357
Preserve videojs directory for dependency script
syeopite ceae48088e
Stop shipping VideoJS files
テクニカル諏訪子 3351ad8197 fix non-JS player
syeopite 5054510d15
Prevent VR from being initialized in listen mode ()
syeopite 50c8afb525
Handle equirectangular projections for VR ()
syeopite 2abec5b62f
Use colorized version of safari-pinned-tab.svg
syeopite 31de2d304c
Change README logo to use vector image
Samantaz Fox fd313f0d66
Fix alignment of "invidious" logo on search page
The alignment was broken by 
Samantaz Fox cfcb64c516
Fix layout of video 'card' items
Previous changes broke alignment of text and icons
Samantaz Fox 9e4fd193c6 Limit descriptions width to ease mixed LTR/RTL text reading
This will prevent, on large pages, the LTR and RTL text to be
far away, on each side of the page. This could happen on channel
and playlists descriptions, when the page is displayed on a large
screen.
Mostafa Ahangarha f616b8e518 Revert "remove unnecessary text-align"
This reverts commit 97b469f59c.
Mostafa Ahangarha 97b469f59c remove unnecessary text-align
Cadence Ember 7ec93825b6 Change description-box from flex to block
I also make minor changes to the surroundings so that the same layout
and functionality as before is preserved.
Mostafa Ahangarha 4a4867deeb
Undo last commit
Mostafa Ahangarha 965a8ea9fd
Change display to block
Change display from flex to block so that the direction of content would get properly set
Mostafa Ahangarha 3e8ddabcc1
Add bidi support
Adding these styles is the easiest way to add bidi (bidirectional text) support without or with least side effect. I have tested it by adding it manually on yewtu.be instance and so far it works very well.
Graham 908bc7561b
Add 10px margin to top and bottom of hr element
Paul Braeuning e38b602b7d Disallow /watch path for bots again
syeopite f529948d81
Change videojs-vr to the unminified version
syeopite 6e6f4d5a37
Allow configurable support of interactive 360 vid
syeopite f06053b1cf
Fix projection settings for VR
syeopite df0cd30236
Add support for VR videos through videojs-vr
TheFrenchGhosty 75e5b49c3a
Merge pull request from syeopite/mobile-ui
Improve player controls for mobile devices
TheFrenchGhosty 76c9cf62ff
Merge pull request from syeopite/watch-on-invidious
Add watch on Invidious button to embeds
syeopite 65663fb857
Update code to reflect 'read more' btn name change
syeopite c5fae84263
Add functionality to read more button
syeopite d6585d7583
Overhaul Invidious's "Youtube" player style
syeopite 1924d75c2b
Improve mobile user interface for video player
syeopite 06b27d932d
Move player styling to separate file
syeopite 53cdb04be7
Improve mobile ux with videojs-mobile-ui
TheFrenchGhosty b9e57d0283
Merge pull request from syeopite/add996
Change empty home page to search engine like layout
138138138 4336a55c2e
Update default.css
syeopite bc5c0f65b8
Add watch on Invidious button to embeds
syeopite 1057d0eaa6
Fix response design on search homepage
syeopite 73b1284234
Fix search-widget styling for change in
syeopite 5f2e87f0e3
Fix rendering of hr element
syeopite d9528f5cc3
Change positioning of footer to use flexbox
syeopite 909606826d
Change footer div into footer element
syeopite e6e2d51b58
Improve search widget margins
syeopite ea16c01fa2
Fix mobile responsive design for footer
syeopite fe879e6d94
Fix missing colon in empty.css
syeopite 049e8e07ef
Fix footer position to bottom of page
syeopite 47dfd4e681
Scale text logo on search engine like homepage
syeopite 555108c7fd
Add styling to search bar on empty home page
syeopite b3099001be
Fix minor scaling issue in filter drop down.
Basically prevents filter content from jumping above the dropbox when there's
enough space to do
Andrew Zhao 89fd35e02d fix comment replies
syeopite 48a3c3a0c1
Add hover state to filter UI
syeopite fab9ae64a0
Remove duplicate styling code
syeopite 83b5fd252e
Enhance search filter UI for JS disabled users
Change filters UI box to use <details>.

Stylize detail button for filter ui

Fix localization for 'filter'

Fix CSS

Fix styling
Perflyst bcb44ab600
Merge branch 'master' into patch-1
Andrew Zhao 9b79e35d52 do not preload captions
138138138 3b484c362e
Skip duration multiply by playback rate
Fast Forward/Backward like YouTube. The skip duration is multiplied by playback rate.
138138138 121224b1b0
Fix ; () {}
138138138 ddd7f3f384
Update player.js
138138138 a6970e02f9
Fix double duration on all Apple devices
The fix will be applied when Safari browser is detected.
138138138 685902adab
Update player.js
Fixes audio mode duration doubled in iPhone iOS browsers. The player will stop after reaching the real duration. 
iOS() checks both iOS and iPadOS. 
Only tested on iPhone iOS browsers. Testers needed for behavior of iPadOS and MacOS.
Andrew Zhao 4a0b10984a Bump videojs and fix webworker
TheFrenchGhosty 1ad4685bb7
Merge pull request from tenpura-shrimp/searchui
Add ui for search sort and filter
Andrew Zhao 15ba3325d9 add ui for searching
Andre Borie 3046350cb2 Fix DASH playback bug.
Perflyst c7e65ce795
Merge pull request from tenpura-shrimp/ignorevideoplayback
do not add local to xhr when in videoplayback
Andrew Zhao 5a08dfa72f fix incorrect use of setinterval in js
Andrew Zhao ac0ed14eae do not add local to xhr when in videoplayback
Perflyst eeeecf9763
Merge pull request from saltycrys/add-dash-quality-preference
Add DASH quality preference
saltycrys 75c6844b66 Improve storyboards
Instead of limiting the width of storyboards through CSS it is now done in the
VTT directly.
saltycrys eed78c960d Improve DASH quality preference
Besides `auto`, `best` and `worst` it is now possible to select a target height.
If the target height is not available the closest lower height is selected.
saltycrys eea7ca9b72 Add DASH quality preference
The options are `auto` (the current and default behavior), `best` and `worst`.

The UI is only updated once playback starts.
saltycrys fc67dd18d0 Increase color contrast of light theme links
saltycrys b3e9b92344 Fix pure-button hover color on a-tags
TheFrenchGhosty 5e8856e65b
Merge pull request from saltycrys/add-embed-link
Add embed link to watch page
Andrew Zhao 0cb442d40e do not proxy hls on supported browser
saltycrys 680dc1f962 Shuffle URL params
The `list` and `index` params are the most important and come first now.
TheFrenchGhosty fe73eccb90
Merge pull request from saltycrys/theme-flash
Apply dark theme immediately
saltycrys 5f932e9749 Fix CSS specificity issues
saltycrys ff46c18164 Move themes into default.css
Now that themes are controlled with a class instead of setting
media="none" on the stylesheet link and both themes already being
duplicated in default.css for the automatic themeing it makes sense
to have all theme related CSS in the same place.

This commit also fixes the missing dark theme on embeds.
saltycrys de777907f2 Apply dark theme immediately
Themes are now controlled with a class on the body element.

If a preference is set the body element will have either "dark-theme"
or "light-theme" class. If no preference is set or the preference is
empty the class will be "no-theme".

"dark-theme" and "light-theme" are handled by darktheme.css and
lighttheme.css respectively.

"no-theme" is handled by default.css where depending on the value of
"prefers-color-scheme" the styles corresponding to "dark-theme" or
"light-theme" are applied.

Unfortunately this means that both themes are duplicated, once in the
theme .css and once in default.css.
saltycrys 0530045536
Remove double empty line
saltycrys d3e4739745 Improve storyboard display
saltycrys 3379f3ef61 Update videojs-vtt-thumbnails to latest upstream version
Note that the latest version on NPM is over two years old so this was built from source.
Matthew McGarvey 5937e0289e Fix feed menu overlap at ipad screen widths
TheFrenchGhosty 3ab3a5a236
Merge pull request from leonklingele/keydown-mediakeys-detection
js: add support to detect media keys in keydown handler
Omar Roth 3f97bebd69
Support adding video to playlist from watch page
Omar Roth 0e58d99f4e Fix player mouseover events
Omar Roth bd7950b757
Add toggle_parent to dynamic handlers
leonklingele 70cbe91776
Migrate to a good Content Security Policy ()
So attacks such as XSS (see [0]) will no longer be of an issue.

[0]: https://github.com/omarroth/invidious/issues/1022
Kyle Copperfield a3045a3953
Use a MediaQueryListener to toggle on demand. Tested on OSX. ()
Closes .
Leon Klingele e3593fe197
js: add support to detect media keys in keydown handler
See [0] for all the relevant codes.

[0]: https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/key/Key_Values#Multimedia_keys

Fixes a regression introduced in e6b4e12689.
Fixes https://github.com/omarroth/invidious/issues/712.
Jorge Maldonado Ventura dd9f1024f4 Remove invalid HTML from embed player
Omar Roth 72bfdfd925
Merge pull request from jorgesumle/embed
Change embed code
Omar Roth 0560d2cfb7
Bump video.js
Jorge Maldonado Ventura 58c1a68ad9 Change embed code
Omar Roth 23ccaea2ff
Fix comment event listener
Omar Roth be055d9dcb
Add support for custom playlists
Omar Roth 330ffb803f
Remove invalid source map directive for videojs-quality-selector
Omar Roth e03b4b7505
Hide scrollbar for player menus
Omar Roth e61c8046f4
Fix z-index, scrollbar in player
agony affeeb39de Fixed bug that made the whole 'Invidious' div clickable. Solves
Omar Roth 553d52a45e
Update silvermine quality selector
Omar Roth be2ee33273
Fix overflow for player controls
Omar Roth 9766322e99
Update videojs-quality-selector
Omar Roth 7d3ecd2297
Bump JS/CSS dependencies
leonklingele acaf7b969a js: add support to detect alt, meta and control key in keydown handler ()
This fixes a quite severe user experience issue where pressing the
'alt', 'meta' and/or 'ctrl' key along with one of the supported keys
(e.g. 'f' to enter video fullscreen mode) would overwrite the default
browser behavior. In the case of 'f+meta' we would enter fullscreen
mode, and not open the browser search panel as one might expect.

This change is required to stay consistent with the way YouTube
handles keydown events.
Omar Roth 2b94975345
Fix playlist_thumbnail extractor
leonklingele e6b4e12689 js: add support for keydown events ()
* js: add support for keydown events

This will modify the player behavior even if the player element is unfocused.

Based on the YouTube key bindings, allow to

- toggle playback with space and 'k' key
- increase and decrease player volume with up / down arrow key
- mute and unmute player with 'm' key
- jump forwards and backwards by 5 seconds with right / left arrow key
- jump forwards and backwards by 10 seconds with 'l' / 'j'  key
- set video progress with number keys 0–9
- toggle captions with 'c' key
- toggle fullscreen mode with 'f' key
- play next video with 'N' key
- increase and decrease playback speed with '>' / '<' key

* js: remove unused dependency 'videojs.hotkeys.min.js'

Support for controlling the player volume by scrolling over it is
still retained by copying over the relevant code part from the
aforementioned library.
Dragnucs 7eaac995bd Change font family to better native selection ()
psvenk f54fbd057e Add prefers-color-scheme support ()
* Add prefers-color-scheme support

This should fix <https://github.com/omarroth/invidious/issues/559>.
The cookie storage format has been changed from boolean
("true"/"false") to tri-state ("dark"/"light"/""), so that users
without a cookie set will get dark mode if they have enabled the dark
theme in their operating system. The code for handling the cookie
state, along with the user's operating system theme, has been factored
out into a new function `update_mode`, which is called both at window
load and at the "storage" event listener, because the "storage" event
listener is only trigerred when a change is made to the localStorage
from another tab/window (for more info - see
<https://stackoverflow.com/a/4679754>).
Omar Roth f6f176afc1
Merge pull request from leonklingele/add-player-styles
Add support for player styles
Omar Roth 3de37a61c5
Update videojs-http-source-selector
Leon Klingele 46577fb128
Add support for player styles
This currently includes the following styles:

- Invidious, the default
- YouTube, using a centered play button and always visible video control bar

Implements https://github.com/omarroth/invidious/issues/670.
Supersedes https://github.com/omarroth/invidious/pull/661.
Leon Klingele fe2cffb25b
Fix jumpy page on search field focus
Omar Roth d034fecc89
Remove default arguments from function definitions
Omar Roth e8a56e0fea
Add '1.75' playback speed
Omar Roth bcd239ac2b
Add community page
Omar Roth aac240fe41
Resize comment thumbnails
Omar Roth 8fad0af935
Add caption styling
Omar Roth a3cc3c57fd
Add cursor: none to player
Omar Roth 0d0d3edeae
Add thumbnail and banners to channel page
Omar Roth cc6d6ddd66
Prevent firing _onStreamProgress after aborting