diff options
| author | Luke Pulverenti <luke.pulverenti@gmail.com> | 2013-03-23 00:04:36 -0400 |
|---|---|---|
| committer | Luke Pulverenti <luke.pulverenti@gmail.com> | 2013-03-23 00:04:36 -0400 |
| commit | b20151fff373100da7946df93afb7dd4dccea3e4 (patch) | |
| tree | a16d7085c0eab807c309c94461ed60821029f1ff | |
| parent | 4bc27f3a65ddbffcc7b74683df72503f20df275c (diff) | |
copy dashboard to the output folder and load from the file system, instead of using embedded resources
156 files changed, 806 insertions, 9073 deletions
diff --git a/MediaBrowser.Api/BaseApiService.cs b/MediaBrowser.Api/BaseApiService.cs index 98e51ec40..133f22bcd 100644 --- a/MediaBrowser.Api/BaseApiService.cs +++ b/MediaBrowser.Api/BaseApiService.cs @@ -63,9 +63,32 @@ namespace MediaBrowser.Api public static Dictionary<string, string> GetAuthorization(IHttpRequest httpReq) { var auth = httpReq.Headers[HttpHeaders.Authorization]; - if (auth == null) return null; - var parts = auth.Split(' '); + return GetAuthorization(auth); + } + + /// <summary> + /// Gets the authorization. + /// </summary> + /// <param name="httpReq">The HTTP req.</param> + /// <returns>Dictionary{System.StringSystem.String}.</returns> + public static Dictionary<string, string> GetAuthorization(IRequestContext httpReq) + { + var auth = httpReq.GetHeader("Authorization"); + + return GetAuthorization(auth); + } + + /// <summary> + /// Gets the authorization. + /// </summary> + /// <param name="authorizationHeader">The authorization header.</param> + /// <returns>Dictionary{System.StringSystem.String}.</returns> + private static Dictionary<string, string> GetAuthorization(string authorizationHeader) + { + if (authorizationHeader == null) return null; + + var parts = authorizationHeader.Split(' '); // There should be at least to parts if (parts.Length < 2) return null; @@ -77,8 +100,8 @@ namespace MediaBrowser.Api } // Remove uptil the first space - auth = auth.Substring(auth.IndexOf(' ')); - parts = auth.Split(','); + authorizationHeader = authorizationHeader.Substring(authorizationHeader.IndexOf(' ')); + parts = authorizationHeader.Split(','); var result = new Dictionary<string, string>(StringComparer.OrdinalIgnoreCase); diff --git a/MediaBrowser.Api/Images/ImageService.cs b/MediaBrowser.Api/Images/ImageService.cs index 90100dfa7..46c357579 100644 --- a/MediaBrowser.Api/Images/ImageService.cs +++ b/MediaBrowser.Api/Images/ImageService.cs @@ -250,14 +250,14 @@ namespace MediaBrowser.Api.Images /// <param name="request">The request.</param> public void Post(PostUserImage request) { - var pathInfo = PathInfo.Parse(Request.PathInfo); + var pathInfo = PathInfo.Parse(RequestContext.PathInfo); var id = new Guid(pathInfo.GetArgumentValue<string>(1)); request.Type = (ImageType)Enum.Parse(typeof(ImageType), pathInfo.GetArgumentValue<string>(3), true); var item = _userManager.Users.First(i => i.Id == id); - var task = PostImage(item, request.RequestStream, request.Type, Request.ContentType); + var task = PostImage(item, request.RequestStream, request.Type, RequestContext.ContentType); Task.WaitAll(task); } diff --git a/MediaBrowser.Api/Playback/BaseStreamingService.cs b/MediaBrowser.Api/Playback/BaseStreamingService.cs index 03068c4c7..1740ad2eb 100644 --- a/MediaBrowser.Api/Playback/BaseStreamingService.cs +++ b/MediaBrowser.Api/Playback/BaseStreamingService.cs @@ -624,7 +624,7 @@ namespace MediaBrowser.Api.Playback var media = (IHasMediaStreams)item; - var url = Request.PathInfo; + var url = RequestContext.PathInfo; if (!request.AudioCodec.HasValue) { diff --git a/MediaBrowser.Api/Playback/Hls/AudioHlsService.cs b/MediaBrowser.Api/Playback/Hls/AudioHlsService.cs index 98033c057..ea1c8d301 100644 --- a/MediaBrowser.Api/Playback/Hls/AudioHlsService.cs +++ b/MediaBrowser.Api/Playback/Hls/AudioHlsService.cs @@ -40,7 +40,7 @@ namespace MediaBrowser.Api.Playback.Hls public object Get(GetHlsAudioSegment request) { - var file = SegmentFilePrefix + request.SegmentId + Path.GetExtension(Request.PathInfo); + var file = SegmentFilePrefix + request.SegmentId + Path.GetExtension(RequestContext.PathInfo); file = Path.Combine(ApplicationPaths.EncodedMediaCachePath, file); diff --git a/MediaBrowser.Api/Playback/Hls/VideoHlsService.cs b/MediaBrowser.Api/Playback/Hls/VideoHlsService.cs index 2b822dd1e..58224e325 100644 --- a/MediaBrowser.Api/Playback/Hls/VideoHlsService.cs +++ b/MediaBrowser.Api/Playback/Hls/VideoHlsService.cs @@ -32,7 +32,7 @@ namespace MediaBrowser.Api.Playback.Hls public object Get(GetHlsVideoSegment request) { - var file = SegmentFilePrefix + request.SegmentId + Path.GetExtension(Request.PathInfo); + var file = SegmentFilePrefix + request.SegmentId + Path.GetExtension(RequestContext.PathInfo); file = Path.Combine(ApplicationPaths.EncodedMediaCachePath, file); diff --git a/MediaBrowser.Api/Playback/Progressive/BaseProgressiveStreamingService.cs b/MediaBrowser.Api/Playback/Progressive/BaseProgressiveStreamingService.cs index fcdc945b2..90c233e90 100644 --- a/MediaBrowser.Api/Playback/Progressive/BaseProgressiveStreamingService.cs +++ b/MediaBrowser.Api/Playback/Progressive/BaseProgressiveStreamingService.cs @@ -87,15 +87,15 @@ namespace MediaBrowser.Api.Playback.Progressive /// </summary> private bool AddDlnaHeaders(StreamState state) { - var headers = Request.Headers; + var timeSeek = RequestContext.GetHeader("TimeSeekRange.dlna.org"); - if (!string.IsNullOrEmpty(headers["TimeSeekRange.dlna.org"])) + if (!string.IsNullOrEmpty(timeSeek)) { Response.StatusCode = 406; return false; } - var transferMode = headers["transferMode.dlna.org"]; + var transferMode = RequestContext.GetHeader("transferMode.dlna.org"); Response.AddHeader("transferMode.dlna.org", string.IsNullOrEmpty(transferMode) ? "Streaming" : transferMode); var contentFeatures = string.Empty; diff --git a/MediaBrowser.Api/PluginService.cs b/MediaBrowser.Api/PluginService.cs index 074d51b44..123d276e5 100644 --- a/MediaBrowser.Api/PluginService.cs +++ b/MediaBrowser.Api/PluginService.cs @@ -252,7 +252,7 @@ namespace MediaBrowser.Api { // We need to parse this manually because we told service stack not to with IRequiresRequestStream // https://code.google.com/p/servicestack/source/browse/trunk/Common/ServiceStack.Text/ServiceStack.Text/Controller/PathInfo.cs - var pathInfo = PathInfo.Parse(Request.PathInfo); + var pathInfo = PathInfo.Parse(RequestContext.PathInfo); var id = new Guid(pathInfo.GetArgumentValue<string>(1)); var plugin = _appHost.Plugins.First(p => p.Id == id); diff --git a/MediaBrowser.Api/ScheduledTasks/ScheduledTaskService.cs b/MediaBrowser.Api/ScheduledTasks/ScheduledTaskService.cs index a20013b12..8716899f4 100644 --- a/MediaBrowser.Api/ScheduledTasks/ScheduledTaskService.cs +++ b/MediaBrowser.Api/ScheduledTasks/ScheduledTaskService.cs @@ -182,7 +182,7 @@ namespace MediaBrowser.Api.ScheduledTasks { // We need to parse this manually because we told service stack not to with IRequiresRequestStream // https://code.google.com/p/servicestack/source/browse/trunk/Common/ServiceStack.Text/ServiceStack.Text/Controller/PathInfo.cs - var pathInfo = PathInfo.Parse(Request.PathInfo); + var pathInfo = PathInfo.Parse(RequestContext.PathInfo); var id = new Guid(pathInfo.GetArgumentValue<string>(1)); var task = TaskManager.ScheduledTasks.FirstOrDefault(i => i.Id == id); diff --git a/MediaBrowser.Api/UserLibrary/UserLibraryService.cs b/MediaBrowser.Api/UserLibrary/UserLibraryService.cs index 8b38f3c10..15f09f375 100644 --- a/MediaBrowser.Api/UserLibrary/UserLibraryService.cs +++ b/MediaBrowser.Api/UserLibrary/UserLibraryService.cs @@ -474,7 +474,7 @@ namespace MediaBrowser.Api.UserLibrary { // We need to parse this manually because we told service stack not to with IRequiresRequestStream // https://code.google.com/p/servicestack/source/browse/trunk/Common/ServiceStack.Text/ServiceStack.Text/Controller/PathInfo.cs - var pathInfo = PathInfo.Parse(Request.PathInfo); + var pathInfo = PathInfo.Parse(RequestContext.PathInfo); var userId = new Guid(pathInfo.GetArgumentValue<string>(1)); var itemId = pathInfo.GetArgumentValue<string>(3); @@ -595,7 +595,7 @@ namespace MediaBrowser.Api.UserLibrary var item = DtoBuilder.GetItemByClientId(request.Id, _userManager, _libraryManager, user.Id); - var auth = RequestFilterAttribute.GetAuthorization(Request); + var auth = RequestFilterAttribute.GetAuthorization(RequestContext); if (auth != null) { @@ -613,7 +613,7 @@ namespace MediaBrowser.Api.UserLibrary var item = DtoBuilder.GetItemByClientId(request.Id, _userManager, _libraryManager, user.Id); - var auth = RequestFilterAttribute.GetAuthorization(Request); + var auth = RequestFilterAttribute.GetAuthorization(RequestContext); if (auth != null) { @@ -633,7 +633,7 @@ namespace MediaBrowser.Api.UserLibrary var item = DtoBuilder.GetItemByClientId(request.Id, _userManager, _libraryManager, user.Id); - var auth = RequestFilterAttribute.GetAuthorization(Request); + var auth = RequestFilterAttribute.GetAuthorization(RequestContext); if (auth != null) { diff --git a/MediaBrowser.Api/UserService.cs b/MediaBrowser.Api/UserService.cs index b0a5bf4eb..4e32204e9 100644 --- a/MediaBrowser.Api/UserService.cs +++ b/MediaBrowser.Api/UserService.cs @@ -274,7 +274,7 @@ namespace MediaBrowser.Api { // We need to parse this manually because we told service stack not to with IRequiresRequestStream // https://code.google.com/p/servicestack/source/browse/trunk/Common/ServiceStack.Text/ServiceStack.Text/Controller/PathInfo.cs - var pathInfo = PathInfo.Parse(Request.PathInfo); + var pathInfo = PathInfo.Parse(RequestContext.PathInfo); var id = new Guid(pathInfo.GetArgumentValue<string>(1)); var dtoUser = request; diff --git a/MediaBrowser.Model/Configuration/ServerConfiguration.cs b/MediaBrowser.Model/Configuration/ServerConfiguration.cs index 8e0425447..11b0153b8 100644 --- a/MediaBrowser.Model/Configuration/ServerConfiguration.cs +++ b/MediaBrowser.Model/Configuration/ServerConfiguration.cs @@ -261,7 +261,15 @@ namespace MediaBrowser.Model.Configuration [ProtoMember(57)] public bool EnableDeveloperTools { get; set; } - // Next Proto number ====> 61 + /// <summary> + /// Gets or sets a value indicating whether [enable dashboard response caching]. + /// Allows potential contributors without visual studio to modify production dashboard code and test changes. + /// </summary> + /// <value><c>true</c> if [enable dashboard response caching]; otherwise, <c>false</c>.</value> + [ProtoMember(61)] + public bool EnableDashboardResponseCaching { get; set; } + + // Next Proto number ====> 62 /// <summary> /// Initializes a new instance of the <see cref="ServerConfiguration" /> class. diff --git a/MediaBrowser.Server.Implementations/HttpServer/BaseRestService.cs b/MediaBrowser.Server.Implementations/HttpServer/BaseRestService.cs index 4799bf0b8..ff2273750 100644 --- a/MediaBrowser.Server.Implementations/HttpServer/BaseRestService.cs +++ b/MediaBrowser.Server.Implementations/HttpServer/BaseRestService.cs @@ -1,5 +1,4 @@ -using System.Net; -using MediaBrowser.Common.Extensions; +using MediaBrowser.Common.Extensions; using MediaBrowser.Common.IO; using MediaBrowser.Common.Net; using MediaBrowser.Model.Logging; @@ -11,7 +10,7 @@ using System; using System.Collections.Generic; using System.Globalization; using System.IO; -using System.Linq; +using System.Net; using System.Threading.Tasks; using MimeTypes = MediaBrowser.Common.Net.MimeTypes; @@ -27,7 +26,7 @@ namespace MediaBrowser.Server.Implementations.HttpServer /// </summary> /// <value>The logger.</value> public ILogger Logger { get; set; } - + /// <summary> /// Gets a value indicating whether this instance is range request. /// </summary> @@ -36,7 +35,7 @@ namespace MediaBrowser.Server.Implementations.HttpServer { get { - return Request.Headers.AllKeys.Contains("Range"); + return !string.IsNullOrEmpty(RequestContext.GetHeader("Range")); } } @@ -55,8 +54,6 @@ namespace MediaBrowser.Server.Implementations.HttpServer throw new ArgumentNullException("result"); } - Response.AddHeader("Vary", "Accept-Encoding"); - return RequestContext.ToOptimizedResult(result); } @@ -200,11 +197,6 @@ namespace MediaBrowser.Server.Implementations.HttpServer var compress = ShouldCompressResponse(contentType); - if (compress) - { - Response.AddHeader("Vary", "Accept-Encoding"); - } - return ToStaticResult(contentType, factoryFn, compress, headersOnly).Result; } @@ -266,9 +258,9 @@ namespace MediaBrowser.Server.Implementations.HttpServer if (IsRangeRequest) { - return new RangeRequestWriter(Request.Headers, httpListenerResponse, stream, headersOnly); + return new RangeRequestWriter(RequestContext.GetHeader("Range"), httpListenerResponse, stream, headersOnly); } - + httpListenerResponse.ContentLength64 = stream.Length; return headersOnly ? null : new StreamWriter(stream, Logger); } @@ -332,22 +324,26 @@ namespace MediaBrowser.Server.Implementations.HttpServer { var isNotModified = true; - if (Request.Headers.AllKeys.Contains("If-Modified-Since")) + var ifModifiedSinceHeader = RequestContext.GetHeader("If-Modified-Since"); + + if (!string.IsNullOrEmpty(ifModifiedSinceHeader)) { DateTime ifModifiedSince; - if (DateTime.TryParse(Request.Headers["If-Modified-Since"], out ifModifiedSince)) + if (DateTime.TryParse(ifModifiedSinceHeader, out ifModifiedSince)) { isNotModified = IsNotModified(ifModifiedSince.ToUniversalTime(), cacheDuration, lastDateModified); } } + var ifNoneMatchHeader = RequestContext.GetHeader("If-None-Match"); + // Validate If-None-Match - if (isNotModified && (cacheKey.HasValue || !string.IsNullOrEmpty(Request.Headers["If-None-Match"]))) + if (isNotModified && (cacheKey.HasValue || !string.IsNullOrEmpty(ifNoneMatchHeader))) { Guid ifNoneMatch; - if (Guid.TryParse(Request.Headers["If-None-Match"] ?? string.Empty, out ifNoneMatch)) + if (Guid.TryParse(ifNoneMatchHeader ?? string.Empty, out ifNoneMatch)) { if (cacheKey.HasValue && cacheKey.Value == ifNoneMatch) { diff --git a/MediaBrowser.Server.Implementations/HttpServer/HttpServer.cs b/MediaBrowser.Server.Implementations/HttpServer/HttpServer.cs index 0fc2c0dda..79663dca9 100644 --- a/MediaBrowser.Server.Implementations/HttpServer/HttpServer.cs +++ b/MediaBrowser.Server.Implementations/HttpServer/HttpServer.cs @@ -162,9 +162,18 @@ namespace MediaBrowser.Server.Implementations.HttpServer if (!string.IsNullOrEmpty(exception.Message)) { - res.AddHeader("X-Application-Error-Code", exception.Message); + res.AddHeader("X-Application-Error-Code", exception.Message.Replace(Environment.NewLine, " ")); } } + + if (dto is CompressedResult) + { + // Per Google PageSpeed + // This instructs the proxies to cache two versions of the resource: one compressed, and one uncompressed. + // The correct version of the resource is delivered based on the client request header. + // This is a good choice for applications that are singly homed and depend on public proxies for user locality. + res.AddHeader("Vary", "Accept-Encoding"); + } }); } diff --git a/MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs b/MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs index 9981e5fe1..b61e05d0b 100644 --- a/MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs +++ b/MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs @@ -1,7 +1,6 @@ using ServiceStack.Service; using System; using System.Collections.Generic; -using System.Collections.Specialized; using System.IO; using System.Linq; using System.Net; @@ -17,19 +16,19 @@ namespace MediaBrowser.Server.Implementations.HttpServer /// <value>The source stream.</value> private Stream SourceStream { get; set; } private HttpListenerResponse Response { get; set; } - private NameValueCollection RequestHeaders { get; set; } + private string RangeHeader { get; set; } private bool IsHeadRequest { get; set; } /// <summary> /// Initializes a new instance of the <see cref="StreamWriter" /> class. /// </summary> - /// <param name="requestHeaders">The request headers.</param> + /// <param name="rangeHeader">The range header.</param> /// <param name="response">The response.</param> /// <param name="source">The source.</param> /// <param name="isHeadRequest">if set to <c>true</c> [is head request].</param> - public RangeRequestWriter(NameValueCollection requestHeaders, HttpListenerResponse response, Stream source, bool isHeadRequest) + public RangeRequestWriter(string rangeHeader, HttpListenerResponse response, Stream source, bool isHeadRequest) { - RequestHeaders = requestHeaders; + RangeHeader = rangeHeader; Response = response; SourceStream = source; IsHeadRequest = isHeadRequest; @@ -52,7 +51,7 @@ namespace MediaBrowser.Server.Implementations.HttpServer _requestedRanges = new List<KeyValuePair<long, long?>>(); // Example: bytes=0-,32-63 - var ranges = RequestHeaders["Range"].Split('=')[1].Split(','); + var ranges = RangeHeader.Split('=')[1].Split(','); foreach (var range in ranges) { diff --git a/MediaBrowser.ServerApplication/MediaBrowser.ServerApplication.csproj b/MediaBrowser.ServerApplication/MediaBrowser.ServerApplication.csproj index a91fb19fa..8c8f8b4f3 100644 --- a/MediaBrowser.ServerApplication/MediaBrowser.ServerApplication.csproj +++ b/MediaBrowser.ServerApplication/MediaBrowser.ServerApplication.csproj @@ -404,6 +404,9 @@ xcopy "$(TargetDir)x86" "$(SolutionDir)..\Deploy\Server\System\x86" /y mkdir "$(SolutionDir)..\Deploy\Server\System\CorePlugins" xcopy "$(TargetDir)CorePlugins" "$(SolutionDir)..\Deploy\Server\System\CorePlugins" /y +mkdir "$(SolutionDir)..\Deploy\Server\System\dashboard-ui" +xcopy "$(TargetDir)dashboard-ui" "$(SolutionDir)..\Deploy\Server\System\dashboard-ui" /y + del "$(SolutionDir)..\Deploy\MBServer.zip" "$(SolutionDir)ThirdParty\7zip\7za" a -tzip "$(SolutionDir)..\Deploy\MBServer.zip" "$(SolutionDir)..\Deploy\Server\*" )</PostBuildEvent> diff --git a/MediaBrowser.WebDashboard/Api/DashboardService.cs b/MediaBrowser.WebDashboard/Api/DashboardService.cs index d9852446e..0c2b8a376 100644 --- a/MediaBrowser.WebDashboard/Api/DashboardService.cs +++ b/MediaBrowser.WebDashboard/Api/DashboardService.cs @@ -1,8 +1,10 @@ -using System.Reflection; +using System.Diagnostics; using MediaBrowser.Common.Extensions; +using MediaBrowser.Common.IO; using MediaBrowser.Common.Net; using MediaBrowser.Common.ScheduledTasks; using MediaBrowser.Controller; +using MediaBrowser.Controller.Configuration; using MediaBrowser.Controller.Library; using MediaBrowser.Controller.Plugins; using MediaBrowser.Model.Logging; @@ -14,7 +16,7 @@ using System.Collections.Generic; using System.ComponentModel.Composition; using System.IO; using System.Linq; -using System.Net; +using System.Reflection; using System.Text; using System.Text.RegularExpressions; using System.Threading.Tasks; @@ -90,20 +92,31 @@ namespace MediaBrowser.WebDashboard.Api /// </summary> private readonly IUserManager _userManager; + /// <summary> + /// The _app host + /// </summary> private readonly IServerApplicationHost _appHost; + /// <summary> + /// The _library manager + /// </summary> private readonly ILibraryManager _libraryManager; + private readonly IServerConfigurationManager _serverConfigurationManager; + /// <summary> /// Initializes a new instance of the <see cref="DashboardService" /> class. /// </summary> /// <param name="taskManager">The task manager.</param> /// <param name="userManager">The user manager.</param> - public DashboardService(ITaskManager taskManager, IUserManager userManager, IServerApplicationHost appHost, ILibraryManager libraryManager) + /// <param name="appHost">The app host.</param> + /// <param name="libraryManager">The library manager.</param> + public DashboardService(ITaskManager taskManager, IUserManager userManager, IServerApplicationHost appHost, ILibraryManager libraryManager, IServerConfigurationManager serverConfigurationManager) { _taskManager = taskManager; _userManager = userManager; _appHost = appHost; _libraryManager = libraryManager; + _serverConfigurationManager = serverConfigurationManager; } /// <summary> @@ -119,9 +132,11 @@ namespace MediaBrowser.WebDashboard.Api /// <summary> /// Gets the dashboard info. /// </summary> + /// <param name="appHost">The app host.</param> /// <param name="logger">The logger.</param> /// <param name="taskManager">The task manager.</param> /// <param name="userManager">The user manager.</param> + /// <param name="libraryManager">The library manager.</param> /// <returns>DashboardInfo.</returns> public static async Task<DashboardInfo> GetDashboardInfo(IServerApplicationHost appHost, ILogger logger, ITaskManager taskManager, IUserManager userManager, ILibraryManager libraryManager) { @@ -188,6 +203,14 @@ namespace MediaBrowser.WebDashboard.Api var contentType = MimeTypes.GetMimeType(path); + // Don't cache if not configured to do so + // But always cache images to simulate production + if (!_serverConfigurationManager.Configuration.EnableDashboardResponseCaching && !contentType.StartsWith("image/", StringComparison.OrdinalIgnoreCase)) + { + Response.ContentType = contentType; + return GetResourceStream(path).Result; + } + TimeSpan? cacheDuration = null; // Cache images unconditionally - updates to image files will require new filename @@ -199,7 +222,9 @@ namespace MediaBrowser.WebDashboard.Api var assembly = GetType().Assembly.GetName(); - return ToStaticResult(assembly.Version.ToString().GetMD5(), null, cacheDuration, contentType, () => GetResourceStream(path)); + var cacheKey = (assembly.Version + path).GetMD5(); + + return ToStaticResult(cacheKey, null, cacheDuration, contentType, () => GetResourceStream(path)); } /// <summary> @@ -217,7 +242,7 @@ namespace MediaBrowser.WebDashboard.Api } else { - resourceStream = GetType().Assembly.GetManifestResourceStream("MediaBrowser.WebDashboard.Html." + ConvertUrlToResourcePath(path)); + resourceStream = GetRawResourceStream(path); } if (resourceStream != null) @@ -236,32 +261,20 @@ namespace MediaBrowser.WebDashboard.Api } /// <summary> - /// Redirects the specified CTX. + /// Gets the raw resource stream. /// </summary> - /// <param name="ctx">The CTX.</param> - /// <param name="url">The URL.</param> - private void Redirect(HttpListenerContext ctx, string url) + /// <param name="path">The path.</param> + /// <returns>Task{Stream}.</returns> + private Stream GetRawResourceStream(string path) { - // Try to prevent the browser from caching the redirect response (the right way) - ctx.Response.Headers[HttpResponseHeader.CacheControl] = "no-cache, no-store, must-revalidate"; - ctx.Response.Headers[HttpResponseHeader.Pragma] = "no-cache, no-store, must-revalidate"; - ctx.Response.Headers[HttpResponseHeader.Expires] = "-1"; + var runningDirectory = Path.GetDirectoryName(Process.GetCurrentProcess().MainModule.FileName); - ctx.Response.Redirect(url); - ctx.Response.Close(); - } + path = Path.Combine(runningDirectory, "dashboard-ui", path.Replace('/', '\\')); - /// <summary> - /// Preserves the current query string when redirecting - /// </summary> - /// <param name="request">The request.</param> - /// <param name="newUrl">The new URL.</param> - /// <returns>System.String.</returns> - private string GetRedirectUrl(HttpListenerRequest request, string newUrl) - { - var query = request.Url.Query; + return new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.ReadWrite, StreamDefaults.DefaultFileStreamBufferSize, true); - return string.IsNullOrEmpty(query) ? newUrl : newUrl + query; + // This code is used when the files are embedded resources + //return GetType().Assembly.GetManifestResourceStream("MediaBrowser.WebDashboard.Html." + ConvertUrlToResourcePath(path)); } /// <summary> @@ -454,13 +467,21 @@ namespace MediaBrowser.WebDashboard.Api foreach (var file in scriptFiles) { - await AppendResource(assembly, memoryStream, resourcePrefix + file, newLineBytes).ConfigureAwait(false); + await AppendResource(memoryStream, "scripts/" + file, newLineBytes).ConfigureAwait(false); } memoryStream.Position = 0; return memoryStream; } + /// <summary> + /// Appends the resource. + /// </summary> + /// <param name="assembly">The assembly.</param> + /// <param name="outputStream">The output stream.</param> + /// <param name="path">The path.</param> + /// <param name="newLineBytes">The new line bytes.</param> + /// <returns>Task.</returns> private async Task AppendResource(Assembly assembly, Stream outputStream, string path, byte[] newLineBytes) { using (var stream = assembly.GetManifestResourceStream(path)) @@ -471,6 +492,22 @@ namespace MediaBrowser.WebDashboard.Api } } + /// <summary> + /// Appends the resource. + /// </summary> + /// <param name="outputStream">The output stream.</param> + /// <param name="path">The path.</param> + /// <param name="newLineBytes">The new line bytes.</param> + /// <returns>Task.</returns> + private async Task AppendResource(Stream outputStream, string path, byte[] newLineBytes) + { + using (var stream = GetRawResourceStream(path)) + { + await stream.CopyToAsync(outputStream).ConfigureAwait(false); + + await outputStream.WriteAsync(newLineBytes, 0, newLineBytes.Length).ConfigureAwait(false); + } + } } } diff --git a/MediaBrowser.WebDashboard/ApiClient.js b/MediaBrowser.WebDashboard/ApiClient.js index f3b24cd29..1d2d18006 100644 --- a/MediaBrowser.WebDashboard/ApiClient.js +++ b/MediaBrowser.WebDashboard/ApiClient.js @@ -2,7 +2,7 @@ window.MediaBrowser = {}; } -MediaBrowser.ApiClient = function ($, navigator) { +MediaBrowser.ApiClient = function ($, navigator, JSON, WebSocket, setTimeout) { /** * Creates a new api client instance @@ -15,8 +15,9 @@ MediaBrowser.ApiClient = function ($, navigator) { var self = this; var deviceName = "Web Browser"; - var deviceId = SHA1(navigator.userAgent + (navigator.cpuClass || "")); + var deviceId = MediaBrowser.SHA1(navigator.userAgent + (navigator.cpuClass || "")); var currentUserId; + var webSocket; /** * Gets the server host name. @@ -88,6 +89,55 @@ MediaBrowser.ApiClient = function ($, navigator) { return url; }; + self.openWebSocket = function (port) { + + var url = "ws://" + serverHostName + ":" + port + "/mediabrowser"; + + webSocket = new WebSocket(url); + + webSocket.onmessage = function (msg) { + msg = JSON.parse(msg.data); + $(self).trigger("websocketmessage", [msg]); + }; + + webSocket.onopen = function () { + setTimeout(function () { + $(self).trigger("websocketopen"); + }, 500); + }; + webSocket.onerror = function () { + setTimeout(function () { + $(self).trigger("websocketerror"); + }, 0); + }; + webSocket.onclose = function () { + setTimeout(function () { + $(self).trigger("websocketclose"); + }, 0); + }; + }; + + self.sendWebSocketMessage = function (name, data) { + + var msg = { MessageType: name }; + + if (data) { + msg.Data = data; + } + + msg = JSON.stringify(msg); + + webSocket.send(msg); + }; + + self.isWebSocketOpen = function () { + return webSocket && webSocket.readyState === WebSocket.OPEN; + }; + + self.isWebSocketOpenOrConnecting = function () { + return webSocket && (webSocket.readyState === WebSocket.OPEN || webSocket.readyState === WebSocket.CONNECTING); + }; + /** * Gets an item from the server * Omit itemId to get the root folder. @@ -1184,7 +1234,7 @@ MediaBrowser.ApiClient = function ($, navigator) { var url = self.getUrl("Users/" + userId + "/authenticate"); var postData = { - password: SHA1(password || "") + password: MediaBrowser.SHA1(password || "") }; return self.ajax({ @@ -1214,7 +1264,7 @@ MediaBrowser.ApiClient = function ($, navigator) { }; - postData.currentPassword = SHA1(currentPassword); + postData.currentPassword = MediaBrowser.SHA1(currentPassword); if (newPassword) { postData.newPassword = newPassword; @@ -1523,7 +1573,7 @@ MediaBrowser.ApiClient = function ($, navigator) { }; }; -}(jQuery, navigator); +}(jQuery, navigator, JSON, window.WebSocket, setTimeout); /** * Provides a friendly way to create an api client instance using information from the browser's current url @@ -1533,4 +1583,177 @@ MediaBrowser.ApiClient.create = function (clientName) { var loc = window.location; return new MediaBrowser.ApiClient(loc.protocol, loc.hostname, loc.port, clientName); +}; + +/** +* +* Secure Hash Algorithm (SHA1) +* http://www.webtoolkit.info/ +* +**/ +MediaBrowser.SHA1 = function (msg) { + + function rotate_left(n, s) { + var t4 = (n << s) | (n >>> (32 - s)); + return t4; + }; + + function lsb_hex(val) { + var str = ""; + var i; + var vh; + var vl; + + for (i = 0; i <= 6; i += 2) { + vh = (val >>> (i * 4 + 4)) & 0x0f; + vl = (val >>> (i * 4)) & 0x0f; + str += vh.toString(16) + vl.toString(16); + } + return str; + }; + + function cvt_hex(val) { + var str = ""; + var i; + var v; + + for (i = 7; i >= 0; i--) { + v = (val >>> (i * 4)) & 0x0f; + str += v.toString(16); + } + return str; + }; + + + function Utf8Encode(string) { + string = string.replace(/\r\n/g, "\n"); + var utftext = ""; + + for (var n = 0; n < string.length; n++) { + + var c = string.charCodeAt(n); + + if (c < 128) { + utftext += String.fromCharCode(c); + } + else if ((c > 127) && (c < 2048)) { + utftext += String.fromCharCode((c >> 6) | 192); + utftext += String.fromCharCode((c & 63) | 128); + } + else { + utftext += String.fromCharCode((c >> 12) | 224); + utftext += String.fromCharCode(((c >> 6) & 63) | 128); + utftext += String.fromCharCode((c & 63) | 128); + } + + } + + return utftext; + }; + + var blockstart; + var i, j; + var W = new Array(80); + var H0 = 0x67452301; + var H1 = 0xEFCDAB89; + var H2 = 0x98BADCFE; + var H3 = 0x10325476; + var H4 = 0xC3D2E1F0; + var A, B, C, D, E; + var temp; + + msg = Utf8Encode(msg); + + var msg_len = msg.length; + + var word_array = new Array(); + for (i = 0; i < msg_len - 3; i += 4) { + j = msg.charCodeAt(i) << 24 | msg.charCodeAt(i + 1) << 16 | + msg.charCodeAt(i + 2) << 8 | msg.charCodeAt(i + 3); + word_array.push(j); + } + + switch (msg_len % 4) { + case 0: + i = 0x080000000; + break; + case 1: + i = msg.charCodeAt(msg_len - 1) << 24 | 0x0800000; + break; + + case 2: + i = msg.charCodeAt(msg_len - 2) << 24 | msg.charCodeAt(msg_len - 1) << 16 | 0x08000; + break; + + case 3: + i = msg.charCodeAt(msg_len - 3) << 24 | msg.charCodeAt(msg_len - 2) << 16 | msg.charCodeAt(msg_len - 1) << 8 | 0x80; + break; + } + + word_array.push(i); + + while ((word_array.length % 16) != 14) word_array.push(0); + + word_array.push(msg_len >>> 29); + word_array.push((msg_len << 3) & 0x0ffffffff); + + + for (blockstart = 0; blockstart < word_array.length; blockstart += 16) { + + for (i = 0; i < 16; i++) W[i] = word_array[blockstart + i]; + for (i = 16; i <= 79; i++) W[i] = rotate_left(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1); + + A = H0; + B = H1; + C = H2; + D = H3; + E = H4; + + for (i = 0; i <= 19; i++) { + temp = (rotate_left(A, 5) + ((B & C) | (~B & D)) + E + W[i] + 0x5A827999) & 0x0ffffffff; + E = D; + D = C; + C = rotate_left(B, 30); + B = A; + A = temp; + } + + for (i = 20; i <= 39; i++) { + temp = (rotate_left(A, 5) + (B ^ C ^ D) + E + W[i] + 0x6ED9EBA1) & 0x0ffffffff; + E = D; + D = C; + C = rotate_left(B, 30); + B = A; + A = temp; + } + + for (i = 40; i <= 59; i++) { + temp = (rotate_left(A, 5) + ((B & C) | (B & D) | (C & D)) + E + W[i] + 0x8F1BBCDC) & 0x0ffffffff; + E = D; + D = C; + C = rotate_left(B, 30); + B = A; + A = temp; + } + + for (i = 60; i <= 79; i++) { + temp = (rotate_left(A, 5) + (B ^ C ^ D) + E + W[i] + 0xCA62C1D6) & 0x0ffffffff; + E = D; + D = C; + C = rotate_left(B, 30); + B = A; + A = temp; + } + + H0 = (H0 + A) & 0x0ffffffff; + H1 = (H1 + B) & 0x0ffffffff; + H2 = (H2 + C) & 0x0ffffffff; + H3 = (H3 + D) & 0x0ffffffff; + H4 = (H4 + E) & 0x0ffffffff; + + } + + var temp = cvt_hex(H0) + cvt_hex(H1) + cvt_hex(H2) + cvt_hex(H3) + cvt_hex(H4); + + return temp.toLowerCase(); };
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/Readme.txt b/MediaBrowser.WebDashboard/Html/Readme.txt deleted file mode 100644 index c47c07541..000000000 --- a/MediaBrowser.WebDashboard/Html/Readme.txt +++ /dev/null @@ -1,4 +0,0 @@ -All static files such as html, images, etc, need to be marked as embedded resources.
-
-Here is a link for more information regarding the Build Action property.
-http://msdn.microsoft.com/en-us/library/0c6xyb66.aspx
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/about.html b/MediaBrowser.WebDashboard/Html/about.html deleted file mode 100644 index 07b14cd8b..000000000 --- a/MediaBrowser.WebDashboard/Html/about.html +++ /dev/null @@ -1,36 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>About</title> -</head> -<body> - <div id="aboutPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - <div class="content-primary"> - <div class="readOnlyContent"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="support.html" data-role="button">General</a> - <a href="log.html" data-role="button">View Log</a> - <a href="supporter.html" data-role="button">Become a Supporter</a> - <a href="supporterKey.html" data-role="button">Supporter Key</a> - <a href="about.html" data-role="button" class="ui-btn-active">About</a> - </div> - <p> - <img class="imgLogoIcon" src="css/images/mblogoicon.png" /><img class="imgLogoText" src="css/images/mblogotextblack.png" /> - <br /> - <br /> - Version <span id="appVersionNumber"></span> - </p> - <hr/> - <br/> - <br/> - <p> - Utilizing <a href="http://www.pismotechnic.com/pfm/" target="_blank">Pismo File Mount</a> through a donated license. - </p> - </div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/addPlugin.html b/MediaBrowser.WebDashboard/Html/addPlugin.html deleted file mode 100644 index 2244d5c14..000000000 --- a/MediaBrowser.WebDashboard/Html/addPlugin.html +++ /dev/null @@ -1,83 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title></title> -</head> -<body> - <div id="addPluginPage" data-role="page" class="page type-interior pluginConfigurationPage"> - - <div data-role="content"> - <div class="content-primary"> - <p> - <a data-role="button" data-icon="arrow-left" data-inline="true" data-mini="true" data-theme="b" href="pluginCatalog.html">Plugin Catalog</a> - </p> - <form id="addPluginForm"> - <p id="tagline" style="font-style: italic;"></p> - <p id="pPreviewImage" style="text-align: center; margin: 2em 0;"></p> - - <p id="overview"></p> - - <div data-role="collapsible" data-content-theme="c" data-collapsed="false" style="margin-top: 2em;" data-theme="a"> - <h3>Install</h3> - <p id="pCurrentVersion"> - </p> - <p> - <label for="selectVersion">Select version to install:</label> - <select id="selectVersion" name="selectVersion"></select> - </p> - - <p> - <button id="btnInstall" type="submit" data-icon="download" data-theme="b">Install</button> - </p> - </div> - </form> - - <form name="_xclick" target="_blank" action="https://www.paypal.com/cgi-bin/webscr" method="post"> - <div class="premiumPackage" data-role="collapsible" data-content-theme="c" data-collapsed="false" style="margin-top: 2em; display: none" data-theme="a"> - <h3>Registration</h3> - <p id="regStatus"> - </p> - <p id="regInfo"> - </p> - <div class="premiumHasPrice" style="display: none"> - <p id="regPrice"> - </p> - <input type="hidden" name="cmd" value="_xclick"> - <input type="hidden" id="payPalEmail" name="business" value="mb_1358534950_biz@reedsplace.com"> - <input type="hidden" name="currency_code" value="USD"> - <input type="hidden" id="featureName" name="item_name" value="MBSupporter"> - <input type="hidden" id="amount" name="amount" value="10"> - <input type="hidden" id="featureId" name="item_number" value="MBSupporter"> - <input type="hidden" name="notify_url" value="http://mb3admin.com/admin/service/services/ppipn.php"> - <input type="hidden" name="return" id ="paypalReturnUrl" value="#"> - <a data-role="button" id="ppButton" onclick="_xclick.submit();"><img src="css/images/registerpp.png"/></a> - <p id="noEmail" style="display: none"><strong>This developer has not provided a PayPal email. Please see their - website for registration information.</strong> - </p> - - </div> - - </div> - - <div data-role="collapsible" data-content-theme="c" data-collapsed="false" style="margin-top: 2em;" data-theme="a"> - <h3>Developer Info</h3> - <p id="developer"></p> - <p id="pViewWebsite" style="display: none;"> - <a href="#" data-rel="external" target="_blank">View Website</a> - </p> - </div> - - <div data-role="collapsible" data-content-theme="c" style="margin-top: 2em;" data-theme="a"> - <h3>Revision History</h3> - <div id="revisionHistory"></div> - </div> - </form> - - </div> - </div> - <script type="text/javascript"> - $('#addPluginForm').on('submit', AddPluginPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/advanced.html b/MediaBrowser.WebDashboard/Html/advanced.html deleted file mode 100644 index d5592b50e..000000000 --- a/MediaBrowser.WebDashboard/Html/advanced.html +++ /dev/null @@ -1,64 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Advanced</title> -</head> -<body> - <div id="advancedConfigurationPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - <div class="content-primary"> - <form id="advancedConfigurationForm"> - - <ul data-role="listview" class="ulForm"> - <li> - <input type="checkbox" id="chkRunAtStartup" name="chkRunAtStartup" /> - <label for="chkRunAtStartup">Run server at startup</label> - </li> - <li> - <label for="selectAutomaticUpdateLevel">Automatic update level</label> - <select name="selectAutomaticUpdateLevel" id="selectAutomaticUpdateLevel"> - <option value="Release">Official Release</option> - <option value="Beta">Beta</option> - <option value="Dev">Dev</option> - </select> - </li> - <li> - <label for="txtPortNumber">Http server port number: </label> - <input type="number" id="txtPortNumber" name="txtPortNumber" pattern="[0-9]*" required="required" min="1" /> - </li> - <li id="fldWebSocketPortNumber" style="display: none;"> - <label for="txtWebSocketPortNumber">Web socket port number: </label> - <input type="number" id="txtWebSocketPortNumber" name="txtWebSocketPortNumber" pattern="[0-9]*" required="required" min="1" /> - </li> - <li> - <input type="checkbox" id="chkEnableDeveloperTools" name="chkEnableDeveloperTools" /> - <label for="chkEnableDeveloperTools">Enable developer tools</label> - <div class="fieldDescription"> - When enabled, developer tools will be available from the system tray. - </div> - </li> - <li> - <input type="checkbox" id="chkDebugLog" name="chkDebugLog" /> - <label for="chkDebugLog">Enable debug logging </label> - </li> - <li> - <button type="submit" data-theme="b" data-icon="ok"> - Save - </button> - <button type="button" onclick="Dashboard.navigate('dashboard.html');" data-icon="delete"> - Cancel - </button> - </li> - </ul> - - </form> - </div> - </div> - - <script type="text/javascript"> - $('#advancedConfigurationForm').on('submit', AdvancedConfigurationPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/advancedMetadata.html b/MediaBrowser.WebDashboard/Html/advancedMetadata.html deleted file mode 100644 index 6ea3d7e74..000000000 --- a/MediaBrowser.WebDashboard/Html/advancedMetadata.html +++ /dev/null @@ -1,40 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Metadata</title> -</head> -<body> - <div id="advancedMetadataConfigurationPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="metadata.html" data-role="button">Basics</a> - <a href="metadataImages.html" data-role="button">Images</a> - <a href="advancedMetadata.html" data-role="button" class="ui-btn-active">Advanced</a> - </div> - - <form id="advancedMetadataConfigurationForm"> - <ul data-role="listview" class="ulForm"> - <li> - <label>Disable internet providers for:</label> - <div id="divItemTypes"></div> - </li> - <li style="display: none;"> - <button class="btnSubmit" type="submit" data-theme="b"> - Save - </button> - </li> - </ul> - </form> - </div> - - </div> - - <script type="text/javascript"> - $('#advancedMetadataConfigurationForm').on('submit', AdvancedMetadataConfigurationPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/css/images/bg.png b/MediaBrowser.WebDashboard/Html/css/images/bg.png Binary files differdeleted file mode 100644 index d1e835871..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/bg.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/checkMarkGreen.png b/MediaBrowser.WebDashboard/Html/css/images/checkMarkGreen.png Binary files differdeleted file mode 100644 index c5cd1c7d4..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/checkMarkGreen.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/checkmarkblack.png b/MediaBrowser.WebDashboard/Html/css/images/checkmarkblack.png Binary files differdeleted file mode 100644 index d825a1d76..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/checkmarkblack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/clients/android.png b/MediaBrowser.WebDashboard/Html/css/images/clients/android.png Binary files differdeleted file mode 100644 index 88e3b93e4..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/clients/android.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/clients/dlna.png b/MediaBrowser.WebDashboard/Html/css/images/clients/dlna.png Binary files differdeleted file mode 100644 index 0910220de..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/clients/dlna.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/clients/html5.png b/MediaBrowser.WebDashboard/Html/css/images/clients/html5.png Binary files differdeleted file mode 100644 index 2fdbe426a..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/clients/html5.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/clients/ios.png b/MediaBrowser.WebDashboard/Html/css/images/clients/ios.png Binary files differdeleted file mode 100644 index 1429af5dc..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/clients/ios.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/clients/mb.png b/MediaBrowser.WebDashboard/Html/css/images/clients/mb.png Binary files differdeleted file mode 100644 index c641c0652..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/clients/mb.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/clients/win8.png b/MediaBrowser.WebDashboard/Html/css/images/clients/win8.png Binary files differdeleted file mode 100644 index 7ee409ff8..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/clients/win8.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/clients/windowsphone.png b/MediaBrowser.WebDashboard/Html/css/images/clients/windowsphone.png Binary files differdeleted file mode 100644 index 1a31e55f6..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/clients/windowsphone.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/clients/windowsrt.png b/MediaBrowser.WebDashboard/Html/css/images/clients/windowsrt.png Binary files differdeleted file mode 100644 index 6a91da5e6..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/clients/windowsrt.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/cloudNetwork.png b/MediaBrowser.WebDashboard/Html/css/images/cloudNetwork.png Binary files differdeleted file mode 100644 index 2f917c1a0..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/cloudNetwork.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/currentUserDefaultBlack.png b/MediaBrowser.WebDashboard/Html/css/images/currentUserDefaultBlack.png Binary files differdeleted file mode 100644 index fff3f51a2..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/currentUserDefaultBlack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/currentUserDefaultWhite.png b/MediaBrowser.WebDashboard/Html/css/images/currentUserDefaultWhite.png Binary files differdeleted file mode 100644 index acfa26e9d..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/currentUserDefaultWhite.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/defaultCollectionImage.png b/MediaBrowser.WebDashboard/Html/css/images/defaultCollectionImage.png Binary files differdeleted file mode 100644 index d1e862a69..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/defaultCollectionImage.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/donatepp.png b/MediaBrowser.WebDashboard/Html/css/images/donatepp.png Binary files differdeleted file mode 100644 index c99d2ea13..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/donatepp.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/home.png b/MediaBrowser.WebDashboard/Html/css/images/home.png Binary files differdeleted file mode 100644 index 216608e42..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/home.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/iossplash.png b/MediaBrowser.WebDashboard/Html/css/images/iossplash.png Binary files differdeleted file mode 100644 index 981277891..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/iossplash.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/itemDetails/audioDefault.png b/MediaBrowser.WebDashboard/Html/css/images/itemDetails/audioDefault.png Binary files differdeleted file mode 100644 index 4e59c995e..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/itemDetails/audioDefault.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/itemDetails/gameDefault.png b/MediaBrowser.WebDashboard/Html/css/images/itemDetails/gameDefault.png Binary files differdeleted file mode 100644 index b08ade6e4..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/itemDetails/gameDefault.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/itemDetails/videoDefault.png b/MediaBrowser.WebDashboard/Html/css/images/itemDetails/videoDefault.png Binary files differdeleted file mode 100644 index b315bdf1a..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/itemDetails/videoDefault.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/leftArrowBlack.png b/MediaBrowser.WebDashboard/Html/css/images/leftArrowBlack.png Binary files differdeleted file mode 100644 index 91e4a2571..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/leftArrowBlack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/leftArrowWhite.png b/MediaBrowser.WebDashboard/Html/css/images/leftArrowWhite.png Binary files differdeleted file mode 100644 index 9f3140b17..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/leftArrowWhite.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/logindefault.png b/MediaBrowser.WebDashboard/Html/css/images/logindefault.png Binary files differdeleted file mode 100644 index 9e7311e4f..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/logindefault.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/mblogoicon.png b/MediaBrowser.WebDashboard/Html/css/images/mblogoicon.png Binary files differdeleted file mode 100644 index 95c49e437..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/mblogoicon.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/mblogotextblack.png b/MediaBrowser.WebDashboard/Html/css/images/mblogotextblack.png Binary files differdeleted file mode 100644 index cd22f437f..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/mblogotextblack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/mblogotextwhite.png b/MediaBrowser.WebDashboard/Html/css/images/mblogotextwhite.png Binary files differdeleted file mode 100644 index b1a7c8fc7..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/mblogotextwhite.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/media/nextTrack.png b/MediaBrowser.WebDashboard/Html/css/images/media/nextTrack.png Binary files differdeleted file mode 100644 index 173734fe0..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/media/nextTrack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/media/pause.png b/MediaBrowser.WebDashboard/Html/css/images/media/pause.png Binary files differdeleted file mode 100644 index 1f347cdef..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/media/pause.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/media/play.png b/MediaBrowser.WebDashboard/Html/css/images/media/play.png Binary files differdeleted file mode 100644 index 0a0529f2f..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/media/play.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/media/playCircle.png b/MediaBrowser.WebDashboard/Html/css/images/media/playCircle.png Binary files differdeleted file mode 100644 index 6d2ffd341..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/media/playCircle.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/media/previousTrack.png b/MediaBrowser.WebDashboard/Html/css/images/media/previousTrack.png Binary files differdeleted file mode 100644 index f5b47417f..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/media/previousTrack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/media/stop.png b/MediaBrowser.WebDashboard/Html/css/images/media/stop.png Binary files differdeleted file mode 100644 index ea6bcb96e..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/media/stop.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/movieFolder.png b/MediaBrowser.WebDashboard/Html/css/images/movieFolder.png Binary files differdeleted file mode 100644 index ac52cab35..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/movieFolder.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/notifications/cancelled.png b/MediaBrowser.WebDashboard/Html/css/images/notifications/cancelled.png Binary files differdeleted file mode 100644 index 319fd7fab..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/notifications/cancelled.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/notifications/done.png b/MediaBrowser.WebDashboard/Html/css/images/notifications/done.png Binary files differdeleted file mode 100644 index b64e558cd..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/notifications/done.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/notifications/download.png b/MediaBrowser.WebDashboard/Html/css/images/notifications/download.png Binary files differdeleted file mode 100644 index 780f72dcb..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/notifications/download.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/notifications/error.png b/MediaBrowser.WebDashboard/Html/css/images/notifications/error.png Binary files differdeleted file mode 100644 index c6b5693c4..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/notifications/error.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/notifications/info.png b/MediaBrowser.WebDashboard/Html/css/images/notifications/info.png Binary files differdeleted file mode 100644 index fb724718f..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/notifications/info.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/premiumflag.png b/MediaBrowser.WebDashboard/Html/css/images/premiumflag.png Binary files differdeleted file mode 100644 index e34fe810e..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/premiumflag.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/registerpp.png b/MediaBrowser.WebDashboard/Html/css/images/registerpp.png Binary files differdeleted file mode 100644 index e5ecaa863..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/registerpp.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/rightArrow.png b/MediaBrowser.WebDashboard/Html/css/images/rightArrow.png Binary files differdeleted file mode 100644 index f5771d419..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/rightArrow.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/stars.png b/MediaBrowser.WebDashboard/Html/css/images/stars.png Binary files differdeleted file mode 100644 index 4a31313f0..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/stars.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/suppbadge.png b/MediaBrowser.WebDashboard/Html/css/images/suppbadge.png Binary files differdeleted file mode 100644 index 9295ae07d..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/suppbadge.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/supporterflag.png b/MediaBrowser.WebDashboard/Html/css/images/supporterflag.png Binary files differdeleted file mode 100644 index 880d434d5..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/supporterflag.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/toolsBlack.png b/MediaBrowser.WebDashboard/Html/css/images/toolsBlack.png Binary files differdeleted file mode 100644 index 233e7ea17..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/toolsBlack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/toolsWhite.png b/MediaBrowser.WebDashboard/Html/css/images/toolsWhite.png Binary files differdeleted file mode 100644 index c55c16766..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/toolsWhite.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/touchicon.png b/MediaBrowser.WebDashboard/Html/css/images/touchicon.png Binary files differdeleted file mode 100644 index 3aca7a4d3..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/touchicon.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/touchicon114.png b/MediaBrowser.WebDashboard/Html/css/images/touchicon114.png Binary files differdeleted file mode 100644 index f18e9f05a..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/touchicon114.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/touchicon72.png b/MediaBrowser.WebDashboard/Html/css/images/touchicon72.png Binary files differdeleted file mode 100644 index 4987cb905..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/touchicon72.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/images/userFlyoutDefault.png b/MediaBrowser.WebDashboard/Html/css/images/userFlyoutDefault.png Binary files differdeleted file mode 100644 index f27a4bcb3..000000000 --- a/MediaBrowser.WebDashboard/Html/css/images/userFlyoutDefault.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/css/site.css b/MediaBrowser.WebDashboard/Html/css/site.css deleted file mode 100644 index 3a837e0c0..000000000 --- a/MediaBrowser.WebDashboard/Html/css/site.css +++ /dev/null @@ -1,836 +0,0 @@ -@font-face { - font-family: "Open Sans"; - font-style: normal; - font-weight: 700; - src: local("Open Sans Bold"), local("OpenSans-Bold"), url(http://themes.googleusercontent.com/static/fonts/opensans/v6/k3k702ZOKiLJc3WVjuplzJ1r3JsPcQLi8jytr04NNhU.woff) format('woff'); -} - -@font-face { - font-family: "Open Sans"; - font-style: normal; - font-weight: 300; - src: local("Open Sans Light"), local("OpenSans-Light"), url(http://themes.googleusercontent.com/static/fonts/opensans/v6/DXI1ORHCpsQm3Vp6mXoaTZ1r3JsPcQLi8jytr04NNhU.woff) format('woff'); -} - -@font-face { - font-family: "Open Sans"; - font-style: normal; - font-weight: 800; - src: local("Open Sans Extrabold"), local("OpenSans-Extrabold"), url(http://themes.googleusercontent.com/static/fonts/opensans/v6/EInbV5DfGHOiMmvb1Xr-hp1r3JsPcQLi8jytr04NNhU.woff) format('woff'); -} - -@font-face { - font-family: "Open Sans"; - font-style: normal; - font-weight: 400; - src: local("Open Sans"), local("OpenSans"), url(http://themes.googleusercontent.com/static/fonts/opensans/v6/K88pR3goAWT7BTt32Z01mz8E0i7KZn-EPnyo3HZu7kw.woff) format('woff'); -} - -body { - overflow-y: scroll!important; -} - -h1 { - font-family: 'Segoe UI Light', 'Open Sans', Arial, Helvetica, sans-serif; - font-weight: 200; - font-size: 32pt; -} - -.toolsSidebar h1 { - font-size: 42pt; -} - -.ui-loader h1 { - font-weight: bold; - font-family: Arial; -} - -h2 { - font-family: 'Segoe UI Semiight', 'Open Sans', Arial, Helvetica, sans-serif; - font-weight: 400; - font-size: 22pt; -} - -pre, textarea.pre { - display: block; - padding: 8.5px; - font-size: 12.025px; - line-height: 18px; - word-break: break-all; - word-wrap: break-word; - white-space: pre; - white-space: pre-wrap; - background-color: #f5f5f5; - border: 1px solid #ccc; - border: 1px solid rgba(0, 0, 0, 0.15); - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - font-family: Menlo, Monaco, Consolas, "Courier New", monospace; - color: #000; -} - -.type-interior h2 { - color: #1B58B8; -} - -/* - Page / Base styles - */ -.page { - background: #f2f2f2; - background-attachment: fixed; -} - -.libraryPage, .itemListContent { - background: #262626!important; - background-attachment: fixed!important; -} - - .libraryPage .interiorLink { - color: #2489ce; - font-weight: bold; - } - -/* - Header - */ -.header { - padding: 10px 0 10px 10px; -} - -.imgLogoIcon { - height: 45px; -} - -.imgLogoText { - height: 45px; - display: none; - margin-left: 5px; -} - - -.ui-popup-container { - z-index: 99999; -} - -.headerButtons { - float: right; - position: absolute; - top: 10px; - right: 10px; -} - -.header .imageLink { - display: inline-block; -} - -.imageLink + .imageLink { - margin-left: 30px; -} - -.header .imageLink img { - height: 32px; - vertical-align: middle; -} - -.imageLink.supporter { - display:none; -} - -.btnCurrentUser { - text-decoration: none; -} - -.currentUsername { - margin-right: 7px; - font-size: 20px; - color: #000; - position: relative; - top: 4px; -} - -.libraryPage .currentUsername { - color: #fff; -} - -h1 .imageLink { - margin-left: 15px; -} - - h1 .imageLink img { - height: 32px; - } - -.imageLink:hover { - opacity: .5; -} - -.type-home h1, .listHeader { - margin-top: 1.25em; - margin-bottom: 10px; - padding-bottom: 5px; - font-weight: normal; - border-bottom: 1px solid #777; -} - -.libraryPage .ui-content > h1:first-child { - margin-top: 0; -} - -.pageTitle { - margin-top: 0; -} - -.imageButton { - background: transparent; - border: 0; - padding: 0; - cursor: pointer; - cursor: hand; -} - - .imageButton:hover { - opacity: .5; - } - - .imageButton[disabled], .imageButton[disabled]:hover { - opacity: .3!important; - cursor: default; - } - -/* - Forms - */ -form, .readOnlyContent { - max-width: 600px; -} - -.fieldDescription { - font-size: 11px; - padding-left: 5px; -} - -.ulForm { - margin-bottom: 20px!important; -} - - .ulForm li:not(.ui-li-divider) { - background: none; - border-top: none; - border-bottom: none; - } - -.popup .ulForm { - margin-bottom: 0!important; -} - -.popup .ui-content { - padding: 20px; -} - -.content-secondary { - z-index: 99996; - background: #262626; - border: 0; - margin-top: 40px; -} - - .content-secondary h1 { - margin: 0; - padding: 20px 0 20px 30px; - color: #fff; - } - -.sidebarLinks a { - display: block; - padding: 12px 15px 12px 30px; - text-decoration: none; - color: #fff!important; - text-shadow: none!important; - font-weight: normal!important; - font-size: 17px; -} - - .sidebarLinks a:hover { - background: #f2f2f2; - color: #000!important; - } - - .sidebarLinks a.selectedSidebarLink { - background: #2572EB!important; - color: #fff!important; - } - -/* Tabs (e.g. advanced metadata page) */ -.localnav { - margin-bottom: 40px!important; -} - - .localnav + form { - margin-top: -10px; - } - -.page > .ui-content { - padding-bottom: 100px; -} - -@media all and (min-width: 650px) { - - .imgLogoIcon { - height: 50px; - } - - .imgLogoText { - height: 50px; - display: inline; - } - - .imageLink.supporter { - display:inline-block; - } - - .header { - padding-left: 30px; - padding-top: 15px; - padding-bottom: 15px; - } - - .headerButtons { - top: 20px; - right: 30px; - } - - .libraryPage .ui-content { - padding-right: 50px; - padding-left: 50px; - } - - .type-interior > .ui-content { - padding-right: 0; - padding-left: 0; - padding-top: 0; - overflow: hidden; - } - - .content-secondary { - text-align: left; - width: 45%; - position: fixed; - top: 0; - left: 0; - bottom: 0; - margin: 0; - } - - .content-primary { - width: 45%; - float: right; - padding: 0 6% 3em 0; - margin: 0; - } - - .content-primary ul:first-child { - margin-top: 0; - } -} - -@media all and (min-width: 750px) { - - .content-secondary { - width: 34%; - } - - .content-primary { - width: 56%; - } -} - -@media all and (min-width: 1200px) { - - - .content-secondary { - width: 30%; - } - - .content-primary { - width: 60%; - } -} - -@media all and (min-width: 1440px) { - - - .content-secondary { - width: 25%; - } - - .content-primary { - width: 65%; - } -} - -@media all and (min-width: 1920px) { - - - .content-secondary { - width: 20%; - } - - .content-primary { - width: 70%; - } -} - -/* - Media Library Page - */ -.mediaFolderButtons { - margin-top: 10px; -} - -.mediaFolderLocations { - margin: 1em .25em!important; -} - -.mediaLocationsHeader { - padding-top: .75em!important; - padding-bottom: .75em!important; -} - - .mediaLocationsHeader .ui-btn { - position: absolute; - right: 3px; - margin-top: 0!important; - margin-bottom: 0!important; - top: 6px; - } - -#divVirtualFolders .ui-btn-inner, .mediaLocationsHeader, #divVirtualFolders .ui-btn-text { - font-size: 14px; -} - -#ulDirectoryPickerList a { - padding-top: .4em; - padding-bottom: .4em; - font-size: 15px; -} - -/* - Plugin updates Page - */ -#pluginUpdatesForm table { - width: 100%; -} - -#pluginUpdatesForm td + td { - text-align: center; -} - - -/* - List Vew Items - */ - -.posterViewItem { - display: inline-block; - margin: 5px; - text-align: center; - font-size: 15px; - padding: 0; - position: relative; - padding-bottom: 28px; -} - -.posterViewItemWithDualText { - padding-bottom: 56px; -} - -.posterViewItemWithNoText { - padding-bottom: 0!important; -} - -.posterViewItem a { - color: white!important; - font-weight: normal!important; - text-decoration: none; -} - -.posterViewItem img { - max-width: 155px; - max-height: 148px; - vertical-align: bottom; -} - -.premiumBanner img { - position: absolute; - text-align: right; - top: 0; - right: 0; - width: 75px!important; - height: 75px!important; - max-width: 75px!important; - max-height: 75px!important; -} - -.posterViewItemText { - text-overflow: ellipsis; - overflow: hidden; - text-wrap: none; - white-space: nowrap; - margin: 0; - padding: 4px 2px 0; - position: absolute; - bottom: 0; - left: 0; - right: 0; - height: 24px; - background: #181818; - text-shadow: none; -} - -.posterViewItemPrimaryText { - bottom: 28px; -} - -.posterViewItem:hover, .userItem:hover { - -moz-box-shadow: 0 0 20px 3px #2572EB; - -webkit-box-shadow: 0 0 20px 3px #2572EB; - box-shadow: 0 0 20px 3px #2572EB; -} - -@media all and (min-width: 750px) { - - .posterViewItem { - font-size: 16px; - padding-bottom: 29px; - } - - .posterViewItemWithDualText { - padding-bottom: 58px; - } - - .posterViewItemText { - padding-top: 5px; - } - - .posterViewItemPrimaryText { - bottom: 29px; - } - - .posterViewItem img { - max-width: 190px; - max-height: 190px; - } -} - -@media all and (min-width: 1200px) { - - .posterViewItem { - font-size: 17px; - } - - .posterViewItem img { - max-width: 280px; - max-height: 250px; - } -} - -@media all and (min-width: 1920px) { - - .posterViewItem { - font-size: 19px; - padding-bottom: 33px; - } - - .posterViewItemWithDualText { - padding-bottom: 66px; - } - - .posterViewItemPrimaryText { - bottom: 33px; - } - - .posterViewItemText { - height: 28px; - } - - .posterViewItem img { - max-width: 352px; - max-height: 300px; - } -} - -/* Startup wizard */ -.wizardPage { - background: #e2e2e2; -} - -.wizardContent { - max-width: 800px; - padding: .5em 2em 1em; - margin: 0 auto; - background: #f2f2f2; -} - -.wizardNavigation { - text-align: right; -} - -.wizardContent form { - max-width: 100%; -} - -.wizardContent p { - margin: 2em 0; -} - -.wizardContent h2 img { - height: 35px; - vertical-align: middle; - margin-right: .5em; - position: relative; - top: -3px; -} - -/* User Image */ -.imageDropZone { - border: 2px dashed #bbb; - -moz-border-radius: 5px; - -webkit-border-radius: 5px; - border-radius: 5px; - padding: 25px; - text-align: center; - color: #bbb; -} - -/* Dashboard home */ -.tblConnections td { - padding: .5em 0 .5em 1.25em; -} - - .tblConnections td:first-child { - padding-left: 0; - } - -.tblConnections img { - height: 50px; -} - -.clientNowPlayingImage { - border-radius: 5px; - border: 2px solid #ccc; -} - -/* Footer */ -#footer { - background: #5a5a5a; - position: fixed; - bottom: -2px; - left: -2px; - right: -2px; - z-index: 99997; -} - -.footerNotification { - text-shadow: none; - padding: .5em 1em; - margin: 0; - font-weight: normal; - border-top: 1px solid #999; -} - -.notificationIcon { - height: 24px; - margin-right: 1em; - vertical-align: middle; -} - -/* - * Gradient Shadow - */ - -/* All HTML5 progress enabled browsers */ -progress { - /* Turns off styling - not usually needed, but good to know. */ - appearance: none; - -moz-appearance: none; - -webkit-appearance: none; - /* gets rid of default border in Firefox and Opera. */ - border: solid #cccccc 2px; - border-radius: 4px; - margin: 0; -} - - /* Polyfill */ - progress[role]:after { - background-image: none; /* removes default background from polyfill */ - } - -/* - * Background of the progress bar background - */ - -/* Firefox and Polyfill */ -progress { - background: #cccccc !important; /* !important only needed in polyfill */ -} - - /* Chrome */ - progress::-webkit-progress-bar { - background: #cccccc; - } - - /* - * Background of the progress bar value - */ - - /* Firefox */ - progress::-moz-progress-bar { - border-radius: 5px; - background-image: -moz-linear-gradient( center bottom, rgb(43,194,83) 37%, rgb(84,240,84) 69% ); - } - - /* Chrome */ - progress::-webkit-progress-value { - border-radius: 5px; - background-image: -webkit-gradient( linear, left bottom, left top, color-stop(0, rgb(43,194,83)), color-stop(1, rgb(84,240,84)) ); - background-image: -webkit-linear-gradient( center bottom, rgb(43,194,83) 37%, rgb(84,240,84) 69% ); - } - - /* Polyfill */ - progress[aria-valuenow]:before { - border-radius: 5px; - background-image: -moz-linear-gradient( center bottom, rgb(43,194,83) 37%, rgb(84,240,84) 69% ); - background-image: -ms-linear-gradient( center bottom, rgb(43,194,83) 37%, rgb(84,240,84) 69% ); - background-image: -o-linear-gradient( center bottom, rgb(43,194,83) 37%, rgb(84,240,84) 69% ); - } - -/* Detail Page*/ - -.itemDetailImage { - max-width: 100%; - max-height: 400px; -} - -.itemImageBlock { - vertical-align: top; -} - -.itemDetailBlock { - vertical-align: top; - padding-top: 1em; -} - - .itemDetailBlock p { - margin-top: 0; - } - -.starRating { - background-image: url(); - background-position: left center; - background-repeat: no-repeat; - width: 24px; - height: 20px; - display: inline-block; - background-size: cover; -} - -.galleryImage { - width: 120px; - display: inline-block; - margin: 5px; -} - -.halfStarRating { - background-position: center center; -} - -.emptyStarRating { - background-position: right center; -} - -@media all and (min-width: 650px) { - .itemImageBlock { - display: inline-block; - } - - .itemDetailImage, .itemImageBlock { - max-width: 220px; - } - - .itemDetailBlock { - padding-top: 0; - display: inline-block; - width: 45%; - padding-left: 20px; - max-width: 800px; - } - - .galleryImage { - width: 150px; - } -} - -@media all and (min-width: 750px) { - - .itemDetailImage, .itemImageBlock { - max-width: 300px; - } - - .itemDetailBlock { - padding-left: 30px; - } -} - - -@media all and (min-width: 1200px) { - - .itemDetailImage, .itemImageBlock { - max-width: 400px; - } - - .itemDetailBlock { - width: 55%; - } - - .galleryImage { - width: 200px; - } -} - -/* Now playing bar */ -#nowPlayingBar { - padding: 10px 20px 8px; - border-top: 1px solid #5490CC; -} - -.mediaButton { - margin: 0 20px 0 0; - display: inline-block; -} - -#mediaElement { - margin-right: 20px; - display: inline-block; - position: relative; -} - -.mediaButton img { - height: 28px; -} - -.itemVideo { - position: absolute; - z-index: 99998; - height: auto; - width: 180px; - bottom: -5px; -} - -@media all and (min-width: 650px) { - - .itemVideo { - width: 270px; - } -} diff --git a/MediaBrowser.WebDashboard/Html/dashboard.html b/MediaBrowser.WebDashboard/Html/dashboard.html deleted file mode 100644 index 693af7d26..000000000 --- a/MediaBrowser.WebDashboard/Html/dashboard.html +++ /dev/null @@ -1,57 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Dashboard</title> -</head> -<body> - <div id="dashboardPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - <div class="content-primary"> - <div class="readOnlyContent"> - <div data-role="collapsible" data-content-theme="c" data-collapsed="false" style="margin-top: 2em;"> - <h3>Server Information</h3> - <div> - <p> - Version <span id="appVersionNumber"></span> - </p> - <p id="pUpToDate" style="display: none;"> - <img src="css/images/checkMarkGreen.png" style="height: 20px; margin-right: 3px; position: relative; top: 4px;" /> - Media Browser Server is up to date - </p> - <div id="pUpdateNow" style="display: none;"> - <p><strong>A new version of Media Browser Server is available!</strong></p> - <p id="newVersionNumber"></p> - <button id="btnUpdateApplication" type="button" data-icon="download" data-theme="b" onclick="DashboardPage.updateApplication();">Update Now</button> - </div> - <div id="pPluginUpdates"></div> - </div> - </div> - - <div id="collapsiblePendingInstallations" data-role="collapsible" data-content-theme="c" data-collapsed="false" style="margin-top: 2em; display: none;"> - <h3>Pending Installations</h3> - <p>The following components have been installed or updated:</p> - <div id="pendingInstallations"> - </div> - <p>Please restart the server to finish applying updates.</p> - <button type="button" data-icon="refresh" data-theme="b" onclick="Dashboard.restartServer();">Restart Now</button> - </div> - - <div data-role="collapsible" data-content-theme="c" data-collapsed="false" style="margin-top: 2em;"> - <h3>Active Users</h3> - <div id="divConnections"> - </div> - </div> - - <div data-role="collapsible" data-content-theme="c" data-collapsed="false" style="margin-top: 2em;"> - <h3>Running Tasks</h3> - <div id="divRunningTasks"> - </div> - <p><a href="scheduledTasks.html">Manage Scheduled Tasks</a></p> - </div> - </div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/editUser.html b/MediaBrowser.WebDashboard/Html/editUser.html deleted file mode 100644 index 85ae14132..000000000 --- a/MediaBrowser.WebDashboard/Html/editUser.html +++ /dev/null @@ -1,63 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title></title> -</head> -<body> - <div id="editUserPage" data-role="page" class="page type-interior userProfilesConfigurationPage"> - - <div data-role="content"> - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" id="userProfileNavigation" style="display: none;" data-mini="true"> - <a href="#" data-role="button" class="ui-btn-active">Profile</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('userImage.html', true);">Image</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('updatePassword.html', true);">Password</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('library.html', true);">Media Library</a> - </div> - <form id="editUserProfileForm"> - <ul data-role="listview" class="ulForm"> - <li id="fldUserName"> - <label for="txtUserName">Name: </label> - <input id="txtUserName" name="txtUserName" required="required" type="text" /> - </li> - <li id="fldMaxParentalRating" style="display: none;"> - <label for="selectMaxParentalRating">Max parental rating:</label> - <select name="selectMaxParentalRating" id="selectMaxParentalRating"></select> - </li> - <li id="fldIsAdmin" style="display: none;"> - <input type="checkbox" id="chkIsAdmin" name="chkIsAdmin" /> - <label for="chkIsAdmin">Allow this user to manage the server</label> - </li> - </ul> - <h2>Video Playback Settings</h2> - <ul data-role="listview" class="ulForm"> - <li> - <label for="selectAudioLanguage">Audio language preference: </label> - <select name="selectAudioLanguage" id="selectAudioLanguage"></select> - </li> - <li> - <label for="selectSubtitleLanguage">Subtitle language preference: </label> - <select name="selectSubtitleLanguage" id="selectSubtitleLanguage"></select> - </li> - <li> - <input type="checkbox" id="chkForcedSubtitlesOnly" name="chkForcedSubtitlesOnly" /> - <label for="chkForcedSubtitlesOnly">Display only forced subtitles</label> - </li> - <li> - <button type="submit" data-theme="b" data-icon="ok"> - Save - </button> - <button type="button" onclick="history.back();" data-icon="delete"> - Cancel - </button> - </li> - </ul> - </form> - </div> - </div> - <script type="text/javascript"> - $('#editUserProfileForm').on('submit', EditUserPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/favicon.ico b/MediaBrowser.WebDashboard/Html/favicon.ico Binary files differdeleted file mode 100644 index 1541dabdc..000000000 --- a/MediaBrowser.WebDashboard/Html/favicon.ico +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/index.html b/MediaBrowser.WebDashboard/Html/index.html deleted file mode 100644 index 960f49533..000000000 --- a/MediaBrowser.WebDashboard/Html/index.html +++ /dev/null @@ -1,33 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Media Browser</title> -</head> -<body> - <div id="indexPage" data-role="page" class="page type-home libraryPage" data-theme="a"> - <div data-role="content"> - <h1>What's New <a href="#" class="imageLink"> - <img src="css/images/rightArrow.png" /></a></h1> - - <div id="divWhatsNew"></div> - - <div id="divResumable" style="display: none;"> - <h1>Resume <a href="#" class="imageLink"> - <img src="css/images/rightArrow.png" /></a></h1> - - <div id="divResumableItems"></div> - </div> - - <h1>My Library <a href="#" class="imageLink"> - <img src="css/images/rightArrow.png" /></a></h1> - - <div id="divMyLibrary"></div> - - <h1>Collections <a href="#" class="imageLink"> - <img src="css/images/rightArrow.png" /></a></h1> - - <div id="divCollections"></div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/itemDetails.html b/MediaBrowser.WebDashboard/Html/itemDetails.html deleted file mode 100644 index b1c4b32e9..000000000 --- a/MediaBrowser.WebDashboard/Html/itemDetails.html +++ /dev/null @@ -1,66 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title></title> -</head> -<body> - <div id="itemDetailPage" data-role="page" class="page libraryPage" data-theme="a"> - <div data-role="content" style="padding-top: 0;"> - - <h1 id="itemName" style="padding-left: 10px; margin: 0;"></h1> - - <div style="padding: 10px;"> - <div class="itemImageBlock"> - <div id="itemMedia" style="position: relative;"> - <div id="itemImage"></div> - <div id="playButtonShadow" style="display: none; height: 48px; position: absolute; bottom: 0; left: 0; right: 0; background: black; opacity: .75;"> - </div> - <button id="btnPlay" type="button" class="imageButton" style="display: none; position: absolute; bottom: 5px; left: 10px;" data-role="none" title="Play" onclick="ItemDetailPage.play();"> - <img src="css/images/media/playCircle.png" style="height: 28px;" /> - </button> - </div> - </div> - - <div class="itemDetailBlock"> - - <p id="itemTagline" style="font-style: italic;"></p> - <p id="itemOverview"></p> - <p id="itemCommunityRating"></p> - <p id="itemMiscInfo" style="color: #ddd; font-size: 14px;"></p> - - <p id="itemGenres"> - </p> - - <p id="itemStudios"> - </p> - </div> - </div> - - <div data-role="collapsible" data-content-theme="a" id="mediaInfoCollapsible"> - <h3>Media Info</h3> - <div id="mediaInfoContent"></div> - </div> - <div data-role="collapsible" data-content-theme="a" id="scenesCollapsible"> - <h3>Scenes</h3> - <div id="scenesContent"></div> - </div> - <div data-role="collapsible" data-content-theme="a"> - <h3>Special Features</h3> - <p>I'm the collapsible content. By default I'm closed, but you can click the header to open me.</p> - </div> - <div data-role="collapsible" data-content-theme="a"> - <h3>Trailers</h3> - <p>I'm the collapsible content. By default I'm closed, but you can click the header to open me.</p> - </div> - <div data-role="collapsible" data-content-theme="a"> - <h3>Cast & Crew</h3> - <p>I'm the collapsible content. By default I'm closed, but you can click the header to open me.</p> - </div> - <div data-role="collapsible" data-content-theme="a" id="galleryCollapsible"> - <h3>Gallery</h3> - <div id="galleryContent"></div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/itemList.html b/MediaBrowser.WebDashboard/Html/itemList.html deleted file mode 100644 index 4be44b821..000000000 --- a/MediaBrowser.WebDashboard/Html/itemList.html +++ /dev/null @@ -1,23 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title></title> -</head> -<body> - <div id="itemListPage" data-role="page" class="page libraryPage" data-theme="a"> - <div data-role="content" class="itemListContent"> - <div style="text-align: right;"> - <button type="button" onclick="$( '#optionsPanel', $.mobile.activePage ).panel( 'open' );" data-mini="true" data-inline="true">Options</button> - </div> - <h1 id="itemName" class="listHeader"></h1> - - - <div id="listItems"></div> - </div> - - <div data-role="panel" id="optionsPanel" data-position="right" data-display="overlay" data-position-fixed="true" data-theme="a"> - <div>Panel content</div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/library.html b/MediaBrowser.WebDashboard/Html/library.html deleted file mode 100644 index 9ba35b03a..000000000 --- a/MediaBrowser.WebDashboard/Html/library.html +++ /dev/null @@ -1,57 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title> </title> -</head> -<body> - <div id="mediaLibraryPage" data-role="page" class="page type-interior mediaLibraryPage"> - - <div data-role="content"> - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" id="userProfileNavigation" style="display: none;" data-mini="true"> - <a href="#" data-role="button" onclick="Dashboard.navigate('editUser.html', true);">Profile</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('userImage.html', true);">Image</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('updatePassword.html', true);">Password</a> - <a href="#" data-role="button" class="ui-btn-active">Media Library</a> - </div> - <div class="readOnlyContent"> - <p id="fldUseDefaultLibrary" style="display: none;"> - <input type="checkbox" id="chkUseDefaultLibrary" name="chkUseDefaultLibrary" onchange="MediaLibraryPage.setUseDefaultMediaLibrary(this.checked);" /> - <label for="chkUseDefaultLibrary">Use default media library</label> - </p> - <div id="divMediaLibrary"> - <p>Below are your media collections. Expand a collection to add or remove media locations assigned to it.</p> - <p> - <button type="button" data-icon="plus" onclick="MediaLibraryPage.addVirtualFolder();">Add media collection</button> - </p> - <div id="divVirtualFolders"></div> - </div> - </div> - </div> - </div> - <div data-role="popup" id="popupEnterText" class="ui-corner-all popup"> - - <div class="ui-corner-top ui-bar-a" style="text-align: center; padding: 0 20px;"> - <h3>Rename</h3> - </div> - - <div data-role="content" class="ui-corner-bottom ui-content"> - <form id="textEntryForm"> - <label for="txtValue">New name:</label> - <input type="text" name="txtValue" id="txtValue" required="required" /> - - <p> - <button type="submit" data-theme="b" data-icon="ok"> - Ok - </button> - <button type="button" data-icon="delete" onclick="$(this).parents('.popup').popup('close');"> - Cancel - </button> - </p> - </form> - </div> - - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/log.html b/MediaBrowser.WebDashboard/Html/log.html deleted file mode 100644 index 0cc5bbbf1..000000000 --- a/MediaBrowser.WebDashboard/Html/log.html +++ /dev/null @@ -1,31 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Log File</title> -</head> -<body> - <div id="logPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="support.html" data-role="button">General</a> - <a href="log.html" data-role="button" class="ui-btn-active">View Log</a> - <a href="supporter.html" data-role="button">Become a Supporter</a> - <a href="supporterKey.html" data-role="button">Supporter Key</a> - <a href="about.html" data-role="button">About</a> - </div> - <p> - <label for="chkAutoScroll">Auto-scroll</label> - <input type="checkbox" id="chkAutoScroll" onchange="LogPage.updateAutoScroll(this.checked);" name="chkAutoScroll" data-inline="true" /> - </p> - <textarea id="logContents" class="pre" style="overflow-y:hidden;"></textarea> - <p> - <label for="chkAutoScrollBottom">Auto-scroll</label> - <input type="checkbox" id="chkAutoScrollBottom" name="chkAutoScrollBottom" onchange="LogPage.updateAutoScroll(this.checked);" data-inline="true" /> - </p> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/login.html b/MediaBrowser.WebDashboard/Html/login.html deleted file mode 100644 index 36c453d55..000000000 --- a/MediaBrowser.WebDashboard/Html/login.html +++ /dev/null @@ -1,39 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Sign In</title> -</head> -<body> - <div id="loginPage" data-role="page" class="page standalonePage"> - - <div data-role="content"> - <div id="divUsers" style="margin: 50px 0px 20px; text-align: center;"></div> - </div> - - <div data-role="popup" id="popupLogin" class="ui-corner-all popup"> - <form id="loginForm"> - <div class="ui-corner-top ui-bar-a" style="text-align: center;"> - <h3>Please sign in</h3> - </div> - <div data-role="content" class="ui-corner-bottom ui-content"> - <label for="pw" class="ui-hidden-accessible">Password:</label> - <input type="password" name="pw" id="pw" value="" placeholder="password" /> - - <p> - <button type="submit" data-theme="b" data-icon="ok"> - Sign in - </button> - <button type="button" data-icon="delete" onclick="$(this).parents('.popup').popup('close');"> - Cancel - </button> - </p> - </div> - </form> - </div> - - <script type="text/javascript"> - $('#loginForm').on('submit', LoginPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/metadata.html b/MediaBrowser.WebDashboard/Html/metadata.html deleted file mode 100644 index 15b2943e4..000000000 --- a/MediaBrowser.WebDashboard/Html/metadata.html +++ /dev/null @@ -1,56 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Metadata</title> -</head> -<body> - <div id="metadataConfigurationPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="metadata.html" data-role="button" class="ui-btn-active">Basics</a> - <a href="metadataImages.html" data-role="button">Images</a> - <a href="advancedMetadata.html" data-role="button">Advanced</a> - </div> - - <form id="metadataConfigurationForm"> - <ul data-role="listview" class="ulForm"> - <li> - <input type="checkbox" id="chkEnableInternetProviders" name="chkEnableInternetProviders" onchange="MetadataConfigurationPage.submit();" /> - <label for="chkEnableInternetProviders">Download metadata from the internet </label> - </li> - <li> - <input type="checkbox" id="chkSaveLocal" name="chkSaveLocal" onchange="MetadataConfigurationPage.submit();" /> - <label for="chkSaveLocal">Save metadata within media folders </label> - </li> - <li> - <label for="txtRefreshDays">Metadata refresh period (days): </label> - <input type="number" id="txtRefreshDays" name="txtRefreshDays" pattern="[0-9]*" required="required" min="1" onchange="MetadataConfigurationPage.submit();" /> - </li> - <li> - <label for="selectLanguage">Preferred language: </label> - <select name="selectLanguage" id="selectLanguage" onchange="MetadataConfigurationPage.submit();"></select> - </li> - <li> - <label for="selectCountry">Country: </label> - <select name="selectCountry" id="selectCountry" onchange="MetadataConfigurationPage.submit();"></select> - </li> - <li style="display: none;"> - <button class="btnSubmit" type="submit" data-theme="b"> - Save - </button> - </li> - </ul> - </form> - </div> - - </div> - - <script type="text/javascript"> - $('#metadataConfigurationForm').on('submit', MetadataConfigurationPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/metadataImages.html b/MediaBrowser.WebDashboard/Html/metadataImages.html deleted file mode 100644 index 41cf20616..000000000 --- a/MediaBrowser.WebDashboard/Html/metadataImages.html +++ /dev/null @@ -1,164 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Metadata</title> -</head> -<body> - <div id="metadataImagesConfigurationPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="metadata.html" data-role="button">Basics</a> - <a href="metadataImages.html" data-role="button" class="ui-btn-active">Images</a> - <a href="advancedMetadata.html" data-role="button">Advanced</a> - </div> - - <form id="metadataImagesConfigurationForm"> - <ul data-role="listview" class="ulForm"> - <li> - <input type="checkbox" id="chkRefreshItemImages" name="chkRefreshItemImages" onchange="MetadataImagesPage.submit();" /> - <label for="chkRefreshItemImages">Refresh existing images </label> - <div class="fieldDescription"> - When enabled, images will be refreshed periodically - </div> - </li> - <li> - <label for="txtNumbackdrops">Max number of backdrops per item: </label> - <input type="number" id="txtNumbackdrops" name="txtNumbackdrops" pattern="[0-9]*" required="required" min="1" onchange="MetadataImagesPage.submit();" /> - </li> - </ul> - <p>Enable additional image downloading:</p> - <div data-role="collapsible"> - <h3>Movies</h3> - <div data-role="controlgroup"> - <input type="checkbox" data-mini="true" id="chkDownloadMovieArt" name="chkDownloadMovieArt" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadMovieArt">Movie Art</label> - - <input type="checkbox" data-mini="true" id="chkDownloadMovieBanner" name="chkDownloadMovieBanner" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadMovieBanner">Movie Banner</label> - - <input type="checkbox" data-mini="true" id="chkDownloadMovieDisc" name="chkDownloadMovieDisc" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadMovieDisc">Movie Disc</label> - - <input type="checkbox" data-mini="true" id="chkDownloadMovieLogo" name="chkDownloadMovieLogo" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadMovieLogo">Movie Logo</label> - - <input type="checkbox" data-mini="true" id="chkDownloadMovieThumb" name="chkDownloadMovieThumb" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadMovieThumb">Movie Thumb</label> - - - </div> - </div> - - <div data-role="collapsible"> - <h3>TV Series</h3> - <div data-role="controlgroup"> - <input type="checkbox" data-mini="true" id="chKDownloadTVArt" name="chKDownloadTVArt" onchange="MetadataImagesPage.submit();" /> - <label for="chKDownloadTVArt">TV Series Art</label> - - <input type="checkbox" data-mini="true" id="chkDownloadTVBanner" name="chkDownloadTVBanner" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadTVBanner">TV Series Banner</label> - - <input type="checkbox" data-mini="true" id="chkDownloadTVLogo" name="chkDownloadTVLogo" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadTVLogo">TV Series Logo</label> - - <input type="checkbox" data-mini="true" id="chkDownloadTVThumb" name="chkDownloadTVThumb" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadTVThumb">TV Series Thumb</label> - </div> - </div> - - - <div data-role="collapsible"> - <h3>TV Seasons</h3> - <div data-role="controlgroup"> - <input type="checkbox" data-mini="true" id="chkDownloadSeasonBackdrops" name="chkDownloadSeasonBackdrops" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadSeasonBackdrops">TV Season Backdrops</label> - - <input type="checkbox" data-mini="true" id="chkDownloadSeasonBanner" name="chkDownloadSeasonBanner" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadSeasonBanner">TV Season Banner</label> - - <input type="checkbox" data-mini="true" id="chkDownloadSeasonThumb" name="chkDownloadSeasonThumb" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadSeasonThumb">TV Season Thumb</label> - </div> - - </div> - - <div data-role="collapsible"> - <h3>Music Artists</h3> - <div data-role="controlgroup"> - <input type="checkbox" data-mini="true" id="chkDownloadArtistThumb" name="chkDownloadArtistThumb" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadArtistThumb">Music Artist Thumb (primary image)</label> - - <input type="checkbox" data-mini="true" id="chkDownloadArtistBackdrops" name="chkDownloadArtistBackdrops" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadArtistBackdrops">Music Artist Backdrops</label> - - <input type="checkbox" data-mini="true" id="chkDownloadArtistLogo" name="chkDownloadArtistLogo" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadArtistLogo">Music Artist Logo</label> - - <input type="checkbox" data-mini="true" id="chkDownloadArtistBanner" name="chkDownloadArtistBanner" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadArtistBanner">Music Artist Banner</label> - </div> - - </div> - <div data-role="collapsible"> - <h3>Music Albums</h3> - <div data-role="controlgroup"> - <input type="checkbox" data-mini="true" id="chkDownloadAlbumPrimary" name="chkDownloadAlbumPrimary" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadAlbumPrimary">Music Album Cover</label> - - <input type="checkbox" data-mini="true" id="chkDownloadAlbumBackdrops" name="chkDownloadAlbumBackdrops" onchange="MetadataImagesPage.submit();" /> - <label for="chkDownloadAlbumBackdrops">Music Album Backdrops</label> - </div> - - </div> - <br /> - <br /> - <ul data-role="listview" class="ulForm"> - <li> - <label for="selectTmdbPosterDownloadSize">Tmdb poster download size: </label> - <select id="selectTmdbPosterDownloadSize" name="selectTmdbPosterDownloadSize" onchange="MetadataImagesPage.submit();"> - <option value="original">original</option> - <option value="w92">w92</option> - <option value="w154">w154</option> - <option value="w185">w185</option> - <option value="w342">w342</option> - <option value="w500">w500</option> - </select> - </li> - <li> - <label for="selectTmdbBackdropDownloadSize">Tmdb backdrop download size: </label> - <select id="selectTmdbBackdropDownloadSize" name="selectTmdbBackdropDownloadSize" onchange="MetadataImagesPage.submit();"> - <option value="original">original</option> - <option value="w380">w380</option> - <option value="w780">w780</option> - <option value="w1280">w1280</option> - </select> - </li> - <li> - <label for="selectTmdbPersonImageDownloadSize">Tmdb person image download size: </label> - <select id="selectTmdbPersonImageDownloadSize" name="selectTmdbPersonImageDownloadSize" onchange="MetadataImagesPage.submit();"> - <option value="original">original</option> - <option value="w45">w45</option> - <option value="w185">w185</option> - <option value="h632">h632</option> - </select> - </li> - <li style="display: none;"> - <button class="btnSubmit" type="submit" data-theme="b"> - Save - </button> - </li> - </ul> - </form> - </div> - - </div> - - <script type="text/javascript"> - $('#metadataImagesConfigurationForm').on('submit', MetadataImagesPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/pluginCatalog.html b/MediaBrowser.WebDashboard/Html/pluginCatalog.html deleted file mode 100644 index 1b5ad7428..000000000 --- a/MediaBrowser.WebDashboard/Html/pluginCatalog.html +++ /dev/null @@ -1,22 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Plugins</title> -</head> -<body> - <div id="pluginCatalogPage" data-role="page" class="page type-interior pluginConfigurationPage"> - - <div data-role="content"> - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="plugins.html" data-role="button">Installed Plugins</a> - <a href="pluginCatalog.html" data-role="button" class="ui-btn-active">Plugin Catalog</a> - <a href="pluginUpdates.html" data-role="button">Automatic Updates</a> - </div> - - <div id="pluginTiles"></div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/pluginUpdates.html b/MediaBrowser.WebDashboard/Html/pluginUpdates.html deleted file mode 100644 index ed5ba54b1..000000000 --- a/MediaBrowser.WebDashboard/Html/pluginUpdates.html +++ /dev/null @@ -1,34 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Plugins</title> -</head> -<body> - <div id="pluginUpdatesPage" data-role="page" class="page type-interior pluginConfigurationPage"> - - <div data-role="content"> - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="plugins.html" data-role="button">Installed Plugins</a> - <a href="pluginCatalog.html" data-role="button">Plugin Catalog</a> - <a href="pluginUpdates.html" data-role="button" class="ui-btn-active">Automatic Updates</a> - </div> - - <form id="pluginUpdatesForm"> - - <table id="tblPluginUpdates"> - <thead> - <tr> - <th></th> - <th>Automatic updates</th> - <th>Update level</th> - </tr> - </thead> - <tbody id="tbodyPluginUpdates"></tbody> - </table> - </form> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/plugins.html b/MediaBrowser.WebDashboard/Html/plugins.html deleted file mode 100644 index ee74ae375..000000000 --- a/MediaBrowser.WebDashboard/Html/plugins.html +++ /dev/null @@ -1,24 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Plugins</title> -</head> -<body> - <div id="pluginsPage" data-role="page" class="page type-interior pluginConfigurationPage"> - - <div data-role="content"> - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="plugins.html" data-role="button" class="ui-btn-active">Installed Plugins</a> - <a href="pluginCatalog.html" data-role="button">Plugin Catalog</a> - <a href="pluginUpdates.html" data-role="button">Automatic Updates</a> - </div> - - <div class="readOnlyContent"> - <ul id="ulInstalledPlugins" data-role="listview" data-inset="true" data-auto-enhanced="false" data-split-icon="minus"></ul> - </div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/scheduledTask.html b/MediaBrowser.WebDashboard/Html/scheduledTask.html deleted file mode 100644 index fbfe3cc71..000000000 --- a/MediaBrowser.WebDashboard/Html/scheduledTask.html +++ /dev/null @@ -1,90 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title></title> -</head> -<body> - <div id="scheduledTaskPage" data-role="page" class="page type-interior"> - <div data-role="content"> - <div class="content-primary"> - <div class="readOnlyContent"> - <p id="pTaskDescription"></p> - <p> - <button type="button" data-icon="plus" onclick="ScheduledTaskPage.showAddTriggerPopup();"> - Add Task Trigger - </button> - </p> - <ul id="ulTaskTriggers" data-role="listview" data-inset="true" data-auto-enhanced="false" data-split-icon="minus"></ul> - </div> - </div> - </div> - <div data-role="popup" id="popupAddTrigger" class="ui-corner-all popup" style="min-width: 300px;"> - <form id="addTriggerForm"> - <div class="ui-corner-top ui-bar-a" style="text-align: center; padding: 0 20px;"> - <h3>Add Task Trigger</h3> - </div> - <div data-role="content" class="ui-corner-bottom ui-content"> - - <ul data-role="listview" class="ulForm"> - <li> - <label for="selectTriggerType">Trigger Type:</label> - <select id="selectTriggerType" name="selectTriggerType" onchange="ScheduledTaskPage.refreshTriggerFields(this.value);"> - <option value="DailyTrigger">Daily</option> - <option value="WeeklyTrigger">Weekly</option> - <option value="IntervalTrigger">On an interval</option> - <option value="StartupTrigger">On application startup</option> - <option value="SystemEventTrigger">After a system event</option> - </select> - </li> - <li id="fldDayOfWeek"> - <label for="selectDayOfWeek">Day:</label> - <select id="selectDayOfWeek" name="selectDayOfWeek"> - <option value="Sunday">Sunday</option> - <option value="Monday">Monday</option> - <option value="Tuesday">Tuesday</option> - <option value="Wednesday">Wednesday</option> - <option value="Thursday">Thursday</option> - <option value="Friday">Friday</option> - <option value="Saturday">Saturday</option> - </select> - </li> - <li id="fldTimeOfDay"> - <label for="txtTimeOfDay">Time:</label> - <input type="time" id="txtTimeOfDay" name="txtTimeOfDay" required="required" /> - </li> - <li id="fldSelectSystemEvent"> - <label for="selectSystemEvent">Event:</label> - <select id="selectSystemEvent" name="selectSystemEvent"> - <option value="WakeFromSleep">Wake from sleep</option> - </select> - </li> - <li id="fldSelectInterval"> - <label for="selectInterval">Every:</label> - <select id="selectInterval" name="selectInterval"> - <option value="9000000000">15 minutes</option> - <option value="18000000000">30 minutes</option> - <option value="27000000000">45 minutes</option> - <option value="36000000000">1 hour</option> - <option value="72000000000">2 hours</option> - <option value="108000000000">3 hours</option> - <option value="144000000000">4 hours</option> - <option value="216000000000">6 hours</option> - <option value="288000000000">8 hours</option> - <option value="432000000000">12 hours</option> - </select> - </li> - <li> - <button type="submit" data-theme="b" data-icon="ok"> - Add - </button> - <button type="button" data-icon="delete" onclick="$(this).parents('.popup').popup('close');"> - Cancel - </button> - </li> - </ul> - </div> - </form> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/scheduledTasks.html b/MediaBrowser.WebDashboard/Html/scheduledTasks.html deleted file mode 100644 index dfbac291b..000000000 --- a/MediaBrowser.WebDashboard/Html/scheduledTasks.html +++ /dev/null @@ -1,18 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Scheduled Tasks</title> -</head> -<body> - <div id="scheduledTasksPage" data-role="page" class="page type-interior"> - <div data-role="content"> - <div class="content-primary"> - <div class="readOnlyContent"> - <p>Below are Media Browser's scheduled tasks. Click into a task to adjust it's schedule.</p> - <ul id="ulScheduledTasks" data-role="listview" data-inset="true" data-auto-enhanced="false" data-split-icon="Play"></ul> - </div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/scripts/AddPluginPage.js b/MediaBrowser.WebDashboard/Html/scripts/AddPluginPage.js deleted file mode 100644 index 24f7581e9..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/AddPluginPage.js +++ /dev/null @@ -1,249 +0,0 @@ -var AddPluginPage = { - - onPageShow: function () { - - var page = this; - - Dashboard.showLoadingMsg(); - - var name = getParameterByName('name'); - - var promise1 = ApiClient.getPackageInfo(name); - var promise2 = ApiClient.getInstalledPlugins(); - var promise3 = ApiClient.getPluginSecurityInfo(); - - $.when(promise1, promise2, promise3).done(function (response1, response2, response3) { - - AddPluginPage.renderPackage(response1[0], response2[0], response3[0], page); - - }); - }, - - renderPackage: function (pkg, installedPlugins, pluginSecurityInfo, page) { - - var installedPlugin = installedPlugins.filter(function (ip) { - return ip.Name == pkg.name; - })[0]; - - AddPluginPage.populateVersions(pkg, page, installedPlugin); - AddPluginPage.populateHistory(pkg); - - Dashboard.setPageTitle(pkg.name); - - if (pkg.shortDescription) { - $('#tagline', page).show().html(pkg.shortDescription); - } else { - $('#tagline', page).hide(); - } - - $('#overview', page).html(pkg.overview || ""); - - - $('#developer', page).html(pkg.owner); - - if (pkg.isPremium) { - $('.premiumPackage', page).show(); - - // Fill in registration info - var regStatus = "<strong>"; - if (pkg.isRegistered) { - regStatus += "You are currently registered for this feature"; - } else { - if (new Date(pkg.expDate).getTime() < new Date(1970, 1, 1).getTime()) { - regStatus += "This feature has no registration information"; - } else { - if (new Date(pkg.expDate).getTime() <= new Date().getTime()) { - regStatus += "The trial period for this feature has expired"; - } else { - regStatus += "The trial period for this feature will expire in " + Math.round((new Date(pkg.expDate).getTime() - new Date().getTime()) / (86400000)) + " day(s)"; - } - } - } - - regStatus += "</strong>"; - $('#regStatus', page).html(regStatus); - - if (pluginSecurityInfo.IsMBSupporter) { - $('#regInfo', page).html(pkg.regInfo || ""); - if (pkg.price > 0) { - // Fill in PayPal info - $('premiumHasPrice', page).show(); - $('#featureId', page).val(pkg.featureId); - $('#featureName', page).val(pkg.name); - $('#amount', page).val(pkg.price); - $('#regPrice', page).html("<h2>Price: $" + pkg.price.toFixed(2) + " (USD)</h2>"); - var url = "http://mb3admin.com/admin/service/user/getPayPalEmail?id=" + pkg.owner; - $.getJSON(url).done(function(dev) { - if (dev.payPalEmail) { - $('#payPalEmail', page).val(dev.payPalEmail); - - } else { - $('#ppButton', page).hide(); - $('#noEmail', page).show(); - } - }); - } else { - // Supporter-only feature - $('premiumHasPrice', page).hide(); - } - } else { - $('#regInfo', page).html("<h3>You must be a <a href='supporter.html'>Media Browser Supporter</a> in order to gain access to this feature.</h3>"); - $('#ppButton', page).hide(); - } - - } else { - $('.premiumPackage', page).hide(); - } - - if (pkg.richDescUrl) { - $('#pViewWebsite', page).show(); - $('#pViewWebsite a', page)[0].href = pkg.richDescUrl; - } else { - $('#pViewWebsite', page).hide(); - } - - if (pkg.previewImage) { - - var color = pkg.tileColor || "#2572EB"; - var img = pkg.previewImage ? pkg.previewImage : pkg.thumbImage; - $('#pPreviewImage', page).show().html("<img src='" + img + "' style='max-width: 100%;border-radius:10px;-moz-box-shadow: 0 0 20px 3px " + color + ";-webkit-box-shadow: 0 0 20px 3px " + color + ";box-shadow: 0 0 20px 3px " + color + ";' />"); - } else { - $('#pPreviewImage', page).hide().html(""); - } - - if (installedPlugin) { - $('#pCurrentVersion', page).show().html("You currently have version <strong>" + installedPlugin.Version + "</strong> installed."); - - } else { - $('#pCurrentVersion', page).hide().html(""); - } - - Dashboard.hideLoadingMsg(); - }, - - populateVersions: function (packageInfo, page, installedPlugin) { - - var html = ''; - - for (var i = 0, length = packageInfo.versions.length; i < length; i++) { - - var version = packageInfo.versions[i]; - - html += '<option value="' + version.versionStr + '|' + version.classification + '">' + version.versionStr + ' (' + version.classification + ')</option>'; - - } - - var selectmenu = $('#selectVersion', page).html(html); - - var packageVersion; - - if (installedPlugin) { - - // Select the first available package with the same update class as the installed version - packageVersion = packageInfo.versions.filter(function (current) { - - return current.classification == installedPlugin.UpdateClass; - })[0]; - - - } else { - $('#pCurrentVersion', page).hide().html(""); - } - - // If we don't have a package version to select, pick the first release build - if (!packageVersion) { - - // Select the first available package with the same update class as the installed version - packageVersion = packageInfo.versions.filter(function (current) { - - return current.classification == "Release"; - })[0]; - } - - // If we still don't have a package version to select, pick the first Beta build - if (!packageVersion) { - - // Select the first available package with the same update class as the installed version - packageVersion = packageInfo.versions.filter(function (current) { - - return current.classification == "Beta"; - })[0]; - } - - if (packageVersion) { - var val = packageVersion.versionStr + '|' + packageVersion.classification; - - $('#selectVersion', page).val(val); - } - - selectmenu.selectmenu('refresh'); - }, - - populateHistory: function (packageInfo) { - - var html = ''; - - for (var i = 0, length = Math.min(packageInfo.versions.length, 10) ; i < length; i++) { - - var version = packageInfo.versions[i]; - - html += '<h2 style="margin:.5em 0;">' + version.versionStr + ' (' + version.classification + ')</h2>'; - - html += '<div style="margin-bottom:1.5em;">' + version.description + '</div>'; - } - - $('#revisionHistory', $.mobile.activePage).html(html); - }, - - onSubmit: function () { - - Dashboard.showLoadingMsg(); - - $('#btnInstall', $.mobile.activePage).button('disable'); - - var name = getParameterByName('name'); - - ApiClient.getInstalledPlugins().done(function (plugins) { - - var installedPlugin = plugins.filter(function (ip) { - return ip.Name == name; - })[0]; - - var vals = $('#selectVersion', $.mobile.activePage).val().split('|'); - - var version = vals[0]; - - if (installedPlugin && installedPlugin.Version == version) { - - Dashboard.hideLoadingMsg(); - - Dashboard.confirm("Are you sure you wish to reinstall the same version you already have? In most cases this will not have any effect.", "Plugin Reinstallation", function (confirmResult) { - - if (confirmResult) { - - Dashboard.showLoadingMsg(); - AddPluginPage.performInstallation(name, vals[1], version); - } else { - $('#btnInstall', $.mobile.activePage).button('enable'); - } - - }); - } else { - AddPluginPage.performInstallation(name, vals[1], version); - } - }); - - - return false; - }, - - performInstallation: function (packageName, updateClass, version) { - - ApiClient.installPlugin(packageName, updateClass, version).done(function () { - - Dashboard.hideLoadingMsg(); - }); - } -}; - -$(document).on('pageshow', "#addPluginPage", AddPluginPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/AdvancedConfigurationPage.js b/MediaBrowser.WebDashboard/Html/scripts/AdvancedConfigurationPage.js deleted file mode 100644 index f8c0d0a7d..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/AdvancedConfigurationPage.js +++ /dev/null @@ -1,65 +0,0 @@ -var AdvancedConfigurationPage = { - - onPageShow: function () { - Dashboard.showLoadingMsg(); - - var promise1 = ApiClient.getServerConfiguration(); - - var promise2 = ApiClient.getSystemInfo(); - - $.when(promise1, promise2).done(function (response1, response2) { - - AdvancedConfigurationPage.loadPage(response1[0], response2[0]); - - }); - }, - - loadPage: function (config, systemInfo) { - - var page = $.mobile.activePage; - - if (systemInfo.SupportsNativeWebSocket) { - - $('#fldWebSocketPortNumber', page).hide(); - } else { - $('#fldWebSocketPortNumber', page).show(); - } - - $('#selectAutomaticUpdateLevel', page).val(config.SystemUpdateLevel).selectmenu('refresh'); - $('#txtWebSocketPortNumber', page).val(config.LegacyWebSocketPortNumber); - - $('#txtPortNumber', page).val(config.HttpServerPortNumber); - $('#chkDebugLog', page).checked(config.EnableDebugLevelLogging).checkboxradio("refresh"); - - $('#chkEnableDeveloperTools', page).checked(config.EnableDeveloperTools).checkboxradio("refresh"); - $('#chkRunAtStartup', page).checked(config.RunAtStartup).checkboxradio("refresh"); - - Dashboard.hideLoadingMsg(); - }, - - onSubmit: function () { - - Dashboard.showLoadingMsg(); - - var form = this; - - ApiClient.getServerConfiguration().done(function (config) { - - config.LegacyWebSocketPortNumber = $('#txtWebSocketPortNumber', form).val(); - - config.HttpServerPortNumber = $('#txtPortNumber', form).val(); - config.EnableDebugLevelLogging = $('#chkDebugLog', form).checked(); - - config.EnableDeveloperTools = $('#chkEnableDeveloperTools', form).checked(); - config.RunAtStartup = $('#chkRunAtStartup', form).checked(); - config.SystemUpdateLevel = $('#selectAutomaticUpdateLevel', form).val(); - - ApiClient.updateServerConfiguration(config).done(Dashboard.processServerConfigurationUpdateResult); - }); - - // Disable default form submission - return false; - } -}; - -$(document).on('pageshow', "#advancedConfigurationPage", AdvancedConfigurationPage.onPageShow); diff --git a/MediaBrowser.WebDashboard/Html/scripts/AdvancedMetadataConfigurationPage.js b/MediaBrowser.WebDashboard/Html/scripts/AdvancedMetadataConfigurationPage.js deleted file mode 100644 index 41e0f7223..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/AdvancedMetadataConfigurationPage.js +++ /dev/null @@ -1,69 +0,0 @@ -var AdvancedMetadataConfigurationPage = { - - onPageShow: function () { - - Dashboard.showLoadingMsg(); - - var page = this; - - var promise1 = ApiClient.getServerConfiguration(); - var promise2 = ApiClient.getItemTypes({ HasInternetProvider: true }); - - $.when(promise1, promise2).done(function (response1, response2) { - - AdvancedMetadataConfigurationPage.load(page, response1[0], response2[0]); - - }); - }, - - load: function (page, config, itemTypes) { - - AdvancedMetadataConfigurationPage.loadItemTypes(page, config, itemTypes); - Dashboard.hideLoadingMsg(); - }, - - loadItemTypes: function (page, configuration, types) { - - var html = '<div data-role="controlgroup">'; - - for (var i = 0, length = types.length; i < length; i++) { - - var type = types[i]; - var id = "checkbox-" + i + "a"; - - var checkedAttribute = configuration.InternetProviderExcludeTypes.indexOf(type) != -1 ? ' checked="checked"' : ''; - - html += '<input' + checkedAttribute + ' class="chkItemType" data-itemtype="' + type + '" type="checkbox" name="' + id + '" id="' + id + '" onchange="AdvancedMetadataConfigurationPage.submit();" />'; - html += '<label for="' + id + '">' + type + '</label>'; - } - - html += "</div>"; - - $('#divItemTypes', page).html(html).trigger("create"); - }, - - submit: function () { - - $('.btnSubmit', $.mobile.activePage)[0].click(); - - }, - - onSubmit: function () { - var form = this; - - ApiClient.getServerConfiguration().done(function (config) { - - config.InternetProviderExcludeTypes = $.map($('.chkItemType:checked', form), function (currentCheckbox) { - - return currentCheckbox.getAttribute('data-itemtype'); - }); - - ApiClient.updateServerConfiguration(config); - }); - - // Disable default form submission - return false; - } -}; - -$(document).on('pageshow', "#advancedMetadataConfigurationPage", AdvancedMetadataConfigurationPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/DashboardPage.js b/MediaBrowser.WebDashboard/Html/scripts/DashboardPage.js deleted file mode 100644 index 47ff3b0c1..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/DashboardPage.js +++ /dev/null @@ -1,462 +0,0 @@ -var DashboardPage = { - - onPageShow: function () { - - Dashboard.showLoadingMsg(); - DashboardPage.pollForInfo(); - DashboardPage.startInterval(); - $(document).on("websocketmessage", DashboardPage.onWebSocketMessage).on("websocketopen", DashboardPage.onWebSocketConnectionChange).on("websocketerror", DashboardPage.onWebSocketConnectionChange).on("websocketclose", DashboardPage.onWebSocketConnectionChange); - - DashboardPage.lastAppUpdateCheck = null; - DashboardPage.lastPluginUpdateCheck = null; - }, - - onPageHide: function () { - - $(document).off("websocketmessage", DashboardPage.onWebSocketMessage).off("websocketopen", DashboardPage.onWebSocketConnectionChange).off("websocketerror", DashboardPage.onWebSocketConnectionChange).off("websocketclose", DashboardPage.onWebSocketConnectionChange); - DashboardPage.stopInterval(); - }, - - startInterval: function () { - - if (Dashboard.isWebSocketOpen()) { - Dashboard.sendWebSocketMessage("DashboardInfoStart", "0,1500"); - } - }, - - stopInterval: function () { - - if (Dashboard.isWebSocketOpen()) { - Dashboard.sendWebSocketMessage("DashboardInfoStop"); - } - }, - - onWebSocketMessage: function (e, msg) { - - if (msg.MessageType == "DashboardInfo") { - DashboardPage.renderInfo(msg.Data); - } - }, - - onWebSocketConnectionChange: function () { - - DashboardPage.stopInterval(); - DashboardPage.startInterval(); - }, - - pollForInfo: function () { - $.getJSON("dashboardInfo").done(DashboardPage.renderInfo); - }, - - renderInfo: function (dashboardInfo) { - - DashboardPage.lastDashboardInfo = dashboardInfo; - - DashboardPage.renderRunningTasks(dashboardInfo); - DashboardPage.renderSystemInfo(dashboardInfo); - DashboardPage.renderActiveConnections(dashboardInfo); - - Dashboard.hideLoadingMsg(); - }, - - renderActiveConnections: function (dashboardInfo) { - - var page = $.mobile.activePage; - - var html = ''; - - if (!dashboardInfo.ActiveConnections.length) { - html += '<p>There are no users currently connected.</p>'; - $('#divConnections', page).html(html).trigger('create'); - return; - } - - html += '<table class="tblConnections" style="border-collapse:collapse;">'; - - for (var i = 0, length = dashboardInfo.ActiveConnections.length; i < length; i++) { - - var connection = dashboardInfo.ActiveConnections[i]; - - var user = dashboardInfo.Users.filter(function (u) { - return u.Id == connection.UserId; - })[0]; - - html += '<tr>'; - - html += '<td style="text-align:center;">'; - html += DashboardPage.getClientType(connection); - html += '</td>'; - - html += '<td>'; - html += user.Name; - html += '</td>'; - - html += '<td>'; - html += connection.DeviceName; - html += '</td>'; - - html += '<td>'; - html += DashboardPage.getNowPlayingImage(connection.NowPlayingItem); - html += '</td>'; - - html += '<td>'; - html += DashboardPage.getNowPlayingText(connection, connection.NowPlayingItem); - html += '</td>'; - - html += '</tr>'; - - } - - html += '</table>'; - - $('#divConnections', page).html(html); - }, - - getClientType: function (connection) { - - var clientLowered = connection.Client.toLowerCase(); - - if (clientLowered == "dashboard") { - - return "<img src='css/images/clients/html5.png' alt='Dashboard' title='Dashboard' />"; - } - if (clientLowered == "media browser classic") { - - return "<img src='css/images/clients/mb.png' alt='Media Browser Classic' title='Media Browser Classic' />"; - } - if (clientLowered == "media browser theater") { - - return "<img src='css/images/clients/mb.png' alt='Media Browser Theater' title='Media Browser Theater' />"; - } - if (clientLowered == "android") { - - return "<img src='css/images/clients/android.png' alt='Android' title='Android' />"; - } - if (clientLowered == "ios") { - - return "<img src='css/images/clients/ios.png' alt='iOS' title='iOS' />"; - } - if (clientLowered == "windows rt") { - - return "<img src='css/images/clients/windowsrt.png' alt='Windows RT' title='Windows RT' />"; - } - if (clientLowered == "windows phone") { - - return "<img src='css/images/clients/windowsphone.png' alt='Windows Phone' title='Windows Phone' />"; - } - if (clientLowered == "dlna") { - - return "<img src='css/images/clients/dlna.png' alt='Dlna' title='Dlna' />"; - } - - return connection.Client; - }, - - getNowPlayingImage: function (item) { - - if (item) { - - if (item.BackdropImageTag) { - var url = ApiClient.getImageUrl(item.Id, { - type: "Backdrop", - height: 100, - tag: item.BackdropImageTag - }); - - return "<img class='clientNowPlayingImage' src='" + url + "' alt='" + item.Name + "' title='" + item.Name + "' />"; - } - else if (item.PrimaryImageTag) { - - var url = ApiClient.getImageUrl(item.Id, { - type: "Primary", - height: 100, - tag: item.PrimaryImageTag - }); - - return "<img class='clientNowPlayingImage' src='" + url + "' alt='" + item.Name + "' title='" + item.Name + "' />"; - } - } - - return ""; - }, - - getNowPlayingText: function (connection, item) { - - var html = ""; - - if (item) { - - html += "<div>" + item.Name + "</div>"; - - html += "<div>"; - - if (item.RunTimeTicks) { - html += DashboardPage.getDisplayText(connection.NowPlayingPositionTicks || 0) + " / "; - - html += DashboardPage.getDisplayText(item.RunTimeTicks); - } - - html += "</div>"; - } - - return html; - }, - - getDisplayText: function (ticks) { - - var ticksPerHour = 36000000000; - - var parts = []; - - var hours = ticks / ticksPerHour; - hours = parseInt(hours); - - if (hours) { - parts.push(hours); - } - - ticks -= (hours * ticksPerHour); - - var ticksPerMinute = 600000000; - - var minutes = ticks / ticksPerMinute; - minutes = parseInt(minutes); - - ticks -= (minutes * ticksPerMinute); - - if (minutes < 10) { - minutes = '0' + minutes; - } - parts.push(minutes); - - var ticksPerSecond = 10000000; - - var seconds = ticks / ticksPerSecond; - seconds = parseInt(seconds); - - if (seconds < 10) { - seconds = '0' + seconds; - } - parts.push(seconds); - - return parts.join(':'); - }, - - renderRunningTasks: function (dashboardInfo) { - - var page = $.mobile.activePage; - - var html = ''; - - if (!dashboardInfo.RunningTasks.length) { - html += '<p>No tasks are currently running.</p>'; - } - - for (var i = 0, length = dashboardInfo.RunningTasks.length; i < length; i++) { - - - var task = dashboardInfo.RunningTasks[i]; - - html += '<p>'; - - html += task.Name; - - if (task.State == "Running") { - var progress = Math.round(task.CurrentProgressPercentage || 0); - html += '<span style="color:#267F00;margin-right:5px;font-weight:bold;"> - ' + progress + '%</span>'; - - html += '<button type="button" data-icon="stop" data-iconpos="notext" data-inline="true" data-theme="b" data-mini="true" onclick="DashboardPage.stopTask(\'' + task.Id + '\');">Stop</button>'; - } - else if (task.State == "Cancelling") { - html += '<span style="color:#cc0000;"> - Stopping</span>'; - } - - html += '</p>'; - } - - - $('#divRunningTasks', page).html(html).trigger('create'); - }, - - renderSystemInfo: function (dashboardInfo) { - - Dashboard.updateSystemInfo(dashboardInfo.SystemInfo); - - var page = $.mobile.activePage; - - $('#appVersionNumber', page).html(dashboardInfo.SystemInfo.Version); - - if (dashboardInfo.RunningTasks.filter(function (task) { - - return task.Id == dashboardInfo.ApplicationUpdateTaskId; - - }).length) { - - $('#btnUpdateApplication', page).button('disable'); - } else { - $('#btnUpdateApplication', page).button('enable'); - } - - DashboardPage.renderApplicationUpdateInfo(dashboardInfo); - DashboardPage.renderPluginUpdateInfo(dashboardInfo); - DashboardPage.renderPendingInstallations(dashboardInfo.SystemInfo); - }, - - renderApplicationUpdateInfo: function (dashboardInfo) { - - var page = $.mobile.activePage; - - if (dashboardInfo.SystemInfo.IsNetworkDeployed && !dashboardInfo.SystemInfo.HasPendingRestart) { - - // Only check once every 10 mins - if (DashboardPage.lastAppUpdateCheck && (new Date().getTime() - DashboardPage.lastAppUpdateCheck) < 600000) { - return; - } - - DashboardPage.lastAppUpdateCheck = new Date().getTime(); - - ApiClient.getAvailableApplicationUpdate().done(function (packageInfo) { - - var version = packageInfo[0]; - - if (!version) { - $('#pUpToDate', page).show(); - $('#pUpdateNow', page).hide(); - } else { - $('#pUpToDate', page).hide(); - - $('#pUpdateNow', page).show(); - - $('#newVersionNumber', page).html("Version " + version.versionStr + " is now available for download."); - } - - }).fail(function () { - - Dashboard.showFooterNotification({ html: '<img src="css/images/notifications/error.png" class="notificationIcon" />There was an error connecting to the remote Media Browser repository.', id: "MB3ConnectionError" }); - - }); - - } else { - - if (dashboardInfo.SystemInfo.HasPendingRestart) { - $('#pUpToDate', page).hide(); - } else { - $('#pUpToDate', page).show(); - } - - $('#pUpdateNow', page).hide(); - } - }, - - renderPendingInstallations: function (systemInfo) { - - var page = $.mobile.activePage; - - if (systemInfo.CompletedInstallations.length) { - - $('#collapsiblePendingInstallations', page).show(); - - } else { - $('#collapsiblePendingInstallations', page).hide(); - - return; - } - - var html = ''; - - for (var i = 0, length = systemInfo.CompletedInstallations.length; i < length; i++) { - - var update = systemInfo.CompletedInstallations[i]; - - html += '<div><strong>' + update.Name + '</strong> (' + update.Version + ')</div>'; - } - - $('#pendingInstallations', page).html(html); - }, - - renderPluginUpdateInfo: function (dashboardInfo) { - - // Only check once every 10 mins - if (DashboardPage.lastPluginUpdateCheck && (new Date().getTime() - DashboardPage.lastPluginUpdateCheck) < 600000) { - return; - } - - DashboardPage.lastPluginUpdateCheck = new Date().getTime(); - - var page = $.mobile.activePage; - - ApiClient.getAvailablePluginUpdates().done(function (updates) { - - var elem = $('#pPluginUpdates', page); - - if (updates.length) { - - elem.show(); - - } else { - elem.hide(); - - return; - } - var html = ''; - - for (var i = 0, length = updates.length; i < length; i++) { - - var update = updates[i]; - - html += '<p><strong>A new version of ' + update.name + ' is available!</strong></p>'; - - html += '<button type="button" data-icon="download" data-theme="b" onclick="DashboardPage.installPluginUpdate(this);" data-name="' + update.name + '" data-version="' + update.versionStr + '" data-classification="' + update.classification + '">Update Now</button>'; - } - - elem.html(html).trigger('create'); - - }).fail(function () { - - Dashboard.showFooterNotification({ html: '<img src="css/images/notifications/error.png" class="notificationIcon" />There was an error connecting to the remote Media Browser repository.', id: "MB3ConnectionError" }); - - }); - }, - - installPluginUpdate: function (button) { - - $(button).button('disable'); - - var name = button.getAttribute('data-name'); - var version = button.getAttribute('data-version'); - var classification = button.getAttribute('data-classification'); - - Dashboard.showLoadingMsg(); - - ApiClient.installPlugin(name, classification, version).done(function () { - - Dashboard.hideLoadingMsg(); - }); - }, - - updateApplication: function () { - - var page = $.mobile.activePage; - $('#btnUpdateApplication', page).button('disable'); - - Dashboard.showLoadingMsg(); - - ApiClient.startScheduledTask(DashboardPage.lastDashboardInfo.ApplicationUpdateTaskId).done(function () { - - DashboardPage.pollForInfo(); - - Dashboard.hideLoadingMsg(); - }); - }, - - stopTask: function (id) { - - ApiClient.stopScheduledTask(id).done(function () { - - DashboardPage.pollForInfo(); - }); - - } -}; - -$(document).on('pageshow', "#dashboardPage", DashboardPage.onPageShow).on('pagehide', "#dashboardPage", DashboardPage.onPageHide);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/DisplaySettingsPage.js b/MediaBrowser.WebDashboard/Html/scripts/DisplaySettingsPage.js deleted file mode 100644 index da87a106f..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/DisplaySettingsPage.js +++ /dev/null @@ -1,46 +0,0 @@ -var DisplaySettingsPage = { - - onPageShow: function () { - Dashboard.showLoadingMsg(); - - var page = this; - - ApiClient.getServerConfiguration().done(function (config) { - - $('#txtWeatherLocation', page).val(config.WeatherLocation); - $('#txtMinResumePct', page).val(config.MinResumePct); - $('#txtMaxResumePct', page).val(config.MaxResumePct); - $('#txtMinResumeDuration', page).val(config.MinResumeDurationSeconds); - $('#selectWeatherUnit', page).val(config.WeatherUnit).selectmenu("refresh"); - - Dashboard.hideLoadingMsg(); - }); - - }, - - submit: function() { - - $('.btnSubmit', $.mobile.activePage)[0].click(); - - }, - - onSubmit: function () { - var form = this; - - ApiClient.getServerConfiguration().done(function (config) { - - config.WeatherLocation = $('#txtWeatherLocation', form).val(); - config.WeatherUnit = $('#selectWeatherUnit', form).val(); - config.MinResumePct = $('#txtMinResumePct', form).val(); - config.MaxResumePct = $('#txtMaxResumePct', form).val(); - config.MinResumeDurationSeconds = $('#txtMinResumeDuration', form).val(); - - ApiClient.updateServerConfiguration(config); - }); - - // Disable default form submission - return false; - } -}; - -$(document).on('pageshow', "#displaySettingsPage", DisplaySettingsPage.onPageShow); diff --git a/MediaBrowser.WebDashboard/Html/scripts/EditUserPage.js b/MediaBrowser.WebDashboard/Html/scripts/EditUserPage.js deleted file mode 100644 index 0d362e5de..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/EditUserPage.js +++ /dev/null @@ -1,175 +0,0 @@ -var EditUserPage = { - - onPageShow: function () { - Dashboard.showLoadingMsg(); - - var userId = getParameterByName("userId"); - - if (userId) { - $('#userProfileNavigation', this).show(); - } else { - $('#userProfileNavigation', this).hide(); - } - - var promise4 = ApiClient.getCultures(); - - var promise3 = ApiClient.getParentalRatings(); - - var promise1; - - if (!userId) { - - var deferred = $.Deferred(); - - deferred.resolveWith(null, [{ - Configuration: {} - }]); - - promise1 = deferred.promise(); - } else { - - promise1 = ApiClient.getUser(userId); - } - - var promise2 = Dashboard.getCurrentUser(); - - $.when(promise1, promise2, promise3, promise4).done(function (response1, response2, response3, response4) { - - EditUserPage.loadUser(response1[0] || response1, response2[0], response3[0], response4[0]); - - }); - }, - - loadUser: function (user, loggedInUser, allParentalRatings, allCultures) { - - var page = $($.mobile.activePage); - - EditUserPage.populateLanguages($('#selectAudioLanguage', page), allCultures); - EditUserPage.populateLanguages($('#selectSubtitleLanguage', page), allCultures); - EditUserPage.populateRatings(allParentalRatings, page); - - if (!loggedInUser.Configuration.IsAdministrator || user.Id == loggedInUser.Id) { - - $('#fldIsAdmin', page).hide(); - $('#fldMaxParentalRating', page).hide(); - } else { - $('#fldIsAdmin', page).show(); - $('#fldMaxParentalRating', page).show(); - } - - Dashboard.setPageTitle(user.Name || "Add User"); - - $('#txtUserName', page).val(user.Name); - - var ratingValue = ""; - - if (user.Configuration.MaxParentalRating) { - - for (var i = 0, length = allParentalRatings.length; i < length; i++) { - - var rating = allParentalRatings[i]; - - if (user.Configuration.MaxParentalRating >= rating.Value) { - ratingValue = rating.Value; - } - } - } - - $('#selectMaxParentalRating', page).val(ratingValue).selectmenu("refresh"); - - $('#selectAudioLanguage', page).val(user.Configuration.AudioLanguagePreference || "").selectmenu("refresh"); - $('#selectSubtitleLanguage', page).val(user.Configuration.SubtitleLanguagePreference || "").selectmenu("refresh"); - - $('#chkForcedSubtitlesOnly', page).checked(user.Configuration.UseForcedSubtitlesOnly || false).checkboxradio("refresh"); - $('#chkIsAdmin', page).checked(user.Configuration.IsAdministrator || false).checkboxradio("refresh"); - - Dashboard.hideLoadingMsg(); - }, - - populateLanguages: function (select, allCultures) { - - var html = ""; - - html += "<option value=''>None</option>"; - - for (var i = 0, length = allCultures.length; i < length; i++) { - - var culture = allCultures[i]; - - html += "<option value='" + culture.ThreeLetterISOLanguageName + "'>" + culture.DisplayName + "</option>"; - } - - select.html(html).selectmenu("refresh"); - }, - - populateRatings: function (allParentalRatings, page) { - - var html = ""; - - html += "<option value=''>None</option>"; - - for (var i = 0, length = allParentalRatings.length; i < length; i++) { - - var rating = allParentalRatings[i]; - - html += "<option value='" + rating.Value + "'>" + rating.Name + "</option>"; - } - - $('#selectMaxParentalRating', page).html(html).selectmenu("refresh"); - }, - - saveUser: function (user) { - - var page = $($.mobile.activePage); - - user.Name = $('#txtUserName', page).val(); - user.Configuration.MaxParentalRating = $('#selectMaxParentalRating', page).val() || null; - - user.Configuration.IsAdministrator = $('#chkIsAdmin', page).checked(); - - user.Configuration.AudioLanguagePreference = $('#selectAudioLanguage', page).val(); - user.Configuration.SubtitleLanguagePreference = $('#selectSubtitleLanguage', page).val(); - user.Configuration.UseForcedSubtitlesOnly = $('#chkForcedSubtitlesOnly', page).checked(); - - var userId = getParameterByName("userId"); - - if (userId) { - ApiClient.updateUser(user).done(EditUserPage.saveComplete); - } else { - ApiClient.createUser(user).done(EditUserPage.saveComplete); - } - }, - - saveComplete: function () { - Dashboard.hideLoadingMsg(); - - var userId = getParameterByName("userId"); - - Dashboard.validateCurrentUser(); - - if (userId) { - Dashboard.alert("Settings saved."); - } else { - Dashboard.navigate("userProfiles.html"); - } - }, - - onSubmit: function () { - Dashboard.showLoadingMsg(); - - var userId = getParameterByName("userId"); - - if (!userId) { - EditUserPage.saveUser({ - Configuration: {} - }); - } else { - ApiClient.getUser(userId).done(EditUserPage.saveUser); - } - - // Disable default form submission - return false; - } -}; - -$(document).on('pageshow', "#editUserPage", EditUserPage.onPageShow); diff --git a/MediaBrowser.WebDashboard/Html/scripts/Extensions.js b/MediaBrowser.WebDashboard/Html/scripts/Extensions.js deleted file mode 100644 index 699ad6143..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/Extensions.js +++ /dev/null @@ -1,506 +0,0 @@ -// Array Remove - By John Resig (MIT Licensed) -Array.prototype.remove = function (from, to) { - var rest = this.slice((to || from) + 1 || this.length); - this.length = from < 0 ? this.length + from : from; - return this.push.apply(this, rest); -}; - -String.prototype.endsWith = function (suffix) { - return this.indexOf(suffix, this.length - suffix.length) !== -1; -}; - -$.fn.checked = function (value) { - if (value === true || value === false) { - // Set the value of the checkbox - return $(this).each(function () { - this.checked = value; - }); - } else { - // Return check state - return $(this).is(':checked'); - } -}; - -var WebNotifications = { - - show: function (data) { - if (window.webkitNotifications) { - if (!webkitNotifications.checkPermission()) { - var notif = webkitNotifications.createNotification(data.icon, data.title, data.body); - notif.show(); - - if (data.timeout) { - setTimeout(function () { - notif.cancel(); - }, data.timeout); - } - - return notif; - } else { - webkitNotifications.requestPermission(function () { - return WebNotifications.show(data); - }); - } - } - else if (window.Notification) { - if (Notification.permissionLevel() === "granted") { - var notif = new Notification(data.title, data); - notif.show(); - - if (data.timeout) { - setTimeout(function () { - notif.cancel(); - }, data.timeout); - } - - return notif; - } else if (Notification.permissionLevel() === "default") { - Notification.requestPermission(function () { - return WebNotifications.show(data); - }); - } - } - }, - - requestPermission: function () { - if (window.webkitNotifications) { - if (!webkitNotifications.checkPermission()) { - } else { - webkitNotifications.requestPermission(function () { - }); - } - } - else if (window.Notification) { - if (Notification.permissionLevel() === "granted") { - } else if (Notification.permissionLevel() === "default") { - Notification.requestPermission(function () { - }); - } - } - } -}; - -/* - * Javascript Humane Dates - * Copyright (c) 2008 Dean Landolt (deanlandolt.com) - * Re-write by Zach Leatherman (zachleat.com) - * - * Adopted from the John Resig's pretty.js - * at http://ejohn.org/blog/javascript-pretty-date - * and henrah's proposed modification - * at http://ejohn.org/blog/javascript-pretty-date/#comment-297458 - * - * Licensed under the MIT license. - */ - -function humane_date(date_str) { - var time_formats = [[90, 'a minute'], // 60*1.5 - [3600, 'minutes', 60], // 60*60, 60 - [5400, 'an hour'], // 60*60*1.5 - [86400, 'hours', 3600], // 60*60*24, 60*60 - [129600, 'a day'], // 60*60*24*1.5 - [604800, 'days', 86400], // 60*60*24*7, 60*60*24 - [907200, 'a week'], // 60*60*24*7*1.5 - [2628000, 'weeks', 604800], // 60*60*24*(365/12), 60*60*24*7 - [3942000, 'a month'], // 60*60*24*(365/12)*1.5 - [31536000, 'months', 2628000], // 60*60*24*365, 60*60*24*(365/12) - [47304000, 'a year'], // 60*60*24*365*1.5 - [3153600000, 'years', 31536000] // 60*60*24*365*100, 60*60*24*365 - ]; - - var dt = new Date; - var date = parseISO8601Date(date_str, true); - - var seconds = ((dt - date) / 1000); - var token = ' ago'; - var i = 0; - var format; - - if (seconds < 0) { - seconds = Math.abs(seconds); - token = ''; - } - - while (format = time_formats[i++]) { - if (seconds < format[0]) { - if (format.length == 2) { - return format[1] + token; - } else { - return Math.round(seconds / format[2]) + ' ' + format[1] + token; - } - } - } - - // overflow for centuries - if (seconds > 4730400000) - return Math.round(seconds / 4730400000) + ' centuries' + token; - - return date_str; -}; - -function humane_elapsed(firstDateStr, secondDateStr) { - var dt1 = new Date(firstDateStr); - var dt2 = new Date(secondDateStr); - var seconds = (dt2.getTime() - dt1.getTime()) / 1000; - var numdays = Math.floor((seconds % 31536000) / 86400); - var numhours = Math.floor(((seconds % 31536000) % 86400) / 3600); - var numminutes = Math.floor((((seconds % 31536000) % 86400) % 3600) / 60); - var numseconds = Math.round((((seconds % 31536000) % 86400) % 3600) % 60); - - var elapsedStr = ''; - elapsedStr += numdays == 1 ? numdays + ' day ' : ''; - elapsedStr += numdays > 1 ? numdays + ' days ' : ''; - elapsedStr += numhours == 1 ? numhours + ' hour ' : ''; - elapsedStr += numhours > 1 ? numhours + ' hours ' : ''; - elapsedStr += numminutes == 1 ? numminutes + ' minute ' : ''; - elapsedStr += numminutes > 1 ? numminutes + ' minutes ' : ''; - elapsedStr += elapsedStr.length > 0 ? 'and ' : ''; - elapsedStr += numseconds == 1 ? numseconds + ' second' : ''; - elapsedStr += numseconds == 0 || numseconds > 1 ? numseconds + ' seconds' : ''; - - return elapsedStr; - -} - -function getParameterByName(name) { - name = name.replace(/[\[]/, "\\\[").replace(/[\]]/, "\\\]"); - var regexS = "[\\?&]" + name + "=([^&#]*)"; - var regex = new RegExp(regexS); - var results = regex.exec(window.location.search); - if (results == null) - return ""; - else - return decodeURIComponent(results[1].replace(/\+/g, " ")); -} - -function parseISO8601Date(s, toLocal) { - - // parenthese matches: - // year month day hours minutes seconds - // dotmilliseconds - // tzstring plusminus hours minutes - var re = /(\d{4})-(\d\d)-(\d\d)T(\d\d):(\d\d):(\d\d)(\.\d+)?(Z|([+-])(\d\d):(\d\d))/; - - var d = []; - d = s.match(re); - - // "2010-12-07T11:00:00.000-09:00" parses to: - // ["2010-12-07T11:00:00.000-09:00", "2010", "12", "07", "11", - // "00", "00", ".000", "-09:00", "-", "09", "00"] - // "2010-12-07T11:00:00.000Z" parses to: - // ["2010-12-07T11:00:00.000Z", "2010", "12", "07", "11", - // "00", "00", ".000", "Z", undefined, undefined, undefined] - - if (!d) { - throw "Couldn't parse ISO 8601 date string '" + s + "'"; - } - - // parse strings, leading zeros into proper ints - var a = [1, 2, 3, 4, 5, 6, 10, 11]; - for (var i in a) { - d[a[i]] = parseInt(d[a[i]], 10); - } - d[7] = parseFloat(d[7]); - - // Date.UTC(year, month[, date[, hrs[, min[, sec[, ms]]]]]) - // note that month is 0-11, not 1-12 - // see https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Date/UTC - var ms = Date.UTC(d[1], d[2] - 1, d[3], d[4], d[5], d[6]); - - // if there are milliseconds, add them - if (d[7] > 0) { - ms += Math.round(d[7] * 1000); - } - - // if there's a timezone, calculate it - if (d[8] != "Z" && d[10]) { - var offset = d[10] * 60 * 60 * 1000; - if (d[11]) { - offset += d[11] * 60 * 1000; - } - if (d[9] == "-") { - ms -= offset; - } else { - ms += offset; - } - } else if (!toLocal) { - ms += new Date().getTimezoneOffset() * 60000; - } - - return new Date(ms); -}; - -/** -* -* Secure Hash Algorithm (SHA1) -* http://www.webtoolkit.info/ -* -**/ - -function SHA1(msg) { - - function rotate_left(n, s) { - var t4 = (n << s) | (n >>> (32 - s)); - return t4; - }; - - function lsb_hex(val) { - var str = ""; - var i; - var vh; - var vl; - - for (i = 0; i <= 6; i += 2) { - vh = (val >>> (i * 4 + 4)) & 0x0f; - vl = (val >>> (i * 4)) & 0x0f; - str += vh.toString(16) + vl.toString(16); - } - return str; - }; - - function cvt_hex(val) { - var str = ""; - var i; - var v; - - for (i = 7; i >= 0; i--) { - v = (val >>> (i * 4)) & 0x0f; - str += v.toString(16); - } - return str; - }; - - - function Utf8Encode(string) { - string = string.replace(/\r\n/g, "\n"); - var utftext = ""; - - for (var n = 0; n < string.length; n++) { - - var c = string.charCodeAt(n); - - if (c < 128) { - utftext += String.fromCharCode(c); - } - else if ((c > 127) && (c < 2048)) { - utftext += String.fromCharCode((c >> 6) | 192); - utftext += String.fromCharCode((c & 63) | 128); - } - else { - utftext += String.fromCharCode((c >> 12) | 224); - utftext += String.fromCharCode(((c >> 6) & 63) | 128); - utftext += String.fromCharCode((c & 63) | 128); - } - - } - - return utftext; - }; - - var blockstart; - var i, j; - var W = new Array(80); - var H0 = 0x67452301; - var H1 = 0xEFCDAB89; - var H2 = 0x98BADCFE; - var H3 = 0x10325476; - var H4 = 0xC3D2E1F0; - var A, B, C, D, E; - var temp; - - msg = Utf8Encode(msg); - - var msg_len = msg.length; - - var word_array = new Array(); - for (i = 0; i < msg_len - 3; i += 4) { - j = msg.charCodeAt(i) << 24 | msg.charCodeAt(i + 1) << 16 | - msg.charCodeAt(i + 2) << 8 | msg.charCodeAt(i + 3); - word_array.push(j); - } - - switch (msg_len % 4) { - case 0: - i = 0x080000000; - break; - case 1: - i = msg.charCodeAt(msg_len - 1) << 24 | 0x0800000; - break; - - case 2: - i = msg.charCodeAt(msg_len - 2) << 24 | msg.charCodeAt(msg_len - 1) << 16 | 0x08000; - break; - - case 3: - i = msg.charCodeAt(msg_len - 3) << 24 | msg.charCodeAt(msg_len - 2) << 16 | msg.charCodeAt(msg_len - 1) << 8 | 0x80; - break; - } - - word_array.push(i); - - while ((word_array.length % 16) != 14) word_array.push(0); - - word_array.push(msg_len >>> 29); - word_array.push((msg_len << 3) & 0x0ffffffff); - - - for (blockstart = 0; blockstart < word_array.length; blockstart += 16) { - - for (i = 0; i < 16; i++) W[i] = word_array[blockstart + i]; - for (i = 16; i <= 79; i++) W[i] = rotate_left(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1); - - A = H0; - B = H1; - C = H2; - D = H3; - E = H4; - - for (i = 0; i <= 19; i++) { - temp = (rotate_left(A, 5) + ((B & C) | (~B & D)) + E + W[i] + 0x5A827999) & 0x0ffffffff; - E = D; - D = C; - C = rotate_left(B, 30); - B = A; - A = temp; - } - - for (i = 20; i <= 39; i++) { - temp = (rotate_left(A, 5) + (B ^ C ^ D) + E + W[i] + 0x6ED9EBA1) & 0x0ffffffff; - E = D; - D = C; - C = rotate_left(B, 30); - B = A; - A = temp; - } - - for (i = 40; i <= 59; i++) { - temp = (rotate_left(A, 5) + ((B & C) | (B & D) | (C & D)) + E + W[i] + 0x8F1BBCDC) & 0x0ffffffff; - E = D; - D = C; - C = rotate_left(B, 30); - B = A; - A = temp; - } - - for (i = 60; i <= 79; i++) { - temp = (rotate_left(A, 5) + (B ^ C ^ D) + E + W[i] + 0xCA62C1D6) & 0x0ffffffff; - E = D; - D = C; - C = rotate_left(B, 30); - B = A; - A = temp; - } - - H0 = (H0 + A) & 0x0ffffffff; - H1 = (H1 + B) & 0x0ffffffff; - H2 = (H2 + C) & 0x0ffffffff; - H3 = (H3 + D) & 0x0ffffffff; - H4 = (H4 + E) & 0x0ffffffff; - - } - - var temp = cvt_hex(H0) + cvt_hex(H1) + cvt_hex(H2) + cvt_hex(H3) + cvt_hex(H4); - - return temp.toLowerCase(); - -} - -// jqm.page.params.js - version 0.1 -// Copyright (c) 2011, Kin Blas -// All rights reserved. -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are met: -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above copyright -// notice, this list of conditions and the following disclaimer in the -// documentation and/or other materials provided with the distribution. -// * Neither the name of the <organization> nor the -// names of its contributors may be used to endorse or promote products -// derived from this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND -// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED -// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE -// DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY -// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES -// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND -// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS -// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -(function ($, window, undefined) { - - // Given a query string, convert all the name/value pairs - // into a property/value object. If a name appears more than - // once in a query string, the value is automatically turned - // into an array. - function queryStringToObject(qstr) { - var result = {}, nvPairs = ((qstr || "").replace(/^\?/, "").split(/&/)), i, pair, n, v; - - for (i = 0; i < nvPairs.length; i++) { - var pstr = nvPairs[i]; - if (pstr) { - pair = pstr.split(/=/); - n = pair[0]; - v = pair[1]; - if (result[n] === undefined) { - result[n] = v; - } else { - if (typeof result[n] !== "object") { - result[n] = [result[n]]; - } - result[n].push(v); - } - } - } - - return result; - } - - // The idea here is to listen for any pagebeforechange notifications from - // jQuery Mobile, and then muck with the toPage and options so that query - // params can be passed to embedded/internal pages. So for example, if a - // changePage() request for a URL like: - // - // http://mycompany.com/myapp/#page-1?foo=1&bar=2 - // - // is made, the page that will actually get shown is: - // - // http://mycompany.com/myapp/#page-1 - // - // The browser's location will still be updated to show the original URL. - // The query params for the embedded page are also added as a property/value - // object on the options object. You can access it from your page notifications - // via data.options.pageData. - $(document).bind("pagebeforechange", function (e, data) { - - // We only want to handle the case where we are being asked - // to go to a page by URL, and only if that URL is referring - // to an internal page by id. - - if (typeof data.toPage === "string") { - var u = $.mobile.path.parseUrl(data.toPage); - if ($.mobile.path.isEmbeddedPage(u)) { - - // The request is for an internal page, if the hash - // contains query (search) params, strip them off the - // toPage URL and then set options.dataUrl appropriately - // so the location.hash shows the originally requested URL - // that hash the query params in the hash. - - var u2 = $.mobile.path.parseUrl(u.hash.replace(/^#/, "")); - if (u2.search) { - if (!data.options.dataUrl) { - data.options.dataUrl = data.toPage; - } - data.options.pageData = queryStringToObject(u2.search); - data.toPage = u.hrefNoHash + "#" + u2.pathname; - } - } - } - }); - -})(jQuery, window);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/IndexPage.js b/MediaBrowser.WebDashboard/Html/scripts/IndexPage.js deleted file mode 100644 index ee84e07de..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/IndexPage.js +++ /dev/null @@ -1,106 +0,0 @@ -var IndexPage = { - - onPageShow: function () { - IndexPage.loadLibrary(Dashboard.getCurrentUserId(), this); - }, - - loadLibrary: function (userId, page) { - - if (!userId) { - return; - } - - page = $(page); - - var options = { - - limit: 5, - sortBy: "DateCreated", - sortOrder: "Descending", - filters: "IsRecentlyAdded,IsNotFolder", - ImageTypes: "Primary,Backdrop,Thumb", - recursive: true - }; - - ApiClient.getItems(userId, options).done(function (result) { - - $('#divWhatsNew', page).html(Dashboard.getPosterViewHtml({ - items: result.Items, - preferBackdrop: true, - showTitle: true - })); - - }); - - options = { - - limit: 5, - sortBy: "DatePlayed", - sortOrder: "Descending", - filters: "IsResumable", - recursive: true - }; - - ApiClient.getItems(userId, options).done(function (result) { - - $('#divResumableItems', page).html(Dashboard.getPosterViewHtml({ - items: result.Items, - preferBackdrop: true, - showTitle: true - })); - - if (result.Items.length) { - $('#divResumable', page).show(); - } else { - $('#divResumable', page).hide(); - } - - }); - - options = { - - sortBy: "SortName" - }; - - ApiClient.getItems(userId, options).done(function (result) { - - $('#divCollections', page).html(Dashboard.getPosterViewHtml({ - items: result.Items, - showTitle: true - })); - - }); - - IndexPage.loadMyLibrary(userId, page); - }, - - loadMyLibrary: function (userId, page) { - - var items = [{ - Name: "Recently Played", - IsFolder: true - }, { - Name: "Favorites", - IsFolder: true - }, { - Name: "Genres", - IsFolder: true - }, { - Name: "Studios", - IsFolder: true - }, { - Name: "Performers", - IsFolder: true - }, { - Name: "Directors", - IsFolder: true - }]; - - $('#divMyLibrary', page).html(Dashboard.getPosterViewHtml({ - items: items, - showTitle: true - })); - } -}; - -$(document).on('pageshow', "#indexPage", IndexPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/ItemDetailPage.js b/MediaBrowser.WebDashboard/Html/scripts/ItemDetailPage.js deleted file mode 100644 index 8a97943b0..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/ItemDetailPage.js +++ /dev/null @@ -1,376 +0,0 @@ -var ItemDetailPage = { - - onPageShow: function () { - - ItemDetailPage.reload(); - - $('#galleryCollapsible', this).on('expand', ItemDetailPage.onGalleryExpand); - }, - - onPageHide: function () { - - $('#galleryCollapsible', this).off('expand', ItemDetailPage.onGalleryExpand); - - ItemDetailPage.item = null; - }, - - reload: function () { - var id = getParameterByName('id'); - - Dashboard.showLoadingMsg(); - - ApiClient.getItem(Dashboard.getCurrentUserId(), id).done(ItemDetailPage.renderItem); - }, - - renderItem: function (item) { - - ItemDetailPage.item = item; - - var page = $.mobile.activePage; - - ItemDetailPage.item = item; - - var name = item.Name; - - if (item.IndexNumber != null) { - name = item.IndexNumber + " - " + name; - } - - Dashboard.setPageTitle(name); - - ItemDetailPage.renderImage(item); - ItemDetailPage.renderOverviewBlock(item); - ItemDetailPage.renderScenes(item); - ItemDetailPage.renderMediaInfo(item); - - $('#itemName', page).html(name); - - Dashboard.hideLoadingMsg(); - }, - - renderImage: function (item) { - - var page = $.mobile.activePage; - - var imageTags = item.ImageTags || {}; - - var html = ''; - - var url; - var useBackgroundColor; - - if (imageTags.Primary) { - - url = ApiClient.getImageUrl(item.Id, { - type: "Primary", - width: 800, - tag: item.ImageTags.Primary - }); - } - else if (item.BackdropImageTags && item.BackdropImageTags.length) { - - url = ApiClient.getImageUrl(item.Id, { - type: "Backdrop", - width: 800, - tag: item.BackdropImageTags[0] - }); - } - else if (imageTags.Thumb) { - - url = ApiClient.getImageUrl(item.Id, { - type: "Thumb", - width: 800, - tag: item.ImageTags.Thumb - }); - } - else if (imageTags.Disc) { - - url = ApiClient.getImageUrl(item.Id, { - type: "Disc", - width: 800, - tag: item.ImageTags.Disc - }); - } - else if (item.MediaType == "Audio") { - url = "css/images/itemDetails/audioDefault.png"; - useBackgroundColor = true; - } - else if (item.MediaType == "Game") { - url = "css/images/itemDetails/gameDefault.png"; - useBackgroundColor = true; - } - else { - url = "css/images/itemDetails/videoDefault.png"; - useBackgroundColor = true; - } - - if (url) { - - var style = useBackgroundColor ? "background-color:" + Dashboard.getRandomMetroColor() + ";" : ""; - - html += "<img class='itemDetailImage' src='" + url + "' style='" + style + "' />"; - } - - $('#itemImage', page).html(html); - }, - - renderOverviewBlock: function (item) { - - var page = $.mobile.activePage; - - if (item.Taglines && item.Taglines.length) { - $('#itemTagline', page).html(item.Taglines[0]).show(); - } else { - $('#itemTagline', page).hide(); - } - - if (item.Overview) { - $('#itemOverview', page).html(item.Overview).show(); - } else { - $('#itemOverview', page).hide(); - } - - if (item.CommunityRating) { - $('#itemCommunityRating', page).html(ItemDetailPage.getStarRating(item)).show().attr('title', item.CommunityRating); - } else { - $('#itemCommunityRating', page).hide(); - } - - if (MediaPlayer.canPlay(item)) { - $('#btnPlay', page).show(); - $('#playButtonShadow', page).show(); - } else { - $('#btnPlay', page).hide(); - $('#playButtonShadow', page).hide(); - } - - var miscInfo = []; - - if (item.ProductionYear) { - miscInfo.push(item.ProductionYear); - } - - if (item.OfficialRating) { - miscInfo.push(item.OfficialRating); - } - - if (item.RunTimeTicks) { - - var minutes = item.RunTimeTicks / 600000000; - - minutes = minutes || 1; - - miscInfo.push(parseInt(minutes) + "min"); - } - - if (item.DisplayMediaType) { - miscInfo.push(item.DisplayMediaType); - } - - if (item.VideoFormat && item.VideoFormat !== 'Standard') { - miscInfo.push(item.VideoFormat); - } - - $('#itemMiscInfo', page).html(miscInfo.join(' ')); - - ItemDetailPage.renderGenres(item); - ItemDetailPage.renderStudios(item); - }, - - renderGenres: function (item) { - - var page = $.mobile.activePage; - - if (item.Genres && item.Genres.length) { - var elem = $('#itemGenres', page).show(); - - var html = 'Genres: '; - - for (var i = 0, length = item.Genres.length; i < length; i++) { - - if (i > 0) { - html += ' / '; - } - - html += '<a class="interiorLink" href="#">' + item.Genres[i] + '</a>'; - } - - elem.html(html); - - - } else { - $('#itemGenres', page).hide(); - } - }, - - renderStudios: function (item) { - - var page = $.mobile.activePage; - - if (item.Studios && item.Studios.length) { - var elem = $('#itemStudios', page).show(); - - var html = 'Studios: '; - - for (var i = 0, length = item.Studios.length; i < length; i++) { - - if (i > 0) { - html += ' / '; - } - - html += '<a class="interiorLink" href="#">' + item.Studios[i] + '</a>'; - } - - elem.html(html); - - - } else { - $('#itemStudios', page).hide(); - } - }, - - getStarRating: function (item) { - var rating = item.CommunityRating; - - var html = ""; - for (var i = 1; i <= 10; i++) { - if (rating < i - 1) { - html += "<div class='starRating emptyStarRating'></div>"; - } - else if (rating < i) { - html += "<div class='starRating halfStarRating'></div>"; - } - else { - html += "<div class='starRating'></div>"; - } - } - - return html; - }, - - renderScenes: function (item) { - - var html = ''; - - var page = $.mobile.activePage; - - if (!item.Chapters || !item.Chapters.length) { - $('#scenesCollapsible', page).hide(); - $('#scenesContent', page).html(html); - return; - } - - for (var i = 0, length = item.Chapters.length; i < length; i++) { - - var chapter = item.Chapters[i]; - - - } - - $('#scenesCollapsible', page).show(); - $('#scenesContent', page).html(html); - }, - - play: function () { - MediaPlayer.play([ItemDetailPage.item]); - }, - - onGalleryExpand: function() { - - if (ItemDetailPage.item) { - - ItemDetailPage.renderGallery(ItemDetailPage.item); - - $(this).off('expand', ItemDetailPage.onGalleryExpand); - } - }, - - renderGallery: function (item) { - - var page = $.mobile.activePage; - - var imageTags = item.ImageTags || {}; - - var html = ''; - - var downloadWidth = 400; - - if (imageTags.Logo) { - - html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(item.Id, { - type: "Logo", - width: downloadWidth, - tag: item.ImageTags.Logo - }) + '" />'; - } - if (imageTags.Thumb) { - - html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(item.Id, { - type: "Thumb", - width: downloadWidth, - tag: item.ImageTags.Thumb - }) + '" />'; - } - if (imageTags.Art) { - - html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(item.Id, { - type: "Art", - width: downloadWidth, - tag: item.ImageTags.Art - }) + '" />'; - } - if (imageTags.Menu) { - - html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(item.Id, { - type: "Menu", - width: downloadWidth, - tag: item.ImageTags.Menu - }) + '" />'; - } - if (imageTags.Disc) { - - html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(item.Id, { - type: "Disc", - width: downloadWidth, - tag: item.ImageTags.Disc - }) + '" />'; - } - if (imageTags.Box) { - - html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(item.Id, { - type: "Box", - width: downloadWidth, - tag: item.ImageTags.Box - }) + '" />'; - } - - if (item.BackdropImageTags) { - - for (var i = 0, length = item.BackdropImageTags.length; i < length; i++) { - html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(item.Id, { - type: "Backdrop", - width: downloadWidth, - tag: item.BackdropImageTags[0], - index: i - }) + '" />'; - } - - } - - $('#galleryContent', page).html(html); - }, - - renderMediaInfo: function(item) { - - var page = $.mobile.activePage; - - if (!item.MediaStreams || !item.MediaStreams.length) { - $('#mediaInfoCollapsible', page).hide(); - return; - } - - $('#mediaInfoCollapsible', page).show(); - } -}; - -$(document).on('pageshow', "#itemDetailPage", ItemDetailPage.onPageShow).on('pagehide', "#itemDetailPage", ItemDetailPage.onPageHide); diff --git a/MediaBrowser.WebDashboard/Html/scripts/ItemListPage.js b/MediaBrowser.WebDashboard/Html/scripts/ItemListPage.js deleted file mode 100644 index bf89fa813..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/ItemListPage.js +++ /dev/null @@ -1,46 +0,0 @@ -var ItemListPage = { - - onPageShow: function () { - - ItemListPage.reload(); - }, - - reload: function () { - - var userId = Dashboard.getCurrentUserId(); - - var parentId = getParameterByName('parentId'); - - var query = {}; - - if (parentId) { - query.parentId = parentId; - - ApiClient.getItem(userId, parentId).done(ItemListPage.renderTitle); - } - - ApiClient.getItems(userId, query).done(ItemListPage.renderItems); - }, - - renderItems: function(result) { - - var items = result.Items; - - var renderOptions = { - - items: items - }; - - var html = Dashboard.getPosterViewHtml(renderOptions); - - $('#listItems', $.mobile.activePage).html(html); - }, - - renderTitle: function (item) { - - - $('#itemName', $.mobile.activePage).html(item.Name); - } -}; - -$(document).on('pageshow', "#itemListPage", ItemListPage.onPageShow); diff --git a/MediaBrowser.WebDashboard/Html/scripts/LogPage.js b/MediaBrowser.WebDashboard/Html/scripts/LogPage.js deleted file mode 100644 index 133eb34fb..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/LogPage.js +++ /dev/null @@ -1,86 +0,0 @@ -var LogPage = { - - onPageShow: function () { - - LogPage.startLine = 0; - - $('#logContents', this).html(''); - - $(document).on("websocketmessage", LogPage.onWebSocketMessage).on("websocketopen", LogPage.onWebSocketConnectionChange).on("websocketerror", LogPage.onWebSocketConnectionChange).on("websocketclose", LogPage.onWebSocketConnectionChange); - - LogPage.startInterval(); - - var autoScroll = localStorage.getItem("autoScrollLogPage"); - - if (autoScroll == "true") { - LogPage.updateAutoScroll(true); - } - else if (autoScroll == "false") { - LogPage.updateAutoScroll(false); - } - }, - - onPageHide: function () { - - $(document).off("websocketmessage", LogPage.onWebSocketMessage).off("websocketopen", LogPage.onWebSocketConnectionChange).off("websocketerror", LogPage.onWebSocketConnectionChange).off("websocketclose", LogPage.onWebSocketConnectionChange); - - LogPage.stopInterval(); - }, - - startInterval: function () { - - if (Dashboard.isWebSocketOpen()) { - Dashboard.sendWebSocketMessage("LogFileStart", "0,2000"); - } - }, - - stopInterval: function () { - - if (Dashboard.isWebSocketOpen()) { - Dashboard.sendWebSocketMessage("LogFileStop"); - } - }, - - onWebSocketConnectionChange: function () { - LogPage.stopInterval(); - LogPage.startInterval(); - }, - - onWebSocketMessage: function (e, msg) { - - if (msg.MessageType == "LogFile") { - LogPage.appendLines(msg.Data); - } - }, - - appendLines: function (lines) { - - if (!lines.length) { - return; - } - - LogPage.startLine += lines.length; - - lines = lines.join('\n') + '\n'; - - var elem = $('#logContents', $.mobile.activePage).append(lines)[0]; - - elem.style.height = (elem.scrollHeight) + 'px'; - - if ($('#chkAutoScroll', $.mobile.activePage).checked()) { - $('html, body').animate({ scrollTop: $(document).height() }, 'slow'); - } - }, - - updateAutoScroll: function (value) { - - var page = $.mobile.activePage; - - $('#chkAutoScrollBottom', page).checked(value).checkboxradio('refresh'); - $('#chkAutoScroll', page).checked(value).checkboxradio('refresh'); - - localStorage.setItem("autoScrollLogPage", value.toString()); - } -}; - -$(document).on('pageshow', "#logPage", LogPage.onPageShow).on('pagehide', "#logPage", LogPage.onPageHide);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/LoginPage.js b/MediaBrowser.WebDashboard/Html/scripts/LoginPage.js deleted file mode 100644 index 5c17b90cb..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/LoginPage.js +++ /dev/null @@ -1,119 +0,0 @@ -var LoginPage = { - - onPageShow: function () { - Dashboard.showLoadingMsg(); - - ApiClient.getUsers().done(LoginPage.loadUserList); - }, - - getLastSeenText: function (lastActivityDate) { - - if (!lastActivityDate) { - return ""; - } - - return "Last seen " + humane_date(lastActivityDate); - }, - - getImagePath: function (user) { - - if (!user.PrimaryImageTag) { - return "css/images/logindefault.png"; - } - - return ApiClient.getUserImageUrl(user.Id, { - width: 240, - tag: user.PrimaryImageTag, - type: "Primary" - }); - }, - - authenticateUserLink: function (link) { - - LoginPage.authenticateUser(link.getAttribute('data-username'), link.getAttribute('data-userid')); - }, - - authenticateUser: function (username, userId, password) { - - Dashboard.showLoadingMsg(); - - ApiClient.authenticateUser(userId, password).done(function () { - - Dashboard.setCurrentUser(userId); - - window.location = "index.html?u=" + userId; - - }).fail(function () { - Dashboard.hideLoadingMsg(); - - setTimeout(function () { - Dashboard.showError("Invalid user or password."); - }, 300); - }); - }, - - loadUserList: function (users) { - var html = ""; - - for (var i = 0, length = users.length; i < length; i++) { - var user = users[i]; - - var linkId = "lnkUser" + i; - - var background = Dashboard.getRandomMetroColor(); - - html += '<div class="posterViewItem posterViewItemWithDualText">'; - - if (user.HasPassword) { - html += "<a id='" + linkId + "' data-userid='" + user.Id + "' data-username='" + user.Name + "' href='#popupLogin' data-rel='popup' onclick='LoginPage.authenticatingLinkId=this.id;' \">"; - } else { - html += "<a id='" + linkId + "' data-userid='" + user.Id + "' data-username='" + user.Name + "' href='#' onclick='LoginPage.authenticateUserLink(this);' \">"; - } - - if (user.PrimaryImageTag) { - - var imgUrl = ApiClient.getUserImageUrl(user.Id, { - width: 500, - tag: user.PrimaryImageTag, - type: "Primary" - }); - - html += '<img src="' + imgUrl + '" />'; - } else { - html += '<img style="background:' + background + ';" src="css/images/logindefault.png"/>'; - } - - html += '<div class="posterViewItemText posterViewItemPrimaryText">' + user.Name + '</div>'; - html += '<div class="posterViewItemText">'; - var lastSeen = LoginPage.getLastSeenText(user.LastActivityDate); - if (lastSeen != "") { - html += lastSeen; - } - else { - html += " "; - } - html += '</div>'; - - html += '</a>'; - - html += '</div>'; - } - - $('#divUsers', '#loginPage').html(html); - - Dashboard.hideLoadingMsg(); - }, - - onSubmit: function () { - $('#popupLogin', '#loginPage').popup('close'); - - var link = $('#' + LoginPage.authenticatingLinkId)[0]; - - LoginPage.authenticateUser(link.getAttribute('data-username'), link.getAttribute('data-userid'), $('#pw', '#loginPage').val()); - - // Disable default form submission - return false; - } -}; - -$(document).on('pageshow', "#loginPage", LoginPage.onPageShow); diff --git a/MediaBrowser.WebDashboard/Html/scripts/MediaLibraryPage.js b/MediaBrowser.WebDashboard/Html/scripts/MediaLibraryPage.js deleted file mode 100644 index 4f4d119d8..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/MediaLibraryPage.js +++ /dev/null @@ -1,272 +0,0 @@ -var MediaLibraryPage = { - - onPageShow: function () { - - MediaLibraryPage.lastVirtualFolderName = ""; - - MediaLibraryPage.reloadLibrary(); - }, - - reloadLibrary: function () { - - Dashboard.showLoadingMsg(); - - var userId = getParameterByName("userId"); - - var page = $.mobile.activePage; - - if (userId) { - - $('#userProfileNavigation', page).show(); - - ApiClient.getUser(userId).done(function (user) { - - Dashboard.setPageTitle(user.Name); - - $('#fldUseDefaultLibrary', page).show(); - - $('#chkUseDefaultLibrary', page).checked(!user.Configuration.UseCustomLibrary).checkboxradio("refresh"); - - if (user.Configuration.UseCustomLibrary) { - - ApiClient.getVirtualFolders(userId).done(MediaLibraryPage.reloadVirtualFolders); - $('#divMediaLibrary', page).show(); - } else { - $('#divMediaLibrary', page).hide(); - Dashboard.hideLoadingMsg(); - } - - }); - - } else { - - $('#userProfileNavigation', page).hide(); - ApiClient.getVirtualFolders().done(MediaLibraryPage.reloadVirtualFolders); - - $('#fldUseDefaultLibrary', page).hide(); - $('#divMediaLibrary', page).show(); - Dashboard.setPageTitle("Media Library"); - } - }, - - reloadVirtualFolders: function (virtualFolders) { - - var page = $.mobile.activePage; - - if (virtualFolders) { - MediaLibraryPage.virtualFolders = virtualFolders; - } else { - virtualFolders = MediaLibraryPage.virtualFolders; - } - - var html = ''; - - for (var i = 0, length = virtualFolders.length; i < length; i++) { - - var virtualFolder = virtualFolders[i]; - - var isCollapsed = MediaLibraryPage.lastVirtualFolderName != virtualFolder.Name; - - html += MediaLibraryPage.getVirtualFolderHtml(virtualFolder, isCollapsed, i); - } - - $('#divVirtualFolders', page).html(html).trigger('create'); - - Dashboard.hideLoadingMsg(); - }, - - getVirtualFolderHtml: function (virtualFolder, isCollapsed, index) { - - isCollapsed = isCollapsed ? "true" : "false"; - var html = '<div class="collapsibleVirtualFolder" data-role="collapsible" data-collapsed="' + isCollapsed + '" data-content-theme="c">'; - - html += '<h3>' + virtualFolder.Name + '</h3>'; - - html += '<ul class="mediaFolderLocations" data-inset="true" data-role="listview" data-split-icon="minus">'; - - html += '<li data-role="list-divider" class="mediaLocationsHeader">Media Locations'; - html += '<button type="button" data-icon="plus" data-mini="true" data-theme="c" data-inline="true" data-iconpos="notext" onclick="MediaLibraryPage.addMediaLocation(' + index + ');"></button>'; - html += '</li>'; - - for (var i = 0, length = virtualFolder.Locations.length; i < length; i++) { - - var location = virtualFolder.Locations[i]; - html += '<li>'; - html += '<a class="lnkMediaLocation" href="#">' + location + '</a>'; - html += '<a href="#" data-index="' + i + '" data-folderindex="' + index + '" onclick="MediaLibraryPage.deleteMediaLocation(this);"></a>'; - html += '</li>'; - } - html += '</ul>'; - - html += '<p>'; - html += '<button type="button" data-inline="true" data-icon="minus" data-folderindex="' + index + '" onclick="MediaLibraryPage.deleteVirtualFolder(this);">Remove collection</button>'; - html += '<button type="button" data-inline="true" data-icon="pencil" data-folderindex="' + index + '" onclick="MediaLibraryPage.renameVirtualFolder(this);">Rename collection</button>'; - html += '</p>'; - - html += '</div>'; - - return html; - }, - - setUseDefaultMediaLibrary: function (useDefaultLibrary) { - - Dashboard.showLoadingMsg(); - - var userId = getParameterByName("userId"); - - ApiClient.getUser(userId).done(function (user) { - - user.Configuration.UseCustomLibrary = !useDefaultLibrary; - - ApiClient.updateUser(user).done(MediaLibraryPage.reloadLibrary); - }); - }, - - addVirtualFolder: function () { - - MediaLibraryPage.getTextValue("Add Media Collection", "Name:", "", function (name) { - - var userId = getParameterByName("userId"); - - MediaLibraryPage.lastVirtualFolderName = name; - - ApiClient.addVirtualFolder(name, userId).done(MediaLibraryPage.processOperationResult); - - }); - }, - - addMediaLocation: function (virtualFolderIndex) { - - MediaLibraryPage.selectDirectory(function (path) { - - if (path) { - - var virtualFolder = MediaLibraryPage.virtualFolders[virtualFolderIndex]; - - MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; - - var userId = getParameterByName("userId"); - - ApiClient.addMediaPath(virtualFolder.Name, path, userId).done(MediaLibraryPage.processOperationResult); - } - - }); - }, - - selectDirectory: function (callback) { - - Dashboard.selectDirectory({callback: callback}); - }, - - getTextValue: function (header, label, initialValue, callback) { - - var page = $.mobile.activePage; - - var popup = $('#popupEnterText', page); - - $('h3', popup).html(header); - $('label', popup).html(label); - $('#txtValue', popup).val(initialValue); - - popup.popup("open").on("popupafterclose", function () { - - $(this).off("popupafterclose").off("click"); - - $('#textEntryForm', this).off("submit"); - - }); - - $('#textEntryForm', popup).on('submit', function () { - - if (callback) { - callback($('#txtValue', popup).val()); - } - - return false; - }); - }, - - renameVirtualFolder: function (button) { - - var folderIndex = button.getAttribute('data-folderindex'); - var virtualFolder = MediaLibraryPage.virtualFolders[folderIndex]; - - MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; - - MediaLibraryPage.getTextValue(virtualFolder.Name, "Rename " + virtualFolder.Name, virtualFolder.Name, function (newName) { - - if (virtualFolder.Name != newName) { - - var userId = getParameterByName("userId"); - - ApiClient.renameVirtualFolder(virtualFolder.Name, newName, userId).done(MediaLibraryPage.processOperationResult); - } - }); - }, - - deleteVirtualFolder: function (button) { - - var folderIndex = button.getAttribute('data-folderindex'); - var virtualFolder = MediaLibraryPage.virtualFolders[folderIndex]; - - var parent = $(button).parents('.collapsibleVirtualFolder'); - - var locations = $('.lnkMediaLocation', parent).map(function () { - return this.innerHTML; - }).get(); - - var msg = "Are you sure you wish to remove " + virtualFolder.Name + "?"; - - if (locations.length) { - msg += "<br/><br/>The following media locations will be removed from your library:<br/><br/>"; - msg += locations.join("<br/>"); - } - - MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; - - Dashboard.confirm(msg, "Remove Media Folder", function (confirmResult) { - - if (confirmResult) { - - var userId = getParameterByName("userId"); - - ApiClient.removeVirtualFolder(virtualFolder.Name, userId).done(MediaLibraryPage.processOperationResult); - } - - }); - }, - - deleteMediaLocation: function (button) { - - var folderIndex = button.getAttribute('data-folderindex'); - var index = parseInt(button.getAttribute('data-index')); - - var virtualFolder = MediaLibraryPage.virtualFolders[folderIndex]; - - MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; - - var location = virtualFolder.Locations[index]; - - Dashboard.confirm("Are you sure you wish to remove " + location + "?", "Remove Media Location", function (confirmResult) { - - if (confirmResult) { - - var userId = getParameterByName("userId"); - - ApiClient.removeMediaPath(virtualFolder.Name, location, userId).done(MediaLibraryPage.processOperationResult); - } - }); - }, - - processOperationResult: function (result) { - Dashboard.hideLoadingMsg(); - - var page = $.mobile.activePage; - - $('#popupEnterText', page).popup("close"); - $('#popupDirectoryPicker', page).popup("close"); - MediaLibraryPage.reloadLibrary(); - } -}; - -$(document).on('pageshow', ".mediaLibraryPage", MediaLibraryPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/MediaPlayer.js b/MediaBrowser.WebDashboard/Html/scripts/MediaPlayer.js deleted file mode 100644 index 928fb06b6..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/MediaPlayer.js +++ /dev/null @@ -1,182 +0,0 @@ -var MediaPlayer = { - - canPlay: function (item) { - - if (item.MediaType === "Video") { - - var media = document.createElement('video'); - - if (media.canPlayType) { - - return media.canPlayType('video/mp4').replace(/no/, '') || media.canPlayType('video/mp2t').replace(/no/, '') || media.canPlayType('video/webm').replace(/no/, '') || media.canPlayType('application/x-mpegURL').replace(/no/, '') || media.canPlayType('video/ogv').replace(/no/, ''); - } - - return false; - } - - if (item.MediaType === "Audio") { - - var media = document.createElement('audio'); - - if (media.canPlayType) { - return media.canPlayType('audio/mpeg').replace(/no/, '') || media.canPlayType('audio/aac').replace(/no/, ''); - } - - return false; - } - - return false; - }, - - play: function (items) { - - if (MediaPlayer.isPlaying()) { - MediaPlayer.stop(); - } - - var item = items[0]; - - var mediaElement; - - if (item.MediaType === "Video") { - - mediaElement = MediaPlayer.playVideo(items); - } - - else if (item.MediaType === "Audio") { - - mediaElement = MediaPlayer.playAudio(items); - } - - if (!mediaElement) { - return; - } - - MediaPlayer.mediaElement = mediaElement; - - var nowPlayingBar = $('#nowPlayingBar').show(); - - if (items.length > 1) { - $('#previousTrackButton', nowPlayingBar)[0].disabled = false; - $('#nextTrackButton', nowPlayingBar)[0].disabled = false; - } else { - $('#previousTrackButton', nowPlayingBar)[0].disabled = true; - $('#nextTrackButton', nowPlayingBar)[0].disabled = true; - } - }, - - playAudio: function (items) { - var item = items[0]; - - var baseParams = { - audioChannels: 2, - audioBitrate: 128000 - }; - - var mp3Url = ApiClient.getUrl('Audio/' + item.Id + '/stream.mp3', $.extend({}, baseParams, { - audioCodec: 'mp3' - })); - - var aacUrl = ApiClient.getUrl('Audio/' + item.Id + '/stream.aac', $.extend({}, baseParams, { - audioCodec: 'aac' - })); - - var webmUrl = ApiClient.getUrl('Audio/' + item.Id + '/stream.webma', $.extend({}, baseParams, { - audioCodec: 'Vorbis' - })); - - var oggUrl = ApiClient.getUrl('Audio/' + item.Id + '/stream.oga', $.extend({}, baseParams, { - audioCodec: 'Vorbis' - })); - - var html = ''; - html += '<audio class="itemAudio" preload="none" controls autoplay>'; - html += '<source type="audio/mpeg" src="' + mp3Url + '" />'; - html += '<source type="audio/aac" src="' + aacUrl + '" />'; - html += '<source type="audio/webm" src="' + webmUrl + '" />'; - html += '<source type="audio/ogg" src="' + oggUrl + '" />'; - html += '</audio'; - - var nowPlayingBar = $('#nowPlayingBar').show(); - - $('#mediaElement', nowPlayingBar).html(html); - - return $('audio', nowPlayingBar)[0]; - }, - - playVideo: function (items) { - - var item = items[0]; - - // Account for screen rotation. Use the larger dimension as the width. - var screenWidth = Math.max(screen.height, screen.width); - var screenHeight = Math.min(screen.height, screen.width); - - var baseParams = { - audioChannels: 2, - audioBitrate: 128000, - videoBitrate: 500000, - maxWidth: screenWidth, - maxHeight: screenHeight - }; - - var mp4VideoUrl = ApiClient.getUrl('Videos/' + item.Id + '/stream.mp4', $.extend({}, baseParams, { - videoCodec: 'h264', - audioCodec: 'aac' - })); - - var tsVideoUrl = ApiClient.getUrl('Videos/' + item.Id + '/stream.ts', $.extend({}, baseParams, { - videoCodec: 'h264', - audioCodec: 'aac' - })); - - var webmVideoUrl = ApiClient.getUrl('Videos/' + item.Id + '/stream.webm', $.extend({}, baseParams, { - videoCodec: 'vpx', - audioCodec: 'Vorbis' - })); - - var hlsVideoUrl = ApiClient.getUrl('Videos/' + item.Id + '/stream.m3u8', $.extend({}, baseParams, { - videoCodec: 'h264', - audioCodec: 'aac' - })); - - var ogvVideoUrl = ApiClient.getUrl('Videos/' + item.Id + '/stream.ogv', $.extend({}, baseParams, { - videoCodec: 'theora', - audioCodec: 'Vorbis' - })); - - var html = ''; - html += '<video class="itemVideo" preload="none" controls autoplay>'; - html += '<source type="video/webm" src="' + webmVideoUrl + '" />'; - html += '<source type="video/mp4" src="' + mp4VideoUrl + '" />'; - html += '<source type=\'video/mp2t; codecs="h264, aac"\' src="' + tsVideoUrl + '" />'; - html += '<source type="application/x-mpegURL" src="' + hlsVideoUrl + '" />'; - html += '<source type="video/ogg" src="' + ogvVideoUrl + '" />'; - - html += '</video'; - - var nowPlayingBar = $('#nowPlayingBar').show(); - - $('#mediaElement', nowPlayingBar).html(html); - - return $('video', nowPlayingBar)[0]; - }, - - stop: function () { - - var elem = MediaPlayer.mediaElement; - - elem.pause(); - elem.src = ""; - - $(elem).remove(); - - $('#nowPlayingBar').hide(); - - MediaPlayer.mediaElement = null; - }, - - isPlaying: function () { - return MediaPlayer.mediaElement; - } -};
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/MetadataConfigurationPage.js b/MediaBrowser.WebDashboard/Html/scripts/MetadataConfigurationPage.js deleted file mode 100644 index bfb7b7881..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/MetadataConfigurationPage.js +++ /dev/null @@ -1,107 +0,0 @@ -var MetadataConfigurationPage = { - - onPageShow: function () { - Dashboard.showLoadingMsg(); - - var page = this; - - var config; - var allCultures; - var allCountries; - - ApiClient.getServerConfiguration().done(function (result) { - - config = result; - MetadataConfigurationPage.load(page, config, allCultures, allCountries); - }); - - ApiClient.getCultures().done(function (result) { - - MetadataConfigurationPage.populateLanguages(result); - - allCultures = result; - MetadataConfigurationPage.load(page, config, allCultures, allCountries); - }); - - ApiClient.getCountries().done(function (result) { - - MetadataConfigurationPage.populateCountries(result); - - allCountries = result; - MetadataConfigurationPage.load(page, config, allCultures, allCountries); - }); - }, - - load: function (page, config, allCultures, allCountries) { - - if (!config || !allCultures || !allCountries) { - return; - } - - $('#chkEnableInternetProviders', page).checked(config.EnableInternetProviders).checkboxradio("refresh"); - $('#chkSaveLocal', page).checked(config.SaveLocalMeta).checkboxradio("refresh"); - $('#txtRefreshDays', page).val(config.MetadataRefreshDays); - $('#selectLanguage', page).val(config.PreferredMetadataLanguage).selectmenu("refresh"); - $('#selectCountry', page).val(config.MetadataCountryCode).selectmenu("refresh"); - - Dashboard.hideLoadingMsg(); - }, - - populateCountries: function (allCountries) { - - var html = ""; - - html += "<option value=''>None</option>"; - - for (var i = 0, length = allCountries.length; i < length; i++) { - - var culture = allCountries[i]; - - html += "<option value='" + culture.TwoLetterISORegionName + "'>" + culture.DisplayName + "</option>"; - } - - $('#selectCountry', '#metadataConfigurationPage').html(html).selectmenu("refresh"); - }, - - populateLanguages: function (allCultures) { - - var html = ""; - - html += "<option value=''>None</option>"; - - for (var i = 0, length = allCultures.length; i < length; i++) { - - var culture = allCultures[i]; - - html += "<option value='" + culture.TwoLetterISOLanguageName + "'>" + culture.DisplayName + "</option>"; - } - - $('#selectLanguage', '#metadataConfigurationPage').html(html).selectmenu("refresh"); - }, - - submit: function () { - - $('.btnSubmit', $.mobile.activePage)[0].click(); - - }, - - onSubmit: function () { - var form = this; - - ApiClient.getServerConfiguration().done(function (config) { - - config.EnableInternetProviders = $('#chkEnableInternetProviders', form).checked(); - config.SaveLocalMeta = $('#chkSaveLocal', form).checked(); - config.MetadataRefreshDays = $('#txtRefreshDays', form).val(); - config.PreferredMetadataLanguage = $('#selectLanguage', form).val(); - config.MetadataCountryCode = $('#selectCountry', form).val(); - - ApiClient.updateServerConfiguration(config); - }); - - // Disable default form submission - return false; - } -}; - -$(document).on('pageshow', "#metadataConfigurationPage", MetadataConfigurationPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/MetadataImagesPage.js b/MediaBrowser.WebDashboard/Html/scripts/MetadataImagesPage.js deleted file mode 100644 index c50cd37d7..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/MetadataImagesPage.js +++ /dev/null @@ -1,90 +0,0 @@ -var MetadataImagesPage = { - - onPageShow: function () { - - Dashboard.showLoadingMsg(); - - var page = this; - - ApiClient.getServerConfiguration().done(function(result) { - MetadataImagesPage.load(page, result); - }); - }, - - load: function (page, config) { - - $('#selectTmdbPersonImageDownloadSize', page).val(config.TmdbFetchedProfileSize).selectmenu("refresh"); - $('#selectTmdbPosterDownloadSize', page).val(config.TmdbFetchedPosterSize).selectmenu("refresh"); - $('#selectTmdbBackdropDownloadSize', page).val(config.TmdbFetchedBackdropSize).selectmenu("refresh"); - - $('#chkRefreshItemImages', page).checked(config.RefreshItemImages).checkboxradio("refresh"); - $('#txtNumbackdrops', page).val(config.MaxBackdrops); - - $('#chkDownloadMovieArt', page).checked(config.DownloadMovieImages.Art).checkboxradio("refresh"); - $('#chkDownloadMovieBanner', page).checked(config.DownloadMovieImages.Banner).checkboxradio("refresh"); - $('#chkDownloadMovieDisc', page).checked(config.DownloadMovieImages.Disc).checkboxradio("refresh"); - $('#chkDownloadMovieLogo', page).checked(config.DownloadMovieImages.Logo).checkboxradio("refresh"); - $('#chkDownloadMovieThumb', page).checked(config.DownloadMovieImages.Thumb).checkboxradio("refresh"); - $('#chKDownloadTVArt', page).checked(config.DownloadSeriesImages.Art).checkboxradio("refresh"); - $('#chkDownloadTVBanner', page).checked(config.DownloadSeriesImages.Banner).checkboxradio("refresh"); - $('#chkDownloadTVLogo', page).checked(config.DownloadSeriesImages.Logo).checkboxradio("refresh"); - $('#chkDownloadTVThumb', page).checked(config.DownloadSeriesImages.Thumb).checkboxradio("refresh"); - $('#chkDownloadSeasonBanner', page).checked(config.DownloadSeasonImages.Banner).checkboxradio("refresh"); - $('#chkDownloadSeasonThumb', page).checked(config.DownloadSeasonImages.Thumb).checkboxradio("refresh"); - $('#chkDownloadSeasonBackdrops', page).checked(config.DownloadSeasonImages.Backdrops).checkboxradio("refresh"); - $('#chkDownloadArtistThumb', page).checked(config.DownloadMusicArtistImages.Thumb).checkboxradio("refresh"); - $('#chkDownloadArtistBackdrops', page).checked(config.DownloadMusicArtistImages.Backdrops).checkboxradio("refresh"); - $('#chkDownloadArtistLogo', page).checked(config.DownloadMusicArtistImages.Logo).checkboxradio("refresh"); - $('#chkDownloadArtistBanner', page).checked(config.DownloadMusicArtistImages.Banner).checkboxradio("refresh"); - $('#chkDownloadAlbumPrimary', page).checked(config.DownloadMusicAlbumImages.Primary).checkboxradio("refresh"); - $('#chkDownloadAlbumBackdrops', page).checked(config.DownloadMusicAlbumImages.Backdrops).checkboxradio("refresh"); - - Dashboard.hideLoadingMsg(); - }, - - submit: function () { - - $('.btnSubmit', $.mobile.activePage)[0].click(); - - }, - - onSubmit: function () { - var form = this; - - ApiClient.getServerConfiguration().done(function (config) { - - config.TmdbFetchedProfileSize = $('#selectTmdbPersonImageDownloadSize', form).val(); - config.TmdbFetchedPosterSize = $('#selectTmdbPosterDownloadSize', form).val(); - config.TmdbFetchedBackdropSize = $('#selectTmdbBackdropDownloadSize', form).val(); - - config.RefreshItemImages = $('#chkRefreshItemImages', form).checked(); - config.MaxBackdrops = $('#txtNumbackdrops', form).val(); - - config.DownloadMovieImages.Art = $('#chkDownloadMovieArt', form).checked(); - config.DownloadMovieImages.Banner = $('#chkDownloadMovieBanner', form).checked(); - config.DownloadMovieImages.Disc = $('#chkDownloadMovieDisc', form).checked(); - config.DownloadMovieImages.Logo = $('#chkDownloadMovieLogo', form).checked(); - config.DownloadMovieImages.Thumb = $('#chkDownloadMovieThumb', form).checked(); - config.DownloadSeriesImages.Art = $('#chKDownloadTVArt', form).checked(); - config.DownloadSeriesImages.Banner = $('#chkDownloadTVBanner', form).checked(); - config.DownloadSeriesImages.Logo = $('#chkDownloadTVLogo', form).checked(); - config.DownloadSeriesImages.Thumb = $('#chkDownloadTVThumb', form).checked(); - config.DownloadSeasonImages.Banner = $('#chkDownloadSeasonBanner', form).checked(); - config.DownloadSeasonImages.Thumb = $('#chkDownloadSeasonThumb', form).checked(); - config.DownloadSeasonImages.Backdrops = $('#chkDownloadSeasonBackdrops', form).checked(); - config.DownloadMusicArtistImages.Backdrops = $('#chkDownloadArtistBackdrops', form).checked(); - config.DownloadMusicArtistImages.Logo = $('#chkDownloadArtistLogo', form).checked(); - config.DownloadMusicArtistImages.Thumb = $('#chkDownloadArtistThumb', form).checked(); - config.DownloadMusicArtistImages.Banner = $('#chkDownloadArtistBanner', form).checked(); - config.DownloadMusicAlbumImages.Primary = $('#chkDownloadAlbumPrimary', form).checked(); - config.DownloadMusicAlbumImages.Backdrops = $('#chkDownloadAlbumBackdrops', form).checked(); - - ApiClient.updateServerConfiguration(config); - }); - - // Disable default form submission - return false; - } -}; - -$(document).on('pageshow', "#metadataImagesConfigurationPage", MetadataImagesPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/PluginCatalogPage.js b/MediaBrowser.WebDashboard/Html/scripts/PluginCatalogPage.js deleted file mode 100644 index cde6be9d4..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/PluginCatalogPage.js +++ /dev/null @@ -1,86 +0,0 @@ -var PluginCatalogPage = { - - onPageShow: function () { - PluginCatalogPage.reloadList(); - }, - - reloadList: function () { - - Dashboard.showLoadingMsg(); - - var promise1 = ApiClient.getAvailablePlugins(); - - var promise2 = ApiClient.getInstalledPlugins(); - - $.when(promise1, promise2).done(function (response1, response2) { - - PluginCatalogPage.populateList(response1[0], response2[0]); - }); - }, - - populateList: function (availablePlugins, installedPlugins) { - - var page = $($.mobile.activePage); - - availablePlugins = availablePlugins.filter(function (p) { - - return p.type == "UserInstalled"; - - }).sort(function (a, b) { - - return a.name > b.name ? 1 : -1; - - }); - - var html = ""; - - for (var i = 0, length = availablePlugins.length; i < length; i++) { - - var plugin = availablePlugins[i]; - - html += "<div class='posterViewItem'><a href='addPlugin.html?name=" + encodeURIComponent(plugin.name) + "'>"; - - if (plugin.thumbImage) { - html += "<img src='" + plugin.thumbImage + "' />"; - } else { - html += "<img style='background:#444444;' src='css/images/defaultCollectionImage.png' />"; - } - - if (plugin.isPremium) { - if (plugin.price > 0) { - html += "<div class='premiumBanner'><img src='css/images/premiumflag.png' /></div>"; - } else { - html += "<div class='premiumBanner'><img src='css/images/supporterflag.png' /></div>"; - } - } - - var color = plugin.tileColor || Dashboard.getRandomMetroColor(); - - html += "<div class='posterViewItemText' style='background:" + color + "'>"; - - var installedPlugin = installedPlugins.filter(function (ip) { - return ip.Name == plugin.name; - })[0]; - - html += "<div>"; - if (installedPlugin) { - - html += plugin.name + " (Installed)"; - } else { - html += plugin.name; - } - html += "</div>"; - - html += "</div>"; - - html += "</a></div>"; - - } - - $('#pluginTiles', page).html(html); - - Dashboard.hideLoadingMsg(); - } -}; - -$(document).on('pageshow', "#pluginCatalogPage", PluginCatalogPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/PluginUpdatesPage.js b/MediaBrowser.WebDashboard/Html/scripts/PluginUpdatesPage.js deleted file mode 100644 index 56bc6b4cf..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/PluginUpdatesPage.js +++ /dev/null @@ -1,104 +0,0 @@ -var PluginUpdatesPage = { - - onPageShow: function () { - - Dashboard.showLoadingMsg(); - - $('.liPluginUpdate', this).remove(); - - ApiClient.getInstalledPlugins().done(PluginUpdatesPage.loadPlugins); - - }, - - loadPlugins: function (plugins) { - - var elem = $('#tbodyPluginUpdates', $.mobile.activePage).html(''); - - for (var i = 0, length = plugins.length; i < length; i++) { - - PluginUpdatesPage.addPlugin(plugins[i], i, elem); - - } - - Dashboard.hideLoadingMsg(); - }, - - addPlugin: function (plugin, fieldIndex, elem) { - - var html = ""; - - html += "<tr>"; - - html += "<td><h3>" + plugin.Name + "</h3></td>"; - - var fieldId = "liPluginUpdateFielda" + fieldIndex; - - var options = PluginUpdatesPage.getHtmlOptions(["Off", "On"], (plugin.EnableAutoUpdate ? "On" : "Off")); - - html += "<td>"; - html += "<select data-id='" + plugin.Id + "' onchange='PluginUpdatesPage.setAutoUpdate(this);' data-role='slider' id='" + fieldId + "' name='" + fieldId + "'>" + options + "</select>"; - html += "</td>"; - - fieldId = "liPluginUpdateFieldb" + fieldIndex; - - options = PluginUpdatesPage.getHtmlOptions(["Release", "Beta", "Dev"], plugin.UpdateClass); - - html += "<td>"; - html += "<select data-id='" + plugin.Id + "' onchange='PluginUpdatesPage.setUpdateClass(this);' data-inline='true' id='" + fieldId + "' name='" + fieldId + "'>" + options + "</select>"; - html += "</td>"; - - html += "</tr>"; - - elem.append(html).trigger('create'); - }, - - getHtmlOptions: function (names, selectedValue) { - - var html = ""; - - for (var i = 0, length = names.length; i < length; i++) { - - var name = names[i]; - - if (name == selectedValue) { - html += '<option value="' + name + '" selected="selected">' + name + '</option>'; - } else { - html += '<option value="' + name + '">' + name + '</option>'; - } - } - - - return html; - - }, - - setAutoUpdate: function (select) { - - var id = $(select).attr('data-id'); - - Dashboard.showLoadingMsg(); - - ApiClient.getPluginConfiguration(id).done(function (config) { - - config.EnableAutoUpdate = select.selectedIndex === 1; - - ApiClient.updatePluginConfiguration(id, config).done(Dashboard.hideLoadingMsg); - }); - }, - - setUpdateClass: function (select) { - - var id = $(select).attr('data-id'); - - Dashboard.showLoadingMsg(); - - ApiClient.getPluginConfiguration(id).done(function (config) { - - config.UpdateClass = select.value; - - ApiClient.updatePluginConfiguration(id, config).done(Dashboard.hideLoadingMsg); - }); - } -}; - -$(document).on('pageshow', "#pluginUpdatesPage", PluginUpdatesPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/PluginsPage.js b/MediaBrowser.WebDashboard/Html/scripts/PluginsPage.js deleted file mode 100644 index c8ffe02d8..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/PluginsPage.js +++ /dev/null @@ -1,86 +0,0 @@ -var PluginsPage = { - - onPageShow: function () { - PluginsPage.reloadList(); - }, - - reloadList: function () { - - Dashboard.showLoadingMsg(); - - var promise1 = ApiClient.getInstalledPlugins(); - - var promise2 = $.getJSON("configurationpages?pageType=PluginConfiguration"); - - $.when(promise1, promise2).done(function(response1, response2) { - - PluginsPage.populateList(response1[0], response2[0]); - - }); - }, - - populateList: function (plugins, pluginConfigurationPages) { - - var page = $($.mobile.activePage); - - plugins = plugins.sort(function (plugin1, plugin2) { - - return (plugin1.Name) > (plugin2.Name) ? 1 : -1; - - }); - - var html = ""; - - for (var i = 0, length = plugins.length; i < length; i++) { - - var plugin = plugins[i]; - - var configPage = $.grep(pluginConfigurationPages, function (pluginConfigurationPage) { - return pluginConfigurationPage.PluginId == plugin.Id; - })[0]; - - html += "<li>"; - - var href = configPage ? Dashboard.getConfigurationPageUrl(configPage.Name) : "#"; - - html += "<a href='" + href + "'>"; - - html += "<h3>" + plugin.Name + "</h3>"; - - html += "<p><strong>" + plugin.Version + "</strong></p>"; - - html += "</a>"; - - html += "<a data-id='" + plugin.Id + "' data-pluginname='" + plugin.Name + "' onclick='PluginsPage.deletePlugin(this);' href='#'>Delete</a>"; - - html += "</li>"; - } - - $('#ulInstalledPlugins', page).html(html).listview('refresh'); - - Dashboard.hideLoadingMsg(); - }, - - deletePlugin: function (link) { - - var name = link.getAttribute('data-pluginname'); - var uniqueid = link.getAttribute('data-id'); - - var msg = "Are you sure you wish to uninstall " + name + "?"; - - Dashboard.confirm(msg, "Uninstall Plugin", function (result) { - - if (result) { - Dashboard.showLoadingMsg(); - - ApiClient.uninstallPlugin(uniqueid).done(function () { - - PluginsPage.reloadList(); - }); - } - }); - - } -}; - -$(document).on('pageshow', "#pluginsPage", PluginsPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/ScheduledTaskPage.js b/MediaBrowser.WebDashboard/Html/scripts/ScheduledTaskPage.js deleted file mode 100644 index e7ea33f80..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/ScheduledTaskPage.js +++ /dev/null @@ -1,294 +0,0 @@ -var ScheduledTaskPage = { - - onPageShow: function () { - - ScheduledTaskPage.refreshScheduledTask(); - }, - - refreshScheduledTask: function () { - Dashboard.showLoadingMsg(); - - var id = getParameterByName('id'); - - - ApiClient.getScheduledTask(id).done(ScheduledTaskPage.loadScheduledTask); - }, - - loadScheduledTask: function (task) { - - Dashboard.setPageTitle(task.Name); - - $('#pTaskDescription', $.mobile.activePage).html(task.Description); - - ScheduledTaskPage.loadTaskTriggers(task); - - Dashboard.hideLoadingMsg(); - }, - - loadTaskTriggers: function (task) { - - var html = ''; - - html += '<li data-role="list-divider"><h3>Task Triggers</h3></li>'; - - for (var i = 0, length = task.Triggers.length; i < length; i++) { - - var trigger = task.Triggers[i]; - - html += '<li>'; - - html += '<a href="#">'; - html += ScheduledTaskPage.getTriggerFriendlyName(trigger); - html += '</a>'; - - html += '<a href="#" onclick="ScheduledTaskPage.confirmDeleteTrigger(' + i + ');">Delete</a>'; - - html += '</li>'; - } - - $('#ulTaskTriggers', $.mobile.activePage).html(html).listview('refresh'); - }, - - getTriggerFriendlyName: function (trigger) { - - if (trigger.Type == 'DailyTrigger') { - return 'Daily at ' + ScheduledTaskPage.getDisplayTime(trigger.TimeOfDayTicks); - } - - if (trigger.Type == 'WeeklyTrigger') { - - return trigger.DayOfWeek + 's at ' + ScheduledTaskPage.getDisplayTime(trigger.TimeOfDayTicks); - } - - if (trigger.Type == 'SystemEventTrigger') { - - if (trigger.SystemEvent == 'WakeFromSleep') { - return 'On wake from sleep'; - } - } - - if (trigger.Type == 'IntervalTrigger') { - - var hours = trigger.IntervalTicks / 36000000000; - - if (hours == .25) { - return "Every 15 minutes"; - } - if (hours == .5) { - return "Every 30 minutes"; - } - if (hours == .75) { - return "Every 45 minutes"; - } - if (hours == 1) { - return "Every hour"; - } - - return 'Every ' + hours + ' hours'; - } - - if (trigger.Type == 'StartupTrigger') { - return 'On application startup'; - } - - return trigger.Type; - }, - - getDisplayTime: function (ticks) { - - var hours = ticks / 36000000000; - - if (hours < 1) { - hours = 0; - } - - hours = parseInt(hours); - - ticks -= (hours * 36000000000); - - var minutes = parseInt(ticks / 600000000); - - var suffix = "am"; - - if (hours > 11) { - suffix = "pm"; - } - - hours = hours % 12; - - if (hours == 0) { - hours = 12; - } - - if (minutes < 10) { - minutes = '0' + minutes; - } - - return hours + ':' + minutes + ' ' + suffix; - }, - - showAddTriggerPopup: function () { - - var page = $.mobile.activePage; - - $('#selectTriggerType', page).val('DailyTrigger').trigger('change').selectmenu('refresh'); - - $('#popupAddTrigger', page).popup("open").on("popupafterclose", function () { - - $('#addTriggerForm', page).off("submit"); - $(this).off("popupafterclose"); - }); - - $('#addTriggerForm', page).on('submit', function () { - - ScheduledTaskPage.addTrigger(); - - return false; - }); - }, - - addTrigger: function () { - - Dashboard.showLoadingMsg(); - - var id = getParameterByName('id'); - - ApiClient.getScheduledTask(id).done(function (task) { - - task.Triggers.push(ScheduledTaskPage.getTriggerToAdd()); - - ApiClient.updateScheduledTaskTriggers(task.Id, task.Triggers).done(function () { - - $('#popupAddTrigger').popup('close'); - - ScheduledTaskPage.refreshScheduledTask(); - - }); - - }); - - }, - - confirmDeleteTrigger: function (index) { - - Dashboard.confirm("Are you sure you wish to delete this task trigger?", "Delete Task Trigger", function (result) { - - if (result) { - ScheduledTaskPage.deleteTrigger(index); - } - - }); - - }, - - deleteTrigger: function (index) { - - Dashboard.showLoadingMsg(); - - var id = getParameterByName('id'); - - - ApiClient.getScheduledTask(id).done(function (task) { - - task.Triggers.remove(index); - - ApiClient.updateScheduledTaskTriggers(task.Id, task.Triggers).done(function () { - - ScheduledTaskPage.refreshScheduledTask(); - - }); - - }); - }, - - refreshTriggerFields: function (triggerType) { - - var page = $.mobile.activePage; - - if (triggerType == 'DailyTrigger') { - - $('#fldTimeOfDay', page).show(); - $('#fldDayOfWeek', page).hide(); - $('#fldSelectSystemEvent', page).hide(); - $('#fldSelectInterval', page).hide(); - $('#txtTimeOfDay', page).attr('required', 'required'); - } - - else if (triggerType == 'WeeklyTrigger') { - $('#fldTimeOfDay', page).show(); - $('#fldDayOfWeek', page).show(); - $('#fldSelectSystemEvent', page).hide(); - $('#fldSelectInterval', page).hide(); - $('#txtTimeOfDay', page).attr('required', 'required'); - } - - else if (triggerType == 'SystemEventTrigger') { - $('#fldTimeOfDay', page).hide(); - $('#fldDayOfWeek', page).hide(); - $('#fldSelectSystemEvent', page).show(); - $('#fldSelectInterval', page).hide(); - $('#txtTimeOfDay', page).removeAttr('required'); - } - - else if (triggerType == 'IntervalTrigger') { - $('#fldTimeOfDay', page).hide(); - $('#fldDayOfWeek', page).hide(); - $('#fldSelectSystemEvent', page).hide(); - $('#fldSelectInterval', page).show(); - $('#txtTimeOfDay', page).removeAttr('required'); - } - - else if (triggerType == 'StartupTrigger') { - $('#fldTimeOfDay', page).hide(); - $('#fldDayOfWeek', page).hide(); - $('#fldSelectSystemEvent', page).hide(); - $('#fldSelectInterval', page).hide(); - $('#txtTimeOfDay', page).removeAttr('required'); - } - }, - - getTriggerToAdd: function () { - - var page = $.mobile.activePage; - - var trigger = { - Type: $('#selectTriggerType', page).val() - }; - - if (trigger.Type == 'DailyTrigger') { - trigger.TimeOfDayTicks = ScheduledTaskPage.getTimeOfDayTicks($('#txtTimeOfDay', page).val()); - } - - else if (trigger.Type == 'WeeklyTrigger') { - trigger.DayOfWeek = $('#selectDayOfWeek', page).val(); - trigger.TimeOfDayTicks = ScheduledTaskPage.getTimeOfDayTicks($('#txtTimeOfDay', page).val()); - } - - else if (trigger.Type == 'SystemEventTrigger') { - trigger.SystemEvent = $('#selectSystemEvent', page).val(); - } - - else if (trigger.Type == 'IntervalTrigger') { - trigger.IntervalTicks = $('#selectInterval', page).val(); - } - - return trigger; - }, - - getTimeOfDayTicks: function (val) { - - var vals = val.split(':'); - - var hours = vals[0]; - var minutes = vals[1]; - - // Add hours - var ticks = hours * 60 * 60 * 1000 * 10000; - - ticks += minutes * 60 * 1000 * 10000; - - return ticks; - } -}; - -$(document).on('pageshow', "#scheduledTaskPage", ScheduledTaskPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/ScheduledTasksPage.js b/MediaBrowser.WebDashboard/Html/scripts/ScheduledTasksPage.js deleted file mode 100644 index 1a0a26d63..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/ScheduledTasksPage.js +++ /dev/null @@ -1,169 +0,0 @@ -var ScheduledTasksPage = { - - onPageShow: function () { - - Dashboard.showLoadingMsg(); - - ScheduledTasksPage.reloadList(true); - - $(document).on("websocketmessage", ScheduledTasksPage.onWebSocketMessage).on("websocketopen", ScheduledTasksPage.onWebSocketConnectionChange).on("websocketerror", ScheduledTasksPage.onWebSocketConnectionChange).on("websocketclose", ScheduledTasksPage.onWebSocketConnectionChange); - }, - - onPageHide: function () { - $(document).off("websocketmessage", ScheduledTasksPage.onWebSocketMessage).off("websocketopen", ScheduledTasksPage.onWebSocketConnectionChange).off("websocketerror", ScheduledTasksPage.onWebSocketConnectionChange).off("websocketclose", ScheduledTasksPage.onWebSocketConnectionChange); - ScheduledTasksPage.stopInterval(); - }, - - startInterval: function () { - - if (Dashboard.isWebSocketOpen()) { - Dashboard.sendWebSocketMessage("ScheduledTasksInfoStart", "1500,1500"); - } - }, - - stopInterval: function () { - - if (Dashboard.isWebSocketOpen()) { - Dashboard.sendWebSocketMessage("ScheduledTasksInfoStop"); - } - }, - - onWebSocketMessage: function (e, msg) { - - if (msg.MessageType == "ScheduledTasksInfo") { - ScheduledTasksPage.populateList(msg.Data); - } - }, - - onWebSocketConnectionChange: function() { - ScheduledTasksPage.reloadList(true); - }, - - reloadList: function (updateInterval) { - - if (updateInterval) { - ScheduledTasksPage.stopInterval(); - } - - ApiClient.getScheduledTasks().done(function (tasks) { - ScheduledTasksPage.populateList(tasks); - Dashboard.hideLoadingMsg(); - - if (updateInterval) { - ScheduledTasksPage.startInterval(); - } - - }); - }, - - populateList: function (tasks) { - - tasks = tasks.sort(function (a, b) { - - a = a.Category + " " + a.Name; - b = b.Category + " " + b.Name; - - if (a == b) { - return 0; - } - - if (a < b) { - return -1; - } - - return 1; - }); - - var page = $($.mobile.activePage); - - var html = ""; - - var currentCategory; - - for (var i = 0, length = tasks.length; i < length; i++) { - - var task = tasks[i]; - - if (task.Category != currentCategory) { - currentCategory = task.Category; - - html += "<li data-role='list-divider'>" + currentCategory + "</li>"; - } - - html += "<li>"; - - html += "<a href='scheduledTask.html?id=" + task.Id + "'>"; - - html += "<h3>" + task.Name + "</h3>"; - - if (task.State == "Idle") { - - if (task.LastExecutionResult) { - - var text = "Last ran " + humane_date(task.LastExecutionResult.EndTimeUtc) + ', taking ' + humane_elapsed(task.LastExecutionResult.StartTimeUtc, task.LastExecutionResult.EndTimeUtc); - - if (task.LastExecutionResult.Status == "Failed") { - text += " <span style='color:#FF0000;'>(failed)</span>"; - } - else if (task.LastExecutionResult.Status == "Cancelled") { - text += " <span style='color:#0026FF;'>(cancelled)</span>"; - } - else if (task.LastExecutionResult.Status == "Aborted") { - text += " <span style='color:#FF0000;'>(Aborted by server shutdown)</span>"; - } - - html += "<p>" + text + "</p>"; - } - - html += "<a href='#' data-icon='play' onclick='ScheduledTasksPage.startTask(\"" + task.Id + "\");'>Start</a>"; - } - else if (task.State == "Running") { - - var progress = Math.round(task.CurrentProgressPercentage || 0); - - html += '<p><progress max="100" value="' + progress + '" title="' + progress + '%">'; - html += '' + progress + '%'; - html += '</progress>'; - - html += "<span style='color:#009F00;margin-left:5px;'>" + progress + "%</span>"; - html += '</p>'; - - html += "<a href='#' data-icon='stop' onclick='ScheduledTasksPage.stopTask(\"" + task.Id + "\");'>Stop</a>"; - - } else { - - html += "<p style='color:#FF0000;'>Stopping</p>"; - html += "<a href='#' data-icon='play' style='visibility:hidden;'>Start</a>"; - } - - html += "</a>"; - - html += "</li>"; - } - - $('#ulScheduledTasks', page).html(html).listview('refresh'); - }, - - startTask: function (id) { - - Dashboard.showLoadingMsg(); - - ApiClient.startScheduledTask(id).done(function (result) { - - ScheduledTasksPage.reloadList(); - }); - - }, - - stopTask: function (id) { - - Dashboard.showLoadingMsg(); - - ApiClient.stopScheduledTask(id).done(function (result) { - - ScheduledTasksPage.reloadList(); - }); - } -}; - -$(document).on('pageshow', "#scheduledTasksPage", ScheduledTasksPage.onPageShow).on('pagehide', "#scheduledTasksPage", ScheduledTasksPage.onPageHide);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/SupporterKeyPage.js b/MediaBrowser.WebDashboard/Html/scripts/SupporterKeyPage.js deleted file mode 100644 index 88748064f..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/SupporterKeyPage.js +++ /dev/null @@ -1,77 +0,0 @@ -var SupporterKeyPage = { - - onPageShow: function () { - SupporterKeyPage.load(); - }, - - onPageHide: function () { - - }, - - load: function() { - Dashboard.showLoadingMsg(); - var page = $.mobile.activePage; - - ApiClient.getPluginSecurityInfo().done(function (info) { - $('#txtSupporterKey', page).val(info.SupporterKey); - $('#txtLegacyKey', page).val(info.LegacyKey); - if (info.IsMBSupporter) { - $('.supporterOnly', page).show(); - } else { - $('.supporterOnly', page).hide(); - } - Dashboard.hideLoadingMsg(); - }); - }, - - updateSupporterKey: function () { - - Dashboard.showLoadingMsg(); - var page = $.mobile.activePage; - - var key = $('#txtSupporterKey', page).val(); - var legacyKey = $('#txtLegacyKey', page).val(); - - var info = { - SupporterKey: key, - LegacyKey: legacyKey - }; - - ApiClient.updatePluginSecurityInfo(info).done(function () { - Dashboard.resetPluginSecurityInfo(); - Dashboard.hideLoadingMsg(); - SupporterPage.load(); - - }); - - return false; - }, - - retrieveSupporterKey: function () { - - Dashboard.showLoadingMsg(); - var page = $.mobile.activePage; - - var email = $('#txtEmail', page).val(); - - var url = "http://mb3admin.com/admin/service/supporter/retrievekey?email="+email; - console.log(url); - $.post(url).done(function (res) { - var result = JSON.parse(res); - Dashboard.hideLoadingMsg(); - if (result.Success) { - Dashboard.alert("Key emailed to "+email); - } else { - Dashboard.showError(result.ErrorMessage); - } - console.log(result); - - }); - - return false; - } - -}; - -$(document).on('pageshow', "#supporterKeyPage", SupporterKeyPage.onPageShow) - .on('pagehide', "#supporterKeyPage", SupporterKeyPage.onPageHide); diff --git a/MediaBrowser.WebDashboard/Html/scripts/SupporterPage.js b/MediaBrowser.WebDashboard/Html/scripts/SupporterPage.js deleted file mode 100644 index 2a599f259..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/SupporterPage.js +++ /dev/null @@ -1,29 +0,0 @@ -var SupporterPage = { - - onPageShow: function () { - SupporterPage.load(); - }, - - onPageHide: function () { - - }, - - load: function() { - Dashboard.showLoadingMsg(); - var page = $.mobile.activePage; - - ApiClient.getPluginSecurityInfo().done(function (info) { - $('#txtSupporterKey', page).val(info.SupporterKey); - if (info.IsMBSupporter) { - $('.supporterOnly', page).show(); - } else { - $('.supporterOnly', page).hide(); - } - $('#paypalReturnUrl', page).val(ApiClient.getCustomUrl("dashboard/supporterKey.html")); - Dashboard.hideLoadingMsg(); - }); - } -}; - -$(document).on('pageshow', "#supporterPage", SupporterPage.onPageShow) - .on('pagehide', "#supporterPage", SupporterPage.onPageHide); diff --git a/MediaBrowser.WebDashboard/Html/scripts/UpdatePasswordPage.js b/MediaBrowser.WebDashboard/Html/scripts/UpdatePasswordPage.js deleted file mode 100644 index 9c3a009b2..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/UpdatePasswordPage.js +++ /dev/null @@ -1,88 +0,0 @@ -var UpdatePasswordPage = { - - onPageShow: function () { - UpdatePasswordPage.loadUser(); - }, - - loadUser: function() { - var page = $.mobile.activePage; - - var userid = getParameterByName("userId"); - - ApiClient.getUser(userid).done(function (user) { - - Dashboard.setPageTitle(user.Name); - - if (user.HasPassword) { - $('#btnResetPassword', page).show(); - } else { - $('#btnResetPassword', page).hide(); - } - - }); - - $('#txtCurrentPassword', page).val(''); - $('#txtNewPassword', page).val(''); - $('#txtNewPasswordConfirm', page).val(''); - }, - - save: function () { - - var userId = getParameterByName("userId"); - - var page = $($.mobile.activePage); - var currentPassword = $('#txtCurrentPassword', page).val(); - var newPassword = $('#txtNewPassword', page).val(); - - ApiClient.updateUserPassword(userId, currentPassword, newPassword).done(UpdatePasswordPage.saveComplete); - }, - - saveComplete: function () { - - Dashboard.hideLoadingMsg(); - - Dashboard.alert("Password saved."); - UpdatePasswordPage.loadUser(); - }, - - resetPassword: function () { - - var msg = "Are you sure you wish to reset the password?"; - - Dashboard.confirm(msg, "Password Reset", function (result) { - - if (result) { - var userId = getParameterByName("userId"); - - Dashboard.showLoadingMsg(); - - ApiClient.resetUserPassword(userId).done(function () { - - Dashboard.hideLoadingMsg(); - Dashboard.alert("The password has been reset."); - UpdatePasswordPage.loadUser(); - - }); - } - }); - }, - - onSubmit: function () { - var page = $($.mobile.activePage); - - if ($('#txtNewPassword', page).val() != $('#txtNewPasswordConfirm', page).val()) { - - Dashboard.showError("Password and password confirmation must match."); - return false; - } - - Dashboard.showLoadingMsg(); - - UpdatePasswordPage.save(); - - // Disable default form submission - return false; - } -}; - -$(document).on('pageshow', "#updatePasswordPage", UpdatePasswordPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/UserImagePage.js b/MediaBrowser.WebDashboard/Html/scripts/UserImagePage.js deleted file mode 100644 index 58dadc6f8..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/UserImagePage.js +++ /dev/null @@ -1,181 +0,0 @@ -var UserImagePage = { - - onPageShow: function () { - - UserImagePage.reloadUser(); - - $("#userImageDropZone", this).on('dragover', UserImagePage.onImageDragOver).on('drop', UserImagePage.onImageDrop); - }, - - onPageHide: function () { - $("#userImageDropZone", this).off('dragover', UserImagePage.onImageDragOver).off('drop', UserImagePage.onImageDrop); - }, - - reloadUser: function () { - - var userId = getParameterByName("userId"); - - Dashboard.showLoadingMsg(); - - ApiClient.getUser(userId).done(function (user) { - - var page = $($.mobile.activePage); - - $('#uploadUserImage', page).val('').trigger('change'); - - Dashboard.setPageTitle(user.Name); - - if (user.PrimaryImageTag) { - - var imageUrl = ApiClient.getUserImageUrl(user.Id, { - height: 450, - tag: user.PrimaryImageTag, - type: "Primary" - }); - - $('#fldImage', page).show().html('').html("<img height='200px' src='" + imageUrl + "' />"); - - $('#fldDeleteImage', page).show(); - $('#headerUploadNewImage', page).show(); - } else { - $('#fldImage', page).hide().html(''); - $('#fldDeleteImage', page).hide(); - $('#headerUploadNewImage', page).hide(); - } - - Dashboard.hideLoadingMsg(); - }); - }, - - deleteImage: function () { - - Dashboard.confirm("Are you sure you wish to delete the image?", "Delete Image", function (result) { - - if (result) { - - Dashboard.showLoadingMsg(); - - var userId = getParameterByName("userId"); - - ApiClient.deleteUserImage(userId, "primary").done(UserImagePage.processImageChangeResult); - } - - }); - }, - - processImageChangeResult: function () { - - Dashboard.hideLoadingMsg(); - - Dashboard.validateCurrentUser(); - UserImagePage.reloadUser(); - }, - - onFileUploadChange: function (fileUpload) { - - UserImagePage.setFiles(fileUpload.files); - }, - - setFiles: function (files) { - - var page = $.mobile.activePage; - - var file = files[0]; - - if (!file || !file.type.match('image.*')) { - $('#userImageOutput', page).html(''); - $('#fldUpload', page).hide(); - UserImagePage.currentFile = null; - return; - } - - UserImagePage.currentFile = file; - - var reader = new FileReader(); - - reader.onerror = UserImagePage.onFileReaderError; - reader.onloadstart = UserImagePage.onFileReaderOnloadStart; - reader.onabort = UserImagePage.onFileReaderAbort; - - // Closure to capture the file information. - reader.onload = (function (theFile) { - return function (e) { - - // Render thumbnail. - var html = ['<img style="max-width:500px;max-height:200px;" src="', e.target.result, '" title="', escape(theFile.name), '"/>'].join(''); - - $('#userImageOutput', page).html(html); - $('#fldUpload', page).show(); - }; - })(file); - - // Read in the image file as a data URL. - reader.readAsDataURL(file); - }, - - onFileReaderError: function (evt) { - - Dashboard.hideLoadingMsg(); - - switch (evt.target.error.code) { - case evt.target.error.NOT_FOUND_ERR: - Dashboard.showError('File Not Found!'); - break; - case evt.target.error.NOT_READABLE_ERR: - Dashboard.showError('File is not readable'); - break; - case evt.target.error.ABORT_ERR: - break; // noop - default: - Dashboard.showError('An error occurred reading this file.'); - }; - }, - - onFileReaderOnloadStart: function (evt) { - - $('#fldUpload', $.mobile.activePage).hide(); - }, - - onFileReaderAbort: function (evt) { - - Dashboard.hideLoadingMsg(); - Dashboard.showError('File read cancelled'); - }, - - onSubmit: function () { - - var file = UserImagePage.currentFile; - - if (!file || !file.type.match('image.*')) { - return false; - } - - Dashboard.showLoadingMsg(); - - var userId = getParameterByName("userId"); - - ApiClient.uploadUserImage(userId, 'Primary', file).done(UserImagePage.processImageChangeResult); - - return false; - }, - - onImageDrop: function (e) { - - e.preventDefault(); - - UserImagePage.setFiles(e.originalEvent.dataTransfer.files); - - return false; - }, - - onImageDragOver: function (e) { - - e.preventDefault(); - - e.originalEvent.dataTransfer.dropEffect = 'Copy'; - - return false; - } -}; - -$(document).on('pageshow', "#userImagePage", UserImagePage.onPageShow).on('pagehide', "#userImagePage", UserImagePage.onPageHide); diff --git a/MediaBrowser.WebDashboard/Html/scripts/UserProfilesPage.js b/MediaBrowser.WebDashboard/Html/scripts/UserProfilesPage.js deleted file mode 100644 index b6fe09716..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/UserProfilesPage.js +++ /dev/null @@ -1,76 +0,0 @@ -var UserProfilesPage = { - onPageShow: function () { - - UserProfilesPage.loadPageData(); - }, - - loadPageData: function () { - - Dashboard.showLoadingMsg(); - ApiClient.getUsers().done(UserProfilesPage.renderUsers); - }, - - renderUsers: function (users) { - - var html = ""; - - html += '<li data-role="list-divider"><h3>Users</h3></li>'; - - for (var i = 0, length = users.length; i < length; i++) { - - var user = users[i]; - - html += "<li>"; - - html += "<a onclick='Dashboard.navigate(\"editUser.html?userId=" + user.Id + "\");' href='#'>"; - - if (user.PrimaryImageTag) { - - var url = ApiClient.getUserImageUrl(user.Id, { - width: 225, - tag: user.PrimaryImageTag, - type: "Primary" - }); - html += "<img src='" + url + "' />"; - } else { - html += "<img src='css/images/userFlyoutDefault.png' />"; - } - - html += "<h3>" + user.Name + "</h3>"; - - html += "</a>"; - - html += "<a onclick='UserProfilesPage.deleteUser(this);' data-userid='" + user.Id + "' data-username='" + user.Name + "' href='#'>Delete</a>"; - - html += "</li>"; - } - - $('#ulUserProfiles', $('#userProfilesPage')).html(html).listview('refresh'); - - Dashboard.hideLoadingMsg(); - }, - - deleteUser: function (link) { - - var name = link.getAttribute('data-username'); - - var msg = "Are you sure you wish to delete " + name + "?"; - - Dashboard.confirm(msg, "Delete User", function (result) { - - if (result) { - Dashboard.showLoadingMsg(); - - var id = link.getAttribute('data-userid'); - - ApiClient.deleteUser(id).done(function () { - - Dashboard.validateCurrentUser(); - UserProfilesPage.loadPageData(); - }); - } - }); - } -}; - -$(document).on('pageshow', "#userProfilesPage", UserProfilesPage.onPageShow); diff --git a/MediaBrowser.WebDashboard/Html/scripts/WizardFinishPage.js b/MediaBrowser.WebDashboard/Html/scripts/WizardFinishPage.js deleted file mode 100644 index 1633bf140..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/WizardFinishPage.js +++ /dev/null @@ -1,16 +0,0 @@ -var WizardFinishPage = { - - onFinish: function() { - - ApiClient.getServerConfiguration().done(function (config) { - - config.IsStartupWizardCompleted = true; - - ApiClient.updateServerConfiguration(config).done(function() { - Dashboard.navigate('dashboard.html'); - }); - }); - - } - -};
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/WizardStartPage.js b/MediaBrowser.WebDashboard/Html/scripts/WizardStartPage.js deleted file mode 100644 index 4d3dbfd19..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/WizardStartPage.js +++ /dev/null @@ -1,17 +0,0 @@ -var WizardStartPage = { - - gotoNextPage: function () { - - ApiClient.getUsers().done(function (users) { - - if (users.length > 1) { - - Dashboard.navigate('wizardLibrary.html'); - - } else { - Dashboard.navigate('wizardUser.html'); - } - }); - - } -};
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/WizardUserPage.js b/MediaBrowser.WebDashboard/Html/scripts/WizardUserPage.js deleted file mode 100644 index a01654ae1..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/WizardUserPage.js +++ /dev/null @@ -1,59 +0,0 @@ -var WizardUserPage = { - - onPageShow: function () { - - Dashboard.showLoadingMsg(); - - var page = this; - - ApiClient.getUsers().done(function (users) { - - var user = users[0] || { Name: "User" }; - - $('#txtUsername', page).val(user.Name); - - Dashboard.hideLoadingMsg(); - }); - - }, - - onSubmit: function() { - - Dashboard.showLoadingMsg(); - - var page = $.mobile.activePage; - - ApiClient.getUsers().done(function (users) { - - var user; - - if (users.length) { - - user = users[0]; - - user.Name = $('#txtUsername', page).val(); - - ApiClient.updateUser(user).done(WizardUserPage.saveComplete); - - } else { - - user = { Name: $('#txtUsername', page).val() }; - - ApiClient.createUser(user).done(WizardUserPage.saveComplete); - } - - }); - - return false; - }, - - saveComplete: function () { - - Dashboard.hideLoadingMsg(); - - Dashboard.navigate('wizardLibrary.html'); - } - -}; - -$(document).on('pageshow', "#wizardUserPage", WizardUserPage.onPageShow); diff --git a/MediaBrowser.WebDashboard/Html/scripts/aboutPage.js b/MediaBrowser.WebDashboard/Html/scripts/aboutPage.js deleted file mode 100644 index 14c593d54..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/aboutPage.js +++ /dev/null @@ -1,24 +0,0 @@ -var AboutPage = { - - onPageShow: function () { - AboutPage.pollForInfo(); - }, - - - pollForInfo: function () { - ApiClient.getSystemInfo().done(AboutPage.renderInfo); - }, - - renderInfo: function (info) { - AboutPage.renderSystemInfo(info); - }, - - - renderSystemInfo: function (info) { - var page = $.mobile.activePage; - $('#appVersionNumber', page).html(info.Version); - }, - -}; - -$(document).on('pageshow', "#aboutPage", AboutPage.onPageShow);
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/scripts/site.js b/MediaBrowser.WebDashboard/Html/scripts/site.js deleted file mode 100644 index 27dc97810..000000000 --- a/MediaBrowser.WebDashboard/Html/scripts/site.js +++ /dev/null @@ -1,1235 +0,0 @@ -$.ajaxSetup({
- crossDomain: true,
-
- error: function (event, jqxhr, settings, exception) {
- Dashboard.hideLoadingMsg();
-
- if (!Dashboard.suppressAjaxErrors) {
- setTimeout(function () {
-
-
- var msg = event.getResponseHeader("X-Application-Error-Code") || Dashboard.defaultErrorMessage;
-
- Dashboard.showError(msg);
- }, 500);
- }
- }
-});
-
-$.support.cors = true;
-
-$(document).one('click', WebNotifications.requestPermission);
-
-var Dashboard = {
- jQueryMobileInit: function () {
-
- //$.mobile.defaultPageTransition = 'slide';
-
- // Page
- //$.mobile.page.prototype.options.theme = "a";
- //$.mobile.page.prototype.options.headerTheme = "a";
- //$.mobile.page.prototype.options.contentTheme = "a";
- //$.mobile.page.prototype.options.footerTheme = "a";
-
- //$.mobile.button.prototype.options.theme = "c";
- $.mobile.listview.prototype.options.dividerTheme = "b";
-
- $.mobile.popup.prototype.options.theme = "c";
- //$.mobile.collapsible.prototype.options.contentTheme = "a";
- },
-
- getCurrentUser: function () {
-
- if (!Dashboard.getUserPromise) {
- Dashboard.getUserPromise = ApiClient.getUser(Dashboard.getCurrentUserId()).fail(Dashboard.logout);
- }
-
- return Dashboard.getUserPromise;
- },
-
- validateCurrentUser: function () {
- Dashboard.getUserPromise = null;
-
- if (Dashboard.getCurrentUserId()) {
- Dashboard.getCurrentUser();
- }
-
- var header = $('.header', $.mobile.activePage);
-
- if (header.length) {
- // Re-render the header
- header.remove();
- Dashboard.ensureHeader($.mobile.activePage);
- }
- },
-
- getCurrentUserId: function () {
-
- var userId = localStorage.getItem("userId");
-
- if (!userId) {
- var autoLoginUserId = getParameterByName('u');
-
- if (autoLoginUserId) {
- userId = autoLoginUserId;
- localStorage.setItem("userId", userId);
- }
- }
-
- return userId;
- },
-
- setCurrentUser: function (userId) {
- localStorage.setItem("userId", userId);
- ApiClient.currentUserId(userId);
- Dashboard.getUserPromise = null;
- },
-
- logout: function () {
- localStorage.removeItem("userId");
- Dashboard.getUserPromise = null;
- ApiClient.currentUserId(null);
- window.location = "login.html";
- },
-
- showError: function (message) {
-
- $.mobile.loading('show', {
- theme: "e",
- text: message,
- textonly: true,
- textVisible: true
- });
-
- setTimeout(function () {
- $.mobile.loading('hide');
- }, 2000);
- },
-
- alert: function (message) {
-
- $.mobile.loading('show', {
- theme: "e",
- text: message,
- textonly: true,
- textVisible: true
- });
-
- setTimeout(function () {
- $.mobile.loading('hide');
- }, 2000);
- },
-
- updateSystemInfo: function (info) {
-
- var isFirstLoad = !Dashboard.lastSystemInfo;
-
- Dashboard.lastSystemInfo = info;
- Dashboard.ensureWebSocket(info);
-
- if (!Dashboard.initialServerVersion) {
- Dashboard.initialServerVersion = info.Version;
- }
-
- if (info.HasPendingRestart) {
-
- Dashboard.hideDashboardVersionWarning();
- Dashboard.showServerRestartWarning();
-
- } else {
-
- Dashboard.hideServerRestartWarning();
-
- if (Dashboard.initialServerVersion != info.Version) {
-
- Dashboard.showDashboardVersionWarning();
- }
- }
-
- if (isFirstLoad) {
- Dashboard.showFailedAssemblies(info.FailedPluginAssemblies);
- }
-
- Dashboard.showInProgressInstallations(info.InProgressInstallations);
- },
-
- showFailedAssemblies: function (failedAssemblies) {
-
- for (var i = 0, length = failedAssemblies.length; i < length; i++) {
-
- var assembly = failedAssemblies[i];
-
- var html = '<img src="css/images/notifications/error.png" class="notificationIcon" />';
-
- var index = assembly.lastIndexOf('\\');
-
- if (index != -1) {
- assembly = assembly.substring(index + 1);
- }
-
- html += '<span>';
- html += assembly + " failed to load.";
- html += '</span>';
-
- Dashboard.showFooterNotification({ html: html });
-
- }
- },
-
- showInProgressInstallations: function (installations) {
-
- installations = installations || [];
-
- for (var i = 0, length = installations.length; i < length; i++) {
-
- var installation = installations[i];
-
- var percent = installation.PercentComplete || 0;
-
- if (percent < 100) {
- Dashboard.showPackageInstallNotification(installation, "progress");
- }
- }
-
- if (installations.length) {
-
- Dashboard.ensureInstallRefreshInterval();
- } else {
- Dashboard.stopInstallRefreshInterval();
- }
- },
-
- ensureInstallRefreshInterval: function () {
-
- if (!Dashboard.installRefreshInterval) {
-
- if (Dashboard.isWebSocketOpen()) {
- Dashboard.sendWebSocketMessage("SystemInfoStart", "0,350");
- }
- Dashboard.installRefreshInterval = 1;
- }
- },
-
- stopInstallRefreshInterval: function () {
-
- if (Dashboard.installRefreshInterval) {
- if (Dashboard.isWebSocketOpen()) {
- Dashboard.sendWebSocketMessage("SystemInfoStop");
- }
- Dashboard.installRefreshInterval = null;
- }
- },
-
- cancelInstallation: function (id) {
-
- ApiClient.cancelPackageInstallation(id).always(Dashboard.refreshSystemInfoFromServer);
-
- },
-
- showServerRestartWarning: function () {
-
- var html = '<span style="margin-right: 1em;">Please restart Media Browser Server to finish updating.</span>';
- html += '<button type="button" data-icon="refresh" onclick="Dashboard.restartServer();" data-theme="b" data-inline="true" data-mini="true">Restart Server</button>';
-
- Dashboard.showFooterNotification({ id: "serverRestartWarning", html: html, forceShow: true, allowHide: false });
- },
-
- hideServerRestartWarning: function () {
-
- $('#serverRestartWarning').remove();
- },
-
- showDashboardVersionWarning: function () {
-
- var html = '<span style="margin-right: 1em;">Please refresh this page to receive new updates from the server.</span>';
- html += '<button type="button" data-icon="refresh" onclick="Dashboard.reloadPage();" data-theme="b" data-inline="true" data-mini="true">Refresh Page</button>';
-
- Dashboard.showFooterNotification({ id: "dashboardVersionWarning", html: html, forceShow: true, allowHide: false });
- },
-
- reloadPage: function () {
-
- window.location.href = window.location.href;
- },
-
- hideDashboardVersionWarning: function () {
-
- $('#dashboardVersionWarning').remove();
- },
-
- showFooterNotification: function (options) {
-
- var removeOnHide = !options.id;
-
- options.id = options.id || "notification" + new Date().getTime() + parseInt(Math.random());
-
- var parentElem = $('#footerNotifications');
-
- var elem = $('#' + options.id, parentElem);
-
- if (!elem.length) {
- elem = $('<p id="' + options.id + '" class="footerNotification"></p>').appendTo(parentElem);
- }
-
- var onclick = removeOnHide ? "$(\"#" + options.id + "\").remove();" : "$(\"#" + options.id + "\").hide();";
-
- if (options.allowHide !== false) {
- options.html += "<span style='margin-left: 1em;'><button type='button' onclick='" + onclick + "' data-icon='delete' data-iconpos='notext' data-mini='true' data-inline='true' data-theme='a'>Hide</button></span>";
- }
-
- if (options.forceShow) {
- elem.show();
- }
-
- elem.html(options.html).trigger('create');
-
- if (options.timeout) {
-
- setTimeout(function () {
-
- if (removeOnHide) {
- elem.remove();
- } else {
- elem.hide();
- }
-
- }, options.timeout);
- }
- },
-
- getConfigurationPageUrl: function (name) {
- return "ConfigurationPage?name=" + encodeURIComponent(name);
- },
-
- navigate: function (url, preserveQueryString) {
-
- var queryString = window.location.search;
- if (preserveQueryString && queryString) {
- url += queryString;
- }
- $.mobile.changePage(url);
- },
-
- showLoadingMsg: function () {
- $.mobile.showPageLoadingMsg();
- },
-
- hideLoadingMsg: function () {
- $.mobile.hidePageLoadingMsg();
- },
-
- processPluginConfigurationUpdateResult: function () {
-
- Dashboard.hideLoadingMsg();
-
- Dashboard.alert("Settings saved.");
- },
-
- defaultErrorMessage: "There was an error processing the request.",
-
- processServerConfigurationUpdateResult: function (result) {
-
- Dashboard.hideLoadingMsg();
-
- Dashboard.alert("Settings saved.");
- },
-
- confirm: function (message, title, callback) {
-
- $('#confirmFlyout').popup("close").remove();
-
- var html = '<div data-role="popup" id="confirmFlyout" style="max-width:500px;" class="ui-corner-all">';
-
- html += '<div class="ui-corner-top ui-bar-a" style="text-align:center;">';
- html += '<h3>' + title + '</h3>';
- html += '</div>';
-
- html += '<div data-role="content" class="ui-corner-bottom ui-content">';
-
- html += '<div style="padding: 1em .25em;margin: 0;">';
- html += message;
- html += '</div>';
-
- html += '<p><button type="button" data-icon="ok" onclick="$(\'#confirmFlyout\')[0].confirm=true;$(\'#confirmFlyout\').popup(\'close\');" data-theme="b">Ok</button></p>';
- html += '<p><button type="button" data-icon="delete" onclick="$(\'#confirmFlyout\').popup(\'close\');" data-theme="a">Cancel</button></p>';
- html += '</div>';
-
- html += '</div>';
-
- $(document.body).append(html);
-
- $('#confirmFlyout').popup().trigger('create').popup("open").on("popupafterclose", function () {
-
- if (callback) {
- callback(this.confirm == true);
- }
-
- $(this).off("popupafterclose").remove();
- });
- },
-
- refreshSystemInfoFromServer: function () {
- ApiClient.getSystemInfo().done(function (info) {
-
- Dashboard.updateSystemInfo(info);
- });
- },
-
- restartServer: function () {
-
- Dashboard.suppressAjaxErrors = true;
- Dashboard.showLoadingMsg();
-
- ApiClient.performPendingRestart().done(function () {
-
- setTimeout(function () {
- Dashboard.reloadPageWhenServerAvailable();
- }, 250);
-
- }).fail(function () {
- Dashboard.suppressAjaxErrors = false;
- });
- },
-
- reloadPageWhenServerAvailable: function (retryCount) {
-
- ApiClient.getSystemInfo().done(function (info) {
-
- // If this is back to false, the restart completed
- if (!info.HasPendingRestart) {
- Dashboard.reloadPage();
- } else {
- Dashboard.retryReload(retryCount);
- }
-
- }).fail(function() {
- Dashboard.retryReload(retryCount);
- });
- },
-
- retryReload: function (retryCount) {
- setTimeout(function () {
-
- retryCount = retryCount || 0;
- retryCount++;
-
- if (retryCount < 10) {
- Dashboard.reloadPageWhenServerAvailable(retryCount);
- } else {
- Dashboard.suppressAjaxErrors = false;
- }
- }, 500);
- },
-
- getPosterViewHtml: function (options) {
-
- var html = "";
-
- for (var i = 0, length = options.items.length; i < length; i++) {
- var item = options.items[i];
-
- var hasPrimaryImage = item.ImageTags && item.ImageTags.Primary;
-
- var href = item.IsFolder ? (item.Id ? "itemList.html?parentId=" + item.Id : "#") : "itemDetails.html?id=" + item.Id;
-
- var showText = options.showTitle || !hasPrimaryImage || (item.Type !== 'Movie' && item.Type !== 'Series' && item.Type !== 'Season' && item.Type !== 'Trailer');
-
- var cssClass = showText ? "posterViewItem" : "posterViewItem posterViewItemWithNoText";
-
- html += "<div class='" + cssClass + "'><a href='" + href + "'>";
-
- if (options.preferBackdrop && item.BackdropImageTags && item.BackdropImageTags.length) {
- html += "<img src='" + ApiClient.getImageUrl(item.Id, {
- type: "Backdrop",
- height: 198,
- width: 352,
- tag: item.BackdropImageTags[0]
- }) + "' />";
- } else if (hasPrimaryImage) {
- html += "<img src='" + ApiClient.getImageUrl(item.Id, {
- type: "Primary",
- height: 300,
- tag: item.ImageTags.Primary
- }) + "' />";
- }
- else if (item.BackdropImageTags && item.BackdropImageTags.length) {
- html += "<img src='" + ApiClient.getImageUrl(item.Id, {
- type: "Backdrop",
- height: 198,
- width: 352,
- tag: item.BackdropImageTags[0]
- }) + "' />";
- } else {
- html += "<img style='background:" + Dashboard.getRandomMetroColor() + ";' src='css/images/defaultCollectionImage.png' />";
- }
-
- if (showText) {
- html += "<div class='posterViewItemText'>";
- html += item.Name;
- html += "</div>";
- }
-
- html += "</a></div>";
- }
-
- return html;
- },
-
- showUserFlyout: function () {
-
- Dashboard.getCurrentUser().done(function (user) {
-
- var html = '<div data-role="popup" id="userFlyout" style="max-width:400px;margin-top:50px;margin-right:20px;" class="ui-corner-all" data-position-to=".btnCurrentUser:visible">';
-
- html += '<a href="#" data-rel="back" data-role="button" data-theme="a" data-icon="delete" data-iconpos="notext" class="ui-btn-right">Close</a>';
-
- html += '<div class="ui-corner-top ui-bar-a" style="text-align:center;">';
- html += '<h3>' + user.Name + '</h3>';
- html += '</div>';
-
- html += '<div data-role="content" class="ui-corner-bottom ui-content">';
-
- html += '<p style="text-align:center;">';
-
- var imageUrl = user.PrimaryImageTag ? ApiClient.getUserImageUrl(user.Id, {
-
- height: 400,
- tag: user.PrimaryImageTag,
- type: "Primary"
-
- }) : "css/images/userFlyoutDefault.png";
-
- html += '<img style="max-height:125px;max-width:200px;" src="' + imageUrl + '" />';
- html += '</p>';
-
- html += '<p><button type="button" onclick="Dashboard.navigate(\'editUser.html?userId=' + user.Id + '\');" data-icon="user">View Profile</button></p>';
- html += '<p><button type="button" onclick="Dashboard.logout();" data-icon="lock">Sign Out</button></p>';
- html += '</div>';
-
- html += '</div>';
-
- $(document.body).append(html);
-
- $('#userFlyout').popup().trigger('create').popup("open").on("popupafterclose", function () {
-
- $(this).off("popupafterclose").remove();
- });
- });
- },
-
- selectDirectory: function (options) {
-
- options = options || {};
-
- options.header = options.header || "Select Media Path";
-
- var html = '<div data-role="popup" id="popupDirectoryPicker" class="ui-corner-all popup">';
-
- html += '<div class="ui-corner-top ui-bar-a" style="text-align: center; padding: 0 20px;">';
- html += '<h3>' + options.header + '</h3>';
- html += '</div>';
-
- html += '<div data-role="content" class="ui-corner-bottom ui-content">';
- html += '<form>';
- html += '<p>Browse to or enter the folder containing the media. Network paths (UNC) are recommended for optimal playback performance.</p>';
-
- html += '<div data-role="fieldcontain" style="margin:0;">';
- html += '<label for="txtDirectoryPickerPath">Current Folder:</label>';
- html += '<input id="txtDirectoryPickerPath" name="txtDirectoryPickerPath" type="text" onchange="Dashboard.refreshDirectoryBrowser(this.value);" required="required" style="font-weight:bold;" />';
- html += '</div>';
-
- html += '<div style="height: 300px; overflow-y: auto;">';
- html += '<ul id="ulDirectoryPickerList" data-role="listview" data-inset="true" data-auto-enhanced="false"></ul>';
- html += '</div>';
-
- html += '<p>';
- html += '<button type="submit" data-theme="b" data-icon="ok">OK</button>';
- html += '<button type="button" data-icon="delete" onclick="$(this).parents(\'.popup\').popup(\'close\');">Cancel</button>';
- html += '</p>';
- html += '</form>';
- html += '</div>';
- html += '</div>';
-
- $($.mobile.activePage).append(html);
-
- var popup = $('#popupDirectoryPicker').popup().trigger('create').popup("open").on("popupafterclose", function () {
-
- $('form', this).off("submit");
- $(this).off("click").off("popupafterclose").remove();
-
- }).on("click", ".lnkDirectory", function () {
-
- var path = this.getAttribute('data-path');
-
- Dashboard.refreshDirectoryBrowser(path);
- });
-
- var txtCurrentPath = $('#txtDirectoryPickerPath', popup);
-
- if (options.path) {
- txtCurrentPath.val(options.path);
- }
-
- $('form', popup).on('submit', function () {
-
- if (options.callback) {
- options.callback($('#txtDirectoryPickerPath', this).val());
- }
-
- return false;
- });
-
- Dashboard.refreshDirectoryBrowser(txtCurrentPath.val());
- },
-
- refreshDirectoryBrowser: function (path) {
- var page = $.mobile.activePage;
-
- Dashboard.showLoadingMsg();
-
- var promise;
-
- if (path === "Network") {
- promise = ApiClient.getNetworkDevices();
- }
- else if (path) {
- promise = ApiClient.getDirectoryContents(path, { includeDirectories: true });
- } else {
- promise = ApiClient.getDrives();
- }
-
- promise.done(function (folders) {
-
- $('#txtDirectoryPickerPath', page).val(path || "");
-
- var html = '';
-
- if (path) {
-
- var parentPath = path;
-
- if (parentPath.endsWith('\\')) {
- parentPath = parentPath.substring(0, parentPath.length - 1);
- }
-
- var lastIndex = parentPath.lastIndexOf('\\');
- parentPath = lastIndex == -1 ? "" : parentPath.substring(0, lastIndex);
-
- if (parentPath.endsWith(':')) {
- parentPath += "\\";
- }
-
- if (parentPath == '\\') {
- parentPath = "Network";
- }
-
- html += '<li><a class="lnkDirectory" data-path="' + parentPath + '" href="#">..</a></li>';
- }
-
- for (var i = 0, length = folders.length; i < length; i++) {
-
- var folder = folders[i];
-
- html += '<li><a class="lnkDirectory" data-path="' + folder.Path + '" href="#">' + folder.Name + '</a></li>';
- }
-
- if (!path) {
- html += '<li><a class="lnkDirectory" data-path="Network" href="#">Network</a></li>';
- }
-
- $('#ulDirectoryPickerList', page).html(html).listview('refresh');
-
- Dashboard.hideLoadingMsg();
-
- }).fail(function () {
-
- $('#txtDirectoryPickerPath', page).val("");
- $('#ulDirectoryPickerList', page).html('').listview('refresh');
-
- Dashboard.hideLoadingMsg();
- });
- },
-
- getPluginSecurityInfo: function () {
-
- if (!Dashboard.getPluginSecurityInfoPromise) {
-
- var deferred = $.Deferred();
-
- // Don't let this blow up the dashboard when it fails
- $.ajax({
- type: "GET",
- url: ApiClient.getUrl("Plugins/SecurityInfo"),
- dataType: 'json',
-
- error: function () {
- // Don't show normal dashboard errors
- }
-
- }).done(function (result) {
- deferred.resolveWith(null, [[result]]);
- });
-
- Dashboard.getPluginSecurityInfoPromise = deferred;
- }
-
- return Dashboard.getPluginSecurityInfoPromise;
- },
-
- resetPluginSecurityInfo: function () {
- Dashboard.getPluginSecurityInfoPromise = null;
- },
-
- ensureHeader: function (page) {
-
- if (!$('.header', page).length) {
-
- var isLoggedIn = Dashboard.getCurrentUserId();
-
- if (isLoggedIn) {
-
- Dashboard.getCurrentUser().done(function (user) {
- Dashboard.renderHeader(page, user);
- });
-
- } else {
-
- Dashboard.renderHeader(page);
- }
- }
- },
-
- renderHeader: function (page, user) {
-
- var headerHtml = '';
- headerHtml += '<div class="header">';
-
- var isLibraryPage = page.hasClass('libraryPage');
-
- headerHtml += '<a class="logo" href="index.html">';
-
- if (page.hasClass('standalonePage')) {
-
- headerHtml += '<img class="imgLogoIcon" src="css/images/mblogoicon.png" /><img class="imgLogoText" src="css/images/mblogotextblack.png" />';
- }
- else if (isLibraryPage) {
-
- headerHtml += '<img class="imgLogoIcon" src="css/images/mblogoicon.png" /><img class="imgLogoText" src="css/images/mblogotextwhite.png" />';
- }
- headerHtml += '</a>';
-
- var imageColor = isLibraryPage ? "White" : "Black";
-
- if (user && !page.hasClass('wizardPage')) {
- headerHtml += '<div class="headerButtons">';
- headerHtml += '<a class="imageLink btnCurrentUser" href="#" onclick="Dashboard.showUserFlyout();"><span class="currentUsername">' + user.Name + '</span>';
-
- if (user.PrimaryImageTag) {
-
- var url = ApiClient.getUserImageUrl(user.Id, {
- width: 225,
- tag: user.PrimaryImageTag,
- type: "Primary"
- });
-
- headerHtml += '<img src="' + url + '" />';
- } else {
- headerHtml += '<img src="css/images/currentUserDefault' + imageColor + '.png" />';
- }
- headerHtml += '</a>';
-
- if (user.Configuration.IsAdministrator) {
- headerHtml += '<a class="imageLink btnTools" href="dashboard.html"><img src="css/images/tools' + imageColor + '.png" /></a>';
- }
-
- headerHtml += '</div>';
- }
-
- headerHtml += '</div>';
- page.prepend(headerHtml);
-
- Dashboard.getPluginSecurityInfo().done(function (pluginSecurityInfo) {
- if (pluginSecurityInfo.IsMBSupporter) {
- $('<a class="imageLink" href="supporter.html"><img src="css/images/suppbadge.png" /></a>').insertBefore('.btnTools', page);
- }
- });
- },
-
- ensureToolsMenu: function (page) {
-
- if (!page.hasClass('type-interior')) {
- return;
- }
-
- var sidebar = $('.toolsSidebar', page);
-
- if (!sidebar.length) {
-
- var html = '<div class="content-secondary ui-bar-a toolsSidebar">';
-
- html += '<h1><a href="index.html" class="imageLink" style="margin-left: 0;margin-right: 20px;"> <img src="css/images/home.png" /></a>Tools</h1>';
-
- html += '<div class="sidebarLinks">';
-
- var links = Dashboard.getToolsMenuLinks(page);
-
- for (var i = 0, length = links.length; i < length; i++) {
-
- var link = links[i];
-
- if (link.href) {
-
- if (link.selected) {
- html += '<a class="selectedSidebarLink" href="' + link.href + '">' + link.name + '</a>';
- } else {
- html += '<a href="' + link.href + '">' + link.name + '</a>';
- }
-
- }
- }
-
- // collapsible
- html += '</div>';
-
- // content-secondary
- html += '</div>';
-
- $(page).append(html);
- }
- },
-
- getToolsMenuLinks: function (page) {
-
- var pageElem = page[0];
-
- return [{
- name: "Dashboard",
- href: "dashboard.html",
- selected: pageElem.id == "dashboardPage"
- }, {
- name: "Media Library",
- href: "library.html",
- selected: pageElem.id == "mediaLibraryPage"
- }, {
- name: "Metadata",
- href: "metadata.html",
- selected: pageElem.id == "metadataConfigurationPage" || pageElem.id == "advancedMetadataConfigurationPage" || pageElem.id == "metadataImagesConfigurationPage"
- }, {
- name: "Plugins",
- href: "plugins.html",
- selected: page.hasClass("pluginConfigurationPage")
- }, {
- name: "User Profiles",
- href: "userProfiles.html",
- selected: page.hasClass("userProfilesConfigurationPage")
- }, {
- name: "Display Settings",
- href: "uiSettings.html",
- selected: pageElem.id == "displaySettingsPage"
- }, {
- name: "Advanced",
- href: "advanced.html",
- selected: pageElem.id == "advancedConfigurationPage"
- }, {
- name: "Scheduled Tasks",
- href: "scheduledTasks.html",
- selected: pageElem.id == "scheduledTasksPage" || pageElem.id == "scheduledTaskPage"
- }, {
- name: "Help",
- href: "support.html",
- selected: pageElem.id == "supportPage" || pageElem.id == "logPage" || pageElem.id == "supporterPage" || pageElem.id == "supporterKeyPage" || pageElem.id == "aboutPage"
- }];
-
- },
-
- ensureWebSocket: function (systemInfo) {
-
- if (!("WebSocket" in window)) {
- // Not supported by the browser
- return;
- }
-
- if (Dashboard.webSocket) {
- if (Dashboard.webSocket.readyState === WebSocket.OPEN || Dashboard.webSocket.readyState === WebSocket.CONNECTING) {
- return;
- }
- }
-
- systemInfo = systemInfo || Dashboard.lastSystemInfo;
-
- var url = "ws://" + ApiClient.serverHostName() + ":" + systemInfo.WebSocketPortNumber + "/mediabrowser";
-
- var ws = new WebSocket(url);
-
- ws.onmessage = Dashboard.onWebSocketMessage;
-
- ws.onopen = function () {
- setTimeout(function () {
- $(document).trigger("websocketopen");
- }, 500);
- };
- ws.onerror = function () {
- setTimeout(function () {
- $(document).trigger("websocketerror");
- }, 0);
- };
- ws.onclose = function () {
- setTimeout(function () {
- $(document).trigger("websocketclose");
- }, 0);
- };
-
- Dashboard.webSocket = ws;
- },
-
- resetWebSocketPingInterval: function () {
-
- if (Dashboard.pingWebSocketInterval) {
- clearInterval(Dashboard.pingWebSocketInterval);
- Dashboard.pingWebSocketInterval = null;
- }
- Dashboard.pingWebSocketInterval = setInterval(Dashboard.pingWebSocket, 30000);
- },
-
- pingWebSocket: function () {
-
- // Send a ping to the server every so often to try and keep the connection alive
- if (Dashboard.isWebSocketOpen()) {
- Dashboard.sendWebSocketMessage("ping");
- }
-
- },
-
- onWebSocketMessage: function (msg) {
-
- msg = JSON.parse(msg.data);
-
- if (msg.MessageType === "LibraryChanged") {
- Dashboard.processLibraryUpdateNotification(msg.Data);
- }
- else if (msg.MessageType === "UserDeleted") {
- Dashboard.validateCurrentUser();
- }
- else if (msg.MessageType === "SystemInfo") {
- Dashboard.updateSystemInfo(msg.Data);
- }
- else if (msg.MessageType === "HasPendingRestartChanged") {
- Dashboard.updateSystemInfo(msg.Data);
- }
- else if (msg.MessageType === "UserUpdated") {
- Dashboard.validateCurrentUser();
-
- var user = msg.Data;
-
- if (user.Id == Dashboard.getCurrentUserId()) {
-
- $('.currentUsername').html(user.Name);
- }
- }
- else if (msg.MessageType === "PackageInstallationCompleted") {
- Dashboard.showPackageInstallNotification(msg.Data, "completed");
- Dashboard.refreshSystemInfoFromServer();
- }
- else if (msg.MessageType === "PackageInstallationFailed") {
- Dashboard.showPackageInstallNotification(msg.Data, "failed");
- Dashboard.refreshSystemInfoFromServer();
- }
- else if (msg.MessageType === "PackageInstallationCancelled") {
- Dashboard.showPackageInstallNotification(msg.Data, "cancelled");
- Dashboard.refreshSystemInfoFromServer();
- }
- else if (msg.MessageType === "PackageInstalling") {
- Dashboard.showPackageInstallNotification(msg.Data, "progress");
- Dashboard.refreshSystemInfoFromServer();
- }
- else if (msg.MessageType === "ScheduledTaskEndExecute") {
-
- Dashboard.showTaskCompletionNotification(msg.Data);
- }
-
- $(document).trigger("websocketmessage", [msg]);
- },
-
- sendWebSocketMessage: function (name, data) {
-
- var msg = { MessageType: name };
-
- if (data) {
- msg.Data = data;
- }
-
- msg = JSON.stringify(msg);
-
- Dashboard.webSocket.send(msg);
- },
-
- isWebSocketOpen: function () {
- return Dashboard.webSocket && Dashboard.webSocket.readyState === WebSocket.OPEN;
- },
-
- showTaskCompletionNotification: function (result) {
-
- var html = '';
-
- if (result.Status == "Completed") {
- html += '<img src="css/images/notifications/done.png" class="notificationIcon" />';
- return;
- }
- else if (result.Status == "Cancelled") {
- html += '<img src="css/images/notifications/info.png" class="notificationIcon" />';
- return;
- }
- else {
- html += '<img src="css/images/notifications/error.png" class="notificationIcon" />';
- }
-
- html += '<span>';
- html += result.Name + " " + result.Status;
- html += '</span>';
-
- var timeout = 0;
-
- if (result.Status == 'Cancelled') {
- timeout = 2000;
- }
-
- Dashboard.showFooterNotification({ html: html, id: result.Id, forceShow: true, timeout: timeout });
- },
-
- showPackageInstallNotification: function (installation, status) {
-
- var html = '';
-
- if (status == 'completed') {
- html += '<img src="css/images/notifications/done.png" class="notificationIcon" />';
- }
- else if (status == 'cancelled') {
- html += '<img src="css/images/notifications/info.png" class="notificationIcon" />';
- }
- else if (status == 'failed') {
- html += '<img src="css/images/notifications/error.png" class="notificationIcon" />';
- }
- else if (status == 'progress') {
- html += '<img src="css/images/notifications/download.png" class="notificationIcon" />';
- }
-
- html += '<span style="margin-right: 1em;">';
-
- if (status == 'completed') {
- html += installation.Name + ' ' + installation.Version + ' installation completed';
- }
- else if (status == 'cancelled') {
- html += installation.Name + ' ' + installation.Version + ' installation was cancelled';
- }
- else if (status == 'failed') {
- html += installation.Name + ' ' + installation.Version + ' installation failed';
- }
- else if (status == 'progress') {
- html += 'Installing ' + installation.Name + ' ' + installation.Version;
- }
-
- html += '</span>';
-
- if (status == 'progress') {
-
- var percentComplete = Math.round(installation.PercentComplete || 0);
-
- html += '<progress style="margin-right: 1em;" max="100" value="' + percentComplete + '" title="' + percentComplete + '%">';
- html += '' + percentComplete + '%';
- html += '</progress>';
-
- if (percentComplete < 100) {
- var btnId = "btnCancel" + installation.Id;
- html += '<button id="' + btnId + '" type="button" data-icon="delete" onclick="$(\'' + btnId + '\').button(\'disable\');Dashboard.cancelInstallation(\'' + installation.Id + '\');" data-theme="b" data-inline="true" data-mini="true">Cancel</button>';
- }
- }
-
- var timeout = 0;
-
- if (status == 'cancelled') {
- timeout = 2000;
- }
-
- var forceShow = status != "progress";
- var allowHide = status != "progress" && status != 'cancelled';
-
- Dashboard.showFooterNotification({ html: html, id: installation.Id, timeout: timeout, forceShow: forceShow, allowHide: allowHide });
- },
-
- processLibraryUpdateNotification: function (data) {
-
- var newItems = data.ItemsAdded.filter(function (a) {
- return !a.IsFolder;
- });
-
- if (!Dashboard.newItems) {
- Dashboard.newItems = [];
- }
-
- for (var i = 0, length = newItems.length ; i < length; i++) {
-
- Dashboard.newItems.push(newItems[i]);
- }
-
- if (Dashboard.newItemTimeout) {
- clearTimeout(Dashboard.newItemTimeout);
- }
-
- Dashboard.newItemTimeout = setTimeout(Dashboard.onNewItemTimerStopped, 60000);
- },
-
- onNewItemTimerStopped: function () {
-
- var newItems = Dashboard.newItems;
-
- newItems = newItems.sort(function (a, b) {
-
- if (a.PrimaryImageTag && b.PrimaryImageTag) {
- return 0;
- }
-
- if (a.PrimaryImageTag) {
- return -1;
- }
-
- return 1;
- });
-
- Dashboard.newItems = [];
- Dashboard.newItemTimeout = null;
-
- // Show at most 3 notifications
- for (var i = 0, length = Math.min(newItems.length, 3) ; i < length; i++) {
-
- var item = newItems[i];
-
- var data = {
- title: "New " + item.Type,
- body: item.Name,
- timeout: 6000
- };
-
- if (item.PrimaryImageTag) {
- data.icon = ApiClient.getImageUrl(item.Id, {
- width: 100,
- tag: item.PrimaryImageTag,
- type: "Primary"
- });
-
- if (!item.Id || data.icon.indexOf("undefined") != -1) {
- alert("bad image url: " + JSON.stringify(item));
- console.log("bad image url: " + JSON.stringify(item));
-
- continue;
- }
- }
-
- WebNotifications.show(data);
- }
- },
-
- ensurePageTitle: function (page) {
-
- if (!page.hasClass('type-interior')) {
- return;
- }
-
- var pageElem = page[0];
-
- if (pageElem.hasPageTitle) {
- return;
- }
-
- var parent = $('.content-primary', page);
-
- if (!parent.length) {
- parent = $('.ui-content', page)[0];
- }
-
- $(parent).prepend("<h2 class='pageTitle'>" + (document.title || " ") + "</h2>");
-
- pageElem.hasPageTitle = true;
- },
-
- setPageTitle: function (title) {
-
- $('.pageTitle', $.mobile.activePage).html(title);
-
- if (title) {
- document.title = title;
- }
- },
-
- metroColors: ["#6FBD45", "#4BB3DD", "#4164A5", "#E12026", "#800080", "#E1B222", "#008040", "#0094FF", "#FF00C7", "#FF870F", "#7F0037"],
-
- getRandomMetroColor: function () {
-
- var index = Math.floor(Math.random() * (Dashboard.metroColors.length - 1));
-
- return Dashboard.metroColors[index];
- }
-
-};
-
-var ApiClient = MediaBrowser.ApiClient.create("Dashboard");
-
-$(function () {
-
- var footerHtml = '<div id="footer" class="ui-bar-a">';
-
- footerHtml += '<div id="nowPlayingBar" style="display:none;">';
-
- footerHtml += '<button id="previousTrackButton" class="imageButton mediaButton" title="Previous Track" type="button"><img src="css/images/media/previousTrack.png" /></button>';
-
- footerHtml += '<button id="stopButton" class="imageButton mediaButton" title="Stop" type="button" onclick="MediaPlayer.stop();"><img src="css/images/media/stop.png" /></button>';
-
- footerHtml += '<button id="nextTrackButton" class="imageButton mediaButton" title="Next Track" type="button"><img src="css/images/media/nextTrack.png" /></button>';
-
- footerHtml += '<div id="mediaElement"></div>';
-
- footerHtml += '</div>';
-
- footerHtml += '<div id="footerNotifications"></div>';
-
- footerHtml += '</div>';
-
-
- $(document.body).append(footerHtml);
-});
-
-Dashboard.jQueryMobileInit();
-
-$(document).on('pagebeforeshow', ".page", function () {
-
- Dashboard.refreshSystemInfoFromServer();
-
- var page = $(this);
-
- Dashboard.ensureHeader(page);
- Dashboard.ensurePageTitle(page);
-
-}).on('pageinit', ".page", function () {
-
- var page = $(this);
-
- var userId = Dashboard.getCurrentUserId();
- ApiClient.currentUserId(userId);
-
- if (!userId) {
-
- if (this.id !== "loginPage" && !page.hasClass('wizardPage')) {
-
- Dashboard.logout();
- }
- }
-
- else {
-
- Dashboard.getCurrentUser().done(function (user) {
-
- if (user.Configuration.IsAdministrator) {
- Dashboard.ensureToolsMenu(page);
- }
- });
- }
-});
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/support.html b/MediaBrowser.WebDashboard/Html/support.html deleted file mode 100644 index 185ae01e6..000000000 --- a/MediaBrowser.WebDashboard/Html/support.html +++ /dev/null @@ -1,43 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Support</title> -</head> -<body> - <div id="supportPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - <div class="content-primary"> - <div class="readOnlyContent"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="support.html" data-role="button" class="ui-btn-active">General</a> - <a href="log.html" data-role="button">View Log</a> - <a href="supporter.html" data-role="button">Become a Supporter</a> - <a href="supporterKey.html" data-role="button">Supporter Key</a> - <a href="about.html" data-role="button">About</a> - </div> - <h2>General Help</h2> - <p> - Media Browser has a thriving community of users and a vast knowledge base of information to help you get the most - out of your media collection. - </p> - <p> - The Community Tracker is a place where you can ask questions, post feature requests and report bugs and get timely - <em>and friendly</em> help from a thriving community of users and developers. - </p> - <a data-role="button" data-icon="arrow-r" data-iconpos="right" href="http://community.mediabrowser.tv" target="_blank">Visit the Community Tracker</a> - <p> - Also, within the tracker, there is a large Knowledge Base of information compiled from users and developers to help you get the - most out of Media Browser. - </p> - <a data-role="button" data-icon="search" data-iconpos="right" href="http://community.mediabrowser.tv/topics?category_id=5&&status=published" target="_blank">Search the Knowledge Base</a> - <p> - Finally, you can visit the Media Browser Web site to see what's happening with MB now and keep up with the developer blog. - </p> - <a data-role="button" data-icon="home" data-iconpos="right" href="http://www.mediabrowser3.com" target="_blank">Visit the Media Browser Web Site</a> - </div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/supporter.html b/MediaBrowser.WebDashboard/Html/supporter.html deleted file mode 100644 index 3beb6e3b9..000000000 --- a/MediaBrowser.WebDashboard/Html/supporter.html +++ /dev/null @@ -1,70 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Support</title> -</head> -<body> - <div id="supporterPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - <div class="content-primary"> - <div class="readOnlyContent"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="support.html" data-role="button">General</a> - <a href="log.html" data-role="button">View Log</a> - <a href="supporter.html" data-role="button" class="ui-btn-active">Become a Supporter</a> - <a href="supporterKey.html" data-role="button">Supporter Key</a> - <a href="about.html" data-role="button">About</a> - </div> - <h2>Support the Media Browser Team</h2> - <p> - By becoming a Media Browser Supporter, you ensure the continued development and support of this product <strong>and open up a whole new world of premium plug-ins.</strong> - </p> - <p style="margin-bottom: 30px"> - A portion of all MB3 Supporter donations is also contributed to some of our metadata providers (<a href="http://themoviedb.org" target="_blank">The Movie Db</a>, - <a href="http://thetvdb.com" target="_blank">The TVdb</a>, and <a href="http://fanart.tv" target="_blank">FanArt.tv</a>) - </p> - <p style="margin-bottom: 30px"> - Premium plug-ins can be installed and used for their trial periods (14 days on any particular machine) but, to register them for use - beyond that period, you also have to be a Media Browser Supporter. - - </p> - <div style="display: none; padding: 10px 10px 10px 10px; margin-bottom: 10px" class="ui-bar-e supporterOnly"> - <p> - <strong><em>Thank You</em></strong> for your past support of the Media Browser Team. Users like you make it possible for - Media Browser to exist and keep getting better and better. You can always support us again if you feel you are getting maximum - value from the product. - - </p> - </div> - <form name="_xclick" action="https://www.paypal.com/cgi-bin/webscr" - method="post"> - <label for="donateAmt" >Amount (USD)</label> - <select id="donateAmt" name="amount" > - <option>10</option> - <option>15</option> - <option>20</option> - <option>30</option> - <option>50</option> - </select> - - <input type="hidden" name="cmd" value="_xclick"> - <input type="hidden" name="business" value="donate@mediabrowser3.com"> - <input type="hidden" name="currency_code" value="USD"> - <input type="hidden" name="item_name" value="Media Browser Supporter"> - <input type="hidden" name="item_number" value="MBSupporter"> - <input type="hidden" name="notify_url" value="http://mb3admin.com/admin/service/services/ppipn.php"> - <input type="hidden" name="return" id ="paypalReturnUrl" value="#"> - <a data-role="button" onclick="_xclick.submit();"><img src="css/images/donatepp.png"/></a> - - <p><small><em>This button is now <strong>live</strong>. Transactions will result in real money being transferred.</em></small></p> - - - </form> - - </div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/supporterKey.html b/MediaBrowser.WebDashboard/Html/supporterKey.html deleted file mode 100644 index 7d565640f..000000000 --- a/MediaBrowser.WebDashboard/Html/supporterKey.html +++ /dev/null @@ -1,74 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Support</title> -</head> -<body> - <div id="supporterKeyPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - <div class="content-primary"> - <div class="readOnlyContent"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="support.html" data-role="button">General</a> - <a href="log.html" data-role="button">View Log</a> - <a href="supporter.html" data-role="button">Become a Supporter</a> - <a href="supporterKey.html" data-role="button" class="ui-btn-active">Supporter Key</a> - <a href="about.html" data-role="button">About</a> - </div> - <h2>Supporter Key</h2> - </div> - <form id="supporterKeyForm"> - <div style="margin-top: 40px; margin-bottom: 40px"> - <label for="txtSupporterKey">MB3 Supporter Key (paste from email)</label> - <input type="password" id="txtSupporterKey" name="txtSupporterKey" data-inline="true" /> - <div class="fieldDescription"> - <strong>After becoming a supporter, you will be emailed a Supporter Key. Simply copy and paste that key into this field and start - enjoying everything the community has developed for Media Browser. <em>Only MB 3 Supporter Keys are valid here</em></strong> - </div> - - </div> - <div style="margin-top: 40px; margin-bottom: 40px"> - <label for="txtLegacyKey">Legacy Supporter Key (from MB 2.x)</label> - <input type="password" id="txtLegacyKey" name="txtLegacyKey" data-inline="true" /> - <div class="fieldDescription"> - <strong>Some premium plug-ins may give credit for registrations with previous versions in MB 2.x. Enter your MB 2.x - Supporter Key here to allow that credit. - </strong> - </div> - - </div> - <p> - <button type="submit" id="mbLegacyKeyBtn" data-theme="b">Save</button> - - </p> - - </form> - <hr/> - <h2>Lost Key</h2> - <form id="lostKeyForm"> - <div style="margin-top: 40px; margin-bottom: 40px"> - <label for="txtEmail">Email Address</label> - <input type="email" required id="txtEmail" name="txtEmail" data-inline="true" /> - <div class="fieldDescription"> - <strong>If you have lost your key, enter the email address associated with your PayPal account here and hit "Retrieve Key". The key - will be emailed to you and you can come back here and paste it above.</strong> - </div> - - </div> - <p> - <button type="submit" id="mbRetrieveKeyBtn" data-theme="b" >Retrieve Key</button> - - </p> - - </form> - - </div> - </div> - <script type="text/javascript"> - $('#supporterKeyForm').on('submit', SupporterKeyPage.updateSupporterKey); - $('#lostKeyForm').on('submit', SupporterKeyPage.retrieveSupporterKey); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/faicons-v2.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/faicons-v2.png Binary files differdeleted file mode 100644 index 4293bcde9..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/faicons-v2.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/faicons.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/faicons.png Binary files differdeleted file mode 100644 index eb0308948..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/faicons.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/font/fontawesome-webfont.eot b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/font/fontawesome-webfont.eot Binary files differdeleted file mode 100644 index 11d2f415f..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/font/fontawesome-webfont.eot +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/font/fontawesome-webfont.woff b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/font/fontawesome-webfont.woff Binary files differdeleted file mode 100644 index 7e892f878..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/font/fontawesome-webfont.woff +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/ajax-loader.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/ajax-loader.png Binary files differdeleted file mode 100644 index 0973ae040..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/ajax-loader.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-18-black-pack.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-18-black-pack.png Binary files differdeleted file mode 100644 index 07d96586c..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-18-black-pack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-18-white-pack.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-18-white-pack.png Binary files differdeleted file mode 100644 index 0159f628f..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-18-white-pack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-36-black-pack.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-36-black-pack.png Binary files differdeleted file mode 100644 index 562e839b9..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-36-black-pack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-36-white-pack.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-36-white-pack.png Binary files differdeleted file mode 100644 index 81f082a4a..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/images/icons-36-white-pack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/index.html b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/index.html deleted file mode 100644 index 7d3a8cc21..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/index.html +++ /dev/null @@ -1,305 +0,0 @@ -<!doctype html> -<html> -<head> - <title> jQuery Mobile Icon Pack</title> - - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <!-- jQuery Mobile CSS bits --> - <link rel="stylesheet" href="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.css" /> - - <!-- Custom css --> - <link rel="stylesheet" href="jqm-icon-pack-3.0.0-fa.css" /> - - <!-- Javascript includes --> - <script src="http://code.jquery.com/jquery-1.8.2.min.js"></script> - <script src="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.js"></script> -</head> -<body> - <div data-role="page"> - - <div data-role="header"> - <a href="../index.html" data-icon="home">Back</a> - <h1>jQuery Mobile Icon Pack</h1> - </div> - - <div data-role="content"> - - <a href="http://jqmiconpack.andymatthews.net" data-ajax="false" data-role="button" data-theme="e">Build your own!</a> - <a href="https://github.com/commadelimited/jQuery-Mobile-Icon-Pack" data-role="button">Download the Icon Pack</a> - - <h3>Font Awesome Icons</h3> - <a href="index.html" data-role="button" data-icon="cloud-download" data-theme="b">data-icon="cloud-download"</a> - <a href="index.html" data-role="button" data-icon="cloud-upload" data-theme="b">data-icon="cloud-upload"</a> - <a href="index.html" data-role="button" data-icon="lightbulb" data-theme="b">data-icon="lightbulb"</a> - <a href="index.html" data-role="button" data-icon="exchange" data-theme="b">data-icon="exchange"</a> - <a href="index.html" data-role="button" data-icon="bell-alt" data-theme="b">data-icon="bell-alt"</a> - <a href="index.html" data-role="button" data-icon="file-alt" data-theme="b">data-icon="file-alt"</a> - <a href="index.html" data-role="button" data-icon="beer" data-theme="b">data-icon="beer"</a> - <a href="index.html" data-role="button" data-icon="coffee" data-theme="b">data-icon="coffee"</a> - <a href="index.html" data-role="button" data-icon="food" data-theme="b">data-icon="food"</a> - <a href="index.html" data-role="button" data-icon="fighter-jet" data-theme="b">data-icon="fighter-jet"</a> - <a href="index.html" data-role="button" data-icon="user-md" data-theme="b">data-icon="user-md"</a> - <a href="index.html" data-role="button" data-icon="stethoscope" data-theme="b">data-icon="stethoscope"</a> - <a href="index.html" data-role="button" data-icon="suitcase" data-theme="b">data-icon="suitcase"</a> - <a href="index.html" data-role="button" data-icon="building" data-theme="b">data-icon="building"</a> - <a href="index.html" data-role="button" data-icon="hospital" data-theme="b">data-icon="hospital"</a> - <a href="index.html" data-role="button" data-icon="ambulance" data-theme="b">data-icon="ambulance"</a> - <a href="index.html" data-role="button" data-icon="medkit" data-theme="b">data-icon="medkit"</a> - <a href="index.html" data-role="button" data-icon="h-sign" data-theme="b">data-icon="h-sign"</a> - <a href="index.html" data-role="button" data-icon="plus-sign-alt" data-theme="b">data-icon="plus-sign-alt"</a> - <a href="index.html" data-role="button" data-icon="spinner" data-theme="b">data-icon="spinner"</a> - <a href="index.html" data-role="button" data-icon="angle-left" data-theme="b">data-icon="angle-left"</a> - <a href="index.html" data-role="button" data-icon="angle-right" data-theme="b">data-icon="angle-right"</a> - <a href="index.html" data-role="button" data-icon="angle-up" data-theme="b">data-icon="angle-up"</a> - <a href="index.html" data-role="button" data-icon="angle-down" data-theme="b">data-icon="angle-down"</a> - <a href="index.html" data-role="button" data-icon="double-angle-left" data-theme="b">data-icon="double-angle-left"</a> - <a href="index.html" data-role="button" data-icon="double-angle-right" data-theme="b">data-icon="double-angle-right"</a> - <a href="index.html" data-role="button" data-icon="double-angle-up" data-theme="b">data-icon="double-angle-up"</a> - <a href="index.html" data-role="button" data-icon="double-angle-down" data-theme="b">data-icon="double-angle-down"</a> - <a href="index.html" data-role="button" data-icon="circle-blank" data-theme="b">data-icon="circle-blank"</a> - <a href="index.html" data-role="button" data-icon="circle" data-theme="b">data-icon="circle"</a> - <a href="index.html" data-role="button" data-icon="desktop" data-theme="b">data-icon="desktop"</a> - <a href="index.html" data-role="button" data-icon="laptop" data-theme="b">data-icon="laptop"</a> - <a href="index.html" data-role="button" data-icon="tablet" data-theme="b">data-icon="tablet"</a> - <a href="index.html" data-role="button" data-icon="mobile-phone" data-theme="b">data-icon="mobile-phone"</a> - <a href="index.html" data-role="button" data-icon="quote-left" data-theme="b">data-icon="quote-left"</a> - <a href="index.html" data-role="button" data-icon="quote-right" data-theme="b">data-icon="quote-right"</a> - <a href="index.html" data-role="button" data-icon="github-alt" data-theme="b">data-icon="github-alt"</a> - <a href="index.html" data-role="button" data-icon="folder-close-alt" data-theme="b">data-icon="folder-close-alt"</a> - <a href="index.html" data-role="button" data-icon="folder-open-alt" data-theme="b">data-icon="folder-open-alt"</a> - - - - - - - - - <a href="index.html" data-role="button" data-icon="glass">data-icon="glass"</a> - <a href="index.html" data-role="button" data-icon="music">data-icon="music"</a> - <a href="index.html" data-role="button" data-icon="fasearch">data-icon="fasearch"</a> - <a href="index.html" data-role="button" data-icon="envelope">data-icon="envelope"</a> - <a href="index.html" data-role="button" data-icon="heart">data-icon="heart"</a> - <a href="index.html" data-role="button" data-icon="fastar">data-icon="fastar"</a> - <a href="index.html" data-role="button" data-icon="star-empty">data-icon="star-empty"</a> - <a href="index.html" data-role="button" data-icon="user">data-icon="user"</a> - <a href="index.html" data-role="button" data-icon="film">data-icon="film"</a> - <a href="index.html" data-role="button" data-icon="th-large">data-icon="th-large"</a> - <a href="index.html" data-role="button" data-icon="th">data-icon="th"</a> - <a href="index.html" data-role="button" data-icon="th-list">data-icon="th-list"</a> - <a href="index.html" data-role="button" data-icon="ok">data-icon="ok"</a> - <a href="index.html" data-role="button" data-icon="remove">data-icon="remove"</a> - <a href="index.html" data-role="button" data-icon="zoom-in">data-icon="zoom-in"</a> - <a href="index.html" data-role="button" data-icon="zoom-out">data-icon="zoom-out"</a> - <a href="index.html" data-role="button" data-icon="off">data-icon="off"</a> - <a href="index.html" data-role="button" data-icon="signal">data-icon="signal"</a> - <a href="index.html" data-role="button" data-icon="cog">data-icon="cog"</a> - <a href="index.html" data-role="button" data-icon="trash">data-icon="trash"</a> - <a href="index.html" data-role="button" data-icon="fahome">data-icon="fahome"</a> - <a href="index.html" data-role="button" data-icon="file">data-icon="file"</a> - <a href="index.html" data-role="button" data-icon="time">data-icon="time"</a> - <a href="index.html" data-role="button" data-icon="road">data-icon="road"</a> - <a href="index.html" data-role="button" data-icon="download-alt">data-icon="download-alt"</a> - <a href="index.html" data-role="button" data-icon="download">data-icon="download"</a> - <a href="index.html" data-role="button" data-icon="upload">data-icon="upload"</a> - <a href="index.html" data-role="button" data-icon="inbox">data-icon="inbox"</a> - <a href="index.html" data-role="button" data-icon="play-circle">data-icon="play-circle"</a> - <a href="index.html" data-role="button" data-icon="repeat">data-icon="repeat"</a> - <a href="index.html" data-role="button" data-icon="farefresh">data-icon="farefresh"</a> - <a href="index.html" data-role="button" data-icon="list-alt">data-icon="list-alt"</a> - <a href="index.html" data-role="button" data-icon="lock">data-icon="lock"</a> - <a href="index.html" data-role="button" data-icon="flag">data-icon="flag"</a> - <a href="index.html" data-role="button" data-icon="headphones">data-icon="headphones"</a> - <a href="index.html" data-role="button" data-icon="volume-off">data-icon="volume-off"</a> - <a href="index.html" data-role="button" data-icon="volume-down">data-icon="volume-down"</a> - <a href="index.html" data-role="button" data-icon="volume-up">data-icon="volume-up"</a> - <a href="index.html" data-role="button" data-icon="qrcode">data-icon="qrcode"</a> - <a href="index.html" data-role="button" data-icon="barcode">data-icon="barcode"</a> - <a href="index.html" data-role="button" data-icon="tag">data-icon="tag"</a> - <a href="index.html" data-role="button" data-icon="tags">data-icon="tags"</a> - <a href="index.html" data-role="button" data-icon="book">data-icon="book"</a> - <a href="index.html" data-role="button" data-icon="bookmark">data-icon="bookmark"</a> - <a href="index.html" data-role="button" data-icon="print">data-icon="print"</a> - <a href="index.html" data-role="button" data-icon="camera">data-icon="camera"</a> - <a href="index.html" data-role="button" data-icon="font">data-icon="font"</a> - <a href="index.html" data-role="button" data-icon="bold">data-icon="bold"</a> - <a href="index.html" data-role="button" data-icon="italic">data-icon="italic"</a> - <a href="index.html" data-role="button" data-icon="text-height">data-icon="text-height"</a> - <a href="index.html" data-role="button" data-icon="text-width">data-icon="text-width"</a> - <a href="index.html" data-role="button" data-icon="align-left">data-icon="align-left"</a> - <a href="index.html" data-role="button" data-icon="align-center">data-icon="align-center"</a> - <a href="index.html" data-role="button" data-icon="align-right">data-icon="align-right"</a> - <a href="index.html" data-role="button" data-icon="align-justify">data-icon="align-justify"</a> - <a href="index.html" data-role="button" data-icon="list">data-icon="list"</a> - <a href="index.html" data-role="button" data-icon="indent-left">data-icon="indent-left"</a> - <a href="index.html" data-role="button" data-icon="indent-right">data-icon="indent-right"</a> - <a href="index.html" data-role="button" data-icon="facetime-video">data-icon="facetime-video"</a> - <a href="index.html" data-role="button" data-icon="picture">data-icon="picture"</a> - <a href="index.html" data-role="button" data-icon="pencil">data-icon="pencil"</a> - <a href="index.html" data-role="button" data-icon="map-marker">data-icon="map-marker"</a> - <a href="index.html" data-role="button" data-icon="adjust">data-icon="adjust"</a> - <a href="index.html" data-role="button" data-icon="tint">data-icon="tint"</a> - <a href="index.html" data-role="button" data-icon="edit">data-icon="edit"</a> - <a href="index.html" data-role="button" data-icon="share">data-icon="share"</a> - <a href="index.html" data-role="button" data-icon="facheck">data-icon="facheck"</a> - <a href="index.html" data-role="button" data-icon="move">data-icon="move"</a> - <a href="index.html" data-role="button" data-icon="step-backward">data-icon="step-backward"</a> - <a href="index.html" data-role="button" data-icon="fast-backward">data-icon="fast-backward"</a> - <a href="index.html" data-role="button" data-icon="backward">data-icon="backward"</a> - <a href="index.html" data-role="button" data-icon="play">data-icon="play"</a> - <a href="index.html" data-role="button" data-icon="pause">data-icon="pause"</a> - <a href="index.html" data-role="button" data-icon="stop">data-icon="stop"</a> - <a href="index.html" data-role="button" data-icon="faforward">data-icon="faforward"</a> - <a href="index.html" data-role="button" data-icon="fast-forward">data-icon="fast-forward"</a> - <a href="index.html" data-role="button" data-icon="step-forward">data-icon="step-forward"</a> - <a href="index.html" data-role="button" data-icon="eject">data-icon="eject"</a> - <a href="index.html" data-role="button" data-icon="chevron-left">data-icon="chevron-left"</a> - <a href="index.html" data-role="button" data-icon="chevron-right">data-icon="chevron-right"</a> - <a href="index.html" data-role="button" data-icon="plus-sign">data-icon="plus-sign"</a> - <a href="index.html" data-role="button" data-icon="minus-sign">data-icon="minus-sign"</a> - <a href="index.html" data-role="button" data-icon="remove-sign">data-icon="remove-sign"</a> - <a href="index.html" data-role="button" data-icon="ok-sign">data-icon="ok-sign"</a> - <a href="index.html" data-role="button" data-icon="question-sign">data-icon="question-sign"</a> - <a href="index.html" data-role="button" data-icon="info-sign">data-icon="info-sign"</a> - <a href="index.html" data-role="button" data-icon="screenshot">data-icon="screenshot"</a> - <a href="index.html" data-role="button" data-icon="remove-circle">data-icon="remove-circle"</a> - <a href="index.html" data-role="button" data-icon="ok-circle">data-icon="ok-circle"</a> - <a href="index.html" data-role="button" data-icon="ban-circle">data-icon="ban-circle"</a> - <a href="index.html" data-role="button" data-icon="arrow-left">data-icon="arrow-left"</a> - <a href="index.html" data-role="button" data-icon="arrow-right">data-icon="arrow-right"</a> - <a href="index.html" data-role="button" data-icon="arrow-up">data-icon="arrow-up"</a> - <a href="index.html" data-role="button" data-icon="arrow-down">data-icon="arrow-down"</a> - <a href="index.html" data-role="button" data-icon="share-alt">data-icon="share-alt"</a> - <a href="index.html" data-role="button" data-icon="resize-full">data-icon="resize-full"</a> - <a href="index.html" data-role="button" data-icon="resize-small">data-icon="resize-small"</a> - <a href="index.html" data-role="button" data-icon="faplus">data-icon="faplus"</a> - <a href="index.html" data-role="button" data-icon="faminus">data-icon="faminus"</a> - <a href="index.html" data-role="button" data-icon="asterisk">data-icon="asterisk"</a> - <a href="index.html" data-role="button" data-icon="exclamation-sign">data-icon="exclamation-sign"</a> - <a href="index.html" data-role="button" data-icon="gift">data-icon="gift"</a> - <a href="index.html" data-role="button" data-icon="leaf">data-icon="leaf"</a> - <a href="index.html" data-role="button" data-icon="fire">data-icon="fire"</a> - <a href="index.html" data-role="button" data-icon="eye-open">data-icon="eye-open"</a> - <a href="index.html" data-role="button" data-icon="eye-close">data-icon="eye-close"</a> - <a href="index.html" data-role="button" data-icon="warning-sign">data-icon="warning-sign"</a> - <a href="index.html" data-role="button" data-icon="plane">data-icon="plane"</a> - <a href="index.html" data-role="button" data-icon="calendar">data-icon="calendar"</a> - <a href="index.html" data-role="button" data-icon="random">data-icon="random"</a> - <a href="index.html" data-role="button" data-icon="comment">data-icon="comment"</a> - <a href="index.html" data-role="button" data-icon="magnet">data-icon="magnet"</a> - <a href="index.html" data-role="button" data-icon="chevron-up">data-icon="chevron-up"</a> - <a href="index.html" data-role="button" data-icon="chevron-down">data-icon="chevron-down"</a> - <a href="index.html" data-role="button" data-icon="retweet">data-icon="retweet"</a> - <a href="index.html" data-role="button" data-icon="shopping-cart">data-icon="shopping-cart"</a> - <a href="index.html" data-role="button" data-icon="folder-close">data-icon="folder-close"</a> - <a href="index.html" data-role="button" data-icon="folder-open">data-icon="folder-open"</a> - <a href="index.html" data-role="button" data-icon="resize-vertical">data-icon="resize-vertical"</a> - <a href="index.html" data-role="button" data-icon="resize-horizontal">data-icon="resize-horizontal"</a> - <a href="index.html" data-role="button" data-icon="bar-chart">data-icon="bar-chart"</a> - <a href="index.html" data-role="button" data-icon="twitter-sign">data-icon="twitter-sign"</a> - <a href="index.html" data-role="button" data-icon="facebook-sign">data-icon="facebook-sign"</a> - <a href="index.html" data-role="button" data-icon="camera-retro">data-icon="camera-retro"</a> - <a href="index.html" data-role="button" data-icon="key">data-icon="key"</a> - <a href="index.html" data-role="button" data-icon="cogs">data-icon="cogs"</a> - <a href="index.html" data-role="button" data-icon="comments">data-icon="comments"</a> - <a href="index.html" data-role="button" data-icon="thumbs-up">data-icon="thumbs-up"</a> - <a href="index.html" data-role="button" data-icon="thumbs-down">data-icon="thumbs-down"</a> - <a href="index.html" data-role="button" data-icon="star-half">data-icon="star-half"</a> - <a href="index.html" data-role="button" data-icon="heart-empty">data-icon="heart-empty"</a> - <a href="index.html" data-role="button" data-icon="signout">data-icon="signout"</a> - <a href="index.html" data-role="button" data-icon="linkedin-sign">data-icon="linkedin-sign"</a> - <a href="index.html" data-role="button" data-icon="pushpin">data-icon="pushpin"</a> - <a href="index.html" data-role="button" data-icon="external-link">data-icon="external-link"</a> - <a href="index.html" data-role="button" data-icon="signin">data-icon="signin"</a> - <a href="index.html" data-role="button" data-icon="trophy">data-icon="trophy"</a> - <a href="index.html" data-role="button" data-icon="github-sign">data-icon="github-sign"</a> - <a href="index.html" data-role="button" data-icon="upload-alt">data-icon="upload-alt"</a> - <a href="index.html" data-role="button" data-icon="lemon">data-icon="lemon"</a> - - - - - <a href="index.html" data-role="button" data-icon="beaker">data-icon="beaker"</a> - <a href="index.html" data-role="button" data-icon="bell">data-icon="bell"</a> - <a href="index.html" data-role="button" data-icon="bolt">data-icon="bolt"</a> - <a href="index.html" data-role="button" data-icon="bookmark-empty">data-icon="bookmark-empty"</a> - <a href="index.html" data-role="button" data-icon="briefcase">data-icon="briefcase"</a> - <a href="index.html" data-role="button" data-icon="bullhorn">data-icon="bullhorn"</a> - <a href="index.html" data-role="button" data-icon="caret-down">data-icon="caret-down"</a> - <a href="index.html" data-role="button" data-icon="caret-left">data-icon="caret-left"</a> - <a href="index.html" data-role="button" data-icon="caret-right">data-icon="caret-right"</a> - <a href="index.html" data-role="button" data-icon="caret-up">data-icon="caret-up"</a> - <a href="index.html" data-role="button" data-icon="certificate">data-icon="certificate"</a> - <a href="index.html" data-role="button" data-icon="check-empty">data-icon="check-empty"</a> - <a href="index.html" data-role="button" data-icon="circle-arrow-down">data-icon="circle-arrow-down"</a> - <a href="index.html" data-role="button" data-icon="circle-arrow-left">data-icon="circle-arrow-left"</a> - <a href="index.html" data-role="button" data-icon="circle-arrow-right">data-icon="circle-arrow-right"</a> - <a href="index.html" data-role="button" data-icon="circle-arrow-up">data-icon="circle-arrow-up"</a> - <a href="index.html" data-role="button" data-icon="cloud">data-icon="cloud"</a> - <a href="index.html" data-role="button" data-icon="columns">data-icon="columns"</a> - <a href="index.html" data-role="button" data-icon="comment-alt">data-icon="comment-alt"</a> - <a href="index.html" data-role="button" data-icon="comments-alt">data-icon="comments-alt"</a> - <a href="index.html" data-role="button" data-icon="copy">data-icon="copy"</a> - <a href="index.html" data-role="button" data-icon="credit-card">data-icon="credit-card"</a> - <a href="index.html" data-role="button" data-icon="cut">data-icon="cut"</a> - <a href="index.html" data-role="button" data-icon="dashboard">data-icon="dashboard"</a> - <a href="index.html" data-role="button" data-icon="envelope-alt">data-icon="envelope-alt"</a> - <a href="index.html" data-role="button" data-icon="facebook">data-icon="facebook"</a> - <a href="index.html" data-role="button" data-icon="filter">data-icon="filter"</a> - <a href="index.html" data-role="button" data-icon="fullscreen">data-icon="fullscreen"</a> - <a href="index.html" data-role="button" data-icon="github">data-icon="github"</a> - <a href="index.html" data-role="button" data-icon="globe">data-icon="globe"</a> - <a href="index.html" data-role="button" data-icon="google-plus-sign">data-icon="google-plus-sign"</a> - <a href="index.html" data-role="button" data-icon="google-plus">data-icon="google-plus"</a> - <a href="index.html" data-role="button" data-icon="group">data-icon="group"</a> - <a href="index.html" data-role="button" data-icon="hand-down">data-icon="hand-down"</a> - <a href="index.html" data-role="button" data-icon="hand-left">data-icon="hand-left"</a> - <a href="index.html" data-role="button" data-icon="hand-right">data-icon="hand-right"</a> - <a href="index.html" data-role="button" data-icon="hand-up">data-icon="hand-up"</a> - <a href="index.html" data-role="button" data-icon="hdd">data-icon="hdd"</a> - <a href="index.html" data-role="button" data-icon="legal">data-icon="legal"</a> - <a href="index.html" data-role="button" data-icon="link">data-icon="link"</a> - <a href="index.html" data-role="button" data-icon="linkedin">data-icon="linkedin"</a> - <a href="index.html" data-role="button" data-icon="list-ol">data-icon="list-ol"</a> - <a href="index.html" data-role="button" data-icon="list-ul">data-icon="list-ul"</a> - <a href="index.html" data-role="button" data-icon="magic">data-icon="magic"</a> - <a href="index.html" data-role="button" data-icon="money">data-icon="money"</a> - <a href="index.html" data-role="button" data-icon="paper-clip">data-icon="paper-clip"</a> - <a href="index.html" data-role="button" data-icon="paste">data-icon="paste"</a> - <a href="index.html" data-role="button" data-icon="phone-sign">data-icon="phone-sign"</a> - <a href="index.html" data-role="button" data-icon="phone">data-icon="phone"</a> - <a href="index.html" data-role="button" data-icon="pinterest-sign">data-icon="pinterest-sign"</a> - <a href="index.html" data-role="button" data-icon="pinterest">data-icon="pinterest"</a> - <a href="index.html" data-role="button" data-icon="reorder">data-icon="reorder"</a> - <a href="index.html" data-role="button" data-icon="rss">data-icon="rss"</a> - <a href="index.html" data-role="button" data-icon="save">data-icon="save"</a> - <a href="index.html" data-role="button" data-icon="sign-blank">data-icon="sign-blank"</a> - <a href="index.html" data-role="button" data-icon="sitemap">data-icon="sitemap"</a> - <a href="index.html" data-role="button" data-icon="sort-down">data-icon="sort-down"</a> - <a href="index.html" data-role="button" data-icon="sort-up">data-icon="sort-up"</a> - <a href="index.html" data-role="button" data-icon="sort">data-icon="sort"</a> - <a href="index.html" data-role="button" data-icon="strikethrough">data-icon="strikethrough"</a> - <a href="index.html" data-role="button" data-icon="table">data-icon="table"</a> - <a href="index.html" data-role="button" data-icon="tasks">data-icon="tasks"</a> - <a href="index.html" data-role="button" data-icon="truck">data-icon="truck"</a> - <a href="index.html" data-role="button" data-icon="twitter">data-icon="twitter"</a> - <a href="index.html" data-role="button" data-icon="umbrella">data-icon="umbrella"</a> - <a href="index.html" data-role="button" data-icon="underline">data-icon="underline"</a> - <a href="index.html" data-role="button" data-icon="undo">data-icon="undo"</a> - <a href="index.html" data-role="button" data-icon="unlock">data-icon="unlock"</a> - <a href="index.html" data-role="button" data-icon="user-md">data-icon="user-md"</a> - <a href="index.html" data-role="button" data-icon="wrench">data-icon="wrench"</a> - </div> - - <p align="center"> - Glyphs courtesy of <a href="http://fortawesome.github.com/Font-Awesome/">FontAwesome</a> - </p> - - <div data-role="footer" data-theme="c"> - <p align="center">© 2013 - Andy Matthews</p> - </div> - - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/jqm-icon-pack-3.0.0-fa.css b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/jqm-icon-pack-3.0.0-fa.css deleted file mode 100644 index 60408b3aa..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/jqm-icon-pack-3.0.0-fa.css +++ /dev/null @@ -1 +0,0 @@ -.ui-icon{width:20px;height:20px;-moz-border-radius:10px;-webkit-border-radius:10px;border-radius:10px;margin-top:-10px !important;line-height:20px}.ui-icon:before{margin-left:3px}.ui-btn-icon-notext .ui-btn-inner .ui-icon{margin:1px 1px 2px 2px !important}.ui-li-link-alt .ui-btn-inner .ui-icon{margin:-10px -10px auto auto !important}.ui-icon-plus,.ui-icon-minus,.ui-icon-delete,.ui-icon-arrow-r,.ui-icon-arrow-l,.ui-icon-arrow-u,.ui-icon-arrow-d,.ui-icon-check,.ui-icon-gear,.ui-icon-refresh,.ui-icon-forward,.ui-icon-back,.ui-icon-grid,.ui-icon-star,.ui-icon-alert,.ui-icon-info,.ui-icon-home,.ui-icon-search,.ui-icon-searchfield:after,.ui-icon-checkbox-off,.ui-icon-checkbox-on,.ui-icon-radio-off,.ui-icon-radio-on,.ui-icon-email,.ui-icon-page,.ui-icon-question,.ui-icon-foursquare,.ui-icon-dollar,.ui-icon-euro,.ui-icon-pound,.ui-icon-apple,.ui-icon-chat,.ui-icon-trash,.ui-icon-mappin,.ui-icon-direction,.ui-icon-heart,.ui-icon-wrench,.ui-icon-play,.ui-icon-pause,.ui-icon-stop,.ui-icon-person,.ui-icon-music,.ui-icon-wifi,.ui-icon-phone,.ui-icon-power,.ui-icon-lightning,.ui-icon-drink,.ui-icon-android{background-image:url("images/icons-18-white-pack.png") !important}@media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min--moz-device-pixel-ratio: 1.5), only screen and (min-resolution: 240dpi){.ui-icon-plus,.ui-icon-minus,.ui-icon-delete,.ui-icon-arrow-r,.ui-icon-arrow-l,.ui-icon-arrow-u,.ui-icon-arrow-d,.ui-icon-check,.ui-icon-gear,.ui-icon-refresh,.ui-icon-forward,.ui-icon-back,.ui-icon-grid,.ui-icon-star,.ui-icon-alert,.ui-icon-info,.ui-icon-home,.ui-icon-search,.ui-icon-searchfield:after,.ui-icon-checkbox-off,.ui-icon-checkbox-on,.ui-icon-radio-off,.ui-icon-radio-on,.ui-icon-email,.ui-icon-page,.ui-icon-question,.ui-icon-foursquare,.ui-icon-dollar,.ui-icon-euro,.ui-icon-pound,.ui-icon-apple,.ui-icon-chat,.ui-icon-trash,.ui-icon-mappin,.ui-icon-direction,.ui-icon-heart,.ui-icon-wrench,.ui-icon-play,.ui-icon-pause,.ui-icon-stop,.ui-icon-person,.ui-icon-music,.ui-icon-wifi,.ui-icon-phone,.ui-icon-power,.ui-icon-lightning,.ui-icon-drink,.ui-icon-android{background-image:url("images/icons-36-white-pack.png");-moz-background-size:774px 54px;-o-background-size:774px 54px;-webkit-background-size:774px 54px;background-size:774px 54px}.ui-icon-alt{background-image:url("images/icons-36-black-pack.png")}}.ui-icon-plus{background-position:0px 1px !important}.ui-icon-minus{background-position:-36px 1px !important}.ui-icon-delete{background-position:-71px 1px !important}.ui-icon-arrow-r{background-position:-107px 1px !important}.ui-icon-arrow-l{background-position:-143px 1px !important}.ui-icon-arrow-u{background-position:-179px 1px !important}.ui-icon-arrow-d{background-position:-215px 1px !important}.ui-icon-check{background-position:-251px 1px !important}.ui-icon-gear{background-position:-287px 1px !important}.ui-icon-refresh{background-position:-323px 1px !important}.ui-icon-forward{background-position:-359px 1px !important}.ui-icon-back{background-position:-396px 0 !important}.ui-icon-grid{background-position:-431px 1px !important}.ui-icon-star{background-position:-467px 1px !important}.ui-icon-alert{background-position:-503px 1px !important}.ui-icon-info{background-position:-539px 1px !important}.ui-icon-home{background-position:-575px 1px !important}.ui-icon-search,.ui-icon-searchfield:after{background-position:-611px 0px !important}.ui-icon-checkbox-off{background-position:-681px 1px !important}.ui-icon-checkbox-on{background-position:-647px 1px !important}.ui-icon-radio-off{background-position:-752px 1px !important}.ui-icon-radio-on{background-position:-717px 1px !important}.ui-icon-email{background-position:1px -17px !important}.ui-icon-page{background-position:-36px -17px !important}.ui-icon-question{background-position:-71px -17px !important}.ui-icon-foursquare{background-position:-107px -17px !important}.ui-icon-dollar{background-position:-215px -17px !important}.ui-icon-euro{background-position:-251px -17px !important}.ui-icon-pound{background-position:-287px -17px !important}.ui-icon-apple{background-position:-323px -17px !important}.ui-icon-chat{background-position:-359px -17px !important}.ui-icon-trash{background-position:-395px -17px !important}.ui-icon-mappin{background-position:-467px -17px !important}.ui-icon-direction{background-position:-503px -17px !important}.ui-icon-heart{background-position:-539px -17px !important}.ui-icon-wrench{background-position:-575px -17px !important}.ui-icon-play{background-position:-611px -17px !important}.ui-icon-pause{background-position:-647px -17px !important}.ui-icon-stop{background-position:-683px -17px !important}.ui-icon-person{background-position:-719px -17px !important}.ui-icon-music{background-position:-755px -17px !important}.ui-icon-wifi{background-position:-35px -34px !important}.ui-icon-phone{background-position:-72px -36px !important}.ui-icon-power{background-position:-107px -35px !important}.ui-icon-lightning{background-position:-251px -35px !important}.ui-icon-android{background-position:-323px -35px !important}@font-face{font-family:'FontAwesome';src:url("font/fontawesome-webfont.eot");src:url("font/fontawesome-webfont.eot?#iefix") format("embedded-opentype"),url("font/fontawesome-webfont.woff") format("woff"),url("font/fontawesome-webfont.ttf") format("truetype");font-weight:normal;font-style:normal}[class^="ui-icon-"]:before,[class*=" ui-icon-"]:before{font-family:FontAwesome !important;font-weight:normal;font-style:normal;display:inline-block}.ui-icon:not(.ui-icon-loading),.ui-icon-searchfield::after{background:#666666;background:rgba(0,0,0,0.4);color:#ffffff;font-weight:normal;text-shadow:none}.ui-icon-cloud-download:before{content:"\f0ed";margin-left:2px}.ui-icon-cloud-upload:before{content:"\f0ee";margin-left:2px}.ui-icon-lightbulb:before{content:"\f0eb";margin-top:1px;margin-left:3px}.ui-icon-exchange:before{content:"\f0ec"}.ui-icon-bell-alt:before{content:"\f0f3"}.ui-icon-file-alt:before{content:"\f0f6"}.ui-icon-beer:before{content:"\f0fc";margin-top:1px;margin-left:2px}.ui-icon-coffee:before{content:"\f0f4";margin-left:2px}.ui-icon-food:before{content:"\f0f5";margin-top:1px;margin-left:4px}.ui-icon-fighter-jet:before{content:"\f0fb";margin-top:1px;margin-left:2px}.ui-icon-user-md:before{content:"\f0f0"}.ui-icon-stethoscope:before{content:"\f0f1";margin-top:1px;margin-left:4px}.ui-icon-suitcase:before{content:"\f0f2";margin-left:2px}.ui-icon-building:before{content:"\f0f7"}.ui-icon-hospital:before{content:"\f0f8";margin-left:4px}.ui-icon-ambulance:before{content:"\f0f9";margin-top:1px;margin-left:1px}.ui-icon-medkit:before{content:"\f0fa";margin-top:0px;margin-left:2px}.ui-icon-h-sign:before{content:"\f0fd"}.ui-icon-plus-sign-alt:before{content:"\f0fe"}.ui-icon-spinner:before{content:"\f110"}.ui-icon-angle-left:before{content:"\f104"}.ui-icon-angle-right:before{content:"\f105"}.ui-icon-angle-up:before{content:"\f106"}.ui-icon-angle-down:before{content:"\f107"}.ui-icon-double-angle-left:before{content:"\f100"}.ui-icon-double-angle-right:before{content:"\f101";margin-left:4px}.ui-icon-double-angle-up:before{content:"\f102"}.ui-icon-double-angle-down:before{content:"\f103";margin-top:1px}.ui-icon-circle-blank:before{content:"\f10c"}.ui-icon-circle:before{content:"\f111"}.ui-icon-desktop:before{content:"\f108";margin-top:1px;margin-left:2px}.ui-icon-laptop:before{content:"\f109";margin-top:1px;margin-left:2px}.ui-icon-tablet:before{content:"\f10a";margin-top:1px}.ui-icon-mobile-phone:before{content:"\f10b"}.ui-icon-quote-left:before{content:"\f10d"}.ui-icon-quote-right:before{content:"\f10e"}.ui-icon-github-alt:before{content:"\f113"}.ui-icon-folder-close-alt:before{content:"\f114"}.ui-icon-folder-open-alt:before{content:"\f115"}.ui-icon-glass:before{content:"\f000";margin-top:2px}.ui-icon-music:before{content:"\f001";margin-left:1px;margin-top:2px}.ui-icon-fasearch:before{content:"\f002"}.ui-icon-envelope:before{content:"\f003";margin-left:-1px;margin-left:2px;margin-top:1px}.ui-icon-heart:before{content:"\f004";margin-left:3px;margin-top:2px}.ui-icon-fastar:before{content:"\f005"}.ui-icon-star-empty:before{content:"\f006"}.ui-icon-user:before{content:"\f007";margin-left:4px}.ui-icon-film:before{content:"\f008";margin-left:2px}.ui-icon-th-large:before{content:"\f009";margin-left:2px;margin-top:2px}.ui-icon-th:before{content:"\f00a";margin-left:3px;margin-top:2px}.ui-icon-th-list:before{content:"\f00b";margin-left:3px;margin-top:2px}.ui-icon-ok:before{content:"\f00c";margin-left:2px}.ui-icon-remove:before{content:"\f00d";margin-left:3px;margin-top:2px}.ui-icon-zoom-in:before{content:"\f00e"}.ui-icon-zoom-out:before{content:"\f010"}.ui-icon-off:before{content:"\f011"}.ui-icon-signal:before{content:"\f012";margin-left:-1px}.ui-icon-cog:before{content:"\f013";margin-left:3px;margin-top:2px}.ui-icon-trash:before{content:"\f014"}.ui-icon-fahome:before{content:"\f015"}.ui-icon-file:before{content:"\f016"}.ui-icon-time:before{content:"\f017";margin-top:2px}.ui-icon-road:before{content:"\f018"}.ui-icon-download-alt:before{content:"\f019"}.ui-icon-download:before{content:"\f01a";margin-top:2px}.ui-icon-upload:before{content:"\f01b";margin-top:2px}.ui-icon-inbox:before{content:"\f01c"}.ui-icon-play-circle:before{content:"\f01d";margin-top:2px}.ui-icon-repeat:before{content:"\f01e";margin-top:2px}.ui-icon-farefresh:before{content:"\f021";margin-top:2px}.ui-icon-list-alt:before{content:"\f022";margin-left:3px;margin-top:2px}.ui-icon-lock:before{content:"\f023"}.ui-icon-flag:before{content:"\f024";margin-top:2px}.ui-icon-headphones:before{content:"\f025"}.ui-icon-volume-off:before{content:"\f026"}.ui-icon-volume-down:before{content:"\f027"}.ui-icon-volume-up:before{content:"\f028"}.ui-icon-qrcode:before{content:"\f029"}.ui-icon-barcode:before{content:"\f02a"}.ui-icon-tag:before{content:"\f02b"}.ui-icon-tags:before{content:"\f02c"}.ui-icon-book:before{content:"\f02d"}.ui-icon-bookmark:before{content:"\f02e"}.ui-icon-print:before{content:"\f02f"}.ui-icon-camera:before{content:"\f030"}.ui-icon-font:before{content:"\f031";margin-left:2px}.ui-icon-bold:before{content:"\f032";margin-left:2px}.ui-icon-italic:before{content:"\f033"}.ui-icon-text-height:before{content:"\f034"}.ui-icon-text-width:before{content:"\f035"}.ui-icon-align-left:before{content:"\f036"}.ui-icon-align-center:before{content:"\f037"}.ui-icon-align-right:before{content:"\f038"}.ui-icon-align-justify:before{content:"\f039"}.ui-icon-list:before{content:"\f03a"}.ui-icon-indent-left:before{content:"\f03b";margin-left:0px;margin-top:2px}.ui-icon-indent-right:before{content:"\f03c"}.ui-icon-facetime-video:before{content:"\f03d"}.ui-icon-picture:before{content:"\f03e"}.ui-icon-pencil:before{content:"\f040"}.ui-icon-map-marker:before{content:"\f041";margin-left:3px;margin-top:2px}.ui-icon-adjust:before{content:"\f042";margin-top:2px}.ui-icon-tint:before{content:"\f043"}.ui-icon-edit:before{content:"\f044"}.ui-icon-share:before{content:"\f045"}.ui-icon-facheck:before{content:"\f046"}.ui-icon-move:before{content:"\f047"}.ui-icon-step-backward:before{content:"\f048"}.ui-icon-fast-backward:before{content:"\f049"}.ui-icon-backward:before{content:"\f04a"}.ui-icon-play:before{content:"\f04b";margin-left:6px;margin-top:2px}.ui-icon-pause:before{content:"\f04c";margin-top:2px}.ui-icon-stop:before{content:"\f04d";margin-top:2px}.ui-icon-faforward:before{content:"\f04e"}.ui-icon-fast-forward:before{content:"\f050"}.ui-icon-step-forward:before{content:"\f051"}.ui-icon-eject:before{content:"\f052"}.ui-icon-chevron-left:before{content:"\f053";margin-top:2px}.ui-icon-chevron-right:before{content:"\f054";margin-top:2px}.ui-icon-plus-sign:before{content:"\f055";margin-top:2px}.ui-icon-minus-sign:before{content:"\f056";margin-top:2px}.ui-icon-remove-sign:before{content:"\f057";margin-top:2px}.ui-icon-ok-sign:before{content:"\f058";margin-top:2px}.ui-icon-question-sign:before{content:"\f059";margin-top:2px}.ui-icon-info-sign:before{content:"\f05a";margin-top:2px}.ui-icon-screenshot:before{content:"\f05b"}.ui-icon-remove-circle:before{content:"\f05c";margin-top:2px}.ui-icon-ok-circle:before{content:"\f05d";margin-top:2px}.ui-icon-ban-circle:before{content:"\f05e";margin-top:2px}.ui-icon-arrow-left:before{content:"\f060"}.ui-icon-arrow-right:before{content:"\f061"}.ui-icon-arrow-up:before{content:"\f062"}.ui-icon-arrow-down:before{content:"\f063"}.ui-icon-share-alt:before{content:"\f064"}.ui-icon-resize-full:before{content:"\f065"}.ui-icon-resize-small:before{content:"\f066"}.ui-icon-faplus:before{content:"\f067"}.ui-icon-faminus:before{content:"\f068"}.ui-icon-asterisk:before{content:"\f069";margin-top:2px}.ui-icon-exclamation-sign:before{content:"\f06a";margin-top:2px}.ui-icon-gift:before{content:"\f06b"}.ui-icon-leaf:before{content:"\f06c"}.ui-icon-fire:before{content:"\f06d"}.ui-icon-eye-open:before{content:"\f06e"}.ui-icon-eye-close:before{content:"\f070"}.ui-icon-warning-sign:before{content:"\f071"}.ui-icon-plane:before{content:"\f072"}.ui-icon-calendar:before{content:"\f073"}.ui-icon-random:before{content:"\f074"}.ui-icon-comment:before{content:"\f075";margin-top:2px}.ui-icon-magnet:before{content:"\f076";margin-top:2px}.ui-icon-chevron-up:before{content:"\f077"}.ui-icon-chevron-down:before{content:"\f078"}.ui-icon-retweet:before{content:"\f079"}.ui-icon-shopping-cart:before{content:"\f07a"}.ui-icon-folder-close:before{content:"\f07b"}.ui-icon-folder-open:before{content:"\f07c"}.ui-icon-resize-vertical:before{content:"\f07d"}.ui-icon-resize-horizontal:before{content:"\f07e"}.ui-icon-bar-chart:before{content:"\f080"}.ui-icon-twitter-sign:before{content:"\f081"}.ui-icon-facebook-sign:before{content:"\f082"}.ui-icon-camera-retro:before{content:"\f083"}.ui-icon-key:before{content:"\f084"}.ui-icon-cogs:before{content:"\f085"}.ui-icon-comments:before{content:"\f086"}.ui-icon-thumbs-up:before{content:"\f087"}.ui-icon-thumbs-down:before{content:"\f088"}.ui-icon-star-half:before{content:"\f089"}.ui-icon-heart-empty:before{content:"\f08a";margin-top:2px}.ui-icon-signout:before{content:"\f08b"}.ui-icon-linkedin-sign:before{content:"\f08c"}.ui-icon-pushpin:before{content:"\f08d"}.ui-icon-external-link:before{content:"\f08e"}.ui-icon-signin:before{content:"\f090"}.ui-icon-trophy:before{content:"\f091"}.ui-icon-github-sign:before{content:"\f092"}.ui-icon-upload-alt:before{content:"\f093"}.ui-icon-lemon:before{content:"\f094"}.ui-icon-phone:before{content:"\f095"}.ui-icon-check-empty:before{content:"\f096"}.ui-icon-bookmark-empty:before{content:"\f097"}.ui-icon-phone-sign:before{content:"\f098"}.ui-icon-twitter:before{content:"\f099"}.ui-icon-facebook:before{content:"\f09a"}.ui-icon-github:before{content:"\f09b";margin-top:2px}.ui-icon-unlock:before{content:"\f09c"}.ui-icon-credit-card:before{content:"\f09d"}.ui-icon-rss:before{content:"\f09e"}.ui-icon-hdd:before{content:"\f0a0"}.ui-icon-bullhorn:before{content:"\f0a1"}.ui-icon-bell:before{content:"\f0a2"}.ui-icon-certificate:before{content:"\f0a3";margin-top:2px}.ui-icon-hand-right:before{content:"\f0a4"}.ui-icon-hand-left:before{content:"\f0a5"}.ui-icon-hand-up:before{content:"\f0a6"}.ui-icon-hand-down:before{content:"\f0a7"}.ui-icon-circle-arrow-left:before{content:"\f0a8";margin-top:2px}.ui-icon-circle-arrow-right:before{content:"\f0a9";margin-top:2px}.ui-icon-circle-arrow-up:before{content:"\f0aa";margin-top:2px}.ui-icon-circle-arrow-down:before{content:"\f0ab";margin-top:2px}.ui-icon-globe:before{content:"\f0ac";margin-top:2px}.ui-icon-wrench:before{content:"\f0ad"}.ui-icon-tasks:before{content:"\f0ae"}.ui-icon-filter:before{content:"\f0b0"}.ui-icon-briefcase:before{content:"\f0b1"}.ui-icon-fullscreen:before{content:"\f0b2"}.ui-icon-group:before{content:"\f0c0"}.ui-icon-link:before{content:"\f0c1"}.ui-icon-cloud:before{content:"\f0c2"}.ui-icon-beaker:before{content:"\f0c3"}.ui-icon-cut:before{content:"\f0c4"}.ui-icon-copy:before{content:"\f0c5"}.ui-icon-paper-clip:before{content:"\f0c6"}.ui-icon-save:before{content:"\f0c7"}.ui-icon-sign-blank:before{content:"\f0c8"}.ui-icon-reorder:before{content:"\f0c9"}.ui-icon-list-ul:before{content:"\f0ca"}.ui-icon-list-ol:before{content:"\f0cb"}.ui-icon-strikethrough:before{content:"\f0cc"}.ui-icon-underline:before{content:"\f0cd"}.ui-icon-table:before{content:"\f0ce"}.ui-icon-magic:before{content:"\f0d0"}.ui-icon-truck:before{content:"\f0d1"}.ui-icon-pinterest:before{content:"\f0d2";margin-top:2px}.ui-icon-pinterest-sign:before{content:"\f0d3";margin-top:2px}.ui-icon-google-plus-sign:before{content:"\f0d4"}.ui-icon-google-plus:before{content:"\f0d5"}.ui-icon-money:before{content:"\f0d6"}.ui-icon-caret-down:before{content:"\f0d7";margin-top:2px}.ui-icon-caret-up:before{content:"\f0d8"}.ui-icon-caret-left:before{content:"\f0d9";margin-top:2px}.ui-icon-caret-right:before{content:"\f0da";margin-top:2px}.ui-icon-columns:before{content:"\f0db"}.ui-icon-sort:before{content:"\f0dc";margin-top:2px}.ui-icon-sort-down:before{content:"\f0dd"}.ui-icon-sort-up:before{content:"\f0de"}.ui-icon-envelope-alt:before{content:"\f0e0"}.ui-icon-linkedin:before{content:"\f0e1"}.ui-icon-undo:before{content:"\f0e2";margin-top:2px}.ui-icon-legal:before{content:"\f0e3"}.ui-icon-dashboard:before{content:"\f0e4"}.ui-icon-comment-alt:before{content:"\f0e5"}.ui-icon-comments-alt:before{content:"\f0e6"}.ui-icon-bolt:before{content:"\f0e7"}.ui-icon-sitemap:before{content:"\f0e8"}.ui-icon-umbrella:before{content:"\f0e9"}.ui-icon-paste:before{content:"\f0ea"}.ui-icon-user-md:before{content:"\f200"} diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/jqm-icon-pack-3.0.0-fa.scss b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/jqm-icon-pack-3.0.0-fa.scss deleted file mode 100644 index 2796ac004..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/font-awesome/jqm-icon-pack-3.0.0-fa.scss +++ /dev/null @@ -1,419 +0,0 @@ -/* - The following declaration increase the size of the "dot" which contains the icon - This is because some of the font awesome icons are larger than jQuery Mobile icons - It applies to ALL occurrences, but can be commented out or removed if necessary -*/ -.ui-icon { - width: 20px; - height: 20px; - -moz-border-radius: 10px; - -webkit-border-radius: 10px; - border-radius: 10px; - margin-top: -10px !important; - line-height: 20px; -} -.ui-icon:before { margin-left: 3px; } - -/* fix for Github issue #6 */ -.ui-btn-icon-notext .ui-btn-inner .ui-icon { - margin: 1px 1px 2px 2px !important; -} -.ui-li-link-alt .ui-btn-inner .ui-icon { - margin: -10px -10px auto auto !important; -} - -/* supporting original icons */ -.ui-icon-plus, .ui-icon-minus, .ui-icon-delete, .ui-icon-arrow-r, -.ui-icon-arrow-l, .ui-icon-arrow-u, .ui-icon-arrow-d, .ui-icon-check, -.ui-icon-gear, .ui-icon-refresh, .ui-icon-forward, .ui-icon-back, -.ui-icon-grid, .ui-icon-star, .ui-icon-alert, .ui-icon-info, .ui-icon-home, .ui-icon-search, .ui-icon-searchfield:after, -.ui-icon-checkbox-off, .ui-icon-checkbox-on, .ui-icon-radio-off, .ui-icon-radio-on, .ui-icon-email , .ui-icon-page, -.ui-icon-question , .ui-icon-foursquare, .ui-icon-dollar , .ui-icon-euro, -.ui-icon-pound , .ui-icon-apple , .ui-icon-chat , .ui-icon-trash , .ui-icon-mappin , .ui-icon-direction, -.ui-icon-heart , .ui-icon-wrench , .ui-icon-play , .ui-icon-pause , .ui-icon-stop , .ui-icon-person , .ui-icon-music, -.ui-icon-wifi , .ui-icon-phone , .ui-icon-power , -.ui-icon-lightning , .ui-icon-drink , .ui-icon-android { - background-image: url('images/icons-18-white-pack.png') !important; -} - -@media only screen and (-webkit-min-device-pixel-ratio: 1.3), - only screen and (-o-min-device-pixel-ratio: 3/2), - only screen and (min--moz-device-pixel-ratio: 1.3), - only screen and (min-device-pixel-ratio: 1.3), - only screen and (min-resolution: 1.3dppx) { - - .ui-icon-plus, .ui-icon-minus, .ui-icon-delete, .ui-icon-arrow-r, - .ui-icon-arrow-l, .ui-icon-arrow-u, .ui-icon-arrow-d, .ui-icon-check, - .ui-icon-gear, .ui-icon-refresh, .ui-icon-forward, .ui-icon-back, - .ui-icon-grid, .ui-icon-star, .ui-icon-alert, .ui-icon-info, .ui-icon-home, .ui-icon-search, .ui-icon-searchfield:after, - .ui-icon-checkbox-off, .ui-icon-checkbox-on, .ui-icon-radio-off, .ui-icon-radio-on, .ui-icon-email , .ui-icon-page, - .ui-icon-question , .ui-icon-foursquare, .ui-icon-dollar , .ui-icon-euro, - .ui-icon-pound , .ui-icon-apple , .ui-icon-chat , .ui-icon-trash , .ui-icon-mappin , .ui-icon-direction, - .ui-icon-heart , .ui-icon-wrench , .ui-icon-play , .ui-icon-pause , .ui-icon-stop , .ui-icon-person , .ui-icon-music, - .ui-icon-wifi , .ui-icon-phone , .ui-icon-power , - .ui-icon-lightning , .ui-icon-drink , .ui-icon-android { - background-image: url('images/icons-36-white-pack.png') !important; - -moz-background-size: 774px 54px; - -o-background-size: 774px 54px; - -webkit-background-size: 774px 54px; - background-size: 774px 54px; - } - .ui-icon-alt { - background-image: url('images/icons-36-black-pack.png'); - } -} - -/* first row */ -.ui-icon-plus { background-position: 0px 1px !important; } -.ui-icon-minus { background-position: -36px 1px !important; } -.ui-icon-delete { background-position: -71px 1px !important; } -.ui-icon-arrow-r { background-position: -107px 1px !important; } -.ui-icon-arrow-l { background-position: -143px 1px !important; } -.ui-icon-arrow-u { background-position: -179px 1px !important; } -.ui-icon-arrow-d { background-position: -215px 1px !important; } -.ui-icon-check { background-position: -251px 1px !important; } -.ui-icon-gear { background-position: -287px 1px !important; } -.ui-icon-refresh { background-position: -323px 1px !important; } -.ui-icon-forward { background-position: -359px 1px !important; } -.ui-icon-back { background-position: -396px -0 !important; } -.ui-icon-grid { background-position: -431px 1px !important; } -.ui-icon-star { background-position: -467px 1px !important; } -.ui-icon-alert { background-position: -503px 1px !important; } -.ui-icon-info { background-position: -539px 1px !important; } -.ui-icon-home { background-position: -575px 1px !important; } -.ui-icon-search,.ui-icon-searchfield:after { background-position: -611px 0px !important; } -.ui-icon-checkbox-off { background-position: -681px 1px !important; } -.ui-icon-checkbox-on { background-position: -647px 1px !important; } -.ui-icon-radio-off { background-position: -752px 1px !important; } -.ui-icon-radio-on { background-position: -717px 1px !important; } - -/* begin icon pack definitions */ -/* second row */ -.ui-icon-email { background-position: 1px -17px !important; } -.ui-icon-page { background-position: -36px -17px !important; } -.ui-icon-question { background-position: -71px -17px !important; } -.ui-icon-foursquare { background-position: -107px -17px !important; } -.ui-icon-dollar { background-position: -215px -17px !important; } -.ui-icon-euro { background-position: -251px -17px !important; } -.ui-icon-pound { background-position: -287px -17px !important; } -.ui-icon-apple { background-position: -323px -17px !important; } -.ui-icon-chat { background-position: -359px -17px !important; } -.ui-icon-trash { background-position: -395px -17px !important; } -.ui-icon-mappin { background-position: -467px -17px !important; } -.ui-icon-direction { background-position: -503px -17px !important; } -.ui-icon-heart { background-position: -539px -17px !important; } -.ui-icon-wrench { background-position: -575px -17px !important; } -.ui-icon-play { background-position: -611px -17px !important; } -.ui-icon-pause { background-position: -647px -17px !important; } -.ui-icon-stop { background-position: -683px -17px !important; } -.ui-icon-person { background-position: -719px -17px !important; } -.ui-icon-music { background-position: -755px -17px !important; } - -/* third row */ -.ui-icon-wifi { background-position: -35px -34px !important; } -.ui-icon-phone { background-position: -72px -36px !important; } -.ui-icon-power { background-position: -107px -35px !important; } -.ui-icon-lightning { background-position: -251px -35px !important; } -.ui-icon-android { background-position: -323px -35px !important; } - - - - -/* begin primary declarations */ -@font-face { - font-family: 'FontAwesome'; - src: url('font/fontawesome-webfont.eot'); - src: url('font/fontawesome-webfont.eot?#iefix') format('embedded-opentype'), - url('font/fontawesome-webfont.woff') format('woff'), - url('font/fontawesome-webfont.ttf') format('truetype'); - font-weight: normal; - font-style: normal; -} -[class^="ui-icon-"]:before, [class*=" ui-icon-"]:before { - font-family: FontAwesome !important; - font-weight: normal; - font-style: normal; - display: inline-block; -} -.ui-icon:not(.ui-icon-loading), .ui-icon-searchfield::after { - background: #666666; - background: rgba(0, 0, 0, .4); - color: #ffffff; - font-weight: normal; - text-shadow: none; -} -/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen - readers do not read off random characters that represent icons */ -.ui-icon-cloud-download:before { content: "\f0ed"; margin-left: 2px; } -.ui-icon-cloud-upload:before { content: "\f0ee"; margin-left: 2px; } -.ui-icon-lightbulb:before { content: "\f0eb"; margin-top: 1px; margin-left: 3px; } -.ui-icon-exchange:before { content: "\f0ec"; } -.ui-icon-bell-alt:before { content: "\f0f3"; } -.ui-icon-file-alt:before { content: "\f0f6"; } -.ui-icon-beer:before { content: "\f0fc"; margin-top: 1px; margin-left: 2px; } -.ui-icon-coffee:before { content: "\f0f4"; margin-left: 2px; } -.ui-icon-food:before { content: "\f0f5"; margin-top: 1px; margin-left: 4px; } -.ui-icon-fighter-jet:before { content: "\f0fb"; margin-top: 1px; margin-left: 2px; } -.ui-icon-user-md:before { content: "\f0f0"; } -.ui-icon-stethoscope:before { content: "\f0f1"; margin-top: 1px; margin-left: 4px; } -.ui-icon-suitcase:before { content: "\f0f2";; margin-left: 2px; } -.ui-icon-building:before { content: "\f0f7"; } -.ui-icon-hospital:before { content: "\f0f8"; margin-left: 4px; } -.ui-icon-ambulance:before { content: "\f0f9"; margin-top: 1px; margin-left: 1px; } -.ui-icon-medkit:before { content: "\f0fa"; margin-top: 0px; margin-left: 2px; } -.ui-icon-h-sign:before { content: "\f0fd"; } -.ui-icon-plus-sign-alt:before { content: "\f0fe"; } -.ui-icon-spinner:before { content: "\f110"; } -.ui-icon-angle-left:before { content: "\f104"; } -.ui-icon-angle-right:before { content: "\f105"; } -.ui-icon-angle-up:before { content: "\f106"; } -.ui-icon-angle-down:before { content: "\f107"; } -.ui-icon-double-angle-left:before { content: "\f100"; } -.ui-icon-double-angle-right:before { content: "\f101"; margin-left: 4px; } -.ui-icon-double-angle-up:before { content: "\f102"; } -.ui-icon-double-angle-down:before { content: "\f103"; margin-top: 1px; } -.ui-icon-circle-blank:before { content: "\f10c"; } -.ui-icon-circle:before { content: "\f111"; } -.ui-icon-desktop:before { content: "\f108"; margin-top: 1px; margin-left: 2px; } -.ui-icon-laptop:before { content: "\f109"; margin-top: 1px; margin-left: 2px; } -.ui-icon-tablet:before { content: "\f10a"; margin-top: 1px; } -.ui-icon-mobile-phone:before { content: "\f10b"; } -.ui-icon-quote-left:before { content: "\f10d"; } -.ui-icon-quote-right:before { content: "\f10e"; } -.ui-icon-github-alt:before { content: "\f113"; } -.ui-icon-folder-close-alt:before { content: "\f114"; } -.ui-icon-folder-open-alt:before { content: "\f115"; } - -.ui-icon-glass:before { content: "\f000"; margin-top: 2px; } -.ui-icon-music:before { content: "\f001"; margin-left: 1px; margin-top: 2px; } -.ui-icon-fasearch:before { content: "\f002"; } -.ui-icon-envelope:before { content: "\f003"; - margin-left: -1px; - margin-left: 2px; - margin-top: 1px; - } -.ui-icon-heart:before { content: "\f004"; - margin-left: 3px; - margin-top: 2px; - } -.ui-icon-fastar:before { content: "\f005"; } -.ui-icon-star-empty:before { content: "\f006"; } -.ui-icon-user:before { content: "\f007"; margin-left: 4px; } -.ui-icon-film:before { content: "\f008"; margin-left: 2px; } -.ui-icon-th-large:before { content: "\f009"; margin-left: 2px; margin-top: 2px; } -.ui-icon-th:before { content: "\f00a"; margin-left: 3px; margin-top: 2px; } -.ui-icon-th-list:before { content: "\f00b"; margin-left: 3px; margin-top: 2px; } -.ui-icon-ok:before { content: "\f00c"; margin-left: 2px; } -.ui-icon-remove:before { content: "\f00d"; margin-left: 3px; margin-top: 2px; } -.ui-icon-zoom-in:before { content: "\f00e"; } - -.ui-icon-zoom-out:before { content: "\f010"; } -.ui-icon-off:before { content: "\f011"; } -.ui-icon-signal:before { content: "\f012"; margin-left: -1px; } -.ui-icon-cog:before { content: "\f013"; margin-left: 3px; margin-top: 2px; } -.ui-icon-trash:before { content: "\f014"; } -.ui-icon-fahome:before { content: "\f015"; } -.ui-icon-file:before { content: "\f016"; } -.ui-icon-time:before { content: "\f017"; margin-top: 2px; } -.ui-icon-road:before { content: "\f018"; } -.ui-icon-download-alt:before { content: "\f019"; } -.ui-icon-download:before { content: "\f01a"; margin-top: 2px; } -.ui-icon-upload:before { content: "\f01b"; margin-top: 2px; } -.ui-icon-inbox:before { content: "\f01c"; } -.ui-icon-play-circle:before { content: "\f01d"; margin-top: 2px; } -.ui-icon-repeat:before { content: "\f01e"; margin-top: 2px; } - -/* \f020 is not a valid unicode character. all shifted one down */ -.ui-icon-farefresh:before { content: "\f021"; margin-top: 2px; } -.ui-icon-list-alt:before { content: "\f022"; margin-left: 3px; margin-top: 2px; } -.ui-icon-lock:before { content: "\f023"; } -.ui-icon-flag:before { content: "\f024"; margin-top: 2px; } -.ui-icon-headphones:before { content: "\f025"; } -.ui-icon-volume-off:before { content: "\f026"; } -.ui-icon-volume-down:before { content: "\f027"; } -.ui-icon-volume-up:before { content: "\f028"; } -.ui-icon-qrcode:before { content: "\f029"; } -.ui-icon-barcode:before { content: "\f02a"; } -.ui-icon-tag:before { content: "\f02b"; } -.ui-icon-tags:before { content: "\f02c"; } -.ui-icon-book:before { content: "\f02d"; } -.ui-icon-bookmark:before { content: "\f02e"; } -.ui-icon-print:before { content: "\f02f"; } - -.ui-icon-camera:before { content: "\f030"; } -.ui-icon-font:before { content: "\f031"; margin-left: 2px; } -.ui-icon-bold:before { content: "\f032"; margin-left: 2px; } -.ui-icon-italic:before { content: "\f033"; } -.ui-icon-text-height:before { content: "\f034"; } -.ui-icon-text-width:before { content: "\f035"; } -.ui-icon-align-left:before { content: "\f036"; } -.ui-icon-align-center:before { content: "\f037"; } -.ui-icon-align-right:before { content: "\f038"; } -.ui-icon-align-justify:before { content: "\f039"; } -.ui-icon-list:before { content: "\f03a"; } -.ui-icon-indent-left:before { content: "\f03b"; margin-left: 0px; margin-top: 2px; } -.ui-icon-indent-right:before { content: "\f03c"; } -.ui-icon-facetime-video:before { content: "\f03d"; } -.ui-icon-picture:before { content: "\f03e"; } - -.ui-icon-pencil:before { content: "\f040"; } -.ui-icon-map-marker:before { content: "\f041"; margin-left: 3px; margin-top: 2px; } -.ui-icon-adjust:before { content: "\f042"; margin-top: 2px; } -.ui-icon-tint:before { content: "\f043"; } -.ui-icon-edit:before { content: "\f044"; } -.ui-icon-share:before { content: "\f045"; } -.ui-icon-facheck:before { content: "\f046"; } -.ui-icon-move:before { content: "\f047"; } -.ui-icon-step-backward:before { content: "\f048"; } -.ui-icon-fast-backward:before { content: "\f049"; } -.ui-icon-backward:before { content: "\f04a"; } -.ui-icon-play:before { content: "\f04b"; margin-left: 6px; margin-top: 2px; } -.ui-icon-pause:before { content: "\f04c"; margin-top: 2px; } -.ui-icon-stop:before { content: "\f04d"; margin-top: 2px; } -.ui-icon-faforward:before { content: "\f04e"; } - -.ui-icon-fast-forward:before { content: "\f050"; } -.ui-icon-step-forward:before { content: "\f051"; } -.ui-icon-eject:before { content: "\f052"; } -.ui-icon-chevron-left:before { content: "\f053"; margin-top: 2px; } -.ui-icon-chevron-right:before { content: "\f054"; margin-top: 2px; } -.ui-icon-plus-sign:before { content: "\f055"; margin-top: 2px; } -.ui-icon-minus-sign:before { content: "\f056"; margin-top: 2px; } -.ui-icon-remove-sign:before { content: "\f057"; margin-top: 2px; } -.ui-icon-ok-sign:before { content: "\f058"; margin-top: 2px; } -.ui-icon-question-sign:before { content: "\f059"; margin-top: 2px; } -.ui-icon-info-sign:before { content: "\f05a"; margin-top: 2px; } -.ui-icon-screenshot:before { content: "\f05b"; } -.ui-icon-remove-circle:before { content: "\f05c"; margin-top: 2px; } -.ui-icon-ok-circle:before { content: "\f05d"; margin-top: 2px; } -.ui-icon-ban-circle:before { content: "\f05e"; margin-top: 2px; } - -.ui-icon-arrow-left:before { content: "\f060"; } -.ui-icon-arrow-right:before { content: "\f061"; } -.ui-icon-arrow-up:before { content: "\f062"; } -.ui-icon-arrow-down:before { content: "\f063"; } -.ui-icon-share-alt:before { content: "\f064"; } -.ui-icon-resize-full:before { content: "\f065"; } -.ui-icon-resize-small:before { content: "\f066"; } -.ui-icon-faplus:before { content: "\f067"; } -.ui-icon-faminus:before { content: "\f068"; } -.ui-icon-asterisk:before { content: "\f069"; margin-top: 2px; } -.ui-icon-exclamation-sign:before { content: "\f06a"; margin-top: 2px; } -.ui-icon-gift:before { content: "\f06b"; } -.ui-icon-leaf:before { content: "\f06c"; } -.ui-icon-fire:before { content: "\f06d"; } -.ui-icon-eye-open:before { content: "\f06e"; } - -.ui-icon-eye-close:before { content: "\f070"; } -.ui-icon-warning-sign:before { content: "\f071"; } -.ui-icon-plane:before { content: "\f072"; } -.ui-icon-calendar:before { content: "\f073"; } -.ui-icon-random:before { content: "\f074"; } -.ui-icon-comment:before { content: "\f075"; margin-top: 2px; } -.ui-icon-magnet:before { content: "\f076"; margin-top: 2px; } -.ui-icon-chevron-up:before { content: "\f077"; } -.ui-icon-chevron-down:before { content: "\f078"; } -.ui-icon-retweet:before { content: "\f079"; } -.ui-icon-shopping-cart:before { content: "\f07a"; } -.ui-icon-folder-close:before { content: "\f07b"; } -.ui-icon-folder-open:before { content: "\f07c"; } -.ui-icon-resize-vertical:before { content: "\f07d"; } -.ui-icon-resize-horizontal:before { content: "\f07e"; } - -.ui-icon-bar-chart:before { content: "\f080"; } -.ui-icon-twitter-sign:before { content: "\f081"; } -.ui-icon-facebook-sign:before { content: "\f082"; } -.ui-icon-camera-retro:before { content: "\f083"; } -.ui-icon-key:before { content: "\f084"; } -.ui-icon-cogs:before { content: "\f085"; } -.ui-icon-comments:before { content: "\f086"; } -.ui-icon-thumbs-up:before { content: "\f087"; } -.ui-icon-thumbs-down:before { content: "\f088"; } -.ui-icon-star-half:before { content: "\f089"; } -.ui-icon-heart-empty:before { content: "\f08a"; margin-top: 2px; } -.ui-icon-signout:before { content: "\f08b"; } -.ui-icon-linkedin-sign:before { content: "\f08c"; } -.ui-icon-pushpin:before { content: "\f08d"; } -.ui-icon-external-link:before { content: "\f08e"; } - -.ui-icon-signin:before { content: "\f090"; } -.ui-icon-trophy:before { content: "\f091"; } -.ui-icon-github-sign:before { content: "\f092"; } -.ui-icon-upload-alt:before { content: "\f093"; } -.ui-icon-lemon:before { content: "\f094"; } -.ui-icon-phone:before { content: "\f095"; } -.ui-icon-check-empty:before { content: "\f096"; } -.ui-icon-bookmark-empty:before { content: "\f097"; } -.ui-icon-phone-sign:before { content: "\f098"; } -.ui-icon-twitter:before { content: "\f099"; } -.ui-icon-facebook:before { content: "\f09a"; } -.ui-icon-github:before { content: "\f09b"; margin-top: 2px; } -.ui-icon-unlock:before { content: "\f09c"; } -.ui-icon-credit-card:before { content: "\f09d"; } -.ui-icon-rss:before { content: "\f09e"; } - -.ui-icon-hdd:before { content: "\f0a0"; } -.ui-icon-bullhorn:before { content: "\f0a1"; } -.ui-icon-bell:before { content: "\f0a2"; } -.ui-icon-certificate:before { content: "\f0a3"; margin-top: 2px; } -.ui-icon-hand-right:before { content: "\f0a4"; } -.ui-icon-hand-left:before { content: "\f0a5"; } -.ui-icon-hand-up:before { content: "\f0a6"; } -.ui-icon-hand-down:before { content: "\f0a7"; } -.ui-icon-circle-arrow-left:before { content: "\f0a8"; margin-top: 2px; } -.ui-icon-circle-arrow-right:before { content: "\f0a9"; margin-top: 2px; } -.ui-icon-circle-arrow-up:before { content: "\f0aa"; margin-top: 2px; } -.ui-icon-circle-arrow-down:before { content: "\f0ab"; margin-top: 2px; } -.ui-icon-globe:before { content: "\f0ac"; margin-top: 2px; } -.ui-icon-wrench:before { content: "\f0ad"; } -.ui-icon-tasks:before { content: "\f0ae"; } - -.ui-icon-filter:before { content: "\f0b0"; } -.ui-icon-briefcase:before { content: "\f0b1"; } -.ui-icon-fullscreen:before { content: "\f0b2"; } - -.ui-icon-group:before { content: "\f0c0"; } -.ui-icon-link:before { content: "\f0c1"; } -.ui-icon-cloud:before { content: "\f0c2"; } -.ui-icon-beaker:before { content: "\f0c3"; } -.ui-icon-cut:before { content: "\f0c4"; } -.ui-icon-copy:before { content: "\f0c5"; } -.ui-icon-paper-clip:before { content: "\f0c6"; } -.ui-icon-save:before { content: "\f0c7"; } -.ui-icon-sign-blank:before { content: "\f0c8"; } -.ui-icon-reorder:before { content: "\f0c9"; } -.ui-icon-list-ul:before { content: "\f0ca"; } -.ui-icon-list-ol:before { content: "\f0cb"; } -.ui-icon-strikethrough:before { content: "\f0cc"; } -.ui-icon-underline:before { content: "\f0cd"; } -.ui-icon-table:before { content: "\f0ce"; } - -.ui-icon-magic:before { content: "\f0d0"; } -.ui-icon-truck:before { content: "\f0d1"; } -.ui-icon-pinterest:before { content: "\f0d2"; margin-top: 2px; } -.ui-icon-pinterest-sign:before { content: "\f0d3"; margin-top: 2px; } -.ui-icon-google-plus-sign:before { content: "\f0d4"; } -.ui-icon-google-plus:before { content: "\f0d5"; } -.ui-icon-money:before { content: "\f0d6"; } -.ui-icon-caret-down:before { content: "\f0d7"; margin-top: 2px; } -.ui-icon-caret-up:before { content: "\f0d8"; } -.ui-icon-caret-left:before { content: "\f0d9"; margin-top: 2px; } -.ui-icon-caret-right:before { content: "\f0da"; margin-top: 2px; } -.ui-icon-columns:before { content: "\f0db"; } -.ui-icon-sort:before { content: "\f0dc"; margin-top: 2px; } -.ui-icon-sort-down:before { content: "\f0dd"; } -.ui-icon-sort-up:before { content: "\f0de"; } - -.ui-icon-envelope-alt:before { content: "\f0e0"; } -.ui-icon-linkedin:before { content: "\f0e1"; } -.ui-icon-undo:before { content: "\f0e2"; margin-top: 2px; } -.ui-icon-legal:before { content: "\f0e3"; } -.ui-icon-dashboard:before { content: "\f0e4"; } -.ui-icon-comment-alt:before { content: "\f0e5"; } -.ui-icon-comments-alt:before { content: "\f0e6"; } -.ui-icon-bolt:before { content: "\f0e7"; } -.ui-icon-sitemap:before { content: "\f0e8"; } -.ui-icon-umbrella:before { content: "\f0e9"; } -.ui-icon-paste:before { content: "\f0ea"; } - -.ui-icon-user-md:before { content: "\f200"; } diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/ajax-loader.gif b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/ajax-loader.gif Binary files differdeleted file mode 100644 index fd1a189c2..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/ajax-loader.gif +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/ajax-loader.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/ajax-loader.png Binary files differdeleted file mode 100644 index 13b208ddd..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/ajax-loader.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-18-black-pack.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-18-black-pack.png Binary files differdeleted file mode 100644 index 07d96586c..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-18-black-pack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-18-white-pack.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-18-white-pack.png Binary files differdeleted file mode 100644 index 0159f628f..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-18-white-pack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-36-black-pack.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-36-black-pack.png Binary files differdeleted file mode 100644 index 562e839b9..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-36-black-pack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-36-white-pack.png b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-36-white-pack.png Binary files differdeleted file mode 100644 index 81f082a4a..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/images/icons-36-white-pack.png +++ /dev/null diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/index.html b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/index.html deleted file mode 100644 index 19239a30f..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/index.html +++ /dev/null @@ -1,112 +0,0 @@ -<!-- - jQuery Mobile Icon Pack - /index.html ---> -<!doctype html> -<html> -<head> - <title> jQuery Mobile Icon Pack</title> - - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width, initial-scale=1"> - - <!-- jQuery Mobile CSS bits --> - <link rel="stylesheet" href="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.css" /> - - <!-- if you have a custom theme, add it here --> - <link rel="stylesheet" href="jqm-icon-pack-2.0-original.css" /> - - <!-- Javascript includes --> - <script src="http://code.jquery.com/jquery-1.8.2.min.js"></script> - <script src="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.js"></script> -</head> -<body> - <div data-role="page"> - - <div data-role="header"> - <a href="../index.html" data-icon="home">Back</a> - <h1>jQuery Mobile Icon Pack</h1> - </div> - - <div data-role="content"> - - <a href="https://github.com/commadelimited/jQuery-Mobile-Icon-Pack" data-theme="b" data-role="button">Download the Icon Pack</a> - - <div data-role="collapsible-set" data-theme="c" data-content-theme="c"> - - <h3>Standard Buttons</h3> - - <label> <input type="checkbox" name="checkbox-1 "/> I'm a checkbox</label> - <fieldset data-role="controlgroup"> - <legend>Choose a pet:</legend> - <input type="radio" name="radio-pet-1a" id="radio-pet-1a" value="choice-1" checked="checked" /> - <label for="radio-pet-1a">Option 1</label> - - <input type="radio" name="radio-pet-1a" id="radio-pet-2a" value="choice-2" /> - <label for="radio-pet-2a">Option 2</label> - </fieldset> - - <a href="index.html" data-role="button" data-icon="arrow-l">data-icon="arrow-l"</a> - <a href="index.html" data-role="button" data-icon="arrow-r">data-icon="arrow-r"</a> - <a href="index.html" data-role="button" data-icon="arrow-u">data-icon="arrow-u"</a> - <a href="index.html" data-role="button" data-icon="arrow-d">data-icon="arrow-d"</a> - <a href="index.html" data-role="button" data-icon="delete">data-icon="delete"</a> - <a href="index.html" data-role="button" data-icon="plus">data-icon="plus"</a> - <a href="index.html" data-role="button" data-icon="minus">data-icon="minus"</a> - <a href="index.html" data-role="button" data-icon="check">data-icon="check"</a> - <a href="index.html" data-role="button" data-icon="gear">data-icon="gear"</a> - <a href="index.html" data-role="button" data-icon="refresh">data-icon="refresh"</a> - <a href="index.html" data-role="button" data-icon="forward">data-icon="forward"</a> - <a href="index.html" data-role="button" data-icon="back">data-icon="back"</a> - <a href="index.html" data-role="button" data-icon="grid">data-icon="grid"</a> - <a href="index.html" data-role="button" data-icon="star">data-icon="star"</a> - <a href="index.html" data-role="button" data-icon="alert">data-icon="alert"</a> - <a href="index.html" data-role="button" data-icon="info">data-icon="info"</a> - <a href="index.html" data-role="button" data-icon="home">data-icon="home"</a> - <a href="index.html" data-role="button" data-icon="search">data-icon="search"</a> - - <h3>Extended Buttons</h3> - <a href="index.html" data-role="button" data-icon="email">data-icon="email"</a> - <a href="index.html" data-role="button" data-icon="page">data-icon="page"</a> - <a href="index.html" data-role="button" data-icon="question">data-icon="question"</a> - <a href="index.html" data-role="button" data-icon="foursquare">data-icon="foursquare"</a> - <a href="index.html" data-role="button" data-icon="twitter">data-icon="twitter"</a> - <a href="index.html" data-role="button" data-icon="facebook">data-icon="facebook"</a> - <a href="index.html" data-role="button" data-icon="dollar">data-icon="dollar"</a> - <a href="index.html" data-role="button" data-icon="euro">data-icon="euro"</a> - <a href="index.html" data-role="button" data-icon="pound">data-icon="pound"</a> - <a href="index.html" data-role="button" data-icon="apple">data-icon="apple"</a> - <a href="index.html" data-role="button" data-icon="chat">data-icon="chat"</a> - <a href="index.html" data-role="button" data-icon="trash">data-icon="trash"</a> - <a href="index.html" data-role="button" data-icon="bell">data-icon="bell"</a> - <a href="index.html" data-role="button" data-icon="mappin">data-icon="mappin"</a> - <a href="index.html" data-role="button" data-icon="direction">data-icon="direction"</a> - <a href="index.html" data-role="button" data-icon="heart">data-icon="heart"</a> - <a href="index.html" data-role="button" data-icon="wrench">data-icon="wrench"</a> - <a href="index.html" data-role="button" data-icon="play">data-icon="play"</a> - <a href="index.html" data-role="button" data-icon="pause">data-icon="pause"</a> - <a href="index.html" data-role="button" data-icon="stop">data-icon="stop"</a> - <a href="index.html" data-role="button" data-icon="person">data-icon="person"</a> - <a href="index.html" data-role="button" data-icon="music">data-icon="music"</a> - <a href="index.html" data-role="button" data-icon="rss">data-icon="rss"</a> - <a href="index.html" data-role="button" data-icon="wifi">data-icon="wifi"</a> - <a href="index.html" data-role="button" data-icon="phone">data-icon="phone"</a> - <a href="index.html" data-role="button" data-icon="power">data-icon="power"</a> - <a href="index.html" data-role="button" data-icon="lock">data-icon="lock"</a> - <a href="index.html" data-role="button" data-icon="flag">data-icon="flag"</a> - <a href="index.html" data-role="button" data-icon="calendar">data-icon="calendar"</a> - <a href="index.html" data-role="button" data-icon="lightning">data-icon="lightning"</a> - <a href="index.html" data-role="button" data-icon="drink">data-icon="drink"</a> - <a href="index.html" data-role="button" data-icon="android">data-icon="android"</a> - <a href="index.html" data-role="button" data-icon="edit">data-icon="edit"</a> - </div> - - </div> - - <div data-role="footer" data-theme="c"> - <p align="center">© 2013 - Andy Matthews</p> - </div> - - </div> -</body> -</html>
\ No newline at end of file diff --git a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/jqm-icon-pack-2.0-original.css b/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/jqm-icon-pack-2.0-original.css deleted file mode 100644 index 0981b9f2d..000000000 --- a/MediaBrowser.WebDashboard/Html/thirdparty/jqm-icon-pack-3.0/original/jqm-icon-pack-2.0-original.css +++ /dev/null @@ -1,128 +0,0 @@ -/* - jQuery Mobile Icon Pack - andy matthews - @commadelimited -*/ - -/* Icons ------------------------------------------------------------------------------------------------------------*/ - -.ui-icon, -.ui-icon-searchfield:after { - background: #666666; - background: rgba(0,0,0,.4); - background-image: url('images/icons-18-white-pack.png'); - background-repeat: no-repeat; - -moz-border-radius: 9px; - -webkit-border-radius: 9px; - border-radius: 9px; -} - - -/* Alt icon color ------------------------------------------------------------------------------------------------------------*/ - -.ui-icon-alt { - background: #ffffff; - background: rgba(255,255,255,.3); - background-image: url('images/icons-18-black-pack.png'); - background-repeat: no-repeat; -} - -/* restore default loading image */ -.ui-icon-loading { - background: url('images/ajax-loader.gif'); - background-size: 46px 46px; -} - -/* HD/"retina" sprite ------------------------------------------------------------------------------------------------------------*/ - -@media only screen and (-webkit-min-device-pixel-ratio: 1.3), - only screen and (-o-min-device-pixel-ratio: 3/2), - only screen and (min--moz-device-pixel-ratio: 1.3), - only screen and (min-device-pixel-ratio: 1.3), - only screen and (min-resolution: 1.3dppx) { - - .ui-icon-plus, .ui-icon-minus, .ui-icon-delete, .ui-icon-arrow-r, - .ui-icon-arrow-l, .ui-icon-arrow-u, .ui-icon-arrow-d, .ui-icon-check, - .ui-icon-gear, .ui-icon-refresh, .ui-icon-forward, .ui-icon-back, - .ui-icon-grid, .ui-icon-star, .ui-icon-alert, .ui-icon-info, .ui-icon-home, .ui-icon-search, .ui-icon-searchfield:after, - .ui-icon-checkbox-off, .ui-icon-checkbox-on, .ui-icon-radio-off, .ui-icon-radio-on, .ui-icon-email , .ui-icon-page, - .ui-icon-question , .ui-icon-foursquare , .ui-icon-twitter , .ui-icon-facebook , .ui-icon-dollar , .ui-icon-euro, - .ui-icon-pound , .ui-icon-apple , .ui-icon-chat , .ui-icon-trash , .ui-icon-bell , .ui-icon-mappin , .ui-icon-direction, - .ui-icon-heart , .ui-icon-wrench , .ui-icon-play , .ui-icon-pause , .ui-icon-stop , .ui-icon-person , .ui-icon-music, - .ui-icon-rss , .ui-icon-wifi , .ui-icon-phone , .ui-icon-power , .ui-icon-lock , .ui-icon-flag , .ui-icon-calendar, - .ui-icon-lightning , .ui-icon-drink , .ui-icon-android , .ui-icon-edit { - background-image: url('images/icons-36-white-pack.png'); - -moz-background-size: 774px 54px; - -o-background-size: 774px 54px; - -webkit-background-size: 774px 54px; - background-size: 774px 54px; - } - .ui-icon-alt { - background-image: url('images/icons-36-black-pack.png' ); - } -} - -/* first row */ -.ui-icon-plus { background-position: -0 -0; } -.ui-icon-minus { background-position: -36px -0; } -.ui-icon-delete { background-position: -72px -0; } -.ui-icon-arrow-r { background-position: -108px -0; } -.ui-icon-arrow-l { background-position: -144px -0; } -.ui-icon-arrow-u { background-position: -180px -0; } -.ui-icon-arrow-d { background-position: -216px -0; } -.ui-icon-check { background-position: -252px -0; } -.ui-icon-gear { background-position: -288px -0; } -.ui-icon-refresh { background-position: -324px -0; } -.ui-icon-forward { background-position: -360px -0; } -.ui-icon-back { background-position: -396px -0; } -.ui-icon-grid { background-position: -432px -0; } -.ui-icon-star { background-position: -468px -0; } -.ui-icon-alert { background-position: -504px -0; } -.ui-icon-info { background-position: -540px -0; } -.ui-icon-home { background-position: -576px -0; } -.ui-icon-search,.ui-icon-searchfield:after { background-position: -612px -0; } -.ui-icon-checkbox-off { background-position: -684px -0; } -.ui-icon-checkbox-on { background-position: -648px -0; } -.ui-icon-radio-off { background-position: -756px -0; } -.ui-icon-radio-on { background-position: -718px -0; } - -/* begin icon pack definitions */ -/* second row */ -.ui-icon-email { background-position: -0 -18px; } -.ui-icon-page { background-position: -36px -18px; } -.ui-icon-question { background-position: -72px -18px; } -.ui-icon-foursquare { background-position: -108px -18px; } -.ui-icon-twitter { background-position: -144px -18px; } -.ui-icon-facebook { background-position: -180px -18px; } -.ui-icon-dollar { background-position: -216px -18px; } -.ui-icon-euro { background-position: -252px -18px; } -.ui-icon-pound { background-position: -288px -18px; } -.ui-icon-apple { background-position: -324px -18px; } -.ui-icon-chat { background-position: -360px -18px; } -.ui-icon-trash { background-position: -396px -18px; } -.ui-icon-bell { background-position: -432px -18px; } -.ui-icon-mappin { background-position: -468px -18px;} -.ui-icon-direction { background-position: -504px -18px; } -.ui-icon-heart { background-position: -540px -18px; } -.ui-icon-wrench { background-position: -576px -18px; } -.ui-icon-play { background-position: -612px -18px; } -.ui-icon-pause { background-position: -648px -18px; } -.ui-icon-stop { background-position: -684px -18px; } -.ui-icon-person { background-position: -720px -18px; } -.ui-icon-music { background-position: -756px -18px; } - -/* third row */ -.ui-icon-rss { background-position: -0 -36px; } -.ui-icon-wifi { background-position: -36px -36px; } -.ui-icon-phone { background-position: -72px -36px; } -.ui-icon-power { background-position: -108px -36px; } -.ui-icon-lock { background-position: -144px -36px; } -.ui-icon-flag { background-position: -180px -36px; } -.ui-icon-calendar { background-position: -216px -36px; } -.ui-icon-lightning { background-position: -252px -36px; } -.ui-icon-drink { background-position: -288px -36px; } -.ui-icon-android { background-position: -324px -36px; } -.ui-icon-edit { background-position: -360px -36px; } diff --git a/MediaBrowser.WebDashboard/Html/uiSettings.html b/MediaBrowser.WebDashboard/Html/uiSettings.html deleted file mode 100644 index 40f65fd6c..000000000 --- a/MediaBrowser.WebDashboard/Html/uiSettings.html +++ /dev/null @@ -1,65 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Display Settings</title> -</head> -<body> - <div id="displaySettingsPage" data-role="page" class="page type-interior"> - - <div data-role="content"> - <div class="content-primary"> - <form id="displaySettingsForm"> - - <ul data-role="listview" class="ulForm"> - <li> - <label for="txtWeatherLocation">Weather location: </label> - <input id="txtWeatherLocation" name="txtWeatherLocation" type="text" onchange="DisplaySettingsPage.submit();" /> - <div class="fieldDescription"> - US zip code / City, State, Country / City, Country - </div> - </li> - <li> - <label for="selectWeatherUnit">Weather display unit: </label> - <select id="selectWeatherUnit" name="selectWeatherUnit" onchange="DisplaySettingsPage.submit();"> - <option value="Celsius">Celsius</option> - <option value="Fahrenheit">Fahrenheit</option> - </select> - </li> - <li> - <label for="txtMinResumePct">Min resume percentage: </label> - <input type="number" id="txtMinResumePct" name="txtMinResumePct" pattern="[0-9]*" required="required" min="0" max="100" onchange="DisplaySettingsPage.submit();" /> - <div class="fieldDescription"> - Titles are assumed unplayed before this time - </div> - </li> - <li> - <label for="txtMaxResumePct">Max resume percentage: </label> - <input type="number" id="txtMaxResumePct" name="txtMaxResumePct" pattern="[0-9]*" required="required" min="1" max="100" onchange="DisplaySettingsPage.submit();" /> - <div class="fieldDescription"> - Titles are assumed fully played after this time - </div> - </li> - <li> - <label for="txtMinResumeDuration">Min resume duration (seconds): </label> - <input type="number" id="txtMinResumeDuration" name="txtMinResumeDuration" pattern="[0-9]*" required="required" min="0" onchange="DisplaySettingsPage.submit();" /> - <div class="fieldDescription"> - Titles shorter than this will not be resumable - </div> - </li> - <li style="display: none;"> - <button type="submit" data-theme="b" data-icon="ok" class="btnSubmit"> - Save - </button> - </li> - </ul> - - </form> - </div> - </div> - - <script type="text/javascript"> - $('#displaySettingsForm').on('submit', DisplaySettingsPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/updatePassword.html b/MediaBrowser.WebDashboard/Html/updatePassword.html deleted file mode 100644 index b07bd1691..000000000 --- a/MediaBrowser.WebDashboard/Html/updatePassword.html +++ /dev/null @@ -1,53 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title></title> -</head> -<body> - <div id="updatePasswordPage" data-role="page" class="page type-interior userProfilesConfigurationPage"> - - <div data-role="content"> - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="#" onclick="Dashboard.navigate('editUser.html', true);" data-role="button">Profile</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('userImage.html', true);">Image</a> - <a href="#" data-role="button" class="ui-btn-active">Password</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('library.html', true);">Media Library</a> - </div> - <form id="updatePasswordForm"> - <ul data-role="listview" class="ulForm"> - <li> - <label for="txtCurrentPassword">Current password: </label> - <input type="password" id="txtCurrentPassword" name="txtCurrentPassword" /> - </li> - <li> - <label for="txtNewPassword">New password: </label> - <input type="password" id="txtNewPassword" name="txtNewPassword" /> - <div class="fieldDescription"> - Numeric pin codes are recommended for quicker entry with a remote. - </div> - </li> - <li> - <label for="txtNewPasswordConfirm">New password confirm: </label> - <input type="password" id="txtNewPasswordConfirm" name="txtNewPasswordConfirm" /> - </li> - <li> - <button type="submit" data-theme="b" data-icon="ok"> - Save - </button> - <div id="btnResetPassword" style="display: none;"> - <button type="button" data-theme="a" data-icon="lock" onclick="UpdatePasswordPage.resetPassword();"> - Reset Password - </button> - </div> - </li> - </ul> - </form> - </div> - </div> - <script type="text/javascript"> - $('#updatePasswordForm').on('submit', UpdatePasswordPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/userImage.html b/MediaBrowser.WebDashboard/Html/userImage.html deleted file mode 100644 index c28d2129e..000000000 --- a/MediaBrowser.WebDashboard/Html/userImage.html +++ /dev/null @@ -1,53 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title> </title> -</head> -<body> - <div id="userImagePage" data-role="page" class="page type-interior userProfilesConfigurationPage"> - - <div data-role="content"> - <div class="content-primary"> - <div data-role="controlgroup" data-type="horizontal" class="localnav" data-mini="true"> - <a href="#" onclick="Dashboard.navigate('editUser.html', true);" data-role="button">Profile</a> - <a href="#" data-role="button" class="ui-btn-active">Image</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('updatePassword.html', true);">Password</a> - <a href="#" data-role="button" onclick="Dashboard.navigate('library.html', true);">Media Library</a> - </div> - <div class="readOnlyContent"> - <p id="fldImage"></p> - <p id="fldDeleteImage" style="display: none;"> - <button id="btnDeleteImage" type="button" data-icon="delete" onclick="UserImagePage.deleteImage();"> - Delete Image - </button> - </p> - </div> - - <h2 id="headerUploadNewImage" style="display: none;">Upload New Image</h2> - <form id="uploadUserImageForm"> - <ul data-role="listview" class="ulForm"> - <li id="fldNewImage"> - <p>1:1 Aspect Ratio Recommended</p> - <input type="file" accept="image/*" id="uploadUserImage" name="uploadUserImage" onchange="UserImagePage.onFileUploadChange(this);" /> - - <div id="userImageDropZone" class="imageDropZone"> - <h3>Drop Image Here (Chrome / Firefox / Safari)</h3> - <output id="userImageOutput"></output> - </div> - - </li> - <li id="fldNewImagePreview"></li> - <li id="fldUpload" style="display: none;"> - <button type="submit" data-icon="picture">Upload</button> - </li> - </ul> - </form> - - </div> - </div> - <script type="text/javascript"> - $('#uploadUserImageForm').on('submit', UserImagePage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/userProfiles.html b/MediaBrowser.WebDashboard/Html/userProfiles.html deleted file mode 100644 index d94cfd7cb..000000000 --- a/MediaBrowser.WebDashboard/Html/userProfiles.html +++ /dev/null @@ -1,24 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>User Profiles</title> -</head> -<body> - <div id="userProfilesPage" data-role="page" class="page type-interior userProfilesConfigurationPage"> - - <div data-role="content"> - <div class="content-primary"> - <div class="readOnlyContent"> - <p id="pAddUser"> - <button type="button" data-icon="plus" onclick="Dashboard.navigate('editUser.html');"> - Add User - </button> - </p> - - <ul id="ulUserProfiles" data-role="listview" data-inset="true" data-auto-enhanced="false" data-split-icon="minus"></ul> - </div> - </div> - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/wizardFinish.html b/MediaBrowser.WebDashboard/Html/wizardFinish.html deleted file mode 100644 index 3d51aa0bf..000000000 --- a/MediaBrowser.WebDashboard/Html/wizardFinish.html +++ /dev/null @@ -1,26 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Media Browser</title> -</head> -<body> - <div id="wizardFinishPage" data-role="page" class="page standalonePage wizardPage"> - - <div data-role="content"> - - <div class="ui-corner-all ui-shadow wizardContent"> - <h2> - <img src="css/images/checkmarkblack.png" />You're Done!</h2> - - <p>That's all we need for now. Media Browser has begun collecting information about your media library. You do not need to wait for this process to complete before using a client application or changing other settings within the Dashboard.</p> - - <div class="wizardNavigation"> - <button type="button" data-iconpos="left" data-icon="arrow-left" data-inline="true" onclick="history.back();">Previous</button> - <button type="button" data-iconpos="right" data-icon="wrench" data-inline="true" onclick="WizardFinishPage.onFinish();" data-theme="b">Go to the Dashboard</button> - </div> - </div> - - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/wizardLibrary.html b/MediaBrowser.WebDashboard/Html/wizardLibrary.html deleted file mode 100644 index 8d34287e9..000000000 --- a/MediaBrowser.WebDashboard/Html/wizardLibrary.html +++ /dev/null @@ -1,60 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Media Browser</title> -</head> -<body> - <div id="wizardLibraryPage" data-role="page" class="page standalonePage wizardPage mediaLibraryPage"> - - <div data-role="content"> - - <div class="ui-corner-all ui-shadow wizardContent"> - <h2> - <img src="css/images/movieFolder.png" />Media Library</h2> - - <p id="fldUseDefaultLibrary" style="display: none;"> - <input type="checkbox" id="chkUseDefaultLibrary" name="chkUseDefaultLibrary" onchange="MediaLibraryPage.setUseDefaultMediaLibrary(this.checked);" /> - <label for="chkUseDefaultLibrary">Use default media library</label> - </p> - <div id="divMediaLibrary"> - <p>Below are your media collections. Expand a collection to add or remove media locations assigned to it.</p> - <p> - <button type="button" data-icon="plus" onclick="MediaLibraryPage.addVirtualFolder();">Add media collection</button> - </p> - <div id="divVirtualFolders"></div> - </div> - - <div data-role="popup" id="popupEnterText" class="ui-corner-all popup"> - - <div class="ui-corner-top ui-bar-a" style="text-align: center; padding: 0 20px;"> - <h3>Rename</h3> - </div> - - <div data-role="content" class="ui-corner-bottom ui-content"> - <form id="textEntryForm"> - <label for="txtValue">New name:</label> - <input type="text" name="txtValue" id="txtValue" required="required" /> - - <p> - <button type="submit" data-theme="b" data-icon="ok"> - Ok - </button> - <button type="button" data-icon="delete" onclick="$(this).parents('.popup').popup('close');"> - Cancel - </button> - </p> - </form> - </div> - - </div> - - <div class="wizardNavigation"> - <button type="button" data-iconpos="left" data-icon="arrow-left" data-inline="true" onclick="history.back();">Previous</button> - <button type="button" data-iconpos="right" data-icon="arrow-right" data-inline="true" onclick="Dashboard.navigate('wizardFinish.html');">Next</button> - </div> - </div> - - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/wizardStart.html b/MediaBrowser.WebDashboard/Html/wizardStart.html deleted file mode 100644 index 7b4edcb8f..000000000 --- a/MediaBrowser.WebDashboard/Html/wizardStart.html +++ /dev/null @@ -1,24 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Media Browser</title> -</head> -<body> - <div id="wizardStartPage" data-role="page" class="page standalonePage wizardPage"> - - <div data-role="content"> - - <div class="ui-corner-all ui-shadow wizardContent"> - <h2> - <img src="css/images/cloudNetwork.png" />Welcome to Media Browser Server!</h2> - - <p>This wizard will help guide you through the setup process.</p> - <div class="wizardNavigation"> - <button type="button" data-iconpos="right" data-icon="arrow-right" data-inline="true" onclick="WizardStartPage.gotoNextPage();">Next</button> - </div> - </div> - - </div> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/Html/wizardUser.html b/MediaBrowser.WebDashboard/Html/wizardUser.html deleted file mode 100644 index db49bcb6f..000000000 --- a/MediaBrowser.WebDashboard/Html/wizardUser.html +++ /dev/null @@ -1,42 +0,0 @@ -<!DOCTYPE html> -<html> -<head> - <title>Media Browser</title> -</head> -<body> - <div id="wizardUserPage" data-role="page" class="page standalonePage wizardPage"> - - <div data-role="content"> - - <div class="ui-corner-all ui-shadow wizardContent"> - <form id="wizardUserForm"> - <h2> - <img src="css/images/currentUserDefaultBlack.png" style="height: 30px;" />Tell Us About Yourself</h2> - - <p>Media Browser includes built-in support for user profiles, enabling each user to have their own display settings, playstate and ratings.</p> - - <ul data-role="listview" class="ulForm"> - <li> - <label for="txtUsername">Your first name: </label> - <input type="text" id="txtUsername" name="txtUsername" required="required" /> - <div class="fieldDescription"> - More users can be added later within the Dashboard. - </div> - </li> - </ul> - - <div class="wizardNavigation"> - <button type="button" data-iconpos="left" data-icon="arrow-left" data-inline="true" onclick="history.back();">Previous</button> - <button type="submit" data-iconpos="right" data-icon="arrow-right" data-inline="true">Next</button> - </div> - </form> - </div> - - </div> - - <script type="text/javascript"> - $('#wizardUserForm').on('submit', WizardUserPage.onSubmit); - </script> - </div> -</body> -</html> diff --git a/MediaBrowser.WebDashboard/MediaBrowser.WebDashboard.csproj b/MediaBrowser.WebDashboard/MediaBrowser.WebDashboard.csproj index eac4a3e8f..0620c944f 100644 --- a/MediaBrowser.WebDashboard/MediaBrowser.WebDashboard.csproj +++ b/MediaBrowser.WebDashboard/MediaBrowser.WebDashboard.csproj @@ -107,308 +107,579 @@ </ProjectReference>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\index.html" />
+ <Content Include="dashboard-ui\index.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\advanced.html" />
+ <Content Include="dashboard-ui\advanced.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\dashboard.html" />
+ <Content Include="dashboard-ui\dashboard.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\Site.js" />
+ <Content Include="dashboard-ui\scripts\Site.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\site.css" />
+ <Content Include="dashboard-ui\css\site.css">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\library.html" />
+ <Content Include="dashboard-ui\library.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\metadata.html" />
+ <Content Include="dashboard-ui\metadata.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\userProfiles.html" />
+ <Content Include="dashboard-ui\userProfiles.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\plugins.html" />
+ <Content Include="dashboard-ui\plugins.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\login.html" />
+ <Content Include="dashboard-ui\login.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\logindefault.png" />
+ <Content Include="dashboard-ui\css\images\logindefault.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\uiSettings.html" />
+ <Content Include="dashboard-ui\uiSettings.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\editUser.html" />
+ <Content Include="dashboard-ui\editUser.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\favicon.ico" />
+ <Content Include="dashboard-ui\favicon.ico">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\touchicon.png" />
- <EmbeddedResource Include="Html\css\images\touchicon114.png" />
- <EmbeddedResource Include="Html\css\images\touchicon72.png" />
+ <Content Include="dashboard-ui\css\images\touchicon.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\touchicon114.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\touchicon72.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\iossplash.png" />
+ <Content Include="dashboard-ui\css\images\iossplash.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\updatePassword.html" />
+ <Content Include="dashboard-ui\updatePassword.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\userImage.html" />
+ <Content Include="dashboard-ui\userImage.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\IndexPage.js" />
+ <Content Include="dashboard-ui\scripts\IndexPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\defaultCollectionImage.png" />
+ <Content Include="dashboard-ui\css\images\defaultCollectionImage.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\toolsWhite.png" />
+ <Content Include="dashboard-ui\css\images\toolsWhite.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\currentUserDefaultWhite.png" />
+ <Content Include="dashboard-ui\css\images\currentUserDefaultWhite.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\rightArrow.png" />
+ <Content Include="dashboard-ui\css\images\rightArrow.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\userFlyoutDefault.png" />
+ <Content Include="dashboard-ui\css\images\userFlyoutDefault.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\MediaLibraryPage.js" />
+ <Content Include="dashboard-ui\scripts\MediaLibraryPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\DisplaySettingsPage.js" />
+ <Content Include="dashboard-ui\scripts\DisplaySettingsPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\PluginsPage.js" />
+ <Content Include="dashboard-ui\scripts\PluginsPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\MetadataConfigurationPage.js" />
+ <Content Include="dashboard-ui\scripts\MetadataConfigurationPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\LoginPage.js" />
+ <Content Include="dashboard-ui\scripts\LoginPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\UpdatePasswordPage.js" />
+ <Content Include="dashboard-ui\scripts\UpdatePasswordPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\AdvancedConfigurationPage.js" />
- <EmbeddedResource Include="Html\scripts\EditUserPage.js" />
- <EmbeddedResource Include="Html\scripts\UserImagePage.js" />
- <EmbeddedResource Include="Html\scripts\UserProfilesPage.js" />
+ <Content Include="dashboard-ui\scripts\AdvancedConfigurationPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\EditUserPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\UserImagePage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\UserProfilesPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\advancedMetadata.html" />
+ <Content Include="dashboard-ui\advancedMetadata.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\AdvancedMetadataConfigurationPage.js" />
+ <Content Include="dashboard-ui\scripts\AdvancedMetadataConfigurationPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\pluginUpdates.html" />
+ <Content Include="dashboard-ui\pluginUpdates.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\PluginUpdatesPage.js" />
+ <Content Include="dashboard-ui\scripts\PluginUpdatesPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\addPlugin.html" />
- <EmbeddedResource Include="Html\scripts\AddPluginPage.js" />
+ <Content Include="dashboard-ui\addPlugin.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\AddPluginPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\bg.png" />
+ <Content Include="dashboard-ui\css\images\bg.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\pluginCatalog.html" />
- <EmbeddedResource Include="Html\scripts\PluginCatalogPage.js" />
+ <Content Include="dashboard-ui\pluginCatalog.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\PluginCatalogPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\leftArrowBlack.png" />
+ <Content Include="dashboard-ui\css\images\leftArrowBlack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\leftArrowWhite.png" />
+ <Content Include="dashboard-ui\css\images\leftArrowWhite.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\currentUserDefaultBlack.png" />
- <EmbeddedResource Include="Html\css\images\toolsBlack.png" />
+ <Content Include="dashboard-ui\css\images\currentUserDefaultBlack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\toolsBlack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scheduledTasks.html" />
+ <Content Include="dashboard-ui\scheduledTasks.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\ScheduledTasksPage.js" />
+ <Content Include="dashboard-ui\scripts\ScheduledTasksPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scheduledTask.html" />
- <EmbeddedResource Include="Html\scripts\ScheduledTaskPage.js" />
+ <Content Include="dashboard-ui\scheduledTask.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\ScheduledTaskPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\wizardStart.html" />
+ <Content Include="dashboard-ui\wizardStart.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\wizardFinish.html" />
+ <Content Include="dashboard-ui\wizardFinish.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\wizardUser.html" />
- <EmbeddedResource Include="Html\wizardLibrary.html" />
+ <Content Include="dashboard-ui\wizardUser.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\wizardLibrary.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\WizardStartPage.js" />
+ <Content Include="dashboard-ui\scripts\WizardStartPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\WizardUserPage.js" />
+ <Content Include="dashboard-ui\scripts\WizardUserPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\cloudNetwork.png" />
+ <Content Include="dashboard-ui\css\images\cloudNetwork.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\movieFolder.png" />
+ <Content Include="dashboard-ui\css\images\movieFolder.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\checkmarkblack.png" />
+ <Content Include="dashboard-ui\css\images\checkmarkblack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\log.html" />
+ <Content Include="dashboard-ui\log.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\LogPage.js" />
+ <Content Include="dashboard-ui\scripts\LogPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\metadataImages.html" />
+ <Content Include="dashboard-ui\metadataImages.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\MetadataImagesPage.js" />
+ <Content Include="dashboard-ui\scripts\MetadataImagesPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\DashboardPage.js" />
+ <Content Include="dashboard-ui\scripts\DashboardPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\checkMarkGreen.png" />
+ <Content Include="dashboard-ui\css\images\checkMarkGreen.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\clients\html5.png" />
+ <Content Include="dashboard-ui\css\images\clients\html5.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\clients\android.png" />
- <EmbeddedResource Include="Html\css\images\clients\ios.png" />
+ <Content Include="dashboard-ui\css\images\clients\android.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\clients\ios.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\clients\mb.png" />
+ <Content Include="dashboard-ui\css\images\clients\mb.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\clients\windowsrt.png" />
+ <Content Include="dashboard-ui\css\images\clients\windowsrt.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\clients\windowsphone.png" />
- <EmbeddedResource Include="Html\css\images\clients\win8.png" />
+ <Content Include="dashboard-ui\css\images\clients\windowsphone.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\clients\win8.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\notifications\download.png" />
+ <Content Include="dashboard-ui\css\images\notifications\download.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\Extensions.js" />
+ <Content Include="dashboard-ui\scripts\Extensions.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\support.html" />
+ <Content Include="dashboard-ui\support.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\SupporterPage.js" />
+ <Content Include="dashboard-ui\scripts\SupporterPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\supporter.html" />
+ <Content Include="dashboard-ui\supporter.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\suppbadge.png" />
+ <Content Include="dashboard-ui\css\images\suppbadge.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\premiumflag.png" />
+ <Content Include="dashboard-ui\css\images\premiumflag.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\supporterKey.html" />
+ <Content Include="dashboard-ui\supporterKey.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\scripts\SupporterKeyPage.js" />
+ <Content Include="dashboard-ui\scripts\SupporterKeyPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\css\images\donatepp.png" />
+ <Content Include="dashboard-ui\css\images\donatepp.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\faicons-v2.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\faicons.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\images\ajax-loader.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\images\icons-18-black-pack.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\images\icons-18-white-pack.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\images\icons-36-black-pack.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\images\icons-36-white-pack.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\index.html" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\jqm-icon-pack-3.0.0-fa.css" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\original\images\ajax-loader.gif" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\original\images\ajax-loader.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\original\images\icons-18-black-pack.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\original\images\icons-18-white-pack.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\original\images\icons-36-black-pack.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\original\images\icons-36-white-pack.png" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\original\index.html" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\original\jqm-icon-pack-2.0-original.css" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\font\fontawesome-webfont.eot" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\font\fontawesome-webfont.ttf" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\font\fontawesome-webfont.woff" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\font\FontAwesome.otf" />
- <EmbeddedResource Include="Html\thirdparty\jqm-icon-pack-3.0\font-awesome\jqm-icon-pack-3.0.0-fa.scss" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\css\images\registerpp.png" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\css\images\home.png" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\css\images\notifications\done.png" />
- <EmbeddedResource Include="Html\css\images\notifications\error.png" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\css\images\notifications\cancelled.png" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\css\images\notifications\info.png" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\itemDetails.html" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\scripts\ItemDetailPage.js" />
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="Html\scripts\AboutPage.js" />
- <EmbeddedResource Include="Html\css\images\supporterflag.png" />
- <EmbeddedResource Include="Html\scripts\ItemListPage.js" />
- <EmbeddedResource Include="Html\itemList.html" />
- <EmbeddedResource Include="Html\scripts\WizardFinishPage.js" />
- <EmbeddedResource Include="Html\Readme.txt" />
- <EmbeddedResource Include="Html\css\images\media\playCircle.png" />
- <EmbeddedResource Include="Html\css\images\media\nextTrack.png" />
- <EmbeddedResource Include="Html\css\images\media\pause.png" />
- <EmbeddedResource Include="Html\css\images\media\play.png" />
- <EmbeddedResource Include="Html\css\images\media\previousTrack.png" />
- <EmbeddedResource Include="Html\css\images\media\stop.png" />
- <EmbeddedResource Include="Html\css\images\itemDetails\videoDefault.png" />
- <EmbeddedResource Include="Html\css\images\itemDetails\audioDefault.png" />
- <EmbeddedResource Include="Html\css\images\itemDetails\gameDefault.png" />
- <EmbeddedResource Include="Html\css\images\mblogoicon.png" />
- <EmbeddedResource Include="Html\css\images\mblogotextblack.png" />
- <EmbeddedResource Include="Html\css\images\mblogotextwhite.png" />
- <EmbeddedResource Include="Html\css\images\clients\dlna.png" />
- <EmbeddedResource Include="Html\about.html" />
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\faicons-v2.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\faicons.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\images\ajax-loader.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\images\icons-18-black-pack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\images\icons-18-white-pack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\images\icons-36-black-pack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\images\icons-36-white-pack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\index.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\jqm-icon-pack-3.0.0-fa.css">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\original\images\ajax-loader.gif">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\original\images\ajax-loader.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\original\images\icons-18-black-pack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\original\images\icons-18-white-pack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\original\images\icons-36-black-pack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\original\images\icons-36-white-pack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\original\index.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\original\jqm-icon-pack-2.0-original.css">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\font\fontawesome-webfont.eot">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\font\fontawesome-webfont.ttf">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\font\fontawesome-webfont.woff">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\font\FontAwesome.otf">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\thirdparty\jqm-icon-pack-3.0\font-awesome\jqm-icon-pack-3.0.0-fa.scss">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\css\images\registerpp.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\css\images\home.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\css\images\notifications\done.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\notifications\error.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\css\images\notifications\cancelled.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\css\images\notifications\info.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\itemDetails.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\scripts\ItemDetailPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ </ItemGroup>
+ <ItemGroup>
+ <Content Include="dashboard-ui\scripts\AboutPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\supporterflag.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\ItemListPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\itemList.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\WizardFinishPage.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\media\playCircle.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\media\nextTrack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\media\pause.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\media\play.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\media\previousTrack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\media\stop.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\itemDetails\videoDefault.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\itemDetails\audioDefault.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\itemDetails\gameDefault.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\mblogoicon.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\mblogotextblack.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\mblogotextwhite.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\css\images\clients\dlna.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\about.html">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
<EmbeddedResource Include="ApiClient.js" />
- <Content Include="Html\css\images\stars.png" />
- <EmbeddedResource Include="Html\scripts\MediaPlayer.js" />
+ <Content Include="dashboard-ui\css\images\stars.png">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
+ <Content Include="dashboard-ui\scripts\MediaPlayer.js">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </Content>
</ItemGroup>
<ItemGroup>
<None Include="packages.config" />
diff --git a/Nuget/MediaBrowser.Common.Internal.nuspec b/Nuget/MediaBrowser.Common.Internal.nuspec index dd6b78dc3..267fee358 100644 --- a/Nuget/MediaBrowser.Common.Internal.nuspec +++ b/Nuget/MediaBrowser.Common.Internal.nuspec @@ -2,7 +2,7 @@ <package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd"> <metadata> <id>MediaBrowser.Common.Internal</id> - <version>3.0.52</version> + <version>3.0.56</version> <title>MediaBrowser.Common.Internal</title> <authors>Luke</authors> <owners>ebr,Luke,scottisafool</owners> @@ -12,7 +12,7 @@ <description>Contains common components shared by Media Browser Theatre and Media Browser Server. Not intended for plugin developer consumption.</description> <copyright>Copyright © Media Browser 2013</copyright> <dependencies> - <dependency id="MediaBrowser.Common" version="3.0.52" /> + <dependency id="MediaBrowser.Common" version="3.0.56" /> <dependency id="NLog" version="2.0.0.2000" /> <dependency id="ServiceStack.Text" version="3.9.38" /> <dependency id="protobuf-net" version="2.0.0.621" /> diff --git a/Nuget/MediaBrowser.Common.nuspec b/Nuget/MediaBrowser.Common.nuspec index c6207b81d..c3454e397 100644 --- a/Nuget/MediaBrowser.Common.nuspec +++ b/Nuget/MediaBrowser.Common.nuspec @@ -2,7 +2,7 @@ <package xmlns="http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd"> <metadata> <id>MediaBrowser.Common</id> - <version>3.0.52</version> + <version>3.0.56</version> <title>MediaBrowser.Common</title> <authors>Media Browser Team</authors> <owners>ebr,Luke,scottisafool</owners> diff --git a/Nuget/MediaBrowser.Server.Core.nuspec b/Nuget/MediaBrowser.Server.Core.nuspec index 5e774821f..c94c192b8 100644 --- a/Nuget/MediaBrowser.Server.Core.nuspec +++ b/Nuget/MediaBrowser.Server.Core.nuspec @@ -2,7 +2,7 @@ <package xmlns="http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd"> <metadata> <id>MediaBrowser.Server.Core</id> - <version>3.0.52</version> + <version>3.0.56</version> <title>Media Browser.Server.Core</title> <authors>Media Browser Team</authors> <owners>ebr,Luke,scottisafool</owners> @@ -12,7 +12,7 @@ <description>Contains core components required to build plugins for Media Browser Server.</description> <copyright>Copyright © Media Browser 2013</copyright> <dependencies> - <dependency id="MediaBrowser.Common" version="3.0.52" /> + <dependency id="MediaBrowser.Common" version="3.0.56" /> </dependencies> </metadata> <files> |
