videojs / video.js

Video.js - open source HTML5 video player
https://videojs.com
Other
38.1k stars 7.45k forks source link

Firefox bug or videojs bug regarding cross site scripting and control bar font #1585

Closed sethborg closed 10 years ago

sethborg commented 10 years ago

Video uses a font for the control bar icons and if you use the player locally off the hard drive Firefox blocks the font from loading due to its cross site scripting security http://red-team-design.com/firefox-doesnt-allow-cross-domain-fonts-by-default/ However, it works if played locally off a DVD. Is Firefox just treating the DVD as not local so things work better or is this a videojs bug?

Any thoughts on how to get around Firefox's local cross site scripting security for videojs's control bar font? Is it as simple as adjusting the CSS somehow with the local path?

Edit, videojs people, have you thought about embedding the font as a base64 string in your CSS to fix this issue?

videojs_issue

mmcc commented 10 years ago

Even though our font is pretty tiny as far as icon fonts go, I still don't think the ~30% additional overhead for the base64 encoding is worth the tradeoff. If you're goal is to use Video.js locally, then it makes way more sense to use a local font as well.

@font-face{
  font-family: 'VideoJS';
  src: url('local/path/to/font/vjs.eot');
  src: url('local/path/to/font/vjs.eot?#iefix') format('embedded-opentype'),
  url('local/path/to/font/vjs.woff') format('woff'),
  url('local/path/to/font/vjs.ttf') format('truetype'),
  url('local/path/to/font/vjs.svg#icomoon') format('svg');

  font-weight: normal;
  font-style: normal;
}

That is quite strange that it works off the DVD, though. ¯_(ツ)_/¯

Edit: Markdown is not very friendly to that emoticon.

gkatsev commented 10 years ago

Also, particularly if the flash fallback is enabled, you don't want to load via file:// but rather via a local webserver.

sethborg commented 10 years ago

gkatsev that's just not going to happen. I'm running this off a CD. How about offering a base64 CSS for those of us who want to provide that option? I'm not sure how you specify the hash (#) if using data URIs though. I used the below and it works great!

@font-face {
  font-family: 'VideoJS';
  src: url(data:application/x-font-eot;charset=utf-8;base64,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);
  src: url(data:application/x-font-woff;charset=utf-8;base64,d09GRk9UVE8AAA2kAAoAAAAADVwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABDRkYgAAAA9AAACdMAAAnTVAEFP09TLzIAAArIAAAAYAAAAGAOkgMqY21hcAAACygAAABcAAAAXPqtrG5nYXNwAAALhAAAAAgAAAAIAAAAEGhlYWQAAAuMAAAANgAAADYDr5QBaGhlYQAAC8QAAAAkAAAAJAkgBTVobXR4AAAL6AAAAFgAAABYS54C2G1heHAAAAxAAAAABgAAAAYAFlAAbmFtZQAADEgAAAE5AAABOUQYtNZwb3N0AAANhAAAACAAAAAgAAMAAAEABAQAAQEBCGljb21vb24AAQIAAQA7+BwC+BsD+BgEHgoACXf/i4seCgAJd/+LiwwHi0UcBV76VAUdAAAA3Q8dAAAA4hEdAAAACR0AAAnKEgAXAQEIDxETFhsgJSovNDk+Q0hNUldcYWZrcGljb21vb25pY29tb29udTB1MXUyMHVFMDAwdUUwMDF1RTAwMnVFMDAzdUUwMDR1RTAwNXVFMDA2dUUwMDd1RTAwOHVFMDA5dUUwMEF1RTAwQnVFMDBDdUUwMER1RTAwRXVFMDFFdUUwMUZ1RTYwMAAAAgGJABQAFgIAAQAEAAcACgANAEUAVABzAJ0A/QGbAn0CkAOSA6IE2QURBV8GIQagB5QICAi4/pQO/pQO/pQO/JQO+pT6VBWL/DT7NPc0+1T7VCvr91T3VPs09zQF+zT9NBX7VPtU9zT7NPw0i4v4NPc0+zT3VPdUBQ73VPnUFfkU/BT9FPwUBQ73FPnUFffUi4v9lPvUiwX4VPmUFffUi4v9lPvUiwUO+CX6BRWlpaCCi2cIi/3QBYtndoJxpQj7hfeF+zSLi/gU9zSL94X3hQUO+Ln3bxV/i36QgpR4noupnp7c3Iv3GDrceJ6LqZ6enp6pi5549wr7C4v7VPsK+wuCgn6Gf4sI+yj5KhWlpaCCi2cIi/3QBYtndoJxpQj7hfeF+zSLi/gU9zSL94X3hQUO+WT3FBV+i3+QgpV4nYuqnp33F/cXi/dq+xf3F3idi6qenZ2eqoudeN06uPsBi/sHi/sHXvsBOTqCgX+Gf4sI+z/mFX+LfpCClHiei6mentzci/cYOtx4noupnp6enqmLnnj3CvsLi/tU+wr7C4KCfoZ/iwj7KPkqFaWloIKLZwiL/dAFi2d2gnGlCPuF94X7NIuL+BT3NIv3hfeFBQ7L+g6xFX+LfpCClHiei6menuPju/cIi/cQi/cQW/cIM+N4noupnp6enqmLnnj1IcX7IIv7Kov7KlH7ICEhCIKCfoZ/iwj7PuUVfot/kIKVeJ2Lqp6d9xf3F4v3avsX9xd4nYuqnp2dnqqLnXjdOrj7AYv7B4v7B177ATk6goF/hn+LCPs/5hV/i36QgpR4noupnp7c3Iv3GDrceJ6LqZ6enp6pi5549wr7C4v7VPsK+wuCgn6Gf4sI+yj5KhWlpaCCi2cIi/3QBYtndoJxpQj7hfeF+zSLi/gU9zSL94X3hQUO+JT6VBX71PyU99T8lPfU+JQFDvfyi/pUFRwFXouL/poc+qKLi/qaBRwE3fyTFYr3SITaYMKEl3ySf5RhqftZlvt5i/t4i/tjgGJtf4J8hIJ/YlSFPIj7SI77SJE9tFOUfpqFl4MItGv3Y4H3eIn3eY33WZW1q5eTmpGSmLbDktmM90gI/Nu6FYD3IUDe+xqL+w+LK/sDi/tFi/tG4/sD9yWL9wiL3OCX9yEI+x6LBYZXdWNci0KLftOL2Iv1qcG+i7iLqGqPUgj3HIsF+HKLFX/3IUHe+xuL+w6LK/sDi/tFi/tG4vsD9yWL9wiL3OCY9yEI+x6LBYVXdWNdi0KLftOL2Iv1qcG+i7iLp2qQUgj3HIsFDvcU+dQV+ZSLi/2U/ZSLBQ74FPnUFYtExFLSi9KLxMSL0ovSUsREi0SLUlKLRAj3pPsEFYtExFLSi9GLxcSL0ovRUcVFi0SLUlGLRQj3RPukFYtoqG6ui66LqKiLrouubqhoi2iLbm6LaAj7BPukFYtop26vi66LqKiLrouvbqdoi2eLb2+LZwj7pPsEFYuLi4uLi4toqG6ui66LqKiLrouLi4uLi4uLi4uLi4uubqhoi2iLbm6LaIuLi4uLiwj7pPcEFYuLi4uLi4toqG6ui6+Lp6iLrouLi4uLi4uLi4uLi4uvb6dni2iLbm+LZ4uLi4uLiwhr+LQVi4uLi4uLi1a2YMCLwIu2tovAi4uLi4uLi4uLi4uLi8BgtlaLVotgYItWi4uLi4uLCDP7pBWLY6trs4uzi6uri7OLs2urY4tji2tri2MIDvhU+BQVi/w0+zT3NPtU+1Qr6/dU91T7NPc0Bfp0+HQV+1T7VPc0+zT8NIuL+DT3NPs091T3VAUO+JT6FBX3r4v3eftOi/t6i/t6+3n7Tvuvi3CLcI1xjvsC+wL7F3f7E4gIi6YF0K3GyIvRi5WKlIqV+wjXQfcIi/cXi/d693n3TveviwgO+JT6VBX7r4v7eft5i/uvi/uv93n7efevi/evi/d593mL96+L96/7efd5+6+LCIv7lBX3IYv3B/sHi/shi/sh+wf7B/shi/shi/sH9weL9yGL9yH3B/cH9yGLCPfF/MUVOjn7AV77B4v7B4v7Abg63TncXvcBi/cHi/cHuPcB3dwIzkgFi4uLi4uL+xf7F4v7avcX+xfLTN9o5Yvli9+uy8r3F/cXi/dq+xf3FwjOzgXdOrj7AYv7B4v7B177ATk6CA759PeUFV6LYnhubQj8Q/dsBYyTjJOLlIuUipOKkwj4Q/dsBahttHi4i+OL09OL44vjQ9MzizOLQ0OLM4uCjIOMgwj8Q/tsBW6pYp5eizOLQ0OLM4sz00Pji7iLtJ6oqQj4Q/tsBYqDioOLgosz00Pji+OL09OL44vjQ9MziwgO+pT4VBWKznzOcMdxyGTDW7hcuVKvTqNOo0qWSopKikt9UHFQcVVlX11fXWhUdFB0UIBMjEwIjEyZTaRSpFKwV7dguGDAasR1xHTIgciMyIzHmcKjwqO9rrS3tbarvqHCmKyUro+vCIyLjYuMi66LqKeLr4uMi42LjQiLiwUl+z4VdFZpW2FjYWNabFZ2VnZSglKMUoxTmFihWKJcrGWzZbNtu3e+d7+CwYzCjMKXwKG9CKG8q7iysLGvuai8nr2ewJS/isCKvn+7drp2tmyuZq9mpl+eW51ck1iKWQiLiwWLiYuJi4qLaqRvq4iFaIFpfGsIDviU+lQV+6uL+3b7c4T7qZH3hvdM91b3dov3eov3Tvtdi/uLi1a2YMCLwIu2tovAi/ev+3n3efuviwiL/pQV96uL93b3c5L3qYX7hvtM+1b7dov7eov7Tvddi/eLi8BgtlaLVotgYItWi/uv93n7efeviwgO+pT39BWL91T7J6QFhZ2EnIOcCOH3Dfsc9xz7DTUFepN6k3iRCHP3JvtUi3P7JgV4hXqDeoMI+w3h+xz7HOH7DQWDeoR6hXkI+ydyi/tU9ydyBZF5knqUegg0+w33HPsc9w7iBZuDnIOdhQik+yf3VIuk9ycFnZGck5uTCPcONPcc9xw09w0FlJySnJGdCPcnpAX8lGsVRItSxIvSi9LExNKL0ovEUotEi0RSUkSLCA76lBT6lBWLDAoAAAMEAAGQAAUAAAKZAswAAACPApkCzAAAAesAMwEJAAAAAAAAAAAAAAAAAAAAARAAAAAAAAAAAAAAAAAAAAAAQAAA5gADwP/A/8ADwABAAAAAAQAAAAAAAAAAAAAAIAAAAAAAAgAAAAMAAAAUAAMAAQAAABQABABIAAAADgAIAAIABgABACDgDuAf5gD//f//AAAAAAAg4ADgHuYA//3//wAB/+MgBB/1GhUAAwABAAAAAAAAAAAAAAAAAAAAAQAB//8ADwABAAAAAAAAi7ha+V8PPPUACwQAAAAAAM+Zp8UAAAAAz5mnxQAA/7oFXgPAAAAACAACAAAAAAAAAAEAAAPA/8AAAAVeAAAAAAVeAAEAAAAAAAAAAAAAAAAAAAAWAAAAAAAAAAAAAAAAAgAAAAQAAAAEAADABAAAgAQAAAAEAAAABAAAAARAAAAEAADABV4AAAQAAIAEAAA4BAAAAAQAAAAEAAAABAAAAAQAACAEAAAABAAAAAAAUAAAFgAAAAAADgCuAAEAAAAAAAEADgAAAAEAAAAAAAIADgBHAAEAAAAAAAMADgAkAAEAAAAAAAQADgBVAAEAAAAAAAUAFgAOAAEAAAAAAAYABwAyAAEAAAAAAAoAKABjAAMAAQQJAAEADgAAAAMAAQQJAAIADgBHAAMAAQQJAAMADgAkAAMAAQQJAAQADgBVAAMAAQQJAAUAFgAOAAMAAQQJAAYADgA5AAMAAQQJAAoAKABjAGkAYwBvAG0AbwBvAG4AVgBlAHIAcwBpAG8AbgAgADEALgAwAGkAYwBvAG0AbwBvAG5pY29tb29uAGkAYwBvAG0AbwBvAG4AUgBlAGcAdQBsAGEAcgBpAGMAbwBtAG8AbwBuAEcAZQBuAGUAcgBhAHQAZQBkACAAYgB5ACAASQBjAG8ATQBvAG8AbgAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA) format('woff'), 
  url(data:application/x-font-ttf;charset=utf-8;base64,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) format('truetype'),
  url(data:application/x-font-svg;charset=utf-8;base64,<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
<svg xmlns="http://www.w3.org/2000/svg">
<metadata>Generated by IcoMoon</metadata>
<defs>
<font id="icomoon" horiz-adv-x="1024">
<font-face units-per-em="1024" ascent="960" descent="-64" />
<missing-glyph horiz-adv-x="1024" />
<glyph unicode="&#x20;" d="" horiz-adv-x="512" />
<glyph unicode="&#xe000;" d="M1024 960v-416l-160 160-192-192-96 96 192 192-160 160zM448 288l-192-192 160-160h-416v416l160-160 192 192z" />
<glyph unicode="&#xe001;" d="M192 832l640-384-640-384z" />
<glyph unicode="&#xe002;" d="M128 832h320v-768h-320zM576 832h320v-768h-320z" />
<glyph unicode="&#xe003;" d="M401.332 881.332c25.668 25.668 46.668 16.968 46.668-19.332v-828c0-36.3-21-44.998-46.668-19.33l-241.332 241.33h-160v384h160l241.332 241.332z" />
<glyph unicode="&#xe004;" d="M549.020 218.98c-12.286 0-24.568 4.686-33.942 14.058-18.746 18.746-18.746 49.136 0 67.882 81.1 81.1 81.1 213.058 0 294.156-18.746 18.746-18.746 49.138 0 67.882 18.746 18.744 49.136 18.744 67.882 0 118.53-118.53 118.53-311.392 0-429.922-9.372-9.37-21.656-14.056-33.94-14.056zM401.332 881.332c25.668 25.668 46.668 16.968 46.668-19.332v-828c0-36.3-21-44.998-46.668-19.33l-241.332 241.33h-160v384h160l241.332 241.332z" />
<glyph unicode="&#xe005;" d="M719.53 128.47c-12.286 0-24.568 4.686-33.942 14.058-18.744 18.744-18.744 49.136 0 67.882 131.006 131.006 131.006 344.17 0 475.176-18.744 18.746-18.744 49.138 0 67.882 18.744 18.742 49.138 18.744 67.882 0 81.594-81.592 126.53-190.076 126.53-305.468 0-115.39-44.936-223.876-126.53-305.47-9.372-9.374-21.656-14.060-33.94-14.060zM549.020 218.98c-12.286 0-24.568 4.686-33.942 14.058-18.746 18.746-18.746 49.136 0 67.882 81.1 81.1 81.1 213.058 0 294.156-18.746 18.746-18.746 49.138 0 67.882 18.746 18.744 49.136 18.744 67.882 0 118.53-118.53 118.53-311.392 0-429.922-9.372-9.37-21.656-14.056-33.94-14.056zM401.332 881.332c25.668 25.668 46.668 16.968 46.668-19.332v-828c0-36.3-21-44.998-46.668-19.33l-241.332 241.33h-160v384h160l241.332 241.332z" />
<glyph unicode="&#xe006;" d="M890.040 37.96c-12.286 0-24.568 4.686-33.942 14.058-18.744 18.746-18.744 49.136 0 67.882 87.638 87.642 135.904 204.16 135.904 328.1 0 123.938-48.266 240.458-135.904 328.098-18.744 18.746-18.744 49.138 0 67.882 18.744 18.744 49.138 18.744 67.882 0 105.77-105.772 164.022-246.4 164.022-395.98 0-149.582-58.252-290.208-164.022-395.98-9.372-9.374-21.656-14.060-33.94-14.060zM719.53 128.47c-12.286 0-24.568 4.686-33.942 14.058-18.744 18.744-18.744 49.136 0 67.882 131.006 131.006 131.006 344.17 0 475.176-18.744 18.746-18.744 49.138 0 67.882 18.744 18.742 49.138 18.744 67.882 0 81.594-81.592 126.53-190.076 126.53-305.468 0-115.39-44.936-223.876-126.53-305.47-9.372-9.374-21.656-14.060-33.94-14.060zM549.020 218.98c-12.286 0-24.568 4.686-33.942 14.058-18.746 18.746-18.746 49.136 0 67.882 81.1 81.1 81.1 213.058 0 294.156-18.746 18.746-18.746 49.138 0 67.882 18.746 18.744 49.136 18.744 67.882 0 118.53-118.53 118.53-311.392 0-429.922-9.372-9.37-21.656-14.056-33.94-14.056zM401.332 881.332c25.668 25.668 46.668 16.968 46.668-19.332v-828c0-36.3-21-44.998-46.668-19.33l-241.332 241.33h-160v384h160l241.332 241.332z" horiz-adv-x="1088" />
<glyph unicode="&#xe007;" d="M512 960l-320-512 320-512 320 512z" />
<glyph unicode="&#xe008;" d="M0 960h1374.316v-1030.414h-1374.316v1030.414zM1245.462 449.276c-1.706 180.052-8.542 258.568-51.2 314.036-7.68 11.946-22.186 18.772-34.132 27.296-41.814 30.73-238.944 41.814-467.636 41.814-228.702 0-435.21-11.084-476.17-41.814-12.8-8.524-27.316-15.35-35.84-27.296-41.822-55.468-47.786-133.984-50.346-314.036 2.56-180.062 8.524-258.57 50.346-314.036 8.524-12.8 23.040-18.774 35.84-27.306 40.96-31.574 247.468-41.814 476.17-43.52 228.692 1.706 425.822 11.946 467.636 43.52 11.946 8.532 26.452 14.506 34.132 27.306 42.658 55.466 49.494 133.974 51.2 314.036zM662.358 495.904c-11.58 140.898-86.51 223.906-220.556 223.906-122.458 0-218.722-110.432-218.722-287.88 0-178.212 87.73-289.396 232.734-289.396 115.766 0 196.798 85.298 209.588 226.95h-138.302c-5.48-52.548-27.414-92.914-73.72-92.914-73.108 0-86.51 72.354-86.51 149.27 0 105.868 30.46 159.932 81.032 159.932 45.082 0 73.718-32.75 77.976-89.868h136.48zM1140.026 495.904c-11.57 140.898-86.51 223.906-220.546 223.906-122.466 0-218.722-110.432-218.722-287.88 0-178.212 87.73-289.396 232.734-289.396 115.758 0 196.788 85.298 209.58 226.95h-138.304c-5.47-52.548-27.404-92.914-73.71-92.914-73.116 0-86.518 72.354-86.518 149.27 0 105.868 30.468 159.932 81.030 159.932 45.084 0 73.728-32.75 77.986-89.868h136.47z" horiz-adv-x="1374" />
<glyph unicode="&#xe009;" d="M128 832h768v-768h-768z" />
<glyph unicode="&#xe00a;" d="M384 832c0-70.692 57.308-128 128-128s128 57.308 128 128c0 70.692-57.308 128-128 128-70.692 0-128-57.308-128-128zM655.53 719.53c0-70.692 57.308-128 128-128s128 57.308 128 128c0 70.692-57.308 128-128 128-70.692 0-128-57.308-128-128zM832 448c0-35.346 28.654-64 64-64s64 28.654 64 64c0 35.346-28.654 64-64 64-35.346 0-64-28.654-64-64zM719.53 176.47c0-35.346 28.654-64 64-64s64 28.654 64 64c0 35.346-28.654 64-64 64-35.346 0-64-28.654-64-64zM448.002 64c0 0 0 0 0 0 0-35.346 28.654-64 64-64 35.346 0 64 28.654 64 64 0 0 0 0 0 0 0 0 0 0 0 0 0 35.346-28.654 64-64 64-35.346 0-64-28.654-64-64s0 0 0 0zM176.472 176.47c0 0 0 0 0 0 0-35.346 28.654-64 64-64 35.346 0 64 28.654 64 64 0 0 0 0 0 0 0 0 0 0 0 0 0 35.346-28.654 64-64 64-35.346 0-64-28.654-64-64s0 0 0 0zM144.472 719.53c0 0 0 0 0 0 0-53.019 42.981-96 96-96 53.019 0 96 42.981 96 96 0 0 0 0 0 0 0 0 0 0 0 0 0 53.019-42.981 96-96 96-53.019 0-96-42.981-96-96s0 0 0 0zM56 448c0-39.765 32.235-72 72-72s72 32.235 72 72c0 39.765-32.235 72-72 72-39.765 0-72-32.235-72-72z" />
<glyph unicode="&#xe00b;" d="M448 384v-416l-160 160-192-192-96 96 192 192-160 160zM1024 864l-192-192 160-160h-416v416l160-160 192 192z" />
<glyph unicode="&#xe00c;" d="M512 896c282.77 0 512-186.25 512-416 0-229.752-229.23-416-512-416-27.156 0-53.81 1.734-79.824 5.044-109.978-109.978-241.25-129.7-368.176-132.596v26.916c68.536 33.578 128 94.74 128 164.636 0 9.754-0.758 19.33-2.164 28.696-115.796 76.264-189.836 192.754-189.836 323.304 0 229.75 229.23 416 512 416z" />
<glyph unicode="&#xe00d;" d="M512 960c-282.77 0-512-229.23-512-512s229.23-512 512-512 512 229.23 512 512-229.23 512-512 512zM512 704c141.384 0 256-114.616 256-256s-114.616-256-256-256-256 114.616-256 256 114.616 256 256 256zM817.47 142.53c-81.594-81.594-190.080-126.53-305.47-126.53-115.392 0-223.876 44.936-305.47 126.53-81.594 81.594-126.53 190.078-126.53 305.47 0 115.39 44.936 223.876 126.53 305.47l67.882-67.882c0 0 0 0 0 0-131.006-131.006-131.006-344.17 0-475.176 63.462-63.462 147.838-98.412 237.588-98.412 89.748 0 174.124 34.95 237.588 98.412 131.006 131.006 131.006 344.168 0 475.176l67.882 67.882c81.594-81.594 126.53-190.080 126.53-305.47 0-115.392-44.936-223.876-126.53-305.47z" />
<glyph unicode="&#xe00e;" d="M864 256c-45.16 0-85.92-18.738-115.012-48.83l-431.004 215.502c1.314 8.252 2.016 16.706 2.016 25.328s-0.702 17.076-2.016 25.326l431.004 215.502c29.092-30.090 69.852-48.828 115.012-48.828 88.366 0 160 71.634 160 160s-71.634 160-160 160-160-71.634-160-160c0-8.622 0.704-17.076 2.016-25.326l-431.004-215.504c-29.092 30.090-69.852 48.83-115.012 48.83-88.366 0-160-71.636-160-160 0-88.368 71.634-160 160-160 45.16 0 85.92 18.738 115.012 48.828l431.004-215.502c-1.312-8.25-2.016-16.704-2.016-25.326 0-88.368 71.634-160 160-160s160 71.632 160 160c0 88.364-71.634 160-160 160z" />
<glyph unicode="&#xe01e;" d="M1024 448c-1.278 66.862-15.784 133.516-42.576 194.462-26.704 61-65.462 116.258-113.042 161.92-47.552 45.696-103.944 81.82-164.984 105.652-61.004 23.924-126.596 35.352-191.398 33.966-64.81-1.282-129.332-15.374-188.334-41.356-59.048-25.896-112.542-63.47-156.734-109.576-44.224-46.082-79.16-100.708-102.186-159.798-23.114-59.062-34.128-122.52-32.746-185.27 1.286-62.76 14.964-125.148 40.134-182.206 25.088-57.1 61.476-108.828 106.11-151.548 44.61-42.754 97.472-76.504 154.614-98.72 57.118-22.304 118.446-32.902 179.142-31.526 60.708 1.29 120.962 14.554 176.076 38.914 55.15 24.282 105.116 59.48 146.366 102.644 41.282 43.14 73.844 94.236 95.254 149.43 13.034 33.458 21.88 68.4 26.542 103.798 1.246-0.072 2.498-0.12 3.762-0.12 35.346 0 64 28.652 64 64 0 1.796-0.094 3.572-0.238 5.332h0.238zM922.306 278.052c-23.472-53.202-57.484-101.4-99.178-141.18-41.67-39.81-91-71.186-144.244-91.79-53.228-20.678-110.29-30.452-166.884-29.082-56.604 1.298-112.596 13.736-163.82 36.474-51.25 22.666-97.684 55.49-135.994 95.712-38.338 40.198-68.528 87.764-88.322 139.058-19.87 51.284-29.228 106.214-27.864 160.756 1.302 54.552 13.328 108.412 35.254 157.69 21.858 49.3 53.498 93.97 92.246 130.81 38.73 36.868 84.53 65.87 133.874 84.856 49.338 19.060 102.136 28.006 154.626 26.644 52.5-1.306 104.228-12.918 151.562-34.034 47.352-21.050 90.256-51.502 125.624-88.782 35.396-37.258 63.21-81.294 81.39-128.688 18.248-47.392 26.782-98.058 25.424-148.496h0.238c-0.144-1.76-0.238-3.536-0.238-5.332 0-33.012 24.992-60.174 57.086-63.624-6.224-34.822-16.53-68.818-30.78-100.992z" />
<glyph unicode="&#xe01f;" d="M512 960c-278.748 0-505.458-222.762-511.848-499.974 5.92 241.864 189.832 435.974 415.848 435.974 229.75 0 416-200.576 416-448 0-53.020 42.98-96 96-96 53.020 0 96 42.98 96 96 0 282.77-229.23 512-512 512zM512-64c278.748 0 505.458 222.762 511.848 499.974-5.92-241.864-189.832-435.974-415.848-435.974-229.75 0-416 200.576-416 448 0 53.020-42.98 96-96 96-53.020 0-96-42.98-96-96 0-282.77 229.23-512 512-512z" />
<glyph unicode="&#xe600;" d="M1024 351.906v192.188l-146.774 24.462c-5.958 18.132-13.222 35.668-21.694 52.5l86.454 121.034-135.896 135.898-120.826-86.304c-16.91 8.554-34.538 15.888-52.768 21.902l-24.402 146.414h-192.188l-24.402-146.416c-18.23-6.014-35.858-13.348-52.766-21.902l-120.828 86.304-135.898-135.898 86.454-121.036c-8.47-16.83-15.734-34.366-21.692-52.498l-146.774-24.46v-192.188l147.118-24.52c5.96-17.968 13.21-35.348 21.642-52.030l-86.748-121.448 135.898-135.896 121.654 86.894c16.602-8.35 33.89-15.528 51.764-21.434l24.578-147.472h192.188l24.578 147.474c17.874 5.906 35.162 13.084 51.766 21.432l121.652-86.892 135.896 135.896-86.744 121.446c8.432 16.682 15.678 34.062 21.64 52.032l147.118 24.518zM512 320c-70.692 0-128 57.306-128 128 0 70.692 57.308 128 128 128 70.694 0 128-57.308 128-128 0-70.694-57.306-128-128-128z" />
</font></defs></svg>) format('svg');
  font-weight: normal;
  font-style: normal;
}

Edit by @mmcc: code fence to save vertical space.

mmcc commented 10 years ago

@sethborg you can do it yourself if you'd like, but we're not going to provide this.

sethborg commented 10 years ago

ok, it would be helpful to note the option in the documentation somewhere to help people out.

mmcc commented 10 years ago

What option? I would suggest folks set a local path to the font files before suggesting they Base64 encode them.

sethborg commented 10 years ago

Just a note in the documentation saying "If you run this locally, firefox's security won't show the controls in the control bar. You can replace the fonts in the css with a data URI base64 version to get around this"

What do you mean set a local path? Do you mean instead of a relative path set them to the absolute paths like: file:///D:/something/video-js/fonts/font.ttf ? That wouldn't work for this case if someone didn't have their CD/DVD drive on D:

Or do you mean something else?

mmcc commented 10 years ago

Ahh interesting, I didn't realize Firefox had such stringent file:/// restrictions. I get what you're saying now, my apologies for the misunderstanding.

We might want to mention that this is a possibility for folks, but I still don't think we want to include the actual base64 encoded font in the docs. We don't want to have to worry about the two drifting apart over time, and this is a pretty tiny edge case imho.