diff --git a/src/Ombi.Core/Engine/Interfaces/IMovieEngine.cs b/src/Ombi.Core/Engine/Interfaces/IMovieEngine.cs index 75b448372..67768bd2c 100644 --- a/src/Ombi.Core/Engine/Interfaces/IMovieEngine.cs +++ b/src/Ombi.Core/Engine/Interfaces/IMovieEngine.cs @@ -17,5 +17,6 @@ namespace Ombi.Core Task> UpcomingMovies(); Task> LookupImdbInformation(IEnumerable movies); + Task LookupImdbInformation(int theMovieDbId); } } \ No newline at end of file diff --git a/src/Ombi.Core/Engine/MovieSearchEngine.cs b/src/Ombi.Core/Engine/MovieSearchEngine.cs index 9f5e1eb43..e94ec8e8e 100644 --- a/src/Ombi.Core/Engine/MovieSearchEngine.cs +++ b/src/Ombi.Core/Engine/MovieSearchEngine.cs @@ -13,6 +13,7 @@ using System.Collections.Generic; using System.Linq; using System.Security.Principal; using System.Threading.Tasks; +using StackExchange.Profiling; namespace Ombi.Core.Engine { @@ -63,17 +64,41 @@ namespace Ombi.Core.Engine return retVal; } + public async Task LookupImdbInformation(int theMovieDbId) + { + var dbMovies = await GetMovieRequests(); + + var plexSettings = await PlexSettings.GetSettingsAsync(); + var embySettings = await EmbySettings.GetSettingsAsync(); + + var movieInfo = await MovieApi.GetMovieInformationWithVideo(theMovieDbId); + var viewMovie = Mapper.Map(movieInfo); + + return await ProcessSingleMovie(viewMovie, dbMovies, plexSettings, embySettings, true); + } + public async Task> Search(string search) { - var result = await MovieApi.SearchMovie(search); - if (result != null) + using (MiniProfiler.Current.Step("Starting Movie Search Engine")) + using (MiniProfiler.Current.Step("Searching Movie")) { - Logger.LogDebug("Search Result: {result}", result); - return await TransformMovieResultsToResponse(result); + var result = await MovieApi.SearchMovie(search); + + using (MiniProfiler.Current.Step("Fin API, Transforming")) + { + if (result != null) + { + Logger.LogDebug("Search Result: {result}", result); + return await TransformMovieResultsToResponse(result); + } + } + + + return null; } - return null; } + public async Task> PopularMovies() { var result = await MovieApi.PopularMovies(); @@ -121,28 +146,41 @@ namespace Ombi.Core.Engine private async Task> TransformMovieResultsToResponse( IEnumerable movies) { - var viewMovies = new List(); - var dbMovies = await GetMovieRequests(); - var plexSettings = await PlexSettings.GetSettingsAsync(); - var embySettings = await EmbySettings.GetSettingsAsync(); + var viewMovies = new List(); + Dictionary dbMovies; + Settings.Models.External.PlexSettings plexSettings; + Settings.Models.External.EmbySettings embySettings; + using (MiniProfiler.Current.Step("Gettings Movies and Settings")) + { + dbMovies = await GetMovieRequests(); + + plexSettings = await PlexSettings.GetSettingsAsync(); + embySettings = await EmbySettings.GetSettingsAsync(); + } foreach (var movie in movies) + { viewMovies.Add(await ProcessSingleMovie(movie, dbMovies, plexSettings, embySettings)); + } return viewMovies; } private async Task ProcessSingleMovie(SearchMovieViewModel viewMovie, - Dictionary existingRequests, PlexSettings plexSettings, EmbySettings embySettings) + Dictionary existingRequests, PlexSettings plexSettings, EmbySettings embySettings, bool lookupExtraInfo = false) { - var showInfo = await MovieApi.GetMovieInformation(viewMovie.Id); - viewMovie.Id = showInfo.Id; // TheMovieDbId + if (plexSettings.Enable) { - var item = await PlexContentRepo.Get(showInfo.ImdbId); - if (item != null) + if (lookupExtraInfo) { - viewMovie.Available = true; - viewMovie.PlexUrl = item.Url; + var showInfo = await MovieApi.GetMovieInformation(viewMovie.Id); + viewMovie.Id = showInfo.Id; // TheMovieDbId + var item = await PlexContentRepo.Get(showInfo.ImdbId); + if (item != null) + { + viewMovie.Available = true; + viewMovie.PlexUrl = item.Url; + } } // var content = PlexContentRepository.GetAll(); @@ -180,10 +218,11 @@ namespace Ombi.Core.Engine } RunSearchRules(viewMovie); - + return viewMovie; } + private async Task ProcessSingleMovie(MovieSearchResult movie, Dictionary existingRequests, PlexSettings plexSettings, EmbySettings embySettings) { diff --git a/src/Ombi.Core/Ombi.Core.csproj b/src/Ombi.Core/Ombi.Core.csproj index 4fe9a1753..5748422d0 100644 --- a/src/Ombi.Core/Ombi.Core.csproj +++ b/src/Ombi.Core/Ombi.Core.csproj @@ -12,6 +12,7 @@ + diff --git a/src/Ombi.Notification.Discord/Class1.cs b/src/Ombi.Notification.Agents/DiscordNotification.cs similarity index 100% rename from src/Ombi.Notification.Discord/Class1.cs rename to src/Ombi.Notification.Agents/DiscordNotification.cs diff --git a/src/Ombi.Notification.Agents/EmailNotification.cs b/src/Ombi.Notification.Agents/EmailNotification.cs new file mode 100644 index 000000000..f5986dc34 --- /dev/null +++ b/src/Ombi.Notification.Agents/EmailNotification.cs @@ -0,0 +1,227 @@ +using System; +using System.Threading.Tasks; +using MailKit.Net.Smtp; +using MimeKit; +using Ombi.Core.Models.Requests; +using Ombi.Core.Settings; +using Ombi.Notifications.Models; +using Ombi.Notifications.Templates; +using Ombi.Settings.Settings.Models.Notifications; + +namespace Ombi.Notifications.Email +{ + public class EmailNotification : BaseNotification + { + public EmailNotification(ISettingsService settings) : base(settings) + { + } + + public override string NotificationName => nameof(EmailNotification); + + protected override bool ValidateConfiguration(EmailNotificationSettings settings) + { + if (!settings.Enabled) + { + return false; + } + if (settings.Authentication) + { + if (string.IsNullOrEmpty(settings.EmailUsername) || string.IsNullOrEmpty(settings.EmailPassword)) + { + return false; + } + } + if (string.IsNullOrEmpty(settings.EmailHost) || string.IsNullOrEmpty(settings.RecipientEmail) || string.IsNullOrEmpty(settings.EmailPort.ToString())) + { + return false; + } + + return true; + } + + protected override async Task NewRequest(NotificationModel model, EmailNotificationSettings settings) + { + var email = new EmailBasicTemplate(); + var html = email.LoadTemplate( + $"Ombi: New {model.RequestType.GetString()?.ToLower()} request for {model.Title}!", + $"Hello! The user '{model.User}' has requested the {model.RequestType.GetString()?.ToLower()} '{model.Title}'! Please log in to approve this request. Request Date: {model.DateTime:f}", + model.ImgSrc); + + + var message = new NotificationMessage + { + Message = html, + Subject = $"Ombi: New {model.RequestType.GetString()?.ToLower()} request for {model.Title}!", + To = settings.RecipientEmail, + }; + + message.Other.Add("PlainTextBody", $"Hello! The user '{model.User}' has requested the {model.RequestType.GetString()?.ToLower()} '{model.Title}'! Please log in to approve this request. Request Date: {model.DateTime:f}"); + + await Send(message, settings); + } + + protected override async Task Issue(NotificationModel model, EmailNotificationSettings settings) + { + var email = new EmailBasicTemplate(); + var html = email.LoadTemplate( + $"Ombi: New issue for {model.Title}!", + $"Hello! The user '{model.User}' has reported a new issue {model.Body} for the title {model.Title}!", + model.ImgSrc); + + var message = new NotificationMessage + { + Message = html, + Subject = $"Ombi: New issue for {model.Title}!", + To = settings.RecipientEmail, + }; + + message.Other.Add("PlainTextBody", $"Hello! The user '{model.User}' has reported a new issue {model.Body} for the title {model.Title}!"); + + await Send(message, settings); + } + + protected override async Task AddedToRequestQueue(NotificationModel model, EmailNotificationSettings settings) + { + var email = new EmailBasicTemplate(); + var html = email.LoadTemplate( + "Ombi: A request could not be added.", + $"Hello! The user '{model.User}' has requested {model.Title} but it could not be added. This has been added into the requests queue and will keep retrying", + model.ImgSrc); + + var message = new NotificationMessage + { + Message = html, + Subject = $"Ombi: A request could not be added", + To = settings.RecipientEmail, + }; + + message.Other.Add("PlainTextBody", $"Hello! The user '{model.User}' has requested {model.Title} but it could not be added. This has been added into the requests queue and will keep retrying"); + + + await Send(message, settings); + } + + protected override async Task RequestDeclined(NotificationModel model, EmailNotificationSettings settings) + { + var email = new EmailBasicTemplate(); + var html = email.LoadTemplate( + "Ombi: Your request has been declined", + $"Hello! Your request for {model.Title} has been declined, Sorry!", + model.ImgSrc); + + var message = new NotificationMessage + { + Message = html, + Subject = $"Ombi: Your request has been declined", + To = model.UserEmail, + }; + + message.Other.Add("PlainTextBody", $"Hello! Your request for {model.Title} has been declined, Sorry!"); + + + await Send(message, settings); + } + + protected override async Task RequestApproved(NotificationModel model, EmailNotificationSettings settings) + { + var email = new EmailBasicTemplate(); + var html = email.LoadTemplate( + "Ombi: Your request has been approved!", + $"Hello! Your request for {model.Title} has been approved!", + model.ImgSrc); + + var message = new NotificationMessage + { + Message = html, + Subject = $"Ombi: Your request has been approved!", + To = model.UserEmail, + }; + + message.Other.Add("PlainTextBody", $"Hello! Your request for {model.Title} has been approved!"); + + await Send(message, settings); + } + + protected override async Task AvailableRequest(NotificationModel model, EmailNotificationSettings settings) + { + var email = new EmailBasicTemplate(); + var html = email.LoadTemplate( + $"Ombi: {model.Title} is now available!", + $"Hello! You requested {model.Title} on Ombi! This is now available on Plex! :)", + model.ImgSrc); + + + var message = new NotificationMessage + { + Message = html, + Subject = $"Ombi: {model.Title} is now available!", + To = model.UserEmail, + }; + + message.Other.Add("PlainTextBody", $"Hello! You requested {model.Title} on Ombi! This is now available on Plex! :)"); + + await Send(message, settings); + } + + protected override async Task Send(NotificationMessage model, EmailNotificationSettings settings) + { + try + { + var body = new BodyBuilder + { + HtmlBody = model.Message, + TextBody = model.Other["PlainTextBody"] + }; + + var message = new MimeMessage + { + Body = body.ToMessageBody(), + Subject = model.Subject + }; + message.From.Add(new MailboxAddress(settings.EmailSender, settings.EmailSender)); + message.To.Add(new MailboxAddress(model.To, model.To)); + + using (var client = new SmtpClient()) + { + client.Connect(settings.EmailHost, settings.EmailPort); // Let MailKit figure out the correct SecureSocketOptions. + + // Note: since we don't have an OAuth2 token, disable + // the XOAUTH2 authentication mechanism. + client.AuthenticationMechanisms.Remove("XOAUTH2"); + + if (settings.Authentication) + { + client.Authenticate(settings.EmailUsername, settings.EmailPassword); + } + //Log.Info("sending message to {0} \r\n from: {1}\r\n Are we authenticated: {2}", message.To, message.From, client.IsAuthenticated); + await client.SendAsync(message); + await client.DisconnectAsync(true); + } + } + catch (Exception e) + { + //Log.Error(e); + throw new InvalidOperationException(e.Message); + } + } + + protected override async Task Test(NotificationModel model, EmailNotificationSettings settings) + { + var email = new EmailBasicTemplate(); + var html = email.LoadTemplate( + "Test Message", + "This is just a test! Success!", + model.ImgSrc); + var message = new NotificationMessage + { + Message = html, + Subject = $"Ombi: Test", + To = settings.RecipientEmail, + }; + + message.Other.Add("PlainTextBody", "This is just a test! Success!"); + + await Send(message, settings); + } + } +} diff --git a/src/Ombi.Notification.Discord/Ombi.Notification.Discord.csproj b/src/Ombi.Notification.Agents/Ombi.Notification.Agents.csproj similarity index 61% rename from src/Ombi.Notification.Discord/Ombi.Notification.Discord.csproj rename to src/Ombi.Notification.Agents/Ombi.Notification.Agents.csproj index ecacf8bcf..29ae93c81 100644 --- a/src/Ombi.Notification.Discord/Ombi.Notification.Discord.csproj +++ b/src/Ombi.Notification.Agents/Ombi.Notification.Agents.csproj @@ -6,7 +6,10 @@ + + + \ No newline at end of file diff --git a/src/Ombi.Notifications/Ombi.Notifications.csproj b/src/Ombi.Notifications/Ombi.Notifications.csproj index d687e46fd..ea899160a 100644 --- a/src/Ombi.Notifications/Ombi.Notifications.csproj +++ b/src/Ombi.Notifications/Ombi.Notifications.csproj @@ -5,6 +5,11 @@ + + + + + diff --git a/src/Ombi.sln b/src/Ombi.sln index da95c8add..9d31c29d4 100644 --- a/src/Ombi.sln +++ b/src/Ombi.sln @@ -49,8 +49,6 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ombi.Notifications", "Ombi. EndProject Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Notifications", "Notifications", "{EA30DD15-6280-4687-B370-2956EC2E54E5}" EndProject -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ombi.Notifications.Email", "Ombi.Notifications.Email\Ombi.Notifications.Email.csproj", "{72DB97D7-2D60-4B96-8C57-6C0E20E892EB}" -EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ombi.Notifications.Templates", "Ombi.Notifications.Templates\Ombi.Notifications.Templates.csproj", "{6EE01B17-0966-4E11-8BC1-A5318A92AB1D}" EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ombi.Settings", "Ombi.Settings\Ombi.Settings.csproj", "{AE3AA23D-5B66-42AF-B44E-B9B4D8856C6F}" @@ -63,7 +61,7 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ombi.Api.Radarr", "Ombi.Api EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ombi.Api.Discord", "Ombi.Api.Discord\Ombi.Api.Discord.csproj", "{5AF2B6D2-5CC6-49FE-928A-BA27AF52B194}" EndProject -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ombi.Notification.Discord", "Ombi.Notification.Discord\Ombi.Notification.Discord.csproj", "{D7B05CF2-E6B3-4BE5-8A02-6698CC0DCE9A}" +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ombi.Notification.Agents", "Ombi.Notification.Agents\Ombi.Notification.Agents.csproj", "{DC9E3E44-802A-4D9B-A70F-D198CFE4C73D}" EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution @@ -127,10 +125,6 @@ Global {E6EE2830-E4AC-4F2E-AD93-2C9305605761}.Debug|Any CPU.Build.0 = Debug|Any CPU {E6EE2830-E4AC-4F2E-AD93-2C9305605761}.Release|Any CPU.ActiveCfg = Release|Any CPU {E6EE2830-E4AC-4F2E-AD93-2C9305605761}.Release|Any CPU.Build.0 = Release|Any CPU - {72DB97D7-2D60-4B96-8C57-6C0E20E892EB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU - {72DB97D7-2D60-4B96-8C57-6C0E20E892EB}.Debug|Any CPU.Build.0 = Debug|Any CPU - {72DB97D7-2D60-4B96-8C57-6C0E20E892EB}.Release|Any CPU.ActiveCfg = Release|Any CPU - {72DB97D7-2D60-4B96-8C57-6C0E20E892EB}.Release|Any CPU.Build.0 = Release|Any CPU {6EE01B17-0966-4E11-8BC1-A5318A92AB1D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {6EE01B17-0966-4E11-8BC1-A5318A92AB1D}.Debug|Any CPU.Build.0 = Debug|Any CPU {6EE01B17-0966-4E11-8BC1-A5318A92AB1D}.Release|Any CPU.ActiveCfg = Release|Any CPU @@ -155,10 +149,10 @@ Global {5AF2B6D2-5CC6-49FE-928A-BA27AF52B194}.Debug|Any CPU.Build.0 = Debug|Any CPU {5AF2B6D2-5CC6-49FE-928A-BA27AF52B194}.Release|Any CPU.ActiveCfg = Release|Any CPU {5AF2B6D2-5CC6-49FE-928A-BA27AF52B194}.Release|Any CPU.Build.0 = Release|Any CPU - {D7B05CF2-E6B3-4BE5-8A02-6698CC0DCE9A}.Debug|Any CPU.ActiveCfg = Debug|Any CPU - {D7B05CF2-E6B3-4BE5-8A02-6698CC0DCE9A}.Debug|Any CPU.Build.0 = Debug|Any CPU - {D7B05CF2-E6B3-4BE5-8A02-6698CC0DCE9A}.Release|Any CPU.ActiveCfg = Release|Any CPU - {D7B05CF2-E6B3-4BE5-8A02-6698CC0DCE9A}.Release|Any CPU.Build.0 = Release|Any CPU + {DC9E3E44-802A-4D9B-A70F-D198CFE4C73D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {DC9E3E44-802A-4D9B-A70F-D198CFE4C73D}.Debug|Any CPU.Build.0 = Debug|Any CPU + {DC9E3E44-802A-4D9B-A70F-D198CFE4C73D}.Release|Any CPU.ActiveCfg = Release|Any CPU + {DC9E3E44-802A-4D9B-A70F-D198CFE4C73D}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE @@ -173,12 +167,11 @@ Global {CFB5E008-D0D0-43C0-AA06-89E49D17F384} = {9293CA11-360A-4C20-A674-B9E794431BF5} {0E8EF835-E4F0-4EE5-A2B6-678DEE973721} = {9293CA11-360A-4C20-A674-B9E794431BF5} {E6EE2830-E4AC-4F2E-AD93-2C9305605761} = {EA30DD15-6280-4687-B370-2956EC2E54E5} - {72DB97D7-2D60-4B96-8C57-6C0E20E892EB} = {EA30DD15-6280-4687-B370-2956EC2E54E5} {6EE01B17-0966-4E11-8BC1-A5318A92AB1D} = {EA30DD15-6280-4687-B370-2956EC2E54E5} {3880375C-1A7E-4D75-96EC-63B954C42FEA} = {9293CA11-360A-4C20-A674-B9E794431BF5} {FC6A8F7C-9722-4AE4-960D-277ACB0E81CB} = {6F42AB98-9196-44C4-B888-D5E409F415A1} {94D04C1F-E35A-499C-B0A0-9FADEBDF8336} = {9293CA11-360A-4C20-A674-B9E794431BF5} {5AF2B6D2-5CC6-49FE-928A-BA27AF52B194} = {9293CA11-360A-4C20-A674-B9E794431BF5} - {D7B05CF2-E6B3-4BE5-8A02-6698CC0DCE9A} = {EA30DD15-6280-4687-B370-2956EC2E54E5} + {DC9E3E44-802A-4D9B-A70F-D198CFE4C73D} = {EA30DD15-6280-4687-B370-2956EC2E54E5} EndGlobalSection EndGlobal diff --git a/src/Ombi/.gitignore b/src/Ombi/.gitignore index 3c9623388..ae9772467 100644 --- a/src/Ombi/.gitignore +++ b/src/Ombi/.gitignore @@ -2,8 +2,7 @@ /wwwroot/fonts/** /wwwroot/lib/** /wwwroot/maps/** -/wwwroot/app/**/*.js -/wwwroot/app/**/*.js.map +/wwwroot/dist/** /wwwroot/*.js.map /wwwroot/*.js diff --git a/src/Ombi/ClientApp/app/app.module.ts b/src/Ombi/ClientApp/app/app.module.ts index 352bb4d05..4a0cb90fb 100644 --- a/src/Ombi/ClientApp/app/app.module.ts +++ b/src/Ombi/ClientApp/app/app.module.ts @@ -26,8 +26,8 @@ import { SeriesInformationComponent } from './search/seriesinformation.component import { RequestComponent } from './requests/request.component'; import { MovieRequestsComponent } from './requests/movierequests.component'; import { TvRequestsComponent } from './requests/tvrequests.component'; -import { RequestGridComponent } from './requests/request-grid.component'; -import { RequestCardComponent } from './requests/request-card.component'; +import { RequestGridComponent } from './request-grid/request-grid.component'; +import { RequestCardComponent } from './request-grid/request-card.component'; import { LoginComponent } from './login/login.component'; import { LandingPageComponent } from './landingpage/landingpage.component'; diff --git a/src/Ombi/ClientApp/app/requests/request-card.component.html b/src/Ombi/ClientApp/app/request-grid/request-card.component.html similarity index 100% rename from src/Ombi/ClientApp/app/requests/request-card.component.html rename to src/Ombi/ClientApp/app/request-grid/request-card.component.html diff --git a/src/Ombi/ClientApp/app/requests/request-card.component.ts b/src/Ombi/ClientApp/app/request-grid/request-card.component.ts similarity index 100% rename from src/Ombi/ClientApp/app/requests/request-card.component.ts rename to src/Ombi/ClientApp/app/request-grid/request-card.component.ts diff --git a/src/Ombi/ClientApp/app/requests/request-grid.component.html b/src/Ombi/ClientApp/app/request-grid/request-grid.component.html similarity index 100% rename from src/Ombi/ClientApp/app/requests/request-grid.component.html rename to src/Ombi/ClientApp/app/request-grid/request-grid.component.html diff --git a/src/Ombi/ClientApp/app/requests/request-grid.component.ts b/src/Ombi/ClientApp/app/request-grid/request-grid.component.ts similarity index 100% rename from src/Ombi/ClientApp/app/requests/request-grid.component.ts rename to src/Ombi/ClientApp/app/request-grid/request-grid.component.ts diff --git a/src/Ombi/ClientApp/app/requests/movierequests.component.html b/src/Ombi/ClientApp/app/requests/movierequests.component.html index 22abf4df1..8e9b3158c 100644 --- a/src/Ombi/ClientApp/app/requests/movierequests.component.html +++ b/src/Ombi/ClientApp/app/requests/movierequests.component.html @@ -51,14 +51,7 @@
Release Date: {{request.releaseDate | date}}

- +
Requested By: {{user}}
Requested Date: {{request.requestedDate | date}}
diff --git a/src/Ombi/ClientApp/app/requests/tvrequests.component.html b/src/Ombi/ClientApp/app/requests/tvrequests.component.html index 2a35f045e..e19d4f4ec 100644 --- a/src/Ombi/ClientApp/app/requests/tvrequests.component.html +++ b/src/Ombi/ClientApp/app/requests/tvrequests.component.html @@ -153,20 +153,27 @@
-
-
- - + - + +
diff --git a/src/Ombi/ClientApp/app/search/moviesearch.component.ts b/src/Ombi/ClientApp/app/search/moviesearch.component.ts index 2453f3595..9a61a206f 100644 --- a/src/Ombi/ClientApp/app/search/moviesearch.component.ts +++ b/src/Ombi/ClientApp/app/search/moviesearch.component.ts @@ -115,11 +115,20 @@ export class MovieSearchComponent implements OnInit, OnDestroy { } private getExtaInfo() { - this.searchService.extraInfo(this.movieResults) - .takeUntil(this.subscriptions) - .subscribe(m => this.movieResults = m); + + this.movieResults.forEach((val, index) => { + this.searchService.getMovieInformation(val.id) + .takeUntil(this.subscriptions) + .subscribe(m => this.updateItem(val, m)); + }); } + private updateItem(key: ISearchMovieResult, updated: ISearchMovieResult) { + var index = this.movieResults.indexOf(key, 0); + if (index > -1) { + this.movieResults[index] = updated; + } + } private clearResults() { this.movieResults = []; this.searchApplied = false; diff --git a/src/Ombi/ClientApp/app/search/search.component.html b/src/Ombi/ClientApp/app/search/search.component.html index b00c7478e..705ff17ee 100644 --- a/src/Ombi/ClientApp/app/search/search.component.html +++ b/src/Ombi/ClientApp/app/search/search.component.html @@ -31,12 +31,6 @@
- - - - - Content 2 -
\\r\\n
Requested By: {{user}}
\\r\\n\\r\\n
Requested Date: {{request.requestedDate | date}}
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n \\r\\n \\r\\n\\r\\n\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n \\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./ClientApp/app/requests/movierequests.component.html?0a5b"],"names":[],"mappings":"AAAA,+mBAA+mB,oBAAoB,gMAAgM,gBAAgB,oFAAoF,eAAe,IAAI,oCAAoC,kPAAkP,gBAAgB,0iBAA0iB,sBAAsB,yVAAyV,oHAAoH,4BAA4B,qEAAqE,oBAAoB,0BAA0B,cAAc,0FAA0F,WAAW,qFAAqF,MAAM,8DAA8D,iBAAiB,oCAAoC,KAAK,0BAA0B,QAAQ,qIAAqI,MAAM,iEAAiE,8BAA8B,oCAAoC,WAAW,0BAA0B,qBAAqB,uCAAuC,WAAW,uCAAuC,WAAW,oBAAoB,iBAAiB,uCAAuC,KAAK,0BAA0B,KAAK,2DAA2D,kBAAkB,qEAAqE,MAAM,6EAA6E,SAAS,kEAAkE,QAAQ,6VAA6V,mBAAmB,oyBAAoyB,iBAAiB,4EAA4E,IAAI,KAAK,MAAM,+BAA+B,OAAO,0dAA0d,oBAAoB,IAAI,MAAM,OAAO,QAAQ,sBAAsB,WAAW,yFAAyF,WAAW,4DAA4D,4BAA4B,0MAA0M,WAAW,qBAAqB,WAAW,2kBAA2kB,mBAAmB,kGAAkG,IAAI,iBAAiB,WAAW,KAAK,MAAM,uDAAuD,OAAO,6HAA6H,QAAQ,yPAAyP,mBAAmB,28BAA28B,mBAAmB,owCAAowC,mBAAmB,kHAAkH,mBAAmB","file":"176.js","sourcesContent":["module.exports = \"<div class=\\\"form-group\\\">\\r\\n  <div>\\r\\n        <input type=\\\"text\\\" class=\\\"form-control form-control-custom\\\" placeholder=\\\"Search\\\" (keyup)=\\\"search($event)\\\">\\r\\n    </div>\\r\\n</div>\\r\\n<br/>\\r\\n\\r\\n    <div infinite-scroll\\r\\n         [infiniteScrollDistance]=\\\"1\\\"\\r\\n         [infiniteScrollThrottle]=\\\"100\\\"\\r\\n         (scrolled)=\\\"loadMore()\\\">\\r\\n\\r\\n\\r\\n        <div *ngFor=\\\"let request of movieRequests\\\">\\r\\n\\r\\n\\r\\n            <div class=\\\"row\\\">\\r\\n                <div class=\\\"col-sm-2\\\">\\r\\n\\r\\n                    <img class=\\\"img-responsive\\\" src=\\\"https://image.tmdb.org/t/p/w150/{{request.posterPath}}\\\" alt=\\\"poster\\\">\\r\\n\\r\\n                </div>\\r\\n\\r\\n                <div class=\\\"col-sm-5 \\\">\\r\\n                    <div>\\r\\n                        <a href=\\\"http://www.imdb.com/title/{{request.imdbId}}/\\\" target=\\\"_blank\\\">\\r\\n                            <h4 class=\\\"request-title\\\">{{request.title}} ({{request.releaseDate | date: 'yyyy'}})</h4>\\r\\n                        </a>\\r\\n                    </div>\\r\\n                    <br />\\r\\n                    <div>\\r\\n                        <span>Status: </span>\\r\\n                        <span class=\\\"label label-success\\\">{{request.status}}</span>\\r\\n                    </div>\\r\\n\\r\\n                    <div>\\r\\n                        <span>Request status: </span>\\r\\n                        <span *ngIf=\\\"request.available\\\" class=\\\"label label-success\\\">Available</span>\\r\\n                        <span *ngIf=\\\"request.approved && !request.available\\\" class=\\\"label label-info\\\">Processing Request</span>\\r\\n                        <span *ngIf=\\\"request.denied\\\" class=\\\"label label-danger\\\">Request Denied</span>\\r\\n                        <span *ngIf=\\\"request.deniedReason\\\" title=\\\"{{request.deniedReason}}\\\"><i class=\\\"fa fa-info-circle\\\"></i></span>\\r\\n                        <span *ngIf=\\\"!request.approved && !request.availble && !request.denied\\\" class=\\\"label label-warning\\\">Pending Approval</span>\\r\\n\\r\\n                    </div>\\r\\n                    <div *ngIf=\\\"request.denied\\\">\\r\\n                        Denied: <i style=\\\"color:red;\\\" class=\\\"fa fa-check\\\"></i>\\r\\n\\r\\n                    </div>\\r\\n\\r\\n\\r\\n                    <div>Release Date: {{request.releaseDate | date}}</div>\\r\\n                    <br/>\\r\\n\\r\\n                    <!--{{#if_eq type \\\"tv\\\"}}\\r\\n                    {{#if episodes}}\\r\\n                    Episodes: <span class=\\\"customTooltip\\\" data-tooltip-content=\\\"#{{requestId}}toolTipContent\\\"><i class=\\\"fa fa-info-circle\\\"></i></span>\\r\\n                    {{else}}\\r\\n                    <div>@UI.Requests_SeasonsRequested: {{seriesRequested}}</div>\\r\\n\\r\\n                    {{/if}}\\r\\n                    {{/if_eq}}-->\\r\\n                    <div *ngIf=\\\"request.requestedUsers\\\">Requested By: <span *ngFor=\\\"let user of request.requestedUsers\\\">{{user}} </span></div>\\r\\n\\r\\n                    <div>Requested Date: {{request.requestedDate | date}}</div>\\r\\n                    <!--{{#if admin}}\\r\\n                    {{#if currentRootPath}}\\r\\n                    <div class=\\\"{{requestId}}rootPathMain\\\">Root Path: <span id=\\\"{{requestId}}currentRootPath\\\">{{currentRootPath}}</span></div>\\r\\n                    {{/if}}\\r\\n                    {{/if}}\\r\\n                    <div>\\r\\n                        {{#if_eq issueId 0}}\\r\\n                        @*Nothing*@\\r\\n                        {{else}}\\r\\n                        @UI.Issues_Issue: <a href=\\\"@formAction/issues/{{issueId}}\\\"><i class=\\\"fa fa-check\\\"></i></a>\\r\\n                        {{/if_eq}}\\r\\n                    </div>-->\\r\\n                </div>\\r\\n                <div class=\\\"col-sm-3 col-sm-push-3\\\">\\r\\n                    <div *ngIf=\\\"isAdmin\\\">\\r\\n                        <div *ngIf=\\\"!request.approved\\\">\\r\\n                            <form>\\r\\n                                <input name=\\\"requestId\\\" type=\\\"text\\\" value=\\\"{{request.requestId}}\\\" hidden=\\\"hidden\\\" />\\r\\n                                <div *ngIf=\\\"request.hasQualities\\\" class=\\\"btn-group btn-split\\\">\\r\\n                                    <button type=\\\"button\\\" (click)=\\\"approve(request)\\\" class=\\\"btn btn-sm btn-success-outline approve\\\"><i class=\\\"fa fa-plus\\\"></i> Approve</button>\\r\\n                                    <button type=\\\"button\\\" class=\\\"btn btn-success-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"false\\\">\\r\\n                                        <span class=\\\"caret\\\"></span>\\r\\n                                        <span class=\\\"sr-only\\\">Toggle Dropdown</span>\\r\\n                                    </button>\\r\\n                                    <!--<ul class=\\\"dropdown-menu\\\">\\r\\n                {{#each qualities}}\\r\\n                <li><a href=\\\"#\\\" class=\\\"approve-with-quality\\\" id=\\\"{{id}}\\\">{{name}}</a></li>\\r\\n                {{/each}}\\r\\n            </ul>-->\\r\\n                                </div>\\r\\n\\r\\n\\r\\n                                <button *ngIf=\\\"!request.hasQualities\\\" (click)=\\\"approve(request)\\\" style=\\\"text-align: right\\\" class=\\\"btn btn-sm btn-success-outline approve\\\" type=\\\"submit\\\"><i class=\\\"fa fa-plus\\\"></i> Approve</button>\\r\\n                            </form>\\r\\n\\r\\n\\r\\n\\r\\n                            <!--<form method=\\\"POST\\\" action=\\\"@formAction/requests/changeRootFolder{{#if_eq type \\\"tv\\\"}}tv{{else}}movie{{/if_eq}}\\\" id=\\\"changeFolder{{requestId}}\\\">\\r\\n                                <input name=\\\"requestId\\\" type=\\\"text\\\" value=\\\"{{requestId}}\\\" hidden=\\\"hidden\\\"/>\\r\\n                                {{#if_eq hasRootFolders true}}\\r\\n                                <div class=\\\"btn-group btn-split\\\">\\r\\n                                    <button type=\\\"button\\\" class=\\\"btn btn-sm btn-success-outline\\\" id=\\\"changeRootFolderBtn{{requestId}}\\\" custom-button=\\\"{{requestId}}\\\">@*<i class=\\\"fa fa-plus\\\"></i>*@ Change Root Folder</button>\\r\\n                                    <button type=\\\"button\\\" class=\\\"btn btn-success-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"false\\\">\\r\\n                                        <span class=\\\"caret\\\"></span>\\r\\n                                        <span class=\\\"sr-only\\\">@UI.Requests_ToggleDropdown</span>\\r\\n                                    </button>\\r\\n                                    <ul class=\\\"dropdown-menu\\\">\\r\\n                                        {{#each rootFolders}}\\r\\n                                        <li><a href=\\\"#\\\" class=\\\"change-root-folder\\\" id=\\\"{{id}}\\\" requestId=\\\"{{requestId}}\\\">{{path}}</a></li>\\r\\n                                        {{/each}}\\r\\n                                    </ul>\\r\\n                                </div>\\r\\n                                {{/if_eq}}\\r\\n                            </form>-->\\r\\n\\r\\n\\r\\n\\r\\n                            <div *ngIf=\\\"!request.denied\\\">\\r\\n                                <form>\\r\\n                                    <input name=\\\"requestId\\\" type=\\\"text\\\" value=\\\"{{request.requestId}}\\\" hidden=\\\"hidden\\\"/>\\r\\n                                    <input name=\\\"reason\\\" type=\\\"text\\\" hidden=\\\"hidden\\\"/>\\r\\n                                    <div class=\\\"btn-group btn-split\\\">\\r\\n                                        <button type=\\\"button\\\" (click)=\\\"deny(request)\\\" class=\\\"btn btn-sm btn-danger-outline deny\\\"><i class=\\\"fa fa-times\\\"></i> Deny</button>\\r\\n                                        <button type=\\\"button\\\" class=\\\"btn btn-danger-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"false\\\">\\r\\n                                            <span class=\\\"caret\\\"></span>\\r\\n                                            <span class=\\\"sr-only\\\">@UI.Requests_ToggleDropdown</span>\\r\\n                                        </button>\\r\\n                                        <ul class=\\\"dropdown-menu\\\">\\r\\n                                            <li><a class=\\\"deny-with-reason\\\" id=\\\"denyReason{{request.requestId}}\\\" href=\\\"#\\\" data-toggle=\\\"modal\\\" data-target=\\\"#denyReasonModal\\\">Deny with a reason</a></li>\\r\\n                                        </ul>\\r\\n                                    </div>\\r\\n                                </form>\\r\\n                            </div>\\r\\n                        </div>\\r\\n                        <form>\\r\\n                            <button (click)=\\\"removeRequest(request)\\\" style=\\\"text-align: right\\\" class=\\\"btn btn-sm btn-danger-outline delete\\\"><i class=\\\"fa fa-minus\\\"></i> Remove</button>\\r\\n                        </form>\\r\\n            \\r\\n                        <form>\\r\\n                            <button *ngIf=\\\"request.available\\\" (click)=\\\"changeAvailability(request, false)\\\" style=\\\"text-align: right\\\" value=\\\"false\\\" class=\\\"btn btn-sm btn-info-outline change\\\"><i class=\\\"fa fa-minus\\\"></i> Mark Unavailable</button>\\r\\n                            <button *ngIf=\\\"!request.available\\\" (click)=\\\"changeAvailability(request, true)\\\" style=\\\"text-align: right\\\" value=\\\"true\\\" class=\\\"btn btn-sm btn-success-outline change\\\"><i class=\\\"fa fa-plus\\\"></i> Mark Available</button>\\r\\n                            </form>\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n</div>\\r\\n\\r\\n\\r\\n                    <input name=\\\"requestId\\\" type=\\\"text\\\" value=\\\"{{request.requestId}}\\\" hidden=\\\"hidden\\\" />\\r\\n                    <div class=\\\"dropdown\\\">\\r\\n                        <button id=\\\"{{request.requestId}}\\\" class=\\\"btn btn-sm btn-primary-outline dropdown-toggle\\\" type=\\\"button\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"true\\\">\\r\\n                            <i class=\\\"fa fa-plus\\\"></i> Report Issue\\r\\n                            <span class=\\\"caret\\\"></span>\\r\\n                        </button>\\r\\n                        <ul class=\\\"dropdown-menu\\\" aria-labelledby=\\\"dropdownMenu1\\\">\\r\\n                            <li><a issue-select=\\\"0\\\">@UI.Issues_WrongAudio</a></li>\\r\\n                            <li><a issue-select=\\\"1\\\">@UI.Issues_NoSubs</a></li>\\r\\n                            <li><a issue-select=\\\"2\\\">@UI.Issues_WrongContent</a></li>\\r\\n                            <li><a issue-select=\\\"3\\\">@UI.Issues_Playback</a></li>\\r\\n                            <li><a issue-select=\\\"4\\\" data-toggle=\\\"modal\\\" data-target=\\\"#myModal\\\">@UI.Issues_Other</a></li>\\r\\n                        </ul>\\r\\n                    </div>\\r\\n\\r\\n                </div>\\r\\n            </div>\\r\\n            <hr />\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n        </div>\\r\\n    </div>\\r\\n\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./ClientApp/app/requests/movierequests.component.html\n// module id = 176\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 177 */ -/***/ (function(module, exports) { - -eval("module.exports = \"
\\r\\n {{request.title}}\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3JlcXVlc3RzL3JlcXVlc3QtY2FyZC5jb21wb25lbnQuaHRtbD9mZDBkIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdFQUF3RSxhQUFhLGFBQWEsZUFBZSIsImZpbGUiOiIxNzcuanMiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IFwiPGRpdiAqbmdJZj1cXFwicmVxdWVzdFxcXCIgc3R5bGU9XFxcImJhY2tncm91bmQtY29sb3I6YmxhY2s7IGNvbG9yOndoaXRlO1xcXCI+XFxyXFxuICAgIHt7cmVxdWVzdC50aXRsZX19XFxyXFxuPC9kaXY+XCI7XG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9DbGllbnRBcHAvYXBwL3JlcXVlc3RzL3JlcXVlc3QtY2FyZC5jb21wb25lbnQuaHRtbFxuLy8gbW9kdWxlIGlkID0gMTc3XG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0="); - -/***/ }), -/* 178 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n Title\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n Title\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3JlcXVlc3RzL3JlcXVlc3QtZ3JpZC5jb21wb25lbnQuaHRtbD9jZGE5Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG1EQUFtRCwwQkFBMEIsMkNBQTJDLDhCQUE4QiwwQkFBMEIsb0NBQW9DLG1DQUFtQywrQkFBK0IsMENBQTBDLFNBQVMiLCJmaWxlIjoiMTc4LmpzIiwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHMgPSBcIlxcclxcbjxzdHlsZT5cXHJcXG4gICAgLmxhbmRpbmctYm94IHtcXHJcXG4gICAgICAgIGhlaWdodDogMTUwcHg7XFxyXFxuICAgICAgICBiYWNrZ3JvdW5kOiAjMzMzMzMzICFpbXBvcnRhbnQ7XFxyXFxuICAgICAgICBib3JkZXItcmFkaXVzOiAyJTtcXHJcXG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XFxyXFxuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcXHJcXG4gICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XFxyXFxuICAgICAgICB0ZXh0LWFsaWduOiBjZW50ZXI7XFxyXFxuICAgICAgICBib3gtc2hhZG93OiA1cHggM3B4IDVweCBibGFjaztcXHJcXG4gICAgfVxcclxcbjwvc3R5bGU+XFxyXFxuXFxyXFxuPGRpdiAqbmdJZj1cXFwidHZSZXF1ZXN0c1xcXCI+XFxyXFxuICAgIDxkaXYgY2xhc3M9XFxcImNvbC1tZC00XFxcIj5cXHJcXG4gICAgICAgIDxkaXYgY2xhc3M9XFxcImxhbmRpbmctYm94XFxcIj5cXHJcXG4gICAgICAgICAgICA8bWQtY2FyZC10aXRsZT5UaXRsZTwvbWQtY2FyZC10aXRsZT5cXHJcXG4gICAgICAgICAgICA8ZGl2IFtkcmFndWxhXT0nXFxcInJlcXVlc3RzLWJhZ1xcXCInIFtkcmFndWxhTW9kZWxdPVxcXCJ0dlJlcXVlc3RzLm5ld1xcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxiciAvPlxcclxcbiAgICAgICAgICAgICAgICA8YnIgLz5cXHJcXG4gICAgICAgICAgICAgICAgPHJlcXVlc3QtY2FyZCAqbmdGb3I9XFxcImxldCBpdGVtIG9mIHR2UmVxdWVzdHMubmV3XFxcIiBbcmVxdWVzdF09XFxcIml0ZW1cXFwiID48L3JlcXVlc3QtY2FyZD5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcbiAgICA8L2Rpdj5cXHJcXG5cXHJcXG4gICAgPGRpdiBjbGFzcz1cXFwiY29sLW1kLTRcXFwiPlxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwibGFuZGluZy1ib3hcXFwiPlxcclxcblxcclxcbiAgICAgICAgICAgIDxkaXYgW2RyYWd1bGFdPSdcXFwicmVxdWVzdHMtYmFnXFxcIicgW2RyYWd1bGFNb2RlbF09XFxcInR2UmVxdWVzdHMuYXBwcm92ZWRcXFwiPlxcclxcbiAgICAgICAgICAgICAgICA8YnIgLz5cXHJcXG4gICAgICAgICAgICAgICAgPGJyIC8+XFxyXFxuICAgICAgICAgICAgICAgIDxyZXF1ZXN0LWNhcmQgKm5nRm9yPVxcXCJsZXQgaXRlbSBvZiB0dlJlcXVlc3RzLmFwcHJvdmVkXFxcIiBbcmVxdWVzdF09XFxcIml0ZW1cXFwiPjwvcmVxdWVzdC1jYXJkPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuICAgIDwvZGl2PlxcclxcblxcclxcbiAgICA8ZGl2IGNsYXNzPVxcXCJjb2wtbWQtNFxcXCI+XFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJsYW5kaW5nLWJveFxcXCI+XFxyXFxuICAgICAgICAgICAgPG1kLWNhcmQtdGl0bGU+VGl0bGU8L21kLWNhcmQtdGl0bGU+XFxyXFxuICAgICAgICAgICAgPGRpdiBzdHlsZT1cXFwiYm9yZGVyOiBkYXNoZWRcXFwiPlxcclxcbiAgICAgICAgICAgICAgICA8ZGl2IFtkcmFndWxhXT0nXFxcInJlcXVlc3RzLWJhZ1xcXCInIFtkcmFndWxhTW9kZWxdPVxcXCJ0dlJlcXVlc3RzLmF2YWlsYWJsZVxcXCI+XFxyXFxuICAgICAgICAgICAgICAgICAgICA8YnIgLz5cXHJcXG4gICAgICAgICAgICAgICAgICAgIDxiciAvPlxcclxcbiAgICAgICAgICAgICAgICAgICAgPHJlcXVlc3QtY2FyZCAqbmdGb3I9XFxcImxldCBpdGVtIG9mIHR2UmVxdWVzdHMuYXZhaWxhYmxlXFxcIiBbcmVxdWVzdF09XFxcIml0ZW1cXFwiPjwvcmVxdWVzdC1jYXJkPlxcclxcbiAgICAgICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcbiAgICA8L2Rpdj5cXHJcXG48L2Rpdj5cXHJcXG5cIjtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL0NsaWVudEFwcC9hcHAvcmVxdWVzdHMvcmVxdWVzdC1ncmlkLmNvbXBvbmVudC5odG1sXG4vLyBtb2R1bGUgaWQgPSAxNzhcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ=="); - -/***/ }), -/* 179 */ -/***/ (function(module, exports) { - -eval("module.exports = \"

Requests

\\r\\n

Below you can see yours and all other requests, as well as their download and approval status.

\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3JlcXVlc3RzL3JlcXVlc3QuY29tcG9uZW50Lmh0bWw/YWVlZCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSIsImZpbGUiOiIxNzkuanMiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IFwiPGgxIGlkPVxcXCJzZWFyY2hUaXRsZVxcXCI+UmVxdWVzdHM8L2gxPlxcclxcbjxoND5CZWxvdyB5b3UgY2FuIHNlZSB5b3VycyBhbmQgYWxsIG90aGVyIHJlcXVlc3RzLCBhcyB3ZWxsIGFzIHRoZWlyIGRvd25sb2FkIGFuZCBhcHByb3ZhbCBzdGF0dXMuPC9oND5cXHJcXG5cXHJcXG5cXHJcXG5cXHJcXG48dWwgaWQ9XFxcIm5hdi10YWJzXFxcIiBjbGFzcz1cXFwibmF2IG5hdi10YWJzXFxcIiByb2xlPVxcXCJ0YWJsaXN0XFxcIj5cXHJcXG4gICAgPGxpIHJvbGU9XFxcInByZXNlbnRhdGlvblxcXCIgY2xhc3M9XFxcImFjdGl2ZVxcXCI+XFxyXFxuICAgICAgICA8YSBpZD1cXFwibW92aWVUYWJCdXR0b25cXFwiIGFyaWEtY29udHJvbHM9XFxcImhvbWVcXFwiIHJvbGU9XFxcInRhYlxcXCIgZGF0YS10b2dnbGU9XFxcInRhYlxcXCIgKGNsaWNrKT1cXFwic2VsZWN0VGFiKClcXFwiPjxpIGNsYXNzPVxcXCJmYSBmYS1maWxtXFxcIj48L2k+IE1vdmllczwvYT5cXHJcXG4gICAgPC9saT5cXHJcXG4gICAgPGxpIHJvbGU9XFxcInByZXNlbnRhdGlvblxcXCI+XFxyXFxuICAgICAgICA8YSBpZD1cXFwidHZUYWJCdXR0b25cXFwiIGFyaWEtY29udHJvbHM9XFxcInByb2ZpbGVcXFwiIHJvbGU9XFxcInRhYlxcXCIgZGF0YS10b2dnbGU9XFxcInRhYlxcXCIgKGNsaWNrKT1cXFwic2VsZWN0VGFiKClcXFwiPjxpIGNsYXNzPVxcXCJmYSBmYS10ZWxldmlzaW9uXFxcIj48L2k+IFRWIFNob3dzPC9hPlxcclxcblxcclxcbiAgICA8L2xpPlxcclxcbjwvdWw+XFxyXFxuXFxyXFxuPCEtLSBUYWIgcGFuZXMgLS0+XFxyXFxuPGRpdiBjbGFzcz1cXFwidGFiLWNvbnRlbnRcXFwiPlxcclxcbiAgICA8ZGl2IFtoaWRkZW5dPVxcXCIhc2hvd01vdmllXFxcIj5cXHJcXG4gICAgICAgIDxtb3ZpZS1yZXF1ZXN0cz48L21vdmllLXJlcXVlc3RzPlxcclxcbiAgICA8L2Rpdj5cXHJcXG4gICAgPGRpdiBbaGlkZGVuXT1cXFwiIXNob3dUdlxcXCI+XFxyXFxuICAgICAgICA8dHYtcmVxdWVzdHM+PC90di1yZXF1ZXN0cz5cXHJcXG4gICAgPC9kaXY+XFxyXFxuPC9kaXY+XFxyXFxuXFxyXFxuXCI7XG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9DbGllbnRBcHAvYXBwL3JlcXVlc3RzL3JlcXVlc3QuY29tcG9uZW50Lmh0bWxcbi8vIG1vZHVsZSBpZCA9IDE3OVxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 180 */ -/***/ (function(module, exports) { - -eval("module.exports = \"
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n \\\"poster\\\"\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n Status: \\r\\n {{request.status}}\\r\\n
\\r\\n
\\r\\n
\\r\\n Request status: \\r\\n Available\\r\\n Processing Request\\r\\n Request Denied\\r\\n \\r\\n Pending Approval\\r\\n\\r\\n
\\r\\n
\\r\\n Denied: \\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n
Release Date: {{request.releaseDate | date}}
\\r\\n
\\r\\n\\r\\n \\r\\n
Requested By: {{user}}
\\r\\n\\r\\n
Requested Date: {{request.requestedDate | date}}
\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n Requested By: {{user}} \\r\\n
\\r\\n
\\r\\n Seasons Requested: {{s.seasonNumber}} \\r\\n
\\r\\n
\\r\\n Request status: \\r\\n Available\\r\\n Processing Request\\r\\n Request Denied\\r\\n \\r\\n Pending Approval\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./ClientApp/app/requests/tvrequests.component.html?91ce"],"names":[],"mappings":"AAAA,+iBAA+iB,oBAAoB,gLAAgL,gBAAgB,gFAAgF,eAAe,IAAI,oCAAoC,0NAA0N,gBAAgB,+lBAA+lB,sBAAsB,yVAAyV,oHAAoH,4BAA4B,sEAAsE,oBAAoB,0BAA0B,cAAc,0FAA0F,WAAW,qFAAqF,MAAM,8DAA8D,iBAAiB,oCAAoC,KAAK,0BAA0B,QAAQ,qIAAqI,MAAM,iEAAiE,8BAA8B,oCAAoC,WAAW,0BAA0B,qBAAqB,uCAAuC,WAAW,uCAAuC,WAAW,oBAAoB,iBAAiB,uCAAuC,KAAK,0BAA0B,KAAK,2DAA2D,kBAAkB,qEAAqE,MAAM,6EAA6E,SAAS,kEAAkE,QAAQ,iUAAiU,YAAY,0TAA0T,MAAM,8MAA8M,gBAAgB,mkBAAmkB,sBAAsB,slBAAslB,mBAAmB,gyBAAgyB,iBAAiB,gGAAgG,IAAI,KAAK,MAAM,mDAAmD,OAAO,8eAA8e,oBAAoB,IAAI,MAAM,OAAO,QAAQ,sBAAsB,WAAW,qFAAqF,WAAW,wDAAwD,4BAA4B,kMAAkM,WAAW,qBAAqB,WAAW,mjBAAmjB,mBAAmB,8FAA8F,IAAI,iBAAiB,WAAW,KAAK,MAAM,mDAAmD,OAAO,iHAAiH,QAAQ,yOAAyO,mBAAmB,y6BAAy6B,mBAAmB,gtCAAgtC,mBAAmB,0GAA0G,mBAAmB","file":"180.js","sourcesContent":["module.exports = \"<div class=\\\"form-group\\\">\\r\\n    <div>\\r\\n        <input type=\\\"text\\\" class=\\\"form-control form-control-custom\\\" placeholder=\\\"Search\\\" (keyup)=\\\"search($event)\\\">\\r\\n    </div>\\r\\n</div>\\r\\n<br />\\r\\n\\r\\n<div infinite-scroll\\r\\n     [infiniteScrollDistance]=\\\"1\\\"\\r\\n     [infiniteScrollThrottle]=\\\"100\\\"\\r\\n     (scrolled)=\\\"loadMore()\\\">\\r\\n\\r\\n\\r\\n    <div *ngFor=\\\"let request of tvRequests\\\">\\r\\n\\r\\n\\r\\n        <div class=\\\"row\\\">\\r\\n            <div class=\\\"col-sm-2\\\">\\r\\n\\r\\n                <img class=\\\"img-responsive\\\" src=\\\"{{request.posterPath}}\\\" alt=\\\"poster\\\">\\r\\n\\r\\n            </div>\\r\\n\\r\\n            <div class=\\\"col-sm-5 \\\">\\r\\n                <div>\\r\\n                    <a href=\\\"http://www.imdb.com/title/{{request.imdbId}}/\\\" target=\\\"_blank\\\">\\r\\n                        <h4 class=\\\"request-title\\\">{{request.title}} ({{request.releaseDate | date: 'yyyy'}})</h4>\\r\\n                    </a>\\r\\n                </div>\\r\\n                <br />\\r\\n                <div>\\r\\n                    <span>Status: </span>\\r\\n                    <span class=\\\"label label-success\\\">{{request.status}}</span>\\r\\n                </div>\\r\\n                <div *ngIf=\\\"!request.hasChildRequests\\\">\\r\\n                    <div>\\r\\n                        <span>Request status: </span>\\r\\n                        <span *ngIf=\\\"request.available\\\" class=\\\"label label-success\\\">Available</span>\\r\\n                        <span *ngIf=\\\"request.approved && !request.available\\\" class=\\\"label label-info\\\">Processing Request</span>\\r\\n                        <span *ngIf=\\\"request.denied\\\" class=\\\"label label-danger\\\">Request Denied</span>\\r\\n                        <span *ngIf=\\\"request.deniedReason\\\" title=\\\"{{request.deniedReason}}\\\"><i class=\\\"fa fa-info-circle\\\"></i></span>\\r\\n                        <span *ngIf=\\\"!request.approved && !request.availble && !request.denied\\\" class=\\\"label label-warning\\\">Pending Approval</span>\\r\\n\\r\\n                    </div>\\r\\n                    <div *ngIf=\\\"request.denied\\\">\\r\\n                        Denied: <i style=\\\"color:red;\\\" class=\\\"fa fa-check\\\"></i>\\r\\n\\r\\n                    </div>\\r\\n\\r\\n\\r\\n                    <div>Release Date: {{request.releaseDate | date}}</div>\\r\\n                    <br />\\r\\n\\r\\n                    <!--{{#if_eq type \\\"tv\\\"}}\\r\\n                    {{#if episodes}}\\r\\n                    Episodes: <span class=\\\"customTooltip\\\" data-tooltip-content=\\\"#{{requestId}}toolTipContent\\\"><i class=\\\"fa fa-info-circle\\\"></i></span>\\r\\n                    {{else}}\\r\\n                    <div>@UI.Requests_SeasonsRequested: {{seriesRequested}}</div>\\r\\n\\r\\n                    {{/if}}\\r\\n                    {{/if_eq}}-->\\r\\n                    <div *ngIf=\\\"request.requestedUsers\\\">Requested By: <span *ngFor=\\\"let user of request.requestedUsers\\\">{{user}} </span></div>\\r\\n\\r\\n                    <div>Requested Date: {{request.requestedDate | date}}</div>\\r\\n                    <!--{{#if admin}}\\r\\n                    {{#if currentRootPath}}\\r\\n                    <div class=\\\"{{requestId}}rootPathMain\\\">Root Path: <span id=\\\"{{requestId}}currentRootPath\\\">{{currentRootPath}}</span></div>\\r\\n                    {{/if}}\\r\\n                    {{/if}}\\r\\n                    <div>\\r\\n                        {{#if_eq issueId 0}}\\r\\n                        @*Nothing*@\\r\\n                        {{else}}\\r\\n                        @UI.Issues_Issue: <a href=\\\"@formAction/issues/{{issueId}}\\\"><i class=\\\"fa fa-check\\\"></i></a>\\r\\n                        {{/if_eq}}\\r\\n                    </div>-->\\r\\n\\r\\n                </div>\\r\\n                <!--Child Requests-->\\r\\n\\r\\n                <button type=\\\"button\\\" class=\\\"btn btn-sm btn-info-outline\\\" data-toggle=\\\"collapse\\\" [attr.data-target]=\\\"'#' + request.id +'childRequests'\\\">Children</button>\\r\\n                <div id=\\\"{{request.id}}childRequests\\\" class=\\\"collapse\\\">\\r\\n\\r\\n                    <div *ngFor=\\\"let child of request.childRequests\\\">\\r\\n                        <hr />\\r\\n                        <div *ngIf=\\\"request.requestedUsers\\\">\\r\\n                            Requested By: <span *ngFor=\\\"let user of request.requestedUsers\\\">{{user}} </span>\\r\\n                        </div>\\r\\n                        <div *ngIf=\\\"child.seasonRequests\\\">\\r\\n                            Seasons Requested: <span *ngFor=\\\"let s of child.seasonRequests\\\">{{s.seasonNumber}} </span>\\r\\n                        </div>\\r\\n                        <div>\\r\\n                            <span>Request status: </span>\\r\\n                            <span *ngIf=\\\"request.available\\\" class=\\\"label label-success\\\">Available</span>\\r\\n                            <span *ngIf=\\\"request.approved && !request.available\\\" class=\\\"label label-info\\\">Processing Request</span>\\r\\n                            <span *ngIf=\\\"request.denied\\\" class=\\\"label label-danger\\\">Request Denied</span>\\r\\n                            <span *ngIf=\\\"request.deniedReason\\\" title=\\\"{{request.deniedReason}}\\\"><i class=\\\"fa fa-info-circle\\\"></i></span>\\r\\n                            <span *ngIf=\\\"!request.approved && !request.availble && !request.denied\\\" class=\\\"label label-warning\\\">Pending Approval</span>\\r\\n\\r\\n                        </div>\\r\\n                    </div>\\r\\n\\r\\n                </div>\\r\\n\\r\\n            </div>\\r\\n            <div class=\\\"col-sm-3 col-sm-push-3\\\">\\r\\n                <div *ngIf=\\\"isAdmin\\\">\\r\\n                    <div *ngIf=\\\"!request.approved\\\">\\r\\n                        <form>\\r\\n                            <input name=\\\"requestId\\\" type=\\\"text\\\" value=\\\"{{request.requestId}}\\\" hidden=\\\"hidden\\\" />\\r\\n                            <div *ngIf=\\\"request.hasQualities\\\" class=\\\"btn-group btn-split\\\">\\r\\n                                <button type=\\\"button\\\" (click)=\\\"approve(request)\\\" class=\\\"btn btn-sm btn-success-outline approve\\\"><i class=\\\"fa fa-plus\\\"></i> Approve</button>\\r\\n                                <button type=\\\"button\\\" class=\\\"btn btn-success-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"false\\\">\\r\\n                                    <span class=\\\"caret\\\"></span>\\r\\n                                    <span class=\\\"sr-only\\\">Toggle Dropdown</span>\\r\\n                                </button>\\r\\n\\r\\n                                <!--<ul class=\\\"dropdown-menu\\\">\\r\\n                                    {{#each qualities}}\\r\\n                                    <li><a href=\\\"#\\\" class=\\\"approve-with-quality\\\" id=\\\"{{id}}\\\">{{name}}</a></li>\\r\\n                                    {{/each}}\\r\\n                                </ul>-->\\r\\n                            </div>\\r\\n\\r\\n\\r\\n                            <button *ngIf=\\\"!request.hasQualities\\\" (click)=\\\"approve(request)\\\" style=\\\"text-align: right\\\" class=\\\"btn btn-sm btn-success-outline approve\\\" type=\\\"submit\\\"><i class=\\\"fa fa-plus\\\"></i> Approve</button>\\r\\n                        </form>\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n                        <!--<form method=\\\"POST\\\" action=\\\"@formAction/requests/changeRootFolder{{#if_eq type \\\"tv\\\"}}tv{{else}}movie{{/if_eq}}\\\" id=\\\"changeFolder{{requestId}}\\\">\\r\\n                            <input name=\\\"requestId\\\" type=\\\"text\\\" value=\\\"{{requestId}}\\\" hidden=\\\"hidden\\\"/>\\r\\n                            {{#if_eq hasRootFolders true}}\\r\\n                            <div class=\\\"btn-group btn-split\\\">\\r\\n                                <button type=\\\"button\\\" class=\\\"btn btn-sm btn-success-outline\\\" id=\\\"changeRootFolderBtn{{requestId}}\\\" custom-button=\\\"{{requestId}}\\\">@*<i class=\\\"fa fa-plus\\\"></i>*@ Change Root Folder</button>\\r\\n                                <button type=\\\"button\\\" class=\\\"btn btn-success-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"false\\\">\\r\\n                                    <span class=\\\"caret\\\"></span>\\r\\n                                    <span class=\\\"sr-only\\\">@UI.Requests_ToggleDropdown</span>\\r\\n                                </button>\\r\\n                                <ul class=\\\"dropdown-menu\\\">\\r\\n                                    {{#each rootFolders}}\\r\\n                                    <li><a href=\\\"#\\\" class=\\\"change-root-folder\\\" id=\\\"{{id}}\\\" requestId=\\\"{{requestId}}\\\">{{path}}</a></li>\\r\\n                                    {{/each}}\\r\\n                                </ul>\\r\\n                            </div>\\r\\n                            {{/if_eq}}\\r\\n                        </form>-->\\r\\n\\r\\n\\r\\n\\r\\n                        <div *ngIf=\\\"!request.denied\\\">\\r\\n                            <form>\\r\\n                                <input name=\\\"requestId\\\" type=\\\"text\\\" value=\\\"{{request.requestId}}\\\" hidden=\\\"hidden\\\" />\\r\\n                                <input name=\\\"reason\\\" type=\\\"text\\\" hidden=\\\"hidden\\\" />\\r\\n                                <div class=\\\"btn-group btn-split\\\">\\r\\n                                    <button type=\\\"button\\\" (click)=\\\"deny(request)\\\" class=\\\"btn btn-sm btn-danger-outline deny\\\"><i class=\\\"fa fa-times\\\"></i> Deny</button>\\r\\n                                    <button type=\\\"button\\\" class=\\\"btn btn-danger-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"false\\\">\\r\\n                                        <span class=\\\"caret\\\"></span>\\r\\n                                        <span class=\\\"sr-only\\\">@UI.Requests_ToggleDropdown</span>\\r\\n                                    </button>\\r\\n                                    <ul class=\\\"dropdown-menu\\\">\\r\\n                                        <li><a class=\\\"deny-with-reason\\\" id=\\\"denyReason{{request.requestId}}\\\" href=\\\"#\\\" data-toggle=\\\"modal\\\" data-target=\\\"#denyReasonModal\\\">Deny with a reason</a></li>\\r\\n                                    </ul>\\r\\n                                </div>\\r\\n                            </form>\\r\\n                        </div>\\r\\n                    </div>\\r\\n                    <form>\\r\\n                        <button (click)=\\\"removeRequest(request)\\\" style=\\\"text-align: right\\\" class=\\\"btn btn-sm btn-danger-outline delete\\\"><i class=\\\"fa fa-minus\\\"></i> Remove</button>\\r\\n                    </form>\\r\\n\\r\\n                    <form>\\r\\n                        <button *ngIf=\\\"request.available\\\" (click)=\\\"changeAvailability(request, false)\\\" style=\\\"text-align: right\\\" value=\\\"false\\\" class=\\\"btn btn-sm btn-info-outline change\\\"><i class=\\\"fa fa-minus\\\"></i> Mark Unavailable</button>\\r\\n                        <button *ngIf=\\\"!request.available\\\" (click)=\\\"changeAvailability(request, true)\\\" style=\\\"text-align: right\\\" value=\\\"true\\\" class=\\\"btn btn-sm btn-success-outline change\\\"><i class=\\\"fa fa-plus\\\"></i> Mark Available</button>\\r\\n                    </form>\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n                </div>\\r\\n\\r\\n\\r\\n                <input name=\\\"requestId\\\" type=\\\"text\\\" value=\\\"{{request.requestId}}\\\" hidden=\\\"hidden\\\" />\\r\\n                <div class=\\\"dropdown\\\">\\r\\n                    <button id=\\\"{{request.requestId}}\\\" class=\\\"btn btn-sm btn-primary-outline dropdown-toggle\\\" type=\\\"button\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"true\\\">\\r\\n                        <i class=\\\"fa fa-plus\\\"></i> Report Issue\\r\\n                        <span class=\\\"caret\\\"></span>\\r\\n                    </button>\\r\\n                    <ul class=\\\"dropdown-menu\\\" aria-labelledby=\\\"dropdownMenu1\\\">\\r\\n                        <li><a issue-select=\\\"0\\\">@UI.Issues_WrongAudio</a></li>\\r\\n                        <li><a issue-select=\\\"1\\\">@UI.Issues_NoSubs</a></li>\\r\\n                        <li><a issue-select=\\\"2\\\">@UI.Issues_WrongContent</a></li>\\r\\n                        <li><a issue-select=\\\"3\\\">@UI.Issues_Playback</a></li>\\r\\n                        <li><a issue-select=\\\"4\\\" data-toggle=\\\"modal\\\" data-target=\\\"#myModal\\\">@UI.Issues_Other</a></li>\\r\\n                    </ul>\\r\\n                </div>\\r\\n\\r\\n            </div>\\r\\n        </div>\\r\\n        <hr />\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n    </div>\\r\\n</div>\\r\\n\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./ClientApp/app/requests/tvrequests.component.html\n// module id = 180\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 181 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
Sorry, we didn't find any results!
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n \\\"poster\\\"\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n

{{result.title}} ({{result.releaseDate | date: 'yyyy'}})

\\r\\n
\\r\\n\\r\\n\\r\\n Air Date: {{result.firstAired | date: 'dd/MM/yyyy'}}\\r\\n\\r\\n\\r\\n Release Date: {{result.releaseDate | date: 'dd/MM/yyyy'}}\\r\\n\\r\\n Available\\r\\n Processing Request\\r\\n
\\r\\n \\r\\n Pending Approval\\r\\n \\r\\n\\r\\n \\r\\n Not Yet Requested\\r\\n \\r\\n\\r\\n\\r\\n \\r\\n\\r\\n HomePage\\r\\n\\r\\n Trailer\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n

{{result.overview}}

\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n View In Plex\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./ClientApp/app/search/moviesearch.component.html?ae20"],"names":[],"mappings":"AAAA,moDAAmoD,IAAI,8JAA8J,mBAAmB,kMAAkM,WAAW,4DAA4D,cAAc,IAAI,mCAAmC,qKAAqK,wCAAwC,2IAA2I,yCAAyC,0UAA0U,4gBAA4gB,IAAI,0FAA0F,iBAAiB,8IAA8I,gBAAgB,oPAAoP,iBAAiB,0HAA0H,MAAM,6BAA6B,WAAW,2eAA2e,YAAY,oPAAoP,gZAAgZ,WAAW,gPAAgP,oBAAoB,0BAA0B,8BAA8B,yPAAyP,MAAM,0BAA0B,2CAA2C,uCAAuC,IAAI,6CAA6C,eAAe,qBAAqB,MAAM,gCAAgC,KAAK,6DAA6D,eAAe,WAAW,KAAK,gCAAgC,eAAe,sBAAsB,MAAM,oBAAoB,KAAK,mCAAmC,MAAM,2FAA2F,IAAI,iBAAiB,eAAe,qBAAqB,MAAM,qBAAqB,KAAK,yKAAyK,eAAe,sBAAsB,MAAM,qBAAqB,KAAK,0OAA0O,IAAI,wHAAwH,wCAAwC,8CAA8C,IAAI,oIAAoI,IAAI,sKAAsK,IAAI,uIAAuI,QAAQ,kCAAkC,yCAAyC,gFAAgF,IAAI,yIAAyI,QAAQ,yFAAyF,QAAQ,0BAA0B,eAAe,0BAA0B,SAAS,sIAAsI,KAAK,oGAAoG,KAAK,0BAA0B,KAAK,0BAA0B,QAAQ,0BAA0B,QAAQ,+KAA+K,IAAI,+FAA+F,MAAM","file":"181.js","sourcesContent":["module.exports = \"<!-- Movie tab -->\\r\\n<div role=\\\"tabpanel\\\" class=\\\"tab-pane active\\\" id=\\\"MoviesTab\\\">\\r\\n    <div class=\\\"input-group\\\">\\r\\n        <input id=\\\"movieSearchContent\\\" type=\\\"text\\\" class=\\\"form-control form-control-custom form-control-search form-control-withbuttons\\\" (keyup)=\\\"search($event)\\\">\\r\\n        <div class=\\\"input-group-addon\\\">\\r\\n            <div class=\\\"btn-group\\\">\\r\\n                <a href=\\\"#\\\" class=\\\"btn btn-sm btn-primary-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-expanded=\\\"false\\\">\\r\\n                    Suggestions\\r\\n                    <i class=\\\"fa fa-chevron-down\\\"></i>\\r\\n                </a>\\r\\n                <ul class=\\\"dropdown-menu\\\">\\r\\n                    <li><a (click)=\\\"popularMovies()\\\">Popular Movies</a></li>\\r\\n                    <li><a (click)=\\\"upcomingMovies()\\\">Upcoming Movies</a></li>\\r\\n                    <li><a (click)=\\\"topRatedMovies()\\\">Top Rated Movies</a></li>\\r\\n                    <li><a (click)=\\\"nowPlayingMovies()\\\">Now Playing Movies</a></li>\\r\\n                </ul>\\r\\n            </div>\\r\\n            <i id=\\\"movieSearchButton\\\" class=\\\"fa fa-search\\\"></i>\\r\\n        </div>\\r\\n    </div>\\r\\n    <br />\\r\\n    <br />\\r\\n    <!-- Movie content -->\\r\\n    <div id=\\\"movieList\\\">\\r\\n        <div *ngIf=\\\"searchApplied && movieResults?.length <= 0\\\" class='no-search-results'>\\r\\n            <i class='fa fa-film no-search-results-icon'></i><div class='no-search-results-text'>Sorry, we didn't find any results!</div>\\r\\n        </div>\\r\\n\\r\\n        <div *ngFor=\\\"let result of movieResults\\\">\\r\\n            <div class=\\\"row\\\">\\r\\n                <div id=\\\"{{id}}imgDiv\\\" class=\\\"col-sm-2\\\">\\r\\n\\r\\n\\r\\n                    <img *ngIf=\\\"result.posterPath\\\" class=\\\"img-responsive\\\" src=\\\"https://image.tmdb.org/t/p/w150/{{result.posterPath}}\\\" alt=\\\"poster\\\">\\r\\n\\r\\n                </div>\\r\\n                <div class=\\\"col-sm-8\\\">\\r\\n                    <div>\\r\\n                        <a href=\\\"https://www.themoviedb.org/movie/{{result.id}}/\\\" target=\\\"_blank\\\">\\r\\n                            <h4>{{result.title}} ({{result.releaseDate | date: 'yyyy'}})</h4>\\r\\n                        </a>\\r\\n\\r\\n\\r\\n                        <span *ngIf=\\\"result.firstAired\\\" class=\\\"label label-info\\\" target=\\\"_blank\\\">Air Date: {{result.firstAired | date: 'dd/MM/yyyy'}}</span>\\r\\n\\r\\n\\r\\n                        <span *ngIf=\\\"result.releaseDate\\\" class=\\\"label label-info\\\" target=\\\"_blank\\\">Release Date: {{result.releaseDate | date: 'dd/MM/yyyy'}}</span>\\r\\n\\r\\n                        <span *ngIf=\\\"result.available\\\" class=\\\"label label-success\\\">Available</span>\\r\\n                        <span *ngIf=\\\"result.approved && !result.available\\\" class=\\\"label label-info\\\">Processing Request</span>\\r\\n                        <div *ngIf=\\\"result.requested && !result.available; then requested else notRequested\\\"></div>\\r\\n                        <ng-template #requested>\\r\\n                            <span *ngIf=\\\"!result.available\\\" class=\\\"label label-warning\\\">Pending Approval</span>\\r\\n                        </ng-template>\\r\\n\\r\\n                        <ng-template #notRequested>\\r\\n                            <span *ngIf=\\\"!result.available\\\" class=\\\"label label-danger\\\">Not Yet Requested</span>\\r\\n                        </ng-template>\\r\\n\\r\\n\\r\\n                        <span id=\\\"{{id}}netflixTab\\\"></span>\\r\\n\\r\\n                        <a *ngIf=\\\"result.homepage\\\" href=\\\"{{result.homepage}}\\\" target=\\\"_blank\\\"><span class=\\\"label label-info\\\">HomePage</span></a>\\r\\n\\r\\n                        <a *ngIf=\\\"result.trailer\\\" href=\\\"{{result.trailer}}\\\" target=\\\"_blank\\\"><span class=\\\"label label-info\\\">Trailer</span></a>\\r\\n\\r\\n\\r\\n                        <br/>\\r\\n                        <br/>\\r\\n                    </div>\\r\\n                    <p style=\\\"font-size: 0.9rem !important\\\">{{result.overview}}</p>\\r\\n                </div>\\r\\n\\r\\n\\r\\n                <div class=\\\"col-sm-2\\\">\\r\\n                    <input name=\\\"{{type}}Id\\\" type=\\\"text\\\" value=\\\"{{result.id}}\\\" hidden=\\\"hidden\\\"/>\\r\\n\\r\\n                    <div *ngIf=\\\"result.available\\\">\\r\\n                        <button style=\\\"text-align: right\\\" class=\\\"btn btn-success-outline disabled\\\" disabled><i class=\\\"fa fa-check\\\"></i> Available</button>\\r\\n\\r\\n                        <div *ngIf=\\\"result.url\\\">\\r\\n                            <br/>\\r\\n                            <br/>\\r\\n                            <a style=\\\"text-align: right\\\" class=\\\"btn btn-sm btn-primary-outline\\\" href=\\\"{{result.url}}\\\" target=\\\"_blank\\\"><i class=\\\"fa fa-eye\\\"></i> View In Plex</a>\\r\\n\\r\\n                        </div>\\r\\n                    </div>\\r\\n                    <div *ngIf=\\\"!result.available\\\">\\r\\n                    <div *ngIf=\\\"result.requested; then requestedBtn else notRequestedBtn\\\"></div>\\r\\n                    <ng-template #requestedBtn>\\r\\n                        <button style=\\\"text-align: right\\\" class=\\\"btn btn-primary-outline disabled\\\" [disabled]><i class=\\\"fa fa-check\\\"></i> Requested</button>\\r\\n                    </ng-template>\\r\\n                    <ng-template #notRequestedBtn>\\r\\n                        <button id=\\\"{{result.id}}\\\" style=\\\"text-align: right\\\" class=\\\"btn btn-primary-outline\\\" (click)=\\\"request(result)\\\"><i class=\\\"fa fa-plus\\\"></i> Request</button>\\r\\n                    </ng-template>\\r\\n                        </div>\\r\\n                    <!--{{#if_eq type \\\"tv\\\"}}\\r\\n                    {{#if_eq tvFullyAvailable true}}\\r\\n                    @*//TODO Not used yet*@\\r\\n                    <button style=\\\"text-align: right\\\" class=\\\"btn btn-success-outline disabled\\\" disabled><i class=\\\"fa fa-check\\\"></i> @UI.Search_Available</button><br/>\\r\\n                    {{else}}\\r\\n                    {{#if_eq enableTvRequestsForOnlySeries true}}\\r\\n                    <button id=\\\"{{id}}\\\" style=\\\"text-align: right\\\" class=\\\"btn {{#if available}}btn-success-outline{{else}}btn-primary-outline dropdownTv{{/if}} btn-primary-outline\\\" season-select=\\\"0\\\" type=\\\"button\\\" {{#if available}} disabled{{/if}}><i class=\\\"fa fa-plus\\\"></i> {{#if available}}@UI.Search_Available{{else}}@UI.Search_Request{{/if}}</button>\\r\\n                    {{else}}\\r\\n                    <div class=\\\"dropdown\\\">\\r\\n                        <button id=\\\"{{id}}\\\" class=\\\"btn {{#if available}}btn-success-outline{{else}}btn-primary-outline{{/if}} dropdown-toggle\\\" type=\\\"button\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"true\\\">\\r\\n                            <i class=\\\"fa fa-plus\\\"></i> {{#if available}}@UI.Search_Available{{else}}@UI.Search_Request {{/if}}\\r\\n                            <span class=\\\"caret\\\"></span>\\r\\n                        </button>\\r\\n                        <ul class=\\\"dropdown-menu\\\" aria-labelledby=\\\"dropdownMenu1\\\">\\r\\n                            <li><a id=\\\"{{id}}\\\" season-select=\\\"0\\\" class=\\\"dropdownTv \\\" href=\\\"#\\\">@UI.Search_AllSeasons</a></li>\\r\\n                            {{#if_eq disableTvRequestsBySeason false}}\\r\\n                            <li><a id=\\\"{{id}}\\\" season-select=\\\"1\\\" class=\\\"dropdownTv\\\" href=\\\"#\\\">@UI.Search_FirstSeason</a></li>\\r\\n                            <li><a id=\\\"{{id}}\\\" season-select=\\\"2\\\" class=\\\"dropdownTv\\\" href=\\\"#\\\">@UI.Search_LatestSeason</a></li>\\r\\n                            <li><a id=\\\"SeasonSelect\\\" data-identifier=\\\"{{id}}\\\" data-toggle=\\\"modal\\\" data-target=\\\"#seasonsModal\\\" href=\\\"#\\\">@UI.Search_SelectSeason...</a></li>\\r\\n                            {{/if_eq}}\\r\\n                            {{#if_eq disableTvRequestsByEpisode false}}\\r\\n                            <li><a id=\\\"EpisodeSelect\\\" data-identifier=\\\"{{id}}\\\" data-toggle=\\\"modal\\\" data-target=\\\"#episodesModal\\\" href=\\\"#\\\">@UI.Search_SelectEpisode...</a></li>\\r\\n                            {{/if_eq}}\\r\\n                        </ul>\\r\\n                    </div>\\r\\n                    {{/if_eq}}\\r\\n                    {{#if available}}\\r\\n                    {{#if url}}\\r\\n                    <br/>\\r\\n                    <a style=\\\"text-align: right\\\" class=\\\"btn btn-sm btn-primary-outline\\\" href=\\\"{{url}}\\\" target=\\\"_blank\\\"><i class=\\\"fa fa-eye\\\"></i> @UI.Search_ViewInPlex</a>\\r\\n                    {{/if}}\\r\\n                    {{/if}}\\r\\n                    {{/if_eq}}\\r\\n                    {{/if_eq}}-->\\r\\n\\r\\n\\r\\n                    <br/>\\r\\n                    <div *ngIf=\\\"result.available\\\">\\r\\n                        <input name=\\\"providerId\\\" type=\\\"text\\\" value=\\\"{{id}}\\\" hidden=\\\"hidden\\\"/>\\r\\n                        <input name=\\\"type\\\" type=\\\"text\\\" value=\\\"{{type}}\\\" hidden=\\\"hidden\\\"/>\\r\\n                        <div class=\\\"dropdown\\\">\\r\\n                            <button class=\\\"btn btn-sm btn-danger-outline dropdown-toggle\\\" type=\\\"button\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"true\\\">\\r\\n                                <i class=\\\"fa fa-exclamation\\\"></i> @UI.Search_ReportIssue\\r\\n                                <span class=\\\"caret\\\"></span>\\r\\n                            </button>\\r\\n                            <ul class=\\\"dropdown-menu\\\" aria-labelledby=\\\"dropdownMenu1\\\">\\r\\n                                <li><a issue-select=\\\"0\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\">WrongAudio</a></li>\\r\\n                                <li><a issue-select=\\\"1\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\">NoSubs</a></li>\\r\\n                                <li><a issue-select=\\\"2\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\">WrongContent</a></li>\\r\\n                                <li><a issue-select=\\\"3\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\">Playback</a></li>\\r\\n                                <li><a issue-select=\\\"4\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\" data-toggle=\\\"modal\\\" data-target=\\\"#issuesModal\\\">Other</a></li>\\r\\n                            </ul>\\r\\n                        </div>\\r\\n                    </div>\\r\\n\\r\\n                </div>\\r\\n\\r\\n            </div>\\r\\n            <hr/>\\r\\n        </div>\\r\\n\\r\\n    </div>\\r\\n</div>\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./ClientApp/app/search/moviesearch.component.html\n// module id = 181\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 182 */ -/***/ (function(module, exports) { - -eval("module.exports = \"

Search

\\r\\n

Want to watch something that is not currently available?! No problem! Just search for it below and request it!

\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n
    \\r\\n\\r\\n
  • \\r\\n Movies\\r\\n
  • \\r\\n\\r\\n \\r\\n\\r\\n
  • \\r\\n TV Shows\\r\\n\\r\\n
  • \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n Content 2\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3NlYXJjaC9zZWFyY2guY29tcG9uZW50Lmh0bWw/ZGI0MyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSIsImZpbGUiOiIxODIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IFwiPGgxIGlkPVxcXCJzZWFyY2hUaXRsZVxcXCI+U2VhcmNoPC9oMT5cXHJcXG48aDQ+V2FudCB0byB3YXRjaCBzb21ldGhpbmcgdGhhdCBpcyBub3QgY3VycmVudGx5IGF2YWlsYWJsZT8hIE5vIHByb2JsZW0hIEp1c3Qgc2VhcmNoIGZvciBpdCBiZWxvdyBhbmQgcmVxdWVzdCBpdCE8L2g0PlxcclxcbjxiciAvPlxcclxcbjwhLS0gTmF2IHRhYnMgLS0+XFxyXFxuXFxyXFxuXFxyXFxuPHVsIGlkPVxcXCJuYXYtdGFic1xcXCIgY2xhc3M9XFxcIm5hdiBuYXYtdGFic1xcXCIgcm9sZT1cXFwidGFibGlzdFxcXCI+XFxyXFxuXFxyXFxuICAgIDxsaSByb2xlPVxcXCJwcmVzZW50YXRpb25cXFwiIGNsYXNzPVxcXCJhY3RpdmVcXFwiPlxcclxcbiAgICAgICAgPGEgaWQ9XFxcIm1vdmllVGFiQnV0dG9uXFxcIiBocmVmPVxcXCIjTW92aWVzVGFiXFxcIiBhcmlhLWNvbnRyb2xzPVxcXCJob21lXFxcIiByb2xlPVxcXCJ0YWJcXFwiIGRhdGEtdG9nZ2xlPVxcXCJ0YWJcXFwiIChjbGljayk9XFxcInNlbGVjdFRhYigpXFxcIj48aSBjbGFzcz1cXFwiZmEgZmEtZmlsbVxcXCI+PC9pPiBNb3ZpZXM8L2E+XFxyXFxuICAgIDwvbGk+XFxyXFxuXFxyXFxuICAgIDwhLS08bGkgcm9sZT1cXFwicHJlc2VudGF0aW9uXFxcIj5cXHJcXG4gICAgICAgIDxhIGlkPVxcXCJhY3RvclRhYkJ1dHRvblxcXCIgaHJlZj1cXFwiI0FjdG9yc1RhYlxcXCIgYXJpYS1jb250cm9scz1cXFwicHJvZmlsZVxcXCIgcm9sZT1cXFwidGFiXFxcIiBkYXRhLXRvZ2dsZT1cXFwidGFiXFxcIj48aSBjbGFzcz1cXFwiZmEgZmEtdXNlcnNcXFwiPjwvaT4gQWN0b3JzPC9hPlxcclxcblxcclxcbiAgICA8L2xpPi0tPlxcclxcblxcclxcbiAgICA8bGkgcm9sZT1cXFwicHJlc2VudGF0aW9uXFxcIj5cXHJcXG4gICAgICAgIDxhIGlkPVxcXCJ0dlRhYkJ1dHRvblxcXCIgaHJlZj1cXFwiI1R2U2hvd1RhYlxcXCIgYXJpYS1jb250cm9scz1cXFwicHJvZmlsZVxcXCIgcm9sZT1cXFwidGFiXFxcIiBkYXRhLXRvZ2dsZT1cXFwidGFiXFxcIiAoY2xpY2spPVxcXCJzZWxlY3RUYWIoKVxcXCI+PGkgY2xhc3M9XFxcImZhIGZhLXRlbGV2aXNpb25cXFwiPjwvaT4gVFYgU2hvd3M8L2E+XFxyXFxuXFxyXFxuICAgIDwvbGk+XFxyXFxuICAgIDwhLS1cXHJcXG4gICAgIDxsaSByb2xlPVxcXCJwcmVzZW50YXRpb25cXFwiPlxcclxcbiAgICAgICAgIDxhIGhyZWY9XFxcIiNNdXNpY1RhYlxcXCIgYXJpYS1jb250cm9scz1cXFwicHJvZmlsZVxcXCIgcm9sZT1cXFwidGFiXFxcIiBkYXRhLXRvZ2dsZT1cXFwidGFiXFxcIj48aSBjbGFzcz1cXFwiZmEgZmEtbXVzaWNcXFwiPjwvaT4gQWxidW1zPC9hPlxcclxcbiAgICAgPC9saT4tLT5cXHJcXG5cXHJcXG48L3VsPlxcclxcblxcclxcbjwhLS0gVGFiIHBhbmVzIC0tPlxcclxcbjxkaXYgY2xhc3M9XFxcInRhYi1jb250ZW50XFxcIj5cXHJcXG5cXHJcXG4gICAgPGRpdiBbaGlkZGVuXT1cXFwiIXNob3dNb3ZpZVxcXCI+XFxyXFxuICAgICAgICA8bW92aWUtc2VhcmNoPjwvbW92aWUtc2VhcmNoPlxcclxcbiAgICAgICAgPG1kLXRhYi1ncm91cD5cXHJcXG4gICAgICAgICAgICA8bWQtdGFiIGxhYmVsPVxcXCJUYWIgMVxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxpbnB1dCBtZElucHV0IHBsYWNlaG9sZGVyPVxcXCJNb3ZpZSBTZWFyY2hcXFwiIHZhbHVlPVxcXCJkXFxcIj5cXHJcXG4gICAgICAgICAgICA8L21kLXRhYj5cXHJcXG4gICAgICAgICAgICA8bWQtdGFiIGxhYmVsPVxcXCJUYWIgMlxcXCI+Q29udGVudCAyPC9tZC10YWI+XFxyXFxuICAgICAgICA8L21kLXRhYi1ncm91cD5cXHJcXG4gICAgPC9kaXY+XFxyXFxuXFxyXFxuICAgIDwhLS1cXHJcXG4gICAgPGRpdiByb2xlPVxcXCJ0YWJwYW5lbFxcXCIgY2xhc3M9XFxcInRhYi1wYW5lXFxcIiBpZD1cXFwiQWN0b3JzVGFiXFxcIj5cXHJcXG4gICAgICAgIDxkaXYgY2xhc3M9XFxcImlucHV0LWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8aW5wdXQgaWQ9XFxcImFjdG9yU2VhcmNoQ29udGVudFxcXCIgdHlwZT1cXFwidGV4dFxcXCIgY2xhc3M9XFxcImZvcm0tY29udHJvbCBmb3JtLWNvbnRyb2wtY3VzdG9tIGZvcm0tY29udHJvbC1zZWFyY2ggZm9ybS1jb250cm9sLXdpdGhidXR0b25zXFxcIj5cXHJcXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVxcXCJpbnB1dC1ncm91cC1hZGRvblxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxpIGlkPVxcXCJhY3RvclNlYXJjaEJ1dHRvblxcXCIgY2xhc3M9XFxcImZhIGZhLXNlYXJjaFxcXCI+PC9pPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJjaGVja2JveFxcXCI+XFxyXFxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XFxcImNoZWNrYm94XFxcIiBpZD1cXFwiYWN0b3JzU2VhcmNoTmV3XFxcIiBuYW1lPVxcXCJhY3RvcnNTZWFyY2hOZXdcXFwiPjxsYWJlbCBmb3I9XFxcImFjdG9yc1NlYXJjaE5ld1xcXCI+QFVJLlNlYXJjaF9OZXdPbmx5PC9sYWJlbD5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcblxcclxcbiAgICAgICAgPGJyIC8+XFxyXFxuICAgICAgICA8YnIgLz5cXHJcXG4gICAgICAgIDxkaXYgaWQ9XFxcImFjdG9yTW92aWVMaXN0XFxcIj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcbiAgICA8L2Rpdj4tLT5cXHJcXG5cXHJcXG5cXHJcXG4gICAgPGRpdiBbaGlkZGVuXT1cXFwiIXNob3dUdlxcXCI+XFxyXFxuICAgICAgICA8dHYtc2VhcmNoPjwvdHYtc2VhcmNoPlxcclxcblxcclxcbiAgICA8L2Rpdj5cXHJcXG48L2Rpdj5cXHJcXG5cXHJcXG5cXHJcXG5cIjtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL0NsaWVudEFwcC9hcHAvc2VhcmNoL3NlYXJjaC5jb21wb25lbnQuaHRtbFxuLy8gbW9kdWxlIGlkID0gMTgyXG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0="); - -/***/ }), -/* 183 */ -/***/ (function(module, exports) { - -eval("module.exports = \"
\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n

Season: {{season.seasonNumber}}

\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n #\\r\\n \\r\\n \\r\\n \\r\\n Title\\r\\n \\r\\n \\r\\n \\r\\n Air Date\\r\\n \\r\\n \\r\\n \\r\\n Status\\r\\n \\r\\n
\\r\\n {{ep.episodeNumber}}\\r\\n \\r\\n {{ep.title}}\\r\\n \\r\\n {{ep.airDate | date: 'dd/MM/yyyy' }}\\r\\n \\r\\n Available\\r\\n Processing Request\\r\\n
\\r\\n \\r\\n Pending Approval\\r\\n \\r\\n\\r\\n \\r\\n Not Yet Requested\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3NlYXJjaC9zZXJpZXNpbmZvcm1hdGlvbi5jb21wb25lbnQuaHRtbD83NDYyIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGdVQUFnVSxxQkFBcUIsaXNDQUFpc0Msa0JBQWtCLCtHQUErRyxVQUFVLCtHQUErRyxrQ0FBa0MsNFlBQTRZIiwiZmlsZSI6IjE4My5qcyIsInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gXCI8ZGl2ICpuZ0lmPVxcXCJzZXJpZXNcXFwiPlxcclxcbiAgICBcXHJcXG4gICAgPG5nYi10YWJzZXQ+XFxyXFxuICAgICAgICAgICAgIFxcclxcbiAgICAgICAgPGRpdiAqbmdGb3I9XFxcImxldCBzZWFzb24gb2Ygc2VyaWVzLnNlYXNvblJlcXVlc3RzXFxcIj5cXHJcXG4gICAgICAgICAgICA8bmdiLXRhYiBbaWRdPVxcXCJzZWFzb24uc2Vhc29uTnVtYmVyXFxcIiBbdGl0bGVdPVxcXCJzZWFzb24uc2Vhc29uTnVtYmVyXFxcIj5cXHJcXG4gICAgICAgICAgICAgICAgPG5nLXRlbXBsYXRlIG5nYlRhYkNvbnRlbnQ+XFxyXFxuICAgICAgICAgICAgICAgICAgICA8aDI+U2Vhc29uOiB7e3NlYXNvbi5zZWFzb25OdW1iZXJ9fTwvaDI+XFxyXFxuXFxyXFxuICAgICAgICAgICAgICAgICAgICA8dGFibGUgY2xhc3M9XFxcInRhYmxlIHRhYmxlLXN0cmlwZWQgdGFibGUtaG92ZXIgdGFibGUtcmVzcG9uc2l2ZSB0YWJsZS1jb25kZW5zZWRcXFwiPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgIDx0aGVhZD5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICA8dHI+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDx0aD5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICNcXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvYT5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC90aD5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRoPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGE+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVGl0bGVcXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvYT5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC90aD5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRoPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGE+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgQWlyIERhdGVcXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvYT5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC90aD5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRoPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGE+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgU3RhdHVzXFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2E+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvdGg+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICA8L3RoZWFkPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgIDx0Ym9keT5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICA8dHIgKm5nRm9yPVxcXCJsZXQgZXAgb2Ygc2Vhc29uLmVwaXNvZGVzXFxcIj5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAge3tlcC5lcGlzb2RlTnVtYmVyfX1cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC90ZD5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAge3tlcC50aXRsZX19XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvdGQ+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDx0ZD5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHt7ZXAuYWlyRGF0ZSB8IGRhdGU6ICdkZC9NTS95eXl5JyB9fVxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQ+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8c3BhbiAqbmdJZj1cXFwiZXAuYXZhaWxhYmxlXFxcIiBjbGFzcz1cXFwibGFiZWwgbGFiZWwtc3VjY2Vzc1xcXCI+QXZhaWxhYmxlPC9zcGFuPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW4gKm5nSWY9XFxcImVwLmFwcHJvdmVkICYmICFlcC5hdmFpbGFibGVcXFwiIGNsYXNzPVxcXCJsYWJlbCBsYWJlbC1pbmZvXFxcIj5Qcm9jZXNzaW5nIFJlcXVlc3Q8L3NwYW4+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8ZGl2ICpuZ0lmPVxcXCJlcC5yZXF1ZXN0ZWQgJiYgIWVwLmF2YWlsYWJsZTsgdGhlbiByZXF1ZXN0ZWQgZWxzZSBub3RSZXF1ZXN0ZWRcXFwiPjwvZGl2PlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPG5nLXRlbXBsYXRlICNyZXF1ZXN0ZWQ+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW4gKm5nSWY9XFxcIiFlcC5hdmFpbGFibGVcXFwiIGNsYXNzPVxcXCJsYWJlbCBsYWJlbC13YXJuaW5nXFxcIj5QZW5kaW5nIEFwcHJvdmFsPC9zcGFuPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cXHJcXG5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSAjbm90UmVxdWVzdGVkPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuICpuZ0lmPVxcXCIhZXAuYXZhaWxhYmxlXFxcIiBjbGFzcz1cXFwibGFiZWwgbGFiZWwtZGFuZ2VyXFxcIj5Ob3QgWWV0IFJlcXVlc3RlZDwvc3Bhbj5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvdGQ+XFxyXFxuXFxyXFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDx0ZD5cXHJcXG5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxidXR0b24gKGNsaWNrKT1cXFwiYWRkUmVxdWVzdChlcClcXFwiIFtkaXNhYmxlZF09XFxcImVwLmF2YWlsYWJsZSB8fCBlcC5yZXF1ZXN0ZWQgfHwgZXAuYXBwcm92ZWRcXFwiIGNsYXNzPVxcXCJidG4gYnRuLXNtIGJ0bi1wcmltYXJ5LW91dGxpbmVcXFwiPlJlcXVlc3Q8L2J1dHRvbj5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC90ZD5cXHJcXG4gICAgICAgICAgICAgICAgICAgICAgICA8L3RyPlxcclxcbiAgICAgICAgICAgICAgICAgICAgICAgIDwvdGJvZHk+XFxyXFxuICAgICAgICAgICAgICAgICAgICA8L3RhYmxlPlxcclxcbiAgICAgICAgICAgICAgICA8L25nLXRlbXBsYXRlPlxcclxcbiAgICAgICAgICAgIDwvbmdiLXRhYj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcbiAgICA8L25nYi10YWJzZXQ+XFxyXFxuXFxyXFxuICAgXFxyXFxuICAgIFxcclxcbiAgICBcXHJcXG4gICAgPGJ1dHRvbiBpZD1cXFwicmVxdWVzdEZsb2F0aW5nQnRuXFxcIiBjbGFzcz1cXFwiYnRuIGJ0bi1zbSBidG4tc3VjY2Vzc1xcXCIgdGl0bGU9XFxcIkdvIHRvIHRvcFxcXCI+UmVxdWVzdDwvYnV0dG9uPlxcclxcbjwvZGl2PlxcclxcblwiO1xuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIC4vQ2xpZW50QXBwL2FwcC9zZWFyY2gvc2VyaWVzaW5mb3JtYXRpb24uY29tcG9uZW50Lmh0bWxcbi8vIG1vZHVsZSBpZCA9IDE4M1xuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 184 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
Sorry, we didn't find any results!
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n \\\"poster\\\"\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n

{{result.title}} ({{result.firstAired}})

\\r\\n\\r\\n
\\r\\n\\r\\n {{result.status}}\\r\\n\\r\\n\\r\\n Air Date: {{result.firstAired}}\\r\\n\\r\\n\\r\\n Release Date: {{result.releaseDate | date: 'dd/MM/yyyy'}}\\r\\n\\r\\n Available\\r\\n Processing Request\\r\\n
\\r\\n \\r\\n Pending Approval\\r\\n \\r\\n\\r\\n \\r\\n Not Yet Requested\\r\\n \\r\\n\\r\\n\\r\\n \\r\\n\\r\\n HomePage\\r\\n\\r\\n Trailer\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n

{{result.overview}}

\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n View In Plex\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n\\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./ClientApp/app/search/tvsearch.component.html?5f07"],"names":[],"mappings":"AAAA,yhEAAyhE,eAAe,4DAA4D,cAAc,IAAI,mBAAmB,0JAA0J,eAAe,sIAAsI,mBAAmB,2IAA2I,yCAAyC,0UAA0U,4gBAA4gB,IAAI,0FAA0F,iBAAiB,8IAA8I,gBAAgB,oPAAoP,iBAAiB,0HAA0H,MAAM,6BAA6B,WAAW,2eAA2e,YAAY,+LAA+L,uYAAuY,WAAW,kNAAkN,oBAAoB,0BAA0B,8BAA8B,yPAAyP,MAAM,0BAA0B,2CAA2C,uCAAuC,IAAI,6CAA6C,eAAe,qBAAqB,MAAM,gCAAgC,KAAK,6DAA6D,eAAe,WAAW,KAAK,gCAAgC,eAAe,sBAAsB,MAAM,oBAAoB,KAAK,mCAAmC,MAAM,0lCAA0lC,KAAK,qRAAqR,IAAI,+FAA+F,MAAM","file":"184.js","sourcesContent":["module.exports = \"<!-- Movie tab -->\\r\\n<div role=\\\"tabpanel\\\" class=\\\"tab-pane\\\" id=\\\"TvShowTab\\\">\\r\\n    <div class=\\\"input-group\\\">\\r\\n        <input id=\\\"tvSearchContent\\\" type=\\\"text\\\" class=\\\"form-control form-control-custom form-control-search form-control-withbuttons\\\" (keyup)=\\\"search($event)\\\">\\r\\n        <div class=\\\"input-group-addon\\\">\\r\\n            <div class=\\\"btn-group\\\">\\r\\n                <a href=\\\"#\\\" class=\\\"btn btn-sm btn-primary-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-expanded=\\\"false\\\">\\r\\n                    Suggestions\\r\\n                    <i class=\\\"fa fa-chevron-down\\\"></i>\\r\\n                </a>\\r\\n                <ul class=\\\"dropdown-menu\\\">\\r\\n                    <li><a (click)=\\\"popularShows()\\\">Popular Shows</a></li>\\r\\n                    <li><a (click)=\\\"trendingShows()\\\">Trending Shows</a></li>\\r\\n                    <li><a (click)=\\\"mostWatchedShows()\\\">Most Watched Shows</a></li>\\r\\n                    <li><a (click)=\\\"anticipatedShows()\\\">Most Anticipated Shows</a></li>\\r\\n                </ul>\\r\\n            </div><i id=\\\"tvSearchButton\\\" class=\\\"fa fa-search\\\"></i>\\r\\n        </div>\\r\\n    </div>\\r\\n    <br />\\r\\n    <br />\\r\\n    <!-- Movie content -->\\r\\n    <div id=\\\"actorMovieList\\\">\\r\\n    </div>\\r\\n\\r\\n\\r\\n<br />\\r\\n    <br />\\r\\n    <!-- TV content -->\\r\\n    <div id=\\\"tvList\\\">\\r\\n        \\r\\n        <div *ngIf=\\\"searchApplied && tvResults?.length <= 0\\\" class='no-search-results'>\\r\\n            <i class='fa fa-film no-search-results-icon'></i><div class='no-search-results-text'>Sorry, we didn't find any results!</div>\\r\\n        </div>\\r\\n\\r\\n        <div *ngFor=\\\"let result of tvResults\\\">\\r\\n            <div class=\\\"row\\\">\\r\\n                <div class=\\\"col-sm-2\\\">\\r\\n\\r\\n                    <img *ngIf=\\\"result.banner\\\" class=\\\"img-responsive\\\" width=\\\"150\\\" [src]=\\\"result.banner\\\" alt=\\\"poster\\\">\\r\\n\\r\\n                </div>\\r\\n                <div class=\\\"col-sm-8\\\">\\r\\n                    <div>\\r\\n\\r\\n                        <a href=\\\"http://www.imdb.com/title/{{result.imdbId}}/\\\" target=\\\"_blank\\\">\\r\\n                            <h4>{{result.title}} ({{result.firstAired}})</h4>\\r\\n\\r\\n                        </a>\\r\\n\\r\\n                        <span *ngIf=\\\"result.status\\\" class=\\\"label label-primary\\\" target=\\\"_blank\\\">{{result.status}}</span>\\r\\n\\r\\n\\r\\n                        <span *ngIf=\\\"result.firstAired\\\" class=\\\"label label-info\\\" target=\\\"_blank\\\">Air Date: {{result.firstAired}}</span>\\r\\n\\r\\n\\r\\n                        <span *ngIf=\\\"result.releaseDate\\\" class=\\\"label label-info\\\" target=\\\"_blank\\\">Release Date: {{result.releaseDate | date: 'dd/MM/yyyy'}}</span>\\r\\n\\r\\n                        <span *ngIf=\\\"result.available\\\" class=\\\"label label-success\\\">Available</span>\\r\\n                        <span *ngIf=\\\"result.approved && !result.available\\\" class=\\\"label label-info\\\">Processing Request</span>\\r\\n                        <div *ngIf=\\\"result.requested && !result.available; then requested else notRequested\\\"></div>\\r\\n                        <ng-template #requested>\\r\\n                            <span *ngIf=\\\"!result.available\\\" class=\\\"label label-warning\\\">Pending Approval</span>\\r\\n                        </ng-template>\\r\\n\\r\\n                        <ng-template #notRequested>\\r\\n                            <span *ngIf=\\\"!result.available\\\" class=\\\"label label-danger\\\">Not Yet Requested</span>\\r\\n                        </ng-template>\\r\\n\\r\\n\\r\\n                        <span id=\\\"{{id}}netflixTab\\\"></span>\\r\\n\\r\\n                        <a *ngIf=\\\"result.homepage\\\" href=\\\"{{result.homepage}}\\\" target=\\\"_blank\\\"><span class=\\\"label label-info\\\">HomePage</span></a>\\r\\n\\r\\n                        <a *ngIf=\\\"result.trailer\\\" href=\\\"{{result.trailer}}\\\" target=\\\"_blank\\\"><span class=\\\"label label-info\\\">Trailer</span></a>\\r\\n\\r\\n\\r\\n                        <br/>\\r\\n                        <br/>\\r\\n                    </div>\\r\\n                    <p style=\\\"font-size: 0.9rem !important\\\">{{result.overview}}</p>\\r\\n                </div>\\r\\n\\r\\n\\r\\n                <div class=\\\"col-sm-2\\\">\\r\\n                    <input name=\\\"{{type}}Id\\\" type=\\\"text\\\" value=\\\"{{result.id}}\\\" hidden=\\\"hidden\\\"/>\\r\\n\\r\\n                    <div *ngIf=\\\"result.available\\\">\\r\\n                        <button style=\\\"text-align: right\\\" class=\\\"btn btn-success-outline disabled\\\" disabled><i class=\\\"fa fa-check\\\"></i> Available</button>\\r\\n\\r\\n                        <div *ngIf=\\\"result.url\\\">\\r\\n                            <br/>\\r\\n                            <br/>\\r\\n                            <a style=\\\"text-align: right\\\" class=\\\"btn btn-sm btn-primary-outline\\\" href=\\\"{{result.url}}\\\" target=\\\"_blank\\\"><i class=\\\"fa fa-eye\\\"></i> View In Plex</a>\\r\\n\\r\\n                        </div>\\r\\n                    </div>\\r\\n                    <!--<div *ngIf=\\\"result.requested; then requestedBtn else notRequestedBtn\\\"></div>\\r\\n                    <template #requestedBtn>\\r\\n                        <button style=\\\"text-align: right\\\" class=\\\"btn btn-primary-outline disabled\\\" [disabled]><i class=\\\"fa fa-check\\\"></i> Requested</button>\\r\\n                    </template>\\r\\n                    <template #notRequestedBtn>\\r\\n                        <button id=\\\"{{result.id}}\\\" style=\\\"text-align: right\\\" class=\\\"btn btn-primary-outline\\\" (click)=\\\"request(result)\\\"><i class=\\\"fa fa-plus\\\"></i> Request</button>\\r\\n                    </template>-->\\r\\n\\r\\n                    <!--{{#if_eq type \\\"tv\\\"}}\\r\\n                    {{#if_eq tvFullyAvailable true}}\\r\\n                    @*//TODO Not used yet*@\\r\\n                    <button style=\\\"text-align: right\\\" class=\\\"btn btn-success-outline disabled\\\" disabled><i class=\\\"fa fa-check\\\"></i> @UI.Search_Available</button><br/>\\r\\n                    {{else}}\\r\\n                    {{#if_eq enableTvRequestsForOnlySeries true}}\\r\\n                    <button id=\\\"{{id}}\\\" style=\\\"text-align: right\\\" class=\\\"btn {{#if available}}btn-success-outline{{else}}btn-primary-outline dropdownTv{{/if}} btn-primary-outline\\\" season-select=\\\"0\\\" type=\\\"button\\\" {{#if available}} disabled{{/if}}><i class=\\\"fa fa-plus\\\"></i> {{#if available}}@UI.Search_Available{{else}}@UI.Search_Request{{/if}}</button>\\r\\n                    {{else}}\\r\\n                    -->\\r\\n                    <div class=\\\"dropdown\\\">\\r\\n                        <button class=\\\"btn btn-primary-outline dropdown-toggle\\\" type=\\\"button\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"true\\\">\\r\\n                            <i class=\\\"fa fa-plus\\\"></i> Request\\r\\n                            <span class=\\\"caret\\\"></span>\\r\\n                        </button>\\r\\n                        <ul class=\\\"dropdown-menu\\\" aria-labelledby=\\\"dropdownMenu1\\\">\\r\\n                            <li><a (click)=\\\"allSeasons(result)\\\">All Seasons</a></li>\\r\\n                            <li><a (click)=\\\"firstSeason(result)\\\">First Season</a></li>\\r\\n                            <li><a (click)=\\\"latestSeason(result)\\\">Latest Season</a></li>\\r\\n                            <li><a (click)=\\\"selectSeason(result)\\\">Select ...</a></li>\\r\\n                        </ul>\\r\\n                    </div>\\r\\n              \\r\\n                    <!--\\r\\n                    <br/>\\r\\n                    <a style=\\\"text-align: right\\\" class=\\\"btn btn-sm btn-primary-outline\\\" href=\\\"{{url}}\\\" target=\\\"_blank\\\"><i class=\\\"fa fa-eye\\\"></i> @UI.Search_ViewInPlex</a>\\r\\n\\r\\n                    -->\\r\\n\\r\\n\\r\\n                    <br/>\\r\\n                    <div *ngIf=\\\"result.available\\\">\\r\\n                        <input name=\\\"providerId\\\" type=\\\"text\\\" value=\\\"{{id}}\\\" hidden=\\\"hidden\\\"/>\\r\\n                        <input name=\\\"type\\\" type=\\\"text\\\" value=\\\"{{type}}\\\" hidden=\\\"hidden\\\"/>\\r\\n                        <div class=\\\"dropdown\\\">\\r\\n                            <button class=\\\"btn btn-sm btn-danger-outline dropdown-toggle\\\" type=\\\"button\\\" data-toggle=\\\"dropdown\\\" aria-haspopup=\\\"true\\\" aria-expanded=\\\"true\\\">\\r\\n                                <i class=\\\"fa fa-exclamation\\\"></i> @UI.Search_ReportIssue\\r\\n                                <span class=\\\"caret\\\"></span>\\r\\n                            </button>\\r\\n                            <ul class=\\\"dropdown-menu\\\" aria-labelledby=\\\"dropdownMenu1\\\">\\r\\n                                <li><a issue-select=\\\"0\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\">WrongAudio</a></li>\\r\\n                                <li><a issue-select=\\\"1\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\">NoSubs</a></li>\\r\\n                                <li><a issue-select=\\\"2\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\">WrongContent</a></li>\\r\\n                                <li><a issue-select=\\\"3\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\">Playback</a></li>\\r\\n                                <li><a issue-select=\\\"4\\\" class=\\\"dropdownIssue\\\" href=\\\"#\\\" data-toggle=\\\"modal\\\" data-target=\\\"#issuesModal\\\">Other</a></li>\\r\\n                            </ul>\\r\\n                        </div>\\r\\n                    </div>\\r\\n\\r\\n                </div>\\r\\n\\r\\n            </div>\\r\\n            <hr/>\\r\\n        </div>\\r\\n\\r\\n    </div>\\r\\n</div>\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./ClientApp/app/search/tvsearch.component.html\n// module id = 184\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 185 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n
\\r\\n Customization\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n This will be used on all of the notifications e.g. Newsletter, email notification and also the Landing page\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3NldHRpbmdzL2N1c3RvbWl6YXRpb24vY3VzdG9taXphdGlvbi5jb21wb25lbnQuaHRtbD9iOWUzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDJlQUEyZSwwQkFBMEIsd1ZBQXdWLGVBQWUiLCJmaWxlIjoiMTg1LmpzIiwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHMgPSBcIjxzZXR0aW5ncy1tZW51Pjwvc2V0dGluZ3MtbWVudT5cXHJcXG4gICAgPGZpZWxkc2V0ICpuZ0lmPVxcXCJzZXR0aW5nc1xcXCI+XFxyXFxuICAgICAgICA8bGVnZW5kPkN1c3RvbWl6YXRpb248L2xlZ2VuZD5cXHJcXG5cXHJcXG4gICAgICAgIDxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICAgICAgICAgIDxsYWJlbCBmb3I9XFxcImFwcGxpY2F0aW9uTmFtZVxcXCIgY2xhc3M9XFxcImNvbnRyb2wtbGFiZWxcXFwiPkFwcGxpY2F0aW9uIE5hbWU8L2xhYmVsPlxcclxcbiAgICAgICAgICAgIDxkaXY+XFxyXFxuICAgICAgICAgICAgICAgIDxpbnB1dCB0eXBlPVxcXCJ0ZXh0XFxcIiBbKG5nTW9kZWwpXT1cXFwic2V0dGluZ3MuYXBwbGljYXRpb25OYW1lXFxcIiBjbGFzcz1cXFwiZm9ybS1jb250cm9sIGZvcm0tY29udHJvbC1jdXN0b20gXFxcIiBpZD1cXFwiYXBwbGljYXRpb25OYW1lXFxcIiBuYW1lPVxcXCJhcHBsaWNhdGlvbk5hbWVcXFwiIHBsYWNlaG9sZGVyPVxcXCJPbWJpXFxcIiB2YWx1ZT1cXFwie3tzZXR0aW5ncy5hcHBsaWNhdGlvbk5hbWV9fVxcXCI+XFxyXFxuICAgICAgICAgICAgPC9kaXY+XFxyXFxuICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIFxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGxhYmVsIGZvcj1cXFwibG9nb1xcXCIgY2xhc3M9XFxcImNvbnRyb2wtbGFiZWxcXFwiPkN1c3RvbSBMb2dvPC9sYWJlbD5cXHJcXG4gICAgICAgICAgICA8ZGl2PlxcclxcbiAgICAgICAgICAgICAgICA8aW5wdXQgdHlwZT1cXFwidGV4dFxcXCIgWyhuZ01vZGVsKV09XFxcInNldHRpbmdzLmxvZ29cXFwiIGNsYXNzPVxcXCJmb3JtLWNvbnRyb2wgZm9ybS1jb250cm9sLWN1c3RvbSBcXFwiIGlkPVxcXCJsb2dvXFxcIiBuYW1lPVxcXCJsb2dvXFxcIiB2YWx1ZT1cXFwie3tzZXR0aW5ncy5sb2dvfX1cXFwiPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuICAgICAgICA8c21hbGw+VGhpcyB3aWxsIGJlIHVzZWQgb24gYWxsIG9mIHRoZSBub3RpZmljYXRpb25zIGUuZy4gTmV3c2xldHRlciwgZW1haWwgbm90aWZpY2F0aW9uIGFuZCBhbHNvIHRoZSBMYW5kaW5nIHBhZ2U8L3NtYWxsPlxcclxcbiAgICAgICAgXFxyXFxuXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8bGFiZWwgZm9yPVxcXCJsb2dvXFxcIiBjbGFzcz1cXFwiY29udHJvbC1sYWJlbFxcXCI+TG9nbyBQcmV2aWV3OjwvbGFiZWw+XFxyXFxuICAgICAgICAgICAgPGRpdj5cXHJcXG4gICAgICAgICAgICAgICAgPGltZyAqbmdJZj1cXFwic2V0dGluZ3MubG9nb1xcXCIgW3NyY109XFxcInNldHRpbmdzLmxvZ29cXFwiIHN0eWxlPVxcXCJ3aWR0aDogMzAwcHhcXFwiLz5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcblxcclxcblxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGRpdj5cXHJcXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVxcXCJzYXZlKClcXFwiIHR5cGU9XFxcInN1Ym1pdFxcXCIgaWQ9XFxcInNhdmVcXFwiIGNsYXNzPVxcXCJidG4gYnRuLXByaW1hcnktb3V0bGluZVxcXCI+U3VibWl0PC9idXR0b24+XFxyXFxuICAgICAgICAgICAgPC9kaXY+XFxyXFxuICAgICAgICA8L2Rpdj5cXHJcXG4gICAgPC9maWVsZHNldD5cIjtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL0NsaWVudEFwcC9hcHAvc2V0dGluZ3MvY3VzdG9taXphdGlvbi9jdXN0b21pemF0aW9uLmNvbXBvbmVudC5odG1sXG4vLyBtb2R1bGUgaWQgPSAxODVcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ=="); - -/***/ }), -/* 186 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n\\r\\n
\\r\\n
\\r\\n Emby Configuration\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3NldHRpbmdzL2VtYnkvZW1ieS5jb21wb25lbnQuaHRtbD9jYmI2Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGd3QkFBZ3dCLGFBQWEsaVhBQWlYLGVBQWUscWlDQUFxaUMsaUJBQWlCIiwiZmlsZSI6IjE4Ni5qcyIsInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gXCJcXHJcXG48c2V0dGluZ3MtbWVudT48L3NldHRpbmdzLW1lbnU+XFxyXFxuPGRpdiAqbmdJZj1cXFwic2V0dGluZ3NcXFwiPlxcclxcbiAgICA8ZmllbGRzZXQ+XFxyXFxuICAgICAgICA8bGVnZW5kPkVtYnkgQ29uZmlndXJhdGlvbjwvbGVnZW5kPlxcclxcbiAgICAgICAgXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVxcXCJjaGVja2JveFxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxpbnB1dCB0eXBlPVxcXCJjaGVja2JveFxcXCIgaWQ9XFxcImVuYWJsZVxcXCIgWyhuZ01vZGVsKV09XFxcInNldHRpbmdzLmVuYWJsZVxcXCIgbmctY2hlY2tlZD1cXFwic2V0dGluZ3MuZW5hYmxlXFxcIj5cXHJcXG4gICAgICAgICAgICAgICAgPGxhYmVsIGZvcj1cXFwiZW5hYmxlXFxcIj5FbmFibGU8L2xhYmVsPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8bGFiZWwgZm9yPVxcXCJJcFxcXCIgY2xhc3M9XFxcImNvbnRyb2wtbGFiZWxcXFwiPkhvc3RuYW1lIG9yIElQPC9sYWJlbD5cXHJcXG4gICAgICAgICAgICA8ZGl2PlxcclxcbiAgICAgICAgICAgICAgICA8aW5wdXQgdHlwZT1cXFwidGV4dFxcXCIgY2xhc3M9XFxcImZvcm0tY29udHJvbCBmb3JtLWNvbnRyb2wtY3VzdG9tIFxcXCIgaWQ9XFxcIklwXFxcIiBuYW1lPVxcXCJJcFxcXCIgcGxhY2Vob2xkZXI9XFxcImxvY2FsaG9zdFxcXCIgWyhuZ01vZGVsKV09XFxcInNldHRpbmdzLmlwXFxcIiB2YWx1ZT1cXFwie3tzZXR0aW5ncy5pcH19XFxcIj5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcblxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGxhYmVsIGZvcj1cXFwicG9ydE51bWJlclxcXCIgY2xhc3M9XFxcImNvbnRyb2wtbGFiZWxcXFwiPlBvcnQ8L2xhYmVsPlxcclxcbiAgICAgICAgICAgIDxkaXY+XFxyXFxuICAgICAgICAgICAgICAgIDxpbnB1dCB0eXBlPVxcXCJ0ZXh0XFxcIiBbKG5nTW9kZWwpXT1cXFwic2V0dGluZ3MucG9ydFxcXCIgY2xhc3M9XFxcImZvcm0tY29udHJvbCBmb3JtLWNvbnRyb2wtY3VzdG9tIFxcXCIgaWQ9XFxcInBvcnROdW1iZXJcXFwiIG5hbWU9XFxcIlBvcnRcXFwiIHBsYWNlaG9sZGVyPVxcXCJQb3J0IE51bWJlclxcXCIgdmFsdWU9XFxcInt7c2V0dGluZ3MucG9ydH19XFxcIj5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcblxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cXFwiY2hlY2tib3hcXFwiPlxcclxcbiAgICAgICAgICAgICAgICA8aW5wdXQgdHlwZT1cXFwiY2hlY2tib3hcXFwiIGlkPVxcXCJzc2xcXFwiIFsobmdNb2RlbCldPVxcXCJzZXR0aW5ncy5zc2xcXFwiIG5nLWNoZWNrZWQ9XFxcInNldHRpbmdzLnNzbFxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxsYWJlbCBmb3I9XFxcInNzbFxcXCI+U1NMPC9sYWJlbD5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcblxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cXFwiY2hlY2tib3hcXFwiPlxcclxcblxcclxcblxcclxcbiAgICAgICAgICAgICAgICA8aW5wdXQgdHlwZT1cXFwiY2hlY2tib3hcXFwiIGlkPVxcXCJFbmFibGVUdkVwaXNvZGVTZWFyY2hpbmdcXFwiIFsobmdNb2RlbCldPVxcXCJzZXR0aW5ncy5lbmFibGVFcGlzb2RlU2VhcmNoaW5nXFxcIiBuZy1jaGVja2VkPVxcXCJzZXR0aW5ncy5lbmFibGVFcGlzb2RlU2VhcmNoaW5nXFxcIj5cXHJcXG4gICAgICAgICAgICAgICAgPGxhYmVsIGZvcj1cXFwiRW5hYmxlVHZFcGlzb2RlU2VhcmNoaW5nXFxcIj5FbmFibGUgRXBpc29kZSBTZWFyY2hpbmc8L2xhYmVsPlxcclxcblxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuXFxyXFxuXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8bGFiZWwgZm9yPVxcXCJhdXRoVG9rZW5cXFwiIGNsYXNzPVxcXCJjb250cm9sLWxhYmVsXFxcIj5FbWJ5IEFwaSBLZXk8L2xhYmVsPlxcclxcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XFxcIlxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxpbnB1dCB0eXBlPVxcXCJ0ZXh0XFxcIiBjbGFzcz1cXFwiZm9ybS1jb250cm9sLWN1c3RvbSBmb3JtLWNvbnRyb2xcXFwiIGlkPVxcXCJhdXRoVG9rZW5cXFwiIFsobmdNb2RlbCldPVxcXCJzZXR0aW5ncy5hcGlLZXlcXFwiIHBsYWNlaG9sZGVyPVxcXCJFbWJ5IEFwaSBLZXlcXFwiIHZhbHVlPVxcXCJ7e3NldHRpbmdzLmFwaUtleX19XFxcIj5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcblxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGRpdj5cXHJcXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiBpZD1cXFwidGVzdFBsZXhcXFwiIHR5cGU9XFxcInN1Ym1pdFxcXCIgKGNsaWNrKT1cXFwidGVzdCgpXFxcIiBjbGFzcz1cXFwiYnRuIGJ0bi1wcmltYXJ5LW91dGxpbmVcXFwiPlRlc3QgQ29ubmVjdGl2aXR5IDxkaXYgaWQ9XFxcInNwaW5uZXJcXFwiPjwvZGl2PjwvYnV0dG9uPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuXFxyXFxuXFxyXFxuXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8ZGl2PlxcclxcbiAgICAgICAgICAgICAgICA8YnV0dG9uIChjbGljayk9XFxcInNhdmUoKVxcXCIgdHlwZT1cXFwic3VibWl0XFxcIiBpZD1cXFwic2F2ZVxcXCIgY2xhc3M9XFxcImJ0biBidG4tcHJpbWFyeS1vdXRsaW5lXFxcIj5TdWJtaXQ8L2J1dHRvbj5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcbiAgICA8L2ZpZWxkc2V0PlxcclxcbjwvZGl2PlwiO1xuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIC4vQ2xpZW50QXBwL2FwcC9zZXR0aW5ncy9lbWJ5L2VtYnkuY29tcG9uZW50Lmh0bWxcbi8vIG1vZHVsZSBpZCA9IDE4NlxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 187 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n\\r\\n
\\r\\n
\\r\\n Landing Page Configuration\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n If enabled then this will show the landing page before the login page, if this is disabled the user will log in first and then see the landing page.\\r\\n
\\r\\n\\r\\n

Notice Message

\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n

Notice Preview:

\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3NldHRpbmdzL2xhbmRpbmdwYWdlL2xhbmRpbmdwYWdlLmNvbXBvbmVudC5odG1sP2EzNzgiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEscTRDQUFxNEMsWUFBWSIsImZpbGUiOiIxODcuanMiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IFwiXFxyXFxuPHNldHRpbmdzLW1lbnU+PC9zZXR0aW5ncy1tZW51PlxcclxcbjxkaXYgKm5nSWY9XFxcInNldHRpbmdzXFxcIj5cXHJcXG4gICAgPGZpZWxkc2V0PlxcclxcbiAgICAgICAgPGxlZ2VuZD5MYW5kaW5nIFBhZ2UgQ29uZmlndXJhdGlvbjwvbGVnZW5kPlxcclxcblxcclxcblxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cXFwiY2hlY2tib3hcXFwiPlxcclxcbiAgICAgICAgICAgICAgICA8aW5wdXQgdHlwZT1cXFwiY2hlY2tib3hcXFwiIGlkPVxcXCJlbmFibGVcXFwiIG5hbWU9XFxcImVuYWJsZVxcXCIgWyhuZ01vZGVsKV09XFxcInNldHRpbmdzLmVuYWJsZWRcXFwiIG5nLWNoZWNrZWQ9XFxcInNldHRpbmdzLmVuYWJsZWRcXFwiPlxcclxcbiAgICAgICAgICAgICAgICA8bGFiZWwgZm9yPVxcXCJlbmFibGVcXFwiPkVuYWJsZTwvbGFiZWw+XFxyXFxuICAgICAgICAgICAgPC9kaXY+XFxyXFxuICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIFxcclxcblxcclxcbiAgICAgICAgXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVxcXCJjaGVja2JveFxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxpbnB1dCB0eXBlPVxcXCJjaGVja2JveFxcXCIgaWQ9XFxcIkJlZm9yZUxvZ2luXFxcIiBuYW1lPVxcXCJCZWZvcmVMb2dpblxcXCIgWyhuZ01vZGVsKV09XFxcInNldHRpbmdzLmJlZm9yZUxvZ2luXFxcIiBuZy1jaGVja2VkPVxcXCJzZXR0aW5ncy5iZWZvcmVMb2dpblxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxsYWJlbCBmb3I9XFxcIkJlZm9yZUxvZ2luXFxcIj5TaG93IGJlZm9yZSB0aGUgbG9naW48L2xhYmVsPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgICAgIDxzbWFsbD5JZiBlbmFibGVkIHRoZW4gdGhpcyB3aWxsIHNob3cgdGhlIGxhbmRpbmcgcGFnZSBiZWZvcmUgdGhlIGxvZ2luIHBhZ2UsIGlmIHRoaXMgaXMgZGlzYWJsZWQgdGhlIHVzZXIgd2lsbCBsb2cgaW4gZmlyc3QgYW5kIHRoZW4gc2VlIHRoZSBsYW5kaW5nIHBhZ2UuPC9zbWFsbD5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcblxcclxcbiAgICAgICAgPHAgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPk5vdGljZSBNZXNzYWdlPC9wPlxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGRpdj5cXHJcXG4gICAgICAgICAgICAgICAgPHRleHRhcmVhIHJvd3M9XFxcIjRcXFwiIHR5cGU9XFxcInRleHRcXFwiIGNsYXNzPVxcXCJmb3JtLWNvbnRyb2wtY3VzdG9tIGZvcm0tY29udHJvbCBcXFwiIGlkPVxcXCJOb3RpY2VNZXNzYWdlXFxcIiBuYW1lPVxcXCJOb3RpY2VNZXNzYWdlXFxcIiBwbGFjZWhvbGRlcj1cXFwiZS5nLiBUaGUgc2VydmVyIHdpbGwgYmUgZG93biBmb3IgbWFpbnRhaW5jZSAoSFRNTCBpcyBhbGxvd2VkKVxcXCIgIFsobmdNb2RlbCldPVxcXCJzZXR0aW5ncy5ub3RpY2VUZXh0XFxcIiA+e3tub3RpY2VUZXh0fX08L3RleHRhcmVhPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuXFxyXFxuICAgICAgICA8cCBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+Tm90aWNlIFByZXZpZXc6PC9wPlxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgPGRpdiBbaW5uZXJIVE1MXT1cXFwic2V0dGluZ3Mubm90aWNlVGV4dFxcXCI+PC9kaXY+XFxyXFxuICAgICAgICA8L2Rpdj5cXHJcXG5cXHJcXG4gICAgICAgIDxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICAgICAgICAgIDxkaXY+XFxyXFxuICAgICAgICAgICAgICAgIDxidXR0b24gKGNsaWNrKT1cXFwic2F2ZSgpXFxcIiB0eXBlPVxcXCJzdWJtaXRcXFwiIGlkPVxcXCJzYXZlXFxcIiBjbGFzcz1cXFwiYnRuIGJ0bi1wcmltYXJ5LW91dGxpbmVcXFwiPlN1Ym1pdDwvYnV0dG9uPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuICAgIDwvZmllbGRzZXQ+XFxyXFxuPC9kaXY+XCI7XG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9DbGllbnRBcHAvYXBwL3NldHRpbmdzL2xhbmRpbmdwYWdlL2xhbmRpbmdwYWdlLmNvbXBvbmVudC5odG1sXG4vLyBtb2R1bGUgaWQgPSAxODdcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ=="); - -/***/ }), -/* 188 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n\\r\\n
\\r\\n Ombi Configuration\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n You will have to restart after changing the port.\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3NldHRpbmdzL29tYmkvb21iaS5jb21wb25lbnQuaHRtbD9hODc4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLCtjQUErYyxlQUFlLHloQ0FBeWhDLGlCQUFpQiIsImZpbGUiOiIxODguanMiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IFwiXFxyXFxuPHNldHRpbmdzLW1lbnU+PC9zZXR0aW5ncy1tZW51PlxcclxcbiAgICA8ZmllbGRzZXQgKm5nSWY9XFxcInNldHRpbmdzXFxcIj5cXHJcXG4gICAgICAgIDxsZWdlbmQ+T21iaSBDb25maWd1cmF0aW9uPC9sZWdlbmQ+XFxyXFxuXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8bGFiZWwgZm9yPVxcXCJwb3J0TnVtYmVyXFxcIiBjbGFzcz1cXFwiY29udHJvbC1sYWJlbFxcXCI+UG9ydDwvbGFiZWw+XFxyXFxuICAgICAgICAgICAgPGRpdj5cXHJcXG4gICAgICAgICAgICAgICAgPGlucHV0IHR5cGU9XFxcInRleHRcXFwiIFsobmdNb2RlbCldPVxcXCJzZXR0aW5ncy5wb3J0XFxcIiBjbGFzcz1cXFwiZm9ybS1jb250cm9sIGZvcm0tY29udHJvbC1jdXN0b20gXFxcIiBpZD1cXFwicG9ydE51bWJlclxcXCIgbmFtZT1cXFwiUG9ydFxcXCIgcGxhY2Vob2xkZXI9XFxcIlBvcnQgTnVtYmVyXFxcIiB2YWx1ZT1cXFwie3tzZXR0aW5ncy5wb3J0fX1cXFwiPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuICAgICAgICA8c21hbGwgY2xhc3M9XFxcImNvbnRyb2wtbGFiZWxcXFwiPllvdSB3aWxsIGhhdmUgdG8gcmVzdGFydCBhZnRlciBjaGFuZ2luZyB0aGUgcG9ydC48L3NtYWxsPlxcclxcblxcclxcbiAgICAgICAgPCEtLTxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICAgICAgICAgIDxsYWJlbCBmb3I9XFxcIkJhc2VVcmxcXFwiIGNsYXNzPVxcXCJjb250cm9sLWxhYmVsXFxcIj5CYXNlIFVybCBASHRtbC5Ub29sVGlwKFxcXCJUaGlzIHdpbGwgbWFrZSBPbWJpIHJ1biB3aXRoIGEgYmFzZSB1cmwsIHVzdWFsbHkgdXNlZCBpbiByZXZlcnNlIHByb3h5IHNjZW5hcmlvc1xcXCIpPC9sYWJlbD5cXHJcXG5cXHJcXG4gICAgICAgICAgICA8ZGl2PlxcclxcbiAgICAgICAgICAgICAgICA8aW5wdXQgdHlwZT1cXFwidGV4dFxcXCIgY2xhc3M9XFxcImZvcm0tY29udHJvbCBmb3JtLWNvbnRyb2wtY3VzdG9tIFxcXCIgaWQ9XFxcIkJhc2VVcmxcXFwiIG5hbWU9XFxcIkJhc2VVcmxcXFwiIHBsYWNlaG9sZGVyPVxcXCJCYXNlIFVybFxcXCIgdmFsdWU9XFxcIkBNb2RlbC5CYXNlVXJsXFxcIj5cXHJcXG5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPHNtYWxsIGNsYXNzPVxcXCJjb250cm9sLWxhYmVsXFxcIj5Zb3Ugd2lsbCBoYXZlIHRvIHJlc3RhcnQgYWZ0ZXIgY2hhbmdpbmcgdGhlIGJhc2UgdXJsLjwvc21hbGw+LS0+XFxyXFxuXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8bGFiZWwgZm9yPVxcXCJBcGlLZXlcXFwiIGNsYXNzPVxcXCJjb250cm9sLWxhYmVsXFxcIj5BcGkgS2V5PC9sYWJlbD5cXHJcXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVxcXCJpbnB1dC1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxpbnB1dCBbKG5nTW9kZWwpXT1cXFwic2V0dGluZ3MuYXBpS2V5XFxcIiB0eXBlPVxcXCJ0ZXh0XFxcIiBbcmVhZG9ubHldPVxcXCJ0cnVlXFxcIiBjbGFzcz1cXFwiZm9ybS1jb250cm9sIGZvcm0tY29udHJvbC1jdXN0b21cXFwiIGlkPVxcXCJBcGlLZXlcXFwiIG5hbWU9XFxcIkFwaUtleVxcXCIgdmFsdWU9XFxcInt7c2V0dGluZ3MuYXBpS2V5fX1cXFwiPlxcclxcblxcclxcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVxcXCJpbnB1dC1ncm91cC1hZGRvblxcXCI+XFxyXFxuICAgICAgICAgICAgICAgICAgICA8ZGl2IChjbGljayk9XFxcInJlZnJlc2hBcGlLZXkoKVxcXCIgaWQ9XFxcInJlZnJlc2hLZXlcXFwiIGNsYXNzPVxcXCJmYSBmYS1yZWZyZXNoXFxcIiB0aXRsZT1cXFwiUmVzZXQgQVBJIEtleVxcXCI+PC9kaXY+XFxyXFxuICAgICAgICAgICAgICAgIDwvZGl2PlxcclxcblxcclxcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVxcXCJpbnB1dC1ncm91cC1hZGRvblxcXCI+XFxyXFxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmYSBmYS1jbGlwYm9hcmRcXFwiID48L2Rpdj5cXHJcXG4gICAgICAgICAgICAgICAgPC9kaXY+XFxyXFxuICAgICAgICAgICAgPC9kaXY+XFxyXFxuICAgICAgICA8L2Rpdj5cXHJcXG5cXHJcXG4gICAgICAgIDxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XFxcImNoZWNrYm94XFxcIj5cXHJcXG4gICAgICAgICAgICAgICAgPGlucHV0IHR5cGU9XFxcImNoZWNrYm94XFxcIiBpZD1cXFwiQ29sbGVjdEFuYWx5dGljRGF0YVxcXCIgbmFtZT1cXFwiQ29sbGVjdEFuYWx5dGljRGF0YVxcXCIgWyhuZ01vZGVsKV09XFxcInNldHRpbmdzLmNvbGxlY3RBbmFseXRpY0RhdGFcXFwiIG5nLWNoZWNrZWQ9XFxcInNldHRpbmdzLmNvbGxlY3RBbmFseXRpY0RhdGFcXFwiPlxcclxcbiAgICAgICAgICAgICAgICA8bGFiZWwgZm9yPVxcXCJDb2xsZWN0QW5hbHl0aWNEYXRhXFxcIj5BbGxvdyB1cyB0byBjb2xsZWN0IGFub255bW91cyBhbmFseXRpY2FsIGRhdGEgZS5nLiBicm93c2VyIHVzZWQ8L2xhYmVsPlxcclxcbiAgICAgICAgICAgIDwvZGl2PlxcclxcbiAgICAgICAgPC9kaXY+XFxyXFxuXFxyXFxuICAgICAgICA8ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgICAgICAgICA8ZGl2PlxcclxcbiAgICAgICAgICAgICAgICA8YnV0dG9uIChjbGljayk9XFxcInNhdmUoKVxcXCIgdHlwZT1cXFwic3VibWl0XFxcIiBpZD1cXFwic2F2ZVxcXCIgY2xhc3M9XFxcImJ0biBidG4tcHJpbWFyeS1vdXRsaW5lXFxcIj5TdWJtaXQ8L2J1dHRvbj5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcbiAgICA8L2ZpZWxkc2V0PlwiO1xuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIC4vQ2xpZW50QXBwL2FwcC9zZXR0aW5ncy9vbWJpL29tYmkuY29tcG9uZW50Lmh0bWxcbi8vIG1vZHVsZSBpZCA9IDE4OFxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 189 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n
\\r\\n
\\r\\n Plex Configuration\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n Servers\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n If enabled then we will lookup all episodes on your Plex server and store them in the local database. This will stop episode requests that already exist on Plex (that might not be in Sonarr).\\r\\n Please be aware that this is a very resource intensive process and while the Plex Episode Cacher job is running the application may appear slow (Depending on the size of your Plex library).\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n Note: if nothing is selected, we will monitor all libraries\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./ClientApp/app/settings/plex/plex.component.html?e365"],"names":[],"mappings":"AAAA,qNAAqN,khBAAkhB,iiBAAiiB,yxEAAyxE,QAAQ,kpBAAkpB,aAAa,2dAA2d,WAAW,ueAAue,aAAa,g7DAAg7D,sBAAsB,2gBAA2gB,0BAA0B,yhCAAyhC,WAAW,qHAAqH,WAAW,KAAK,WAAW","file":"189.js","sourcesContent":["module.exports = \"<settings-menu></settings-menu>\\r\\n<div *ngIf=\\\"settings\\\">\\r\\n    <fieldset>\\r\\n        <legend>Plex Configuration</legend>\\r\\n\\r\\n        <div class=\\\"checkbox col-md-2 \\\" style=\\\"float: right;\\\">\\r\\n            <input type=\\\"checkbox\\\" id=\\\"advanced\\\" [(ngModel)]=\\\"advanced\\\" ng-checked=\\\"advanced\\\">\\r\\n            <label for=\\\"advanced\\\">Advanced</label>\\r\\n        </div>\\r\\n\\r\\n        <div class=\\\"form-group col-md-3\\\">\\r\\n            <div class=\\\"checkbox\\\">\\r\\n                <input type=\\\"checkbox\\\" id=\\\"enable\\\" [(ngModel)]=\\\"settings.enable\\\" ng-checked=\\\"settings.enable\\\">\\r\\n                <label for=\\\"enable\\\">Enable</label>\\r\\n            </div>\\r\\n        </div>\\r\\n        <div style=\\\"float: right;\\\" class=\\\"col-md-12 col-md-push-10\\\">\\r\\n            <button type=\\\"submit\\\" (click)=\\\"addTab()\\\" class=\\\"btn btn-success-outline\\\">Add Server</button>\\r\\n        </div>\\r\\n\\r\\n        <ngb-tabset>\\r\\n\\r\\n            <div *ngFor=\\\"let server of settings.servers\\\">\\r\\n                <ngb-tab [id]=\\\"server.id\\\" [title]=\\\"server.name\\\">\\r\\n                    <ng-template ngbTabContent>\\r\\n                        <br />\\r\\n                        <br />\\r\\n                        <div class=\\\"col-md-12 col-md-push-10\\\" style=\\\"float: right;\\\">\\r\\n                            <button type=\\\"submit\\\" (click)=\\\"removeServer(server)\\\" class=\\\"btn btn-danger-outline\\\">Remove Server</button>\\r\\n                        </div>\\r\\n                        <br />\\r\\n                        <br />\\r\\n\\r\\n                        <div class=\\\"form-group\\\">\\r\\n                            <label for=\\\"username\\\" class=\\\"control-label\\\">Username and Password</label>\\r\\n                            <div>\\r\\n                                <input type=\\\"text\\\" class=\\\"form-control form-control-custom\\\" id=\\\"username\\\" [(ngModel)]=\\\"username\\\" placeholder=\\\"username\\\">\\r\\n                            </div>\\r\\n                            <br />\\r\\n                            <div>\\r\\n                                <input type=\\\"password\\\" class=\\\"form-control form-control-custom\\\" id=\\\"password\\\" [(ngModel)]=\\\"password\\\" placeholder=\\\"Password\\\">\\r\\n                            </div>\\r\\n                        </div>\\r\\n\\r\\n                        <div class=\\\"form-group\\\">\\r\\n                            <div>\\r\\n                                <button id=\\\"requestToken\\\" (click)=\\\"requestServers(server)\\\" class=\\\"btn btn-primary-outline\\\">Load Servers <i class=\\\"fa fa-key\\\"></i></button>\\r\\n                            </div>\\r\\n                        </div>\\r\\n                        <br />\\r\\n                        <br />\\r\\n                        <div class=\\\"form-group\\\">\\r\\n                            <label for=\\\"username\\\" class=\\\"control-label\\\">Please select the server</label><br />\\r\\n                            <div class=\\\"btn-group\\\">\\r\\n                                <div class=\\\"btn-group\\\">\\r\\n                                    <a [attr.disabled]=\\\"!serversButton ? true : null\\\" href=\\\"#\\\" class=\\\"btn btn-info-outline dropdown-toggle\\\" data-toggle=\\\"dropdown\\\" aria-expanded=\\\"false\\\">\\r\\n                                        Servers\\r\\n                                        <span class=\\\"caret\\\"></span>\\r\\n                                    </a>\\r\\n\\r\\n                                    <ul *ngIf=\\\"loadedServers\\\" class=\\\"dropdown-menu\\\">\\r\\n                                        <li *ngFor=\\\"let s of loadedServers.servers.server\\\">\\r\\n                                            <a (click)=\\\"selectServer(s,server)\\\">{{s.name}}</a>\\r\\n                                        </li>\\r\\n                                    </ul>\\r\\n                                </div>\\r\\n                            </div>\\r\\n                        </div>\\r\\n\\r\\n                        <div *ngIf=\\\"advanced\\\">\\r\\n                            <div class=\\\"form-group\\\">\\r\\n                                <label for=\\\"name\\\" class=\\\"control-label\\\">Server name</label>\\r\\n                                <div>\\r\\n                                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom \\\" id=\\\"name\\\" name=\\\"name\\\" placeholder=\\\"Server\\\" [(ngModel)]=\\\"server.name\\\" value=\\\"{{server.name}}\\\">\\r\\n                                </div>\\r\\n                            </div>\\r\\n\\r\\n                            <div class=\\\"form-group\\\">\\r\\n                                <label for=\\\"Ip\\\" class=\\\"control-label\\\">Hostname or IP</label>\\r\\n                                <div>\\r\\n                                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom \\\" id=\\\"Ip\\\" name=\\\"Ip\\\" placeholder=\\\"localhost\\\" [(ngModel)]=\\\"server.ip\\\" value=\\\"{{server.ip}}\\\">\\r\\n                                </div>\\r\\n                            </div>\\r\\n\\r\\n                            <div class=\\\"form-group\\\">\\r\\n                                <label for=\\\"portNumber\\\" class=\\\"control-label\\\">Port</label>\\r\\n                                <div>\\r\\n                                    <input type=\\\"text\\\" [(ngModel)]=\\\"server.port\\\" class=\\\"form-control form-control-custom \\\" id=\\\"portNumber\\\" name=\\\"Port\\\" placeholder=\\\"Port Number\\\" value=\\\"{{server.port}}\\\">\\r\\n                                </div>\\r\\n                            </div>\\r\\n\\r\\n                            <div class=\\\"form-group\\\">\\r\\n                                <div class=\\\"checkbox\\\">\\r\\n                                    <input type=\\\"checkbox\\\" id=\\\"ssl\\\" [(ngModel)]=\\\"server.ssl\\\" ng-checked=\\\"server.ssl\\\">\\r\\n                                    <label for=\\\"ssl\\\">SSL</label>\\r\\n                                </div>\\r\\n                            </div>\\r\\n\\r\\n                            <div class=\\\"form-group\\\">\\r\\n                                <div class=\\\"checkbox\\\">\\r\\n\\r\\n                                    <input type=\\\"checkbox\\\" id=\\\"EnableTvEpisodeSearching\\\" [(ngModel)]=\\\"server.enableEpisodeSearching\\\" ng-checked=\\\"server.enableEpisodeSearching\\\">\\r\\n                                    <label for=\\\"EnableTvEpisodeSearching\\\">Enable Episode Searching</label>\\r\\n                                </div>\\r\\n                                <small>\\r\\n                                    If enabled then we will lookup all episodes on your Plex server and store them in the local database. This will stop episode requests that already exist on Plex (that might not be in Sonarr).\\r\\n                                    Please be aware that this is a very resource intensive process and while the Plex Episode Cacher job is running the application may appear slow (Depending on the size of your Plex library).\\r\\n                                </small>\\r\\n                            </div>\\r\\n\\r\\n                            <div class=\\\"form-group\\\">\\r\\n                                <label for=\\\"authToken\\\" class=\\\"control-label\\\">Plex Authorization Token</label>\\r\\n                                <div class=\\\"\\\">\\r\\n                                    <input type=\\\"text\\\" class=\\\"form-control-custom form-control\\\" id=\\\"authToken\\\" [(ngModel)]=\\\"server.plexAuthToken\\\" placeholder=\\\"Plex Auth Token\\\" value=\\\"{{server.plexAuthToken}}\\\">\\r\\n                                </div>\\r\\n                            </div>\\r\\n\\r\\n                            <div class=\\\"form-group\\\">\\r\\n                                <label for=\\\"MachineIdentifier\\\" class=\\\"control-label\\\">Machine Identifier</label>\\r\\n                                <div class=\\\"\\\">\\r\\n                                    <input type=\\\"text\\\" class=\\\"form-control-custom form-control\\\" id=\\\"MachineIdentifier\\\" name=\\\"MachineIdentifier\\\" [(ngModel)]=\\\"server.machineIdentifier\\\" value=\\\"{{server.machineIdentifier}}\\\">\\r\\n                                </div>\\r\\n                            </div>\\r\\n                        </div>\\r\\n                        <label>Please select the libraries you want Ombi to look in for content</label>\\r\\n                        <br />\\r\\n                        <small>Note: if nothing is selected, we will monitor all libraries</small>\\r\\n                        <div class=\\\"form-group\\\">\\r\\n                            <div>\\r\\n                                <button (click)=\\\"loadLibraries(server)\\\" class=\\\"btn btn-primary-outline\\\">Load Libraries <i class=\\\"fa fa-film\\\"></i></button>\\r\\n                            </div>\\r\\n                        </div>\\r\\n                        <div *ngIf=\\\"server.plexSelectedLibraries\\\">\\r\\n                            <div *ngFor=\\\"let lib of server.plexSelectedLibraries\\\">\\r\\n                                <div class=\\\"form-group\\\">\\r\\n                                    <div class=\\\"checkbox\\\">\\r\\n                                        <input type=\\\"checkbox\\\" id=\\\"{{lib.title}}\\\" [(ngModel)]=\\\"lib.enabled\\\" ng-checked=\\\"lib.enabled\\\">\\r\\n                                        <label for=\\\"{{lib.title}}\\\">{{lib.title}}</label>\\r\\n                                    </div>\\r\\n                                </div>\\r\\n                            </div>\\r\\n                        </div>\\r\\n\\r\\n                        <div class=\\\"form-group\\\">\\r\\n                            <div>\\r\\n                                <button id=\\\"testPlex\\\" type=\\\"submit\\\" (click)=\\\"testPlex()\\\" class=\\\"btn btn-primary-outline\\\">\\r\\n                                    Test Connectivity\\r\\n                                    <div id=\\\"spinner\\\"></div>\\r\\n                                </button>\\r\\n                            </div>\\r\\n                        </div>\\r\\n                    </ng-template>\\r\\n                </ngb-tab>\\r\\n            </div>\\r\\n        </ngb-tabset>\\r\\n\\r\\n        <div class=\\\"form-group\\\">\\r\\n            <div>\\r\\n                <button (click)=\\\"save()\\\" type=\\\"submit\\\" id=\\\"save\\\" class=\\\"btn btn-primary-outline\\\">Submit</button>\\r\\n            </div>\\r\\n        </div>\\r\\n    </fieldset>\\r\\n</div>\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./ClientApp/app/settings/plex/plex.component.html\n// module id = 189\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 190 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n\\r\\n
\\r\\n
\\r\\n Radarr Settings\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./ClientApp/app/settings/radarr/radarr.component.html?eaa5"],"names":[],"mappings":"AAAA,q5BAAq5B,aAAa,wZAAwZ,eAAe,gXAAgX,iBAAiB,85CAA85C,YAAY,IAAI,cAAc,00BAA00B,WAAW,IAAI,aAAa","file":"190.js","sourcesContent":["module.exports = \"\\r\\n<settings-menu></settings-menu>\\r\\n<div *ngIf=\\\"settings\\\">\\r\\n        <fieldset>\\r\\n            <legend>Radarr Settings</legend>\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div class=\\\"checkbox\\\">\\r\\n                    <input type=\\\"checkbox\\\" [(ngModel)]=\\\"settings.enable\\\" ng-checked=\\\"settings.enable\\\">\\r\\n                    <label for=\\\"enable\\\">Enable</label>\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n            <input hidden=\\\"hidden\\\" name=\\\"FullRootPath\\\" id=\\\"fullRootPath\\\" value=\\\"settings.enable\\\" />\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"Ip\\\" class=\\\"control-label\\\">Hostname or IP</label>\\r\\n                <div class=\\\"\\\">\\r\\n                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom \\\" [(ngModel)]=\\\"settings.ip\\\" id=\\\"Ip\\\" name=\\\"Ip\\\" placeholder=\\\"localhost\\\" value=\\\"{{settings.ip}}\\\">\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"portNumber\\\" class=\\\"control-label\\\">Port</label>\\r\\n\\r\\n                <div class=\\\"\\\">\\r\\n                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom \\\" [(ngModel)]=\\\"settings.port\\\" id=\\\"portNumber\\\" name=\\\"Port\\\" placeholder=\\\"Port Number\\\" value=\\\"{{settings.port}}\\\">\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"ApiKey\\\" class=\\\"control-label\\\">API Key</label>\\r\\n                <div>\\r\\n                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom \\\" [(ngModel)]=\\\"settings.apiKey\\\" id=\\\"ApiKey\\\" name=\\\"ApiKey\\\" value=\\\"{{settings.apiKey}}\\\">\\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div class=\\\"checkbox\\\">\\r\\n\\r\\n                    <input type=\\\"checkbox\\\" id=\\\"Ssl\\\" name=\\\"Ssl\\\" ng-checked=\\\"settings.ssl\\\"><label for=\\\"Ssl\\\">SSL</label>\\r\\n\\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"SubDir\\\" class=\\\"control-label\\\">Base Url</label>\\r\\n                <div>\\r\\n                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom\\\" [(ngModel)]=\\\"settings.subDir\\\" id=\\\"SubDir\\\" name=\\\"SubDir\\\" value=\\\"@Model.SubDir\\\">\\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div>\\r\\n                    <button type=\\\"submit\\\" (click)=\\\"getProfiles()\\\" class=\\\"btn btn-primary-outline\\\">Get Quality Profiles <span *ngIf=\\\"profilesRunning\\\" class=\\\"fa fa-spinner fa-spin\\\"> </span></button>\\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"select\\\" class=\\\"control-label\\\">Quality Profiles</label>\\r\\n                <div id=\\\"profiles\\\">\\r\\n                    <select class=\\\"form-control form-control-custom\\\" id=\\\"select\\\" *ngFor='let quality of qualities'>\\r\\n                        <option [selected]=\\\"qualityProfile === quality.name\\\" [ngValue]=\\\"selectedQuality\\\" value='{{quality.id}}'>{{quality.name}}</option>\\r\\n                    </select>\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div>\\r\\n                    <button type=\\\"submit\\\" (click)=\\\"getRootFolders()\\\" class=\\\"btn btn-primary-outline\\\">Get Root Folders <span *ngIf=\\\"rootFoldersRunning\\\" class=\\\"fa fa-spinner fa-spin\\\" ></span></button>\\r\\n\\r\\n                </div>\\r\\n\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"rootFolders\\\" class=\\\"control-label\\\">Default Root Folders</label>\\r\\n                <div id=\\\"rootFolders\\\">\\r\\n                    <select class=\\\"form-control form-control-custom\\\" *ngFor='let folder of rootFolders'>\\r\\n                        <option [selected]=\\\"rootPath === folder.name\\\" [ngValue]=\\\"selectedRootFolder\\\" value='{{folder.id}}'>{{folder.name}}</option>\\r\\n                    </select>\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div class=\\\"checkbox\\\">\\r\\n                    <input type=\\\"checkbox\\\" id=\\\"SeasonFolders\\\" name=\\\"SeasonFolders\\\" ng-checked=\\\"settings.seasonFolders\\\">\\r\\n                    <label for=\\\"SeasonFolders\\\">Enable season folders</label>\\r\\n                </div>\\r\\n                <label>Enabled Season Folders to organize seasons into individual folders within a show.</label>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div>\\r\\n                    <button (click)=\\\"test()\\\" type=\\\"submit\\\" class=\\\"btn btn-primary-outline\\\">Test Connectivity <span id=\\\"spinner\\\" ></span></button>\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div>\\r\\n                    <button (click)=\\\"save()\\\" type=\\\"submit\\\" class=\\\"btn btn-primary-outline \\\">Submit</button>\\r\\n                </div>\\r\\n            </div>\\r\\n        </fieldset>\\r\\n</div>\\r\\n\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./ClientApp/app/settings/radarr/radarr.component.html\n// module id = 190\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 191 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n\\r\\n
\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3NldHRpbmdzL3NldHRpbmdzbWVudS5jb21wb25lbnQuaHRtbD9iNjllIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBIiwiZmlsZSI6IjE5MS5qcyIsInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gXCI8dWwgY2xhc3M9XFxcIm5hdiBuYXYtdGFic1xcXCI+XFxyXFxuICAgIDxsaSBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPjxhIFtyb3V0ZXJMaW5rXT1cXFwiWycvU2V0dGluZ3MvT21iaSddXFxcIj5PbWJpPC9hPjwvbGk+XFxyXFxuICAgIDxsaSBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPjxhIFtyb3V0ZXJMaW5rXT1cXFwiWycvU2V0dGluZ3MvQ3VzdG9taXphdGlvbiddXFxcIj5DdXN0b21pemF0aW9uPC9hPjwvbGk+XFxyXFxuICAgIDxsaSBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPjxhIFtyb3V0ZXJMaW5rXT1cXFwiWycvU2V0dGluZ3MvTGFuZGluZ1BhZ2UnXVxcXCI+TGFuZGluZyBQYWdlPC9hPjwvbGk+XFxyXFxuXFxyXFxuICAgIDxsaSBjbGFzcz1cXFwiZHJvcGRvd25cXFwiIFtyb3V0ZXJMaW5rQWN0aXZlXT1cXFwiWydhY3RpdmUnXVxcXCI+XFxyXFxuICAgICAgICA8YSBjbGFzcz1cXFwiZHJvcGRvd24tdG9nZ2xlXFxcIiBkYXRhLXRvZ2dsZT1cXFwiZHJvcGRvd25cXFwiPlxcclxcbiAgICAgICAgICAgIE1lZGlhIFNlcnZlciA8c3BhbiBjbGFzcz1cXFwiY2FyZXRcXFwiPjwvc3Bhbj5cXHJcXG4gICAgICAgIDwvYT5cXHJcXG4gICAgICAgIDx1bCBjbGFzcz1cXFwiZHJvcGRvd24tbWVudVxcXCI+XFxyXFxuICAgICAgICAgICAgPGxpIFtyb3V0ZXJMaW5rQWN0aXZlXT1cXFwiWydhY3RpdmUnXVxcXCI+PGEgW3JvdXRlckxpbmtdPVxcXCJbJy9TZXR0aW5ncy9QbGV4J11cXFwiPlBsZXg8L2E+PC9saT5cXHJcXG4gICAgICAgICAgICA8bGkgW3JvdXRlckxpbmtBY3RpdmVdPVxcXCJbJ2FjdGl2ZSddXFxcIj48YSBbcm91dGVyTGlua109XFxcIlsnL1NldHRpbmdzL0VtYnknXVxcXCI+RW1ieTwvYT48L2xpPlxcclxcbiAgICAgICAgPC91bD5cXHJcXG4gICAgPC9saT5cXHJcXG4gICAgXFxyXFxuICAgIDxsaSBjbGFzcz1cXFwiZHJvcGRvd25cXFwiICBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPlxcclxcbiAgICAgICAgPGEgY2xhc3M9XFxcImRyb3Bkb3duLXRvZ2dsZVxcXCIgZGF0YS10b2dnbGU9XFxcImRyb3Bkb3duXFxcIj5cXHJcXG4gICAgICAgICAgICBUViA8c3BhbiBjbGFzcz1cXFwiY2FyZXRcXFwiPjwvc3Bhbj5cXHJcXG4gICAgICAgIDwvYT5cXHJcXG4gICAgICAgIDx1bCBjbGFzcz1cXFwiZHJvcGRvd24tbWVudVxcXCI+XFxyXFxuICAgICAgICAgICAgPGxpIFtyb3V0ZXJMaW5rQWN0aXZlXT1cXFwiWydhY3RpdmUnXVxcXCI+PGEgW3JvdXRlckxpbmtdPVxcXCJbJy9TZXR0aW5ncy9Tb25hcnInXVxcXCIgPlNvbmFycjwvYT48L2xpPlxcclxcbiAgICAgICAgICAgIDxsaSBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPjxhIFtyb3V0ZXJMaW5rXT1cXFwiWycvU2V0dGluZ3MvU2lja1JhZ2UnXVxcXCIgPlNpY2tSYWdlPC9hPjwvbGk+XFxyXFxuICAgICAgICA8L3VsPlxcclxcbiAgICA8L2xpPlxcclxcbiAgICBcXHJcXG4gICAgPGxpIGNsYXNzPVxcXCJkcm9wZG93blxcXCIgW3JvdXRlckxpbmtBY3RpdmVdPVxcXCJbJ2FjdGl2ZSddXFxcIj5cXHJcXG4gICAgICAgIDxhIGNsYXNzPVxcXCJkcm9wZG93bi10b2dnbGVcXFwiIGRhdGEtdG9nZ2xlPVxcXCJkcm9wZG93blxcXCI+XFxyXFxuICAgICAgICAgICAgTW92aWVzIDxzcGFuIGNsYXNzPVxcXCJjYXJldFxcXCI+PC9zcGFuPlxcclxcbiAgICAgICAgPC9hPlxcclxcbiAgICAgICAgPHVsIGNsYXNzPVxcXCJkcm9wZG93bi1tZW51XFxcIj5cXHJcXG4gICAgICAgICAgICA8bGkgW3JvdXRlckxpbmtBY3RpdmVdPVxcXCJbJ2FjdGl2ZSddXFxcIj48YSBbcm91dGVyTGlua109XFxcIlsnL1NldHRpbmdzL0NvdWNoUG90YXRvJ11cXFwiPkNvdWNoUG90YXRvPC9hPjwvbGk+XFxyXFxuICAgICAgICAgICAgPGxpIFtyb3V0ZXJMaW5rQWN0aXZlXT1cXFwiWydhY3RpdmUnXVxcXCI+PGEgW3JvdXRlckxpbmtdPVxcXCJbJy9TZXR0aW5ncy9SYWRhcnInXVxcXCI+UmFkYXJyPC9hPjwvbGk+XFxyXFxuICAgICAgICAgICAgPGxpIFtyb3V0ZXJMaW5rQWN0aXZlXT1cXFwiWydhY3RpdmUnXVxcXCI+PGEgW3JvdXRlckxpbmtdPVxcXCJbJy9TZXR0aW5ncy9XYXRjaGVyJ11cXFwiPldhdGNoZXI8L2E+PC9saT5cXHJcXG4gICAgICAgIDwvdWw+XFxyXFxuICAgIDwvbGk+XFxyXFxuICAgIFxcclxcbiAgICBcXHJcXG4gICAgPGxpIGNsYXNzPVxcXCJkcm9wZG93blxcXCIgW3JvdXRlckxpbmtBY3RpdmVdPVxcXCJbJ2FjdGl2ZSddXFxcIj5cXHJcXG4gICAgICAgIDxhIGNsYXNzPVxcXCJkcm9wZG93bi10b2dnbGVcXFwiIGRhdGEtdG9nZ2xlPVxcXCJkcm9wZG93blxcXCI+XFxyXFxuICAgICAgICAgICAgTm90aWZpY2F0aW9ucyA8c3BhbiBjbGFzcz1cXFwiY2FyZXRcXFwiPjwvc3Bhbj5cXHJcXG4gICAgICAgIDwvYT5cXHJcXG4gICAgICAgIDx1bCBjbGFzcz1cXFwiZHJvcGRvd24tbWVudVxcXCI+XFxyXFxuICAgICAgICAgICAgPGxpIFtyb3V0ZXJMaW5rQWN0aXZlXT1cXFwiWydhY3RpdmUnXVxcXCI+PGEgW3JvdXRlckxpbmtdPVxcXCJbJy9TZXR0aW5ncy9FbWFpbCddXFxcIj5FbWFpbDwvYT48L2xpPlxcclxcbiAgICAgICAgICAgIDxsaSBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPjxhIFtyb3V0ZXJMaW5rXT1cXFwiWycvU2V0dGluZ3MvTmV3c2xldHRlciddXFxcIj5OZXdzbGV0dGVyPC9hPjwvbGk+XFxyXFxuICAgICAgICAgICAgPGxpIFtyb3V0ZXJMaW5rQWN0aXZlXT1cXFwiWydhY3RpdmUnXVxcXCI+PGEgW3JvdXRlckxpbmtdPVxcXCJbJy9TZXR0aW5ncy9QdXNoYnVsbGV0J11cXFwiPlB1c2hidWxsZXQ8L2E+PC9saT5cXHJcXG4gICAgICAgICAgICA8bGkgW3JvdXRlckxpbmtBY3RpdmVdPVxcXCJbJ2FjdGl2ZSddXFxcIj48YSBbcm91dGVyTGlua109XFxcIlsnL1NldHRpbmdzL1B1c2hvdmVyJ11cXFwiPlB1c2hvdmVyPC9hPjwvbGk+XFxyXFxuICAgICAgICA8L3VsPlxcclxcbiAgICA8L2xpPlxcclxcbiAgICBcXHJcXG4gICAgXFxyXFxuICAgIDxsaSBjbGFzcz1cXFwiZHJvcGRvd25cXFwiICBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPlxcclxcbiAgICAgICAgPGEgY2xhc3M9XFxcImRyb3Bkb3duLXRvZ2dsZVxcXCIgZGF0YS10b2dnbGU9XFxcImRyb3Bkb3duXFxcIj5cXHJcXG4gICAgICAgICAgICBTeXN0ZW0gPHNwYW4gY2xhc3M9XFxcImNhcmV0XFxcIj48L3NwYW4+XFxyXFxuICAgICAgICA8L2E+XFxyXFxuICAgICAgICA8dWwgY2xhc3M9XFxcImRyb3Bkb3duLW1lbnVcXFwiPlxcclxcbiAgICAgICAgICAgIDxsaSBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPjxhIFtyb3V0ZXJMaW5rXT1cXFwiWycvU2V0dGluZ3MvVXBkYXRlJ11cXFwiPlVwZGF0ZTwvYT48L2xpPlxcclxcbiAgICAgICAgICAgIDxsaSBbcm91dGVyTGlua0FjdGl2ZV09XFxcIlsnYWN0aXZlJ11cXFwiPjxhIFtyb3V0ZXJMaW5rXT1cXFwiWycvU2V0dGluZ3MvTG9ncyddXFxcIj5Mb2dzPC9hPjwvbGk+XFxyXFxuICAgICAgICAgICAgPGxpIFtyb3V0ZXJMaW5rQWN0aXZlXT1cXFwiWydhY3RpdmUnXVxcXCI+PGEgW3JvdXRlckxpbmtdPVxcXCJbJy9TZXR0aW5ncy9TY2hlZHVsZWRKb2JzJ11cXFwiPlNjaGVkdWxlZCBKb2JzPC9hPjwvbGk+XFxyXFxuICAgICAgICA8L3VsPlxcclxcbiAgICA8L2xpPlxcclxcblxcclxcbjwvdWw+XFxyXFxuXFxyXFxuPGhyLz5cXHJcXG5cIjtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL0NsaWVudEFwcC9hcHAvc2V0dGluZ3Mvc2V0dGluZ3NtZW51LmNvbXBvbmVudC5odG1sXG4vLyBtb2R1bGUgaWQgPSAxOTFcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ=="); - -/***/ }), -/* 192 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n\\r\\n
\\r\\n
\\r\\n Sonarr Settings\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./ClientApp/app/settings/sonarr/sonarr.component.html?3033"],"names":[],"mappings":"AAAA,45BAA45B,aAAa,wZAAwZ,eAAe,uXAAuX,iBAAiB,o6CAAo6C,YAAY,IAAI,cAAc,00BAA00B,WAAW,IAAI,aAAa","file":"192.js","sourcesContent":["module.exports = \"\\r\\n<settings-menu></settings-menu>\\r\\n<div *ngIf=\\\"settings\\\">\\r\\n        <fieldset>\\r\\n            <legend>Sonarr Settings</legend>\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div class=\\\"checkbox\\\">\\r\\n                    <input type=\\\"checkbox\\\" [(ngModel)]=\\\"settings.enable\\\" ng-checked=\\\"settings.enable\\\">\\r\\n                    <label for=\\\"enable\\\">Enable</label>\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n            <input hidden=\\\"hidden\\\" name=\\\"FullRootPath\\\" id=\\\"fullRootPath\\\" value=\\\"settings.enable\\\" />\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"Ip\\\" class=\\\"control-label\\\">Sonarr Hostname or IP</label>\\r\\n                <div class=\\\"\\\">\\r\\n                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom \\\" [(ngModel)]=\\\"settings.ip\\\" id=\\\"Ip\\\" name=\\\"Ip\\\" placeholder=\\\"localhost\\\" value=\\\"{{settings.ip}}\\\">\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"portNumber\\\" class=\\\"control-label\\\">Port</label>\\r\\n\\r\\n                <div class=\\\"\\\">\\r\\n                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom \\\" [(ngModel)]=\\\"settings.port\\\" id=\\\"portNumber\\\" name=\\\"Port\\\" placeholder=\\\"Port Number\\\" value=\\\"{{settings.port}}\\\">\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"ApiKey\\\" class=\\\"control-label\\\">Sonarr API Key</label>\\r\\n                <div>\\r\\n                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom \\\" [(ngModel)]=\\\"settings.apiKey\\\" id=\\\"ApiKey\\\" name=\\\"ApiKey\\\" value=\\\"{{settings.apiKey}}\\\">\\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div class=\\\"checkbox\\\">\\r\\n\\r\\n                    <input type=\\\"checkbox\\\" id=\\\"Ssl\\\" name=\\\"Ssl\\\" ng-checked=\\\"settings.ssl\\\"><label for=\\\"Ssl\\\">SSL</label>\\r\\n\\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"SubDir\\\" class=\\\"control-label\\\">Sonarr Base Url</label>\\r\\n                <div>\\r\\n                    <input type=\\\"text\\\" class=\\\"form-control form-control-custom\\\" [(ngModel)]=\\\"settings.subDir\\\" id=\\\"SubDir\\\" name=\\\"SubDir\\\" value=\\\"@Model.SubDir\\\">\\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div>\\r\\n                    <button type=\\\"submit\\\" (click)=\\\"getProfiles()\\\" class=\\\"btn btn-primary-outline\\\">Get Quality Profiles <span *ngIf=\\\"profilesRunning\\\" class=\\\"fa fa-spinner fa-spin\\\"></span></button>\\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"select\\\" class=\\\"control-label\\\">Quality Profiles</label>\\r\\n                <div id=\\\"profiles\\\">\\r\\n                    <select class=\\\"form-control form-control-custom\\\" id=\\\"select\\\" *ngFor='let quality of qualities'>\\r\\n                        <option [selected]=\\\"qualityProfile === quality.name\\\" [ngValue]=\\\"selectedQuality\\\" value='{{quality.id}}'>{{quality.name}}</option>\\r\\n                    </select>\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div>\\r\\n                    <button type=\\\"submit\\\" (click)=\\\"getRootFolders()\\\" class=\\\"btn btn-primary-outline\\\">Get Root Folders <span *ngIf=\\\"rootFoldersRunning\\\" class=\\\"fa fa-spinner fa-spin\\\" ></span></button>\\r\\n\\r\\n                </div>\\r\\n\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <label for=\\\"rootFolders\\\" class=\\\"control-label\\\">Default Root Folders</label>\\r\\n                <div id=\\\"rootFolders\\\">\\r\\n                    <select class=\\\"form-control form-control-custom\\\" *ngFor='let folder of rootFolders'>\\r\\n                        <option [selected]=\\\"rootPath === folder.name\\\" [ngValue]=\\\"selectedRootFolder\\\" value='{{folder.id}}'>{{folder.name}}</option>\\r\\n                    </select>\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div class=\\\"checkbox\\\">\\r\\n                    <input type=\\\"checkbox\\\" id=\\\"SeasonFolders\\\" name=\\\"SeasonFolders\\\" ng-checked=\\\"settings.seasonFolders\\\">\\r\\n                    <label for=\\\"SeasonFolders\\\">Enable season folders</label>\\r\\n                </div>\\r\\n                <label>Enabled Season Folders to organize seasons into individual folders within a show.</label>\\r\\n            </div>\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div>\\r\\n                    <button (click)=\\\"test()\\\" type=\\\"submit\\\" class=\\\"btn btn-primary-outline\\\">Test Connectivity <span id=\\\"spinner\\\"> </span></button>\\r\\n                </div>\\r\\n            </div>\\r\\n\\r\\n\\r\\n            <div class=\\\"form-group\\\">\\r\\n                <div>\\r\\n                    <button (click)=\\\"save()\\\" type=\\\"submit\\\" class=\\\"btn btn-primary-outline \\\">Submit</button>\\r\\n                </div>\\r\\n            </div>\\r\\n        </fieldset>\\r\\n</div>\\r\\n\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./ClientApp/app/settings/sonarr/sonarr.component.html\n// module id = 192\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 193 */ -/***/ (function(module, exports) { - -eval("module.exports = \"

User Management

\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n Username\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n Alias\\r\\n \\r\\n \\r\\n \\r\\n Email\\r\\n \\r\\n \\r\\n Roles\\r\\n \\r\\n \\r\\n User Type\\r\\n \\r\\n
\\r\\n {{u.username}}\\r\\n \\r\\n {{u.alias}}\\r\\n \\r\\n {{u.emailAddress}}\\r\\n \\r\\n
{{claim.value}}
\\r\\n\\r\\n
\\r\\n Local User\\r\\n Plex User\\r\\n Emby User\\r\\n \\r\\n Details/Edit\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n

Editing User {{selectedUser?.username}}

\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n

Create User

\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./ClientApp/app/usermanagement/usermanagement.component.html?e45a"],"names":[],"mappings":"AAAA,q9CAAq9C,YAAY,mDAAmD,SAAS,mDAAmD,gBAAgB,uHAAuH,aAAa,miBAAmiB,gOAAgO,sEAAsE,wBAAwB,2aAA2a,wBAAwB,8XAA8X,qBAAqB,+aAA+a,4BAA4B,0WAA0W,SAAS,oHAAoH,SAAS,KAAK,SAAS,6mBAA6mB,oPAAoP,ofAAof,uBAAuB,qZAAqZ,oBAAoB,6bAA6b,2BAA2B,4aAA4a,uBAAuB,kXAAkX,SAAS,wHAAwH,SAAS,KAAK,SAAS","file":"193.js","sourcesContent":["module.exports = \"<h1>User Management</h1>\\r\\n\\r\\n\\r\\n<!--Search-->\\r\\n<div class=\\\"row\\\">\\r\\n    <div class=\\\"form-group\\\">\\r\\n        <div class=\\\"input-group\\\">\\r\\n            <div class=\\\"input-group-addon\\\">\\r\\n                <i class=\\\"fa fa-search\\\"></i>\\r\\n            </div>\\r\\n\\r\\n            <input type=\\\"text\\\" class=\\\"form-control\\\" placeholder=\\\"Search\\\" [(ngModel)]=\\\"searchTerm\\\">\\r\\n\\r\\n        </div>\\r\\n    </div>\\r\\n</div>\\r\\n\\r\\n\\r\\n\\r\\n<button type=\\\"button\\\" class=\\\"btn btn-success-outline\\\" (click)=\\\"showCreateDialogue=true\\\">Add User</button>\\r\\n<!-- Table -->\\r\\n<table class=\\\"table table-striped table-hover table-responsive table-condensed\\\">\\r\\n    <thead>\\r\\n    <tr>\\r\\n        <th>\\r\\n            <a>\\r\\n                Username\\r\\n                <!--<span ng-show=\\\"sortType == 'username' && !sortReverse\\\" class=\\\"fa fa-caret-down\\\"></span>\\r\\n                <span ng-show=\\\"sortType == 'username' && sortReverse\\\" class=\\\"fa fa-caret-up\\\"></span>-->\\r\\n            </a>\\r\\n        </th>\\r\\n        <th>\\r\\n            <a>\\r\\n                Alias\\r\\n            </a>\\r\\n        </th>\\r\\n        <th>\\r\\n            <a>\\r\\n                Email\\r\\n            </a>\\r\\n        </th>\\r\\n        <th>\\r\\n            Roles\\r\\n        </th>\\r\\n        <th>\\r\\n            <a>\\r\\n                User Type\\r\\n            </a>\\r\\n        </th>\\r\\n    </tr>\\r\\n    </thead>\\r\\n    <tbody>\\r\\n    <tr *ngFor=\\\"let u of users\\\">\\r\\n        <td>\\r\\n            {{u.username}}\\r\\n        </td>\\r\\n        <td>\\r\\n            {{u.alias}}\\r\\n        </td>\\r\\n        <td>\\r\\n            {{u.emailAddress}}\\r\\n        </td>\\r\\n        <td>\\r\\n            <div *ngFor=\\\"let claim of u.claims\\\"><span *ngIf=\\\"claim.enabled\\\">{{claim.value}}</span></div>\\r\\n\\r\\n        </td>\\r\\n        <td ng-hide=\\\"hideColumns\\\">\\r\\n            <span *ngIf=\\\"u.userType === 1\\\">Local User</span>\\r\\n            <span *ngIf=\\\"u.userType === 2\\\">Plex User</span>\\r\\n            <span *ngIf=\\\"u.userType === 3\\\">Emby User</span>\\r\\n        </td>\\r\\n        <td>\\r\\n            <a (click)=\\\"edit(u)\\\" class=\\\"btn btn-sm btn-info-outline\\\">Details/Edit</a>\\r\\n        </td>\\r\\n    </tr>\\r\\n    </tbody>\\r\\n</table>\\r\\n\\r\\n\\r\\n\\r\\n<div class=\\\"modal fade in\\\" *ngIf=\\\"showEditDialog\\\" style=\\\"display: block;\\\">\\r\\n    <div class=\\\"modal-dialog\\\">\\r\\n        <div class=\\\"modal-content\\\">\\r\\n            <div class=\\\"modal-header\\\">\\r\\n                <button type=\\\"button\\\" class=\\\"close\\\" (click)=\\\"showEditDialog=false\\\">&times;</button>\\r\\n                <h4 class=\\\"modal-title\\\">Editing User {{selectedUser?.username}}</h4>\\r\\n            </div>\\r\\n            <div class=\\\"modal-body\\\">\\r\\n                <div class=\\\"form-group\\\">\\r\\n                    <label for=\\\"username\\\" class=\\\"control-label\\\">Username</label>\\r\\n                    <div>\\r\\n                        <input type=\\\"text\\\" [(ngModel)]=\\\"selectedUser.username\\\" [readonly]=\\\"true\\\" class=\\\"form-control form-control-custom \\\" id=\\\"username\\\" name=\\\"username\\\" value=\\\"{{selectedUser?.username}}\\\">\\r\\n                    </div>\\r\\n                </div>\\r\\n                <div class=\\\"form-group\\\">\\r\\n                    <label for=\\\"alias\\\" class=\\\"control-label\\\">Alias</label>\\r\\n                    <div>\\r\\n                        <input type=\\\"text\\\" [(ngModel)]=\\\"selectedUser.alias\\\" class=\\\"form-control form-control-custom \\\" id=\\\"alias\\\" name=\\\"alias\\\" value=\\\"{{selectedUser?.alias}}\\\">\\r\\n                    </div>\\r\\n                </div>\\r\\n                \\r\\n                <div class=\\\"form-group\\\">\\r\\n                    <label for=\\\"alias\\\" class=\\\"control-label\\\">Email Address</label>\\r\\n                    <div>\\r\\n                        <input type=\\\"text\\\" [(ngModel)]=\\\"selectedUser.emailAddress\\\" class=\\\"form-control form-control-custom \\\" id=\\\"emailAddress\\\" name=\\\"emailAddress\\\" value=\\\"{{selectedUser?.emailAddress}}\\\">\\r\\n                    </div>\\r\\n                </div>\\r\\n                \\r\\n                <div *ngFor=\\\"let c of selectedUser.claims\\\">\\r\\n                    <div class=\\\"form-group\\\">\\r\\n                        <div class=\\\"checkbox\\\">\\r\\n                            <input type=\\\"checkbox\\\" [(ngModel)]=\\\"c.enabled\\\" [value]=\\\"c.value\\\" id=\\\"create{{c.value}}\\\" [attr.name]=\\\"'create' + c.value\\\" ng-checked=\\\"c.enabled\\\">\\r\\n                            <label for=\\\"create{{c.value}}\\\">{{c.value}}</label>\\r\\n\\r\\n                        </div>\\r\\n                    </div>\\r\\n\\r\\n         \\r\\n         \\r\\n                </div>\\r\\n            </div>\\r\\n            <div class=\\\"modal-footer\\\">\\r\\n                <button type=\\\"button\\\" class=\\\"btn btn-danger-outline\\\" (click)=\\\"showEditDialog=false\\\">Close</button>\\r\\n                <button type=\\\"button\\\" class=\\\"btn btn-primary-outline\\\" (click)=\\\"updateUser()\\\">Save changes</button>\\r\\n            </div>\\r\\n        </div>\\r\\n    </div>\\r\\n</div>\\r\\n\\r\\n\\r\\n\\r\\n<div>\\r\\n    <div class=\\\"modal fade in \\\" *ngIf=\\\"showCreateDialogue\\\" style=\\\"display: block;\\\">\\r\\n        <div class=\\\"modal-dialog\\\">\\r\\n            <div class=\\\"modal-content\\\">\\r\\n                <div class=\\\"modal-header\\\">\\r\\n                    <button type=\\\"button\\\" class=\\\"close\\\" (click)=\\\"showCreateDialogue=false\\\">&times;</button>\\r\\n                    <h4 class=\\\"modal-title\\\">Create User</h4>\\r\\n                </div>\\r\\n                <div class=\\\"modal-body\\\">\\r\\n                    <div class=\\\"form-group\\\">\\r\\n                        <label for=\\\"username\\\" class=\\\"control-label\\\">Username</label>\\r\\n                        <div>\\r\\n                            <input type=\\\"text\\\" [(ngModel)]=\\\"createdUser.username\\\" class=\\\"form-control form-control-custom \\\" id=\\\"username\\\" name=\\\"username\\\" value=\\\"{{createdUser?.username}}\\\">\\r\\n                        </div>\\r\\n                    </div>\\r\\n                    <div class=\\\"form-group\\\">\\r\\n                        <label for=\\\"alias\\\" class=\\\"control-label\\\">Alias</label>\\r\\n                        <div>\\r\\n                            <input type=\\\"text\\\" [(ngModel)]=\\\"createdUser.alias\\\" class=\\\"form-control form-control-custom \\\" id=\\\"alias\\\" name=\\\"alias\\\" value=\\\"{{createdUser?.alias}}\\\">\\r\\n                        </div>\\r\\n                    </div>\\r\\n\\r\\n                    <div class=\\\"form-group\\\">\\r\\n                        <label for=\\\"emailAddress\\\" class=\\\"control-label\\\">Email Address</label>\\r\\n                        <div>\\r\\n                            <input type=\\\"text\\\" [(ngModel)]=\\\"createdUser.emailAddress\\\" class=\\\"form-control form-control-custom \\\" id=\\\"emailAddress\\\" name=\\\"emailAddress\\\" value=\\\"{{createdUser?.emailAddress}}\\\">\\r\\n                        </div>\\r\\n                    </div>\\r\\n\\r\\n                    <div class=\\\"form-group\\\">\\r\\n                        <label for=\\\"password\\\" class=\\\"control-label\\\">Password</label>\\r\\n                        <div>\\r\\n                            <input type=\\\"password\\\" [(ngModel)]=\\\"createdUser.password\\\" class=\\\"form-control form-control-custom \\\" id=\\\"password\\\" name=\\\"password\\\" value=\\\"{{createdUser?.password}}\\\">\\r\\n                        </div>\\r\\n                    </div>\\r\\n\\r\\n\\r\\n                    <div *ngFor=\\\"let c of availableClaims\\\">\\r\\n                        <div class=\\\"form-group\\\">\\r\\n                            <div class=\\\"checkbox\\\">\\r\\n                                <input type=\\\"checkbox\\\" [(ngModel)]=\\\"c.enabled\\\" [value]=\\\"c.value\\\" id=\\\"create{{c.value}}\\\" [attr.name]=\\\"'create' + c.value\\\" ng-checked=\\\"c.enabled\\\">\\r\\n                                <label for=\\\"create{{c.value}}\\\">{{c.value}}</label>\\r\\n                            </div>\\r\\n                        </div>\\r\\n                    </div>\\r\\n                </div>\\r\\n                <div class=\\\"modal-footer\\\">\\r\\n                    <button type=\\\"button\\\" class=\\\"btn btn-danger-outline\\\" (click)=\\\"showCreateDialogue=false\\\">Close</button>\\r\\n                    <button type=\\\"button\\\" class=\\\"btn btn-primary-outline\\\" (click)=\\\"create()\\\">Add User</button>\\r\\n                </div>\\r\\n            </div>\\r\\n        </div>\\r\\n    </div>\\r\\n</div>\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./ClientApp/app/usermanagement/usermanagement.component.html\n// module id = 193\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 194 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n

Create the Admin account

\\r\\nThis account will be used to configure your settings and also manage all of the requests. Note: this should not be the same as your Plex/Emby account (you can change this later in the User Management Settings)\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3dpemFyZC9jcmVhdGVhZG1pbi9jcmVhdGVhZG1pbi5jb21wb25lbnQuaHRtbD9lMjEwIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHU3QkFBdTdCIiwiZmlsZSI6IjE5NC5qcyIsInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gXCJcXHJcXG48aDQgY2xhc3M9XFxcIm1lZGlhLWhlYWRpbmcgbGFuZGluZy10aXRsZVxcXCI+Q3JlYXRlIHRoZSBBZG1pbiBhY2NvdW50PC9oND5cXHJcXG48c21hbGw+VGhpcyBhY2NvdW50IHdpbGwgYmUgdXNlZCB0byBjb25maWd1cmUgeW91ciBzZXR0aW5ncyBhbmQgYWxzbyBtYW5hZ2UgYWxsIG9mIHRoZSByZXF1ZXN0cy4gTm90ZTogdGhpcyBzaG91bGQgbm90IGJlIHRoZSBzYW1lIGFzIHlvdXIgUGxleC9FbWJ5IGFjY291bnQgKHlvdSBjYW4gY2hhbmdlIHRoaXMgbGF0ZXIgaW4gdGhlIFVzZXIgTWFuYWdlbWVudCBTZXR0aW5ncyk8L3NtYWxsPlxcclxcbjxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICA8ZGl2PlxcclxcbiAgICAgICAgPGxhYmVsIGZvcj1cXFwiYWRtaW5Vc2VybmFtZVxcXCI+VXNlcm5hbWU8L2xhYmVsPlxcclxcbiAgICAgICAgPGlucHV0IHR5cGU9XFxcInRleHRcXFwiIGNsYXNzPVxcXCJmb3JtLWNvbnRyb2wgZm9ybS1jb250cm9sLWN1c3RvbVxcXCIgaWQ9XFxcImFkbWluVXNlcm5hbWVcXFwiIG5hbWU9XFxcIlVzZXJuYW1lXFxcIiBbKG5nTW9kZWwpXT1cXFwidXNlcm5hbWVcXFwiIHBsYWNlaG9sZGVyPVxcXCJVc2VybmFtZVxcXCI+XFxyXFxuICAgIDwvZGl2PlxcclxcbiAgICA8YnIgLz5cXHJcXG4gICAgPGRpdj5cXHJcXG4gICAgICAgIDxsYWJlbCBmb3I9XFxcImFkbWluUGFzc3dvcmRcXFwiPlBhc3N3b3JkPC9sYWJlbD5cXHJcXG4gICAgICAgIDxpbnB1dCB0eXBlPVxcXCJwYXNzd29yZFxcXCIgY2xhc3M9XFxcImZvcm0tY29udHJvbCBmb3JtLWNvbnRyb2wtY3VzdG9tXFxcIiBpZD1cXFwiYWRtaW5QYXNzd29yZFxcXCIgbmFtZT1cXFwiUGFzc3dvcmRcXFwiIFsobmdNb2RlbCldPVxcXCJwYXNzd29yZFxcXCIgcGxhY2Vob2xkZXI9XFxcIlBhc3N3b3JkXFxcIj5cXHJcXG4gICAgPC9kaXY+XFxyXFxuPC9kaXY+XFxyXFxuXFxyXFxuPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgIDxkaXYgc3R5bGU9XFxcInRleHQtYWxpZ246IGNlbnRlcjsgbWFyZ2luLXRvcDogMjBweFxcXCI+XFxyXFxuICAgICAgICA8YnV0dG9uIChjbGljayk9XFxcImNyZWF0ZVVzZXIoKVxcXCIgdHlwZT1cXFwic3VibWl0XFxcIiBjbGFzcz1cXFwiYnRuIGJ0bi1zdWNjZXNzLW91dGxpbmVcXFwiPkZpbmlzaDwvYnV0dG9uPlxcclxcbiAgICA8L2Rpdj5cXHJcXG48L2Rpdj5cIjtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL0NsaWVudEFwcC9hcHAvd2l6YXJkL2NyZWF0ZWFkbWluL2NyZWF0ZWFkbWluLmNvbXBvbmVudC5odG1sXG4vLyBtb2R1bGUgaWQgPSAxOTRcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ=="); - -/***/ }), -/* 195 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n

Emby Authentication

\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n Next
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3dpemFyZC9lbWJ5L2VtYnkuY29tcG9uZW50Lmh0bWw/Y2E0MiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxpcUJBQWlxQixtQkFBbUIsZ2tCQUFna0IiLCJmaWxlIjoiMTk1LmpzIiwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHMgPSBcIlxcclxcbjxoNCBjbGFzcz1cXFwibWVkaWEtaGVhZGluZyBsYW5kaW5nLXRpdGxlXFxcIj5FbWJ5IEF1dGhlbnRpY2F0aW9uPC9oND5cXHJcXG48ZGl2IGNsYXNzPVxcXCJmb3JtLWdyb3VwXFxcIj5cXHJcXG4gICAgPGxhYmVsIGZvcj1cXFwiSXBcXFwiIGNsYXNzPVxcXCJjb250cm9sLWxhYmVsXFxcIj5FbWJ5IEhvc3RuYW1lIG9yIElQIEFkZHJlc3M8L2xhYmVsPlxcclxcbiAgICA8ZGl2PlxcclxcbiAgICAgICAgPGlucHV0IHR5cGU9XFxcInRleHRcXFwiIFsobmdNb2RlbCldPVxcXCJlbWJ5U2V0dGluZ3MuaXBcXFwiIGNsYXNzPVxcXCJmb3JtLWNvbnRyb2wgZm9ybS1jb250cm9sLWN1c3RvbSBcXFwiIGlkPVxcXCJJcFxcXCIgbmFtZT1cXFwiSXBcXFwiIHBsYWNlaG9sZGVyPVxcXCIxOTIuMTY4LjEuMVxcXCI+XFxyXFxuICAgIDwvZGl2PlxcclxcbjwvZGl2PlxcclxcblxcclxcbjxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICA8bGFiZWwgZm9yPVxcXCJwb3J0TnVtYmVyXFxcIiBjbGFzcz1cXFwiY29udHJvbC1sYWJlbFxcXCI+UG9ydDwvbGFiZWw+XFxyXFxuXFxyXFxuICAgIDxkaXY+XFxyXFxuICAgICAgICA8aW5wdXQgdHlwZT1cXFwidGV4dFxcXCIgWyhuZ01vZGVsKV09XFxcImVtYnlTZXR0aW5ncy5wb3J0XFxcIiBjbGFzcz1cXFwiZm9ybS1jb250cm9sIGZvcm0tY29udHJvbC1jdXN0b20gXFxcIiBpZD1cXFwicG9ydE51bWJlclxcXCIgbmFtZT1cXFwiUG9ydFxcXCIgdmFsdWU9XFxcInt7ZW1ieVNldHRpbmdzLnBvcnR9fVxcXCI+XFxyXFxuICAgIDwvZGl2PlxcclxcbjwvZGl2PlxcclxcbjxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICA8ZGl2IGNsYXNzPVxcXCJjaGVja2JveFxcXCI+XFxyXFxuICAgICAgICA8aW5wdXQgdHlwZT1cXFwiY2hlY2tib3hcXFwiIFsobmdNb2RlbCldPVxcXCJlbWJ5U2V0dGluZ3Muc3NsXFxcIiBpZD1cXFwiU3NsXFxcIiBuYW1lPVxcXCJTc2xcXFwiPjxsYWJlbCBmb3I9XFxcIlNzbFxcXCI+U1NMPC9sYWJlbD5cXHJcXG4gICAgPC9kaXY+XFxyXFxuPC9kaXY+XFxyXFxuPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgIDxsYWJlbCBmb3I9XFxcInVzZXJuYW1lXFxcIiBjbGFzcz1cXFwiY29udHJvbC1sYWJlbFxcXCI+QXBpIEtleTwvbGFiZWw+XFxyXFxuICAgIDxkaXY+XFxyXFxuICAgICAgICA8aW5wdXQgdHlwZT1cXFwidGV4dFxcXCIgWyhuZ01vZGVsKV09XFxcImVtYnlTZXR0aW5ncy5hcGlLZXlcXFwiIGNsYXNzPVxcXCJmb3JtLWNvbnRyb2wgZm9ybS1jb250cm9sLWN1c3RvbVxcXCIgaWQ9XFxcImFwaUtleVxcXCIgbmFtZT1cXFwiQXBpS2V5XFxcIiBwbGFjZWhvbGRlcj1cXFwiQXBpS2V5XFxcIj5cXHJcXG4gICAgPC9kaXY+XFxyXFxuPC9kaXY+XFxyXFxuPGRpdiBzdHlsZT1cXFwidGV4dC1hbGlnbjogY2VudGVyOyBtYXJnaW4tdG9wOiAyMHB4XFxcIj5cXHJcXG4gICAgPGEgKGNsaWNrKT1cXFwic2F2ZSgpXFxcIiBpZD1cXFwiZW1ieUFwaUtleVNhdmVcXFwiIGNsYXNzPVxcXCJidG4gYnRuLXByaW1hcnktb3V0bGluZVxcXCI+TmV4dCA8ZGl2IGlkPVxcXCJzcGlubmVyXFxcIj48L2Rpdj48L2E+XFxyXFxuPC9kaXY+XCI7XG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9DbGllbnRBcHAvYXBwL3dpemFyZC9lbWJ5L2VtYnkuY29tcG9uZW50Lmh0bWxcbi8vIG1vZHVsZSBpZCA9IDE5NVxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 196 */ -/***/ (function(module, exports) { - -eval("module.exports = \"
\\r\\n

Please choose your media server

\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3dpemFyZC9tZWRpYXNlcnZlci9tZWRpYXNlcnZlci5jb21wb25lbnQuaHRtbD85MDQ4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBIiwiZmlsZSI6IjE5Ni5qcyIsInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gXCIgICAgPGRpdj5cXHJcXG4gICAgPGg0IGNsYXNzPVxcXCJtZWRpYS1oZWFkaW5nIGxhbmRpbmctdGl0bGUgd2l6YXJkLWhlYWRpbmdcXFwiIGlkPVxcXCJzdGF0dXNUaXRsZVxcXCI+UGxlYXNlIGNob29zZSB5b3VyIG1lZGlhIHNlcnZlcjwvaDQ+XFxyXFxuICAgIDxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICAgICAgPGRpdiBjbGFzcz1cXFwicm93XFxcIj5cXHJcXG4gICAgICAgICAgICA8YSAoY2xpY2spPVxcXCJlbWJ5KClcXFwiIGlkPVxcXCJlbWJ5SW1nXFxcIj5cXHJcXG4gICAgICAgICAgICAgICAgPGltZyBjbGFzcz1cXFwid2l6YXJkLWltZ1xcXCIgc3JjPVxcXCIvaW1hZ2VzL2VtYnktbG9nby1kYXJrLmpwZ1xcXCIgLz5cXHJcXG4gICAgICAgICAgICA8L2E+XFxyXFxuICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDxkaXYgY2xhc3M9XFxcInJvd1xcXCI+XFxyXFxuICAgICAgICAgICAgPGEgKGNsaWNrKT1cXFwicGxleCgpXFxcIiBpZD1cXFwicGxleEltZ1xcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxpbWcgY2xhc3M9XFxcIndpemFyZC1pbWdcXFwiIHNyYz1cXFwiL2ltYWdlcy9wbGV4LWxvZ28tcmV2ZXJzZWQucG5nXFxcIiAvPlxcclxcbiAgICAgICAgICAgIDwvYT5cXHJcXG5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcblxcclxcbiAgICA8L2Rpdj5cXHJcXG48L2Rpdj5cIjtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL0NsaWVudEFwcC9hcHAvd2l6YXJkL21lZGlhc2VydmVyL21lZGlhc2VydmVyLmNvbXBvbmVudC5odG1sXG4vLyBtb2R1bGUgaWQgPSAxOTZcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ=="); - -/***/ }), -/* 197 */ -/***/ (function(module, exports) { - -eval("module.exports = \"

Plex Authentication

\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\nPlease note we do not store this information, we only store your Plex Authorization Token that will allow Ombi to view your media and friends\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3dpemFyZC9wbGV4L3BsZXguY29tcG9uZW50Lmh0bWw/YjQ4YyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx5d0JBQXl3QiIsImZpbGUiOiIxOTcuanMiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IFwiPGg0IGNsYXNzPVxcXCJtZWRpYS1oZWFkaW5nIGxhbmRpbmctdGl0bGVcXFwiPlBsZXggQXV0aGVudGljYXRpb248L2g0PlxcclxcbjxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICA8bGFiZWwgZm9yPVxcXCJ1c2VybmFtZVxcXCIgY2xhc3M9XFxcImNvbnRyb2wtbGFiZWxcXFwiPlVzZXJuYW1lIGFuZCBQYXNzd29yZDwvbGFiZWw+XFxyXFxuICAgIDxkaXY+XFxyXFxuICAgICAgICA8aW5wdXQgdHlwZT1cXFwidGV4dFxcXCIgWyhuZ01vZGVsKV09XFxcImxvZ2luXFxcIiBjbGFzcz1cXFwiZm9ybS1jb250cm9sIGZvcm0tY29udHJvbC1jdXN0b21cXFwiIGlkPVxcXCJ1c2VybmFtZVxcXCIgIHBsYWNlaG9sZGVyPVxcXCJVc2VybmFtZVxcXCI+XFxyXFxuICAgIDwvZGl2PlxcclxcbiAgICA8YnIgLz5cXHJcXG4gICAgPGRpdj5cXHJcXG4gICAgICAgIDxpbnB1dCB0eXBlPVxcXCJwYXNzd29yZFxcXCIgWyhuZ01vZGVsKV09XFxcInBhc3N3b3JkXFxcIiBjbGFzcz1cXFwiZm9ybS1jb250cm9sIGZvcm0tY29udHJvbC1jdXN0b21cXFwiIHBsYWNlaG9sZGVyPVxcXCJQYXNzd29yZFxcXCI+XFxyXFxuICAgIDwvZGl2PlxcclxcbjwvZGl2PlxcclxcbjxzbWFsbD5QbGVhc2Ugbm90ZSB3ZSBkbyBub3Qgc3RvcmUgdGhpcyBpbmZvcm1hdGlvbiwgd2Ugb25seSBzdG9yZSB5b3VyIFBsZXggQXV0aG9yaXphdGlvbiBUb2tlbiB0aGF0IHdpbGwgYWxsb3cgT21iaSB0byB2aWV3IHlvdXIgbWVkaWEgYW5kIGZyaWVuZHM8L3NtYWxsPlxcclxcbjxkaXYgY2xhc3M9XFxcImZvcm0tZ3JvdXBcXFwiPlxcclxcbiAgICA8ZGl2IHN0eWxlPVxcXCJ0ZXh0LWFsaWduOiBjZW50ZXI7IG1hcmdpbi10b3A6IDIwcHhcXFwiPlxcclxcbiAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVxcXCJyZXF1ZXN0QXV0aFRva2VuKClcXFwiIGNsYXNzPVxcXCJidG4gYnRuLXByaW1hcnktb3V0bGluZVxcXCI+UmVxdWVzdCBUb2tlbiA8aSBjbGFzcz1cXFwiZmEgZmEta2V5XFxcIj48L2k+PC9idXR0b24+XFxyXFxuICAgIDwvZGl2PlxcclxcbjwvZGl2PlwiO1xuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIC4vQ2xpZW50QXBwL2FwcC93aXphcmQvcGxleC9wbGV4LmNvbXBvbmVudC5odG1sXG4vLyBtb2R1bGUgaWQgPSAxOTdcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ=="); - -/***/ }), -/* 198 */ -/***/ (function(module, exports) { - -eval("module.exports = \"\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n

Welcome to Ombi

\\r\\n
\\r\\n we are just going to run though the initial Ombi setup!\\r\\n\\r\\n
\\r\\n Next\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\";//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9DbGllbnRBcHAvYXBwL3dpemFyZC93ZWxjb21lL3dlbGNvbWUuY29tcG9uZW50Lmh0bWw/MDMwMSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx3Z0JBQXdnQiIsImZpbGUiOiIxOTguanMiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IFwiXFxyXFxuPGltZyBjbGFzcz1cXFwibGFuZGluZy1oZWFkZXJcXFwiIHNyYz1cXFwiL2ltYWdlcy9sb2dvLnBuZ1xcXCIgd2lkdGg9XFxcIjMwMFxcXCIgLz5cXHJcXG48ZGl2IGlkPVxcXCJhcmVhXFxcIiBjbGFzcz1cXFwibGFuZGluZy1ibG9jayBzaGFkb3dcXFwiPlxcclxcblxcclxcbiAgICA8ZGl2IGNsYXNzPVxcXCJtZWRpYVxcXCI+XFxyXFxuICAgICAgICA8ZGl2IGlkPVxcXCJjb250ZW50Qm9keVxcXCIgY2xhc3M9XFxcIm1lZGlhLWJvZHlcXFwiPlxcclxcbiAgICAgICAgICAgIDxoNCBjbGFzcz1cXFwibWVkaWEtaGVhZGluZyBsYW5kaW5nLXRpdGxlXFxcIiBpZD1cXFwic3RhdHVzVGl0bGVcXFwiPldlbGNvbWUgdG8gT21iaTwvaDQ+XFxyXFxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cXFwiZm9ybS1ncm91cFxcXCI+XFxyXFxuICAgICAgICAgICAgICAgIDxzbWFsbD53ZSBhcmUganVzdCBnb2luZyB0byBydW4gdGhvdWdoIHRoZSBpbml0aWFsIE9tYmkgc2V0dXAhPC9zbWFsbD5cXHJcXG5cXHJcXG4gICAgICAgICAgICAgICAgPGRpdiBzdHlsZT1cXFwidGV4dC1hbGlnbjogY2VudGVyOyBtYXJnaW4tdG9wOiAyMHB4XFxcIj5cXHJcXG4gICAgICAgICAgICAgICAgICAgIDxhIChjbGljayk9XFxcIm5leHQoKVxcXCIgY2xhc3M9XFxcImJ0biBidG4tcHJpbWFyeS1vdXRsaW5lXFxcIj5OZXh0PC9hPlxcclxcbiAgICAgICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgICAgICA8L2Rpdj5cXHJcXG4gICAgICAgIDwvZGl2PlxcclxcbiAgICA8L2Rpdj5cXHJcXG48L2Rpdj5cXHJcXG5cIjtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL0NsaWVudEFwcC9hcHAvd2l6YXJkL3dlbGNvbWUvd2VsY29tZS5jb21wb25lbnQuaHRtbFxuLy8gbW9kdWxlIGlkID0gMTk4XG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0="); - -/***/ }), -/* 199 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -eval("\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar core_1 = __webpack_require__(0);\nvar dragula_directive_1 = __webpack_require__(116);\nvar dragula_provider_1 = __webpack_require__(55);\nvar DragulaModule = (function () {\n function DragulaModule() {\n }\n return DragulaModule;\n}());\nDragulaModule = __decorate([\n core_1.NgModule({\n exports: [dragula_directive_1.DragulaDirective],\n declarations: [dragula_directive_1.DragulaDirective],\n providers: [dragula_provider_1.DragulaService]\n })\n], DragulaModule);\nexports.DragulaModule = DragulaModule;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9+L25nMi1kcmFndWxhL2NvbXBvbmVudHMvZHJhZ3VsYXIubW9kdWxlLmpzPzI1ZTAiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0Q0FBNEMsUUFBUTtBQUNwRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxDQUFDO0FBQ0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBIiwiZmlsZSI6IjE5OS5qcyIsInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xudmFyIF9fZGVjb3JhdGUgPSAodGhpcyAmJiB0aGlzLl9fZGVjb3JhdGUpIHx8IGZ1bmN0aW9uIChkZWNvcmF0b3JzLCB0YXJnZXQsIGtleSwgZGVzYykge1xuICAgIHZhciBjID0gYXJndW1lbnRzLmxlbmd0aCwgciA9IGMgPCAzID8gdGFyZ2V0IDogZGVzYyA9PT0gbnVsbCA/IGRlc2MgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKHRhcmdldCwga2V5KSA6IGRlc2MsIGQ7XG4gICAgaWYgKHR5cGVvZiBSZWZsZWN0ID09PSBcIm9iamVjdFwiICYmIHR5cGVvZiBSZWZsZWN0LmRlY29yYXRlID09PSBcImZ1bmN0aW9uXCIpIHIgPSBSZWZsZWN0LmRlY29yYXRlKGRlY29yYXRvcnMsIHRhcmdldCwga2V5LCBkZXNjKTtcbiAgICBlbHNlIGZvciAodmFyIGkgPSBkZWNvcmF0b3JzLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKSBpZiAoZCA9IGRlY29yYXRvcnNbaV0pIHIgPSAoYyA8IDMgPyBkKHIpIDogYyA+IDMgPyBkKHRhcmdldCwga2V5LCByKSA6IGQodGFyZ2V0LCBrZXkpKSB8fCByO1xuICAgIHJldHVybiBjID4gMyAmJiByICYmIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgciksIHI7XG59O1xudmFyIGNvcmVfMSA9IHJlcXVpcmUoXCJAYW5ndWxhci9jb3JlXCIpO1xudmFyIGRyYWd1bGFfZGlyZWN0aXZlXzEgPSByZXF1aXJlKFwiLi9kcmFndWxhLmRpcmVjdGl2ZVwiKTtcbnZhciBkcmFndWxhX3Byb3ZpZGVyXzEgPSByZXF1aXJlKFwiLi9kcmFndWxhLnByb3ZpZGVyXCIpO1xudmFyIERyYWd1bGFNb2R1bGUgPSAoZnVuY3Rpb24gKCkge1xuICAgIGZ1bmN0aW9uIERyYWd1bGFNb2R1bGUoKSB7XG4gICAgfVxuICAgIHJldHVybiBEcmFndWxhTW9kdWxlO1xufSgpKTtcbkRyYWd1bGFNb2R1bGUgPSBfX2RlY29yYXRlKFtcbiAgICBjb3JlXzEuTmdNb2R1bGUoe1xuICAgICAgICBleHBvcnRzOiBbZHJhZ3VsYV9kaXJlY3RpdmVfMS5EcmFndWxhRGlyZWN0aXZlXSxcbiAgICAgICAgZGVjbGFyYXRpb25zOiBbZHJhZ3VsYV9kaXJlY3RpdmVfMS5EcmFndWxhRGlyZWN0aXZlXSxcbiAgICAgICAgcHJvdmlkZXJzOiBbZHJhZ3VsYV9wcm92aWRlcl8xLkRyYWd1bGFTZXJ2aWNlXVxuICAgIH0pXG5dLCBEcmFndWxhTW9kdWxlKTtcbmV4cG9ydHMuRHJhZ3VsYU1vZHVsZSA9IERyYWd1bGFNb2R1bGU7XG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL34vbmcyLWRyYWd1bGEvY29tcG9uZW50cy9kcmFndWxhci5tb2R1bGUuanNcbi8vIG1vZHVsZSBpZCA9IDE5OVxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 200 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -eval("\nvar dragula_class_1 = __webpack_require__(54);\nexports.dragula = dragula_class_1.dragula;\nvar dragula_directive_1 = __webpack_require__(116);\nexports.DragulaDirective = dragula_directive_1.DragulaDirective;\nvar dragula_provider_1 = __webpack_require__(55);\nexports.DragulaService = dragula_provider_1.DragulaService;\nvar dragular_module_1 = __webpack_require__(199);\nexports.DragulaModule = dragular_module_1.DragulaModule;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9+L25nMi1kcmFndWxhL2luZGV4LmpzPzNmNmYiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6IjIwMC5qcyIsInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xudmFyIGRyYWd1bGFfY2xhc3NfMSA9IHJlcXVpcmUoXCIuL2NvbXBvbmVudHMvZHJhZ3VsYS5jbGFzc1wiKTtcbmV4cG9ydHMuZHJhZ3VsYSA9IGRyYWd1bGFfY2xhc3NfMS5kcmFndWxhO1xudmFyIGRyYWd1bGFfZGlyZWN0aXZlXzEgPSByZXF1aXJlKFwiLi9jb21wb25lbnRzL2RyYWd1bGEuZGlyZWN0aXZlXCIpO1xuZXhwb3J0cy5EcmFndWxhRGlyZWN0aXZlID0gZHJhZ3VsYV9kaXJlY3RpdmVfMS5EcmFndWxhRGlyZWN0aXZlO1xudmFyIGRyYWd1bGFfcHJvdmlkZXJfMSA9IHJlcXVpcmUoXCIuL2NvbXBvbmVudHMvZHJhZ3VsYS5wcm92aWRlclwiKTtcbmV4cG9ydHMuRHJhZ3VsYVNlcnZpY2UgPSBkcmFndWxhX3Byb3ZpZGVyXzEuRHJhZ3VsYVNlcnZpY2U7XG52YXIgZHJhZ3VsYXJfbW9kdWxlXzEgPSByZXF1aXJlKFwiLi9jb21wb25lbnRzL2RyYWd1bGFyLm1vZHVsZVwiKTtcbmV4cG9ydHMuRHJhZ3VsYU1vZHVsZSA9IGRyYWd1bGFyX21vZHVsZV8xLkRyYWd1bGFNb2R1bGU7XG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL34vbmcyLWRyYWd1bGEvaW5kZXguanNcbi8vIG1vZHVsZSBpZCA9IDIwMFxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 201 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -eval("Object.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"InfiniteScrollModule\", function() { return InfiniteScrollModule; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ɵa\", function() { return InfiniteScrollDirective; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ɵb\", function() { return PositionResolver; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ɵc\", function() { return ScrollRegister; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ɵd\", function() { return ScrollResolver; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__angular_core__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_rxjs_Observable__ = __webpack_require__(24);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_rxjs_Observable___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_rxjs_Observable__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_rxjs_add_observable_fromEvent__ = __webpack_require__(297);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_rxjs_add_observable_fromEvent___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_rxjs_add_observable_fromEvent__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_rxjs_add_observable_of__ = __webpack_require__(298);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_rxjs_add_observable_of___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_rxjs_add_observable_of__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_rxjs_add_operator_sampleTime__ = __webpack_require__(202);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_rxjs_add_operator_sampleTime___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_rxjs_add_operator_sampleTime__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_rxjs_add_operator_filter__ = __webpack_require__(299);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_rxjs_add_operator_filter___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_rxjs_add_operator_filter__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_rxjs_add_operator_mergeMap__ = __webpack_require__(300);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_rxjs_add_operator_mergeMap___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_rxjs_add_operator_mergeMap__);\n\n\n\n\n\n\n\nvar PositionResolver = (function () {\n function PositionResolver() {\n }\n /**\n * @param {?} options\n * @return {?}\n */\n PositionResolver.prototype.create = function (options) {\n var /** @type {?} */ isWindow = this.isElementWindow(options.windowElement);\n var /** @type {?} */ resolver = {\n axis: options.axis,\n container: this.defineContainer(options.windowElement, isWindow),\n isWindow: isWindow,\n };\n return resolver;\n };\n /**\n * @param {?} windowElement\n * @param {?} isContainerWindow\n * @return {?}\n */\n PositionResolver.prototype.defineContainer = function (windowElement, isContainerWindow) {\n var /** @type {?} */ container = (isContainerWindow || !windowElement.nativeElement)\n ? windowElement\n : windowElement.nativeElement;\n return container;\n };\n /**\n * @param {?} windowElement\n * @return {?}\n */\n PositionResolver.prototype.isElementWindow = function (windowElement) {\n var /** @type {?} */ isWindow = Object.prototype.toString.call(windowElement).includes('Window');\n return isWindow;\n };\n /**\n * @param {?} isContainerWindow\n * @param {?} windowElement\n * @return {?}\n */\n PositionResolver.prototype.getDocumentElement = function (isContainerWindow, windowElement) {\n return isContainerWindow\n ? windowElement.document.documentElement\n : null;\n };\n /**\n * @param {?} element\n * @param {?} resolver\n * @return {?}\n */\n PositionResolver.prototype.calculatePoints = function (element, resolver) {\n return resolver.isWindow\n ? this.calculatePointsForWindow(element, resolver)\n : this.calculatePointsForElement(element, resolver);\n };\n /**\n * @param {?} element\n * @param {?} resolver\n * @return {?}\n */\n PositionResolver.prototype.calculatePointsForWindow = function (element, resolver) {\n var axis = resolver.axis, container = resolver.container, isWindow = resolver.isWindow;\n var /** @type {?} */ offsetHeightKey = axis.offsetHeightKey();\n var /** @type {?} */ clientHeightKey = axis.clientHeightKey();\n var /** @type {?} */ topKey = axis.topKey();\n // container's height\n var /** @type {?} */ height = this.height(container, isWindow, offsetHeightKey, clientHeightKey);\n // scrolled until now / current y point\n var /** @type {?} */ scrolledUntilNow = height + this.pageYOffset(this.getDocumentElement(isWindow, container), axis, isWindow);\n // total height / most bottom y point\n var /** @type {?} */ nativeElementHeight = this.height(element.nativeElement, isWindow, offsetHeightKey, clientHeightKey);\n var /** @type {?} */ totalToScroll = this.offsetTop(element.nativeElement, axis, isWindow) + nativeElementHeight;\n return { height: height, scrolledUntilNow: scrolledUntilNow, totalToScroll: totalToScroll };\n };\n /**\n * @param {?} element\n * @param {?} resolver\n * @return {?}\n */\n PositionResolver.prototype.calculatePointsForElement = function (element, resolver) {\n var axis = resolver.axis, container = resolver.container, isWindow = resolver.isWindow;\n var /** @type {?} */ offsetHeightKey = axis.offsetHeightKey();\n var /** @type {?} */ clientHeightKey = axis.clientHeightKey();\n var /** @type {?} */ scrollTop = axis.scrollTopKey();\n var /** @type {?} */ scrollHeight = axis.scrollHeightKey();\n var /** @type {?} */ topKey = axis.topKey();\n var /** @type {?} */ height = this.height(container, isWindow, offsetHeightKey, clientHeightKey);\n // perhaps use this.container.offsetTop instead of 'scrollTop'\n var /** @type {?} */ scrolledUntilNow = container[scrollTop];\n var /** @type {?} */ containerTopOffset = 0;\n var /** @type {?} */ offsetTop = this.offsetTop(container, axis, isWindow);\n if (offsetTop !== void 0) {\n containerTopOffset = offsetTop;\n }\n var /** @type {?} */ totalToScroll = container[scrollHeight];\n return { height: height, scrolledUntilNow: scrolledUntilNow, totalToScroll: totalToScroll };\n };\n /**\n * @param {?} elem\n * @param {?} isWindow\n * @param {?} offsetHeightKey\n * @param {?} clientHeightKey\n * @return {?}\n */\n PositionResolver.prototype.height = function (elem, isWindow, offsetHeightKey, clientHeightKey) {\n if (isNaN(elem[offsetHeightKey])) {\n return this.getDocumentElement(isWindow, elem)[clientHeightKey];\n }\n else {\n return elem[offsetHeightKey];\n }\n };\n /**\n * @param {?} elem\n * @param {?} axis\n * @param {?} isWindow\n * @return {?}\n */\n PositionResolver.prototype.offsetTop = function (elem, axis, isWindow) {\n var /** @type {?} */ topKey = axis.topKey();\n // elem = elem.nativeElement;\n if (!elem.getBoundingClientRect) {\n return;\n }\n return elem.getBoundingClientRect()[topKey] + this.pageYOffset(elem, axis, isWindow);\n };\n /**\n * @param {?} elem\n * @param {?} axis\n * @param {?} isWindow\n * @return {?}\n */\n PositionResolver.prototype.pageYOffset = function (elem, axis, isWindow) {\n var /** @type {?} */ pageYOffset = axis.pageYOffsetKey();\n var /** @type {?} */ scrollTop = axis.scrollTopKey();\n var /** @type {?} */ offsetTop = axis.offsetTopKey();\n if (isNaN(window[pageYOffset])) {\n return this.getDocumentElement(isWindow, elem)[scrollTop];\n }\n else if (elem.ownerDocument) {\n return elem.ownerDocument.defaultView[pageYOffset];\n }\n else {\n return elem[offsetTop];\n }\n };\n return PositionResolver;\n}());\nPositionResolver.decorators = [\n { type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Injectable\"] },\n];\n/**\n * @nocollapse\n */\nPositionResolver.ctorParameters = function () { return []; };\nvar ScrollRegister = (function () {\n function ScrollRegister() {\n }\n /**\n * @param {?} options\n * @return {?}\n */\n ScrollRegister.prototype.attachEvent = function (options) {\n var /** @type {?} */ scroller$ = __WEBPACK_IMPORTED_MODULE_1_rxjs_Observable__[\"Observable\"].fromEvent(options.container, 'scroll')\n .sampleTime(options.throttleDuration)\n .filter(options.filterBefore)\n .mergeMap(function (ev) { return __WEBPACK_IMPORTED_MODULE_1_rxjs_Observable__[\"Observable\"].of(options.mergeMap(ev)); })\n .subscribe(options.scrollHandler);\n return scroller$;\n };\n return ScrollRegister;\n}());\nScrollRegister.decorators = [\n { type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Injectable\"] },\n];\n/**\n * @nocollapse\n */\nScrollRegister.ctorParameters = function () { return []; };\nvar ScrollResolver = (function () {\n function ScrollResolver() {\n this.lastScrollPosition = 0;\n }\n /**\n * @param {?} container\n * @param {?} config\n * @param {?} scrollingDown\n * @return {?}\n */\n ScrollResolver.prototype.shouldScroll = function (container, config, scrollingDown) {\n var /** @type {?} */ distance = config.distance;\n var /** @type {?} */ remaining;\n var /** @type {?} */ containerBreakpoint;\n if (scrollingDown) {\n remaining = container.totalToScroll - container.scrolledUntilNow;\n containerBreakpoint = container.height * distance.down + 1;\n }\n else {\n remaining = container.scrolledUntilNow;\n containerBreakpoint = container.height * distance.up + 1;\n }\n var /** @type {?} */ shouldScroll = remaining <= containerBreakpoint;\n this.lastScrollPosition = container.scrolledUntilNow;\n return shouldScroll;\n };\n /**\n * @param {?} container\n * @return {?}\n */\n ScrollResolver.prototype.isScrollingDown = function (container) {\n return this.lastScrollPosition < container.scrolledUntilNow;\n };\n /**\n * @param {?} container\n * @param {?} config\n * @return {?}\n */\n ScrollResolver.prototype.getScrollStats = function (container, config) {\n var /** @type {?} */ isScrollingDown = this.isScrollingDown(container);\n var /** @type {?} */ shouldScroll = this.shouldScroll(container, config, isScrollingDown);\n return { isScrollingDown: isScrollingDown, shouldScroll: shouldScroll };\n };\n return ScrollResolver;\n}());\nScrollResolver.decorators = [\n { type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Injectable\"] },\n];\n/**\n * @nocollapse\n */\nScrollResolver.ctorParameters = function () { return []; };\nvar AxisResolver = (function () {\n /**\n * @param {?=} vertical\n */\n function AxisResolver(vertical) {\n if (vertical === void 0) { vertical = true; }\n this.vertical = vertical;\n }\n /**\n * @return {?}\n */\n AxisResolver.prototype.clientHeightKey = function () { return this.vertical ? 'clientHeight' : 'clientWidth'; };\n /**\n * @return {?}\n */\n AxisResolver.prototype.offsetHeightKey = function () { return this.vertical ? 'offsetHeight' : 'offsetWidth'; };\n /**\n * @return {?}\n */\n AxisResolver.prototype.scrollHeightKey = function () { return this.vertical ? 'scrollHeight' : 'scrollWidth'; };\n /**\n * @return {?}\n */\n AxisResolver.prototype.pageYOffsetKey = function () { return this.vertical ? 'pageYOffset' : 'pageXOffset'; };\n /**\n * @return {?}\n */\n AxisResolver.prototype.offsetTopKey = function () { return this.vertical ? 'offsetTop' : 'offsetLeft'; };\n /**\n * @return {?}\n */\n AxisResolver.prototype.scrollTopKey = function () { return this.vertical ? 'scrollTop' : 'scrollLeft'; };\n /**\n * @return {?}\n */\n AxisResolver.prototype.topKey = function () { return this.vertical ? 'top' : 'left'; };\n return AxisResolver;\n}());\nvar InfiniteScrollDirective = (function () {\n /**\n * @param {?} element\n * @param {?} zone\n * @param {?} positionResolver\n * @param {?} scrollRegister\n * @param {?} scrollerResolver\n */\n function InfiniteScrollDirective(element, zone, positionResolver, scrollRegister, scrollerResolver) {\n this.element = element;\n this.zone = zone;\n this.positionResolver = positionResolver;\n this.scrollRegister = scrollRegister;\n this.scrollerResolver = scrollerResolver;\n this.scrolled = new __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"EventEmitter\"]();\n this.scrolledUp = new __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"EventEmitter\"]();\n this.infiniteScrollDistance = 2;\n this.infiniteScrollUpDistance = 1.5;\n this.infiniteScrollThrottle = 300;\n this.infiniteScrollDisabled = false;\n this.infiniteScrollContainer = null;\n this.scrollWindow = true;\n this.immediateCheck = false;\n this.horizontal = false;\n this.alwaysCallback = false;\n }\n /**\n * @return {?}\n */\n InfiniteScrollDirective.prototype.ngOnInit = function () {\n var _this = this;\n if (typeof window !== 'undefined') {\n this.zone.runOutsideAngular(function () {\n var /** @type {?} */ containerElement = _this.resolveContainerElement();\n var /** @type {?} */ resolver = _this.positionResolver.create({\n axis: new AxisResolver(!_this.horizontal),\n windowElement: containerElement,\n });\n var /** @type {?} */ options = {\n container: resolver.container,\n filterBefore: function () { return !_this.infiniteScrollDisabled; },\n mergeMap: function () { return _this.positionResolver.calculatePoints(_this.element, resolver); },\n scrollHandler: function (container) { return _this.handleOnScroll(container); },\n throttleDuration: _this.infiniteScrollThrottle\n };\n _this.disposeScroller = _this.scrollRegister.attachEvent(options);\n });\n }\n };\n /**\n * @param {?} container\n * @return {?}\n */\n InfiniteScrollDirective.prototype.handleOnScroll = function (container) {\n var /** @type {?} */ distance = {\n down: this.infiniteScrollDistance,\n up: this.infiniteScrollUpDistance\n };\n var /** @type {?} */ scrollStats = this.scrollerResolver.getScrollStats(container, { distance: distance });\n if (this.shouldTriggerEvents(scrollStats.shouldScroll)) {\n var /** @type {?} */ infiniteScrollEvent = {\n currentScrollPosition: container.scrolledUntilNow\n };\n if (scrollStats.isScrollingDown) {\n this.onScrollDown(infiniteScrollEvent);\n }\n else {\n this.onScrollUp(infiniteScrollEvent);\n }\n }\n };\n /**\n * @param {?} shouldScroll\n * @return {?}\n */\n InfiniteScrollDirective.prototype.shouldTriggerEvents = function (shouldScroll) {\n return (this.alwaysCallback || shouldScroll) && !this.infiniteScrollDisabled;\n };\n /**\n * @return {?}\n */\n InfiniteScrollDirective.prototype.ngOnDestroy = function () {\n if (this.disposeScroller) {\n this.disposeScroller.unsubscribe();\n }\n };\n /**\n * @param {?=} data\n * @return {?}\n */\n InfiniteScrollDirective.prototype.onScrollDown = function (data) {\n var _this = this;\n if (data === void 0) { data = { currentScrollPosition: 0 }; }\n this.zone.run(function () { return _this.scrolled.emit(data); });\n };\n /**\n * @param {?=} data\n * @return {?}\n */\n InfiniteScrollDirective.prototype.onScrollUp = function (data) {\n var _this = this;\n if (data === void 0) { data = { currentScrollPosition: 0 }; }\n this.zone.run(function () { return _this.scrolledUp.emit(data); });\n };\n /**\n * @return {?}\n */\n InfiniteScrollDirective.prototype.resolveContainerElement = function () {\n var /** @type {?} */ selector = this.infiniteScrollContainer;\n var /** @type {?} */ hasWindow = window && window.hasOwnProperty('document');\n var /** @type {?} */ containerIsString = selector && hasWindow && typeof (this.infiniteScrollContainer) === 'string';\n var /** @type {?} */ container = containerIsString\n ? window.document.querySelector(selector)\n : selector;\n if (!selector) {\n container = this.scrollWindow ? window : this.element;\n }\n return container;\n };\n return InfiniteScrollDirective;\n}());\nInfiniteScrollDirective.decorators = [\n { type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Directive\"], args: [{\n selector: '[infiniteScroll], [infinite-scroll], [data-infinite-scroll]'\n },] },\n];\n/**\n * @nocollapse\n */\nInfiniteScrollDirective.ctorParameters = function () { return [\n { type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"ElementRef\"], },\n { type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"NgZone\"], },\n { type: PositionResolver, },\n { type: ScrollRegister, },\n { type: ScrollResolver, },\n]; };\nInfiniteScrollDirective.propDecorators = {\n 'scrolled': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Output\"] },],\n 'scrolledUp': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Output\"] },],\n 'infiniteScrollDistance': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n 'infiniteScrollUpDistance': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n 'infiniteScrollThrottle': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n 'infiniteScrollDisabled': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n 'infiniteScrollContainer': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n 'scrollWindow': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n 'immediateCheck': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n 'horizontal': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n 'alwaysCallback': [{ type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"Input\"] },],\n};\nvar InfiniteScrollModule = (function () {\n function InfiniteScrollModule() {\n }\n return InfiniteScrollModule;\n}());\nInfiniteScrollModule.decorators = [\n { type: __WEBPACK_IMPORTED_MODULE_0__angular_core__[\"NgModule\"], args: [{\n declarations: [InfiniteScrollDirective],\n exports: [InfiniteScrollDirective],\n imports: [],\n providers: [\n PositionResolver,\n ScrollRegister,\n ScrollResolver\n ]\n },] },\n];\n/**\n * @nocollapse\n */\nInfiniteScrollModule.ctorParameters = function () { return []; };\n/**\n * Angular library starter.\n * Build an Angular library compatible with AoT compilation & Tree shaking.\n * Written by Roberto Simonetti.\n * MIT license.\n * https://github.com/robisim74/angular-library-starter\n */\n/**\n * Entry point for all public APIs of the package.\n */\n/**\n * Generated bundle index. Do not edit.\n */\n\n//# sourceMappingURL=ngx-infinite-scroll.es5.js.map\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./~/ngx-infinite-scroll/modules/ngx-infinite-scroll.es5.js?c50b"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;AAA2F;AACtE;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA,uBAAuB,EAAE;AACzB;AACA,uBAAuB,EAAE;AACzB;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,gBAAgB;AAChB;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA;AACA;AACA,uBAAuB,EAAE;AACzB,gBAAgB;AAChB;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA,KAAK,kEAAmB;AACxB;AACA;AACA;AACA;AACA,+CAA+C,WAAW;AAC1D;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB;AACA;AACA,qCAAqC,6FAA4C,EAAE;AACnF;AACA;AACA;AACA;AACA,CAAC;AACD;AACA,KAAK,kEAAmB;AACxB;AACA;AACA;AACA;AACA,6CAA6C,WAAW;AACxD;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,gBAAgB;AAChB;AACA;AACA,CAAC;AACD;AACA,KAAK,kEAAmB;AACxB;AACA;AACA;AACA;AACA,6CAA6C,WAAW;AACxD;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA,kCAAkC,iBAAiB;AACnD;AACA;AACA;AACA,gBAAgB;AAChB;AACA,0DAA0D,uDAAuD;AACjH;AACA,gBAAgB;AAChB;AACA,0DAA0D,uDAAuD;AACjH;AACA,gBAAgB;AAChB;AACA,0DAA0D,uDAAuD;AACjH;AACA,gBAAgB;AAChB;AACA,yDAAyD,sDAAsD;AAC/G;AACA,gBAAgB;AAChB;AACA,uDAAuD,mDAAmD;AAC1G;AACA,gBAAgB;AAChB;AACA,uDAAuD,mDAAmD;AAC1G;AACA,gBAAgB;AAChB;AACA,iDAAiD,uCAAuC;AACxF;AACA,CAAC;AACD;AACA;AACA,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB,eAAe,EAAE;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA,+BAA+B,EAAE;AACjC,+BAA+B,EAAE;AACjC;AACA;AACA,iBAAiB;AACjB,+BAA+B,EAAE;AACjC;AACA,+CAA+C,sCAAsC,EAAE;AACvF,2CAA2C,wEAAwE,EAAE;AACrH,yDAAyD,wCAAwC,EAAE;AACnG;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB;AACA;AACA;AACA,uBAAuB,EAAE,mEAAmE,qBAAqB;AACjH;AACA,2BAA2B,EAAE;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,GAAG;AAClB,gBAAgB;AAChB;AACA;AACA;AACA,8BAA8B,SAAS,4BAA4B;AACnE,mCAAmC,kCAAkC,EAAE;AACvE;AACA;AACA,eAAe,GAAG;AAClB,gBAAgB;AAChB;AACA;AACA;AACA,8BAA8B,SAAS,4BAA4B;AACnE,mCAAmC,oCAAoC,EAAE;AACzE;AACA;AACA,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA,KAAK;AACL;AACA,aAAa,IAAI;AACjB;AACA;AACA;AACA;AACA,sDAAsD;AACtD,KAAK,mEAAoB;AACzB,KAAK,+DAAgB;AACrB,KAAK,0BAA0B;AAC/B,KAAK,wBAAwB;AAC7B,KAAK,wBAAwB;AAC7B,EAAE;AACF;AACA,kBAAkB,8DAAe;AACjC,oBAAoB,8DAAe;AACnC,gCAAgC,6DAAc;AAC9C,kCAAkC,6DAAc;AAChD,gCAAgC,6DAAc;AAC9C,gCAAgC,6DAAc;AAC9C,iCAAiC,6DAAc;AAC/C,sBAAsB,6DAAc;AACpC,wBAAwB,6DAAc;AACtC,oBAAoB,6DAAc;AAClC,wBAAwB,6DAAc;AACtC;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,IAAI;AACjB;AACA;AACA;AACA;AACA,mDAAmD,WAAW;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACQ;AACR","file":"201.js","sourcesContent":["import { Directive, ElementRef, EventEmitter, Injectable, Input, NgModule, NgZone, Output } from '@angular/core';\nimport { Observable } from 'rxjs/Observable';\nimport 'rxjs/add/observable/fromEvent';\nimport 'rxjs/add/observable/of';\nimport 'rxjs/add/operator/sampleTime';\nimport 'rxjs/add/operator/filter';\nimport 'rxjs/add/operator/mergeMap';\nvar PositionResolver = (function () {\n    function PositionResolver() {\n    }\n    /**\n     * @param {?} options\n     * @return {?}\n     */\n    PositionResolver.prototype.create = function (options) {\n        var /** @type {?} */ isWindow = this.isElementWindow(options.windowElement);\n        var /** @type {?} */ resolver = {\n            axis: options.axis,\n            container: this.defineContainer(options.windowElement, isWindow),\n            isWindow: isWindow,\n        };\n        return resolver;\n    };\n    /**\n     * @param {?} windowElement\n     * @param {?} isContainerWindow\n     * @return {?}\n     */\n    PositionResolver.prototype.defineContainer = function (windowElement, isContainerWindow) {\n        var /** @type {?} */ container = (isContainerWindow || !windowElement.nativeElement)\n            ? windowElement\n            : windowElement.nativeElement;\n        return container;\n    };\n    /**\n     * @param {?} windowElement\n     * @return {?}\n     */\n    PositionResolver.prototype.isElementWindow = function (windowElement) {\n        var /** @type {?} */ isWindow = Object.prototype.toString.call(windowElement).includes('Window');\n        return isWindow;\n    };\n    /**\n     * @param {?} isContainerWindow\n     * @param {?} windowElement\n     * @return {?}\n     */\n    PositionResolver.prototype.getDocumentElement = function (isContainerWindow, windowElement) {\n        return isContainerWindow\n            ? windowElement.document.documentElement\n            : null;\n    };\n    /**\n     * @param {?} element\n     * @param {?} resolver\n     * @return {?}\n     */\n    PositionResolver.prototype.calculatePoints = function (element, resolver) {\n        return resolver.isWindow\n            ? this.calculatePointsForWindow(element, resolver)\n            : this.calculatePointsForElement(element, resolver);\n    };\n    /**\n     * @param {?} element\n     * @param {?} resolver\n     * @return {?}\n     */\n    PositionResolver.prototype.calculatePointsForWindow = function (element, resolver) {\n        var axis = resolver.axis, container = resolver.container, isWindow = resolver.isWindow;\n        var /** @type {?} */ offsetHeightKey = axis.offsetHeightKey();\n        var /** @type {?} */ clientHeightKey = axis.clientHeightKey();\n        var /** @type {?} */ topKey = axis.topKey();\n        // container's height\n        var /** @type {?} */ height = this.height(container, isWindow, offsetHeightKey, clientHeightKey);\n        // scrolled until now / current y point\n        var /** @type {?} */ scrolledUntilNow = height + this.pageYOffset(this.getDocumentElement(isWindow, container), axis, isWindow);\n        // total height / most bottom y point\n        var /** @type {?} */ nativeElementHeight = this.height(element.nativeElement, isWindow, offsetHeightKey, clientHeightKey);\n        var /** @type {?} */ totalToScroll = this.offsetTop(element.nativeElement, axis, isWindow) + nativeElementHeight;\n        return { height: height, scrolledUntilNow: scrolledUntilNow, totalToScroll: totalToScroll };\n    };\n    /**\n     * @param {?} element\n     * @param {?} resolver\n     * @return {?}\n     */\n    PositionResolver.prototype.calculatePointsForElement = function (element, resolver) {\n        var axis = resolver.axis, container = resolver.container, isWindow = resolver.isWindow;\n        var /** @type {?} */ offsetHeightKey = axis.offsetHeightKey();\n        var /** @type {?} */ clientHeightKey = axis.clientHeightKey();\n        var /** @type {?} */ scrollTop = axis.scrollTopKey();\n        var /** @type {?} */ scrollHeight = axis.scrollHeightKey();\n        var /** @type {?} */ topKey = axis.topKey();\n        var /** @type {?} */ height = this.height(container, isWindow, offsetHeightKey, clientHeightKey);\n        // perhaps use this.container.offsetTop instead of 'scrollTop'\n        var /** @type {?} */ scrolledUntilNow = container[scrollTop];\n        var /** @type {?} */ containerTopOffset = 0;\n        var /** @type {?} */ offsetTop = this.offsetTop(container, axis, isWindow);\n        if (offsetTop !== void 0) {\n            containerTopOffset = offsetTop;\n        }\n        var /** @type {?} */ totalToScroll = container[scrollHeight];\n        return { height: height, scrolledUntilNow: scrolledUntilNow, totalToScroll: totalToScroll };\n    };\n    /**\n     * @param {?} elem\n     * @param {?} isWindow\n     * @param {?} offsetHeightKey\n     * @param {?} clientHeightKey\n     * @return {?}\n     */\n    PositionResolver.prototype.height = function (elem, isWindow, offsetHeightKey, clientHeightKey) {\n        if (isNaN(elem[offsetHeightKey])) {\n            return this.getDocumentElement(isWindow, elem)[clientHeightKey];\n        }\n        else {\n            return elem[offsetHeightKey];\n        }\n    };\n    /**\n     * @param {?} elem\n     * @param {?} axis\n     * @param {?} isWindow\n     * @return {?}\n     */\n    PositionResolver.prototype.offsetTop = function (elem, axis, isWindow) {\n        var /** @type {?} */ topKey = axis.topKey();\n        // elem = elem.nativeElement;\n        if (!elem.getBoundingClientRect) {\n            return;\n        }\n        return elem.getBoundingClientRect()[topKey] + this.pageYOffset(elem, axis, isWindow);\n    };\n    /**\n     * @param {?} elem\n     * @param {?} axis\n     * @param {?} isWindow\n     * @return {?}\n     */\n    PositionResolver.prototype.pageYOffset = function (elem, axis, isWindow) {\n        var /** @type {?} */ pageYOffset = axis.pageYOffsetKey();\n        var /** @type {?} */ scrollTop = axis.scrollTopKey();\n        var /** @type {?} */ offsetTop = axis.offsetTopKey();\n        if (isNaN(window[pageYOffset])) {\n            return this.getDocumentElement(isWindow, elem)[scrollTop];\n        }\n        else if (elem.ownerDocument) {\n            return elem.ownerDocument.defaultView[pageYOffset];\n        }\n        else {\n            return elem[offsetTop];\n        }\n    };\n    return PositionResolver;\n}());\nPositionResolver.decorators = [\n    { type: Injectable },\n];\n/**\n * @nocollapse\n */\nPositionResolver.ctorParameters = function () { return []; };\nvar ScrollRegister = (function () {\n    function ScrollRegister() {\n    }\n    /**\n     * @param {?} options\n     * @return {?}\n     */\n    ScrollRegister.prototype.attachEvent = function (options) {\n        var /** @type {?} */ scroller$ = Observable.fromEvent(options.container, 'scroll')\n            .sampleTime(options.throttleDuration)\n            .filter(options.filterBefore)\n            .mergeMap(function (ev) { return Observable.of(options.mergeMap(ev)); })\n            .subscribe(options.scrollHandler);\n        return scroller$;\n    };\n    return ScrollRegister;\n}());\nScrollRegister.decorators = [\n    { type: Injectable },\n];\n/**\n * @nocollapse\n */\nScrollRegister.ctorParameters = function () { return []; };\nvar ScrollResolver = (function () {\n    function ScrollResolver() {\n        this.lastScrollPosition = 0;\n    }\n    /**\n     * @param {?} container\n     * @param {?} config\n     * @param {?} scrollingDown\n     * @return {?}\n     */\n    ScrollResolver.prototype.shouldScroll = function (container, config, scrollingDown) {\n        var /** @type {?} */ distance = config.distance;\n        var /** @type {?} */ remaining;\n        var /** @type {?} */ containerBreakpoint;\n        if (scrollingDown) {\n            remaining = container.totalToScroll - container.scrolledUntilNow;\n            containerBreakpoint = container.height * distance.down + 1;\n        }\n        else {\n            remaining = container.scrolledUntilNow;\n            containerBreakpoint = container.height * distance.up + 1;\n        }\n        var /** @type {?} */ shouldScroll = remaining <= containerBreakpoint;\n        this.lastScrollPosition = container.scrolledUntilNow;\n        return shouldScroll;\n    };\n    /**\n     * @param {?} container\n     * @return {?}\n     */\n    ScrollResolver.prototype.isScrollingDown = function (container) {\n        return this.lastScrollPosition < container.scrolledUntilNow;\n    };\n    /**\n     * @param {?} container\n     * @param {?} config\n     * @return {?}\n     */\n    ScrollResolver.prototype.getScrollStats = function (container, config) {\n        var /** @type {?} */ isScrollingDown = this.isScrollingDown(container);\n        var /** @type {?} */ shouldScroll = this.shouldScroll(container, config, isScrollingDown);\n        return { isScrollingDown: isScrollingDown, shouldScroll: shouldScroll };\n    };\n    return ScrollResolver;\n}());\nScrollResolver.decorators = [\n    { type: Injectable },\n];\n/**\n * @nocollapse\n */\nScrollResolver.ctorParameters = function () { return []; };\nvar AxisResolver = (function () {\n    /**\n     * @param {?=} vertical\n     */\n    function AxisResolver(vertical) {\n        if (vertical === void 0) { vertical = true; }\n        this.vertical = vertical;\n    }\n    /**\n     * @return {?}\n     */\n    AxisResolver.prototype.clientHeightKey = function () { return this.vertical ? 'clientHeight' : 'clientWidth'; };\n    /**\n     * @return {?}\n     */\n    AxisResolver.prototype.offsetHeightKey = function () { return this.vertical ? 'offsetHeight' : 'offsetWidth'; };\n    /**\n     * @return {?}\n     */\n    AxisResolver.prototype.scrollHeightKey = function () { return this.vertical ? 'scrollHeight' : 'scrollWidth'; };\n    /**\n     * @return {?}\n     */\n    AxisResolver.prototype.pageYOffsetKey = function () { return this.vertical ? 'pageYOffset' : 'pageXOffset'; };\n    /**\n     * @return {?}\n     */\n    AxisResolver.prototype.offsetTopKey = function () { return this.vertical ? 'offsetTop' : 'offsetLeft'; };\n    /**\n     * @return {?}\n     */\n    AxisResolver.prototype.scrollTopKey = function () { return this.vertical ? 'scrollTop' : 'scrollLeft'; };\n    /**\n     * @return {?}\n     */\n    AxisResolver.prototype.topKey = function () { return this.vertical ? 'top' : 'left'; };\n    return AxisResolver;\n}());\nvar InfiniteScrollDirective = (function () {\n    /**\n     * @param {?} element\n     * @param {?} zone\n     * @param {?} positionResolver\n     * @param {?} scrollRegister\n     * @param {?} scrollerResolver\n     */\n    function InfiniteScrollDirective(element, zone, positionResolver, scrollRegister, scrollerResolver) {\n        this.element = element;\n        this.zone = zone;\n        this.positionResolver = positionResolver;\n        this.scrollRegister = scrollRegister;\n        this.scrollerResolver = scrollerResolver;\n        this.scrolled = new EventEmitter();\n        this.scrolledUp = new EventEmitter();\n        this.infiniteScrollDistance = 2;\n        this.infiniteScrollUpDistance = 1.5;\n        this.infiniteScrollThrottle = 300;\n        this.infiniteScrollDisabled = false;\n        this.infiniteScrollContainer = null;\n        this.scrollWindow = true;\n        this.immediateCheck = false;\n        this.horizontal = false;\n        this.alwaysCallback = false;\n    }\n    /**\n     * @return {?}\n     */\n    InfiniteScrollDirective.prototype.ngOnInit = function () {\n        var _this = this;\n        if (typeof window !== 'undefined') {\n            this.zone.runOutsideAngular(function () {\n                var /** @type {?} */ containerElement = _this.resolveContainerElement();\n                var /** @type {?} */ resolver = _this.positionResolver.create({\n                    axis: new AxisResolver(!_this.horizontal),\n                    windowElement: containerElement,\n                });\n                var /** @type {?} */ options = {\n                    container: resolver.container,\n                    filterBefore: function () { return !_this.infiniteScrollDisabled; },\n                    mergeMap: function () { return _this.positionResolver.calculatePoints(_this.element, resolver); },\n                    scrollHandler: function (container) { return _this.handleOnScroll(container); },\n                    throttleDuration: _this.infiniteScrollThrottle\n                };\n                _this.disposeScroller = _this.scrollRegister.attachEvent(options);\n            });\n        }\n    };\n    /**\n     * @param {?} container\n     * @return {?}\n     */\n    InfiniteScrollDirective.prototype.handleOnScroll = function (container) {\n        var /** @type {?} */ distance = {\n            down: this.infiniteScrollDistance,\n            up: this.infiniteScrollUpDistance\n        };\n        var /** @type {?} */ scrollStats = this.scrollerResolver.getScrollStats(container, { distance: distance });\n        if (this.shouldTriggerEvents(scrollStats.shouldScroll)) {\n            var /** @type {?} */ infiniteScrollEvent = {\n                currentScrollPosition: container.scrolledUntilNow\n            };\n            if (scrollStats.isScrollingDown) {\n                this.onScrollDown(infiniteScrollEvent);\n            }\n            else {\n                this.onScrollUp(infiniteScrollEvent);\n            }\n        }\n    };\n    /**\n     * @param {?} shouldScroll\n     * @return {?}\n     */\n    InfiniteScrollDirective.prototype.shouldTriggerEvents = function (shouldScroll) {\n        return (this.alwaysCallback || shouldScroll) && !this.infiniteScrollDisabled;\n    };\n    /**\n     * @return {?}\n     */\n    InfiniteScrollDirective.prototype.ngOnDestroy = function () {\n        if (this.disposeScroller) {\n            this.disposeScroller.unsubscribe();\n        }\n    };\n    /**\n     * @param {?=} data\n     * @return {?}\n     */\n    InfiniteScrollDirective.prototype.onScrollDown = function (data) {\n        var _this = this;\n        if (data === void 0) { data = { currentScrollPosition: 0 }; }\n        this.zone.run(function () { return _this.scrolled.emit(data); });\n    };\n    /**\n     * @param {?=} data\n     * @return {?}\n     */\n    InfiniteScrollDirective.prototype.onScrollUp = function (data) {\n        var _this = this;\n        if (data === void 0) { data = { currentScrollPosition: 0 }; }\n        this.zone.run(function () { return _this.scrolledUp.emit(data); });\n    };\n    /**\n     * @return {?}\n     */\n    InfiniteScrollDirective.prototype.resolveContainerElement = function () {\n        var /** @type {?} */ selector = this.infiniteScrollContainer;\n        var /** @type {?} */ hasWindow = window && window.hasOwnProperty('document');\n        var /** @type {?} */ containerIsString = selector && hasWindow && typeof (this.infiniteScrollContainer) === 'string';\n        var /** @type {?} */ container = containerIsString\n            ? window.document.querySelector(selector)\n            : selector;\n        if (!selector) {\n            container = this.scrollWindow ? window : this.element;\n        }\n        return container;\n    };\n    return InfiniteScrollDirective;\n}());\nInfiniteScrollDirective.decorators = [\n    { type: Directive, args: [{\n                selector: '[infiniteScroll], [infinite-scroll], [data-infinite-scroll]'\n            },] },\n];\n/**\n * @nocollapse\n */\nInfiniteScrollDirective.ctorParameters = function () { return [\n    { type: ElementRef, },\n    { type: NgZone, },\n    { type: PositionResolver, },\n    { type: ScrollRegister, },\n    { type: ScrollResolver, },\n]; };\nInfiniteScrollDirective.propDecorators = {\n    'scrolled': [{ type: Output },],\n    'scrolledUp': [{ type: Output },],\n    'infiniteScrollDistance': [{ type: Input },],\n    'infiniteScrollUpDistance': [{ type: Input },],\n    'infiniteScrollThrottle': [{ type: Input },],\n    'infiniteScrollDisabled': [{ type: Input },],\n    'infiniteScrollContainer': [{ type: Input },],\n    'scrollWindow': [{ type: Input },],\n    'immediateCheck': [{ type: Input },],\n    'horizontal': [{ type: Input },],\n    'alwaysCallback': [{ type: Input },],\n};\nvar InfiniteScrollModule = (function () {\n    function InfiniteScrollModule() {\n    }\n    return InfiniteScrollModule;\n}());\nInfiniteScrollModule.decorators = [\n    { type: NgModule, args: [{\n                declarations: [InfiniteScrollDirective],\n                exports: [InfiniteScrollDirective],\n                imports: [],\n                providers: [\n                    PositionResolver,\n                    ScrollRegister,\n                    ScrollResolver\n                ]\n            },] },\n];\n/**\n * @nocollapse\n */\nInfiniteScrollModule.ctorParameters = function () { return []; };\n/**\n * Angular library starter.\n * Build an Angular library compatible with AoT compilation & Tree shaking.\n * Written by Roberto Simonetti.\n * MIT license.\n * https://github.com/robisim74/angular-library-starter\n */\n/**\n * Entry point for all public APIs of the package.\n */\n/**\n * Generated bundle index. Do not edit.\n */\nexport { InfiniteScrollModule, InfiniteScrollDirective as ɵa, PositionResolver as ɵb, ScrollRegister as ɵc, ScrollResolver as ɵd };\n//# sourceMappingURL=ngx-infinite-scroll.es5.js.map\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/ngx-infinite-scroll/modules/ngx-infinite-scroll.es5.js\n// module id = 201\n// module chunks = 0"],"sourceRoot":""}"); - -/***/ }), -/* 202 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -eval("\nvar Observable_1 = __webpack_require__(24);\nvar sampleTime_1 = __webpack_require__(205);\nObservable_1.Observable.prototype.sampleTime = sampleTime_1.sampleTime;\n//# sourceMappingURL=sampleTime.js.map//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9+L3J4anMvYWRkL29wZXJhdG9yL3NhbXBsZVRpbWUuanM/M2M1ZiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6IjIwMi5qcyIsInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xudmFyIE9ic2VydmFibGVfMSA9IHJlcXVpcmUoJy4uLy4uL09ic2VydmFibGUnKTtcbnZhciBzYW1wbGVUaW1lXzEgPSByZXF1aXJlKCcuLi8uLi9vcGVyYXRvci9zYW1wbGVUaW1lJyk7XG5PYnNlcnZhYmxlXzEuT2JzZXJ2YWJsZS5wcm90b3R5cGUuc2FtcGxlVGltZSA9IHNhbXBsZVRpbWVfMS5zYW1wbGVUaW1lO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2FtcGxlVGltZS5qcy5tYXBcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL34vcnhqcy9hZGQvb3BlcmF0b3Ivc2FtcGxlVGltZS5qc1xuLy8gbW9kdWxlIGlkID0gMjAyXG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0="); - -/***/ }), -/* 203 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -eval("\nvar __extends = (this && this.__extends) || function (d, b) {\n for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n};\nvar Subscriber_1 = __webpack_require__(118);\nvar tryCatch_1 = __webpack_require__(219);\nvar errorObject_1 = __webpack_require__(216);\n/* tslint:enable:max-line-length */\n/**\n * Returns an Observable that emits all items emitted by the source Observable that are distinct by comparison from the previous item.\n *\n * If a comparator function is provided, then it will be called for each item to test for whether or not that value should be emitted.\n *\n * If a comparator function is not provided, an equality check is used by default.\n *\n * @example A simple example with numbers\n * Observable.of(1, 1, 2, 2, 2, 1, 1, 2, 3, 3, 4)\n * .distinctUntilChanged()\n * .subscribe(x => console.log(x)); // 1, 2, 1, 2, 3, 4\n *\n * @example An example using a compare function\n * interface Person {\n * age: number,\n * name: string\n * }\n *\n * Observable.of(\n * { age: 4, name: 'Foo'},\n * { age: 7, name: 'Bar'},\n * { age: 5, name: 'Foo'})\n * { age: 6, name: 'Foo'})\n * .distinctUntilChanged((p: Person, q: Person) => p.name === q.name)\n * .subscribe(x => console.log(x));\n *\n * // displays:\n * // { age: 4, name: 'Foo' }\n * // { age: 7, name: 'Bar' }\n * // { age: 5, name: 'Foo' }\n *\n * @see {@link distinct}\n * @see {@link distinctUntilKeyChanged}\n *\n * @param {function} [compare] Optional comparison function called to test if an item is distinct from the previous item in the source.\n * @return {Observable} An Observable that emits items from the source Observable with distinct values.\n * @method distinctUntilChanged\n * @owner Observable\n */\nfunction distinctUntilChanged(compare, keySelector) {\n return this.lift(new DistinctUntilChangedOperator(compare, keySelector));\n}\nexports.distinctUntilChanged = distinctUntilChanged;\nvar DistinctUntilChangedOperator = (function () {\n function DistinctUntilChangedOperator(compare, keySelector) {\n this.compare = compare;\n this.keySelector = keySelector;\n }\n DistinctUntilChangedOperator.prototype.call = function (subscriber, source) {\n return source.subscribe(new DistinctUntilChangedSubscriber(subscriber, this.compare, this.keySelector));\n };\n return DistinctUntilChangedOperator;\n}());\n/**\n * We need this JSDoc comment for affecting ESDoc.\n * @ignore\n * @extends {Ignored}\n */\nvar DistinctUntilChangedSubscriber = (function (_super) {\n __extends(DistinctUntilChangedSubscriber, _super);\n function DistinctUntilChangedSubscriber(destination, compare, keySelector) {\n _super.call(this, destination);\n this.keySelector = keySelector;\n this.hasKey = false;\n if (typeof compare === 'function') {\n this.compare = compare;\n }\n }\n DistinctUntilChangedSubscriber.prototype.compare = function (x, y) {\n return x === y;\n };\n DistinctUntilChangedSubscriber.prototype._next = function (value) {\n var keySelector = this.keySelector;\n var key = value;\n if (keySelector) {\n key = tryCatch_1.tryCatch(this.keySelector)(value);\n if (key === errorObject_1.errorObject) {\n return this.destination.error(errorObject_1.errorObject.e);\n }\n }\n var result = false;\n if (this.hasKey) {\n result = tryCatch_1.tryCatch(this.compare)(this.key, key);\n if (result === errorObject_1.errorObject) {\n return this.destination.error(errorObject_1.errorObject.e);\n }\n }\n else {\n this.hasKey = true;\n }\n if (Boolean(result) === false) {\n this.key = key;\n this.destination.next(value);\n }\n };\n return DistinctUntilChangedSubscriber;\n}(Subscriber_1.Subscriber));\n//# sourceMappingURL=distinctUntilChanged.js.map//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9+L3J4anMvb3BlcmF0b3IvZGlzdGluY3RVbnRpbENoYW5nZWQuanM/N2M5ZiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQSxtQkFBbUIsc0JBQXNCO0FBQ3pDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUNBQXFDO0FBQ3JDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRLHFCQUFxQjtBQUM3QixRQUFRLHFCQUFxQjtBQUM3QixRQUFRLHFCQUFxQjtBQUM3QixRQUFRLHFCQUFxQjtBQUM3QjtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUCxPQUFPO0FBQ1AsT0FBTztBQUNQO0FBQ0EsU0FBUztBQUNULFNBQVM7QUFDVDtBQUNBLFdBQVcsU0FBUztBQUNwQixZQUFZLFdBQVc7QUFDdkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxDQUFDO0FBQ0Q7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLENBQUM7QUFDRCIsImZpbGUiOiIyMDMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcbnZhciBfX2V4dGVuZHMgPSAodGhpcyAmJiB0aGlzLl9fZXh0ZW5kcykgfHwgZnVuY3Rpb24gKGQsIGIpIHtcbiAgICBmb3IgKHZhciBwIGluIGIpIGlmIChiLmhhc093blByb3BlcnR5KHApKSBkW3BdID0gYltwXTtcbiAgICBmdW5jdGlvbiBfXygpIHsgdGhpcy5jb25zdHJ1Y3RvciA9IGQ7IH1cbiAgICBkLnByb3RvdHlwZSA9IGIgPT09IG51bGwgPyBPYmplY3QuY3JlYXRlKGIpIDogKF9fLnByb3RvdHlwZSA9IGIucHJvdG90eXBlLCBuZXcgX18oKSk7XG59O1xudmFyIFN1YnNjcmliZXJfMSA9IHJlcXVpcmUoJy4uL1N1YnNjcmliZXInKTtcbnZhciB0cnlDYXRjaF8xID0gcmVxdWlyZSgnLi4vdXRpbC90cnlDYXRjaCcpO1xudmFyIGVycm9yT2JqZWN0XzEgPSByZXF1aXJlKCcuLi91dGlsL2Vycm9yT2JqZWN0Jyk7XG4vKiB0c2xpbnQ6ZW5hYmxlOm1heC1saW5lLWxlbmd0aCAqL1xuLyoqXG4gKiBSZXR1cm5zIGFuIE9ic2VydmFibGUgdGhhdCBlbWl0cyBhbGwgaXRlbXMgZW1pdHRlZCBieSB0aGUgc291cmNlIE9ic2VydmFibGUgdGhhdCBhcmUgZGlzdGluY3QgYnkgY29tcGFyaXNvbiBmcm9tIHRoZSBwcmV2aW91cyBpdGVtLlxuICpcbiAqIElmIGEgY29tcGFyYXRvciBmdW5jdGlvbiBpcyBwcm92aWRlZCwgdGhlbiBpdCB3aWxsIGJlIGNhbGxlZCBmb3IgZWFjaCBpdGVtIHRvIHRlc3QgZm9yIHdoZXRoZXIgb3Igbm90IHRoYXQgdmFsdWUgc2hvdWxkIGJlIGVtaXR0ZWQuXG4gKlxuICogSWYgYSBjb21wYXJhdG9yIGZ1bmN0aW9uIGlzIG5vdCBwcm92aWRlZCwgYW4gZXF1YWxpdHkgY2hlY2sgaXMgdXNlZCBieSBkZWZhdWx0LlxuICpcbiAqIEBleGFtcGxlIDxjYXB0aW9uPkEgc2ltcGxlIGV4YW1wbGUgd2l0aCBudW1iZXJzPC9jYXB0aW9uPlxuICogT2JzZXJ2YWJsZS5vZigxLCAxLCAyLCAyLCAyLCAxLCAxLCAyLCAzLCAzLCA0KVxuICogICAuZGlzdGluY3RVbnRpbENoYW5nZWQoKVxuICogICAuc3Vic2NyaWJlKHggPT4gY29uc29sZS5sb2coeCkpOyAvLyAxLCAyLCAxLCAyLCAzLCA0XG4gKlxuICogQGV4YW1wbGUgPGNhcHRpb24+QW4gZXhhbXBsZSB1c2luZyBhIGNvbXBhcmUgZnVuY3Rpb248L2NhcHRpb24+XG4gKiBpbnRlcmZhY2UgUGVyc29uIHtcbiAqICAgIGFnZTogbnVtYmVyLFxuICogICAgbmFtZTogc3RyaW5nXG4gKiB9XG4gKlxuICogT2JzZXJ2YWJsZS5vZjxQZXJzb24+KFxuICogICAgIHsgYWdlOiA0LCBuYW1lOiAnRm9vJ30sXG4gKiAgICAgeyBhZ2U6IDcsIG5hbWU6ICdCYXInfSxcbiAqICAgICB7IGFnZTogNSwgbmFtZTogJ0Zvbyd9KVxuICogICAgIHsgYWdlOiA2LCBuYW1lOiAnRm9vJ30pXG4gKiAgICAgLmRpc3RpbmN0VW50aWxDaGFuZ2VkKChwOiBQZXJzb24sIHE6IFBlcnNvbikgPT4gcC5uYW1lID09PSBxLm5hbWUpXG4gKiAgICAgLnN1YnNjcmliZSh4ID0+IGNvbnNvbGUubG9nKHgpKTtcbiAqXG4gKiAvLyBkaXNwbGF5czpcbiAqIC8vIHsgYWdlOiA0LCBuYW1lOiAnRm9vJyB9XG4gKiAvLyB7IGFnZTogNywgbmFtZTogJ0JhcicgfVxuICogLy8geyBhZ2U6IDUsIG5hbWU6ICdGb28nIH1cbiAqXG4gKiBAc2VlIHtAbGluayBkaXN0aW5jdH1cbiAqIEBzZWUge0BsaW5rIGRpc3RpbmN0VW50aWxLZXlDaGFuZ2VkfVxuICpcbiAqIEBwYXJhbSB7ZnVuY3Rpb259IFtjb21wYXJlXSBPcHRpb25hbCBjb21wYXJpc29uIGZ1bmN0aW9uIGNhbGxlZCB0byB0ZXN0IGlmIGFuIGl0ZW0gaXMgZGlzdGluY3QgZnJvbSB0aGUgcHJldmlvdXMgaXRlbSBpbiB0aGUgc291cmNlLlxuICogQHJldHVybiB7T2JzZXJ2YWJsZX0gQW4gT2JzZXJ2YWJsZSB0aGF0IGVtaXRzIGl0ZW1zIGZyb20gdGhlIHNvdXJjZSBPYnNlcnZhYmxlIHdpdGggZGlzdGluY3QgdmFsdWVzLlxuICogQG1ldGhvZCBkaXN0aW5jdFVudGlsQ2hhbmdlZFxuICogQG93bmVyIE9ic2VydmFibGVcbiAqL1xuZnVuY3Rpb24gZGlzdGluY3RVbnRpbENoYW5nZWQoY29tcGFyZSwga2V5U2VsZWN0b3IpIHtcbiAgICByZXR1cm4gdGhpcy5saWZ0KG5ldyBEaXN0aW5jdFVudGlsQ2hhbmdlZE9wZXJhdG9yKGNvbXBhcmUsIGtleVNlbGVjdG9yKSk7XG59XG5leHBvcnRzLmRpc3RpbmN0VW50aWxDaGFuZ2VkID0gZGlzdGluY3RVbnRpbENoYW5nZWQ7XG52YXIgRGlzdGluY3RVbnRpbENoYW5nZWRPcGVyYXRvciA9IChmdW5jdGlvbiAoKSB7XG4gICAgZnVuY3Rpb24gRGlzdGluY3RVbnRpbENoYW5nZWRPcGVyYXRvcihjb21wYXJlLCBrZXlTZWxlY3Rvcikge1xuICAgICAgICB0aGlzLmNvbXBhcmUgPSBjb21wYXJlO1xuICAgICAgICB0aGlzLmtleVNlbGVjdG9yID0ga2V5U2VsZWN0b3I7XG4gICAgfVxuICAgIERpc3RpbmN0VW50aWxDaGFuZ2VkT3BlcmF0b3IucHJvdG90eXBlLmNhbGwgPSBmdW5jdGlvbiAoc3Vic2NyaWJlciwgc291cmNlKSB7XG4gICAgICAgIHJldHVybiBzb3VyY2Uuc3Vic2NyaWJlKG5ldyBEaXN0aW5jdFVudGlsQ2hhbmdlZFN1YnNjcmliZXIoc3Vic2NyaWJlciwgdGhpcy5jb21wYXJlLCB0aGlzLmtleVNlbGVjdG9yKSk7XG4gICAgfTtcbiAgICByZXR1cm4gRGlzdGluY3RVbnRpbENoYW5nZWRPcGVyYXRvcjtcbn0oKSk7XG4vKipcbiAqIFdlIG5lZWQgdGhpcyBKU0RvYyBjb21tZW50IGZvciBhZmZlY3RpbmcgRVNEb2MuXG4gKiBAaWdub3JlXG4gKiBAZXh0ZW5kcyB7SWdub3JlZH1cbiAqL1xudmFyIERpc3RpbmN0VW50aWxDaGFuZ2VkU3Vic2NyaWJlciA9IChmdW5jdGlvbiAoX3N1cGVyKSB7XG4gICAgX19leHRlbmRzKERpc3RpbmN0VW50aWxDaGFuZ2VkU3Vic2NyaWJlciwgX3N1cGVyKTtcbiAgICBmdW5jdGlvbiBEaXN0aW5jdFVudGlsQ2hhbmdlZFN1YnNjcmliZXIoZGVzdGluYXRpb24sIGNvbXBhcmUsIGtleVNlbGVjdG9yKSB7XG4gICAgICAgIF9zdXBlci5jYWxsKHRoaXMsIGRlc3RpbmF0aW9uKTtcbiAgICAgICAgdGhpcy5rZXlTZWxlY3RvciA9IGtleVNlbGVjdG9yO1xuICAgICAgICB0aGlzLmhhc0tleSA9IGZhbHNlO1xuICAgICAgICBpZiAodHlwZW9mIGNvbXBhcmUgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgICAgIHRoaXMuY29tcGFyZSA9IGNvbXBhcmU7XG4gICAgICAgIH1cbiAgICB9XG4gICAgRGlzdGluY3RVbnRpbENoYW5nZWRTdWJzY3JpYmVyLnByb3RvdHlwZS5jb21wYXJlID0gZnVuY3Rpb24gKHgsIHkpIHtcbiAgICAgICAgcmV0dXJuIHggPT09IHk7XG4gICAgfTtcbiAgICBEaXN0aW5jdFVudGlsQ2hhbmdlZFN1YnNjcmliZXIucHJvdG90eXBlLl9uZXh0ID0gZnVuY3Rpb24gKHZhbHVlKSB7XG4gICAgICAgIHZhciBrZXlTZWxlY3RvciA9IHRoaXMua2V5U2VsZWN0b3I7XG4gICAgICAgIHZhciBrZXkgPSB2YWx1ZTtcbiAgICAgICAgaWYgKGtleVNlbGVjdG9yKSB7XG4gICAgICAgICAgICBrZXkgPSB0cnlDYXRjaF8xLnRyeUNhdGNoKHRoaXMua2V5U2VsZWN0b3IpKHZhbHVlKTtcbiAgICAgICAgICAgIGlmIChrZXkgPT09IGVycm9yT2JqZWN0XzEuZXJyb3JPYmplY3QpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5kZXN0aW5hdGlvbi5lcnJvcihlcnJvck9iamVjdF8xLmVycm9yT2JqZWN0LmUpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHZhciByZXN1bHQgPSBmYWxzZTtcbiAgICAgICAgaWYgKHRoaXMuaGFzS2V5KSB7XG4gICAgICAgICAgICByZXN1bHQgPSB0cnlDYXRjaF8xLnRyeUNhdGNoKHRoaXMuY29tcGFyZSkodGhpcy5rZXksIGtleSk7XG4gICAgICAgICAgICBpZiAocmVzdWx0ID09PSBlcnJvck9iamVjdF8xLmVycm9yT2JqZWN0KSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHRoaXMuZGVzdGluYXRpb24uZXJyb3IoZXJyb3JPYmplY3RfMS5lcnJvck9iamVjdC5lKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgIHRoaXMuaGFzS2V5ID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoQm9vbGVhbihyZXN1bHQpID09PSBmYWxzZSkge1xuICAgICAgICAgICAgdGhpcy5rZXkgPSBrZXk7XG4gICAgICAgICAgICB0aGlzLmRlc3RpbmF0aW9uLm5leHQodmFsdWUpO1xuICAgICAgICB9XG4gICAgfTtcbiAgICByZXR1cm4gRGlzdGluY3RVbnRpbENoYW5nZWRTdWJzY3JpYmVyO1xufShTdWJzY3JpYmVyXzEuU3Vic2NyaWJlcikpO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGlzdGluY3RVbnRpbENoYW5nZWQuanMubWFwXG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9+L3J4anMvb3BlcmF0b3IvZGlzdGluY3RVbnRpbENoYW5nZWQuanNcbi8vIG1vZHVsZSBpZCA9IDIwM1xuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 204 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -eval("\n/**\n * @param func\n * @return {Observable}\n * @method let\n * @owner Observable\n */\nfunction letProto(func) {\n return func(this);\n}\nexports.letProto = letProto;\n//# sourceMappingURL=let.js.map//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9+L3J4anMvb3BlcmF0b3IvbGV0LmpzPzE4N2MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiMjA0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG4vKipcbiAqIEBwYXJhbSBmdW5jXG4gKiBAcmV0dXJuIHtPYnNlcnZhYmxlPFI+fVxuICogQG1ldGhvZCBsZXRcbiAqIEBvd25lciBPYnNlcnZhYmxlXG4gKi9cbmZ1bmN0aW9uIGxldFByb3RvKGZ1bmMpIHtcbiAgICByZXR1cm4gZnVuYyh0aGlzKTtcbn1cbmV4cG9ydHMubGV0UHJvdG8gPSBsZXRQcm90bztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWxldC5qcy5tYXBcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL34vcnhqcy9vcGVyYXRvci9sZXQuanNcbi8vIG1vZHVsZSBpZCA9IDIwNFxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9"); - -/***/ }), -/* 205 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -eval("\nvar __extends = (this && this.__extends) || function (d, b) {\n for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n};\nvar Subscriber_1 = __webpack_require__(118);\nvar async_1 = __webpack_require__(215);\n/**\n * Emits the most recently emitted value from the source Observable within\n * periodic time intervals.\n *\n * Samples the source Observable at periodic time\n * intervals, emitting what it samples.\n *\n * \n *\n * `sampleTime` periodically looks at the source Observable and emits whichever\n * value it has most recently emitted since the previous sampling, unless the\n * source has not emitted anything since the previous sampling. The sampling\n * happens periodically in time every `period` milliseconds (or the time unit\n * defined by the optional `scheduler` argument). The sampling starts as soon as\n * the output Observable is subscribed.\n *\n * @example Every second, emit the most recent click at most once\n * var clicks = Rx.Observable.fromEvent(document, 'click');\n * var result = clicks.sampleTime(1000);\n * result.subscribe(x => console.log(x));\n *\n * @see {@link auditTime}\n * @see {@link debounceTime}\n * @see {@link delay}\n * @see {@link sample}\n * @see {@link throttleTime}\n *\n * @param {number} period The sampling period expressed in milliseconds or the\n * time unit determined internally by the optional `scheduler`.\n * @param {Scheduler} [scheduler=async] The {@link IScheduler} to use for\n * managing the timers that handle the sampling.\n * @return {Observable} An Observable that emits the results of sampling the\n * values emitted by the source Observable at the specified time interval.\n * @method sampleTime\n * @owner Observable\n */\nfunction sampleTime(period, scheduler) {\n if (scheduler === void 0) { scheduler = async_1.async; }\n return this.lift(new SampleTimeOperator(period, scheduler));\n}\nexports.sampleTime = sampleTime;\nvar SampleTimeOperator = (function () {\n function SampleTimeOperator(period, scheduler) {\n this.period = period;\n this.scheduler = scheduler;\n }\n SampleTimeOperator.prototype.call = function (subscriber, source) {\n return source.subscribe(new SampleTimeSubscriber(subscriber, this.period, this.scheduler));\n };\n return SampleTimeOperator;\n}());\n/**\n * We need this JSDoc comment for affecting ESDoc.\n * @ignore\n * @extends {Ignored}\n */\nvar SampleTimeSubscriber = (function (_super) {\n __extends(SampleTimeSubscriber, _super);\n function SampleTimeSubscriber(destination, period, scheduler) {\n _super.call(this, destination);\n this.period = period;\n this.scheduler = scheduler;\n this.hasValue = false;\n this.add(scheduler.schedule(dispatchNotification, period, { subscriber: this, period: period }));\n }\n SampleTimeSubscriber.prototype._next = function (value) {\n this.lastValue = value;\n this.hasValue = true;\n };\n SampleTimeSubscriber.prototype.notifyNext = function () {\n if (this.hasValue) {\n this.hasValue = false;\n this.destination.next(this.lastValue);\n }\n };\n return SampleTimeSubscriber;\n}(Subscriber_1.Subscriber));\nfunction dispatchNotification(state) {\n var subscriber = state.subscriber, period = state.period;\n subscriber.notifyNext();\n this.schedule(state, period);\n}\n//# sourceMappingURL=sampleTime.js.map//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9+L3J4anMvb3BlcmF0b3Ivc2FtcGxlVGltZS5qcz9mZjM4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBLG1CQUFtQixzQkFBc0I7QUFDekM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsU0FBUztBQUNULFNBQVM7QUFDVCxTQUFTO0FBQ1QsU0FBUztBQUNUO0FBQ0EsV0FBVyxPQUFPO0FBQ2xCO0FBQ0EsV0FBVyxVQUFVLHdCQUF3QixpQkFBaUI7QUFDOUQ7QUFDQSxZQUFZLGNBQWM7QUFDMUI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLCtCQUErQiwyQkFBMkI7QUFDMUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsQ0FBQztBQUNEO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsbUVBQW1FLG1DQUFtQztBQUN0RztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxDQUFDO0FBQ0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6IjIwNS5qcyIsInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xudmFyIF9fZXh0ZW5kcyA9ICh0aGlzICYmIHRoaXMuX19leHRlbmRzKSB8fCBmdW5jdGlvbiAoZCwgYikge1xuICAgIGZvciAodmFyIHAgaW4gYikgaWYgKGIuaGFzT3duUHJvcGVydHkocCkpIGRbcF0gPSBiW3BdO1xuICAgIGZ1bmN0aW9uIF9fKCkgeyB0aGlzLmNvbnN0cnVjdG9yID0gZDsgfVxuICAgIGQucHJvdG90eXBlID0gYiA9PT0gbnVsbCA/IE9iamVjdC5jcmVhdGUoYikgOiAoX18ucHJvdG90eXBlID0gYi5wcm90b3R5cGUsIG5ldyBfXygpKTtcbn07XG52YXIgU3Vic2NyaWJlcl8xID0gcmVxdWlyZSgnLi4vU3Vic2NyaWJlcicpO1xudmFyIGFzeW5jXzEgPSByZXF1aXJlKCcuLi9zY2hlZHVsZXIvYXN5bmMnKTtcbi8qKlxuICogRW1pdHMgdGhlIG1vc3QgcmVjZW50bHkgZW1pdHRlZCB2YWx1ZSBmcm9tIHRoZSBzb3VyY2UgT2JzZXJ2YWJsZSB3aXRoaW5cbiAqIHBlcmlvZGljIHRpbWUgaW50ZXJ2YWxzLlxuICpcbiAqIDxzcGFuIGNsYXNzPVwiaW5mb3JtYWxcIj5TYW1wbGVzIHRoZSBzb3VyY2UgT2JzZXJ2YWJsZSBhdCBwZXJpb2RpYyB0aW1lXG4gKiBpbnRlcnZhbHMsIGVtaXR0aW5nIHdoYXQgaXQgc2FtcGxlcy48L3NwYW4+XG4gKlxuICogPGltZyBzcmM9XCIuL2ltZy9zYW1wbGVUaW1lLnBuZ1wiIHdpZHRoPVwiMTAwJVwiPlxuICpcbiAqIGBzYW1wbGVUaW1lYCBwZXJpb2RpY2FsbHkgbG9va3MgYXQgdGhlIHNvdXJjZSBPYnNlcnZhYmxlIGFuZCBlbWl0cyB3aGljaGV2ZXJcbiAqIHZhbHVlIGl0IGhhcyBtb3N0IHJlY2VudGx5IGVtaXR0ZWQgc2luY2UgdGhlIHByZXZpb3VzIHNhbXBsaW5nLCB1bmxlc3MgdGhlXG4gKiBzb3VyY2UgaGFzIG5vdCBlbWl0dGVkIGFueXRoaW5nIHNpbmNlIHRoZSBwcmV2aW91cyBzYW1wbGluZy4gVGhlIHNhbXBsaW5nXG4gKiBoYXBwZW5zIHBlcmlvZGljYWxseSBpbiB0aW1lIGV2ZXJ5IGBwZXJpb2RgIG1pbGxpc2Vjb25kcyAob3IgdGhlIHRpbWUgdW5pdFxuICogZGVmaW5lZCBieSB0aGUgb3B0aW9uYWwgYHNjaGVkdWxlcmAgYXJndW1lbnQpLiBUaGUgc2FtcGxpbmcgc3RhcnRzIGFzIHNvb24gYXNcbiAqIHRoZSBvdXRwdXQgT2JzZXJ2YWJsZSBpcyBzdWJzY3JpYmVkLlxuICpcbiAqIEBleGFtcGxlIDxjYXB0aW9uPkV2ZXJ5IHNlY29uZCwgZW1pdCB0aGUgbW9zdCByZWNlbnQgY2xpY2sgYXQgbW9zdCBvbmNlPC9jYXB0aW9uPlxuICogdmFyIGNsaWNrcyA9IFJ4Lk9ic2VydmFibGUuZnJvbUV2ZW50KGRvY3VtZW50LCAnY2xpY2snKTtcbiAqIHZhciByZXN1bHQgPSBjbGlja3Muc2FtcGxlVGltZSgxMDAwKTtcbiAqIHJlc3VsdC5zdWJzY3JpYmUoeCA9PiBjb25zb2xlLmxvZyh4KSk7XG4gKlxuICogQHNlZSB7QGxpbmsgYXVkaXRUaW1lfVxuICogQHNlZSB7QGxpbmsgZGVib3VuY2VUaW1lfVxuICogQHNlZSB7QGxpbmsgZGVsYXl9XG4gKiBAc2VlIHtAbGluayBzYW1wbGV9XG4gKiBAc2VlIHtAbGluayB0aHJvdHRsZVRpbWV9XG4gKlxuICogQHBhcmFtIHtudW1iZXJ9IHBlcmlvZCBUaGUgc2FtcGxpbmcgcGVyaW9kIGV4cHJlc3NlZCBpbiBtaWxsaXNlY29uZHMgb3IgdGhlXG4gKiB0aW1lIHVuaXQgZGV0ZXJtaW5lZCBpbnRlcm5hbGx5IGJ5IHRoZSBvcHRpb25hbCBgc2NoZWR1bGVyYC5cbiAqIEBwYXJhbSB7U2NoZWR1bGVyfSBbc2NoZWR1bGVyPWFzeW5jXSBUaGUge0BsaW5rIElTY2hlZHVsZXJ9IHRvIHVzZSBmb3JcbiAqIG1hbmFnaW5nIHRoZSB0aW1lcnMgdGhhdCBoYW5kbGUgdGhlIHNhbXBsaW5nLlxuICogQHJldHVybiB7T2JzZXJ2YWJsZTxUPn0gQW4gT2JzZXJ2YWJsZSB0aGF0IGVtaXRzIHRoZSByZXN1bHRzIG9mIHNhbXBsaW5nIHRoZVxuICogdmFsdWVzIGVtaXR0ZWQgYnkgdGhlIHNvdXJjZSBPYnNlcnZhYmxlIGF0IHRoZSBzcGVjaWZpZWQgdGltZSBpbnRlcnZhbC5cbiAqIEBtZXRob2Qgc2FtcGxlVGltZVxuICogQG93bmVyIE9ic2VydmFibGVcbiAqL1xuZnVuY3Rpb24gc2FtcGxlVGltZShwZXJpb2QsIHNjaGVkdWxlcikge1xuICAgIGlmIChzY2hlZHVsZXIgPT09IHZvaWQgMCkgeyBzY2hlZHVsZXIgPSBhc3luY18xLmFzeW5jOyB9XG4gICAgcmV0dXJuIHRoaXMubGlmdChuZXcgU2FtcGxlVGltZU9wZXJhdG9yKHBlcmlvZCwgc2NoZWR1bGVyKSk7XG59XG5leHBvcnRzLnNhbXBsZVRpbWUgPSBzYW1wbGVUaW1lO1xudmFyIFNhbXBsZVRpbWVPcGVyYXRvciA9IChmdW5jdGlvbiAoKSB7XG4gICAgZnVuY3Rpb24gU2FtcGxlVGltZU9wZXJhdG9yKHBlcmlvZCwgc2NoZWR1bGVyKSB7XG4gICAgICAgIHRoaXMucGVyaW9kID0gcGVyaW9kO1xuICAgICAgICB0aGlzLnNjaGVkdWxlciA9IHNjaGVkdWxlcjtcbiAgICB9XG4gICAgU2FtcGxlVGltZU9wZXJhdG9yLnByb3RvdHlwZS5jYWxsID0gZnVuY3Rpb24gKHN1YnNjcmliZXIsIHNvdXJjZSkge1xuICAgICAgICByZXR1cm4gc291cmNlLnN1YnNjcmliZShuZXcgU2FtcGxlVGltZVN1YnNjcmliZXIoc3Vic2NyaWJlciwgdGhpcy5wZXJpb2QsIHRoaXMuc2NoZWR1bGVyKSk7XG4gICAgfTtcbiAgICByZXR1cm4gU2FtcGxlVGltZU9wZXJhdG9yO1xufSgpKTtcbi8qKlxuICogV2UgbmVlZCB0aGlzIEpTRG9jIGNvbW1lbnQgZm9yIGFmZmVjdGluZyBFU0RvYy5cbiAqIEBpZ25vcmVcbiAqIEBleHRlbmRzIHtJZ25vcmVkfVxuICovXG52YXIgU2FtcGxlVGltZVN1YnNjcmliZXIgPSAoZnVuY3Rpb24gKF9zdXBlcikge1xuICAgIF9fZXh0ZW5kcyhTYW1wbGVUaW1lU3Vic2NyaWJlciwgX3N1cGVyKTtcbiAgICBmdW5jdGlvbiBTYW1wbGVUaW1lU3Vic2NyaWJlcihkZXN0aW5hdGlvbiwgcGVyaW9kLCBzY2hlZHVsZXIpIHtcbiAgICAgICAgX3N1cGVyLmNhbGwodGhpcywgZGVzdGluYXRpb24pO1xuICAgICAgICB0aGlzLnBlcmlvZCA9IHBlcmlvZDtcbiAgICAgICAgdGhpcy5zY2hlZHVsZXIgPSBzY2hlZHVsZXI7XG4gICAgICAgIHRoaXMuaGFzVmFsdWUgPSBmYWxzZTtcbiAgICAgICAgdGhpcy5hZGQoc2NoZWR1bGVyLnNjaGVkdWxlKGRpc3BhdGNoTm90aWZpY2F0aW9uLCBwZXJpb2QsIHsgc3Vic2NyaWJlcjogdGhpcywgcGVyaW9kOiBwZXJpb2QgfSkpO1xuICAgIH1cbiAgICBTYW1wbGVUaW1lU3Vic2NyaWJlci5wcm90b3R5cGUuX25leHQgPSBmdW5jdGlvbiAodmFsdWUpIHtcbiAgICAgICAgdGhpcy5sYXN0VmFsdWUgPSB2YWx1ZTtcbiAgICAgICAgdGhpcy5oYXNWYWx1ZSA9IHRydWU7XG4gICAgfTtcbiAgICBTYW1wbGVUaW1lU3Vic2NyaWJlci5wcm90b3R5cGUubm90aWZ5TmV4dCA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgaWYgKHRoaXMuaGFzVmFsdWUpIHtcbiAgICAgICAgICAgIHRoaXMuaGFzVmFsdWUgPSBmYWxzZTtcbiAgICAgICAgICAgIHRoaXMuZGVzdGluYXRpb24ubmV4dCh0aGlzLmxhc3RWYWx1ZSk7XG4gICAgICAgIH1cbiAgICB9O1xuICAgIHJldHVybiBTYW1wbGVUaW1lU3Vic2NyaWJlcjtcbn0oU3Vic2NyaWJlcl8xLlN1YnNjcmliZXIpKTtcbmZ1bmN0aW9uIGRpc3BhdGNoTm90aWZpY2F0aW9uKHN0YXRlKSB7XG4gICAgdmFyIHN1YnNjcmliZXIgPSBzdGF0ZS5zdWJzY3JpYmVyLCBwZXJpb2QgPSBzdGF0ZS5wZXJpb2Q7XG4gICAgc3Vic2NyaWJlci5ub3RpZnlOZXh0KCk7XG4gICAgdGhpcy5zY2hlZHVsZShzdGF0ZSwgcGVyaW9kKTtcbn1cbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNhbXBsZVRpbWUuanMubWFwXG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9+L3J4anMvb3BlcmF0b3Ivc2FtcGxlVGltZS5qc1xuLy8gbW9kdWxlIGlkID0gMjA1XG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0="); - -/***/ }), -/* 206 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -eval("\nvar __extends = (this && this.__extends) || function (d, b) {\n for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n};\nvar OuterSubscriber_1 = __webpack_require__(303);\nvar subscribeToResult_1 = __webpack_require__(304);\n/**\n * Emits the values emitted by the source Observable until a `notifier`\n * Observable emits a value.\n *\n * Lets values pass until a second Observable,\n * `notifier`, emits something. Then, it completes.\n *\n * \n *\n * `takeUntil` subscribes and begins mirroring the source Observable. It also\n * monitors a second Observable, `notifier` that you provide. If the `notifier`\n * emits a value or a complete notification, the output Observable stops\n * mirroring the source Observable and completes.\n *\n * @example Tick every second until the first click happens\n * var interval = Rx.Observable.interval(1000);\n * var clicks = Rx.Observable.fromEvent(document, 'click');\n * var result = interval.takeUntil(clicks);\n * result.subscribe(x => console.log(x));\n *\n * @see {@link take}\n * @see {@link takeLast}\n * @see {@link takeWhile}\n * @see {@link skip}\n *\n * @param {Observable} notifier The Observable whose first emitted value will\n * cause the output Observable of `takeUntil` to stop emitting values from the\n * source Observable.\n * @return {Observable} An Observable that emits the values from the source\n * Observable until such time as `notifier` emits its first value.\n * @method takeUntil\n * @owner Observable\n */\nfunction takeUntil(notifier) {\n return this.lift(new TakeUntilOperator(notifier));\n}\nexports.takeUntil = takeUntil;\nvar TakeUntilOperator = (function () {\n function TakeUntilOperator(notifier) {\n this.notifier = notifier;\n }\n TakeUntilOperator.prototype.call = function (subscriber, source) {\n return source.subscribe(new TakeUntilSubscriber(subscriber, this.notifier));\n };\n return TakeUntilOperator;\n}());\n/**\n * We need this JSDoc comment for affecting ESDoc.\n * @ignore\n * @extends {Ignored}\n */\nvar TakeUntilSubscriber = (function (_super) {\n __extends(TakeUntilSubscriber, _super);\n function TakeUntilSubscriber(destination, notifier) {\n _super.call(this, destination);\n this.notifier = notifier;\n this.add(subscribeToResult_1.subscribeToResult(this, notifier));\n }\n TakeUntilSubscriber.prototype.notifyNext = function (outerValue, innerValue, outerIndex, innerIndex, innerSub) {\n this.complete();\n };\n TakeUntilSubscriber.prototype.notifyComplete = function () {\n // noop\n };\n return TakeUntilSubscriber;\n}(OuterSubscriber_1.OuterSubscriber));\n//# sourceMappingURL=takeUntil.js.map//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9+L3J4anMvb3BlcmF0b3IvdGFrZVVudGlsLmpzPzk5NjUiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0EsbUJBQW1CLHNCQUFzQjtBQUN6QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsU0FBUztBQUNULFNBQVM7QUFDVCxTQUFTO0FBQ1Q7QUFDQSxXQUFXLFdBQVc7QUFDdEI7QUFDQTtBQUNBLFlBQVksY0FBYztBQUMxQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLENBQUM7QUFDRDtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsQ0FBQztBQUNEIiwiZmlsZSI6IjIwNi5qcyIsInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xudmFyIF9fZXh0ZW5kcyA9ICh0aGlzICYmIHRoaXMuX19leHRlbmRzKSB8fCBmdW5jdGlvbiAoZCwgYikge1xuICAgIGZvciAodmFyIHAgaW4gYikgaWYgKGIuaGFzT3duUHJvcGVydHkocCkpIGRbcF0gPSBiW3BdO1xuICAgIGZ1bmN0aW9uIF9fKCkgeyB0aGlzLmNvbnN0cnVjdG9yID0gZDsgfVxuICAgIGQucHJvdG90eXBlID0gYiA9PT0gbnVsbCA/IE9iamVjdC5jcmVhdGUoYikgOiAoX18ucHJvdG90eXBlID0gYi5wcm90b3R5cGUsIG5ldyBfXygpKTtcbn07XG52YXIgT3V0ZXJTdWJzY3JpYmVyXzEgPSByZXF1aXJlKCcuLi9PdXRlclN1YnNjcmliZXInKTtcbnZhciBzdWJzY3JpYmVUb1Jlc3VsdF8xID0gcmVxdWlyZSgnLi4vdXRpbC9zdWJzY3JpYmVUb1Jlc3VsdCcpO1xuLyoqXG4gKiBFbWl0cyB0aGUgdmFsdWVzIGVtaXR0ZWQgYnkgdGhlIHNvdXJjZSBPYnNlcnZhYmxlIHVudGlsIGEgYG5vdGlmaWVyYFxuICogT2JzZXJ2YWJsZSBlbWl0cyBhIHZhbHVlLlxuICpcbiAqIDxzcGFuIGNsYXNzPVwiaW5mb3JtYWxcIj5MZXRzIHZhbHVlcyBwYXNzIHVudGlsIGEgc2Vjb25kIE9ic2VydmFibGUsXG4gKiBgbm90aWZpZXJgLCBlbWl0cyBzb21ldGhpbmcuIFRoZW4sIGl0IGNvbXBsZXRlcy48L3NwYW4+XG4gKlxuICogPGltZyBzcmM9XCIuL2ltZy90YWtlVW50aWwucG5nXCIgd2lkdGg9XCIxMDAlXCI+XG4gKlxuICogYHRha2VVbnRpbGAgc3Vic2NyaWJlcyBhbmQgYmVnaW5zIG1pcnJvcmluZyB0aGUgc291cmNlIE9ic2VydmFibGUuIEl0IGFsc29cbiAqIG1vbml0b3JzIGEgc2Vjb25kIE9ic2VydmFibGUsIGBub3RpZmllcmAgdGhhdCB5b3UgcHJvdmlkZS4gSWYgdGhlIGBub3RpZmllcmBcbiAqIGVtaXRzIGEgdmFsdWUgb3IgYSBjb21wbGV0ZSBub3RpZmljYXRpb24sIHRoZSBvdXRwdXQgT2JzZXJ2YWJsZSBzdG9wc1xuICogbWlycm9yaW5nIHRoZSBzb3VyY2UgT2JzZXJ2YWJsZSBhbmQgY29tcGxldGVzLlxuICpcbiAqIEBleGFtcGxlIDxjYXB0aW9uPlRpY2sgZXZlcnkgc2Vjb25kIHVudGlsIHRoZSBmaXJzdCBjbGljayBoYXBwZW5zPC9jYXB0aW9uPlxuICogdmFyIGludGVydmFsID0gUnguT2JzZXJ2YWJsZS5pbnRlcnZhbCgxMDAwKTtcbiAqIHZhciBjbGlja3MgPSBSeC5PYnNlcnZhYmxlLmZyb21FdmVudChkb2N1bWVudCwgJ2NsaWNrJyk7XG4gKiB2YXIgcmVzdWx0ID0gaW50ZXJ2YWwudGFrZVVudGlsKGNsaWNrcyk7XG4gKiByZXN1bHQuc3Vic2NyaWJlKHggPT4gY29uc29sZS5sb2coeCkpO1xuICpcbiAqIEBzZWUge0BsaW5rIHRha2V9XG4gKiBAc2VlIHtAbGluayB0YWtlTGFzdH1cbiAqIEBzZWUge0BsaW5rIHRha2VXaGlsZX1cbiAqIEBzZWUge0BsaW5rIHNraXB9XG4gKlxuICogQHBhcmFtIHtPYnNlcnZhYmxlfSBub3RpZmllciBUaGUgT2JzZXJ2YWJsZSB3aG9zZSBmaXJzdCBlbWl0dGVkIHZhbHVlIHdpbGxcbiAqIGNhdXNlIHRoZSBvdXRwdXQgT2JzZXJ2YWJsZSBvZiBgdGFrZVVudGlsYCB0byBzdG9wIGVtaXR0aW5nIHZhbHVlcyBmcm9tIHRoZVxuICogc291cmNlIE9ic2VydmFibGUuXG4gKiBAcmV0dXJuIHtPYnNlcnZhYmxlPFQ+fSBBbiBPYnNlcnZhYmxlIHRoYXQgZW1pdHMgdGhlIHZhbHVlcyBmcm9tIHRoZSBzb3VyY2VcbiAqIE9ic2VydmFibGUgdW50aWwgc3VjaCB0aW1lIGFzIGBub3RpZmllcmAgZW1pdHMgaXRzIGZpcnN0IHZhbHVlLlxuICogQG1ldGhvZCB0YWtlVW50aWxcbiAqIEBvd25lciBPYnNlcnZhYmxlXG4gKi9cbmZ1bmN0aW9uIHRha2VVbnRpbChub3RpZmllcikge1xuICAgIHJldHVybiB0aGlzLmxpZnQobmV3IFRha2VVbnRpbE9wZXJhdG9yKG5vdGlmaWVyKSk7XG59XG5leHBvcnRzLnRha2VVbnRpbCA9IHRha2VVbnRpbDtcbnZhciBUYWtlVW50aWxPcGVyYXRvciA9IChmdW5jdGlvbiAoKSB7XG4gICAgZnVuY3Rpb24gVGFrZVVudGlsT3BlcmF0b3Iobm90aWZpZXIpIHtcbiAgICAgICAgdGhpcy5ub3RpZmllciA9IG5vdGlmaWVyO1xuICAgIH1cbiAgICBUYWtlVW50aWxPcGVyYXRvci5wcm90b3R5cGUuY2FsbCA9IGZ1bmN0aW9uIChzdWJzY3JpYmVyLCBzb3VyY2UpIHtcbiAgICAgICAgcmV0dXJuIHNvdXJjZS5zdWJzY3JpYmUobmV3IFRha2VVbnRpbFN1YnNjcmliZXIoc3Vic2NyaWJlciwgdGhpcy5ub3RpZmllcikpO1xuICAgIH07XG4gICAgcmV0dXJuIFRha2VVbnRpbE9wZXJhdG9yO1xufSgpKTtcbi8qKlxuICogV2UgbmVlZCB0aGlzIEpTRG9jIGNvbW1lbnQgZm9yIGFmZmVjdGluZyBFU0RvYy5cbiAqIEBpZ25vcmVcbiAqIEBleHRlbmRzIHtJZ25vcmVkfVxuICovXG52YXIgVGFrZVVudGlsU3Vic2NyaWJlciA9IChmdW5jdGlvbiAoX3N1cGVyKSB7XG4gICAgX19leHRlbmRzKFRha2VVbnRpbFN1YnNjcmliZXIsIF9zdXBlcik7XG4gICAgZnVuY3Rpb24gVGFrZVVudGlsU3Vic2NyaWJlcihkZXN0aW5hdGlvbiwgbm90aWZpZXIpIHtcbiAgICAgICAgX3N1cGVyLmNhbGwodGhpcywgZGVzdGluYXRpb24pO1xuICAgICAgICB0aGlzLm5vdGlmaWVyID0gbm90aWZpZXI7XG4gICAgICAgIHRoaXMuYWRkKHN1YnNjcmliZVRvUmVzdWx0XzEuc3Vic2NyaWJlVG9SZXN1bHQodGhpcywgbm90aWZpZXIpKTtcbiAgICB9XG4gICAgVGFrZVVudGlsU3Vic2NyaWJlci5wcm90b3R5cGUubm90aWZ5TmV4dCA9IGZ1bmN0aW9uIChvdXRlclZhbHVlLCBpbm5lclZhbHVlLCBvdXRlckluZGV4LCBpbm5lckluZGV4LCBpbm5lclN1Yikge1xuICAgICAgICB0aGlzLmNvbXBsZXRlKCk7XG4gICAgfTtcbiAgICBUYWtlVW50aWxTdWJzY3JpYmVyLnByb3RvdHlwZS5ub3RpZnlDb21wbGV0ZSA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgLy8gbm9vcFxuICAgIH07XG4gICAgcmV0dXJuIFRha2VVbnRpbFN1YnNjcmliZXI7XG59KE91dGVyU3Vic2NyaWJlcl8xLk91dGVyU3Vic2NyaWJlcikpO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dGFrZVVudGlsLmpzLm1hcFxuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIC4vfi9yeGpzL29wZXJhdG9yL3Rha2VVbnRpbC5qc1xuLy8gbW9kdWxlIGlkID0gMjA2XG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0="); - -/***/ }), -/* 207 */ -/***/ (function(module, exports, __webpack_require__) { - -eval("/* WEBPACK VAR INJECTION */(function(global, process) {(function (global, undefined) {\n \"use strict\";\n\n if (global.setImmediate) {\n return;\n }\n\n var nextHandle = 1; // Spec says greater than zero\n var tasksByHandle = {};\n var currentlyRunningATask = false;\n var doc = global.document;\n var registerImmediate;\n\n function setImmediate(callback) {\n // Callback can either be a function or a string\n if (typeof callback !== \"function\") {\n callback = new Function(\"\" + callback);\n }\n // Copy function arguments\n var args = new Array(arguments.length - 1);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 1];\n }\n // Store and register the task\n var task = { callback: callback, args: args };\n tasksByHandle[nextHandle] = task;\n registerImmediate(nextHandle);\n return nextHandle++;\n }\n\n function clearImmediate(handle) {\n delete tasksByHandle[handle];\n }\n\n function run(task) {\n var callback = task.callback;\n var args = task.args;\n switch (args.length) {\n case 0:\n callback();\n break;\n case 1:\n callback(args[0]);\n break;\n case 2:\n callback(args[0], args[1]);\n break;\n case 3:\n callback(args[0], args[1], args[2]);\n break;\n default:\n callback.apply(undefined, args);\n break;\n }\n }\n\n function runIfPresent(handle) {\n // From the spec: \"Wait until any invocations of this algorithm started before this one have completed.\"\n // So if we're currently running a task, we'll need to delay this invocation.\n if (currentlyRunningATask) {\n // Delay by doing a setTimeout. setImmediate was tried instead, but in Firefox 7 it generated a\n // \"too much recursion\" error.\n setTimeout(runIfPresent, 0, handle);\n } else {\n var task = tasksByHandle[handle];\n if (task) {\n currentlyRunningATask = true;\n try {\n run(task);\n } finally {\n clearImmediate(handle);\n currentlyRunningATask = false;\n }\n }\n }\n }\n\n function installNextTickImplementation() {\n registerImmediate = function(handle) {\n process.nextTick(function () { runIfPresent(handle); });\n };\n }\n\n function canUsePostMessage() {\n // The test against `importScripts` prevents this implementation from being installed inside a web worker,\n // where `global.postMessage` means something completely different and can't be used for this purpose.\n if (global.postMessage && !global.importScripts) {\n var postMessageIsAsynchronous = true;\n var oldOnMessage = global.onmessage;\n global.onmessage = function() {\n postMessageIsAsynchronous = false;\n };\n global.postMessage(\"\", \"*\");\n global.onmessage = oldOnMessage;\n return postMessageIsAsynchronous;\n }\n }\n\n function installPostMessageImplementation() {\n // Installs an event handler on `global` for the `message` event: see\n // * https://developer.mozilla.org/en/DOM/window.postMessage\n // * http://www.whatwg.org/specs/web-apps/current-work/multipage/comms.html#crossDocumentMessages\n\n var messagePrefix = \"setImmediate$\" + Math.random() + \"$\";\n var onGlobalMessage = function(event) {\n if (event.source === global &&\n typeof event.data === \"string\" &&\n event.data.indexOf(messagePrefix) === 0) {\n runIfPresent(+event.data.slice(messagePrefix.length));\n }\n };\n\n if (global.addEventListener) {\n global.addEventListener(\"message\", onGlobalMessage, false);\n } else {\n global.attachEvent(\"onmessage\", onGlobalMessage);\n }\n\n registerImmediate = function(handle) {\n global.postMessage(messagePrefix + handle, \"*\");\n };\n }\n\n function installMessageChannelImplementation() {\n var channel = new MessageChannel();\n channel.port1.onmessage = function(event) {\n var handle = event.data;\n runIfPresent(handle);\n };\n\n registerImmediate = function(handle) {\n channel.port2.postMessage(handle);\n };\n }\n\n function installReadyStateChangeImplementation() {\n var html = doc.documentElement;\n registerImmediate = function(handle) {\n // Create a