mirror of
https://github.com/jellyfin/jellyfin-web.git
synced 2024-11-17 19:08:18 -07:00
update offline detection
This commit is contained in:
parent
c651a45dea
commit
930c8cf6d8
@ -102,6 +102,13 @@
|
|||||||
return deferred.promise();
|
return deferred.promise();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function translateFilePath(path) {
|
||||||
|
|
||||||
|
var deferred = DeferredBuilder.Deferred();
|
||||||
|
deferred.resolveWith(null, [path]);
|
||||||
|
return deferred.promise();
|
||||||
|
}
|
||||||
|
|
||||||
window.LocalAssetManager = {
|
window.LocalAssetManager = {
|
||||||
getLocalMediaSource: getLocalMediaSource,
|
getLocalMediaSource: getLocalMediaSource,
|
||||||
saveOfflineUser: saveOfflineUser,
|
saveOfflineUser: saveOfflineUser,
|
||||||
@ -118,7 +125,8 @@
|
|||||||
downloadSubtitles: downloadSubtitles,
|
downloadSubtitles: downloadSubtitles,
|
||||||
hasImage: hasImage,
|
hasImage: hasImage,
|
||||||
downloadImage: downloadImage,
|
downloadImage: downloadImage,
|
||||||
fileExists: fileExists
|
fileExists: fileExists,
|
||||||
|
translateFilePath: translateFilePath
|
||||||
};
|
};
|
||||||
|
|
||||||
})();
|
})();
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "paper-progress",
|
"name": "paper-progress",
|
||||||
"version": "1.0.4",
|
"version": "1.0.5",
|
||||||
"license": "http://polymer.github.io/LICENSE.txt",
|
"license": "http://polymer.github.io/LICENSE.txt",
|
||||||
"description": "A material design progress bar",
|
"description": "A material design progress bar",
|
||||||
"authors": "The Polymer Authors",
|
"authors": "The Polymer Authors",
|
||||||
@ -29,11 +29,11 @@
|
|||||||
"webcomponentsjs": "webcomponents/webcomponentsjs#^0.7.0"
|
"webcomponentsjs": "webcomponents/webcomponentsjs#^0.7.0"
|
||||||
},
|
},
|
||||||
"homepage": "https://github.com/PolymerElements/paper-progress",
|
"homepage": "https://github.com/PolymerElements/paper-progress",
|
||||||
"_release": "1.0.4",
|
"_release": "1.0.5",
|
||||||
"_resolution": {
|
"_resolution": {
|
||||||
"type": "version",
|
"type": "version",
|
||||||
"tag": "v1.0.4",
|
"tag": "v1.0.5",
|
||||||
"commit": "3bef91b5f9479b8b85c4725b441acf8fb433e008"
|
"commit": "baf8049bb33c3f9557d0d3608dc0824847ac34c4"
|
||||||
},
|
},
|
||||||
"_source": "git://github.com/PolymerElements/paper-progress.git",
|
"_source": "git://github.com/PolymerElements/paper-progress.git",
|
||||||
"_target": "^1.0.0",
|
"_target": "^1.0.0",
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "paper-progress",
|
"name": "paper-progress",
|
||||||
"version": "1.0.4",
|
"version": "1.0.5",
|
||||||
"license": "http://polymer.github.io/LICENSE.txt",
|
"license": "http://polymer.github.io/LICENSE.txt",
|
||||||
"description": "A material design progress bar",
|
"description": "A material design progress bar",
|
||||||
"authors": "The Polymer Authors",
|
"authors": "The Polymer Authors",
|
||||||
|
@ -108,7 +108,8 @@ Custom property | Description
|
|||||||
background-color: var(--paper-progress-container-color, --google-grey-300);
|
background-color: var(--paper-progress-container-color, --google-grey-300);
|
||||||
}
|
}
|
||||||
|
|
||||||
:host(.transiting) > * {
|
:host(.transiting) #primaryProgress,
|
||||||
|
:host(.transiting) #secondaryProgress {
|
||||||
-webkit-transition-property: -webkit-transform;
|
-webkit-transition-property: -webkit-transform;
|
||||||
transition-property: transform;
|
transition-property: transform;
|
||||||
|
|
||||||
|
@ -30,89 +30,116 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
|
|||||||
</template>
|
</template>
|
||||||
</test-fixture>
|
</test-fixture>
|
||||||
|
|
||||||
|
<test-fixture id="transitingProgress">
|
||||||
|
<template>
|
||||||
|
<paper-progress class="transiting"></paper-progress>
|
||||||
|
</template>
|
||||||
|
</test-fixture>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
suite('<paper-progress>', function() {
|
suite('basic features', function() {
|
||||||
var range;
|
var progress;
|
||||||
|
|
||||||
setup(function() {
|
setup(function() {
|
||||||
range = fixture('trivialProgress');
|
progress = fixture('trivialProgress');
|
||||||
});
|
});
|
||||||
|
|
||||||
test('check default', function() {
|
test('check default', function() {
|
||||||
assert.equal(range.min, 0);
|
assert.equal(progress.min, 0);
|
||||||
assert.equal(range.max, 100);
|
assert.equal(progress.max, 100);
|
||||||
assert.equal(range.value, 0);
|
assert.equal(progress.value, 0);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('set value', function(done) {
|
test('set value', function(done) {
|
||||||
range.value = 50;
|
progress.value = 50;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.value, 50);
|
assert.equal(progress.value, 50);
|
||||||
// test clamp value
|
// test clamp value
|
||||||
range.value = 60.1;
|
progress.value = 60.1;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.value, 60);
|
assert.equal(progress.value, 60);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('set max', function(done) {
|
test('set max', function(done) {
|
||||||
range.max = 10;
|
progress.max = 10;
|
||||||
range.value = 11;
|
progress.value = 11;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.value, range.max);
|
assert.equal(progress.value, progress.max);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('test ratio', function(done) {
|
test('test ratio', function(done) {
|
||||||
range.max = 10;
|
progress.max = 10;
|
||||||
range.value = 5;
|
progress.value = 5;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.ratio, 50);
|
assert.equal(progress.ratio, 50);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('test secondary ratio', function(done) {
|
test('test secondary ratio', function(done) {
|
||||||
range.max = 10;
|
progress.max = 10;
|
||||||
range.secondaryProgress = 5;
|
progress.secondaryProgress = 5;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.secondaryRatio, 50);
|
assert.equal(progress.secondaryRatio, 50);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('set min', function(done) {
|
test('set min', function(done) {
|
||||||
range.min = 10
|
progress.min = 10
|
||||||
range.max = 50;
|
progress.max = 50;
|
||||||
range.value = 30;
|
progress.value = 30;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.ratio, 50);
|
assert.equal(progress.ratio, 50);
|
||||||
range.value = 0;
|
progress.value = 0;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.value, range.min);
|
assert.equal(progress.value, progress.min);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test('set step', function(done) {
|
test('set step', function(done) {
|
||||||
range.min = 0;
|
progress.min = 0;
|
||||||
range.max = 10;
|
progress.max = 10;
|
||||||
range.value = 5.1;
|
progress.value = 5.1;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.value, 5);
|
assert.equal(progress.value, 5);
|
||||||
range.step = 0.1;
|
progress.step = 0.1;
|
||||||
range.value = 5.1;
|
progress.value = 5.1;
|
||||||
asyncPlatformFlush(function() {
|
asyncPlatformFlush(function() {
|
||||||
assert.equal(range.value, 5.1);
|
assert.equal(progress.value, 5.1);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
suite('transiting class', function() {
|
||||||
|
var progress;
|
||||||
|
|
||||||
|
setup(function() {
|
||||||
|
progress = fixture('transitingProgress');
|
||||||
|
});
|
||||||
|
|
||||||
|
test('progress bars', function() {
|
||||||
|
var stylesForPrimaryProgress = window.getComputedStyle(progress.$.primaryProgress);
|
||||||
|
var stylesForSecondaryProgress = window.getComputedStyle(progress.$.secondaryProgress);
|
||||||
|
var transitionProp = stylesForPrimaryProgress['transition-property'];
|
||||||
|
|
||||||
|
assert.isTrue(transitionProp === 'transform' || transitionProp === '-webkit-transform');
|
||||||
|
assert.equal(stylesForPrimaryProgress['transition-duration'], '0.08s');
|
||||||
|
|
||||||
|
transitionProp = stylesForSecondaryProgress['transition-property'];
|
||||||
|
|
||||||
|
assert.isTrue(transitionProp === 'transform' || transitionProp === '-webkit-transform');
|
||||||
|
assert.equal(stylesForSecondaryProgress['transition-duration'], '0.08s');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
@ -24,29 +24,13 @@
|
|||||||
${HeaderFilters}
|
${HeaderFilters}
|
||||||
</h1>
|
</h1>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
<div class="paperCheckboxList">
|
||||||
<input class="chkStandardFilter" type="checkbox" name="chkUnplayed" id="chkUnplayed" data-filter="IsUnPlayed" data-mini="true" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsPlayed">${OptionPlayed}</paper-checkbox>
|
||||||
<label for="chkUnplayed">${OptionUnplayed}</label>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsUnPlayed">${OptionUnplayed}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsResumable">${OptionResumable}</paper-checkbox>
|
||||||
|
<paper-checkbox class="chkStandardFilter" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
<div class="checkboxContainer">
|
<paper-checkbox class="chkStandardFilter" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
<input class="chkStandardFilter" type="checkbox" name="chkResumable" id="chkResumable" data-filter="IsResumable" data-mini="true" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
<label for="chkResumable">${OptionResumable}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" name="chkIsFavorite" id="chkIsFavorite" data-filter="IsFavorite" data-mini="true" data-role="none">
|
|
||||||
<label for="chkIsFavorite">${OptionFavorite}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" name="chkLikes" id="chkLikes" data-filter="Likes" data-mini="true" data-role="none">
|
|
||||||
<label for="chkLikes">${OptionLikes}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" name="chkDislikes" id="chkDislikes" data-filter="Dislikes" data-mini="true" data-role="none">
|
|
||||||
<label for="chkDislikes">${OptionDislikes}</label>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
85
dashboard-ui/cordova/localassetmanager.js
vendored
85
dashboard-ui/cordova/localassetmanager.js
vendored
@ -467,11 +467,13 @@
|
|||||||
|
|
||||||
getFileSystem().done(function (fileSystem) {
|
getFileSystem().done(function (fileSystem) {
|
||||||
|
|
||||||
fileSystem.root.getFile(fileName, { create: true }, function (targetFile) {
|
createDirectory(getParentDirectoryPath(localPath)).done(function () {
|
||||||
|
|
||||||
|
fileSystem.root.getFile(localPath, { create: true }, function (targetFile) {
|
||||||
|
|
||||||
var downloader = new BackgroundTransfer.BackgroundDownloader();
|
var downloader = new BackgroundTransfer.BackgroundDownloader();
|
||||||
// Create a new download operation.
|
// Create a new download operation.
|
||||||
var download = downloader.createDownload(url, targetFile.toURL());
|
var download = downloader.createDownload(url, targetFile);
|
||||||
// Start the download and persist the promise to be able to cancel the download.
|
// Start the download and persist the promise to be able to cancel the download.
|
||||||
var downloadPromise = download.startAsync().then(function () {
|
var downloadPromise = download.startAsync().then(function () {
|
||||||
|
|
||||||
@ -494,11 +496,66 @@
|
|||||||
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
|
||||||
|
}).fail(getOnFail(deferred));;
|
||||||
|
|
||||||
|
}).fail(getOnFail(deferred));
|
||||||
|
|
||||||
return deferred.promise();
|
return deferred.promise();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function createDirectory(path) {
|
||||||
|
|
||||||
|
var deferred = DeferredBuilder.Deferred();
|
||||||
|
createDirectoryPart(path, 0, deferred);
|
||||||
|
return deferred.promise();
|
||||||
|
}
|
||||||
|
|
||||||
|
function createDirectoryPart(path, index, deferred) {
|
||||||
|
|
||||||
|
var parts = path.split('/');
|
||||||
|
if (index >= parts.length) {
|
||||||
|
deferred.resolve();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
parts.length = index + 1;
|
||||||
|
var pathToCreate = parts.join('/');
|
||||||
|
|
||||||
|
createDirectoryInternal(pathToCreate).done(function () {
|
||||||
|
|
||||||
|
createDirectoryPart(path, index + 1, deferred);
|
||||||
|
|
||||||
|
}).fail(getOnFail(deferred));
|
||||||
|
}
|
||||||
|
|
||||||
|
function createDirectoryInternal(path) {
|
||||||
|
|
||||||
|
Logger.log('creating directory: ' + path);
|
||||||
|
var deferred = DeferredBuilder.Deferred();
|
||||||
|
|
||||||
|
getFileSystem().done(function (fileSystem) {
|
||||||
|
|
||||||
|
fileSystem.root.getDirectory(path, { create: true, exclusive: false }, function (targetFile) {
|
||||||
|
|
||||||
|
Logger.log('createDirectory succeeded');
|
||||||
|
deferred.resolve();
|
||||||
|
|
||||||
|
}, function () {
|
||||||
|
|
||||||
|
Logger.log('createDirectory failed');
|
||||||
|
deferred.reject();
|
||||||
|
});
|
||||||
|
|
||||||
|
}).fail(getOnFail(deferred));
|
||||||
|
|
||||||
|
return deferred.promise();
|
||||||
|
}
|
||||||
|
|
||||||
|
function getParentDirectoryPath(path) {
|
||||||
|
return path.substring(0, path.lastIndexOf('/'));;
|
||||||
|
}
|
||||||
|
|
||||||
function downloadSubtitles(url, localItem, subtitleStream) {
|
function downloadSubtitles(url, localItem, subtitleStream) {
|
||||||
|
|
||||||
var path = item.LocalPath;
|
var path = item.LocalPath;
|
||||||
@ -593,7 +650,7 @@
|
|||||||
function getImageLocalPath(serverId, itemId, imageTag) {
|
function getImageLocalPath(serverId, itemId, imageTag) {
|
||||||
var deferred = DeferredBuilder.Deferred();
|
var deferred = DeferredBuilder.Deferred();
|
||||||
|
|
||||||
var path = "images/" + serverId + "-" + itemId + "/" + imageTag;
|
var path = "images/" + serverId + "/" + itemId + "/" + imageTag;
|
||||||
|
|
||||||
deferred.resolveWith(null, [path]);
|
deferred.resolveWith(null, [path]);
|
||||||
|
|
||||||
@ -640,6 +697,23 @@
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function translateFilePath(path) {
|
||||||
|
|
||||||
|
var deferred = DeferredBuilder.Deferred();
|
||||||
|
|
||||||
|
resolveFile(path, function (fileEntry) {
|
||||||
|
Logger.log('translateFilePath fileExists: true - path: ' + path);
|
||||||
|
Logger.log('translateFilePath resolving with: ' + fileEntry.toURL());
|
||||||
|
deferred.resolveWith(null, [fileEntry.toURL()]);
|
||||||
|
|
||||||
|
}, function () {
|
||||||
|
Logger.log('translateFilePath fileExists: false - path: ' + path);
|
||||||
|
deferred.resolveWith(null, [path]);
|
||||||
|
});
|
||||||
|
|
||||||
|
return deferred.promise();
|
||||||
|
}
|
||||||
|
|
||||||
window.LocalAssetManager = {
|
window.LocalAssetManager = {
|
||||||
getLocalMediaSource: getLocalMediaSource,
|
getLocalMediaSource: getLocalMediaSource,
|
||||||
saveOfflineUser: saveOfflineUser,
|
saveOfflineUser: saveOfflineUser,
|
||||||
@ -656,7 +730,8 @@
|
|||||||
downloadSubtitles: downloadSubtitles,
|
downloadSubtitles: downloadSubtitles,
|
||||||
hasImage: hasImage,
|
hasImage: hasImage,
|
||||||
downloadImage: downloadImage,
|
downloadImage: downloadImage,
|
||||||
fileExists: fileExists
|
fileExists: fileExists,
|
||||||
|
translateFilePath: translateFilePath
|
||||||
};
|
};
|
||||||
|
|
||||||
})();
|
})();
|
@ -1036,7 +1036,7 @@ span.itemCommunityRating:not(:empty) + .userDataIcons {
|
|||||||
.syncIndicator {
|
.syncIndicator {
|
||||||
display: block;
|
display: block;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 32px;
|
top: 5px;
|
||||||
right: 5px;
|
right: 5px;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
@ -1044,15 +1044,12 @@ span.itemCommunityRating:not(:empty) + .userDataIcons {
|
|||||||
height: 24px;
|
height: 24px;
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
background: rgba(0, 0, 0, .8);
|
|
||||||
line-height: 19px;
|
line-height: 19px;
|
||||||
|
background-color: #38c;
|
||||||
}
|
}
|
||||||
|
|
||||||
.workingSyncIndicator iron-icon {
|
.playedIndicator + .syncIndicator {
|
||||||
-webkit-animation: spin 3s infinite linear;
|
top: 32px;
|
||||||
-moz-animation: spin 3s infinite linear;
|
|
||||||
-o-animation: spin 3s infinite linear;
|
|
||||||
-ms-animation: spin 3s infinite linear;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.playedIndicator {
|
.playedIndicator {
|
||||||
|
@ -26,34 +26,13 @@
|
|||||||
${HeaderFilters}
|
${HeaderFilters}
|
||||||
</h1>
|
</h1>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
<div class="paperCheckboxList">
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkPlayed" data-filter="IsPlayed" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsPlayed">${OptionPlayed}</paper-checkbox>
|
||||||
<label for="chkPlayed">${OptionPlayed}</label>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsUnPlayed">${OptionUnplayed}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsResumable">${OptionResumable}</paper-checkbox>
|
||||||
|
<paper-checkbox class="chkStandardFilter" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
<div class="checkboxContainer">
|
<paper-checkbox class="chkStandardFilter" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkUnplayed" data-filter="IsUnPlayed" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
<label for="chkUnplayed">${OptionUnplayed}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkResumable" data-filter="IsResumable" data-role="none">
|
|
||||||
<label for="chkResumable">${OptionResumable}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkIsFavorite" data-filter="IsFavorite" data-role="none">
|
|
||||||
<label for="chkIsFavorite">${OptionFavorite}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkLikes" data-filter="Likes" data-role="none">
|
|
||||||
<label for="chkLikes">${OptionLikes}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkDislikes" data-filter="Dislikes" data-role="none">
|
|
||||||
<label for="chkDislikes">${OptionDislikes}</label>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
@ -138,17 +138,10 @@
|
|||||||
<form>
|
<form>
|
||||||
<div>
|
<div>
|
||||||
<h1>${HeaderFilters}</h1>
|
<h1>${HeaderFilters}</h1>
|
||||||
<div class="checkboxContainer">
|
<div class="paperCheckboxList">
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkLikes" data-filter="Likes" data-mini="true" data-role="none">
|
<paper-checkbox class="chkStandardFilter chkFavorite" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
<label for="chkLikes">${OptionLikes}</label>
|
<paper-checkbox class="chkStandardFilter chkLikes" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter chkDislikes" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkDislikes" data-filter="Dislikes" data-mini="true" data-role="none">
|
|
||||||
<label for="chkDislikes">${OptionDislikes}</label>
|
|
||||||
</div>
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkFavorite" data-filter="IsFavorite" data-mini="true" data-role="none">
|
|
||||||
<label for="chkFavorite">${OptionFavorite}</label>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
@ -147,35 +147,13 @@
|
|||||||
<h1>
|
<h1>
|
||||||
${HeaderFilters}
|
${HeaderFilters}
|
||||||
</h1>
|
</h1>
|
||||||
|
<div class="paperCheckboxList">
|
||||||
<div class="checkboxContainer">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsPlayed">${OptionPlayed}</paper-checkbox>
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkPlayedMovie" data-filter="IsPlayed" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsUnPlayed">${OptionUnplayed}</paper-checkbox>
|
||||||
<label for="chkPlayedMovie">${OptionPlayed}</label>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsResumable">${OptionResumable}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
|
<paper-checkbox class="chkStandardFilter" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
<div class="checkboxContainer">
|
<paper-checkbox class="chkStandardFilter" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkUnplayedMovie" data-filter="IsUnPlayed" data-role="none">
|
|
||||||
<label for="chkUnplayedMovie">${OptionUnplayed}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkResumableMovie" data-filter="IsResumable" data-role="none">
|
|
||||||
<label for="chkResumableMovie">${OptionResumable}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkIsFavoriteMovie" data-filter="IsFavorite" data-role="none">
|
|
||||||
<label for="chkIsFavoriteMovie">${OptionFavorite}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkLikesMovie" data-filter="Likes" data-role="none">
|
|
||||||
<label for="chkLikesMovie">${OptionLikes}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkDislikesMovie" data-filter="Dislikes" data-role="none">
|
|
||||||
<label for="chkDislikesMovie">${OptionDislikes}</label>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<br />
|
<br />
|
||||||
@ -256,34 +234,13 @@
|
|||||||
<h1>
|
<h1>
|
||||||
${HeaderFilters}
|
${HeaderFilters}
|
||||||
</h1>
|
</h1>
|
||||||
<div class="checkboxContainer">
|
<div class="paperCheckboxList">
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkPlayedTrailer" data-filter="IsPlayed" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsPlayed">${OptionPlayed}</paper-checkbox>
|
||||||
<label for="chkPlayedTrailer">${OptionPlayed}</label>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsUnPlayed">${OptionUnplayed}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsResumable">${OptionResumable}</paper-checkbox>
|
||||||
|
<paper-checkbox class="chkStandardFilter" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
<div class="checkboxContainer">
|
<paper-checkbox class="chkStandardFilter" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkUnplayedTrailer" data-filter="IsUnPlayed" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
<label for="chkUnplayedTrailer">${OptionUnplayed}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkResumableTrailer" data-filter="IsResumable" data-role="none">
|
|
||||||
<label for="chkResumableTrailer">${OptionResumable}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkIsFavoriteTrailer" data-filter="IsFavorite" data-role="none">
|
|
||||||
<label for="chkIsFavoriteTrailer">${OptionFavorite}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkLikesTrailer" data-filter="Likes" data-role="none">
|
|
||||||
<label for="chkLikesTrailer">${OptionLikes}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkDislikesTrailer" data-filter="Dislikes" data-role="none">
|
|
||||||
<label for="chkDislikesTrailer">${OptionDislikes}</label>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -143,19 +143,10 @@
|
|||||||
<div>
|
<div>
|
||||||
<h1>${HeaderFilters}</h1>
|
<h1>${HeaderFilters}</h1>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
<div class="paperCheckboxList">
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkIsFavoriteAlbums" data-filter="IsFavorite" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
<label for="chkIsFavoriteAlbums">${OptionFavorite}</label>
|
<paper-checkbox class="chkStandardFilter" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkLikesAlbums" data-filter="Likes" data-role="none">
|
|
||||||
<label for="chkLikesAlbums">${OptionLikes}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkDislikesAlbums" data-filter="Dislikes" data-role="none">
|
|
||||||
<label for="chkDislikesAlbums">${OptionDislikes}</label>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<br />
|
<br />
|
||||||
@ -199,19 +190,10 @@
|
|||||||
<div>
|
<div>
|
||||||
<h1>${HeaderFilters}</h1>
|
<h1>${HeaderFilters}</h1>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
<div class="paperCheckboxList">
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkIsFavoriteArtist" data-filter="IsFavorite" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
<label for="chkIsFavoriteArtist">${OptionFavorite}</label>
|
<paper-checkbox class="chkStandardFilter" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkLikesArtist" data-filter="Likes" data-role="none">
|
|
||||||
<label for="chkLikesArtist">${OptionLikes}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkDislikesArtist" data-filter="Dislikes" data-role="none">
|
|
||||||
<label for="chkDislikesArtist">${OptionDislikes}</label>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<br />
|
<br />
|
||||||
@ -234,19 +216,10 @@
|
|||||||
<div>
|
<div>
|
||||||
<h1>${HeaderFilters}</h1>
|
<h1>${HeaderFilters}</h1>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
<div class="paperCheckboxList">
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkIsFavoriteAlbumArtist" data-filter="IsFavorite" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
<label for="chkIsFavoriteAlbumArtist">${OptionFavorite}</label>
|
<paper-checkbox class="chkStandardFilter" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkLikesAlbumArtist" data-filter="Likes" data-role="none">
|
|
||||||
<label for="chkLikesAlbumArtist">${OptionLikes}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkDislikesAlbumArtist" data-filter="Dislikes" data-role="none">
|
|
||||||
<label for="chkDislikesAlbumArtist">${OptionDislikes}</label>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
@ -270,29 +243,12 @@
|
|||||||
<div>
|
<div>
|
||||||
<h1>${HeaderFilters}</h1>
|
<h1>${HeaderFilters}</h1>
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
<div class="paperCheckboxList">
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkPlayedSongs" data-filter="IsPlayed" data-mini="true" data-role="none">
|
<paper-checkbox class="chkStandardFilter" data-filter="IsPlayed">${OptionPlayed}</paper-checkbox>
|
||||||
<label for="chkPlayedSongs">${OptionPlayed}</label>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsUnPlayed">${OptionUnplayed}</paper-checkbox>
|
||||||
</div>
|
<paper-checkbox class="chkStandardFilter" data-filter="IsFavorite">${OptionFavorite}</paper-checkbox>
|
||||||
|
<paper-checkbox class="chkStandardFilter" data-filter="Likes">${OptionLikes}</paper-checkbox>
|
||||||
<div class="checkboxContainer">
|
<paper-checkbox class="chkStandardFilter" data-filter="Dislikes">${OptionDislikes}</paper-checkbox>
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkUnplayedSongs" data-filter="IsUnPlayed" data-mini="true" data-role="none">
|
|
||||||
<label for="chkUnplayedSongs">${OptionUnplayed}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkIsFavoriteSongs" data-filter="IsFavorite" data-mini="true" data-role="none">
|
|
||||||
<label for="chkIsFavoriteSongs">${OptionFavorite}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkLikesSongs" data-filter="Likes" data-mini="true" data-role="none">
|
|
||||||
<label for="chkLikesSongs">${OptionLikes}</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="checkboxContainer">
|
|
||||||
<input class="chkStandardFilter" type="checkbox" id="chkDislikesSongs" data-filter="Dislikes" data-mini="true" data-role="none">
|
|
||||||
<label for="chkDislikesSongs">${OptionDislikes}</label>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
@ -137,7 +137,8 @@
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
var streamInfo = MediaPlayer.createStreamInfo('Video', item, mediaSource, startPosition);
|
MediaPlayer.createStreamInfo('Video', item, mediaSource, startPosition).done(function (streamInfo) {
|
||||||
|
|
||||||
var currentSrc = streamInfo.url;
|
var currentSrc = streamInfo.url;
|
||||||
|
|
||||||
var audioStreamIndex = getParameterByName('AudioStreamIndex', currentSrc);
|
var audioStreamIndex = getParameterByName('AudioStreamIndex', currentSrc);
|
||||||
@ -159,6 +160,7 @@
|
|||||||
basePlayerState.NowPlayingItem = MediaPlayer.getNowPlayingItemForReporting(item, mediaSource);
|
basePlayerState.NowPlayingItem = MediaPlayer.getNowPlayingItemForReporting(item, mediaSource);
|
||||||
|
|
||||||
deferred.resolveWith(null, [streamInfo]);
|
deferred.resolveWith(null, [streamInfo]);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function getPlayerState(positionTicks) {
|
function getPlayerState(positionTicks) {
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
function hideStatusBar() {
|
function hideStatusBar() {
|
||||||
if (options.type == 'video' && window.StatusBar) {
|
if (options.type == 'video' && window.StatusBar) {
|
||||||
StatusBar.backgroundColorByName("black");
|
StatusBar.backgroundColorByName("black");
|
||||||
StatusBar.overlaysWebView(true);
|
//StatusBar.overlaysWebView(true);
|
||||||
StatusBar.hide();
|
StatusBar.hide();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -20,7 +20,7 @@
|
|||||||
function showStatusBar() {
|
function showStatusBar() {
|
||||||
if (options.type == 'video' && window.StatusBar) {
|
if (options.type == 'video' && window.StatusBar) {
|
||||||
StatusBar.show();
|
StatusBar.show();
|
||||||
StatusBar.overlaysWebView(false);
|
//StatusBar.overlaysWebView(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -355,6 +355,11 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
var val = streamInfo.url;
|
var val = streamInfo.url;
|
||||||
|
|
||||||
|
if (AppInfo.isNativeApp && $.browser.safari) {
|
||||||
|
val = val.replace('file://', '');
|
||||||
|
}
|
||||||
|
|
||||||
requiresSettingStartTimeOnStart = false;
|
requiresSettingStartTimeOnStart = false;
|
||||||
var startTime = getStartTime(val);
|
var startTime = getStartTime(val);
|
||||||
var playNow = false;
|
var playNow = false;
|
||||||
|
@ -270,9 +270,26 @@
|
|||||||
}, delay);
|
}, delay);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function fadeOutLeftBig(elem, iterations) {
|
||||||
|
var keyframes = [{ opacity: '1', transform: 'none', offset: 0 },
|
||||||
|
{ opacity: '0', transform: 'translate3d(-2000px, 0, 0)', offset: 1 }];
|
||||||
|
var timing = { duration: 700, iterations: iterations };
|
||||||
|
return elem.animate(keyframes, timing);
|
||||||
|
}
|
||||||
|
|
||||||
if (!LibraryBrowser.navigateOnLibraryTabSelect()) {
|
if (!LibraryBrowser.navigateOnLibraryTabSelect()) {
|
||||||
tabs.addEventListener('iron-select', function () {
|
tabs.addEventListener('iron-select', function () {
|
||||||
|
|
||||||
|
var selected = pages.selected;
|
||||||
|
if (selected != null) {
|
||||||
|
var newValue = this.selected;
|
||||||
|
fadeOutLeftBig(pages.querySelectorAll('.pageTabContent')[selected], 1).onfinish = function () {
|
||||||
|
pages.selected = newValue;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
else {
|
||||||
pages.selected = this.selected;
|
pages.selected = this.selected;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -2362,12 +2379,12 @@
|
|||||||
|
|
||||||
var syncPercent = item.SyncPercent;
|
var syncPercent = item.SyncPercent;
|
||||||
if (syncPercent) {
|
if (syncPercent) {
|
||||||
return '<div class="workingSyncIndicator syncIndicator"><iron-icon icon="sync"></iron-icon></div>';
|
return '<div class="syncIndicator"><iron-icon icon="sync"></iron-icon></div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (item.SyncStatus == 'Queued' || item.SyncStatus == 'Converting' || item.SyncStatus == 'ReadyToTransfer' || item.SyncStatus == 'Transferring') {
|
if (item.SyncStatus == 'Queued' || item.SyncStatus == 'Converting' || item.SyncStatus == 'ReadyToTransfer' || item.SyncStatus == 'Transferring') {
|
||||||
|
|
||||||
return '<div class="workingSyncIndicator syncIndicator"><iron-icon icon="sync"></iron-icon></div>';
|
return '<div class="syncIndicator"><iron-icon icon="sync"></iron-icon></div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
return '';
|
return '';
|
||||||
|
@ -617,6 +617,13 @@
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var url = 'itemdetails.html?id=' + itemId;
|
||||||
|
if (context) {
|
||||||
|
url += '&context=' + context;
|
||||||
|
}
|
||||||
|
Dashboard.navigate(url);
|
||||||
|
return;
|
||||||
|
|
||||||
var ids = items.map(function (i) {
|
var ids = items.map(function (i) {
|
||||||
return i.Id;
|
return i.Id;
|
||||||
});
|
});
|
||||||
|
@ -121,7 +121,7 @@
|
|||||||
var mainDrawerButton = document.querySelector('.mainDrawerButton');
|
var mainDrawerButton = document.querySelector('.mainDrawerButton');
|
||||||
|
|
||||||
if (mainDrawerButton) {
|
if (mainDrawerButton) {
|
||||||
if (AppInfo.isTouchPreferred) {
|
if (AppInfo.isTouchPreferred || $.browser.mobile) {
|
||||||
|
|
||||||
Events.on(mainDrawerButton, 'click', openMainDrawer);
|
Events.on(mainDrawerButton, 'click', openMainDrawer);
|
||||||
|
|
||||||
@ -178,10 +178,14 @@
|
|||||||
document.body.classList.add('bodyWithPopupOpen');
|
document.body.classList.add('bodyWithPopupOpen');
|
||||||
}
|
}
|
||||||
|
|
||||||
var drawer = document.querySelector('.mainDrawerPanel .mainDrawer');
|
var pageElem = $($.mobile.activePage)[0];
|
||||||
|
|
||||||
|
if (requiresDrawerRefresh || requiresDashboardDrawerRefresh) {
|
||||||
|
|
||||||
ConnectionManager.user(window.ApiClient).done(function (user) {
|
ConnectionManager.user(window.ApiClient).done(function (user) {
|
||||||
|
|
||||||
|
var drawer = document.querySelector('.mainDrawerPanel .mainDrawer');
|
||||||
|
|
||||||
if (requiresDrawerRefresh) {
|
if (requiresDrawerRefresh) {
|
||||||
ensureDrawerStructure(drawer);
|
ensureDrawerStructure(drawer);
|
||||||
|
|
||||||
@ -193,17 +197,16 @@
|
|||||||
updateLibraryMenu(user.localUser);
|
updateLibraryMenu(user.localUser);
|
||||||
}
|
}
|
||||||
|
|
||||||
var pageElem = $($.mobile.activePage)[0];
|
|
||||||
|
|
||||||
if (requiresDrawerRefresh || requiresDashboardDrawerRefresh) {
|
if (requiresDrawerRefresh || requiresDashboardDrawerRefresh) {
|
||||||
refreshDashboardInfoInDrawer(pageElem, user, drawer);
|
refreshDashboardInfoInDrawer(pageElem, user, drawer);
|
||||||
requiresDashboardDrawerRefresh = false;
|
requiresDashboardDrawerRefresh = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
requiresDrawerRefresh = false;
|
requiresDrawerRefresh = false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
updateLibraryNavLinks(pageElem);
|
updateLibraryNavLinks(pageElem);
|
||||||
});
|
|
||||||
|
|
||||||
document.querySelector('.mainDrawerPanel #drawer').classList.add('verticalScrollingDrawer');
|
document.querySelector('.mainDrawerPanel #drawer').classList.add('verticalScrollingDrawer');
|
||||||
}
|
}
|
||||||
@ -714,12 +717,20 @@
|
|||||||
lnkMediaFolder.classList.remove('selectedMediaFolder');
|
lnkMediaFolder.classList.remove('selectedMediaFolder');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateTabLinks(page) {
|
||||||
var context = getParameterByName('context');
|
var context = getParameterByName('context');
|
||||||
|
|
||||||
if (context !== 'playlists') {
|
var elems = page.querySelectorAll('.scopedLibraryViewNav a');
|
||||||
|
|
||||||
elems = page.querySelectorAll('.scopedLibraryViewNav a');
|
var id = page.classList.contains('liveTvPage') || page.classList.contains('channelsPage') || page.classList.contains('metadataEditorPage') || page.classList.contains('reportsPage') || page.classList.contains('mySyncPage') || page.classList.contains('allLibraryPage') ?
|
||||||
|
'' :
|
||||||
|
getTopParentId() || '';
|
||||||
|
|
||||||
|
if (!id) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0, length = elems.length; i < length; i++) {
|
for (i = 0, length = elems.length; i < length; i++) {
|
||||||
|
|
||||||
@ -735,7 +746,6 @@
|
|||||||
lnk.href = src;
|
lnk.href = src;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
function onWebSocketMessage(e, data) {
|
function onWebSocketMessage(e, data) {
|
||||||
|
|
||||||
@ -792,7 +802,9 @@
|
|||||||
|
|
||||||
var page = this;
|
var page = this;
|
||||||
|
|
||||||
|
if (page.classList.contains('type-interior')) {
|
||||||
requiresDashboardDrawerRefresh = true;
|
requiresDashboardDrawerRefresh = true;
|
||||||
|
}
|
||||||
|
|
||||||
onPageBeforeShowDocumentReady(page);
|
onPageBeforeShowDocumentReady(page);
|
||||||
|
|
||||||
@ -861,7 +873,12 @@
|
|||||||
if (AppInfo.enableBottomTabs) {
|
if (AppInfo.enableBottomTabs) {
|
||||||
page.classList.add('noSecondaryNavPage');
|
page.classList.add('noSecondaryNavPage');
|
||||||
|
|
||||||
|
if (page.classList.contains('pageWithAbsoluteTabs')) {
|
||||||
document.querySelector('.footer').classList.add('footerOverBottomTabs');
|
document.querySelector('.footer').classList.add('footerOverBottomTabs');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
document.querySelector('.footer').classList.remove('footerOverBottomTabs');
|
||||||
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
@ -927,6 +944,7 @@
|
|||||||
// Scroll back up so in case vertical scroll was messed with
|
// Scroll back up so in case vertical scroll was messed with
|
||||||
window.scrollTo(0, 0);
|
window.scrollTo(0, 0);
|
||||||
}
|
}
|
||||||
|
updateTabLinks(page);
|
||||||
}
|
}
|
||||||
|
|
||||||
function initHeadRoom(elem) {
|
function initHeadRoom(elem) {
|
||||||
|
@ -96,16 +96,16 @@
|
|||||||
function updateFilterControls(page) {
|
function updateFilterControls(page) {
|
||||||
|
|
||||||
var query = getQuery();
|
var query = getQuery();
|
||||||
$('#chkFavorite', page).checked(query.IsFavorite == true);
|
$('.chkFavorite', page).checked(query.IsFavorite == true);
|
||||||
$('#chkLikes', page).checked(query.IsLiked == true);
|
$('.chkLikes', page).checked(query.IsLiked == true);
|
||||||
$('#chkDislikes', page).checked(query.IsDisliked == true);
|
$('.chkDislikes', page).checked(query.IsDisliked == true);
|
||||||
}
|
}
|
||||||
|
|
||||||
window.LiveTvPage.initChannelsTab = function (page, tabContent) {
|
window.LiveTvPage.initChannelsTab = function (page, tabContent) {
|
||||||
|
|
||||||
var viewPanel = page.querySelector('.channelViewPanel');
|
var viewPanel = page.querySelector('.channelViewPanel');
|
||||||
|
|
||||||
$('#chkFavorite', viewPanel).on('change', function () {
|
$('.chkFavorite', viewPanel).on('change', function () {
|
||||||
|
|
||||||
var query = getQuery();
|
var query = getQuery();
|
||||||
query.StartIndex = 0;
|
query.StartIndex = 0;
|
||||||
@ -115,7 +115,7 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
$('#chkLikes', viewPanel).on('change', function () {
|
$('.chkLikes', viewPanel).on('change', function () {
|
||||||
|
|
||||||
var query = getQuery();
|
var query = getQuery();
|
||||||
query.StartIndex = 0;
|
query.StartIndex = 0;
|
||||||
@ -124,7 +124,7 @@
|
|||||||
reloadItems(tabContent, viewPanel);
|
reloadItems(tabContent, viewPanel);
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#chkDislikes', viewPanel).on('change', function () {
|
$('.chkDislikes', viewPanel).on('change', function () {
|
||||||
|
|
||||||
var query = getQuery();
|
var query = getQuery();
|
||||||
query.StartIndex = 0;
|
query.StartIndex = 0;
|
||||||
|
@ -891,7 +891,7 @@
|
|||||||
|
|
||||||
requirejs(['videorenderer'], function () {
|
requirejs(['videorenderer'], function () {
|
||||||
|
|
||||||
var streamInfo = self.createStreamInfo('Video', item, mediaSource, startPosition);
|
self.createStreamInfo('Video', item, mediaSource, startPosition).done(function (streamInfo) {
|
||||||
|
|
||||||
// Huge hack alert. Safari doesn't seem to like if the segments aren't available right away when playback starts
|
// Huge hack alert. Safari doesn't seem to like if the segments aren't available right away when playback starts
|
||||||
// This will start the transcoding process before actually feeding the video url into the player
|
// This will start the transcoding process before actually feeding the video url into the player
|
||||||
@ -914,6 +914,7 @@
|
|||||||
self.playVideoInternal(item, mediaSource, startPosition, streamInfo, callback);
|
self.playVideoInternal(item, mediaSource, startPosition, streamInfo, callback);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
self.playVideoInternal = function (item, mediaSource, startPosition, streamInfo, callback) {
|
self.playVideoInternal = function (item, mediaSource, startPosition, streamInfo, callback) {
|
||||||
|
@ -291,8 +291,6 @@
|
|||||||
|
|
||||||
profile.ContainerProfiles = [];
|
profile.ContainerProfiles = [];
|
||||||
|
|
||||||
var maxAudioChannels = isVlc ? '6' : '2';
|
|
||||||
|
|
||||||
profile.CodecProfiles = [];
|
profile.CodecProfiles = [];
|
||||||
profile.CodecProfiles.push({
|
profile.CodecProfiles.push({
|
||||||
Type: 'Audio',
|
Type: 'Audio',
|
||||||
@ -303,16 +301,6 @@
|
|||||||
}]
|
}]
|
||||||
});
|
});
|
||||||
|
|
||||||
profile.CodecProfiles.push({
|
|
||||||
Type: 'VideoAudio',
|
|
||||||
Codec: 'mp3',
|
|
||||||
Conditions: [{
|
|
||||||
Condition: 'LessThanEqual',
|
|
||||||
Property: 'AudioChannels',
|
|
||||||
Value: maxAudioChannels
|
|
||||||
}]
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!isVlc) {
|
if (!isVlc) {
|
||||||
profile.CodecProfiles.push({
|
profile.CodecProfiles.push({
|
||||||
Type: 'VideoAudio',
|
Type: 'VideoAudio',
|
||||||
@ -340,7 +328,7 @@
|
|||||||
{
|
{
|
||||||
Condition: 'LessThanEqual',
|
Condition: 'LessThanEqual',
|
||||||
Property: 'AudioChannels',
|
Property: 'AudioChannels',
|
||||||
Value: maxAudioChannels
|
Value: '6'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
@ -641,17 +629,18 @@
|
|||||||
if (validatePlaybackInfoResult(result)) {
|
if (validatePlaybackInfoResult(result)) {
|
||||||
|
|
||||||
self.currentMediaSource = result.MediaSources[0];
|
self.currentMediaSource = result.MediaSources[0];
|
||||||
var streamInfo = self.createStreamInfo(self.currentItem.MediaType, self.currentItem, self.currentMediaSource, ticks);
|
self.createStreamInfo(self.currentItem.MediaType, self.currentItem, self.currentMediaSource, ticks).done(function (streamInfo) {
|
||||||
|
|
||||||
if (!streamInfo.url) {
|
if (!streamInfo.url) {
|
||||||
MediaController.showPlaybackInfoErrorMessage('NoCompatibleStream');
|
MediaController.showPlaybackInfoErrorMessage('NoCompatibleStream');
|
||||||
self.stop();
|
self.stop();
|
||||||
return false;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
self.currentSubtitleStreamIndex = subtitleStreamIndex;
|
self.currentSubtitleStreamIndex = subtitleStreamIndex;
|
||||||
|
|
||||||
changeStreamToUrl(mediaRenderer, playSessionId, streamInfo, streamInfo.startTimeTicksOffset || 0);
|
changeStreamToUrl(mediaRenderer, playSessionId, streamInfo, streamInfo.startTimeTicksOffset || 0);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@ -915,6 +904,8 @@
|
|||||||
|
|
||||||
self.createStreamInfo = function (type, item, mediaSource, startPosition) {
|
self.createStreamInfo = function (type, item, mediaSource, startPosition) {
|
||||||
|
|
||||||
|
var deferred = $.Deferred();
|
||||||
|
|
||||||
var mediaUrl;
|
var mediaUrl;
|
||||||
var contentType;
|
var contentType;
|
||||||
var startTimeTicksOffset = 0;
|
var startTimeTicksOffset = 0;
|
||||||
@ -1018,13 +1009,32 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
var resultInfo = {
|
||||||
url: mediaUrl,
|
url: mediaUrl,
|
||||||
mimeType: contentType,
|
mimeType: contentType,
|
||||||
startTimeTicksOffset: startTimeTicksOffset,
|
startTimeTicksOffset: startTimeTicksOffset,
|
||||||
startPositionInSeekParam: startPositionInSeekParam,
|
startPositionInSeekParam: startPositionInSeekParam,
|
||||||
playMethod: playMethod
|
playMethod: playMethod
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (playMethod == 'DirectPlay' && mediaSource.Protocol == 'File') {
|
||||||
|
|
||||||
|
require(['localassetmanager'], function () {
|
||||||
|
|
||||||
|
LocalAssetManager.translateFilePath(resultInfo.url).done(function (path) {
|
||||||
|
|
||||||
|
resultInfo.url = path;
|
||||||
|
Logger.log('LocalAssetManager.translateFilePath: path: ' + resultInfo.url + ' result: ' + path);
|
||||||
|
deferred.resolveWith(null, [resultInfo]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
deferred.resolveWith(null, [resultInfo]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return deferred.promise();
|
||||||
};
|
};
|
||||||
|
|
||||||
self.lastBitrateDetect = 0;
|
self.lastBitrateDetect = 0;
|
||||||
@ -1872,7 +1882,8 @@
|
|||||||
|
|
||||||
function playAudioInternal(item, mediaSource, startPositionTicks) {
|
function playAudioInternal(item, mediaSource, startPositionTicks) {
|
||||||
|
|
||||||
var streamInfo = self.createStreamInfo('Audio', item, mediaSource, startPositionTicks);
|
self.createStreamInfo('Audio', item, mediaSource, startPositionTicks).done(function (streamInfo) {
|
||||||
|
|
||||||
var audioUrl = streamInfo.url;
|
var audioUrl = streamInfo.url;
|
||||||
self.startTimeTicksOffset = streamInfo.startTimeTicksOffset;
|
self.startTimeTicksOffset = streamInfo.startTimeTicksOffset;
|
||||||
|
|
||||||
@ -1932,6 +1943,7 @@
|
|||||||
mediaRenderer.setCurrentSrc(streamInfo, item, mediaSource);
|
mediaRenderer.setCurrentSrc(streamInfo, item, mediaSource);
|
||||||
self.streamInfo = streamInfo;
|
self.streamInfo = streamInfo;
|
||||||
});
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
var getItemFields = "MediaSources,Chapters";
|
var getItemFields = "MediaSources,Chapters";
|
||||||
|
@ -22,6 +22,39 @@
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getSyncStatusBanner(job) {
|
||||||
|
|
||||||
|
var opacity = '.85';
|
||||||
|
var background = 'rgba(204,51,51,' + opacity + ')';
|
||||||
|
var text = Globalize.translate('SyncJobStatus' + job.Status);
|
||||||
|
|
||||||
|
if (job.Status == 'Completed') {
|
||||||
|
background = 'rgba(82, 181, 75, ' + opacity + ')';
|
||||||
|
}
|
||||||
|
else if (job.Status == 'CompletedWithError') {
|
||||||
|
|
||||||
|
}
|
||||||
|
else if (job.Status == 'Queued') {
|
||||||
|
background = 'rgba(51, 136, 204, ' + opacity + ')';
|
||||||
|
}
|
||||||
|
else if (job.Status == 'ReadyToTransfer') {
|
||||||
|
background = 'rgba(51, 136, 204, ' + opacity + ')';
|
||||||
|
}
|
||||||
|
else if (job.Status == 'Transferring') {
|
||||||
|
background = 'rgba(72, 0, 255, ' + opacity + ')';
|
||||||
|
}
|
||||||
|
else if (job.Status == 'Converting') {
|
||||||
|
background = 'rgba(255, 106, 0, ' + opacity + ')';
|
||||||
|
}
|
||||||
|
|
||||||
|
var html = '';
|
||||||
|
html += '<div class="syncStatusBanner" data-status="' + job.Status + '" style="background-color:' + background + ';position:absolute;top:0;right:0;padding:.5em .5em; text-align:left;color: #fff; font-weight: 500; text-transform:uppercase; border-bottom-left-radius: 3px;">';
|
||||||
|
html += text;
|
||||||
|
html += '</div>';
|
||||||
|
|
||||||
|
return html;
|
||||||
|
}
|
||||||
|
|
||||||
function getSyncJobHtml(page, job, cardBoxCssClass, syncJobPage) {
|
function getSyncJobHtml(page, job, cardBoxCssClass, syncJobPage) {
|
||||||
|
|
||||||
var html = '';
|
var html = '';
|
||||||
@ -54,42 +87,23 @@
|
|||||||
|
|
||||||
html += '<div class="cardImage coveredCardImage lazy" data-src="' + imgUrl + '" style="' + style + '">';
|
html += '<div class="cardImage coveredCardImage lazy" data-src="' + imgUrl + '" style="' + style + '">';
|
||||||
|
|
||||||
if (job.Progress && job.Progress < 100) {
|
var progress = job.Progress || 0;
|
||||||
html += '<div class="cardFooter fullCardFooter lightCardFooter">';
|
|
||||||
|
var footerClass = 'cardFooter fullCardFooter lightCardFooter';
|
||||||
|
|
||||||
|
if (progress == 0 || progress >= 100) {
|
||||||
|
footerClass += ' hide';
|
||||||
|
}
|
||||||
|
|
||||||
|
html += '<div class="' + footerClass + '">';
|
||||||
html += "<div class='cardText cardProgress'>";
|
html += "<div class='cardText cardProgress'>";
|
||||||
html += '<progress class="itemProgressBar" min="0" max="100" value="' + job.Progress + '"></progress>';
|
html += '<progress class="itemProgressBar" min="0" max="100" value="' + progress + '"></progress>';
|
||||||
html += "</div>";
|
html += "</div>";
|
||||||
html += "</div>";
|
html += "</div>";
|
||||||
}
|
|
||||||
|
|
||||||
html += "</div>";
|
html += "</div>";
|
||||||
|
|
||||||
var opacity = '.85';
|
html += getSyncStatusBanner(job);
|
||||||
var background = 'rgba(204,51,51,' + opacity + ')';
|
|
||||||
var text = Globalize.translate('SyncJobStatus' + job.Status);
|
|
||||||
|
|
||||||
if (job.Status == 'Completed') {
|
|
||||||
background = 'rgba(82, 181, 75, ' + opacity + ')';
|
|
||||||
}
|
|
||||||
else if (job.Status == 'CompletedWithError') {
|
|
||||||
|
|
||||||
}
|
|
||||||
else if (job.Status == 'Queued') {
|
|
||||||
background = 'rgba(51, 136, 204, ' + opacity + ')';
|
|
||||||
}
|
|
||||||
else if (job.Status == 'ReadyToTransfer') {
|
|
||||||
background = 'rgba(51, 136, 204, ' + opacity + ')';
|
|
||||||
}
|
|
||||||
else if (job.Status == 'Transferring') {
|
|
||||||
background = 'rgba(72, 0, 255, ' + opacity + ')';
|
|
||||||
}
|
|
||||||
else if (job.Status == 'Converting') {
|
|
||||||
background = 'rgba(255, 106, 0, ' + opacity + ')';
|
|
||||||
}
|
|
||||||
|
|
||||||
html += '<div class="syncStatusBanner" style="background-color:' + background + ';position:absolute;top:0;right:0;padding:.5em .5em; text-align:left;color: #fff; font-weight: 500; text-transform:uppercase; border-bottom-left-radius: 3px;">';
|
|
||||||
html += text;
|
|
||||||
html += '</div>';
|
|
||||||
|
|
||||||
// cardContent
|
// cardContent
|
||||||
html += "</a>";
|
html += "</a>";
|
||||||
@ -139,8 +153,17 @@
|
|||||||
return html;
|
return html;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var lastDataLoad = 0;
|
||||||
|
|
||||||
function loadData(page, jobs) {
|
function loadData(page, jobs) {
|
||||||
|
|
||||||
|
if ((new Date().getTime() - lastDataLoad) < 60000) {
|
||||||
|
refreshData(page, jobs);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
lastDataLoad = new Date().getTime();
|
||||||
|
|
||||||
var html = '';
|
var html = '';
|
||||||
var lastTargetName = '';
|
var lastTargetName = '';
|
||||||
|
|
||||||
@ -195,6 +218,46 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function refreshData(page, jobs) {
|
||||||
|
|
||||||
|
for (var i = 0, length = jobs.length; i < length; i++) {
|
||||||
|
|
||||||
|
var job = jobs[i];
|
||||||
|
refreshJob(page, job);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function refreshJob(page, job) {
|
||||||
|
|
||||||
|
var card = page.querySelector('.card[data-id=\'' + job.Id + '\']');
|
||||||
|
|
||||||
|
if (!card) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var banner = card.querySelector('.syncStatusBanner');
|
||||||
|
|
||||||
|
if (banner.getAttribute('data-status') == job.Status) {
|
||||||
|
var elem = document.createElement('div');
|
||||||
|
elem.innerHTML = getSyncStatusBanner(job);
|
||||||
|
elem = elem.querySelector('.syncStatusBanner');
|
||||||
|
elem.parentNode.removeChild(elem);
|
||||||
|
|
||||||
|
banner.parentNode.replaceChild(elem, banner);
|
||||||
|
}
|
||||||
|
|
||||||
|
var progress = job.Progress || 0;
|
||||||
|
var cardFooter = card.querySelector('.cardFooter');
|
||||||
|
|
||||||
|
if (progress == 0 || progress >= 100) {
|
||||||
|
cardFooter.classList.add('hide');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
cardFooter.classList.remove('hide');
|
||||||
|
cardFooter.querySelector('.itemProgressBar').value = progress;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function showJobMenu(page, elem) {
|
function showJobMenu(page, elem) {
|
||||||
|
|
||||||
var card = $(elem).parents('.card');
|
var card = $(elem).parents('.card');
|
||||||
@ -265,6 +328,9 @@
|
|||||||
|
|
||||||
loadData(page, response.Items);
|
loadData(page, response.Items);
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
loadData(page, response.Items);
|
||||||
|
}, 2000);
|
||||||
Dashboard.hideLoadingMsg();
|
Dashboard.hideLoadingMsg();
|
||||||
|
|
||||||
});
|
});
|
||||||
@ -314,6 +380,7 @@
|
|||||||
$(document).on('pageshowready', ".syncActivityPage", function () {
|
$(document).on('pageshowready', ".syncActivityPage", function () {
|
||||||
|
|
||||||
var page = this;
|
var page = this;
|
||||||
|
lastDataLoad = 0;
|
||||||
|
|
||||||
Dashboard.getPluginSecurityInfo().done(function (pluginSecurityInfo) {
|
Dashboard.getPluginSecurityInfo().done(function (pluginSecurityInfo) {
|
||||||
|
|
||||||
|
@ -85,6 +85,10 @@
|
|||||||
}
|
}
|
||||||
html += '</div>';
|
html += '</div>';
|
||||||
|
|
||||||
|
html += '<div secondary style="padding-top:5px;">';
|
||||||
|
html += '<paper-progress class="mini" style="width:100%;" value="' + (jobItem.Progress || 0) + '"></paper-progress>';
|
||||||
|
html += '</div>';
|
||||||
|
|
||||||
html += '</paper-item-body>';
|
html += '</paper-item-body>';
|
||||||
|
|
||||||
if (hasActions) {
|
if (hasActions) {
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.viewMenuBar.semiTransparent {
|
.viewMenuBar.semiTransparent {
|
||||||
background-color: rgba(28, 28, 28, .8);
|
background-color: rgba(28, 28, 28, .75);
|
||||||
}
|
}
|
||||||
|
|
||||||
.libraryViewNav a {
|
.libraryViewNav a {
|
||||||
@ -192,198 +192,3 @@ paper-tab {
|
|||||||
/* Eliminate transparency to prevent clicks from passing through to the elements underneath */
|
/* Eliminate transparency to prevent clicks from passing through to the elements underneath */
|
||||||
background-color: rgb(26,26,26);
|
background-color: rgb(26,26,26);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Checkboxes */
|
|
||||||
input[type='checkbox'] {
|
|
||||||
-webkit-box-sizing: border-box;
|
|
||||||
-moz-box-sizing: border-box;
|
|
||||||
box-sizing: border-box;
|
|
||||||
-webkit-appearance: none;
|
|
||||||
-moz-appearance: none;
|
|
||||||
-ms-appearance: none;
|
|
||||||
-o-appearance: none;
|
|
||||||
appearance: none;
|
|
||||||
-webkit-user-select: none;
|
|
||||||
-moz-user-select: none;
|
|
||||||
-ms-user-select: none;
|
|
||||||
user-select: none;
|
|
||||||
height: 31px;
|
|
||||||
width: 51px;
|
|
||||||
position: relative;
|
|
||||||
border-radius: 16px;
|
|
||||||
cursor: pointer;
|
|
||||||
outline: 0;
|
|
||||||
z-index: 0;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
border: none;
|
|
||||||
-webkit-transition-duration: 600ms;
|
|
||||||
-moz-transition-duration: 600ms;
|
|
||||||
transition-duration: 600ms;
|
|
||||||
-webkit-transition-timing-function: ease-in-out;
|
|
||||||
-moz-transition-timing-function: ease-in-out;
|
|
||||||
transition-timing-function: ease-in-out;
|
|
||||||
-webkit-touch-callout: none;
|
|
||||||
-webkit-text-size-adjust: none;
|
|
||||||
-webkit-tap-highlight-color: transparent;
|
|
||||||
-webkit-user-select: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-a input[type='checkbox'] {
|
|
||||||
background-color: #e5e5e5;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-b input[type='checkbox'] {
|
|
||||||
background-color: #1f1f1f;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']::before {
|
|
||||||
-webkit-box-sizing: border-box;
|
|
||||||
-moz-box-sizing: border-box;
|
|
||||||
box-sizing: border-box;
|
|
||||||
height: 27px;
|
|
||||||
width: 47px;
|
|
||||||
content: ' ';
|
|
||||||
position: absolute;
|
|
||||||
left: 2px;
|
|
||||||
top: 2px;
|
|
||||||
border-radius: 16px;
|
|
||||||
z-index: 1;
|
|
||||||
-webkit-transition-duration: 300ms;
|
|
||||||
-moz-transition-duration: 300ms;
|
|
||||||
transition-duration: 300ms;
|
|
||||||
-webkit-transform: scale(1);
|
|
||||||
-moz-transform: scale(1);
|
|
||||||
-ms-transform: scale(1);
|
|
||||||
-o-transform: scale(1);
|
|
||||||
transform: scale(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-a input[type='checkbox']::before {
|
|
||||||
background-color: #ffffff;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-b input[type='checkbox']::before {
|
|
||||||
background-color: #000;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']::after {
|
|
||||||
-webkit-box-sizing: border-box;
|
|
||||||
-moz-box-sizing: border-box;
|
|
||||||
box-sizing: border-box;
|
|
||||||
height: 27px;
|
|
||||||
width: 27px;
|
|
||||||
content: ' ';
|
|
||||||
position: absolute;
|
|
||||||
border-radius: 27px;
|
|
||||||
background: #ffffff;
|
|
||||||
z-index: 2;
|
|
||||||
top: 2px;
|
|
||||||
left: 2px;
|
|
||||||
box-shadow: 0px 0px 1px 0px rgba(0, 0, 0, 0.25), 0px 4px 11px 0px rgba(0, 0, 0, 0.08), -1px 3px 3px 0px rgba(0, 0, 0, 0.14);
|
|
||||||
-webkit-transition: -webkit-transform 300ms, width 280ms;
|
|
||||||
-moz-transition: -moz-transform 300ms, width 280ms;
|
|
||||||
transition: transform 300ms, width 280ms;
|
|
||||||
-webkit-transform: translate3d(0, 0, 0);
|
|
||||||
-moz-transform: translate3d(0, 0, 0);
|
|
||||||
-ms-transform: translate3d(0, 0, 0);
|
|
||||||
-o-transform: translate3d(0, 0, 0);
|
|
||||||
transform: translate3d(0, 0, 0);
|
|
||||||
-webkit-transition-timing-function: cubic-bezier(0.42, 0.8, 0.58, 1.2);
|
|
||||||
-moz-transition-timing-function: cubic-bezier(0.42, 0.8, 0.58, 1.2);
|
|
||||||
transition-timing-function: cubic-bezier(0.42, 0.8, 0.58, 1.2);
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:checked {
|
|
||||||
background-color: #4CD964;
|
|
||||||
background-image: -webkit-linear-gradient(-90deg, #4CD964 0%, #4dd865 100%);
|
|
||||||
background-image: linear-gradient(-180deg,#4CD964 0%, #4dd865 100%);
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:checked::after {
|
|
||||||
-webkit-transform: translate3d(16px, 0, 0);
|
|
||||||
-moz-transform: translate3d(16px, 0, 0);
|
|
||||||
-ms-transform: translate3d(16px, 0, 0);
|
|
||||||
-o-transform: translate3d(16px, 0, 0);
|
|
||||||
transform: translate3d(16px, 0, 0);
|
|
||||||
right: 18px;
|
|
||||||
left: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:active::after {
|
|
||||||
width: 35px;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:checked::before, input[type='checkbox']:active::before {
|
|
||||||
-webkit-transform: scale(0);
|
|
||||||
-moz-transform: scale(0);
|
|
||||||
-ms-transform: scale(0);
|
|
||||||
-o-transform: scale(0);
|
|
||||||
transform: scale(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:disabled {
|
|
||||||
opacity: 0.5;
|
|
||||||
cursor: default;
|
|
||||||
-webkit-transition: none;
|
|
||||||
-moz-transition: none;
|
|
||||||
transition: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:disabled:active::before, input[type='checkbox']:disabled:active::after, input[type='checkbox']:disabled:checked:active::before, input[type='checkbox']:disabled:checked::before {
|
|
||||||
width: 27px;
|
|
||||||
-webkit-transition: none;
|
|
||||||
-moz-transition: none;
|
|
||||||
transition: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:disabled:active::before {
|
|
||||||
height: 27px;
|
|
||||||
width: 41px;
|
|
||||||
-webkit-transform: translate3d(6px, 0, 0);
|
|
||||||
-moz-transform: translate3d(6px, 0, 0);
|
|
||||||
-ms-transform: translate3d(6px, 0, 0);
|
|
||||||
-o-transform: translate3d(6px, 0, 0);
|
|
||||||
transform: translate3d(6px, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:disabled:checked:active::before {
|
|
||||||
height: 27px;
|
|
||||||
width: 27px;
|
|
||||||
-webkit-transform: scale(0);
|
|
||||||
-moz-transform: scale(0);
|
|
||||||
-ms-transform: scale(0);
|
|
||||||
-o-transform: scale(0);
|
|
||||||
transform: scale(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-a input[type='checkbox'] {
|
|
||||||
background-color: #e5e5e5;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-b input[type='checkbox'] {
|
|
||||||
background-color: #151515;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-a input[type='checkbox']::before {
|
|
||||||
background-color: #ffffff;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-b input[type='checkbox']::before {
|
|
||||||
background-color: #000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-a input[type='checkbox']::after {
|
|
||||||
background: #ffffff;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui-body-b input[type='checkbox']::after {
|
|
||||||
background: #444;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='checkbox']:checked {
|
|
||||||
background-color: #4CD964;
|
|
||||||
background-image: -webkit-linear-gradient(-90deg, #4CD964 0%, #4dd865 100%);
|
|
||||||
background-image: linear-gradient(-180deg,#4CD964 0%, #4dd865 100%);
|
|
||||||
}
|
|
||||||
|
@ -1,7 +1,14 @@
|
|||||||
.ui-popup-open .ui-header-fixed,
|
.ui-popup.ui-body-a {
|
||||||
|
background: #f4f4f4;
|
||||||
|
}
|
||||||
|
.ui-popup.ui-body-b {
|
||||||
|
background: #222;
|
||||||
|
}
|
||||||
|
.ui-popup-open .ui-header-fixed,
|
||||||
.ui-popup-open .ui-footer-fixed {
|
.ui-popup-open .ui-footer-fixed {
|
||||||
position: absolute !important; /* See issues #4816, #4844 and #4874 and popup.js */
|
position: absolute !important; /* See issues #4816, #4844 and #4874 and popup.js */
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-screen {
|
.ui-popup-screen {
|
||||||
background-image: url(""); /* Necessary to set some form of background to ensure element is clickable in IE6/7. While legacy IE won't understand the data-URI'd image, it ensures no additional requests occur in all other browsers with little overhead. */
|
background-image: url(""); /* Necessary to set some form of background to ensure element is clickable in IE6/7. While legacy IE won't understand the data-URI'd image, it ensures no additional requests occur in all other browsers with little overhead. */
|
||||||
top: 0;
|
top: 0;
|
||||||
@ -13,14 +20,17 @@
|
|||||||
opacity: 0;
|
opacity: 0;
|
||||||
z-index: 1099;
|
z-index: 1099;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-screen.in {
|
.ui-popup-screen.in {
|
||||||
opacity: 0.5;
|
opacity: 0.5;
|
||||||
filter: Alpha(Opacity=50);
|
filter: Alpha(Opacity=50);
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-screen.out {
|
.ui-popup-screen.out {
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
filter: Alpha(Opacity=0);
|
filter: Alpha(Opacity=0);
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-container {
|
.ui-popup-container {
|
||||||
z-index: 1100;
|
z-index: 1100;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
@ -28,19 +38,23 @@
|
|||||||
padding: 0;
|
padding: 0;
|
||||||
outline: 0;
|
outline: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup {
|
.ui-popup {
|
||||||
position: relative;
|
position: relative;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup.ui-body-inherit {
|
.ui-popup.ui-body-inherit {
|
||||||
border-width: 1px;
|
border-width: 1px;
|
||||||
border-style: solid;
|
border-style: solid;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-hidden {
|
.ui-popup-hidden {
|
||||||
left: 0;
|
left: 0;
|
||||||
top: 0;
|
top: 0;
|
||||||
position: absolute !important;
|
position: absolute !important;
|
||||||
visibility: hidden;
|
visibility: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-truncate {
|
.ui-popup-truncate {
|
||||||
height: 1px;
|
height: 1px;
|
||||||
width: 1px;
|
width: 1px;
|
||||||
@ -48,16 +62,20 @@
|
|||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
clip: rect(1px,1px,1px,1px);
|
clip: rect(1px,1px,1px,1px);
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup.ui-content,
|
.ui-popup.ui-content,
|
||||||
.ui-popup .ui-content {
|
.ui-popup .ui-content {
|
||||||
overflow: visible;
|
overflow: visible;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup > .ui-header {
|
.ui-popup > .ui-header {
|
||||||
border-top-width: 0;
|
border-top-width: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup > .ui-footer {
|
.ui-popup > .ui-footer {
|
||||||
border-bottom-width: 0;
|
border-bottom-width: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup > p,
|
.ui-popup > p,
|
||||||
.ui-popup > h1,
|
.ui-popup > h1,
|
||||||
.ui-popup > h2,
|
.ui-popup > h2,
|
||||||
@ -67,10 +85,12 @@
|
|||||||
.ui-popup > h6 {
|
.ui-popup > h6 {
|
||||||
margin: .5em .4375em;
|
margin: .5em .4375em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup > span {
|
.ui-popup > span {
|
||||||
display: block;
|
display: block;
|
||||||
margin: .5em .4375em;
|
margin: .5em .4375em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-container .ui-content > p,
|
.ui-popup-container .ui-content > p,
|
||||||
.ui-popup-container .ui-content > h1,
|
.ui-popup-container .ui-content > h1,
|
||||||
.ui-popup-container .ui-content > h2,
|
.ui-popup-container .ui-content > h2,
|
||||||
@ -80,9 +100,11 @@
|
|||||||
.ui-popup-container .ui-content > h6 {
|
.ui-popup-container .ui-content > h6 {
|
||||||
margin: .5em 0;
|
margin: .5em 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-container .ui-content > span {
|
.ui-popup-container .ui-content > span {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-container .ui-content > p:first-child,
|
.ui-popup-container .ui-content > p:first-child,
|
||||||
.ui-popup-container .ui-content > h1:first-child,
|
.ui-popup-container .ui-content > h1:first-child,
|
||||||
.ui-popup-container .ui-content > h2:first-child,
|
.ui-popup-container .ui-content > h2:first-child,
|
||||||
@ -92,6 +114,7 @@
|
|||||||
.ui-popup-container .ui-content > h6:first-child {
|
.ui-popup-container .ui-content > h6:first-child {
|
||||||
margin-top: 0;
|
margin-top: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-container .ui-content > p:last-child,
|
.ui-popup-container .ui-content > p:last-child,
|
||||||
.ui-popup-container .ui-content > h1:last-child,
|
.ui-popup-container .ui-content > h1:last-child,
|
||||||
.ui-popup-container .ui-content > h2:last-child,
|
.ui-popup-container .ui-content > h2:last-child,
|
||||||
@ -101,20 +124,24 @@
|
|||||||
.ui-popup-container .ui-content > h6:last-child {
|
.ui-popup-container .ui-content > h6:last-child {
|
||||||
margin-bottom: 0;
|
margin-bottom: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup > img {
|
.ui-popup > img {
|
||||||
max-width: 100%;
|
max-width: 100%;
|
||||||
max-height: 100%;
|
max-height: 100%;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup:not(.ui-content) > img:only-child,
|
.ui-popup:not(.ui-content) > img:only-child,
|
||||||
.ui-popup:not(.ui-content) > .ui-btn-left:first-child + img:last-child,
|
.ui-popup:not(.ui-content) > .ui-btn-left:first-child + img:last-child,
|
||||||
.ui-popup:not(.ui-content) > .ui-btn-right:first-child + img:last-child {
|
.ui-popup:not(.ui-content) > .ui-btn-right:first-child + img:last-child {
|
||||||
-webkit-border-radius: inherit;
|
-webkit-border-radius: inherit;
|
||||||
border-radius: inherit;
|
border-radius: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup iframe {
|
.ui-popup iframe {
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup > .ui-btn-left,
|
.ui-popup > .ui-btn-left,
|
||||||
.ui-popup > .ui-btn-right {
|
.ui-popup > .ui-btn-right {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -122,38 +149,74 @@
|
|||||||
margin: 0;
|
margin: 0;
|
||||||
z-index: 1101;
|
z-index: 1101;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup > .ui-btn-left {
|
.ui-popup > .ui-btn-left {
|
||||||
left: -11px;
|
left: -11px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup > .ui-btn-right {
|
.ui-popup > .ui-btn-right {
|
||||||
right: -11px;
|
right: -11px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@-webkit-keyframes fadein {
|
@-webkit-keyframes fadein {
|
||||||
from { opacity: 0; }
|
from {
|
||||||
to { opacity: 1; }
|
opacity: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
to {
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@-moz-keyframes fadein {
|
@-moz-keyframes fadein {
|
||||||
from { opacity: 0; }
|
from {
|
||||||
to { opacity: 1; }
|
opacity: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
to {
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@keyframes fadein {
|
@keyframes fadein {
|
||||||
from { opacity: 0; }
|
from {
|
||||||
to { opacity: 1; }
|
opacity: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
to {
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@-webkit-keyframes fadeout {
|
@-webkit-keyframes fadeout {
|
||||||
from { opacity: 1; }
|
from {
|
||||||
to { opacity: 0; }
|
opacity: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
to {
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@-moz-keyframes fadeout {
|
@-moz-keyframes fadeout {
|
||||||
from { opacity: 1; }
|
from {
|
||||||
to { opacity: 0; }
|
opacity: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
to {
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@keyframes fadeout {
|
@keyframes fadeout {
|
||||||
from { opacity: 1; }
|
from {
|
||||||
to { opacity: 0; }
|
opacity: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
to {
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.fade.out {
|
.fade.out {
|
||||||
@ -301,6 +364,7 @@
|
|||||||
margin-left: -5.857864376269049px;
|
margin-left: -5.857864376269049px;
|
||||||
margin-top: -7.0710678118654755px;
|
margin-top: -7.0710678118654755px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-arrow-container.ui-popup-arrow-b.ie .ui-popup-arrow {
|
.ui-popup-arrow-container.ui-popup-arrow-b.ie .ui-popup-arrow {
|
||||||
margin-left: -5.857864376269049px;
|
margin-left: -5.857864376269049px;
|
||||||
margin-top: -4.142135623730951px;
|
margin-top: -4.142135623730951px;
|
||||||
@ -310,6 +374,7 @@
|
|||||||
margin-left: -7.0710678118654755px;
|
margin-left: -7.0710678118654755px;
|
||||||
margin-top: -5.857864376269049px;
|
margin-top: -5.857864376269049px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-popup-arrow-container.ui-popup-arrow-r.ie .ui-popup-arrow {
|
.ui-popup-arrow-container.ui-popup-arrow-r.ie .ui-popup-arrow {
|
||||||
margin-left: -4.142135623730951px;
|
margin-left: -4.142135623730951px;
|
||||||
margin-top: -5.857864376269049px;
|
margin-top: -5.857864376269049px;
|
||||||
@ -341,12 +406,7 @@
|
|||||||
|
|
||||||
.ui-popup-arrow-container.ie .ui-popup-arrow {
|
.ui-popup-arrow-container.ie .ui-popup-arrow {
|
||||||
-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.7071067811865474, M12=-0.7071067811865477, M21=0.7071067811865477, M22=0.7071067811865474, SizingMethod='auto expand')";
|
-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.7071067811865474, M12=-0.7071067811865477, M21=0.7071067811865477, M22=0.7071067811865474, SizingMethod='auto expand')";
|
||||||
filter: progid:DXImageTransform.Microsoft.Matrix(
|
filter: progid:DXImageTransform.Microsoft.Matrix( M11=0.7071067811865474, M12=-0.7071067811865477, M21=0.7071067811865477, M22=0.7071067811865474, SizingMethod='auto expand');
|
||||||
M11=0.7071067811865474,
|
|
||||||
M12=-0.7071067811865477,
|
|
||||||
M21=0.7071067811865477,
|
|
||||||
M22=0.7071067811865474,
|
|
||||||
SizingMethod='auto expand');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
57
dashboard-ui/thirdparty/paper-button-style.css
vendored
57
dashboard-ui/thirdparty/paper-button-style.css
vendored
@ -391,9 +391,29 @@ paper-menu-item {
|
|||||||
border-color: #eee;
|
border-color: #eee;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.ui-body-a paper-checkbox #checkbox.checked.paper-checkbox {
|
||||||
|
background-color: #52B54B;
|
||||||
|
border-color: #52B54B;
|
||||||
|
}
|
||||||
|
|
||||||
.ui-body-b paper-checkbox #checkbox.checked.paper-checkbox {
|
.ui-body-b paper-checkbox #checkbox.checked.paper-checkbox {
|
||||||
background-color: #2ad;
|
background-color: #52B54B;
|
||||||
border-color: #2ad;
|
border-color: #52B54B;
|
||||||
|
}
|
||||||
|
|
||||||
|
paper-checkbox #checkboxContainer {
|
||||||
|
width: 22px !important;
|
||||||
|
height: 22px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
paper-checkbox paper-ripple {
|
||||||
|
top: -13px !important;
|
||||||
|
left: -13px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
paper-checkbox #checkmark {
|
||||||
|
border-right-width: 4px !important;
|
||||||
|
border-bottom-width: 4px !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.paperCheckboxList paper-checkbox {
|
.paperCheckboxList paper-checkbox {
|
||||||
@ -533,3 +553,36 @@ paper-dialog paper-radio-group paper-radio-button {
|
|||||||
padding: 0 1em;
|
padding: 0 1em;
|
||||||
margin-top: 1em;
|
margin-top: 1em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.paperToggleContainer {
|
||||||
|
padding: .5em 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.paperToggleContainer paper-toggle-button {
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
.paperToggleContainer > span {
|
||||||
|
vertical-align: middle;
|
||||||
|
margin-left: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
paper-toggle-button #toggleBar {
|
||||||
|
background-color: #080808;
|
||||||
|
}
|
||||||
|
|
||||||
|
paper-toggle-button #toggleButton, paper-toggle-button[checked] #toggleBar {
|
||||||
|
background-color: #52B54B;
|
||||||
|
}
|
||||||
|
|
||||||
|
paper-toggle-button paper-ripple {
|
||||||
|
color: #52B54B;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ui-body-b paper-progress #progressContainer {
|
||||||
|
background-color: #222 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
paper-progress.mini #progressContainer {
|
||||||
|
height: 3px !important;
|
||||||
|
}
|
||||||
|
@ -16614,7 +16614,8 @@ iron-selector:not(.narrow-layout) #main ::content [paper-drawer-toggle] {
|
|||||||
background-color: var(--paper-progress-container-color, --google-grey-300);
|
background-color: var(--paper-progress-container-color, --google-grey-300);
|
||||||
}
|
}
|
||||||
|
|
||||||
:host(.transiting) > * {
|
:host(.transiting) #primaryProgress,
|
||||||
|
:host(.transiting) #secondaryProgress {
|
||||||
-webkit-transition-property: -webkit-transform;
|
-webkit-transition-property: -webkit-transform;
|
||||||
transition-property: transform;
|
transition-property: transform;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user