Compare commits
61 Commits
Author | SHA1 | Date | |
---|---|---|---|
e568bc9c8d | |||
c2c4172634 | |||
73de5b5773 | |||
aa1fed0b16 | |||
22331ae9f1 | |||
8b436276bf | |||
c61db87fd6 | |||
388cb4df39 | |||
9feffb2972 | |||
acea5cdb24 | |||
55ed577b6a | |||
20b206a161 | |||
9c028a0ecc | |||
b677c3d7ad | |||
aa6bc2df2f | |||
a16579fd21 | |||
ae5a816df1 | |||
1532f2ab23 | |||
5370fc5c83 | |||
8482a1a320 | |||
f3603ac3fa | |||
44fe647a49 | |||
928a89e599 | |||
80d6d806c4 | |||
aeecf40191 | |||
f368ed572d | |||
5291bf616e | |||
a00407a475 | |||
4f47ec49b1 | |||
c48afb7880 | |||
5d3fb359b8 | |||
0227dfa7d8 | |||
b9915b4b94 | |||
f4c1313c19 | |||
7681d63876 | |||
3bed21bd95 | |||
99cdfd60a1 | |||
c6e5937deb | |||
4404e999eb | |||
3684024a58 | |||
1903b1bcdf | |||
9644833d26 | |||
93e3f7cdd9 | |||
617ae146c1 | |||
3459387f04 | |||
4d483bf66c | |||
9e65b67bc1 | |||
722b153fcd | |||
27a0ec9424 | |||
6520a466f3 | |||
698d7289af | |||
11063a8924 | |||
1071ef5bf9 | |||
28caa00c3f | |||
894ac8088d | |||
148481eccc | |||
26bd4d0833 | |||
b6d5ba43ec | |||
6cbcfd75d1 | |||
ce39369d84 | |||
e73eb87c7e |
2
.gitignore
vendored
@ -3,3 +3,5 @@ node_modules
|
|||||||
*.sublime-workspace
|
*.sublime-workspace
|
||||||
.DS_Store
|
.DS_Store
|
||||||
aws.json
|
aws.json
|
||||||
|
docs/index.dev.html
|
||||||
|
*.mp4
|
||||||
|
62
bower.json
@ -1,33 +1,33 @@
|
|||||||
{
|
{
|
||||||
"name": "plyr",
|
"name": "plyr",
|
||||||
"description": "A simple HTML5 media player using custom controls",
|
"description": "A simple HTML5 media player using custom controls",
|
||||||
"homepage": "http://plyr.io",
|
"homepage": "http://plyr.io",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"Audio",
|
"Audio",
|
||||||
"Video",
|
"Video",
|
||||||
"HTML5 Audio",
|
"HTML5 Audio",
|
||||||
"HTml5 Video"
|
"HTml5 Video"
|
||||||
],
|
],
|
||||||
"authors": [
|
"authors": [
|
||||||
"Sam Potts <me@sampotts.me>"
|
"Sam Potts <me@sampotts.me>"
|
||||||
],
|
],
|
||||||
"dependencies": {},
|
"dependencies": {},
|
||||||
"main": [
|
"main": [
|
||||||
"dist/plyr.css",
|
"dist/plyr.css",
|
||||||
"dist/plyr.js",
|
"dist/plyr.js",
|
||||||
"dist/sprite.svg",
|
"dist/sprite.svg",
|
||||||
"src/less/plyr.less",
|
"src/less/plyr.less",
|
||||||
"src/sass/plyr.sass",
|
"src/sass/plyr.sass",
|
||||||
"src/js/plyr.js"
|
"src/js/plyr.js"
|
||||||
],
|
],
|
||||||
"ignore": [
|
"ignore": [
|
||||||
"node_modules",
|
"node_modules",
|
||||||
"bower_components",
|
"bower_components",
|
||||||
".gitignore"
|
".gitignore"
|
||||||
],
|
],
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "git://github.com/selz/plyr.git"
|
"url": "git://github.com/selz/plyr.git"
|
||||||
},
|
},
|
||||||
"license": "BSD"
|
"license": "MIT"
|
||||||
}
|
}
|
46
bundles.json
@ -1,25 +1,25 @@
|
|||||||
{
|
{
|
||||||
"plyr": {
|
"plyr": {
|
||||||
"less": {
|
"less": {
|
||||||
"plyr.css": ["src/less/plyr.less"]
|
"plyr.css": ["src/less/plyr.less"]
|
||||||
},
|
},
|
||||||
"sass": {
|
"sass": {
|
||||||
"plyr.css": ["src/less/plyr.sass"]
|
"plyr.css": ["src/less/plyr.sass"]
|
||||||
},
|
},
|
||||||
"js": {
|
"js": {
|
||||||
"plyr.js": ["src/js/plyr.js"]
|
"plyr.js": ["src/js/plyr.js"]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"docs": {
|
"docs": {
|
||||||
"less": {
|
"less": {
|
||||||
"docs.css": ["docs/src/less/docs.less"]
|
"docs.css": ["docs/src/less/docs.less"]
|
||||||
},
|
},
|
||||||
"js": {
|
"js": {
|
||||||
"docs.js": [
|
"docs.js": [
|
||||||
"docs/src/js/lib/hogan-3.0.2.mustache.js",
|
"docs/src/js/lib/hogan-3.0.2.mustache.js",
|
||||||
"docs/dist/templates.js",
|
"docs/dist/templates.js",
|
||||||
"docs/src/js/docs.js"
|
"docs/src/js/docs.js"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
54
changelog.md
@ -1,11 +1,63 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
## v1.1.0
|
||||||
|
- Added config option to set which controls are shown (if using the default controls html) and better handling of missing controls
|
||||||
|
|
||||||
|
## v1.0.31
|
||||||
|
- Display duration on metadataloaded
|
||||||
|
|
||||||
|
## v1.0.30
|
||||||
|
- Fixed bug with media longer than 60 minutes (Fixes #69)
|
||||||
|
|
||||||
|
## v1.0.29
|
||||||
|
- Added option to hide controls on fullscreen (default `true`) while palying, after 1s. Pause, mouse hover on progress, or focus on a child control re-shows the controls. On touch a tap of the video (which plays/pauses the video by default) is required. (Fixes #47)
|
||||||
|
- Fixed a bug with caption toggle in 1.0.28
|
||||||
|
|
||||||
|
## v1.0.28
|
||||||
|
- Added API support for browsers that don't have full plyr support (pretty much <=IE9 and `<video>` on iPhone/iPod)
|
||||||
|
|
||||||
|
## v1.0.27
|
||||||
|
- Keyboard accessibility improvements (Fixes #66)
|
||||||
|
|
||||||
|
## v1.0.26
|
||||||
|
- Fixes for SASS (cheers @brunowego)
|
||||||
|
- Indentation reset to 4 spaces
|
||||||
|
|
||||||
|
## v1.0.25
|
||||||
|
- Fixes for iOS volume controls (hidden)
|
||||||
|
- Classnames for left/right controls changed
|
||||||
|
|
||||||
|
## v1.0.24
|
||||||
|
- Added tooltip option to display labels as tooltips (Fixes #50)
|
||||||
|
|
||||||
|
## v1.0.23
|
||||||
|
- Handling loading states in the UI (Fixes #36)
|
||||||
|
|
||||||
|
## v1.0.22
|
||||||
|
- Added support() API method for checking mimetype support
|
||||||
|
- Added source() API method for setting media source(s) (Fixes #44)
|
||||||
|
- Added poster() API method for setting poster source
|
||||||
|
- Refactored captions logic for manual captions
|
||||||
|
|
||||||
|
## v1.0.21
|
||||||
|
- Added an <input type="range"> for seeking to improve experience (and support dragging) (Fixes #40, #42)
|
||||||
|
- Icons for restart and captions improved (and some IDs changed) (Fixes #49)
|
||||||
|
|
||||||
|
## v1.0.20
|
||||||
|
- Default controls included (Fixes #45)
|
||||||
|
- Volume changes on `input` as well as `change` (Fixes #43)
|
||||||
|
- Fix for undefined Play text
|
||||||
|
- License changed to MIT
|
||||||
|
|
||||||
|
## v1.0.19
|
||||||
|
- Fixed firefox fullscreen issue (Fixes #38)
|
||||||
|
|
||||||
## v1.0.18
|
## v1.0.18
|
||||||
- Added CDN references
|
- Added CDN references
|
||||||
|
|
||||||
## v1.0.17
|
## v1.0.17
|
||||||
- SASS support added (thanks to @brunowego)
|
- SASS support added (thanks to @brunowego)
|
||||||
- Docs completely seperated to avoid any confusion
|
- Docs completely separated to avoid any confusion
|
||||||
- New gulp tasks (will add more documentation for this)
|
- New gulp tasks (will add more documentation for this)
|
||||||
|
|
||||||
## v1.0.16
|
## v1.0.16
|
||||||
|
133
controls.md
@ -1,8 +1,8 @@
|
|||||||
# Controls HTML
|
# Controls HTML
|
||||||
|
|
||||||
This is the markup that is rendered for the Plyr controls. The reason it's a seperate option is to allow full customization of markup based on your needs. It's a pet hate of other libraries that use `<a href="#">` or `<span>`s as buttons!
|
This is the markup that is rendered for the Plyr controls. You can use the default controls or provide a customized version of markup based on your needs.
|
||||||
|
|
||||||
The default Plyr setup uses a Hogan template. The reason being to allow for localization at a later date. Check out `controls.html` in `/src/templates` to get an idea of how the default html is structured. Alternatively just use the vanilla HTML below.
|
The demo Plyr setup uses a Hogan template. This purely to allow for localization at a later date. Check out `controls.html` in `/src/templates` to get an idea of how the default html is structured.
|
||||||
|
|
||||||
## Requirements
|
## Requirements
|
||||||
|
|
||||||
@ -13,69 +13,74 @@ You need to add several placeholders to your html template that are replaced whe
|
|||||||
- `{id}` - the dynamically generated ID for the player (for form controls)
|
- `{id}` - the dynamically generated ID for the player (for form controls)
|
||||||
- `{seektime}` - the seek time specified in options for fast forward and rewind
|
- `{seektime}` - the seek time specified in options for fast forward and rewind
|
||||||
|
|
||||||
Currently all buttons and inputs need to be present for Plyr to work but later we'll make it more dynamic so if you omit a button or input, it'll still work.
|
You can include only the controls you need when specifying custom html.
|
||||||
|
|
||||||
## Vanilla HTML template
|
## Example
|
||||||
|
|
||||||
You can of course, just specify vanilla HTML. Here's an example snippet:
|
This is an example `html` option with all controls.
|
||||||
|
|
||||||
```html
|
```javascript
|
||||||
var controls = [
|
["<div class='player-controls'>",
|
||||||
'<div class="player-controls">',
|
"<div class='player-progress'>",
|
||||||
'<div class="player-progress">',
|
"<label for='seek{id}' class='sr-only'>Seek</label>",
|
||||||
'<progress class="player-progress-played" max="100" value="0">',
|
"<input id='seek{id}' class='player-progress-seek' type='range' min='0' max='100' step='0.5' value='0' data-player='seek'>",
|
||||||
'<span>0</span>% played',
|
"<progress class='player-progress-played' max='100' value='0'>",
|
||||||
'</progress>',
|
"<span>0</span>% played",
|
||||||
'<progress class="player-progress-buffer" max="100" value="0">',
|
"</progress>",
|
||||||
'<span>0</span>% buffered',
|
"<progress class='player-progress-buffer' max='100' value='0'>",
|
||||||
'</progress>',
|
"<span>0</span>% buffered",
|
||||||
'</div>',
|
"</progress>",
|
||||||
'<span class="player-controls-playback">',
|
"</div>",
|
||||||
'<button type="button" data-player="restart">',
|
"<span class='player-controls-left'>",
|
||||||
'<svg><use xlink:href="#icon-refresh"></use></svg>',
|
"<button type='button' data-player='restart'>",
|
||||||
'<span class="sr-only">Restart</span>',
|
"<svg><use xlink:href='#icon-restart'></use></svg>",
|
||||||
'</button>',
|
"<span class='sr-only'>Restart</span>",
|
||||||
'<button type="button" data-player="rewind">',
|
"</button>",
|
||||||
'<svg><use xlink:href="#icon-rewind"></use></svg>',
|
"<button type='button' data-player='rewind'>",
|
||||||
'<span class="sr-only">Rewind <span class="player-seek-time">{seektime}</span> seconds</span>',
|
"<svg><use xlink:href='#icon-rewind'></use></svg>",
|
||||||
'</button>',
|
"<span class='sr-only'>Rewind {seektime} secs</span>",
|
||||||
'<button type="button" data-player="play">',
|
"</button>",
|
||||||
'<svg><use xlink:href="#icon-play"></use></svg>',
|
"<button type='button' data-player='play'>",
|
||||||
'<span class="sr-only">Play</span>',
|
"<svg><use xlink:href='#icon-play'></use></svg>",
|
||||||
'</button>',
|
"<span class='sr-only'>Play</span>",
|
||||||
'<button type="button" data-player="pause">',
|
"</button>",
|
||||||
'<svg><use xlink:href="#icon-pause"></use></svg>',
|
"<button type='button' data-player='pause'>",
|
||||||
'<span class="sr-only">Pause</span>',
|
"<svg><use xlink:href='#icon-pause'></use></svg>",
|
||||||
'</button>',
|
"<span class='sr-only'>Pause</span>",
|
||||||
'<button type="button" data-player="fast-forward">',
|
"</button>",
|
||||||
'<svg><use xlink:href="#icon-fast-forward"></use></svg>',
|
"<button type='button' data-player='fast-forward'>",
|
||||||
'<span class="sr-only">Fast forward <span class="player-seek-time">{seektime}</span> seconds</span>',
|
"<svg><use xlink:href='#icon-fast-forward'></use></svg>",
|
||||||
'</button>',
|
"<span class='sr-only'>Forward {seektime} secs</span>",
|
||||||
'<span class="player-time">',
|
"</button>",
|
||||||
'<span class="sr-only">Time</span>',
|
"<span class='player-time'>",
|
||||||
'<span class="player-duration">00:00</span>',
|
"<span class='sr-only'>Current time</span>",
|
||||||
'</span>',
|
"<span class='player-current-time'>00:00</span>",
|
||||||
'</span>',
|
"</span>",
|
||||||
'<span class="player-controls-sound">',
|
"<span class='player-time'>",
|
||||||
'<input class="inverted sr-only" id="mute{id}" type="checkbox" data-player="mute">',
|
"<span class='sr-only'>Duration</span>",
|
||||||
'<label id="mute{id}" for="mute{id}">',
|
"<span class='player-duration'>00:00</span>",
|
||||||
'<svg class="icon-muted"><use xlink:href="#icon-muted"></use></svg>',
|
"</span>",
|
||||||
'<svg><use xlink:href="#icon-sound"></use></svg>',
|
"</span>",
|
||||||
'<span class="sr-only">Mute</span>',
|
"<span class='player-controls-right'>",
|
||||||
'</label>',
|
"<input class='inverted sr-only' id='mute{id}' type='checkbox' data-player='mute'>",
|
||||||
'<label for="volume{id}" class="sr-only">Volume</label>',
|
"<label id='mute{id}' for='mute{id}'>",
|
||||||
'<input id="volume{id}" class="player-volume" type="range" min="0" max="10" value="5" data-player="volume">',
|
"<svg class='icon-muted'><use xlink:href='#icon-muted'></use></svg>",
|
||||||
'<input class="sr-only" id="captions{id}" type="checkbox" data-player="captions">',
|
"<svg><use xlink:href='#icon-volume'></use></svg>",
|
||||||
'<label for="captions{id}">',
|
"<span class='sr-only'>Toggle Mute</span>",
|
||||||
'<svg><use xlink:href="#icon-bubble"></use></svg>',
|
"</label>",
|
||||||
'<span class="sr-only">Captions</span>',
|
"<label for='volume{id}' class='sr-only'>Volume</label>",
|
||||||
'</label>',
|
"<input id='volume{id}' class='player-volume' type='range' min='0' max='10' value='5' data-player='volume'>",
|
||||||
'<button type="button" data-player="fullscreen">',
|
"<input class='sr-only' id='captions{id}' type='checkbox' data-player='captions'>",
|
||||||
'<svg class="icon-exit-fullscreen"><use xlink:href="#icon-collapse"></use></svg>',
|
"<label for='captions{id}'>",
|
||||||
'<svg><use xlink:href="#icon-expand"></use></svg>',
|
"<svg class='icon-captions-on'><use xlink:href='#icon-captions-on'></use></svg>",
|
||||||
'<span class="sr-only">Toggle fullscreen</span>',
|
"<svg><use xlink:href='#icon-captions-off'></use></svg>",
|
||||||
'</button>',
|
"<span class='sr-only'>Toggle Captions</span>",
|
||||||
'</span>',
|
"</label>",
|
||||||
'</div>'
|
"<button type='button' data-player='fullscreen'>",
|
||||||
].join("\n");
|
"<svg class='icon-exit-fullscreen'><use xlink:href='#icon-exit-fullscreen'></use></svg>",
|
||||||
|
"<svg><use xlink:href='#icon-enter-fullscreen'></use></svg>",
|
||||||
|
"<span class='sr-only'>Toggle Fullscreen</span>",
|
||||||
|
"</button>",
|
||||||
|
"</span>",
|
||||||
|
"</div>"].join("\n");
|
||||||
```
|
```
|
Before Width: | Height: | Size: 420 B |
Before Width: | Height: | Size: 360 B |
Before Width: | Height: | Size: 157 B |
Before Width: | Height: | Size: 199 B |
Before Width: | Height: | Size: 329 B |
Before Width: | Height: | Size: 441 B |
Before Width: | Height: | Size: 328 B |
Before Width: | Height: | Size: 419 B |
@ -1,7 +0,0 @@
|
|||||||
The *SVG* folder contains the icons you selected as separate SVG files.
|
|
||||||
|
|
||||||
The *demo.html* lists the icons that you selected. To learn how to insert your icons as inline SVGs (with the <use> element), refer to the source of this HTML file. If you prefer to reference an external SVG instead of embedding it in the HTML, you will need to use javascript to fetch the SVG in order to make sure your SVGs will work fine in IE. IcoMoon's Quick Usage mode can take care of that and host your SVGs too.
|
|
||||||
|
|
||||||
You can ignore the *svgdefs.svg* file. It contains the same SVG <symbol> definitions as the ones you can find in the demo.html file.
|
|
||||||
|
|
||||||
If you prefer using PNGs or CSS sprites, refer to the Preferences panel of the IcoMoon app before downloading your zip pack.
|
|
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M9.016 3c2.748 0 4.984 2.243 4.984 5s-2.236 5-4.97 5l-0.060-0.004c-0.055-0.004-0.11-0.007-0.165-0.010l-0.336-0.014-3.665 1.098 0.629-2.483-0.517-0.747c-0.58-0.839-0.886-1.822-0.886-2.842 0-2.757 2.236-5 4.984-5zM9.016 1c-3.857 0-6.984 3.134-6.984 7 0 1.479 0.46 2.848 1.241 3.978l-1.272 5.022 6.722-2.015c0.098 0.004 0.194 0.015 0.293 0.015 3.857 0 6.984-3.134 6.984-7s-3.127-7-6.984-7v0z" fill="#444444"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 741 B |
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M17.569 8.246l-10.569-6.246c-0.552 0-1 0.448-1 1v1.954l-5-2.954c-0.552 0-1 0.448-1 1v12c0 0.552 0.448 1 1 1l5-2.955v1.955c0 0.552 0.448 1 1 1l10.569-6.246c0.267-0.158 0.431-0.444 0.431-0.754s-0.164-0.597-0.431-0.754zM6 10.722l-4 2.364v-8.172l4 2.364v3.444zM8 13.086v-8.172l6.915 4.086-6.915 4.086z" fill="#444444"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 650 B |
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M17 2h-16c-0.552 0-1 0.448-1 1v12c0 0.552 0.448 1 1 1h16c0.552 0 1-0.448 1-1v-12c0-0.552-0.448-1-1-1zM2 4h2v2h-2v-2zM2 8h2v2h-2v-2zM2 14v-2h2v2h-2zM6 14v-10h6v10h-6zM16 14h-2v-2h2v2zM16 10h-2v-2h2v2zM16 6h-2v-2h2v2z" fill="#444444"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 568 B |
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M16 1h-14c-0.552 0-1 0.448-1 1v12c0 0.552 0.448 1 1 1h5.5c-0.829 0-1.5 0.671-1.5 1.5v0.5h6v-0.5c0-0.829-0.671-1.5-1.5-1.5h5.5c0.552 0 1-0.448 1-1v-12c0-0.552-0.448-1-1-1zM15 12.5c0 0.276-0.224 0.5-0.5 0.5h-11c-0.276 0-0.5-0.224-0.5-0.5v-9c0-0.276 0.224-0.5 0.5-0.5h11c0.276 0 0.5 0.224 0.5 0.5v9z" fill="#444444"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 649 B |
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M5 4.914l6.915 4.086-6.915 4.086v-8.172zM4 2c-0.552 0-1 0.448-1 1v12c0 0.552 0.448 1 1 1l10.569-6.246c0.267-0.158 0.431-0.444 0.431-0.754s-0.164-0.597-0.431-0.754l-10.569-6.246z" fill="#444444"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 530 B |
@ -1,7 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M8.013 14.006h-0.822c-2.372-0.388-4.187-2.453-4.187-4.934 0-0.831 0.213-1.609 0.574-2.299l0.613 0.85c0.446 0.618 1.409 0.446 1.614-0.289l1.162-4.179c0.162-0.58-0.275-1.155-0.877-1.154l-4.174 0.006c-0.741 0.001-1.17 0.841-0.736 1.443l1.128 1.564c-0.817 1.145-1.302 2.544-1.302 4.059 0 3.499 2.566 6.399 5.918 6.917 0.091 0.014 0.18 0.010 0.267-0.001v0.012h0.822c0.545 0 0.987-0.442 0.987-0.987v-0.020c0-0.545-0.442-0.987-0.987-0.987z" fill="#444444"></path>
|
|
||||||
<path d="M16.82 14.551l-1.129-1.564c0.818-1.145 1.302-2.544 1.302-4.059 0-3.499-2.566-6.399-5.918-6.918-0.091-0.014-0.18-0.010-0.267 0.001v-0.013h-0.822c-0.545 0-0.986 0.442-0.986 0.987v0.020c0 0.546 0.442 0.988 0.986 0.988h0.822c2.372 0.388 4.187 2.453 4.187 4.934 0 0.831-0.213 1.609-0.573 2.299l-0.614-0.85c-0.446-0.618-1.409-0.446-1.613 0.289l-1.163 4.179c-0.161 0.581 0.275 1.155 0.878 1.154l4.174-0.006c0.742-0.001 1.17-0.842 0.736-1.443z" fill="#444444"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 1.2 KiB |
@ -1,7 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M10.214 2c-0.111 0-0.225 0.032-0.334 0.101l-4.048 2.81c-0.083 0.058-0.182 0.089-0.283 0.089h-3.553c-0.55 0-0.996 0.448-0.996 1v6c0 0.552 0.446 1 0.996 1h3.553c0.102 0 0.2 0.031 0.283 0.089l4.048 2.81c0.109 0.069 0.223 0.101 0.334 0.101 0.392 0 0.747-0.4 0.747-0.949v-12.101c0-0.55-0.355-0.949-0.747-0.949zM8.969 12.834l-2.387-1.657c-0.166-0.115-0.364-0.178-0.566-0.178h-2.525c-0.275 0-0.498-0.224-0.498-0.5v-3c0-0.276 0.223-0.5 0.498-0.5h2.525c0.202 0 0.4-0.062 0.566-0.178l2.387-1.657v7.669z" fill="#444444"></path>
|
|
||||||
<path d="M16.934 8.799c-0.086-1.748-1.514-2.991-2.507-3.649-0.47-0.312-1.094-0.122-1.325 0.408l-0.038 0.086c-0.188 0.431-0.045 0.939 0.336 1.194 0.706 0.473 1.586 1.247 1.624 2.065 0.032 0.676-0.553 1.468-1.663 2.27-0.398 0.288-0.529 0.839-0.285 1.275l0.042 0.075c0.266 0.475 0.866 0.624 1.3 0.312 1.74-1.251 2.586-2.606 2.516-4.037z" fill="#444444"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 1.2 KiB |
@ -1,7 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M17 9c0-4.418-3.582-8-8-8s-8 3.582-8 8c0 4.418 3.582 8 8 8s8-3.582 8-8zM3 9c0-3.309 2.691-6 6-6s6 2.691 6 6-2.691 6-6 6-6-2.691-6-6z" fill="#444444"></path>
|
|
||||||
<path d="M9.998 12.010v-3.633l1.293 1.317c0.392 0.388 1.025 0.388 1.417 0s0.391-1.016 0-1.403l-2.967-3c-0.188-0.186-0.442-0.291-0.709-0.291-0.011 0-0.023 0-0.034 0.001s-0.023-0.001-0.034-0.001c-0.266 0-0.521 0.105-0.709 0.291l-2.967 3c-0.391 0.388-0.391 1.016 0 1.403s1.025 0.388 1.417 0l1.294-1.317v3.633c0 0.547 0.443 0.99 0.99 0.99h0.018c0.547 0 0.99-0.443 0.99-0.99z" fill="#444444"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 880 B |
@ -1,147 +0,0 @@
|
|||||||
body {
|
|
||||||
padding: 0;
|
|
||||||
margin: 0;
|
|
||||||
font-family: sans-serif;
|
|
||||||
font-size: 1em;
|
|
||||||
line-height: 1.5;
|
|
||||||
color: #555;
|
|
||||||
background: #fff;
|
|
||||||
}
|
|
||||||
h1 {
|
|
||||||
font-size: 1.5em;
|
|
||||||
font-weight: normal;
|
|
||||||
box-shadow: 0 1px #ddd, 0 2px #fff, 0 3px #ddd;
|
|
||||||
}
|
|
||||||
small {
|
|
||||||
font-size: .66666667em;
|
|
||||||
}
|
|
||||||
a {
|
|
||||||
color: #e74c3c;
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
a:hover, a:focus {
|
|
||||||
box-shadow: 0 1px #e74c3c;
|
|
||||||
}
|
|
||||||
.bshadow0, input {
|
|
||||||
box-shadow: inset 0 -2px #e7e7e7;
|
|
||||||
}
|
|
||||||
input:hover {
|
|
||||||
box-shadow: inset 0 -2px #ccc;
|
|
||||||
}
|
|
||||||
input, fieldset {
|
|
||||||
font-size: 1em;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
border: 0;
|
|
||||||
}
|
|
||||||
input {
|
|
||||||
color: inherit;
|
|
||||||
line-height: 1.5;
|
|
||||||
height: 1.5em;
|
|
||||||
padding: .25em 0;
|
|
||||||
}
|
|
||||||
input:focus {
|
|
||||||
outline: none;
|
|
||||||
box-shadow: inset 0 -2px #449fdb;
|
|
||||||
}
|
|
||||||
.glyph {
|
|
||||||
font-size: 16px;
|
|
||||||
width: 17em;
|
|
||||||
margin-right: 1.5em;
|
|
||||||
float: left;
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
.glyph svg {
|
|
||||||
color: #444444;
|
|
||||||
}
|
|
||||||
.liga {
|
|
||||||
width: 80%;
|
|
||||||
width: calc(100% - 2.5em);
|
|
||||||
}
|
|
||||||
.talign-right {
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
||||||
.talign-center {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
.bgc1 {
|
|
||||||
background: #f1f1f1;
|
|
||||||
}
|
|
||||||
.fgc0 {
|
|
||||||
color: #000;
|
|
||||||
}
|
|
||||||
.fgc1 {
|
|
||||||
color: #999;
|
|
||||||
}
|
|
||||||
p {
|
|
||||||
margin-top: 1em;
|
|
||||||
margin-bottom: 1em;
|
|
||||||
}
|
|
||||||
.mvm {
|
|
||||||
margin-top: .75em;
|
|
||||||
margin-bottom: .75em;
|
|
||||||
}
|
|
||||||
.mtn {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
.mtl, .mal {
|
|
||||||
margin-top: 1.5em;
|
|
||||||
}
|
|
||||||
.mbl, .mal {
|
|
||||||
margin-bottom: 1.5em;
|
|
||||||
}
|
|
||||||
.mal, .mhl {
|
|
||||||
margin-left: 1.5em;
|
|
||||||
margin-right: 1.5em;
|
|
||||||
}
|
|
||||||
.mhmm {
|
|
||||||
margin-left: 1em;
|
|
||||||
margin-right: 1em;
|
|
||||||
}
|
|
||||||
.mls {
|
|
||||||
margin-left: .25em;
|
|
||||||
}
|
|
||||||
.ptl {
|
|
||||||
padding-top: 1.5em;
|
|
||||||
}
|
|
||||||
.pbs, .pvs {
|
|
||||||
padding-bottom: .25em;
|
|
||||||
}
|
|
||||||
.pvs, .pts {
|
|
||||||
padding-top: .25em;
|
|
||||||
}
|
|
||||||
.unit {
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
.unitRight {
|
|
||||||
float: right;
|
|
||||||
}
|
|
||||||
.size1of2 {
|
|
||||||
width: 50%;
|
|
||||||
}
|
|
||||||
.size1of1 {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
.clearfix:before, .clearfix:after {
|
|
||||||
content: " ";
|
|
||||||
display: table;
|
|
||||||
}
|
|
||||||
.clearfix:after {
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
.hidden-true {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.textbox0 {
|
|
||||||
width: 3em;
|
|
||||||
background: #f1f1f1;
|
|
||||||
padding: .25em .5em;
|
|
||||||
line-height: 1.5;
|
|
||||||
height: 1.5em;
|
|
||||||
}
|
|
||||||
.fs0 {
|
|
||||||
font-size: 16px;
|
|
||||||
}
|
|
||||||
.fs1 {
|
|
||||||
font-size: 18px;
|
|
||||||
}
|
|
@ -1,99 +0,0 @@
|
|||||||
<!doctype html>
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<title>IcoMoon - SVG Icons</title>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<meta name="viewport" content="width=device-width">
|
|
||||||
<link rel="stylesheet" href="demo-files/demo.css">
|
|
||||||
<link rel="stylesheet" href="style.css">
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<svg display="none" width="0" height="0" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
|
||||||
<defs>
|
|
||||||
<symbol id="icon-bubble" viewBox="0 0 1024 1024">
|
|
||||||
<title>bubble</title>
|
|
||||||
<path class="path1" d="M512.889 170.667c156.334 0 283.556 127.596 283.556 284.444s-127.221 284.444-282.722 284.459l-3.388-0.208c-3.14-0.222-6.251-0.412-9.388-0.555l-19.111-0.791-208.473 62.485 35.778-141.227-29.388-42.51c-32.974-47.751-50.418-103.653-50.418-161.653 0-156.848 127.195-284.444 283.556-284.444zM512.889 56.889c-219.445 0-397.333 178.292-397.333 398.222 0 84.124 26.167 162.028 70.612 226.32l-72.389 285.68 382.416-114.626c5.584 0.236 11.056 0.848 16.695 0.848 219.445 0 397.333-178.292 397.333-398.222s-177.888-398.222-397.333-398.222v0z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-sound" viewBox="0 0 1024 1024">
|
|
||||||
<title>sound</title>
|
|
||||||
<path class="path1" d="M581.056 113.778c-6.332 0-12.779 1.819-19.001 5.764l-230.277 159.847c-4.722 3.292-10.332 5.056-16.11 5.056h-202.112c-31.305 0-56.667 25.472-56.667 56.889v341.333c0 31.417 25.362 56.889 56.667 56.889h202.112c5.778 0 11.388 1.764 16.11 5.056l230.277 159.847c6.222 3.945 12.695 5.764 19.001 5.764 22.277 0 42.5-22.736 42.5-54v-688.43c0-31.278-20.222-54.014-42.5-54.014zM510.222 730.139l-135.78-94.265c-9.472-6.569-20.722-10.1-32.222-10.1h-143.666c-15.666 0-28.334-12.736-28.334-28.444v-170.667c0-15.708 12.667-28.444 28.334-28.444h143.668c11.5 0 22.75-3.527 32.222-10.098l135.778-94.26v436.277z"></path>
|
|
||||||
<path class="path2" d="M963.333 500.583c-4.889-99.417-86.112-170.139-142.612-207.57-26.75-17.737-62.222-6.93-75.364 23.195l-2.137 4.889c-10.667 24.5-2.583 53.403 19.111 67.945 40.167 26.903 90.222 70.958 92.389 117.486 1.833 38.473-31.445 83.5-94.612 129.111-22.667 16.375-30.112 47.708-16.222 72.555l2.389 4.292c15.111 27.001 49.278 35.486 73.945 17.762 98.999-71.15 147.111-148.233 143.111-229.664z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-monitor" viewBox="0 0 1024 1024">
|
|
||||||
<title>monitor</title>
|
|
||||||
<path class="path1" d="M910.222 56.889h-796.444c-31.417 0-56.889 25.472-56.889 56.889v682.667c0 31.417 25.472 56.889 56.889 56.889h312.889c-47.14 0-85.333 38.194-85.333 85.333v28.444h341.333v-28.444c0-47.14-38.194-85.333-85.333-85.333h312.889c31.417 0 56.889-25.472 56.889-56.889v-682.667c0-31.417-25.472-56.889-56.889-56.889zM853.333 711.111c0 15.723-12.722 28.444-28.444 28.444h-625.778c-15.723 0-28.444-12.722-28.444-28.444v-512c0-15.723 12.722-28.444 28.444-28.444h625.778c15.723 0 28.444 12.722 28.444 28.444v512z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-up" viewBox="0 0 1024 1024">
|
|
||||||
<title>up</title>
|
|
||||||
<path class="path1" d="M967.111 512c0-251.362-203.749-455.111-455.111-455.111s-455.111 203.749-455.111 455.111c0 251.362 203.749 455.111 455.111 455.111s455.111-203.749 455.111-455.111zM170.667 512c0-188.222 153.111-341.333 341.333-341.333s341.333 153.111 341.333 341.333-153.111 341.333-341.333 341.333-341.333-153.111-341.333-341.333z"></path>
|
|
||||||
<path class="path2" d="M568.784 683.221v-206.667l73.584 74.917c22.277 22.055 58.332 22.055 80.612 0 22.251-22.055 22.251-57.778 0-79.833l-168.779-170.667c-10.695-10.583-25.166-16.528-40.306-16.528-0.651 0-1.3 0.025-1.95 0.048-0.649-0.023-1.296-0.048-1.948-0.048-15.141 0-29.611 5.945-40.306 16.528l-168.779 170.667c-22.251 22.055-22.251 57.778 0 79.833 22.277 22.055 58.332 22.055 80.612 0l73.588-74.917v206.667c0 31.111 25.223 56.334 56.334 56.334h1.006c31.111 0 56.332-25.223 56.332-56.334z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-play" viewBox="0 0 1024 1024">
|
|
||||||
<title>play</title>
|
|
||||||
<path class="path1" d="M284.444 279.556l393.388 232.444-393.388 232.444v-464.889zM227.556 113.778c-31.417 0-56.889 25.472-56.889 56.889v682.667c0 31.417 25.472 56.889 56.889 56.889l601.278-355.305c15.166-8.972 24.5-25.278 24.5-42.917s-9.333-33.945-24.5-42.917l-601.278-355.305z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-fast-forward" viewBox="0 0 1024 1024">
|
|
||||||
<title>fast-forward</title>
|
|
||||||
<path class="path1" d="M999.5 469.083l-601.278-355.305c-31.417 0-56.889 25.472-56.889 56.889v111.184l-284.444-168.073c-31.417 0-56.889 25.472-56.889 56.889v682.667c0 31.417 25.472 56.889 56.889 56.889l284.444-168.084v111.195c0 31.417 25.472 56.889 56.889 56.889l601.278-355.305c15.195-8.972 24.5-25.278 24.5-42.917s-9.305-33.945-24.5-42.917zM341.333 609.972l-227.556 134.473v-464.889l227.556 134.473v195.943zM455.111 744.444v-464.889l393.388 232.444-393.388 232.444z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-refresh" viewBox="0 0 1024 1024">
|
|
||||||
<title>refresh</title>
|
|
||||||
<path class="path1" d="M455.874 796.763h-46.741c-134.912-22.064-238.203-139.554-238.203-280.692 0-47.296 12.142-91.534 32.651-130.773l34.875 48.352c25.397 35.179 80.169 25.371 91.813-16.452l66.11-237.758c9.198-33.013-15.646-65.719-49.909-65.664l-237.451 0.363c-42.183 0.055-66.555 47.852-41.877 82.087l64.19 88.951c-46.489 65.136-74.084 144.722-74.084 230.894 0 199.076 146 364.055 336.684 393.513 5.196 0.805 10.256 0.583 15.2-0.055v0.693h46.741c31.012 0 56.133-25.122 56.133-56.162v-1.14c0-31.012-25.122-56.158-56.133-56.158z"></path>
|
|
||||||
<path class="path2" d="M956.871 827.803l-64.219-88.951c46.517-65.138 74.084-144.722 74.084-230.894 0-199.076-145.972-364.057-336.656-393.54-5.198-0.805-10.256-0.583-15.202 0.084v-0.724h-46.768c-30.985 0-56.105 25.148-56.105 56.16v1.14c0 31.040 25.12 56.188 56.105 56.188h46.768c134.914 22.064 238.174 139.554 238.174 280.692 0 47.296-12.142 91.534-32.622 130.773l-34.903-48.352c-25.371-35.18-80.171-25.371-91.785 16.423l-66.137 237.756c-9.17 33.042 15.671 65.721 49.936 65.666l237.451-0.334c42.185-0.057 66.555-47.881 41.879-82.087z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-film" viewBox="0 0 1024 1024">
|
|
||||||
<title>film</title>
|
|
||||||
<path class="path1" d="M967.111 113.778h-910.222c-31.417 0-56.889 25.472-56.889 56.889v682.667c0 31.417 25.472 56.889 56.889 56.889h910.222c31.417 0 56.889-25.472 56.889-56.889v-682.667c0-31.417-25.472-56.889-56.889-56.889zM113.778 227.556h113.778v113.778h-113.778v-113.778zM113.778 455.111h113.778v113.778h-113.778v-113.778zM113.778 796.444v-113.778h113.778v113.778h-113.778zM341.333 796.444v-568.889h341.333v568.889h-341.333zM910.222 796.444h-113.778v-113.778h113.778v113.778zM910.222 568.889h-113.778v-113.778h113.778v113.778zM910.222 341.333h-113.778v-113.778h113.778v113.778z"></path>
|
|
||||||
</symbol>
|
|
||||||
</defs>
|
|
||||||
</svg>
|
|
||||||
|
|
||||||
<header class="bgc1 clearfix">
|
|
||||||
<p class="mhl">SVG Icons - Generated by <a href="https://icomoon.io/app">IcoMoon</a></p>
|
|
||||||
</header>
|
|
||||||
<div class="clearfix mhl ptl">
|
|
||||||
<h1 class="mvm mtn fgc1">Grid Size: 18</h1>
|
|
||||||
<div class="glyph fs1">
|
|
||||||
<div class="clearfix pbs">
|
|
||||||
<svg class="icon icon-bubble"><use xlink:href="#icon-bubble"></use></svg><span class="mls"> icon-bubble</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="glyph fs1">
|
|
||||||
<div class="clearfix pbs">
|
|
||||||
<svg class="icon icon-sound"><use xlink:href="#icon-sound"></use></svg><span class="mls"> icon-sound</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="glyph fs1">
|
|
||||||
<div class="clearfix pbs">
|
|
||||||
<svg class="icon icon-monitor"><use xlink:href="#icon-monitor"></use></svg><span class="mls"> icon-monitor</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="glyph fs1">
|
|
||||||
<div class="clearfix pbs">
|
|
||||||
<svg class="icon icon-up"><use xlink:href="#icon-up"></use></svg><span class="mls"> icon-up</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="glyph fs1">
|
|
||||||
<div class="clearfix pbs">
|
|
||||||
<svg class="icon icon-play"><use xlink:href="#icon-play"></use></svg><span class="mls"> icon-play</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="glyph fs1">
|
|
||||||
<div class="clearfix pbs">
|
|
||||||
<svg class="icon icon-fast-forward"><use xlink:href="#icon-fast-forward"></use></svg><span class="mls"> icon-fast-forward</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="glyph fs1">
|
|
||||||
<div class="clearfix pbs">
|
|
||||||
<svg class="icon icon-refresh"><use xlink:href="#icon-refresh"></use></svg><span class="mls"> icon-refresh</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="glyph fs1">
|
|
||||||
<div class="clearfix pbs">
|
|
||||||
<svg class="icon icon-film"><use xlink:href="#icon-film"></use></svg><span class="mls"> icon-film</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,6 +0,0 @@
|
|||||||
.icon {
|
|
||||||
display: inline-block;
|
|
||||||
width: 1em;
|
|
||||||
height: 1em;
|
|
||||||
fill: currentColor;
|
|
||||||
}
|
|
@ -1,39 +0,0 @@
|
|||||||
<svg display="none" width="0" height="0" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
|
||||||
<defs>
|
|
||||||
<symbol id="icon-bubble" viewBox="0 0 1024 1024">
|
|
||||||
<title>bubble</title>
|
|
||||||
<path class="path1" d="M512.889 170.667c156.334 0 283.556 127.596 283.556 284.444s-127.221 284.444-282.722 284.459l-3.388-0.208c-3.14-0.222-6.251-0.412-9.388-0.555l-19.111-0.791-208.473 62.485 35.778-141.227-29.388-42.51c-32.974-47.751-50.418-103.653-50.418-161.653 0-156.848 127.195-284.444 283.556-284.444zM512.889 56.889c-219.445 0-397.333 178.292-397.333 398.222 0 84.124 26.167 162.028 70.612 226.32l-72.389 285.68 382.416-114.626c5.584 0.236 11.056 0.848 16.695 0.848 219.445 0 397.333-178.292 397.333-398.222s-177.888-398.222-397.333-398.222v0z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-sound" viewBox="0 0 1024 1024">
|
|
||||||
<title>sound</title>
|
|
||||||
<path class="path1" d="M581.056 113.778c-6.332 0-12.779 1.819-19.001 5.764l-230.277 159.847c-4.722 3.292-10.332 5.056-16.11 5.056h-202.112c-31.305 0-56.667 25.472-56.667 56.889v341.333c0 31.417 25.362 56.889 56.667 56.889h202.112c5.778 0 11.388 1.764 16.11 5.056l230.277 159.847c6.222 3.945 12.695 5.764 19.001 5.764 22.277 0 42.5-22.736 42.5-54v-688.43c0-31.278-20.222-54.014-42.5-54.014zM510.222 730.139l-135.78-94.265c-9.472-6.569-20.722-10.1-32.222-10.1h-143.666c-15.666 0-28.334-12.736-28.334-28.444v-170.667c0-15.708 12.667-28.444 28.334-28.444h143.668c11.5 0 22.75-3.527 32.222-10.098l135.778-94.26v436.277z"></path>
|
|
||||||
<path class="path2" d="M963.333 500.583c-4.889-99.417-86.112-170.139-142.612-207.57-26.75-17.737-62.222-6.93-75.364 23.195l-2.137 4.889c-10.667 24.5-2.583 53.403 19.111 67.945 40.167 26.903 90.222 70.958 92.389 117.486 1.833 38.473-31.445 83.5-94.612 129.111-22.667 16.375-30.112 47.708-16.222 72.555l2.389 4.292c15.111 27.001 49.278 35.486 73.945 17.762 98.999-71.15 147.111-148.233 143.111-229.664z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-monitor" viewBox="0 0 1024 1024">
|
|
||||||
<title>monitor</title>
|
|
||||||
<path class="path1" d="M910.222 56.889h-796.444c-31.417 0-56.889 25.472-56.889 56.889v682.667c0 31.417 25.472 56.889 56.889 56.889h312.889c-47.14 0-85.333 38.194-85.333 85.333v28.444h341.333v-28.444c0-47.14-38.194-85.333-85.333-85.333h312.889c31.417 0 56.889-25.472 56.889-56.889v-682.667c0-31.417-25.472-56.889-56.889-56.889zM853.333 711.111c0 15.723-12.722 28.444-28.444 28.444h-625.778c-15.723 0-28.444-12.722-28.444-28.444v-512c0-15.723 12.722-28.444 28.444-28.444h625.778c15.723 0 28.444 12.722 28.444 28.444v512z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-up" viewBox="0 0 1024 1024">
|
|
||||||
<title>up</title>
|
|
||||||
<path class="path1" d="M967.111 512c0-251.362-203.749-455.111-455.111-455.111s-455.111 203.749-455.111 455.111c0 251.362 203.749 455.111 455.111 455.111s455.111-203.749 455.111-455.111zM170.667 512c0-188.222 153.111-341.333 341.333-341.333s341.333 153.111 341.333 341.333-153.111 341.333-341.333 341.333-341.333-153.111-341.333-341.333z"></path>
|
|
||||||
<path class="path2" d="M568.784 683.221v-206.667l73.584 74.917c22.277 22.055 58.332 22.055 80.612 0 22.251-22.055 22.251-57.778 0-79.833l-168.779-170.667c-10.695-10.583-25.166-16.528-40.306-16.528-0.651 0-1.3 0.025-1.95 0.048-0.649-0.023-1.296-0.048-1.948-0.048-15.141 0-29.611 5.945-40.306 16.528l-168.779 170.667c-22.251 22.055-22.251 57.778 0 79.833 22.277 22.055 58.332 22.055 80.612 0l73.588-74.917v206.667c0 31.111 25.223 56.334 56.334 56.334h1.006c31.111 0 56.332-25.223 56.332-56.334z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-play" viewBox="0 0 1024 1024">
|
|
||||||
<title>play</title>
|
|
||||||
<path class="path1" d="M284.444 279.556l393.388 232.444-393.388 232.444v-464.889zM227.556 113.778c-31.417 0-56.889 25.472-56.889 56.889v682.667c0 31.417 25.472 56.889 56.889 56.889l601.278-355.305c15.166-8.972 24.5-25.278 24.5-42.917s-9.333-33.945-24.5-42.917l-601.278-355.305z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-fast-forward" viewBox="0 0 1024 1024">
|
|
||||||
<title>fast-forward</title>
|
|
||||||
<path class="path1" d="M999.5 469.083l-601.278-355.305c-31.417 0-56.889 25.472-56.889 56.889v111.184l-284.444-168.073c-31.417 0-56.889 25.472-56.889 56.889v682.667c0 31.417 25.472 56.889 56.889 56.889l284.444-168.084v111.195c0 31.417 25.472 56.889 56.889 56.889l601.278-355.305c15.195-8.972 24.5-25.278 24.5-42.917s-9.305-33.945-24.5-42.917zM341.333 609.972l-227.556 134.473v-464.889l227.556 134.473v195.943zM455.111 744.444v-464.889l393.388 232.444-393.388 232.444z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-refresh" viewBox="0 0 1024 1024">
|
|
||||||
<title>refresh</title>
|
|
||||||
<path class="path1" d="M455.874 796.763h-46.741c-134.912-22.064-238.203-139.554-238.203-280.692 0-47.296 12.142-91.534 32.651-130.773l34.875 48.352c25.397 35.179 80.169 25.371 91.813-16.452l66.11-237.758c9.198-33.013-15.646-65.719-49.909-65.664l-237.451 0.363c-42.183 0.055-66.555 47.852-41.877 82.087l64.19 88.951c-46.489 65.136-74.084 144.722-74.084 230.894 0 199.076 146 364.055 336.684 393.513 5.196 0.805 10.256 0.583 15.2-0.055v0.693h46.741c31.012 0 56.133-25.122 56.133-56.162v-1.14c0-31.012-25.122-56.158-56.133-56.158z"></path>
|
|
||||||
<path class="path2" d="M956.871 827.803l-64.219-88.951c46.517-65.138 74.084-144.722 74.084-230.894 0-199.076-145.972-364.057-336.656-393.54-5.198-0.805-10.256-0.583-15.202 0.084v-0.724h-46.768c-30.985 0-56.105 25.148-56.105 56.16v1.14c0 31.040 25.12 56.188 56.105 56.188h46.768c134.914 22.064 238.174 139.554 238.174 280.692 0 47.296-12.142 91.534-32.622 130.773l-34.903-48.352c-25.371-35.18-80.171-25.371-91.785 16.423l-66.137 237.756c-9.17 33.042 15.671 65.721 49.936 65.666l237.451-0.334c42.185-0.057 66.555-47.881 41.879-82.087z"></path>
|
|
||||||
</symbol>
|
|
||||||
<symbol id="icon-film" viewBox="0 0 1024 1024">
|
|
||||||
<title>film</title>
|
|
||||||
<path class="path1" d="M967.111 113.778h-910.222c-31.417 0-56.889 25.472-56.889 56.889v682.667c0 31.417 25.472 56.889 56.889 56.889h910.222c31.417 0 56.889-25.472 56.889-56.889v-682.667c0-31.417-25.472-56.889-56.889-56.889zM113.778 227.556h113.778v113.778h-113.778v-113.778zM113.778 455.111h113.778v113.778h-113.778v-113.778zM113.778 796.444v-113.778h113.778v113.778h-113.778zM341.333 796.444v-568.889h341.333v568.889h-341.333zM910.222 796.444h-113.778v-113.778h113.778v113.778zM910.222 568.889h-113.778v-113.778h113.778v113.778zM910.222 341.333h-113.778v-113.778h113.778v113.778z"></path>
|
|
||||||
</symbol>
|
|
||||||
</defs>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 6.1 KiB |
2
dist/plyr.css
vendored
2
dist/plyr.js
vendored
2
dist/sprite.svg
vendored
Before Width: | Height: | Size: 5.5 KiB After Width: | Height: | Size: 5.3 KiB |
2
docs/dist/docs.css
vendored
@ -1 +1 @@
|
|||||||
/*! normalize.css v2.1.3 | MIT License | git.io/normalize */article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block}audio,canvas,video{display:inline-block}audio:not([controls]){display:none;height:0}[hidden],template{display:none}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}a{background:0 0}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}hr{box-sizing:content-box;height:0}mark{background:#ff0;color:#000}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em}pre{white-space:pre-wrap}q{quotes:"\201C" "\201D" "\2018" "\2019"}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:0}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0}button,input,select,textarea{font-family:inherit;font-size:100%;margin:0}button,input{line-height:normal}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}textarea{overflow:auto;vertical-align:top}table{border-collapse:collapse;border-spacing:0}@font-face{font-family:Avenir;src:url(//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Medium.woff2) format("woff2"),url(//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Medium.woff) format("woff"),url(//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Medium.ttf) format("truetype");font-style:normal;font-weight:400}@font-face{font-family:Avenir;src:url(//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Heavy.woff2) format("woff2"),url(//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Heavy.woff) format("woff"),url(//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Heavy.ttf) format("truetype");font-style:normal;font-weight:600}*,::after,::before{box-sizing:border-box}body{font-family:Avenir,"Helvetica Neue",Helvetica,Arial,sans-serif;background:#fff;line-height:1.5;text-align:center;color:#6D797F}h1,h2{letter-spacing:-.025em;color:#2E3C44;margin:0 0 10px;line-height:1.2;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}h1{font-size:64px;font-size:4rem;color:#3498DB}p,small{margin:0 0 20px}small{display:block;padding:0 10px;font-size:14px;font-size:.9rem}header{padding:20px;margin-bottom:20px}header p{font-size:18px;font-size:1.1rem}@media (min-width:560px){header{padding-top:60px;padding-bottom:60px}}section{padding-bottom:20px}@media (min-width:560px){section{padding-bottom:40px}}a{text-decoration:none;color:#3498db;border-bottom:1px solid currentColor;transition:all .3s ease}a:focus,a:hover{color:#000}a:focus{outline:#343f4a dotted thin;outline-offset:1px}a.logo{border:0}.btn{display:inline-block;padding:10px 30px;background:#3498db;border:0;color:#fff;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;font-weight:600;border-radius:3px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn:focus,.btn:hover{color:#fff;background:#258cd1}.example-audio .player{max-width:480px}.example-video .player{max-width:1200px}.example-audio .player,.example-video .player{margin:0 auto 20px}.example-audio .player-fullscreen,.example-audio .player.fullscreen-active,.example-video .player-fullscreen,.example-video .player.fullscreen-active{max-width:none}footer{margin-bottom:20px}footer p{margin-bottom:10px}
|
/*! normalize.css v2.1.3 | MIT License | git.io/normalize */article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block}audio,canvas,video{display:inline-block}audio:not([controls]){display:none;height:0}[hidden],template{display:none}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}a{background:0 0}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}hr{box-sizing:content-box;height:0}mark{background:#ff0;color:#000}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em}pre{white-space:pre-wrap}q{quotes:"\201C" "\201D" "\2018" "\2019"}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:0}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0}button,input,select,textarea{font-family:inherit;font-size:100%;margin:0}button,input{line-height:normal}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}textarea{overflow:auto;vertical-align:top}table{border-collapse:collapse;border-spacing:0}@font-face{font-family:Avenir;src:url(//cdn.plyr.io/fonts/avenir-medium.woff2) format("woff2"),url(//cdn.plyr.io/fonts/avenir-medium.woff) format("woff"),url(//cdn.plyr.io/fonts/avenir-medium.ttf) format("truetype");font-style:normal;font-weight:400}@font-face{font-family:Avenir;src:url(//cdn.plyr.io/fonts/avenir-bold.woff2) format("woff2"),url(//cdn.plyr.io/fonts/avenir-bold.woff) format("woff"),url(//cdn.plyr.io/fonts/avenir-bold.ttf) format("truetype");font-style:normal;font-weight:600}*,::after,::before{box-sizing:border-box}body{font-family:Avenir,"Helvetica Neue",Helvetica,Arial,sans-serif;background:#fff;line-height:1.5;text-align:center;color:#6D797F}.error body,html.error{height:100%}.error body{width:100%;display:table;table-layout:fixed}.error main{display:table-cell;width:100%;vertical-align:middle}h1,h2{letter-spacing:-.025em;color:#2E3C44;margin:0 0 10px;line-height:1.2;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}h1{font-size:64px;font-size:4rem;color:#3498DB}p,small{margin:0 0 20px}small{display:block;padding:0 10px;font-size:14px;font-size:.9rem}header{padding:20px;margin-bottom:20px}header p{font-size:18px;font-size:1.1rem}@media (min-width:560px){header{padding-top:60px;padding-bottom:60px}}section{padding-bottom:20px}@media (min-width:560px){section{padding-bottom:40px}}a{text-decoration:none;color:#3498db;border-bottom:1px solid currentColor;transition:all .3s ease}a:focus,a:hover{color:#000}a:focus{outline:#343f4a dotted thin;outline-offset:1px}a.logo{border:0}.btn{display:inline-block;padding:10px 30px;background:#3498db;border:0;color:#fff;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;font-weight:600;border-radius:3px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn:focus,.btn:hover{color:#fff;background:#258cd1}.example-audio .player{max-width:520px}.example-video .player{max-width:1200px}.example-audio .player,.example-video .player{margin:0 auto 20px}.example-audio .player-fullscreen,.example-audio .player.fullscreen-active,.example-video .player-fullscreen,.example-video .player.fullscreen-active{max-width:none}footer{margin-bottom:20px}footer p{margin-bottom:10px}
|
2
docs/dist/docs.js
vendored
2
docs/dist/templates.js
vendored
@ -1,2 +1,2 @@
|
|||||||
var templates = {};
|
var templates = {};
|
||||||
templates['controls'] = new Hogan.Template({code: function (c,p,i) { var t=this;t.b(i=i||"");t.b("<div class=\"player-controls\">");t.b("\n" + i);t.b(" <div class=\"player-progress\">");t.b("\n" + i);t.b(" <progress class=\"player-progress-played\" max=\"100\" value=\"0\">");t.b("\n" + i);t.b(" <span>0</span>% played");t.b("\n" + i);t.b(" </progress>");t.b("\n" + i);t.b(" <progress class=\"player-progress-buffer\" max=\"100\" value=\"0\">");t.b("\n" + i);t.b(" <span>0</span>% buffered");t.b("\n" + i);t.b(" </progress>");t.b("\n" + i);t.b(" </div>");t.b("\n" + i);t.b(" <span class=\"player-controls-playback\">");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"restart\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-refresh\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Restart</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"rewind\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-rewind\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Rewind <span class=\"player-seek-time\">{seektime}</span> seconds</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"play\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-play\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Play</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"pause\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-pause\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Pause</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"fast-forward\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-fast-forward\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Fast forward <span class=\"player-seek-time\">{seektime}</span> seconds</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <span class=\"player-time\">");t.b("\n" + i);t.b(" <span class=\"sr-only\">Time</span>");t.b("\n" + i);t.b(" <span class=\"player-duration\">00:00</span>");t.b("\n" + i);t.b(" </span>");t.b("\n" + i);t.b(" </span>");t.b("\n" + i);t.b(" <span class=\"player-controls-sound\">");t.b("\n" + i);t.b(" <input class=\"inverted sr-only\" id=\"mute{id}\" type=\"checkbox\" data-player=\"mute\">");t.b("\n" + i);t.b(" <label id=\"mute{id}\" for=\"mute{id}\">");t.b("\n" + i);t.b(" <svg class=\"icon-muted\"><use xlink:href=\"#icon-muted\"></use></svg>");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-sound\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Mute</span>");t.b("\n" + i);t.b(" </label>");t.b("\n");t.b("\n" + i);t.b(" <label for=\"volume{id}\" class=\"sr-only\">Volume</label>");t.b("\n" + i);t.b(" <input id=\"volume{id}\" class=\"player-volume\" type=\"range\" min=\"0\" max=\"10\" value=\"5\" data-player=\"volume\">");t.b("\n");t.b("\n" + i);t.b(" <input class=\"sr-only\" id=\"captions{id}\" type=\"checkbox\" data-player=\"captions\">");t.b("\n" + i);t.b(" <label for=\"captions{id}\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-bubble\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Captions</span>");t.b("\n" + i);t.b(" </label>");t.b("\n");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"fullscreen\">");t.b("\n" + i);t.b(" <svg class=\"icon-exit-fullscreen\"><use xlink:href=\"#icon-collapse\"></use></svg>");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-expand\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Toggle fullscreen</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" </span>");t.b("\n" + i);t.b("</div>");return t.fl(); },partials: {}, subs: { }});
|
templates['controls'] = new Hogan.Template({code: function (c,p,i) { var t=this;t.b(i=i||"");t.b("<div class=\"player-controls\">");t.b("\n" + i);t.b(" <div class=\"player-progress\">");t.b("\n" + i);t.b(" <label for=\"seek{id}\" class=\"sr-only\">Seek</label>");t.b("\n" + i);t.b(" <input id=\"seek{id}\" class=\"player-progress-seek\" type=\"range\" min=\"0\" max=\"100\" step=\"0.5\" value=\"0\" data-player=\"seek\">");t.b("\n" + i);t.b(" <progress class=\"player-progress-played\" max=\"100\" value=\"0\">");t.b("\n" + i);t.b(" <span>0</span>% played");t.b("\n" + i);t.b(" </progress>");t.b("\n" + i);t.b(" <progress class=\"player-progress-buffer\" max=\"100\" value=\"0\">");t.b("\n" + i);t.b(" <span>0</span>% buffered");t.b("\n" + i);t.b(" </progress>");t.b("\n" + i);t.b(" </div>");t.b("\n" + i);t.b(" <span class=\"player-controls-left\">");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"restart\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-restart\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Restart</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"rewind\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-rewind\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Rewind {seektime} secs</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"play\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-play\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Play</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"pause\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-pause\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Pause</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"fast-forward\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-fast-forward\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Forward {seektime} secs</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <span class=\"player-time\">");t.b("\n" + i);t.b(" <span class=\"sr-only\">Current time</span>");t.b("\n" + i);t.b(" <span class=\"player-current-time\">00:00</span>");t.b("\n" + i);t.b(" </span>");t.b("\n" + i);t.b(" <span class=\"player-time\">");t.b("\n" + i);t.b(" <span class=\"sr-only\">Duration</span>");t.b("\n" + i);t.b(" <span class=\"player-duration\">00:00</span>");t.b("\n" + i);t.b(" </span>");t.b("\n" + i);t.b(" </span>");t.b("\n" + i);t.b(" <span class=\"player-controls-right\">");t.b("\n" + i);t.b(" <input class=\"inverted sr-only\" id=\"mute{id}\" type=\"checkbox\" data-player=\"mute\">");t.b("\n" + i);t.b(" <label id=\"mute{id}\" for=\"mute{id}\">");t.b("\n" + i);t.b(" <svg class=\"icon-muted\"><use xlink:href=\"#icon-muted\"></use></svg>");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-volume\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Toggle Mute</span>");t.b("\n" + i);t.b(" </label>");t.b("\n");t.b("\n" + i);t.b(" <label for=\"volume{id}\" class=\"sr-only\">Volume</label>");t.b("\n" + i);t.b(" <input id=\"volume{id}\" class=\"player-volume\" type=\"range\" min=\"0\" max=\"10\" step=\"0.5\" value=\"0\" data-player=\"volume\">");t.b("\n");t.b("\n" + i);t.b(" <input class=\"sr-only\" id=\"captions{id}\" type=\"checkbox\" data-player=\"captions\">");t.b("\n" + i);t.b(" <label for=\"captions{id}\">");t.b("\n" + i);t.b(" <svg class=\"icon-captions-on\"><use xlink:href=\"#icon-captions-on\"></use></svg>");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-captions-off\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Toggle Captions</span>");t.b("\n" + i);t.b(" </label>");t.b("\n");t.b("\n" + i);t.b(" <button type=\"button\" data-player=\"fullscreen\">");t.b("\n" + i);t.b(" <svg class=\"icon-exit-fullscreen\"><use xlink:href=\"#icon-exit-fullscreen\"></use></svg>");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-enter-fullscreen\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Toggle Fullscreen</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" </span>");t.b("\n" + i);t.b("</div>");return t.fl(); },partials: {}, subs: { }});
|
18
docs/error.html
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<!doctype html>
|
||||||
|
<html lang="en" class="error">
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8" />
|
||||||
|
<title>Doh. Looks like something went wrong.</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
|
||||||
|
<!-- Docs styles -->
|
||||||
|
<link rel="stylesheet" href="//cdn.plyr.io/1.1.0/docs.css">
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<main>
|
||||||
|
<h1>Doh.</h1>
|
||||||
|
<p>Looks like something went wrong.</p>
|
||||||
|
<a href="http://plyr.io" class="btn">Back to plyr.io</a>
|
||||||
|
</main>
|
||||||
|
</body>
|
||||||
|
</html>
|
152
docs/index.html
@ -1,79 +1,95 @@
|
|||||||
<!doctype html>
|
<!doctype html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8" />
|
<meta charset="utf-8" />
|
||||||
<title>Plyr - A simple HTML5 media player</title>
|
<title>Plyr - A simple HTML5 media player</title>
|
||||||
<meta name="description" content="A simple HTML5 media player with custom controls and WebVTT captions.">
|
<meta name="description" content="A simple HTML5 media player with custom controls and WebVTT captions.">
|
||||||
<meta name="author" content="Sam Potts">
|
<meta name="author" content="Sam Potts">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
|
||||||
<!-- Styles -->
|
<!-- Styles -->
|
||||||
<link rel="stylesheet" href="//cdn.plyr.io/1.0.17/plyr.css">
|
<link rel="stylesheet" href="//cdn.plyr.io/1.1.0/plyr.css">
|
||||||
|
|
||||||
<!-- Docs styles -->
|
<!-- Docs styles -->
|
||||||
<link rel="stylesheet" href="//cdn.plyr.io/1.0.17/docs.css">
|
<link rel="stylesheet" href="//cdn.plyr.io/1.1.0/docs.css">
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<header>
|
<header>
|
||||||
<h1>Plyr</h1>
|
<h1>Plyr</h1>
|
||||||
<p>A simple HTML5 media player with custom controls and WebVTT captions.</p>
|
<p>A simple HTML5 media player with custom controls and WebVTT captions.</p>
|
||||||
<a href="https://github.com/selz/plyr" target="_blank" class="btn">Download on Github</a>
|
<a href="https://github.com/selz/plyr" target="_blank" class="btn">Download on GitHub</a>
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
<main>
|
<main>
|
||||||
<section class="example-video">
|
<section class="example-video">
|
||||||
<div class="player">
|
<div class="player">
|
||||||
<video poster="//cdn.selz.com/plyr/1.0/poster.jpg" controls crossorigin>
|
<video poster="//cdn.selz.com/plyr/1.0/poster.jpg" controls crossorigin>
|
||||||
<!-- Video files -->
|
<!-- Video files -->
|
||||||
<source src="//cdn.selz.com/plyr/1.0/movie.mp4" type="video/mp4">
|
<source src="//cdn.selz.com/plyr/1.0/movie.mp4" type="video/mp4">
|
||||||
<source src="//cdn.selz.com/plyr/1.0/movie.webm" type="video/webm">
|
<source src="//cdn.selz.com/plyr/1.0/movie.webm" type="video/webm">
|
||||||
|
|
||||||
<!-- Text track file -->
|
<!-- Text track file -->
|
||||||
<track kind="captions" label="English" srclang="en" src="//cdn.selz.com/plyr/1.0/movie_en_captions.vtt" default>
|
<track kind="captions" label="English" srclang="en" src="//cdn.selz.com/plyr/1.0/en.vtt" default>
|
||||||
|
|
||||||
<!-- Fallback for browsers that don't support the <video> element -->
|
<!-- Fallback for browsers that don't support the <video> element -->
|
||||||
<div>
|
<div>
|
||||||
<a href="//cdn.selz.com/plyr/1.0/movie.mp4">Download</a>
|
<a href="//cdn.selz.com/plyr/1.0/movie.mp4">Download</a>
|
||||||
</div>
|
</div>
|
||||||
</video>
|
</video>
|
||||||
</div>
|
</div>
|
||||||
<small>Big Buck Bunny. More info can be found at <a href="https://peach.blender.org" target="_blank">peach.blender.org</a>.</small>
|
<small>Big Buck Bunny. More info can be found at <a href="https://peach.blender.org" target="_blank">peach.blender.org</a>.</small>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
<section class="example-audio">
|
<section class="example-audio">
|
||||||
<div class="player">
|
<div class="player">
|
||||||
<audio controls>
|
<audio controls>
|
||||||
<!-- Audio files -->
|
<!-- Audio files -->
|
||||||
<source src="//cdn.selz.com/plyr/1.0/logistics-96-sample.mp3" type="audio/mp3">
|
<source src="//cdn.selz.com/plyr/1.0/logistics-96-sample.mp3" type="audio/mp3">
|
||||||
<source src="//cdn.selz.com/plyr/1.0/logistics-96-sample.ogg" type="audio/ogg">
|
<source src="//cdn.selz.com/plyr/1.0/logistics-96-sample.ogg" type="audio/ogg">
|
||||||
|
|
||||||
<!-- Fallback for browsers that don't support the <audio> element -->
|
<!-- Fallback for browsers that don't support the <audio> element -->
|
||||||
<div>
|
<div>
|
||||||
<a href="//cdn.selz.com/plyr/1.0/logistics-96-sample.mp3">Download</a>
|
<a href="//cdn.selz.com/plyr/1.0/logistics-96-sample.mp3">Download</a>
|
||||||
</div>
|
</div>
|
||||||
</audio>
|
</audio>
|
||||||
</div>
|
</div>
|
||||||
<small>"96" by Logistics, which can be purchased from <a href="https://www.hospitalrecords.com/shop/artist/logistics" target="_blank">Hospital Records</a>.</small>
|
<small>"96" by Logistics, which can be purchased from <a href="https://www.hospitalrecords.com/shop/artist/logistics" target="_blank">Hospital Records</a>.</small>
|
||||||
</section>
|
</section>
|
||||||
</main>
|
</main>
|
||||||
|
|
||||||
<footer>
|
<footer>
|
||||||
<p>Used by …</p>
|
<p>Used by …</p>
|
||||||
<a href="https://selz.com" target="_blank" class="logo">
|
<a href="https://selz.com" target="_blank" class="logo">
|
||||||
<img src="https://d33i624pw6jj68.cloudfront.net/static/img/logos/selz.svg" alt="Selz">
|
<img src="https://d33i624pw6jj68.cloudfront.net/static/img/logos/selz.svg" alt="Selz">
|
||||||
</a>
|
</a>
|
||||||
</footer>
|
</footer>
|
||||||
|
|
||||||
<!-- Load SVG defs -->
|
<!-- Load SVG defs -->
|
||||||
<!-- You should bundle all SVG/Icons into one file using a build tool such as gulp and svg store -->
|
<!-- You should bundle all SVG/Icons into one file using a build tool such as gulp and svg store -->
|
||||||
<script>
|
<script>
|
||||||
(function(d,p){var a=new XMLHttpRequest(),b=d.body;a.open("GET",p,!0);a.send();a.onload=function(){var c=d.createElement("div");c.style.display="none";c.innerHTML=a.responseText;b.insertBefore(c,b.childNodes[0])}})(document,"//cdn.plyr.io/1.0.17/sprite.svg");
|
(function(d, u){
|
||||||
</script>
|
var a = new XMLHttpRequest(),
|
||||||
|
b = d.body;
|
||||||
|
|
||||||
<!-- Plyr core script -->
|
// Check for CORS support
|
||||||
<script src="//cdn.plyr.io/1.0.17/plyr.js"></script>
|
// If you're loading from same domain, you can remove the if statement
|
||||||
|
if("withCredentials" in a) {
|
||||||
|
a.open("GET", u, true);
|
||||||
|
a.send();
|
||||||
|
a.onload = function(){
|
||||||
|
var c = d.createElement("div");
|
||||||
|
c.style.display="none";
|
||||||
|
c.innerHTML = a.responseText;
|
||||||
|
b.insertBefore(c, b.childNodes[0]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})(document, "https://cdn.plyr.io/1.1.0/sprite.svg");
|
||||||
|
</script>
|
||||||
|
|
||||||
<!-- Docs script -->
|
<!-- Plyr core script -->
|
||||||
<script src="//cdn.plyr.io/1.0.17/docs.js"></script>
|
<script src="//cdn.plyr.io/1.1.0/plyr.js"></script>
|
||||||
</body>
|
|
||||||
|
<!-- Docs script -->
|
||||||
|
<script src="//cdn.plyr.io/1.1.0/docs.js"></script>
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
@ -15,8 +15,8 @@ plyr.setup({
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Google analytics
|
// Google analytics
|
||||||
// For demo site (http://plyr.io) only
|
// For demo site (http://[www.]plyr.io) only
|
||||||
if(document.domain === "plyr.io") {
|
if(document.domain.indexOf("plyr.io") > -1) {
|
||||||
(function(i,s,o,g,r,a,m){i.GoogleAnalyticsObject=r;i[r]=i[r]||function(){
|
(function(i,s,o,g,r,a,m){i.GoogleAnalyticsObject=r;i[r]=i[r]||function(){
|
||||||
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
|
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
|
||||||
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
|
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
|
||||||
|
@ -12,140 +12,153 @@
|
|||||||
// Variables
|
// Variables
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
// Colors
|
// Colors
|
||||||
@blue: #3498DB;
|
@blue: #3498DB;
|
||||||
@gray-dark: #343f4a;
|
@gray-dark: #343f4a;
|
||||||
@gray: #565d64;
|
@gray: #565d64;
|
||||||
@gray-light: #cbd0d3;
|
@gray-light: #cbd0d3;
|
||||||
|
|
||||||
// Elements
|
// Elements
|
||||||
@link-color: @blue;
|
@link-color: @blue;
|
||||||
@padding-base: 20px;
|
@padding-base: 20px;
|
||||||
|
|
||||||
// Breakpoints
|
// Breakpoints
|
||||||
@screen-md: 768px;
|
@screen-md: 768px;
|
||||||
|
|
||||||
// BORDER-BOX ALL THE THINGS!
|
// BORDER-BOX ALL THE THINGS!
|
||||||
// http://paulirish.com/2012/box-sizing-border-box-ftw/
|
// http://paulirish.com/2012/box-sizing-border-box-ftw/
|
||||||
*, *::after, *::before {
|
*, *::after, *::before {
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Base
|
// Base
|
||||||
html {
|
|
||||||
//font-size: 62.5%;
|
|
||||||
}
|
|
||||||
body {
|
body {
|
||||||
font-family: "Avenir", "Helvetica Neue", Helvetica, Arial, sans-serif;
|
font-family: "Avenir", "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||||||
background: #fff;
|
background: #fff;
|
||||||
line-height: 1.5;
|
line-height: 1.5;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
color: #6D797F;
|
color: #6D797F;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error page
|
||||||
|
html.error,
|
||||||
|
.error body {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
.error body {
|
||||||
|
width: 100%;
|
||||||
|
display: table;
|
||||||
|
table-layout: fixed;
|
||||||
|
}
|
||||||
|
.error main {
|
||||||
|
display: table-cell;
|
||||||
|
width: 100%;
|
||||||
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Type
|
// Type
|
||||||
h1,
|
h1,
|
||||||
h2 {
|
h2 {
|
||||||
letter-spacing: -.025em;
|
letter-spacing: -.025em;
|
||||||
color: #2E3C44;
|
color: #2E3C44;
|
||||||
margin: 0 0 (@padding-base / 2);
|
margin: 0 0 (@padding-base / 2);
|
||||||
line-height: 1.2;
|
line-height: 1.2;
|
||||||
.font-smoothing();
|
.font-smoothing();
|
||||||
}
|
}
|
||||||
h1 {
|
h1 {
|
||||||
.font-size(64);
|
.font-size(64);
|
||||||
color: #3498DB;
|
color: #3498DB;
|
||||||
}
|
}
|
||||||
p,
|
p,
|
||||||
small {
|
small {
|
||||||
margin: 0 0 @padding-base;
|
margin: 0 0 @padding-base;
|
||||||
}
|
}
|
||||||
small {
|
small {
|
||||||
display: block;
|
display: block;
|
||||||
padding: 0 (@padding-base / 2);
|
padding: 0 (@padding-base / 2);
|
||||||
.font-size(14);
|
.font-size(14);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
header {
|
header {
|
||||||
padding: @padding-base;
|
padding: @padding-base;
|
||||||
margin-bottom: @padding-base;
|
margin-bottom: @padding-base;
|
||||||
|
|
||||||
p {
|
p {
|
||||||
.font-size(18);
|
.font-size(18);
|
||||||
}
|
}
|
||||||
@media (min-width: 560px) {
|
@media (min-width: 560px) {
|
||||||
padding-top: (@padding-base * 3);
|
padding-top: (@padding-base * 3);
|
||||||
padding-bottom: (@padding-base * 3);
|
padding-bottom: (@padding-base * 3);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sections
|
// Sections
|
||||||
section {
|
section {
|
||||||
padding-bottom: @padding-base;
|
padding-bottom: @padding-base;
|
||||||
|
|
||||||
@media (min-width: 560px) {
|
@media (min-width: 560px) {
|
||||||
padding-bottom: (@padding-base * 2);
|
padding-bottom: (@padding-base * 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Links & Buttons
|
// Links & Buttons
|
||||||
a {
|
a {
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
color: @link-color;
|
color: @link-color;
|
||||||
border-bottom: 1px solid currentColor;
|
border-bottom: 1px solid currentColor;
|
||||||
transition: all .3s ease;
|
transition: all .3s ease;
|
||||||
|
|
||||||
&:hover,
|
&:hover,
|
||||||
&:focus {
|
&:focus {
|
||||||
color: #000;
|
color: #000;
|
||||||
}
|
}
|
||||||
&:focus {
|
&:focus {
|
||||||
.tab-focus();
|
.tab-focus();
|
||||||
}
|
}
|
||||||
&.logo {
|
&.logo {
|
||||||
border: 0;
|
border: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.btn {
|
.btn {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
padding: (@padding-base / 2) (@padding-base * 1.5);
|
padding: (@padding-base / 2) (@padding-base * 1.5);
|
||||||
background: @link-color;
|
background: @link-color;
|
||||||
border: 0;
|
border: 0;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
.font-smoothing(on);
|
.font-smoothing(on);
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
user-select: none;
|
user-select: none;
|
||||||
|
|
||||||
&:hover,
|
&:hover,
|
||||||
&:focus {
|
&:focus {
|
||||||
color: #fff;
|
color: #fff;
|
||||||
background: darken(@link-color, 5%);
|
background: darken(@link-color, 5%);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Players
|
// Players
|
||||||
.example-audio .player {
|
.example-audio .player {
|
||||||
max-width: 480px;
|
max-width: 520px;
|
||||||
}
|
}
|
||||||
.example-video .player {
|
.example-video .player {
|
||||||
max-width: 1200px;
|
max-width: 1200px;
|
||||||
}
|
}
|
||||||
.example-audio .player,
|
.example-audio .player,
|
||||||
.example-video .player {
|
.example-video .player {
|
||||||
margin: 0 auto @padding-base;
|
margin: 0 auto @padding-base;
|
||||||
|
|
||||||
&-fullscreen,
|
&-fullscreen,
|
||||||
&.fullscreen-active {
|
&.fullscreen-active {
|
||||||
max-width: none;
|
max-width: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Footer
|
// Footer
|
||||||
footer {
|
footer {
|
||||||
margin-bottom: @padding-base;
|
margin-bottom: @padding-base;
|
||||||
|
|
||||||
p {
|
p {
|
||||||
margin-bottom: (@padding-base / 2);
|
margin-bottom: (@padding-base / 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,16 +1,16 @@
|
|||||||
@font-face {
|
@font-face {
|
||||||
font-family: "Avenir";
|
font-family: "Avenir";
|
||||||
src: url("//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Medium.woff2") format("woff2"),
|
src: url("//cdn.plyr.io/fonts/avenir-medium.woff2") format("woff2"),
|
||||||
url("//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Medium.woff") format("woff"),
|
url("//cdn.plyr.io/fonts/avenir-medium.woff") format("woff"),
|
||||||
url("//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Medium.ttf") format("truetype");
|
url("//cdn.plyr.io/fonts/avenir-medium.ttf") format("truetype");
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-weight: 400;
|
font-weight: 400;
|
||||||
}
|
}
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: "Avenir";
|
font-family: "Avenir";
|
||||||
src: url("//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Heavy.woff2") format("woff2"),
|
src: url("//cdn.plyr.io/fonts/avenir-bold.woff2") format("woff2"),
|
||||||
url("//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Heavy.woff") format("woff"),
|
url("//cdn.plyr.io/fonts/avenir-bold.woff") format("woff"),
|
||||||
url("//cdn.sampotts.me/plyr/fonts/AvenirLTStd-Heavy.ttf") format("truetype");
|
url("//cdn.plyr.io/fonts/avenir-bold.ttf") format("truetype");
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
}
|
}
|
@ -5,38 +5,38 @@
|
|||||||
// Contain floats: nicolasgallagher.com/micro-clearfix-hack/
|
// Contain floats: nicolasgallagher.com/micro-clearfix-hack/
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
.clearfix() {
|
.clearfix() {
|
||||||
zoom: 1;
|
zoom: 1;
|
||||||
&:before,
|
&:before,
|
||||||
&:after { content: ""; display: table; }
|
&:after { content: ""; display: table; }
|
||||||
&:after { clear: both; }
|
&:after { clear: both; }
|
||||||
}
|
}
|
||||||
|
|
||||||
// Webkit-style focus
|
// Webkit-style focus
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
.tab-focus() {
|
.tab-focus() {
|
||||||
// Default
|
// Default
|
||||||
outline: thin dotted @gray-dark;
|
outline: thin dotted @gray-dark;
|
||||||
// Webkit
|
// Webkit
|
||||||
//outline: 5px auto -webkit-focus-ring-color;
|
//outline: 5px auto -webkit-focus-ring-color;
|
||||||
outline-offset: 1px;
|
outline-offset: 1px;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use rems for font sizing
|
// Use rems for font sizing
|
||||||
// Leave <body> at 100%/16px
|
// Leave <body> at 100%/16px
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
.font-size(@font-size: 16){
|
.font-size(@font-size: 16){
|
||||||
@rem: round((@font-size / 16), 1);
|
@rem: round((@font-size / 16), 1);
|
||||||
font-size: (@font-size * 1px);
|
font-size: (@font-size * 1px);
|
||||||
font-size: ~"@{rem}rem";
|
font-size: ~"@{rem}rem";
|
||||||
}
|
}
|
||||||
|
|
||||||
// Font smoothing
|
// Font smoothing
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
.font-smoothing(@mode: on) when (@mode = on) {
|
.font-smoothing(@mode: on) when (@mode = on) {
|
||||||
-moz-osx-font-smoothing: grayscale;
|
-moz-osx-font-smoothing: grayscale;
|
||||||
-webkit-font-smoothing: antialiased;
|
-webkit-font-smoothing: antialiased;
|
||||||
}
|
}
|
||||||
.font-smoothing(@mode: on) when (@mode = off) {
|
.font-smoothing(@mode: on) when (@mode = off) {
|
||||||
-moz-osx-font-smoothing: auto;
|
-moz-osx-font-smoothing: auto;
|
||||||
-webkit-font-smoothing: subpixel-antialiased;
|
-webkit-font-smoothing: subpixel-antialiased;
|
||||||
}
|
}
|
@ -1,59 +1,66 @@
|
|||||||
<div class="player-controls">
|
<div class="player-controls">
|
||||||
<div class="player-progress">
|
<div class="player-progress">
|
||||||
<progress class="player-progress-played" max="100" value="0">
|
<label for="seek{id}" class="sr-only">Seek</label>
|
||||||
<span>0</span>% played
|
<input id="seek{id}" class="player-progress-seek" type="range" min="0" max="100" step="0.5" value="0" data-player="seek">
|
||||||
</progress>
|
<progress class="player-progress-played" max="100" value="0">
|
||||||
<progress class="player-progress-buffer" max="100" value="0">
|
<span>0</span>% played
|
||||||
<span>0</span>% buffered
|
</progress>
|
||||||
</progress>
|
<progress class="player-progress-buffer" max="100" value="0">
|
||||||
</div>
|
<span>0</span>% buffered
|
||||||
<span class="player-controls-playback">
|
</progress>
|
||||||
<button type="button" data-player="restart">
|
</div>
|
||||||
<svg><use xlink:href="#icon-refresh"></use></svg>
|
<span class="player-controls-left">
|
||||||
<span class="sr-only">Restart</span>
|
<button type="button" data-player="restart">
|
||||||
</button>
|
<svg><use xlink:href="#icon-restart"></use></svg>
|
||||||
<button type="button" data-player="rewind">
|
<span class="sr-only">Restart</span>
|
||||||
<svg><use xlink:href="#icon-rewind"></use></svg>
|
</button>
|
||||||
<span class="sr-only">Rewind <span class="player-seek-time">{seektime}</span> seconds</span>
|
<button type="button" data-player="rewind">
|
||||||
</button>
|
<svg><use xlink:href="#icon-rewind"></use></svg>
|
||||||
<button type="button" data-player="play">
|
<span class="sr-only">Rewind {seektime} secs</span>
|
||||||
<svg><use xlink:href="#icon-play"></use></svg>
|
</button>
|
||||||
<span class="sr-only">Play</span>
|
<button type="button" data-player="play">
|
||||||
</button>
|
<svg><use xlink:href="#icon-play"></use></svg>
|
||||||
<button type="button" data-player="pause">
|
<span class="sr-only">Play</span>
|
||||||
<svg><use xlink:href="#icon-pause"></use></svg>
|
</button>
|
||||||
<span class="sr-only">Pause</span>
|
<button type="button" data-player="pause">
|
||||||
</button>
|
<svg><use xlink:href="#icon-pause"></use></svg>
|
||||||
<button type="button" data-player="fast-forward">
|
<span class="sr-only">Pause</span>
|
||||||
<svg><use xlink:href="#icon-fast-forward"></use></svg>
|
</button>
|
||||||
<span class="sr-only">Fast forward <span class="player-seek-time">{seektime}</span> seconds</span>
|
<button type="button" data-player="fast-forward">
|
||||||
</button>
|
<svg><use xlink:href="#icon-fast-forward"></use></svg>
|
||||||
<span class="player-time">
|
<span class="sr-only">Forward {seektime} secs</span>
|
||||||
<span class="sr-only">Time</span>
|
</button>
|
||||||
<span class="player-duration">00:00</span>
|
<span class="player-time">
|
||||||
</span>
|
<span class="sr-only">Current time</span>
|
||||||
</span>
|
<span class="player-current-time">00:00</span>
|
||||||
<span class="player-controls-sound">
|
</span>
|
||||||
<input class="inverted sr-only" id="mute{id}" type="checkbox" data-player="mute">
|
<span class="player-time">
|
||||||
<label id="mute{id}" for="mute{id}">
|
<span class="sr-only">Duration</span>
|
||||||
<svg class="icon-muted"><use xlink:href="#icon-muted"></use></svg>
|
<span class="player-duration">00:00</span>
|
||||||
<svg><use xlink:href="#icon-sound"></use></svg>
|
</span>
|
||||||
<span class="sr-only">Mute</span>
|
</span>
|
||||||
</label>
|
<span class="player-controls-right">
|
||||||
|
<input class="inverted sr-only" id="mute{id}" type="checkbox" data-player="mute">
|
||||||
|
<label id="mute{id}" for="mute{id}">
|
||||||
|
<svg class="icon-muted"><use xlink:href="#icon-muted"></use></svg>
|
||||||
|
<svg><use xlink:href="#icon-volume"></use></svg>
|
||||||
|
<span class="sr-only">Toggle Mute</span>
|
||||||
|
</label>
|
||||||
|
|
||||||
<label for="volume{id}" class="sr-only">Volume</label>
|
<label for="volume{id}" class="sr-only">Volume</label>
|
||||||
<input id="volume{id}" class="player-volume" type="range" min="0" max="10" value="5" data-player="volume">
|
<input id="volume{id}" class="player-volume" type="range" min="0" max="10" step="0.5" value="0" data-player="volume">
|
||||||
|
|
||||||
<input class="sr-only" id="captions{id}" type="checkbox" data-player="captions">
|
<input class="sr-only" id="captions{id}" type="checkbox" data-player="captions">
|
||||||
<label for="captions{id}">
|
<label for="captions{id}">
|
||||||
<svg><use xlink:href="#icon-bubble"></use></svg>
|
<svg class="icon-captions-on"><use xlink:href="#icon-captions-on"></use></svg>
|
||||||
<span class="sr-only">Captions</span>
|
<svg><use xlink:href="#icon-captions-off"></use></svg>
|
||||||
</label>
|
<span class="sr-only">Toggle Captions</span>
|
||||||
|
</label>
|
||||||
|
|
||||||
<button type="button" data-player="fullscreen">
|
<button type="button" data-player="fullscreen">
|
||||||
<svg class="icon-exit-fullscreen"><use xlink:href="#icon-collapse"></use></svg>
|
<svg class="icon-exit-fullscreen"><use xlink:href="#icon-exit-fullscreen"></use></svg>
|
||||||
<svg><use xlink:href="#icon-expand"></use></svg>
|
<svg><use xlink:href="#icon-enter-fullscreen"></use></svg>
|
||||||
<span class="sr-only">Toggle fullscreen</span>
|
<span class="sr-only">Toggle Fullscreen</span>
|
||||||
</button>
|
</button>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
363
gulpfile.js
@ -2,59 +2,62 @@
|
|||||||
// Gulp build script
|
// Gulp build script
|
||||||
// ==========================================================================
|
// ==========================================================================
|
||||||
/*global require, __dirname*/
|
/*global require, __dirname*/
|
||||||
|
/*jshint -W079 */
|
||||||
|
|
||||||
var fs = require("fs"),
|
var fs = require("fs"),
|
||||||
path = require("path"),
|
path = require("path"),
|
||||||
gulp = require("gulp"),
|
gulp = require("gulp"),
|
||||||
gutil = require("gulp-util"),
|
gutil = require("gulp-util"),
|
||||||
concat = require("gulp-concat"),
|
concat = require("gulp-concat"),
|
||||||
uglify = require("gulp-uglify"),
|
uglify = require("gulp-uglify"),
|
||||||
less = require("gulp-less"),
|
less = require("gulp-less"),
|
||||||
sass = require("gulp-sass"),
|
sass = require("gulp-sass"),
|
||||||
minify = require("gulp-minify-css"),
|
minify = require("gulp-minify-css"),
|
||||||
run = require("run-sequence"),
|
run = require("run-sequence"),
|
||||||
prefix = require("gulp-autoprefixer"),
|
prefix = require("gulp-autoprefixer"),
|
||||||
svgstore = require("gulp-svgstore"),
|
svgstore = require("gulp-svgstore"),
|
||||||
svgmin = require("gulp-svgmin"),
|
svgmin = require("gulp-svgmin"),
|
||||||
hogan = require("gulp-hogan-compile"),
|
hogan = require("gulp-hogan-compile"),
|
||||||
rename = require("gulp-rename"),
|
rename = require("gulp-rename"),
|
||||||
s3 = require("gulp-s3"),
|
s3 = require("gulp-s3"),
|
||||||
gzip = require("gulp-gzip"),
|
gzip = require("gulp-gzip"),
|
||||||
replace = require("gulp-replace");
|
replace = require("gulp-replace"),
|
||||||
|
open = require("gulp-open"),
|
||||||
|
size = require("gulp-size");
|
||||||
|
|
||||||
var root = __dirname,
|
var root = __dirname,
|
||||||
paths = {
|
paths = {
|
||||||
plyr: {
|
plyr: {
|
||||||
// Source paths
|
// Source paths
|
||||||
src: {
|
src: {
|
||||||
less: path.join(root, "src/less/**/*"),
|
less: path.join(root, "src/less/**/*"),
|
||||||
sass: path.join(root, "src/sass/**/*"),
|
sass: path.join(root, "src/sass/**/*"),
|
||||||
js: path.join(root, "src/js/**/*"),
|
js: path.join(root, "src/js/**/*"),
|
||||||
sprite: path.join(root, "src/sprite/*.svg")
|
sprite: path.join(root, "src/sprite/*.svg")
|
||||||
},
|
},
|
||||||
// Output paths
|
// Output paths
|
||||||
output: path.join(root, "dist/")
|
output: path.join(root, "dist/")
|
||||||
},
|
},
|
||||||
docs: {
|
docs: {
|
||||||
// Source paths
|
// Source paths
|
||||||
src: {
|
src: {
|
||||||
less: path.join(root, "docs/src/less/**/*"),
|
less: path.join(root, "docs/src/less/**/*"),
|
||||||
js: path.join(root, "docs/src/js/**/*"),
|
js: path.join(root, "docs/src/js/**/*"),
|
||||||
templates: path.join(root, "docs/src/templates/*.html")
|
templates: path.join(root, "docs/src/templates/*.html")
|
||||||
},
|
},
|
||||||
// Output paths
|
// Output paths
|
||||||
output: path.join(root, "docs/dist/"),
|
output: path.join(root, "docs/dist/"),
|
||||||
// Docs
|
// Docs
|
||||||
root: path.join(root, "docs/")
|
root: path.join(root, "docs/")
|
||||||
},
|
},
|
||||||
upload: [path.join(root, "dist/**"), path.join(root, "docs/dist/**")]
|
upload: [path.join(root, "dist/**"), path.join(root, "docs/dist/**")]
|
||||||
},
|
},
|
||||||
|
|
||||||
// Task arrays
|
// Task arrays
|
||||||
tasks = {
|
tasks = {
|
||||||
less: [],
|
less: [],
|
||||||
sass: [],
|
sass: [],
|
||||||
js: []
|
js: []
|
||||||
},
|
},
|
||||||
|
|
||||||
// Fetch bundles from JSON
|
// Fetch bundles from JSON
|
||||||
@ -67,88 +70,88 @@ function loadJSON(path) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var build = {
|
var build = {
|
||||||
js: function (files, bundle) {
|
js: function (files, bundle) {
|
||||||
for (var key in files) {
|
for (var key in files) {
|
||||||
(function(key) {
|
(function(key) {
|
||||||
var name = "js-" + key;
|
var name = "js-" + key;
|
||||||
tasks.js.push(name);
|
tasks.js.push(name);
|
||||||
|
|
||||||
gulp.task(name, function () {
|
gulp.task(name, function () {
|
||||||
return gulp
|
return gulp
|
||||||
.src(bundles[bundle].js[key])
|
.src(bundles[bundle].js[key])
|
||||||
.pipe(concat(key))
|
.pipe(concat(key))
|
||||||
.pipe(uglify())
|
.pipe(uglify())
|
||||||
.pipe(gulp.dest(paths[bundle].output));
|
.pipe(gulp.dest(paths[bundle].output));
|
||||||
});
|
});
|
||||||
})(key);
|
})(key);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
less: function(files, bundle) {
|
less: function(files, bundle) {
|
||||||
for (var key in files) {
|
for (var key in files) {
|
||||||
(function (key) {
|
(function (key) {
|
||||||
var name = "less-" + key;
|
var name = "less-" + key;
|
||||||
tasks.less.push(name);
|
tasks.less.push(name);
|
||||||
|
|
||||||
gulp.task(name, function () {
|
gulp.task(name, function () {
|
||||||
return gulp
|
return gulp
|
||||||
.src(bundles[bundle].less[key])
|
.src(bundles[bundle].less[key])
|
||||||
.pipe(less())
|
.pipe(less())
|
||||||
.on("error", gutil.log)
|
.on("error", gutil.log)
|
||||||
.pipe(concat(key))
|
.pipe(concat(key))
|
||||||
.pipe(prefix(["last 2 versions"], { cascade: true }))
|
.pipe(prefix(["last 2 versions"], { cascade: true }))
|
||||||
.pipe(minify())
|
.pipe(minify())
|
||||||
.pipe(gulp.dest(paths[bundle].output));
|
.pipe(gulp.dest(paths[bundle].output));
|
||||||
});
|
});
|
||||||
})(key);
|
})(key);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
sass: function(files, bundle) {
|
sass: function(files, bundle) {
|
||||||
for (var key in files) {
|
for (var key in files) {
|
||||||
(function (key) {
|
(function (key) {
|
||||||
var name = "sass-" + key;
|
var name = "sass-" + key;
|
||||||
tasks.sass.push(name);
|
tasks.sass.push(name);
|
||||||
|
|
||||||
gulp.task(name, function () {
|
gulp.task(name, function () {
|
||||||
return gulp
|
return gulp
|
||||||
.src(bundles[bundle].sass[key])
|
.src(bundles[bundle].sass[key])
|
||||||
.pipe(sass())
|
.pipe(sass())
|
||||||
.on("error", gutil.log)
|
.on("error", gutil.log)
|
||||||
.pipe(concat(key))
|
.pipe(concat(key))
|
||||||
.pipe(prefix(["last 2 versions"], { cascade: true }))
|
.pipe(prefix(["last 2 versions"], { cascade: true }))
|
||||||
.pipe(minify())
|
.pipe(minify())
|
||||||
.pipe(gulp.dest(paths[bundle].output));
|
.pipe(gulp.dest(paths[bundle].output));
|
||||||
});
|
});
|
||||||
})(key);
|
})(key);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
sprite: function() {
|
sprite: function() {
|
||||||
// Process Icons
|
// Process Icons
|
||||||
gulp.task("sprite", function () {
|
gulp.task("sprite", function () {
|
||||||
return gulp
|
return gulp
|
||||||
.src(paths.plyr.src.sprite)
|
.src(paths.plyr.src.sprite)
|
||||||
.pipe(svgmin({
|
.pipe(svgmin({
|
||||||
plugins: [{
|
plugins: [{
|
||||||
removeDesc: true
|
removeDesc: true
|
||||||
}]
|
}]
|
||||||
}))
|
}))
|
||||||
.pipe(svgstore())
|
.pipe(svgstore())
|
||||||
.pipe(gulp.dest(paths.plyr.output));
|
.pipe(gulp.dest(paths.plyr.output));
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
templates: function() {
|
templates: function() {
|
||||||
// Build templates
|
// Build templates
|
||||||
gulp.task("templates", function () {
|
gulp.task("templates", function () {
|
||||||
return gulp
|
return gulp
|
||||||
.src(paths.docs.src.templates)
|
.src(paths.docs.src.templates)
|
||||||
.pipe(hogan("templates.js", {
|
.pipe(hogan("templates.js", {
|
||||||
wrapper: false,
|
wrapper: false,
|
||||||
templateName: function (file) {
|
templateName: function (file) {
|
||||||
return path.basename(file.relative.replace(/\\/g, "-"), path.extname(file.relative));
|
return path.basename(file.relative.replace(/\\/g, "-"), path.extname(file.relative));
|
||||||
}
|
}
|
||||||
}))
|
}))
|
||||||
.pipe(gulp.dest(paths.docs.output));
|
.pipe(gulp.dest(paths.docs.output));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// Plyr core files
|
// Plyr core files
|
||||||
@ -164,22 +167,22 @@ build.js(bundles.docs.js, "docs");
|
|||||||
|
|
||||||
// Default gulp task
|
// Default gulp task
|
||||||
gulp.task("default", function(){
|
gulp.task("default", function(){
|
||||||
run("templates", tasks.js, tasks.less, "sprite");
|
run("templates", tasks.js, tasks.less, "sprite");
|
||||||
});
|
});
|
||||||
|
|
||||||
// Build all JS (inc. templates)
|
// Build all JS (inc. templates)
|
||||||
gulp.task("js", function(){
|
gulp.task("js", function(){
|
||||||
run("templates", tasks.js);
|
run("templates", tasks.js);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Build SASS (for testing, default is LESS)
|
// Build SASS (for testing, default is LESS)
|
||||||
gulp.task("sass", function(){
|
gulp.task("sass", function(){
|
||||||
run(tasks.sass);
|
run(tasks.sass);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Watch for file changes
|
// Watch for file changes
|
||||||
gulp.task("watch", function () {
|
gulp.task("watch", function () {
|
||||||
// Plyr core
|
// Plyr core
|
||||||
gulp.watch(paths.plyr.src.js, tasks.js);
|
gulp.watch(paths.plyr.src.js, tasks.js);
|
||||||
gulp.watch(paths.plyr.src.less, tasks.less);
|
gulp.watch(paths.plyr.src.less, tasks.less);
|
||||||
gulp.watch(paths.plyr.src.sprite, "sprite");
|
gulp.watch(paths.plyr.src.sprite, "sprite");
|
||||||
@ -187,57 +190,87 @@ gulp.task("watch", function () {
|
|||||||
// Docs
|
// Docs
|
||||||
gulp.watch(paths.docs.src.js, tasks.js);
|
gulp.watch(paths.docs.src.js, tasks.js);
|
||||||
gulp.watch(paths.docs.src.less, tasks.less);
|
gulp.watch(paths.docs.src.less, tasks.less);
|
||||||
gulp.watch(paths.docs.src.templates, "js");
|
gulp.watch(paths.docs.src.templates, "js");
|
||||||
});
|
});
|
||||||
|
|
||||||
// Publish the docs site
|
// Publish a version to CDN and docs
|
||||||
try {
|
// --------------------------------------------
|
||||||
var aws = loadJSON(path.join(root, "aws.json"));
|
|
||||||
}
|
|
||||||
catch (e) { }
|
|
||||||
|
|
||||||
var version = package.version,
|
// Some options
|
||||||
maxAge = 31536000, // seconds 1 year
|
var aws = loadJSON(path.join(root, "aws.json")),
|
||||||
|
version = package.version,
|
||||||
|
maxAge = 31536000, // seconds 1 year
|
||||||
options = {
|
options = {
|
||||||
cdn: {
|
cdn: {
|
||||||
headers: {
|
headers: {
|
||||||
"Cache-Control": "max-age=" + maxAge + ", no-transform, public",
|
"Cache-Control": "max-age=" + maxAge + ", no-transform, public",
|
||||||
"Vary": "Accept-Encoding"
|
"Vary": "Accept-Encoding"
|
||||||
},
|
},
|
||||||
gzippedOnly: true
|
gzippedOnly: true
|
||||||
},
|
},
|
||||||
docs: {
|
docs: {
|
||||||
headers: {
|
headers: {
|
||||||
"Cache-Control": "public, must-revalidate, proxy-revalidate, max-age=0",
|
"Cache-Control": "public, must-revalidate, proxy-revalidate, max-age=0",
|
||||||
"Vary": "Accept-Encoding"
|
"Vary": "Accept-Encoding"
|
||||||
},
|
},
|
||||||
gzippedOnly: true
|
gzippedOnly: true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
cdnpath = new RegExp(aws.cdn.bucket + "\/(\\d+\\.)?(\\d+\\.)?(\\*|\\d+)","gi");
|
cdnpath = new RegExp(aws.cdn.bucket + "\/(\\d+\\.)?(\\d+\\.)?(\\*|\\d+)","gi");
|
||||||
|
|
||||||
|
// Publish version to CDN bucket
|
||||||
gulp.task("cdn", function () {
|
gulp.task("cdn", function () {
|
||||||
console.log("Uploading " + version + " to " + aws.cdn.bucket);
|
console.log("Uploading " + version + " to " + aws.cdn.bucket);
|
||||||
|
|
||||||
// Upload to CDN
|
// Upload to CDN
|
||||||
gulp.src(paths.upload)
|
gulp.src(paths.upload)
|
||||||
.pipe(rename(function (path) {
|
.pipe(size({
|
||||||
path.dirname = path.dirname.replace(".", version);
|
showFiles: true,
|
||||||
}))
|
gzip: true
|
||||||
.pipe(gzip())
|
}))
|
||||||
.pipe(s3(aws.cdn, options.cdn));
|
.pipe(rename(function (path) {
|
||||||
|
path.dirname = path.dirname.replace(".", version);
|
||||||
|
}))
|
||||||
|
.pipe(gzip())
|
||||||
|
.pipe(s3(aws.cdn, options.cdn));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Publish to Docs bucket
|
||||||
gulp.task("docs", function () {
|
gulp.task("docs", function () {
|
||||||
console.log("Uploading " + version + " docs to " + aws.docs.bucket);
|
console.log("Uploading " + version + " docs to " + aws.docs.bucket);
|
||||||
|
|
||||||
// Replace versioned files in index.html
|
// Replace versioned files in readme.md
|
||||||
gulp.src([paths.docs.root + "index.html"])
|
gulp.src([root + "/readme.md"])
|
||||||
.pipe(replace(cdnpath, aws.cdn.bucket + "/" + version))
|
.pipe(replace(cdnpath, aws.cdn.bucket + "/" + version))
|
||||||
.pipe(gzip())
|
.pipe(gulp.dest(root));
|
||||||
.pipe(s3(aws.docs, options.docs));
|
|
||||||
|
// Replace versioned files in *.html
|
||||||
|
gulp.src([paths.docs.root + "*.html"])
|
||||||
|
.pipe(replace(cdnpath, aws.cdn.bucket + "/" + version))
|
||||||
|
.pipe(gulp.dest(paths.docs.root))
|
||||||
|
.pipe(gzip())
|
||||||
|
.pipe(s3(aws.docs, options.docs));
|
||||||
|
|
||||||
|
// Upload error.html to cdn using docs options
|
||||||
|
gulp.src([paths.docs.root + "error.html"])
|
||||||
|
.pipe(gzip())
|
||||||
|
.pipe(s3(aws.cdn, options.docs));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Open the docs site to check it's sweet
|
||||||
|
gulp.task("open", function () {
|
||||||
|
console.log("Opening " + aws.docs.bucket + "...");
|
||||||
|
|
||||||
|
// A file must be specified or gulp will skip the task
|
||||||
|
// Doesn't matter which file since we set the URL above
|
||||||
|
// Weird, I know...
|
||||||
|
gulp.src([paths.docs.root + "index.html"])
|
||||||
|
.pipe(open("", {
|
||||||
|
url: "http://" + aws.docs.bucket
|
||||||
|
}));
|
||||||
|
});
|
||||||
|
|
||||||
|
// Do everything
|
||||||
gulp.task("publish", function () {
|
gulp.task("publish", function () {
|
||||||
run("templates", tasks.js, tasks.less, "sprite", "cdn", "docs");
|
run("templates", tasks.js, tasks.less, "sprite", "cdn", "docs", "open");
|
||||||
});
|
});
|
25
license.md
@ -1,12 +1,21 @@
|
|||||||
Copyright (c) 2015, Selz.com
|
The MIT License (MIT)
|
||||||
All rights reserved.
|
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
|
Copyright (c) 2015 Selz.com
|
||||||
|
|
||||||
1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "plyr",
|
"name": "plyr",
|
||||||
"version": "1.0.18",
|
"version": "1.1.0",
|
||||||
"description": "A simple HTML5 media player using custom controls",
|
"description": "A simple HTML5 media player using custom controls",
|
||||||
"homepage": "http://plyr.io",
|
"homepage": "http://plyr.io",
|
||||||
"main": "gulpfile.js",
|
"main": "gulpfile.js",
|
||||||
@ -13,10 +13,12 @@
|
|||||||
"gulp-hogan-compile": "^0.4.1",
|
"gulp-hogan-compile": "^0.4.1",
|
||||||
"gulp-less": "~1.3.1",
|
"gulp-less": "~1.3.1",
|
||||||
"gulp-minify-css": "~0.3.6",
|
"gulp-minify-css": "~0.3.6",
|
||||||
|
"gulp-open": "^0.3.2",
|
||||||
"gulp-rename": "^1.2.0",
|
"gulp-rename": "^1.2.0",
|
||||||
"gulp-replace": "^0.5.3",
|
"gulp-replace": "^0.5.3",
|
||||||
"gulp-s3": "^0.3.0",
|
"gulp-s3": "^0.3.0",
|
||||||
"gulp-sass": "^1.3.3",
|
"gulp-sass": "^1.3.3",
|
||||||
|
"gulp-size": "^1.2.1",
|
||||||
"gulp-svgmin": "^1.0.0",
|
"gulp-svgmin": "^1.0.0",
|
||||||
"gulp-svgstore": "^5.0.0",
|
"gulp-svgstore": "^5.0.0",
|
||||||
"gulp-uglify": "~0.3.1",
|
"gulp-uglify": "~0.3.1",
|
||||||
@ -38,5 +40,5 @@
|
|||||||
"authors": [
|
"authors": [
|
||||||
"Sam Potts <me@sampotts.me>"
|
"Sam Potts <me@sampotts.me>"
|
||||||
],
|
],
|
||||||
"license": "BSD"
|
"license": "MIT"
|
||||||
}
|
}
|
||||||
|
144
readme.md
@ -3,34 +3,42 @@ A simple, accessible HTML5 media player.
|
|||||||
|
|
||||||
[Checkout the demo](http://plyr.io)
|
[Checkout the demo](http://plyr.io)
|
||||||
|
|
||||||
|
[](http://plyr.io)
|
||||||
|
|
||||||
## Why?
|
## Why?
|
||||||
We wanted a lightweight, accessible and customisable media player that just supports *modern* browsers. Sure, there are many other players out there but we wanted to keep things simple, using the right elements for the job.
|
We wanted a lightweight, accessible and customisable media player that just supports *modern* browsers. Sure, there are many other players out there but we wanted to keep things simple, using the right elements for the job.
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
- **Accessible** - full support for captions and screen readers.
|
- **Accessible** - full support for captions and screen readers.
|
||||||
- **Lightweight** - just 4.8KB minified and gzipped.
|
- **Lightweight** - just 6KB minified and gzipped.
|
||||||
- **Customisable** - make the player look how you want with the markup you want.
|
- **Customisable** - make the player look how you want with the markup you want.
|
||||||
- **Semantic** - uses HTML5 form inputs for volume (range) and progress element for playback progress.
|
- **Semantic** - uses the *right* elements. `<input type="range">` for volume and `<progress>` for progress and well, `<button>`s for buttons. There's no `<span>` or `<a href="#">` button hacks.
|
||||||
- **Responsive** - any screen size.
|
- **Responsive** - as you'd expect these days.
|
||||||
- **No dependencies** - written in vanilla JavaScript.
|
- **Audio & Video** - support for both formats.
|
||||||
- **API** - easy to use API.
|
- **API** - toggle playback, volume, seeking, and more.
|
||||||
- **Fallback** - if there's no support, the native players are used.
|
- **Fullscreen** - supports native fullscreen with fallback to "full window" modes.
|
||||||
- **Fullscreen** - options to run the player full browser or the user can toggle fullscreen.
|
- **No dependencies** - written in vanilla JavaScript, no jQuery required.
|
||||||
|
|
||||||
|
Oh and yes, it works with Bootstrap.
|
||||||
|
|
||||||
## Changelog
|
## Changelog
|
||||||
Check out [the changelog](changelog.md)
|
Check out [the changelog](changelog.md)
|
||||||
|
|
||||||
## Planned development
|
## Planned development
|
||||||
- Accept a string selector, a node, or a nodelist for the `container` property of `selectors`.
|
- Accept a string selector, a node, or a nodelist for the `container` property of `selectors`.
|
||||||
- Accept a selector for the `html` template property.
|
|
||||||
- Multiple language captions (with selection)
|
- Multiple language captions (with selection)
|
||||||
- Localisation of control labels
|
- Playlists (audio and video)
|
||||||
|
- Set source by API
|
||||||
|
- Tooltip option (for seeking and controls)
|
||||||
|
... and whatever else has been raised in [issues](https://github.com/Selz/plyr/issues)
|
||||||
|
|
||||||
If you have any cool ideas or features, please let me know by [creating an issue](https://github.com/Selz/plyr/issues/new) or of course, forking and sending a pull request.
|
If you have any cool ideas or features, please let me know by [creating an issue](https://github.com/Selz/plyr/issues/new) or of course, forking and sending a pull request.
|
||||||
|
|
||||||
## Implementation
|
## Implementation
|
||||||
|
|
||||||
Check `docs/index.html` and `docs/dist/docs.js` for an example setup.
|
Check `docs/index.html` and `docs/dist/docs.js` for an example setup.
|
||||||
|
|
||||||
|
**Heads up**, the example `index.html` file needs to be served from a webserver (such as Apache, Nginx, IIS or similar) unless you change the file sources to include http or https. e.g. change `//cdn.plyr.io/1.1.0/plyr.js` to `https://cdn.plyr.io/1.1.0/plyr.js`
|
||||||
|
|
||||||
### Bower
|
### Bower
|
||||||
If bower is your thang, you can grab Plyr using:
|
If bower is your thang, you can grab Plyr using:
|
||||||
@ -40,14 +48,14 @@ bower install plyr
|
|||||||
More info on setting up dependencies can be found in the [Bower Docs](http://bower.io/docs/creating-packages/#maintaining-dependencies)
|
More info on setting up dependencies can be found in the [Bower Docs](http://bower.io/docs/creating-packages/#maintaining-dependencies)
|
||||||
|
|
||||||
### CDN
|
### CDN
|
||||||
If you want to use our CDN, you can use the following. Currently it's HTTP only.
|
If you want to use our CDN, you can use the following. HTTPS (SSL) is supported.
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<link rel="stylesheet" href="http://cdn.plyr.io/1.0.18/plyr.css">
|
<link rel="stylesheet" href="//cdn.plyr.io/1.1.0/plyr.css">
|
||||||
<script src="http://cdn.plyr.io/1.0.18/plyr.js"></script>
|
<script src="//cdn.plyr.io/1.1.0/plyr.js"></script>
|
||||||
```
|
```
|
||||||
|
|
||||||
You can also access the `sprite.svg` file at `http://cdn.plyr.io/1.0.18/sprite.svg`.
|
You can also access the `sprite.svg` file at `//cdn.plyr.io/1.1.0/sprite.svg`.
|
||||||
|
|
||||||
### CSS
|
### CSS
|
||||||
If you want to use the default css, add the `plyr.css` file from /dist into your head, or even better use `plyr.less` or `plyr.sass` file included in `/src` in your build to save a request.
|
If you want to use the default css, add the `plyr.css` file from /dist into your head, or even better use `plyr.less` or `plyr.sass` file included in `/src` in your build to save a request.
|
||||||
@ -129,13 +137,15 @@ Much of the behaviour of the player is configurable when initialising the librar
|
|||||||
<script src="dist/plyr.js"></script>
|
<script src="dist/plyr.js"></script>
|
||||||
<script>
|
<script>
|
||||||
plyr.setup({
|
plyr.setup({
|
||||||
html: **your controls html**
|
*options*
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Options
|
#### Options
|
||||||
|
|
||||||
|
You can pass the following options to the setup method.
|
||||||
|
|
||||||
<table class="table" width="100%">
|
<table class="table" width="100%">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
@ -155,8 +165,14 @@ plyr.setup({
|
|||||||
<tr>
|
<tr>
|
||||||
<td><code>html</code></td>
|
<td><code>html</code></td>
|
||||||
<td>String</td>
|
<td>String</td>
|
||||||
<td><code>—</code></td>
|
<td><code><a href="controls.md">See controls.md</a></code></td>
|
||||||
<td>This is **required**. See <a href="controls.md">controls.md</a> for more info on how the html needs to be structured.</td>
|
<td>See <a href="controls.md">controls.md</a> for more info on how the html needs to be structured.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td><code>controls</code></td>
|
||||||
|
<td>Array</td>
|
||||||
|
<td><code>["restart", "rewind", "play", "fast-forward", "current-time", "duration", "mute", "volume", "captions", "fullscreen"]</code></td>
|
||||||
|
<td>Toggle which control elements you would like to display when using the default controls html. If you specify a <code>html</code> option, this is redundant. The default value is to display everything.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>debug</code></td>
|
<td><code>debug</code></td>
|
||||||
@ -174,19 +190,31 @@ plyr.setup({
|
|||||||
<td><code>volume</code></td>
|
<td><code>volume</code></td>
|
||||||
<td>Number</td>
|
<td>Number</td>
|
||||||
<td><code>5</code></td>
|
<td><code>5</code></td>
|
||||||
<td>A number, between 1 and 10, representing the inital volume of the player.</td>
|
<td>A number, between 1 and 10, representing the initial volume of the player.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>click</code></td>
|
<td><code>click</code></td>
|
||||||
<td>Boolean</td>
|
<td>Boolean</td>
|
||||||
<td><code>true</code></td>
|
<td><code>true</code></td>
|
||||||
<td>Click (or tap) will toggle pause/play of a `<video>`.</td>
|
<td>Click (or tap) will toggle pause/play of a <code><video></code>.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td><code>tooltips</code></td>
|
||||||
|
<td>Boolean</td>
|
||||||
|
<td><code>false</code></td>
|
||||||
|
<td>Display control labels as tooltips on :hover & :focus (by default, the labels are screen reader only).</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td><code>displayDuration</code></td>
|
||||||
|
<td>Boolean</td>
|
||||||
|
<td><code>true</code></td>
|
||||||
|
<td>Displays the duration of the media on the "metadataloaded" event (on startup) in the current time display. This will only work if the `preload` attribute is not set to `none` (or is not set at all) and you choose not to display the duration (see <code>controls</code> option).</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>selectors</code></td>
|
<td><code>selectors</code></td>
|
||||||
<td>Object</td>
|
<td>Object</td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>See `plyr.js` in `/src` for more info. The only option you might want to change is `player` which is the hook used for Plyr, the default is `.player`.</td>
|
<td>See <code>plyr.js</code> in <code>/src</code> for more info. The only option you might want to change is <code>player</code> which is the hook used for Plyr, the default is <code>.player</code>.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>classes</code></td>
|
<td><code>classes</code></td>
|
||||||
@ -198,19 +226,19 @@ plyr.setup({
|
|||||||
<td><code>captions</code></td>
|
<td><code>captions</code></td>
|
||||||
<td>Object</td>
|
<td>Object</td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>This currently contains one property `defaultActive` which toggles if captions should be on by default. The default value is `false`.</td>
|
<td>One property <code>defaultActive</code> which toggles if captions should be on by default. The default value is <code>false</code>.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>fullscreen</code></td>
|
<td><code>fullscreen</code></td>
|
||||||
<td>Object</td>
|
<td>Object</td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>This currently contains two properties; `enabled` which toggles if fullscreen should be enabled (if the browser supports it). The default value is `true`. Also an extra property called `fallback` which will enable a 'full window' view for older browsers. The default value is `true`.</td>
|
<td>Three properties; <code>enabled</code> which toggles if fullscreen should be enabled (if the browser supports it). The default value is <code>true</code>. A <code>fallback</code> property which will enable a full window view for older browsers. The default value is <code>true</code>. A <code>hideControls</code> property which will hide the controls when fullscreen is active and the video is playing, after 1s. The controls reappear on hover of the progress bar (mouse), focusing a child control or pausing the video (by tap/click of video if `click` is `true`). The default value is <code>true</code>.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>storage</code></td>
|
<td><code>storage</code></td>
|
||||||
<td>Object</td>
|
<td>Object</td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>This currently contains one property `enabled` which toggles if local storage should be enabled (if the browser supports it). The default value is `true`. This enables storing user settings, currently it only stores volume but more will be added later.</td>
|
<td>Two properties; <code>enabled</code> which toggles if local storage should be enabled (if the browser supports it). The default value is `true`. This enables storing user settings, currently it only stores volume but more will be added later. The second property <code>key</code> is the key used for the local storage. The default is <code>plyr_volume</code> until more settings are stored.</td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
@ -235,45 +263,75 @@ Here's a list of the methods supported:
|
|||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>play</code></td>
|
<td><code>play()</code></td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>Plays the media</td>
|
<td>Plays the media</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>pause</code></td>
|
<td><code>pause()</code></td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>Pauses the media</td>
|
<td>Pauses the media</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>restart</code></td>
|
<td><code>restart()</code></td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>Restarts playback</td>
|
<td>Restarts playback</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>rewind</code></td>
|
<td><code>rewind(...)</code></td>
|
||||||
<td>Number</td>
|
<td>Number</td>
|
||||||
<td>Rewinds by the provided parameter, in seconds. If no parameter is provided, the default seekInterval is used (10 seconds).</td>
|
<td>Rewinds by the provided parameter, in seconds. If no parameter is provided, the default seekInterval is used (10 seconds).</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>forward</code></td>
|
<td><code>forward(...)</code></td>
|
||||||
<td>Number</td>
|
<td>Number</td>
|
||||||
<td>Fast forwards by the provided parameter, in seconds. If no parameter is provided, the default seekInterval is used (10 seconds).</td>
|
<td>Fast forwards by the provided parameter, in seconds. If no parameter is provided, the default seekInterval is used (10 seconds).</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>setVolume</code></td>
|
<td><code>seek(...)</code></td>
|
||||||
<td>Number</td>
|
<td>Number</td>
|
||||||
<td>Sets the player voume to the provided parameter. The value should be between 0 (muted) and 10 (loudest). If no parameter is provided, the default volume is used (5). Values over 10 are ignored.</td>
|
<td>Seeks the media to the provided parameter, time in seconds.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>toggleMute</code></td>
|
<td><code>setVolume(...)</code></td>
|
||||||
|
<td>Number</td>
|
||||||
|
<td>Sets the player volume to the provided parameter. The value should be between 0 (muted) and 10 (loudest). If no parameter is provided, the default volume is used (5). Values over 10 are ignored.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td><code>toggleMute()</code></td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>Toggles mute for the player.</td>
|
<td>Toggles mute for the player.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>toggleCaptions</code></td>
|
<td><code>toggleCaptions()</code></td>
|
||||||
<td>—</td>
|
<td>—</td>
|
||||||
<td>Toggles whether captions are enabled.</td>
|
<td>Toggles whether captions are enabled.</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td><code>support(...)</code></td>
|
||||||
|
<td>String</td>
|
||||||
|
<td>Determine if a player supports a certain MIME type.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td><code>source(...)</code></td>
|
||||||
|
<td>String or Array</td>
|
||||||
|
<td>
|
||||||
|
Set the media source.
|
||||||
|
<br><br>
|
||||||
|
<strong>string</strong><br>
|
||||||
|
<code>.source("/path/to/video.mp4")</code><br>
|
||||||
|
This will set the <code>src</code> attribute on the <code>video</code> or <code>audio</code> element.
|
||||||
|
<br><br>
|
||||||
|
<strong>array</strong><br>
|
||||||
|
<code>.source([{ src: "/path/to/video.webm", type: "video/webm", ...more attributes... }, { src: "/path/to/video.mp4", type: "video/mp4", ...more attributes... }])`</code><br>
|
||||||
|
This will inject a child `source` element for every element in the array with the specified attributes. `src` is the only required attribute although adding `type` is recommended as it helps the browser decide which file to download and play.
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td><code>poster(...)</code></td>
|
||||||
|
<td>String</td>
|
||||||
|
<td>Set the poster url. This is supported for the <code>video</code> element only.</td>
|
||||||
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
@ -309,19 +367,21 @@ Fullscreen in Plyr is supported for all browsers that [currently support it](htt
|
|||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<tr>
|
<tr>
|
||||||
|
<td>✔¹</td>
|
||||||
<td>✔</td>
|
<td>✔</td>
|
||||||
<td>✔</td>
|
<td>✔</td>
|
||||||
<td>✔</td>
|
<td>✔</td>
|
||||||
<td>✔</td>
|
<td>API²</td>
|
||||||
<td>✖¹</td>
|
<td>✔³</td>
|
||||||
<td>✔²</td>
|
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
¹ Native player used (no support for `<progress>` or `<input type="range">`)
|
¹ Mobile Safari on the iPhone forces the native player for `<video>` so no useful customisation is possible. `<audio>` elements have volume controls disabled.
|
||||||
|
|
||||||
² IE10 has no native fullscreen support, fallback can be used (see options)
|
² Native player used (no support for `<progress>` or `<input type="range">`) but the API is supported (v1.0.28+)
|
||||||
|
|
||||||
|
³ IE10 has no native fullscreen support, fallback can be used (see options)
|
||||||
|
|
||||||
The `enabled` option can be used to disable certain User Agents. For example, if you don't want to use Plyr for smartphones, you could use:
|
The `enabled` option can be used to disable certain User Agents. For example, if you don't want to use Plyr for smartphones, you could use:
|
||||||
|
|
||||||
@ -333,7 +393,7 @@ If a User Agent is disabled but supports `<video>` and `<audio>` natively, it wi
|
|||||||
Any unsupported browsers will display links to download the media if the correct html is used.
|
Any unsupported browsers will display links to download the media if the correct html is used.
|
||||||
|
|
||||||
## Issues
|
## Issues
|
||||||
If you find anything weird with Plyr, please let us know using the Github issues tracker.
|
If you find anything weird with Plyr, please let us know using the GitHub issues tracker.
|
||||||
|
|
||||||
## Author
|
## Author
|
||||||
Plyr is developed by Sam Potts ([@sam_potts](https://twitter.com/sam_potts)) ([sampotts.me](http://sampotts.me))
|
Plyr is developed by Sam Potts ([@sam_potts](https://twitter.com/sam_potts)) ([sampotts.me](http://sampotts.me))
|
||||||
@ -341,7 +401,12 @@ Plyr is developed by Sam Potts ([@sam_potts](https://twitter.com/sam_potts)) ([s
|
|||||||
## Mentions
|
## Mentions
|
||||||
- [The Changelog](http://thechangelog.com/plyr-simple-html5-media-player-custom-controls-webvtt-captions/)
|
- [The Changelog](http://thechangelog.com/plyr-simple-html5-media-player-custom-controls-webvtt-captions/)
|
||||||
- [HTML5 Weekly #177](http://html5weekly.com/issues/177)
|
- [HTML5 Weekly #177](http://html5weekly.com/issues/177)
|
||||||
|
- [Responsive Design #149](http://us4.campaign-archive2.com/?u=559bc631fe5294fc66f5f7f89&id=451a61490f)
|
||||||
- [Web Design Weekly #174](https://web-design-weekly.com/2015/02/24/web-design-weekly-174/)
|
- [Web Design Weekly #174](https://web-design-weekly.com/2015/02/24/web-design-weekly-174/)
|
||||||
|
- [Hacker News](https://news.ycombinator.com/item?id=9136774)
|
||||||
|
- [Web Platform Daily](http://webplatformdaily.org/releases/2015-03-04)
|
||||||
|
- [LayerVault Designer News](https://news.layervault.com/stories/45394-plyr--a-simple-html5-media-player)
|
||||||
|
- [The Treehouse Show #131](https://teamtreehouse.com/library/episode-131-origami-react-responsive-hero-images)
|
||||||
|
|
||||||
## Used by
|
## Used by
|
||||||
- [Selz.com](https://selz.com)
|
- [Selz.com](https://selz.com)
|
||||||
@ -352,10 +417,11 @@ Let me know on [Twitter](https://twitter.com/sam_potts) I can add you to the abo
|
|||||||
Credit to the PayPal HTML5 Video player from which Plyr's caption functionality is ported from:
|
Credit to the PayPal HTML5 Video player from which Plyr's caption functionality is ported from:
|
||||||
- [PayPal's Accessible HTML5 Video Player](https://github.com/paypal/accessible-html5-video-player)
|
- [PayPal's Accessible HTML5 Video Player](https://github.com/paypal/accessible-html5-video-player)
|
||||||
- The icons used in Plyr are [Vicons](https://dribbble.com/shots/1663443-60-Vicons-Free-Icon-Set) plus some ones I made
|
- The icons used in Plyr are [Vicons](https://dribbble.com/shots/1663443-60-Vicons-Free-Icon-Set) plus some ones I made
|
||||||
|
- [An awesome guide for Plyr in Japanese!](http://syncer.jp/how-to-use-plyr-io) by [@arayutw](https://twitter.com/arayutw)
|
||||||
|
|
||||||
Also these links helped created Plyr:
|
Also these links helped created Plyr:
|
||||||
- [Media Events - W3.org](http://www.w3.org/2010/05/video/mediaevents.html)
|
- [Media Events - W3.org](http://www.w3.org/2010/05/video/mediaevents.html)
|
||||||
- [Styling the `<progress>` element - hongkiat.com](http://www.hongkiat.com/blog/html5-progress-bar/)
|
- [Styling the `<progress>` element - hongkiat.com](http://www.hongkiat.com/blog/html5-progress-bar/)
|
||||||
|
|
||||||
## Copyright and License
|
## Copyright and License
|
||||||
Copyright 2014, Selz.com under [the BSD license](license.md).
|
[The MIT license](license.md).
|
1048
src/js/plyr.js
@ -5,434 +5,601 @@
|
|||||||
// Variables
|
// Variables
|
||||||
// -------------------------------
|
// -------------------------------
|
||||||
// Colors
|
// Colors
|
||||||
@blue: #3498DB;
|
@blue: #3498DB;
|
||||||
@gray-dark: #343f4a;
|
@gray-dark: #343f4a;
|
||||||
@gray: #565d64;
|
@gray: #565d64;
|
||||||
@gray-light: #cbd0d3;
|
@gray-light: #cbd0d3;
|
||||||
|
|
||||||
// Font sizes
|
// Font sizes
|
||||||
@font-size-small: 14px;
|
@font-size-small: 14px;
|
||||||
@font-size-base: 16px;
|
@font-size-base: 16px;
|
||||||
@font-size-large: ceil((@font-size-base * 1.5));
|
@font-size-large: ceil((@font-size-base * 1.5));
|
||||||
|
|
||||||
// Controls
|
// Controls
|
||||||
@control-spacing: 10px;
|
@control-spacing: 10px;
|
||||||
@controls-bg: @gray-dark;
|
@controls-bg: @gray-dark;
|
||||||
@control-bg-hover: @blue;
|
@control-bg-hover: @blue;
|
||||||
@control-color: @gray-light;
|
@control-color: @gray-light;
|
||||||
@control-color-inactive: @gray;
|
@control-color-inactive: @gray;
|
||||||
@control-color-focus: #fff;
|
@control-color-hover: #fff;
|
||||||
@control-color-hover: #fff;
|
|
||||||
|
// Tooltips
|
||||||
|
@tooltip-bg: @controls-bg;
|
||||||
|
@tooltip-color: #fff;
|
||||||
|
@tooltip-padding: @control-spacing;
|
||||||
|
@tooltip-arrow-size: 5px;
|
||||||
|
@tooltip-radius: 3px;
|
||||||
|
|
||||||
// Progress
|
// Progress
|
||||||
@progress-bg: lighten(@gray, 10%);
|
@progress-bg: rgba(red(@gray), green(@gray), blue(@gray), .2);
|
||||||
@progress-playing-bg: @blue;
|
@progress-playing-bg: @blue;
|
||||||
@progress-buffered-bg: @gray;
|
@progress-buffered-bg: rgba(red(@gray), green(@gray), blue(@gray), .25);
|
||||||
|
@progress-loading-size: 40px;
|
||||||
|
@progress-loading-bg: rgba(0,0,0, .15);
|
||||||
|
|
||||||
// Range
|
// Volume
|
||||||
@range-track-height: 6px;
|
@volume-track-height: 6px;
|
||||||
@range-track-bg: @gray;
|
@volume-track-bg: @gray;
|
||||||
@range-thumb-height: (@range-track-height * 2);
|
@volume-thumb-height: (@volume-track-height * 2);
|
||||||
@range-thumb-width: (@range-track-height * 2);
|
@volume-thumb-width: (@volume-track-height * 2);
|
||||||
@range-thumb-bg: @control-color;
|
@volume-thumb-bg: @control-color;
|
||||||
@range-thumb-bg-focus: @control-bg-hover;
|
@volume-thumb-bg-focus: @control-bg-hover;
|
||||||
|
|
||||||
// Breakpoints
|
// Breakpoints
|
||||||
@bp-control-split: 560px; // When controls split into left/right
|
@bp-control-split: 560px; // When controls split into left/right
|
||||||
@bp-captions-large: 768px; // When captions jump to the larger font size
|
@bp-captions-large: 768px; // When captions jump to the larger font size
|
||||||
|
|
||||||
// Utility classes & mixins
|
// Utility classes & mixins
|
||||||
// -------------------------------
|
// -------------------------------
|
||||||
// Screen reader only
|
// Screen reader only
|
||||||
.sr-only {
|
.sr-only {
|
||||||
position: absolute !important;
|
position: absolute !important;
|
||||||
clip: rect(1px, 1px, 1px, 1px);
|
clip: rect(1px, 1px, 1px, 1px);
|
||||||
padding: 0 !important;
|
padding: 0 !important;
|
||||||
border: 0 !important;
|
border: 0 !important;
|
||||||
height: 1px !important;
|
height: 1px !important;
|
||||||
width: 1px !important;
|
width: 1px !important;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
// Contain floats: nicolasgallagher.com/micro-clearfix-hack/
|
// Contain floats: nicolasgallagher.com/micro-clearfix-hack/
|
||||||
.clearfix() {
|
.clearfix() {
|
||||||
zoom: 1;
|
zoom: 1;
|
||||||
&:before,
|
&:before,
|
||||||
&:after { content: ""; display: table; }
|
&:after { content: ""; display: table; }
|
||||||
&:after { clear: both; }
|
&:after { clear: both; }
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tab focus styles
|
// Tab focus styles
|
||||||
.tab-focus() {
|
.tab-focus() {
|
||||||
outline: thin dotted #000;
|
outline: thin dotted #000;
|
||||||
outline-offset: 1px;
|
outline-offset: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Range styling
|
// Animation
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
.range-thumb() {
|
@keyframes progress {
|
||||||
height: @range-thumb-height;
|
to { background-position: @progress-loading-size 0; }
|
||||||
width: @range-thumb-width;
|
|
||||||
background: @range-thumb-bg;
|
|
||||||
border: 0;
|
|
||||||
border-radius: (@range-thumb-height / 2);
|
|
||||||
transition: background .3s ease;
|
|
||||||
cursor: ew-resize;
|
|
||||||
}
|
}
|
||||||
.range-track() {
|
|
||||||
height: @range-track-height;
|
// <input type="range"> styling
|
||||||
background: @range-track-bg;
|
// ---------------------------------------
|
||||||
border: 0;
|
.volume-thumb() {
|
||||||
border-radius: (@range-track-height / 2);
|
height: @volume-thumb-height;
|
||||||
|
width: @volume-thumb-width;
|
||||||
|
background: @volume-thumb-bg;
|
||||||
|
border: 0;
|
||||||
|
border-radius: (@volume-thumb-height / 2);
|
||||||
|
transition: background .3s ease;
|
||||||
|
cursor: ew-resize;
|
||||||
|
}
|
||||||
|
.volume-track() {
|
||||||
|
height: @volume-track-height;
|
||||||
|
background: @volume-track-bg;
|
||||||
|
border: 0;
|
||||||
|
border-radius: (@volume-track-height / 2);
|
||||||
|
}
|
||||||
|
.seek-thumb() {
|
||||||
|
background: transparent;
|
||||||
|
border: 0;
|
||||||
|
width: (@control-spacing * 2);
|
||||||
|
height: @control-spacing;
|
||||||
|
}
|
||||||
|
.seek-track() {
|
||||||
|
background: none;
|
||||||
|
border: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Font smoothing
|
// Font smoothing
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
.font-smoothing(@mode: on) when (@mode = on) {
|
.font-smoothing(@mode: on) when (@mode = on) {
|
||||||
-moz-osx-font-smoothing: grayscale;
|
-moz-osx-font-smoothing: grayscale;
|
||||||
-webkit-font-smoothing: antialiased;
|
-webkit-font-smoothing: antialiased;
|
||||||
}
|
}
|
||||||
.font-smoothing(@mode: on) when (@mode = off) {
|
.font-smoothing(@mode: on) when (@mode = off) {
|
||||||
-moz-osx-font-smoothing: auto;
|
-moz-osx-font-smoothing: auto;
|
||||||
-webkit-font-smoothing: subpixel-antialiased;
|
-webkit-font-smoothing: subpixel-antialiased;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Styles
|
// Styles
|
||||||
// -------------------------------
|
// -------------------------------
|
||||||
// Base
|
// Base
|
||||||
.player {
|
.player {
|
||||||
position: relative;
|
position: relative;
|
||||||
max-width: 100%;
|
max-width: 100%;
|
||||||
min-width: 290px;
|
min-width: 290px;
|
||||||
overflow: hidden; // For the controls
|
|
||||||
|
|
||||||
// border-box everything
|
// border-box everything
|
||||||
// http://paulirish.com/2012/box-sizing-border-box-ftw/
|
// http://paulirish.com/2012/box-sizing-border-box-ftw/
|
||||||
&,
|
&,
|
||||||
*,
|
*,
|
||||||
*::after,
|
*::after,
|
||||||
*::before {
|
*::before {
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
// For video
|
// For video
|
||||||
&-video-wrapper {
|
&-video-wrapper {
|
||||||
position: relative;
|
position: relative;
|
||||||
}
|
}
|
||||||
video {
|
video {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: auto;
|
height: auto;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Captions
|
// Captions
|
||||||
&-captions {
|
&-captions {
|
||||||
display: none;
|
display: none;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
padding: 20px;
|
padding: 20px;
|
||||||
min-height: 2.5em;
|
min-height: 2.5em;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
font-size: @font-size-base;
|
font-size: @font-size-base;
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
text-shadow:
|
text-shadow:
|
||||||
-1px -1px 0 @gray,
|
-1px -1px 0 @gray,
|
||||||
1px -1px 0 @gray,
|
1px -1px 0 @gray,
|
||||||
-1px 1px 0 @gray,
|
-1px 1px 0 @gray,
|
||||||
1px 1px 0 @gray;
|
1px 1px 0 @gray;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
.font-smoothing();
|
.font-smoothing();
|
||||||
|
|
||||||
@media (min-width: @bp-captions-large) {
|
@media (min-width: @bp-captions-large) {
|
||||||
font-size: @font-size-large;
|
font-size: @font-size-large;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
&.captions-active &-captions {
|
&.captions-active &-captions {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Player controls
|
// Player controls
|
||||||
&-controls {
|
&-controls {
|
||||||
.clearfix();
|
.clearfix();
|
||||||
.font-smoothing();
|
.font-smoothing();
|
||||||
position: relative;
|
position: relative;
|
||||||
padding: (@control-spacing * 2) @control-spacing @control-spacing;
|
padding: @control-spacing;
|
||||||
background: @controls-bg;
|
background: @controls-bg;
|
||||||
line-height: 1;
|
line-height: 1;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
|
||||||
// Layout
|
// Layout
|
||||||
&-sound {
|
&-right {
|
||||||
display: block;
|
display: block;
|
||||||
margin: @control-spacing auto 0;
|
margin: @control-spacing auto 0;
|
||||||
}
|
}
|
||||||
@media (min-width: @bp-control-split) {
|
@media (min-width: @bp-control-split) {
|
||||||
&-playback {
|
&-left {
|
||||||
float: left;
|
float: left;
|
||||||
}
|
}
|
||||||
&-sound {
|
&-right {
|
||||||
float: right;
|
float: right;
|
||||||
margin-top: 0;
|
margin-top: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
input + label,
|
input + label,
|
||||||
button {
|
button {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
margin: 0 2px;
|
margin: 0 2px;
|
||||||
padding: (@control-spacing / 2) @control-spacing;
|
padding: (@control-spacing / 2) @control-spacing;
|
||||||
|
|
||||||
transition: background .3s ease;
|
transition: background .3s ease;
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
|
||||||
svg {
|
svg {
|
||||||
width: 18px;
|
width: 18px;
|
||||||
height: 18px;
|
height: 18px;
|
||||||
display: block;
|
display: block;
|
||||||
fill: currentColor;
|
fill: currentColor;
|
||||||
transition: fill .3s ease;
|
transition: fill .3s ease;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
input + label,
|
input + label,
|
||||||
input.inverted:checked + label {
|
.inverted:checked + label {
|
||||||
color: @control-color-inactive;
|
color: @control-color-inactive;
|
||||||
}
|
}
|
||||||
button,
|
button,
|
||||||
input.inverted + label,
|
.inverted + label,
|
||||||
input:checked + label {
|
input:checked + label {
|
||||||
color: @control-color;
|
color: @control-color;
|
||||||
}
|
}
|
||||||
button {
|
button {
|
||||||
border: 0;
|
border: 0;
|
||||||
background: transparent;
|
background: transparent;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
input:focus + label,
|
|
||||||
button:focus {
|
// Specificity for overriding .inverted
|
||||||
.tab-focus();
|
button:focus,
|
||||||
color: @control-color-focus;
|
button:hover,
|
||||||
}
|
[type="checkbox"]:focus + label,
|
||||||
button:hover,
|
[type="checkbox"] + label:hover {
|
||||||
input + label:hover {
|
background: @control-bg-hover;
|
||||||
background: @control-bg-hover;
|
color: @control-color-hover;
|
||||||
color: @control-color-hover;
|
}
|
||||||
}
|
button:focus,
|
||||||
.icon-exit-fullscreen,
|
input:focus + label {
|
||||||
.icon-muted {
|
outline: 0;
|
||||||
display: none;
|
}
|
||||||
}
|
.icon-exit-fullscreen,
|
||||||
.player-time {
|
.icon-muted,
|
||||||
display: inline-block;
|
.icon-captions-on {
|
||||||
vertical-align: middle;
|
display: none;
|
||||||
margin-left: @control-spacing;
|
}
|
||||||
color: @control-color;
|
.player-time {
|
||||||
font-weight: 600;
|
display: inline-block;
|
||||||
font-size: @font-size-small;
|
vertical-align: middle;
|
||||||
.font-smoothing();
|
margin-left: @control-spacing;
|
||||||
}
|
color: @control-color;
|
||||||
}
|
font-weight: 600;
|
||||||
|
font-size: @font-size-small;
|
||||||
|
.font-smoothing();
|
||||||
|
}
|
||||||
|
|
||||||
// Player progress
|
// Media duration hidden on small screens
|
||||||
// <progress> element
|
.player-time + .player-time {
|
||||||
&-progress {
|
display: none;
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
width: 100%;
|
|
||||||
height: @control-spacing;
|
|
||||||
background: @progress-bg;
|
|
||||||
|
|
||||||
&-buffer,
|
@media (min-width: @bp-control-split) {
|
||||||
&-played {
|
display: inline-block;
|
||||||
position: absolute;
|
}
|
||||||
left: 0;
|
|
||||||
top: 0;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
margin: 0;
|
|
||||||
vertical-align: top;
|
|
||||||
|
|
||||||
&[value] {
|
|
||||||
-webkit-appearance: none;
|
|
||||||
border: none;
|
|
||||||
background: transparent;
|
|
||||||
|
|
||||||
&::-webkit-progress-bar {
|
// Add a slash in before
|
||||||
background: transparent;
|
&::before {
|
||||||
}
|
content: "\2044";
|
||||||
|
margin-right: @control-spacing;
|
||||||
|
color: darken(@control-color, 30%);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Inherit from currentColor;
|
// Tooltips
|
||||||
&::-webkit-progress-value {
|
&-tooltip {
|
||||||
background: currentColor;
|
visibility: hidden;
|
||||||
}
|
position: absolute;
|
||||||
&::-moz-progress-bar {
|
z-index: 2;
|
||||||
background: currentColor;
|
bottom: 100%;
|
||||||
}
|
margin-bottom: @tooltip-padding;
|
||||||
}
|
padding: @tooltip-padding (@tooltip-padding * 1.5);
|
||||||
}
|
|
||||||
&-played {
|
|
||||||
z-index: 2;
|
|
||||||
}
|
|
||||||
&-played[value] {
|
|
||||||
cursor: pointer;
|
|
||||||
color: @progress-playing-bg;
|
|
||||||
}
|
|
||||||
&-buffer[value] {
|
|
||||||
color: @progress-buffered-bg;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// States
|
opacity: 0;
|
||||||
&-controls [data-player='pause'],
|
background: @tooltip-bg;
|
||||||
&.playing .player-controls [data-player='play'] {
|
border-radius: @tooltip-radius;
|
||||||
display: none;
|
color: @tooltip-color;
|
||||||
}
|
font-size: @font-size-small;
|
||||||
&.playing .player-controls [data-player='pause'] {
|
line-height: 1.5;
|
||||||
display: inline-block;
|
font-weight: 600;
|
||||||
}
|
|
||||||
|
|
||||||
// Muted
|
transform: translate(-50%, (@tooltip-padding * 3));
|
||||||
&.muted .player-controls .icon-muted {
|
transition: transform .2s .2s ease, opacity .2s .2s ease;
|
||||||
display: block;
|
|
||||||
|
|
||||||
& + svg {
|
&::after {
|
||||||
display: none;
|
content: "";
|
||||||
}
|
display: block;
|
||||||
}
|
position: absolute;
|
||||||
|
left: 50%;
|
||||||
|
bottom: -@tooltip-arrow-size;
|
||||||
|
margin-left: -@tooltip-arrow-size;
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
transition: inherit;
|
||||||
|
border-style: solid;
|
||||||
|
border-width: @tooltip-arrow-size @tooltip-arrow-size 0 @tooltip-arrow-size;
|
||||||
|
border-color: @controls-bg transparent transparent;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
label:hover .player-tooltip,
|
||||||
|
input:focus + label .player-tooltip,
|
||||||
|
button:hover .player-tooltip,
|
||||||
|
button:focus .player-tooltip {
|
||||||
|
visibility: visible;
|
||||||
|
opacity: 1;
|
||||||
|
transform: translate(-50%, 0);
|
||||||
|
}
|
||||||
|
label:hover .player-tooltip,
|
||||||
|
button:hover .player-tooltip {
|
||||||
|
z-index: 3;
|
||||||
|
}
|
||||||
|
|
||||||
// Volume control
|
// Player progress
|
||||||
// <input[type='range']> element
|
// <progress> element
|
||||||
// Specificty is for bootstrap compatibility
|
&-progress {
|
||||||
&-volume[type=range] {
|
position: absolute;
|
||||||
display: inline-block;
|
bottom: 100%;
|
||||||
vertical-align: middle;
|
left: 0;
|
||||||
-webkit-appearance: none;
|
right: 0;
|
||||||
-moz-appearance: none;
|
width: 100%;
|
||||||
width: 100px;
|
height: @control-spacing;
|
||||||
margin: 0 @control-spacing 0 0;
|
background: @progress-bg;
|
||||||
padding: 0;
|
|
||||||
cursor: pointer;
|
|
||||||
background: none;
|
|
||||||
|
|
||||||
// Webkit
|
|
||||||
&::-webkit-slider-runnable-track {
|
|
||||||
.range-track();
|
|
||||||
}
|
|
||||||
&::-webkit-slider-thumb {
|
|
||||||
-webkit-appearance: none;
|
|
||||||
margin-top: -((@range-thumb-height - @range-track-height) / 2);
|
|
||||||
.range-thumb();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Mozilla
|
&-buffer[value],
|
||||||
&::-moz-range-track {
|
&-played[value],
|
||||||
.range-track();
|
&-seek[type=range] {
|
||||||
}
|
position: absolute;
|
||||||
&::-moz-range-thumb {
|
left: 0;
|
||||||
.range-thumb();
|
top: 0;
|
||||||
}
|
width: 100%;
|
||||||
|
height: @control-spacing;
|
||||||
// Microsoft
|
margin: 0;
|
||||||
&::-ms-track {
|
padding: 0;
|
||||||
height: @range-track-height;
|
vertical-align: top;
|
||||||
background: transparent;
|
|
||||||
border-color: transparent;
|
|
||||||
border-width: ((@range-thumb-height - @range-track-height) / 2) 0;
|
|
||||||
color: transparent;
|
|
||||||
}
|
|
||||||
&::-ms-fill-lower,
|
|
||||||
&::-ms-fill-upper {
|
|
||||||
.range-track();
|
|
||||||
}
|
|
||||||
&::-ms-thumb {
|
|
||||||
.range-thumb();
|
|
||||||
}
|
|
||||||
|
|
||||||
&:focus {
|
-webkit-appearance: none;
|
||||||
outline: 0;
|
-moz-appearance: none;
|
||||||
|
border: none;
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
&-buffer[value],
|
||||||
|
&-played[value] {
|
||||||
|
&::-webkit-progress-bar {
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
&::-webkit-slider-thumb {
|
// Inherit from currentColor;
|
||||||
background: @range-thumb-bg-focus;
|
&::-webkit-progress-value {
|
||||||
}
|
background: currentColor;
|
||||||
&::-moz-range-thumb {
|
}
|
||||||
background: @range-thumb-bg-focus;
|
&::-moz-progress-bar {
|
||||||
}
|
background: currentColor;
|
||||||
&::-ms-thumb {
|
}
|
||||||
background: @range-thumb-bg-focus;
|
}
|
||||||
}
|
&-played[value] {
|
||||||
}
|
z-index: 2;
|
||||||
}
|
color: @progress-playing-bg;
|
||||||
|
}
|
||||||
|
&-buffer[value] {
|
||||||
|
color: @progress-buffered-bg;
|
||||||
|
}
|
||||||
|
|
||||||
// Full screen mode
|
// Seek control
|
||||||
&-fullscreen,
|
// <input[type='range']> element
|
||||||
&.fullscreen-active {
|
// Specificity is for bootstrap compatibility
|
||||||
position: fixed;
|
&-seek[type=range] {
|
||||||
top: 0;
|
z-index: 4;
|
||||||
left: 0;
|
cursor: pointer;
|
||||||
right: 0;
|
outline: 0;
|
||||||
bottom: 0;
|
|
||||||
height: 100%;
|
|
||||||
width: 100%;
|
|
||||||
z-index: 10000000;
|
|
||||||
background: #000;
|
|
||||||
|
|
||||||
.player-video-wrapper {
|
// Webkit
|
||||||
height: 100%;
|
&::-webkit-slider-runnable-track {
|
||||||
width: 100%;
|
.seek-track();
|
||||||
|
}
|
||||||
|
&::-webkit-slider-thumb {
|
||||||
|
-webkit-appearance: none;
|
||||||
|
.seek-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
video {
|
// Mozilla
|
||||||
height: 100%;
|
&::-moz-range-track {
|
||||||
}
|
.seek-track();
|
||||||
.player-captions {
|
}
|
||||||
top: auto;
|
&::-moz-range-thumb {
|
||||||
bottom: 90px;
|
-moz-appearance: none;
|
||||||
|
.seek-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Microsoft
|
||||||
|
&::-ms-track {
|
||||||
|
color: transparent;
|
||||||
|
.seek-track();
|
||||||
|
}
|
||||||
|
&::-ms-fill-lower,
|
||||||
|
&::-ms-fill-upper {
|
||||||
|
.seek-track();
|
||||||
|
}
|
||||||
|
&::-ms-thumb {
|
||||||
|
.seek-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
@media (min-width: @bp-control-split) and (max-width: (@bp-captions-large - 1)) {
|
&:focus {
|
||||||
bottom: 60px;
|
outline: 0;
|
||||||
}
|
}
|
||||||
@media (min-width: @bp-captions-large) {
|
&::-moz-focus-outer {
|
||||||
bottom: 80px;
|
border: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.player-controls {
|
|
||||||
position: absolute;
|
|
||||||
bottom: 0;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// When true full screen, show exit fullscreen icon
|
// Loading state
|
||||||
&.fullscreen-active .icon-exit-fullscreen {
|
&.loading .player-progress-buffer {
|
||||||
display: block;
|
animation: progress 1s linear infinite;
|
||||||
|
background-size: @progress-loading-size @progress-loading-size;
|
||||||
|
background-repeat: repeat-x;
|
||||||
|
background-color: @progress-buffered-bg;
|
||||||
|
background-image: linear-gradient(
|
||||||
|
-45deg,
|
||||||
|
@progress-loading-bg 25%,
|
||||||
|
transparent 25%,
|
||||||
|
transparent 50%,
|
||||||
|
@progress-loading-bg 50%,
|
||||||
|
@progress-loading-bg 75%,
|
||||||
|
transparent 75%,
|
||||||
|
transparent);
|
||||||
|
color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
& + svg {
|
// States
|
||||||
display: none;
|
&-controls [data-player='pause'],
|
||||||
}
|
&.playing .player-controls [data-player='play'] {
|
||||||
}
|
display: none;
|
||||||
|
}
|
||||||
|
&.playing .player-controls [data-player='pause'] {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
// Some options are hidden by default
|
// Volume control
|
||||||
[data-player='captions'],
|
// <input[type='range']> element
|
||||||
[data-player='captions'] + label,
|
// Specificity is for bootstrap compatibility
|
||||||
[data-player='fullscreen'],
|
&-volume[type=range] {
|
||||||
[data-player='fullscreen'] + label {
|
display: inline-block;
|
||||||
display: none;
|
vertical-align: middle;
|
||||||
}
|
-webkit-appearance: none;
|
||||||
&.captions-enabled [data-player='captions'],
|
-moz-appearance: none;
|
||||||
&.captions-enabled [data-player='captions'] + label,
|
width: 100px;
|
||||||
&.fullscreen-enabled [data-player='fullscreen'],
|
margin: 0 @control-spacing 0 0;
|
||||||
&.fullscreen-enabled [data-player='fullscreen'] + label {
|
padding: 0;
|
||||||
display: inline-block;
|
cursor: pointer;
|
||||||
}
|
background: none;
|
||||||
|
|
||||||
|
// Webkit
|
||||||
|
&::-webkit-slider-runnable-track {
|
||||||
|
.volume-track();
|
||||||
|
}
|
||||||
|
&::-webkit-slider-thumb {
|
||||||
|
-webkit-appearance: none;
|
||||||
|
margin-top: -((@volume-thumb-height - @volume-track-height) / 2);
|
||||||
|
.volume-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
// Full browser view hides toggle
|
// Mozilla
|
||||||
&-fullscreen [data-player='fullscreen'],
|
&::-moz-range-track {
|
||||||
&-fullscreen [data-player='fullscreen'] + label {
|
.volume-track();
|
||||||
display: none !important;
|
}
|
||||||
}
|
&::-moz-range-thumb {
|
||||||
|
.volume-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Microsoft
|
||||||
|
&::-ms-track {
|
||||||
|
height: @volume-track-height;
|
||||||
|
background: transparent;
|
||||||
|
border-color: transparent;
|
||||||
|
border-width: ((@volume-thumb-height - @volume-track-height) / 2) 0;
|
||||||
|
color: transparent;
|
||||||
|
}
|
||||||
|
&::-ms-fill-lower,
|
||||||
|
&::-ms-fill-upper {
|
||||||
|
.volume-track();
|
||||||
|
}
|
||||||
|
&::-ms-thumb {
|
||||||
|
.volume-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
|
&:focus {
|
||||||
|
outline: 0;
|
||||||
|
|
||||||
|
&::-webkit-slider-thumb {
|
||||||
|
background: @volume-thumb-bg-focus;
|
||||||
|
}
|
||||||
|
&::-moz-range-thumb {
|
||||||
|
background: @volume-thumb-bg-focus;
|
||||||
|
}
|
||||||
|
&::-ms-thumb {
|
||||||
|
background: @volume-thumb-bg-focus;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hide sound controls on iOS
|
||||||
|
// It's not supported to change volume using JavaScript:
|
||||||
|
// https://developer.apple.com/library/safari/documentation/AudioVideo/Conceptual/Using_HTML5_Audio_Video/Device-SpecificConsiderations/Device-SpecificConsiderations.html
|
||||||
|
&.ios &-volume,
|
||||||
|
&.ios [data-player='mute'],
|
||||||
|
&.ios [data-player='mute'] + label,
|
||||||
|
&-audio.ios &-controls-right {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
// Center buttons so it looks less odd
|
||||||
|
&-audio.ios &-controls-left {
|
||||||
|
float: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Full screen mode
|
||||||
|
&-fullscreen,
|
||||||
|
&.fullscreen-active {
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
z-index: 10000000;
|
||||||
|
background: #000;
|
||||||
|
|
||||||
|
video {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
.player-video-wrapper {
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
|
.player-captions {
|
||||||
|
top: auto;
|
||||||
|
bottom: 90px;
|
||||||
|
|
||||||
|
@media (min-width: @bp-control-split) and (max-width: (@bp-captions-large - 1)) {
|
||||||
|
bottom: 60px;
|
||||||
|
}
|
||||||
|
@media (min-width: @bp-captions-large) {
|
||||||
|
bottom: 80px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.player-controls {
|
||||||
|
position: absolute;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hide controls when playing in full screen
|
||||||
|
&.fullscreen-hide-controls.playing .player-controls {
|
||||||
|
transform: translateY(100%) translateY(@control-spacing / 2);
|
||||||
|
transition: transform .3s 1s ease;
|
||||||
|
|
||||||
|
&.hover {
|
||||||
|
transform: translateY(0);
|
||||||
|
transition-delay: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Change icons on state change
|
||||||
|
&.fullscreen-active .icon-exit-fullscreen,
|
||||||
|
&.muted .player-controls .icon-muted,
|
||||||
|
&.captions-active .player-controls .icon-captions-on {
|
||||||
|
display: block;
|
||||||
|
|
||||||
|
& + svg {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Some options are hidden by default
|
||||||
|
[data-player='captions'],
|
||||||
|
[data-player='captions'] + label,
|
||||||
|
[data-player='fullscreen'],
|
||||||
|
[data-player='fullscreen'] + label {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
&.captions-enabled [data-player='captions'],
|
||||||
|
&.captions-enabled [data-player='captions'] + label,
|
||||||
|
&.fullscreen-enabled [data-player='fullscreen'],
|
||||||
|
&.fullscreen-enabled [data-player='fullscreen'] + label {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
}
|
}
|
@ -5,439 +5,609 @@
|
|||||||
// Variables
|
// Variables
|
||||||
// -------------------------------
|
// -------------------------------
|
||||||
// Colors
|
// Colors
|
||||||
$blue: #3498DB;
|
$blue: #3498DB;
|
||||||
$gray-dark: #343f4a;
|
$gray-dark: #343f4a;
|
||||||
$gray: #565d64;
|
$gray: #565d64;
|
||||||
$gray-light: #cbd0d3;
|
$gray-light: #cbd0d3;
|
||||||
|
|
||||||
// Font sizes
|
// Font sizes
|
||||||
$font-size-small: 14px;
|
$font-size-small: 14px;
|
||||||
$font-size-base: 16px;
|
$font-size-base: 16px;
|
||||||
$font-size-large: ceil(($font-size-base * 1.5));
|
$font-size-large: ceil(($font-size-base * 1.5));
|
||||||
|
|
||||||
// Controls
|
// Controls
|
||||||
$control-spacing: 10px;
|
$control-spacing: 10px;
|
||||||
$controls-bg: $gray-dark;
|
$controls-bg: $gray-dark;
|
||||||
$control-bg-hover: $blue;
|
$control-bg-hover: $blue;
|
||||||
$control-color: $gray-light;
|
$control-color: $gray-light;
|
||||||
$control-color-inactive: $gray;
|
$control-color-inactive: $gray;
|
||||||
$control-color-focus: #fff;
|
$control-color-hover: #fff;
|
||||||
$control-color-hover: #fff;
|
|
||||||
|
// Tooltips
|
||||||
|
$tooltip-bg: $controls-bg;
|
||||||
|
$tooltip-color: #fff;
|
||||||
|
$tooltip-padding: $control-spacing;
|
||||||
|
$tooltip-arrow-size: 5px;
|
||||||
|
$tooltip-radius: 3px;
|
||||||
|
|
||||||
// Progress
|
// Progress
|
||||||
$progress-bg: lighten($gray, 10%);
|
$progress-bg: rgba(red($gray), green($gray), blue($gray), .2);
|
||||||
$progress-playing-bg: $blue;
|
$progress-playing-bg: $blue;
|
||||||
$progress-buffered-bg: $gray;
|
$progress-buffered-bg: rgba(red($gray), green($gray), blue($gray), .25);
|
||||||
|
$progress-loading-size: 40px;
|
||||||
|
$progress-loading-bg: rgba(0,0,0, .15);
|
||||||
|
|
||||||
// Range
|
// Volume
|
||||||
$range-track-height: 6px;
|
$volume-track-height: 6px;
|
||||||
$range-track-bg: $gray;
|
$volume-track-bg: $gray;
|
||||||
$range-thumb-height: ($range-track-height * 2);
|
$volume-thumb-height: ($volume-track-height * 2);
|
||||||
$range-thumb-width: ($range-track-height * 2);
|
$volume-thumb-width: ($volume-track-height * 2);
|
||||||
$range-thumb-bg: $control-color;
|
$volume-thumb-bg: $control-color;
|
||||||
$range-thumb-bg-focus: $control-bg-hover;
|
$volume-thumb-bg-focus: $control-bg-hover;
|
||||||
|
|
||||||
// Breakpoints
|
// Breakpoints
|
||||||
$bp-control-split: 560px; // When controls split into left/right
|
$bp-control-split: 560px; // When controls split into left/right
|
||||||
$bp-captions-large: 768px; // When captions jump to the larger font size
|
$bp-captions-large: 768px; // When captions jump to the larger font size
|
||||||
|
|
||||||
// Utility classes & mixins
|
// Utility classes & mixins
|
||||||
// -------------------------------
|
// -------------------------------
|
||||||
// Screen reader only
|
// Screen reader only
|
||||||
.sr-only {
|
.sr-only {
|
||||||
position: absolute !important;
|
position: absolute !important;
|
||||||
clip: rect(1px, 1px, 1px, 1px);
|
clip: rect(1px, 1px, 1px, 1px);
|
||||||
padding: 0 !important;
|
padding: 0 !important;
|
||||||
border: 0 !important;
|
border: 0 !important;
|
||||||
height: 1px !important;
|
height: 1px !important;
|
||||||
width: 1px !important;
|
width: 1px !important;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
// Contain floats: nicolasgallagher.com/micro-clearfix-hack/
|
// Contain floats: nicolasgallagher.com/micro-clearfix-hack/
|
||||||
@mixin clearfix()
|
@mixin clearfix()
|
||||||
{
|
{
|
||||||
zoom: 1;
|
zoom: 1;
|
||||||
&:before,
|
&:before,
|
||||||
&:after { content: ""; display: table; }
|
&:after { content: ""; display: table; }
|
||||||
&:after { clear: both; }
|
&:after { clear: both; }
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tab focus styles
|
// Tab focus styles
|
||||||
@mixin tab-focus()
|
@mixin tab-focus()
|
||||||
{
|
{
|
||||||
outline: thin dotted #000;
|
outline: thin dotted #000;
|
||||||
outline-offset: 1px;
|
outline-offset: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Range styling
|
// Animation
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
@mixin range-thumb()
|
@keyframes progress {
|
||||||
{
|
to { background-position: $progress-loading-size 0; }
|
||||||
height: $range-thumb-height;
|
|
||||||
width: $range-thumb-width;
|
|
||||||
background: $range-thumb-bg;
|
|
||||||
border: 0;
|
|
||||||
border-radius: ($range-thumb-height / 2);
|
|
||||||
transition: background .3s ease;
|
|
||||||
cursor: ew-resize;
|
|
||||||
}
|
}
|
||||||
@mixin range-track()
|
|
||||||
|
// <input type="range"> styling
|
||||||
|
// ---------------------------------------
|
||||||
|
@mixin volume-thumb()
|
||||||
{
|
{
|
||||||
height: $range-track-height;
|
height: $volume-thumb-height;
|
||||||
background: $range-track-bg;
|
width: $volume-thumb-width;
|
||||||
border: 0;
|
background: $volume-thumb-bg;
|
||||||
border-radius: ($range-track-height / 2);
|
border: 0;
|
||||||
|
border-radius: ($volume-thumb-height / 2);
|
||||||
|
transition: background .3s ease;
|
||||||
|
cursor: ew-resize;
|
||||||
|
}
|
||||||
|
@mixin volume-track()
|
||||||
|
{
|
||||||
|
height: $volume-track-height;
|
||||||
|
background: $volume-track-bg;
|
||||||
|
border: 0;
|
||||||
|
border-radius: ($volume-track-height / 2);
|
||||||
|
}
|
||||||
|
@mixin seek-thumb()
|
||||||
|
{
|
||||||
|
background: transparent;
|
||||||
|
border: 0;
|
||||||
|
width: ($control-spacing * 2);
|
||||||
|
height: $control-spacing;
|
||||||
|
}
|
||||||
|
@mixin seek-track()
|
||||||
|
{
|
||||||
|
background: none;
|
||||||
|
border: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Font smoothing
|
// Font smoothing
|
||||||
// ---------------------------------------
|
// ---------------------------------------
|
||||||
@mixin font-smoothing($mode: on) when ($mode = on)
|
@mixin font-smoothing($mode: on)
|
||||||
{
|
{
|
||||||
-moz-osx-font-smoothing: grayscale;
|
@if $mode == 'on' {
|
||||||
-webkit-font-smoothing: antialiased;
|
-moz-osx-font-smoothing: grayscale;
|
||||||
}
|
-webkit-font-smoothing: antialiased;
|
||||||
@mixin font-smoothing($mode: on) when ($mode = off)
|
} @else if $mode == 'off' {
|
||||||
{
|
-moz-osx-font-smoothing: auto;
|
||||||
-moz-osx-font-smoothing: auto;
|
-webkit-font-smoothing: subpixel-antialiased;
|
||||||
-webkit-font-smoothing: subpixel-antialiased;
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Styles
|
// Styles
|
||||||
// -------------------------------
|
// -------------------------------
|
||||||
// Base
|
// Base
|
||||||
.player {
|
.player {
|
||||||
position: relative;
|
position: relative;
|
||||||
max-width: 100%;
|
max-width: 100%;
|
||||||
min-width: 290px;
|
min-width: 290px;
|
||||||
overflow: hidden; // For the controls
|
|
||||||
|
|
||||||
// border-box everything
|
// border-box everything
|
||||||
// http://paulirish.com/2012/box-sizing-border-box-ftw/
|
// http://paulirish.com/2012/box-sizing-border-box-ftw/
|
||||||
&,
|
&,
|
||||||
*,
|
*,
|
||||||
*::after,
|
*::after,
|
||||||
*::before {
|
*::before {
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
// For video
|
// For video
|
||||||
&-video-wrapper {
|
&-video-wrapper {
|
||||||
position: relative;
|
position: relative;
|
||||||
}
|
}
|
||||||
video {
|
video {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: auto;
|
height: auto;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Captions
|
// Captions
|
||||||
&-captions {
|
&-captions {
|
||||||
display: none;
|
display: none;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
padding: 20px;
|
padding: 20px;
|
||||||
min-height: 2.5em;
|
min-height: 2.5em;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
font-size: $font-size-base;
|
font-size: $font-size-base;
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
text-shadow:
|
text-shadow:
|
||||||
-1px -1px 0 $gray,
|
-1px -1px 0 $gray,
|
||||||
1px -1px 0 $gray,
|
1px -1px 0 $gray,
|
||||||
-1px 1px 0 $gray,
|
-1px 1px 0 $gray,
|
||||||
1px 1px 0 $gray;
|
1px 1px 0 $gray;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
@include font-smoothing();
|
@include font-smoothing();
|
||||||
|
|
||||||
@media (min-width: $bp-captions-large) {
|
@media (min-width: $bp-captions-large) {
|
||||||
font-size: $font-size-large;
|
font-size: $font-size-large;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
&.captions-active &-captions {
|
&.captions-active &-captions {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Player controls
|
// Player controls
|
||||||
&-controls {
|
&-controls {
|
||||||
@include clearfix();
|
@include clearfix();
|
||||||
@include font-smoothing();
|
@include font-smoothing();
|
||||||
position: relative;
|
position: relative;
|
||||||
padding: ($control-spacing * 2) $control-spacing $control-spacing;
|
padding: $control-spacing;
|
||||||
background: $controls-bg;
|
background: $controls-bg;
|
||||||
line-height: 1;
|
line-height: 1;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
|
||||||
// Layout
|
// Layout
|
||||||
&-sound {
|
&-right {
|
||||||
display: block;
|
display: block;
|
||||||
margin: $control-spacing auto 0;
|
margin: $control-spacing auto 0;
|
||||||
}
|
}
|
||||||
@media (min-width: $bp-control-split) {
|
@media (min-width: $bp-control-split) {
|
||||||
&-playback {
|
&-left {
|
||||||
float: left;
|
float: left;
|
||||||
}
|
}
|
||||||
&-sound {
|
&-right {
|
||||||
float: right;
|
float: right;
|
||||||
margin-top: 0;
|
margin-top: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
input + label,
|
input + label,
|
||||||
button {
|
button {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
margin: 0 2px;
|
margin: 0 2px;
|
||||||
padding: ($control-spacing / 2) $control-spacing;
|
padding: ($control-spacing / 2) $control-spacing;
|
||||||
|
|
||||||
transition: background .3s ease;
|
transition: background .3s ease;
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
|
||||||
svg {
|
svg {
|
||||||
width: 18px;
|
width: 18px;
|
||||||
height: 18px;
|
height: 18px;
|
||||||
display: block;
|
display: block;
|
||||||
fill: currentColor;
|
fill: currentColor;
|
||||||
transition: fill .3s ease;
|
transition: fill .3s ease;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
input + label,
|
input + label,
|
||||||
input.inverted:checked + label {
|
.inverted:checked + label {
|
||||||
color: $control-color-inactive;
|
color: $control-color-inactive;
|
||||||
}
|
}
|
||||||
button,
|
button,
|
||||||
input.inverted + label,
|
.inverted + label,
|
||||||
input:checked + label {
|
input:checked + label {
|
||||||
color: $control-color;
|
color: $control-color;
|
||||||
}
|
}
|
||||||
button {
|
button {
|
||||||
border: 0;
|
border: 0;
|
||||||
background: transparent;
|
background: transparent;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
input:focus + label,
|
|
||||||
button:focus {
|
|
||||||
@include tab-focus();
|
|
||||||
color: $control-color-focus;
|
|
||||||
}
|
|
||||||
button:hover,
|
|
||||||
input + label:hover {
|
|
||||||
background: $control-bg-hover;
|
|
||||||
color: $control-color-hover;
|
|
||||||
}
|
|
||||||
.icon-exit-fullscreen,
|
|
||||||
.icon-muted {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.player-time {
|
|
||||||
display: inline-block;
|
|
||||||
vertical-align: middle;
|
|
||||||
margin-left: $control-spacing;
|
|
||||||
color: $control-color;
|
|
||||||
font-weight: 600;
|
|
||||||
font-size: $font-size-small;
|
|
||||||
@include font-smoothing();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Player progress
|
// Specificity for overriding .inverted
|
||||||
// <progress> element
|
button:focus,
|
||||||
&-progress {
|
button:hover,
|
||||||
position: absolute;
|
[type="checkbox"]:focus + label,
|
||||||
top: 0;
|
[type="checkbox"] + label:hover {
|
||||||
left: 0;
|
background: $control-bg-hover;
|
||||||
right: 0;
|
color: $control-color-hover;
|
||||||
width: 100%;
|
}
|
||||||
height: $control-spacing;
|
button:focus,
|
||||||
background: $progress-bg;
|
input:focus + label {
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
|
.icon-exit-fullscreen,
|
||||||
|
.icon-muted,
|
||||||
|
.icon-captions-on {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.player-time {
|
||||||
|
display: inline-block;
|
||||||
|
vertical-align: middle;
|
||||||
|
margin-left: $control-spacing;
|
||||||
|
color: $control-color;
|
||||||
|
font-weight: 600;
|
||||||
|
font-size: $font-size-small;
|
||||||
|
@include font-smoothing();
|
||||||
|
}
|
||||||
|
|
||||||
&-buffer,
|
// Media duration hidden on small screens
|
||||||
&-played {
|
.player-time + .player-time {
|
||||||
position: absolute;
|
display: none;
|
||||||
left: 0;
|
|
||||||
top: 0;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
margin: 0;
|
|
||||||
vertical-align: top;
|
|
||||||
|
|
||||||
&[value] {
|
@media (min-width: $bp-control-split) {
|
||||||
-webkit-appearance: none;
|
display: inline-block;
|
||||||
border: none;
|
}
|
||||||
background: transparent;
|
|
||||||
|
|
||||||
&::-webkit-progress-bar {
|
// Add a slash in before
|
||||||
background: transparent;
|
&::before {
|
||||||
}
|
content: "\2044";
|
||||||
|
margin-right: $control-spacing;
|
||||||
|
color: darken($control-color, 30%);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Inherit from currentColor;
|
// Tooltips
|
||||||
&::-webkit-progress-value {
|
&-tooltip {
|
||||||
background: currentColor;
|
visibility: hidden;
|
||||||
}
|
position: absolute;
|
||||||
&::-moz-progress-bar {
|
z-index: 2;
|
||||||
background: currentColor;
|
bottom: 100%;
|
||||||
}
|
margin-bottom: $tooltip-padding;
|
||||||
}
|
padding: $tooltip-padding ($tooltip-padding * 1.5);
|
||||||
}
|
|
||||||
&-played {
|
|
||||||
z-index: 2;
|
|
||||||
}
|
|
||||||
&-played[value] {
|
|
||||||
cursor: pointer;
|
|
||||||
color: $progress-playing-bg;
|
|
||||||
}
|
|
||||||
&-buffer[value] {
|
|
||||||
color: $progress-buffered-bg;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// States
|
opacity: 0;
|
||||||
&-controls [data-player='pause'],
|
background: $tooltip-bg;
|
||||||
&.playing .player-controls [data-player='play'] {
|
border-radius: $tooltip-radius;
|
||||||
display: none;
|
color: $tooltip-color;
|
||||||
}
|
font-size: $font-size-small;
|
||||||
&.playing .player-controls [data-player='pause'] {
|
line-height: 1.5;
|
||||||
display: inline-block;
|
font-weight: 600;
|
||||||
}
|
|
||||||
|
|
||||||
// Muted
|
transform: translate(-50%, ($tooltip-padding * 3));
|
||||||
&.muted .player-controls .icon-muted {
|
transition: transform .2s .2s ease, opacity .2s .2s ease;
|
||||||
display: block;
|
|
||||||
|
|
||||||
& + svg {
|
&::after {
|
||||||
display: none;
|
content: "";
|
||||||
}
|
display: block;
|
||||||
}
|
position: absolute;
|
||||||
|
left: 50%;
|
||||||
|
bottom: -$tooltip-arrow-size;
|
||||||
|
margin-left: -$tooltip-arrow-size;
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
transition: inherit;
|
||||||
|
border-style: solid;
|
||||||
|
border-width: $tooltip-arrow-size $tooltip-arrow-size 0 $tooltip-arrow-size;
|
||||||
|
border-color: $controls-bg transparent transparent;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
label:hover .player-tooltip,
|
||||||
|
input:focus + label .player-tooltip,
|
||||||
|
button:hover .player-tooltip,
|
||||||
|
button:focus .player-tooltip {
|
||||||
|
visibility: visible;
|
||||||
|
opacity: 1;
|
||||||
|
transform: translate(-50%, 0);
|
||||||
|
}
|
||||||
|
label:hover .player-tooltip,
|
||||||
|
button:hover .player-tooltip {
|
||||||
|
z-index: 3;
|
||||||
|
}
|
||||||
|
|
||||||
// Volume control
|
// Player progress
|
||||||
// <input[type='range']> element
|
// <progress> element
|
||||||
// Specificty is for bootstrap compatibility
|
&-progress {
|
||||||
&-volume[type=range] {
|
position: absolute;
|
||||||
vertical-align: middle;
|
bottom: 100%;
|
||||||
-webkit-appearance: none;
|
left: 0;
|
||||||
-moz-appearance: none;
|
right: 0;
|
||||||
width: 100px;
|
width: 100%;
|
||||||
margin: 0 $control-spacing 0 0;
|
height: $control-spacing;
|
||||||
padding: 0;
|
background: $progress-bg;
|
||||||
cursor: pointer;
|
|
||||||
background: none;
|
|
||||||
|
|
||||||
// Webkit
|
&-buffer[value],
|
||||||
&::-webkit-slider-runnable-track {
|
&-played[value],
|
||||||
@include range-track();
|
&-seek[type=range] {
|
||||||
}
|
position: absolute;
|
||||||
&::-webkit-slider-thumb {
|
left: 0;
|
||||||
-webkit-appearance: none;
|
top: 0;
|
||||||
margin-top: -(($range-thumb-height - $range-track-height) / 2);
|
width: 100%;
|
||||||
@include range-thumb();
|
height: $control-spacing;
|
||||||
}
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
vertical-align: top;
|
||||||
|
|
||||||
// Mozilla
|
-webkit-appearance: none;
|
||||||
&::-moz-range-track {
|
-moz-appearance: none;
|
||||||
@include range-track();
|
border: none;
|
||||||
}
|
background: transparent;
|
||||||
&::-moz-range-thumb {
|
}
|
||||||
@include range-thumb();
|
&-buffer[value],
|
||||||
}
|
&-played[value] {
|
||||||
|
&::-webkit-progress-bar {
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
// Microsoft
|
// Inherit from currentColor;
|
||||||
&::-ms-track {
|
&::-webkit-progress-value {
|
||||||
height: $range-track-height;
|
background: currentColor;
|
||||||
background: transparent;
|
}
|
||||||
border-color: transparent;
|
&::-moz-progress-bar {
|
||||||
border-width: (($range-thumb-height - $range-track-height) / 2) 0;
|
background: currentColor;
|
||||||
color: transparent;
|
}
|
||||||
}
|
}
|
||||||
&::-ms-fill-lower,
|
&-played[value] {
|
||||||
&::-ms-fill-upper {
|
z-index: 2;
|
||||||
@include range-track();
|
color: $progress-playing-bg;
|
||||||
}
|
}
|
||||||
&::-ms-thumb {
|
&-buffer[value] {
|
||||||
@include range-thumb();
|
color: $progress-buffered-bg;
|
||||||
}
|
}
|
||||||
|
|
||||||
&:focus {
|
// Seek control
|
||||||
outline: 0;
|
// <input[type='range']> element
|
||||||
|
// Specificity is for bootstrap compatibility
|
||||||
|
&-seek[type=range] {
|
||||||
|
z-index: 4;
|
||||||
|
cursor: pointer;
|
||||||
|
outline: 0;
|
||||||
|
|
||||||
&::-webkit-slider-thumb {
|
// Webkit
|
||||||
background: $range-thumb-bg-focus;
|
&::-webkit-slider-runnable-track {
|
||||||
}
|
@include seek-track();
|
||||||
&::-moz-range-thumb {
|
}
|
||||||
background: $range-thumb-bg-focus;
|
&::-webkit-slider-thumb {
|
||||||
}
|
-webkit-appearance: none;
|
||||||
&::-ms-thumb {
|
@include seek-thumb();
|
||||||
background: $range-thumb-bg-focus;
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Full screen mode
|
// Mozilla
|
||||||
&-fullscreen,
|
&::-moz-range-track {
|
||||||
&.fullscreen-active {
|
@include seek-track();
|
||||||
position: fixed;
|
}
|
||||||
top: 0;
|
&::-moz-range-thumb {
|
||||||
left: 0;
|
-moz-appearance: none;
|
||||||
right: 0;
|
@include seek-thumb();
|
||||||
bottom: 0;
|
}
|
||||||
height: 100%;
|
|
||||||
width: 100%;
|
|
||||||
z-index: 10000000;
|
|
||||||
background: #000;
|
|
||||||
|
|
||||||
.player-video-wrapper {
|
// Microsoft
|
||||||
height: 100%;
|
&::-ms-track {
|
||||||
width: 100%;
|
color: transparent;
|
||||||
|
@include seek-track();
|
||||||
|
}
|
||||||
|
&::-ms-fill-lower,
|
||||||
|
&::-ms-fill-upper {
|
||||||
|
@include seek-track();
|
||||||
|
}
|
||||||
|
&::-ms-thumb {
|
||||||
|
@include seek-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
video {
|
&:focus {
|
||||||
height: 100%;
|
outline: 0;
|
||||||
}
|
}
|
||||||
.player-captions {
|
&::-moz-focus-outer {
|
||||||
top: auto;
|
border: 0;
|
||||||
bottom: 90px;
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@media (min-width: $bp-control-split) and (max-width: ($bp-captions-large - 1)) {
|
// Loading state
|
||||||
bottom: 60px;
|
&.loading .player-progress-buffer {
|
||||||
}
|
animation: progress 1s linear infinite;
|
||||||
@media (min-width: $bp-captions-large) {
|
background-size: $progress-loading-size $progress-loading-size;
|
||||||
bottom: 80px;
|
background-repeat: repeat-x;
|
||||||
}
|
background-color: $progress-buffered-bg;
|
||||||
}
|
background-image: linear-gradient(
|
||||||
}
|
-45deg,
|
||||||
.player-controls {
|
$progress-loading-bg 25%,
|
||||||
position: absolute;
|
transparent 25%,
|
||||||
bottom: 0;
|
transparent 50%,
|
||||||
left: 0;
|
$progress-loading-bg 50%,
|
||||||
right: 0;
|
$progress-loading-bg 75%,
|
||||||
}
|
transparent 75%,
|
||||||
}
|
transparent);
|
||||||
|
color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
// When true full screen, show exit fullscreen icon
|
// States
|
||||||
&.fullscreen-active .icon-exit-fullscreen {
|
&-controls [data-player='pause'],
|
||||||
display: block;
|
&.playing .player-controls [data-player='play'] {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
&.playing .player-controls [data-player='pause'] {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
& + svg {
|
// Volume control
|
||||||
display: none;
|
// <input[type='range']> element
|
||||||
}
|
// Specificity is for bootstrap compatibility
|
||||||
}
|
&-volume[type=range] {
|
||||||
|
display: inline-block;
|
||||||
|
vertical-align: middle;
|
||||||
|
-webkit-appearance: none;
|
||||||
|
-moz-appearance: none;
|
||||||
|
width: 100px;
|
||||||
|
margin: 0 $control-spacing 0 0;
|
||||||
|
padding: 0;
|
||||||
|
cursor: pointer;
|
||||||
|
background: none;
|
||||||
|
|
||||||
// Some options are hidden by default
|
// Webkit
|
||||||
[data-player='captions'],
|
&::-webkit-slider-runnable-track {
|
||||||
[data-player='captions'] + label,
|
@include volume-track();
|
||||||
[data-player='fullscreen'],
|
}
|
||||||
[data-player='fullscreen'] + label {
|
&::-webkit-slider-thumb {
|
||||||
display: none;
|
-webkit-appearance: none;
|
||||||
}
|
margin-top: -(($volume-thumb-height - $volume-track-height) / 2);
|
||||||
&.captions-enabled [data-player='captions'],
|
@include volume-thumb();
|
||||||
&.captions-enabled [data-player='captions'] + label,
|
}
|
||||||
&.fullscreen-enabled [data-player='fullscreen'],
|
|
||||||
&.fullscreen-enabled [data-player='fullscreen'] + label {
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Full browser view hides toggle
|
// Mozilla
|
||||||
&-fullscreen [data-player='fullscreen'],
|
&::-moz-range-track {
|
||||||
&-fullscreen [data-player='fullscreen'] + label {
|
@include volume-track();
|
||||||
display: none !important;
|
}
|
||||||
}
|
&::-moz-range-thumb {
|
||||||
}
|
@include volume-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Microsoft
|
||||||
|
&::-ms-track {
|
||||||
|
height: $volume-track-height;
|
||||||
|
background: transparent;
|
||||||
|
border-color: transparent;
|
||||||
|
border-width: (($volume-thumb-height - $volume-track-height) / 2) 0;
|
||||||
|
color: transparent;
|
||||||
|
}
|
||||||
|
&::-ms-fill-lower,
|
||||||
|
&::-ms-fill-upper {
|
||||||
|
@include volume-track();
|
||||||
|
}
|
||||||
|
&::-ms-thumb {
|
||||||
|
@include volume-thumb();
|
||||||
|
}
|
||||||
|
|
||||||
|
&:focus {
|
||||||
|
outline: 0;
|
||||||
|
|
||||||
|
&::-webkit-slider-thumb {
|
||||||
|
background: $volume-thumb-bg-focus;
|
||||||
|
}
|
||||||
|
&::-moz-range-thumb {
|
||||||
|
background: $volume-thumb-bg-focus;
|
||||||
|
}
|
||||||
|
&::-ms-thumb {
|
||||||
|
background: $volume-thumb-bg-focus;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hide sound controls on iOS
|
||||||
|
// It's not supported to change volume using JavaScript:
|
||||||
|
// https://developer.apple.com/library/safari/documentation/AudioVideo/Conceptual/Using_HTML5_Audio_Video/Device-SpecificConsiderations/Device-SpecificConsiderations.html
|
||||||
|
&.ios &-volume,
|
||||||
|
&.ios [data-player='mute'],
|
||||||
|
&.ios [data-player='mute'] + label,
|
||||||
|
&-audio.ios &-controls-right {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
// Center buttons so it looks less odd
|
||||||
|
&-audio.ios &-controls-left {
|
||||||
|
float: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Full screen mode
|
||||||
|
&-fullscreen,
|
||||||
|
&.fullscreen-active {
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
z-index: 10000000;
|
||||||
|
background: #000;
|
||||||
|
|
||||||
|
video {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
.player-video-wrapper {
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
|
.player-captions {
|
||||||
|
top: auto;
|
||||||
|
bottom: 90px;
|
||||||
|
|
||||||
|
@media (min-width: $bp-control-split) and (max-width: ($bp-captions-large - 1)) {
|
||||||
|
bottom: 60px;
|
||||||
|
}
|
||||||
|
@media (min-width: $bp-captions-large) {
|
||||||
|
bottom: 80px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.player-controls {
|
||||||
|
position: absolute;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hide controls when playing in full screen
|
||||||
|
&.fullscreen-hide-controls.playing .player-controls {
|
||||||
|
transform: translateY(100%) translateY($control-spacing / 2);
|
||||||
|
transition: transform .3s 1s ease;
|
||||||
|
|
||||||
|
&.hover {
|
||||||
|
transform: translateY(0);
|
||||||
|
transition-delay: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Change icons on state change
|
||||||
|
&.fullscreen-active .icon-exit-fullscreen,
|
||||||
|
&.muted .player-controls .icon-muted,
|
||||||
|
&.captions-active .player-controls .icon-captions-on {
|
||||||
|
display: block;
|
||||||
|
|
||||||
|
& + svg {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Some options are hidden by default
|
||||||
|
[data-player='captions'],
|
||||||
|
[data-player='captions'] + label,
|
||||||
|
[data-player='fullscreen'],
|
||||||
|
[data-player='fullscreen'] + label {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
&.captions-enabled [data-player='captions'],
|
||||||
|
&.captions-enabled [data-player='captions'] + label,
|
||||||
|
&.fullscreen-enabled [data-player='fullscreen'],
|
||||||
|
&.fullscreen-enabled [data-player='fullscreen'] + label {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M9.016 3c2.748 0 4.984 2.243 4.984 5s-2.236 5-4.97 5l-0.060-0.004c-0.055-0.004-0.11-0.007-0.165-0.010l-0.336-0.014-3.665 1.098 0.629-2.483-0.517-0.747c-0.58-0.839-0.886-1.822-0.886-2.842 0-2.757 2.236-5 4.984-5zM9.016 1c-3.857 0-6.984 3.134-6.984 7 0 1.479 0.46 2.848 1.241 3.978l-1.272 5.022 6.722-2.015c0.098 0.004 0.194 0.015 0.293 0.015 3.857 0 6.984-3.134 6.984-7s-3.127-7-6.984-7v0z"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 725 B |
10
src/sprite/icon-captions-off.svg
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg width="18px" height="18px" viewBox="0 0 18 18" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">
|
||||||
|
<!-- Generator: Sketch 3.2.2 (9983) - http://www.bohemiancoding.com/sketch -->
|
||||||
|
<title>icon-captions-off</title>
|
||||||
|
<desc>Created with Sketch.</desc>
|
||||||
|
<defs></defs>
|
||||||
|
<g id="Page-1" stroke="none" stroke-width="1" sketch:type="MSPage">
|
||||||
|
<path d="M1,2 C0.448,2 0,2.448 0,3 L0,15 C0,15.552 0.448,16 1,16 L17,16 C17.552,16 18,15.552 18,15 L18,3 C18,2.448 17.552,2 17,2 L1,2 Z M2,14 L2,4 L16,4 L16,14 L2,14 L2,14 Z" id="Shape" sketch:type="MSShapeGroup"></path>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 747 B |
13
src/sprite/icon-captions-on.svg
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg width="18px" height="18px" viewBox="0 0 18 18" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">
|
||||||
|
<!-- Generator: Sketch 3.2.2 (9983) - http://www.bohemiancoding.com/sketch -->
|
||||||
|
<title>icon-captions-on</title>
|
||||||
|
<desc>Created with Sketch.</desc>
|
||||||
|
<defs></defs>
|
||||||
|
<g id="Page-1" stroke="none" stroke-width="1" sketch:type="MSPage">
|
||||||
|
<path d="M1,2 C0.448,2 0,2.448 0,3 L0,15 C0,15.552 0.448,16 1,16 L17,16 C17.552,16 18,15.552 18,15 L18,3 C18,2.448 17.552,2 17,2 L1,2 Z M2,14 L2,4 L16,4 L16,14 L2,14 L2,14 Z" id="Shape" sketch:type="MSShapeGroup"></path>
|
||||||
|
<rect id="Rectangle-1" sketch:type="MSShapeGroup" x="3" y="11" width="3" height="2"></rect>
|
||||||
|
<rect id="Rectangle-3" sketch:type="MSShapeGroup" x="12" y="11" width="3" height="2"></rect>
|
||||||
|
<rect id="Rectangle-2" sketch:type="MSShapeGroup" x="7" y="11" width="4" height="2"></rect>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.0 KiB |
Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 2.1 KiB |
Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 2.1 KiB |
@ -1,7 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generated by IcoMoon.io -->
|
|
||||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
||||||
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
|
|
||||||
<path d="M8.013 14.006h-0.822c-2.372-0.388-4.187-2.453-4.187-4.934 0-0.831 0.213-1.609 0.574-2.299l0.613 0.85c0.446 0.618 1.409 0.446 1.614-0.289l1.162-4.179c0.162-0.58-0.275-1.155-0.877-1.154l-4.174 0.006c-0.741 0.001-1.17 0.841-0.736 1.443l1.128 1.564c-0.817 1.145-1.302 2.544-1.302 4.059 0 3.499 2.566 6.399 5.918 6.917 0.091 0.014 0.18 0.010 0.267-0.001v0.012h0.822c0.545 0 0.987-0.442 0.987-0.987v-0.020c0-0.545-0.442-0.987-0.987-0.987z"></path>
|
|
||||||
<path d="M16.82 14.551l-1.129-1.564c0.818-1.145 1.302-2.544 1.302-4.059 0-3.499-2.566-6.399-5.918-6.918-0.091-0.014-0.18-0.010-0.267 0.001v-0.013h-0.822c-0.545 0-0.986 0.442-0.986 0.987v0.020c0 0.546 0.442 0.988 0.986 0.988h0.822c2.372 0.388 4.187 2.453 4.187 4.934 0 0.831-0.213 1.609-0.573 2.299l-0.614-0.85c-0.446-0.618-1.409-0.446-1.613 0.289l-1.163 4.179c-0.161 0.581 0.275 1.155 0.878 1.154l4.174-0.006c0.742-0.001 1.17-0.842 0.736-1.443z"></path>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 1.2 KiB |
10
src/sprite/icon-restart.svg
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg width="18px" height="18px" viewBox="0 0 18 18" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">
|
||||||
|
<!-- Generator: Sketch 3.2.2 (9983) - http://www.bohemiancoding.com/sketch -->
|
||||||
|
<title>icon-restart</title>
|
||||||
|
<desc>Created with Sketch.</desc>
|
||||||
|
<defs></defs>
|
||||||
|
<g id="Page-1" stroke="none" stroke-width="1" sketch:type="MSPage">
|
||||||
|
<path d="M17,2 C16.448,2 16,2.448 16,3 L16,7.318 L7,2 C6.448,2 6,2.448 6,3 L6,4.954 L1,2 C0.448,2 0,2.448 0,3 L0,15 C0,15.552 0.448,16 1,16 L6,13.045 L6,15 C6,15.552 6.448,16 7,16 L16,10.682 L16,15 C16,15.552 16.448,16 17,16 C17.552,16 18,15.552 18,15 L18,3 C18,2.448 17.552,2 17,2 L17,2 Z M6,10.722 L2,13.086 L2,4.914 L6,7.278 L6,10.722 L6,10.722 Z M8,13.086 L8,4.914 L14.915,9 L8,13.086 L8,13.086 Z" id="Shape" sketch:type="MSShapeGroup" transform="translate(9.000000, 9.000000) scale(-1, 1) translate(-9.000000, -9.000000) "></path>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.0 KiB |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |