1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00

update caching headers

This commit is contained in:
Luke Pulverenti 2016-11-27 14:36:56 -05:00
parent 087c2139c6
commit 4201f1065d
10 changed files with 118 additions and 165 deletions

View file

@ -14,12 +14,12 @@
}, },
"devDependencies": {}, "devDependencies": {},
"ignore": [], "ignore": [],
"version": "1.4.351", "version": "1.4.354",
"_release": "1.4.351", "_release": "1.4.354",
"_resolution": { "_resolution": {
"type": "version", "type": "version",
"tag": "1.4.351", "tag": "1.4.354",
"commit": "0369e11308d178da80ef85d261cc75b84a273f13" "commit": "3d8a04970adc76c6197984d6c2e29967cfa6b25e"
}, },
"_source": "https://github.com/MediaBrowser/emby-webcomponents.git", "_source": "https://github.com/MediaBrowser/emby-webcomponents.git",
"_target": "^1.2.1", "_target": "^1.2.1",

View file

@ -116,6 +116,38 @@
return false; return false;
} }
var _supportsCssAnimation;
function supportsCssAnimation() {
if (_supportsCssAnimation === true || _supportsCssAnimation === false) {
return _supportsCssAnimation;
}
var animation = false,
animationstring = 'animation',
keyframeprefix = '',
domPrefixes = 'Webkit Moz O ms Khtml'.split(' '),
pfx = '',
elm = document.createElement('div');
if (elm.style.animationName !== undefined) { animation = true; }
if (animation === false) {
for (var i = 0; i < domPrefixes.length; i++) {
if (elm.style[domPrefixes[i] + 'AnimationName'] !== undefined) {
pfx = domPrefixes[i];
animationstring = pfx + 'Animation';
keyframeprefix = '-' + pfx.toLowerCase() + '-';
animation = true;
break;
}
}
}
_supportsCssAnimation = animation;
return _supportsCssAnimation;
}
var uaMatch = function (ua) { var uaMatch = function (ua) {
ua = ua.toLowerCase(); ua = ua.toLowerCase();
@ -196,7 +228,6 @@
if (userAgent.toLowerCase().indexOf("playstation 4") !== -1) { if (userAgent.toLowerCase().indexOf("playstation 4") !== -1) {
browser.ps4 = true; browser.ps4 = true;
browser.tv = true;
} }
if (isMobile(userAgent)) { if (isMobile(userAgent)) {
@ -225,6 +256,7 @@
} }
browser.keyboard = hasKeyboard(browser); browser.keyboard = hasKeyboard(browser);
browser.supportsCssAnimation = supportsCssAnimation;
return browser; return browser;
}); });

View file

@ -13,6 +13,10 @@
return true; return true;
} }
if (!browser.supportsCssAnimation()) {
return false;
}
// An indication of an older browser // An indication of an older browser
if (browser.noFlex) { if (browser.noFlex) {
return false; return false;

View file

@ -73,7 +73,7 @@
this.classList.add('emby-button'); this.classList.add('emby-button');
if (browser.safari || browser.firefox || browser.noFlex) { if (browser.safari || browser.firefox) {
this.classList.add('emby-button-noflex'); this.classList.add('emby-button-noflex');
} }

View file

@ -83,6 +83,10 @@ _:-ms-input-placeholder, :root .mdl-slider {
transition: transform 0.18s cubic-bezier(0.4, 0, 0.2, 1), border 0.18s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.18s cubic-bezier(0.4, 0, 0.2, 1), background 0.28s cubic-bezier(0.4, 0, 0.2, 1); transition: transform 0.18s cubic-bezier(0.4, 0, 0.2, 1), border 0.18s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.18s cubic-bezier(0.4, 0, 0.2, 1), background 0.28s cubic-bezier(0.4, 0, 0.2, 1);
} }
.slider-no-webkit-thumb::-webkit-slider-thumb {
opacity: 0 !important;
}
.mdl-slider::-moz-range-thumb { .mdl-slider::-moz-range-thumb {
-moz-appearance: none; -moz-appearance: none;
width: 1em; width: 1em;

View file

@ -57,6 +57,10 @@
this.classList.add('mdl-slider'); this.classList.add('mdl-slider');
this.classList.add('mdl-js-slider'); this.classList.add('mdl-js-slider');
if (browser.noFlex) {
this.classList.add('slider-no-webkit-thumb')
}
var containerElement = this.parentNode; var containerElement = this.parentNode;
containerElement.classList.add('mdl-slider__container'); containerElement.classList.add('mdl-slider__container');

View file

@ -270,6 +270,7 @@
.programGrid { .programGrid {
padding-bottom: 4px; padding-bottom: 4px;
flex-grow: 1;
} }
.timeslotHeader { .timeslotHeader {

View file

@ -9,10 +9,6 @@ define(['browser', 'dom', 'css!./viewcontainer-lite'], function (browser, dom) {
function enableAnimation() { function enableAnimation() {
if (browser.animate) {
return true;
}
if (browser.tv) { if (browser.tv) {
return false; return false;
} }
@ -21,7 +17,7 @@ define(['browser', 'dom', 'css!./viewcontainer-lite'], function (browser, dom) {
return false; return false;
} }
return browser.edge && !browser.mobile; return browser.supportsCssAnimation();
} }
function loadView(options) { function loadView(options) {
@ -102,7 +98,7 @@ define(['browser', 'dom', 'css!./viewcontainer-lite'], function (browser, dom) {
function animate(newAnimatedPage, oldAnimatedPage, transition, isBack) { function animate(newAnimatedPage, oldAnimatedPage, transition, isBack) {
if (enableAnimation() && oldAnimatedPage && newAnimatedPage.animate) { if (enableAnimation() && oldAnimatedPage) {
if (transition === 'slide') { if (transition === 'slide') {
return slide(newAnimatedPage, oldAnimatedPage, transition, isBack); return slide(newAnimatedPage, oldAnimatedPage, transition, isBack);
} else if (transition === 'fade') { } else if (transition === 'fade') {
@ -262,10 +258,6 @@ define(['browser', 'dom', 'css!./viewcontainer-lite'], function (browser, dom) {
selectedPageIndex = -1; selectedPageIndex = -1;
} }
if (enableAnimation()) {
require(['webAnimations']);
}
return { return {
loadView: loadView, loadView: loadView,
tryRestoreView: tryRestoreView, tryRestoreView: tryRestoreView,

View file

@ -1,4 +1,4 @@
define([], function () { define(['events'], function (events) {
'use strict'; 'use strict';
// LinkParser // LinkParser
@ -42,52 +42,6 @@
+ "(?:\\:(?:[a-z0-9\\$\\-\\_\\.\\+\\!\\*\\'\\(\\)\\,\\;\\?\\&\\=]|(?:\\%[a-f0-9]{2})){1,25})?" // followed by optional password (: + 1-25 normal or url escaped characters) + "(?:\\:(?:[a-z0-9\\$\\-\\_\\.\\+\\!\\*\\'\\(\\)\\,\\;\\?\\&\\=]|(?:\\%[a-f0-9]{2})){1,25})?" // followed by optional password (: + 1-25 normal or url escaped characters)
+ "\\@)"; + "\\@)";
var hostnames = "(?:[a-z0-9][a-z0-9\\-]{0,64}\\.)+"; // named host
var unknownTLDs = "(?:[a-z]{2,})";
// unicode regexp isn't really supported in JS. It can be emulated with XRegExp
// <http://xregexp.com/> but that creates a pretty big performance hit that
// is very noticable on mobile devices. We'll add an option in the future to
// support them.
var XRegExp_hostnames = "(?:[\\p{L}0-9][\\p{L}0-9\\-]{0,64}\\.)+"; // named host
var XRegExp_unknownTLDs = "(?:[\\p{L}]{2,})"; // top level domain
// strings that start with one of these are more likely to be URLs
var knownSubdomains = "(?:(?:www|ftp)\\.)";
// update from here when needed: https://data.iana.org/TLD/tlds-alpha-by-domain.txt
var knownTLDs = "(?:"
+ "A[CDEFGILMNOQRSTUWXZ]|ACADEMY|ACCOUNTANTS|ACTOR|AERO|AGENCY|AIRFORCE|ARCHI|ARPA|ASIA|ASSOCIATES|AUDIO|AUTOS|AXA"
+ "|B[ABDEFGHIJMNORSTVWYZ]|BAR|BARGAINS|BAYERN|BEER|BERLIN|BEST|BID|BIKE|BIZ|BLACK|BLACKFRIDAY|BLUE|BOUTIQUE|BUILD|BUILDERS|BUZZ"
+ "|C[ACDFGHIKLMNORUVWXYZ]|CAB|CAMERA|CAMP|CAPITAL|CARDS|CARE|CAREER|CAREERS|CASH|CAT|CATERING|CENTER|CEO|CHEAP|CHRISTMAS|CHURCH|CITIC|CLAIMS|CLEANING|CLINIC|CLOTHING|CLUB|CODES|COFFEE|COLLEGE|COLOGNE|COM|COMMUNITY|COMPANYCOMPUTER|CONDOS|CONSTRUCTION|CONSULTING|CONTRACTORS|COOKING|COOL|COOP|COUNTRY|CREDIT|CREDITCARD|CRUISES"
+ "|D[EJKMOZ]|DANCE|DATING|DEMOCRAT|DENTAL|DESI|DIAMONDS|DIGITAL|DIRECTORY|DISCOUNT|DNP|DOMAINS"
+ "|E[CEGRSTU]|EDU|EDUCATION|EMAIL|ENGINEERING|ENTERPRISES|EQUIPMENT|ESTATE|EUS|EVENTS|EXCHANGE|EXPERT|EXPOSED"
+ "|F[IJKMOR]|FAIL|FARM|FEEDBACK|FINANCE|FINANCIAL|FISH|FISHING|FITNESS|FLIGHTS|FLORIST|FOO|FOUNDATION|FROGANS|FUND|FURNITURE|FUTBOL"
+ "|G[ABDEFGHILMNPQRSTUWY]|GAL|GALLERY|GIFT|GLASS|GLOBO|GMO|GOP|GOV|GRAPHICS|GRATIS|GRIPE|GUIDE|GUITARS|GURU"
+ "|H[KMNRTU]|HAUS|HIPHOP|HOLDINGS|HOLIDAY|HOMES|HORSE|HOUSE"
+ "|I[DELMNOQRST]|IMMOBILIEN|INDUSTRIES|INFO|INK|INSTITUTE|INSURE|INT|INTERNATIONAL|INVESTMENTS"
+ "|J[EMOP]|JETZT|JOBS|JUEGOS"
+ "|K[EGHIMNPRWYZ]|KAUFEN|KIM|KITCHEN|KIWI|KOELN|KRED"
+ "|L[ABCIKRSTUVY]|LAND|LEASE|LIFE|LIGHTING|LIMITED|LIMO|LINK|LOANS|LONDON|LUXE|LUXURY"
+ "|M[ACDEGHKLMNOPQRSTUVWXYZ]|MAISON|MANAGEMENT|MANGO|MARKETING|MEDIA|MEET|MENU|MIAMI|MIL|MOBI|MODA|MOE|MONASH|MOSCOW|MOTORCYCLES|MUSEUM"
+ "|N[ACEFGILOPRUZ]|NAGOYA|NAME|NET|NEUSTAR|NINJA|NYC"
+ "|O[M]|OKINAWA|ONL|ORG"
+ "|P[AEFGHKLMNRSTWY]|PARIS|PARTNERS|PARTS|PHOTO|PHOTOGRAPHY|PHOTOS|PICS|PICTURES|PINK|PLUMBING|POST|PRO|PRODUCTIONS|PROPERTIES|PUB"
+ "|Q[A]|QPON|QUEBEC"
+ "|R[EOSUW]|RECIPES|RED|REISE|REISEN|REN|RENTALS|REPAIR|REPORT|REST|REVIEWS|RICH|RIO|ROCKS|RODEO|RUHR|RYUKYU"
+ "|S[ABCDEGHIJKLMNORTUVXYZ]|SAARLAND|SCHULE|SERVICES|SEXY|SHIKSHA|SHOES|SINGLES|SOCIAL|SOHU|SOLAR|SOLUTIONS|SOY|SUPPLIES|SUPPLY|SUPPORT|SURGERY|SYSTEMS"
+ "|T[CDFGHJKLMNOPRTVWZ]|TATTOO|TAX|TECHNOLOGY|TEL|TIENDA|TIPS|TODAY|TOKYO|TOOLS|TOWN|TOYS|TRADE|TRAINING|TRAVEL"
+ "|U[AGKSYZ]|UNIVERSITY|UNO"
+ "|V[ACEGINU]|VACATIONS|VEGAS|VENTURES|VERSICHERUNG|VIAJES|VILLAS|VISION|VODKA|VOTE|VOTING|VOTO|VOYAGE"
+ "|W[FS]|WANG|WATCH|WEBCAM|WED|WIEN|WIKI|WORKS|WTC|WTF"
+ "|XXX|XYZ"
+ "|Y[ET]|YACHTS|YOKOHAMA"
+ "|Z[AMW]|ZONE"
// IDN TLDs in both punycode and unicode format
+ "|XN--(?:3BST00M|3DS443G|3E0B707E|45BRJ9C|55QW42G|55QX5D|6FRZ82G|6QQ986B3XL|80ADXHKS|80AO21A|80ASEHDB|80ASWG|90A3AC|C1AVG|CG4BKI|CLCHC0EA0B2G2A9GCD|CZR694B|CZRU2D|D1ACJ3B|FIQ228C5HS|FIQ64B|FIQS8S|FIQZ9S|FPCRJ9C3D|FZC2C9E2C|GECRJ9C|H2BRJ9C|I1B6B1A6A2E|IO0A7I|J1AMH|J6W193G|KPRW13D|KPRY57D|L1ACC|LGBBAT1AD8J|MGB9AWBF|MGBA3A4F16A|MGBAAM7A8H|MGBAB2BD|MGBAYH7GPA|MGBBH1A71E|MGBC0A9AZCG|MGBERP4A5D4AR|MGBX4CD0AB|NGBC5AZD|NQV7F|NQV7FS00EMA|O3CW4H|OGBPF8FL|P1AI|PGBS0DH|Q9JYB4C|RHQV96G|S9BRJ9C|SES554G|UNUP4Y|WGBH1C|WGBL6A|XKC2AL3HYE2A|XKC2DL3A5EE0H|YFRO4I67O|YGBI2AMMX|ZFR164B)"
+ "|\u0627\u0644\u0627\u0631\u062F\u0646|\u4E2D\u570B|\u4E2D\u56FD|\u0627\u0645\u0627\u0631\u0627\u062A|\u9999\u6E2F|\u0627\u06CC\u0631\u0627\u0646|\u0DBD\u0D82\u0D9A\u0DCF|\u0B87\u0BB2\u0B99\u0BCD\u0B95\u0BC8|\u0645\u0635\u0631|\u0642\u0637\u0631|\u0420\u0424|\u0633\u0648\u0631\u064A\u0629|\u53F0\u7063|\u53F0\u6E7E"
+ ")";
// IPv6 Regex http://forums.intermapper.com/viewtopic.php?t=452 // IPv6 Regex http://forums.intermapper.com/viewtopic.php?t=452
// by Dartware, LLC is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License // by Dartware, LLC is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License
// http://intermapper.com/ // http://intermapper.com/
@ -117,45 +71,7 @@
// If we have a recognized protocol at the beginning of the URL, we're // If we have a recognized protocol at the beginning of the URL, we're
// more relaxed about what we accept, because we assume the user wants // more relaxed about what we accept, because we assume the user wants
// this to be a URL, and we're not accidentally matching human language // this to be a URL, and we're not accidentally matching human language
+ protocols + protocols + "?"
// optional username:password@
+ credentials + "?"
// loose definition of a host name
// any valid unicode sequence is ok for domain
// this is our failsafe. If we don't recognize a TLD (because new TLDs are
// constantly being added) and the host name doesn't start with a common
// prefix like www, then this should catch anything that begins with a
// valid protocol (above)
+ hostnames + unknownTLDs
// ============================
// OR no protocol and a stricter form of a host name, with something that
// we recognize as a likely URL. This will hopefully keep us from matching
// typos like.this as a URL.
+ "|(?!" + protocols + ")"
// optional username:password@
+ credentials + "?"
+ "(?:"
// ends with known TLD
+ hostnames + knownTLDs
// OR begins with a known common subdomain
+ "|" + knownSubdomains + hostnames + unknownTLDs
// OR contains a slash after the TLD (very likely a URL, unlikely to exist in common language)
+ "|" + hostnames + unknownTLDs + "(?=\\/)" // use a lookahead so we don't pre-match the path below
+ ")"
// ============================
// OR we'll also accept IPv6 and IPv4 addresses, with or without a protocol, since it's highly
// unlikely that these would appear in normal language without being intended as a URL
+ "|" + protocols + "?"
// optional username:password@ // optional username:password@
+ credentials + "?" + credentials + "?"
@ -309,8 +225,8 @@
return null; return null;
} }
Events.on(ConnectionManager, 'localusersignedin', clearCache); events.on(ConnectionManager, 'localusersignedin', clearCache);
Events.on(ConnectionManager, 'localusersignedout', clearCache); events.on(ConnectionManager, 'localusersignedout', clearCache);
return { return {
getServerAddress: getServerAddress getServerAddress: getServerAddress

View file

@ -994,7 +994,7 @@
var context = inferContext(item); var context = inferContext(item);
var href = LibraryBrowser.getHref(item.Studios[i], context); var href = LibraryBrowser.getHref(item.Studios[0], context);
html += ' on <a class="textlink" href="' + href + '">' + item.Studios[0].Name + '</a>'; html += ' on <a class="textlink" href="' + href + '">' + item.Studios[0].Name + '</a>';
} }
} }