update mac project
This commit is contained in:
parent
97ece5bd6f
commit
7f376fde27
|
@ -14,7 +14,7 @@ namespace MediaBrowser.Server.Mac
|
||||||
{
|
{
|
||||||
public override void AwakeFromNib()
|
public override void AwakeFromNib()
|
||||||
{
|
{
|
||||||
|
//new MenuBarIcon ().ShowIcon ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,8 @@ namespace MediaBrowser.Server.Mac
|
||||||
|
|
||||||
public override void FinishedLaunching (NSObject notification)
|
public override void FinishedLaunching (NSObject notification)
|
||||||
{
|
{
|
||||||
new MenuBarIcon ().ShowIcon ();
|
new MenuBarIcon (MainClass.AppHost.LogManager.GetLogger("Tray"))
|
||||||
|
.ShowIcon ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@ namespace MediaBrowser.Server.Mac
|
||||||
{
|
{
|
||||||
class MainClass
|
class MainClass
|
||||||
{
|
{
|
||||||
private static ApplicationHost _appHost;
|
internal static ApplicationHost AppHost;
|
||||||
|
|
||||||
private static ILogger _logger;
|
private static ILogger _logger;
|
||||||
|
|
||||||
|
@ -56,13 +56,6 @@ namespace MediaBrowser.Server.Mac
|
||||||
NSApplication.Main (args);
|
NSApplication.Main (args);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void AddDependencies(MenuBarIcon appController){
|
|
||||||
appController.AppHost = _appHost;
|
|
||||||
appController.Logger = _logger;
|
|
||||||
appController.ConfigurationManager = _appHost.ServerConfigurationManager;
|
|
||||||
appController.Localization = _appHost.LocalizationManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static ServerApplicationPaths CreateApplicationPaths(string applicationPath, string programDataPath)
|
private static ServerApplicationPaths CreateApplicationPaths(string applicationPath, string programDataPath)
|
||||||
{
|
{
|
||||||
if (string.IsNullOrEmpty(programDataPath))
|
if (string.IsNullOrEmpty(programDataPath))
|
||||||
|
@ -96,10 +89,10 @@ namespace MediaBrowser.Server.Mac
|
||||||
|
|
||||||
var nativeApp = new NativeApp();
|
var nativeApp = new NativeApp();
|
||||||
|
|
||||||
_appHost = new ApplicationHost(appPaths, logManager, options, fileSystem, "MBServer.Mono", false, nativeApp);
|
AppHost = new ApplicationHost(appPaths, logManager, options, fileSystem, "MBServer.Mono", false, nativeApp);
|
||||||
|
|
||||||
if (options.ContainsOption("-v")) {
|
if (options.ContainsOption("-v")) {
|
||||||
Console.WriteLine (_appHost.ApplicationVersion.ToString());
|
Console.WriteLine (AppHost.ApplicationVersion.ToString());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,9 +105,14 @@ namespace MediaBrowser.Server.Mac
|
||||||
{
|
{
|
||||||
var initProgress = new Progress<double>();
|
var initProgress = new Progress<double>();
|
||||||
|
|
||||||
await _appHost.Init (initProgress).ConfigureAwait (false);
|
await AppHost.Init (initProgress).ConfigureAwait (false);
|
||||||
|
|
||||||
//await _appHost.RunStartupTasks ().ConfigureAwait (false);
|
await AppHost.RunStartupTasks ().ConfigureAwait (false);
|
||||||
|
|
||||||
|
if (MenuBarIcon.Instance != null)
|
||||||
|
{
|
||||||
|
MenuBarIcon.Instance.Localize ();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -138,7 +136,7 @@ namespace MediaBrowser.Server.Mac
|
||||||
private static void ShutdownApp()
|
private static void ShutdownApp()
|
||||||
{
|
{
|
||||||
_logger.Info ("Calling ApplicationHost.Dispose");
|
_logger.Info ("Calling ApplicationHost.Dispose");
|
||||||
_appHost.Dispose ();
|
AppHost.Dispose ();
|
||||||
|
|
||||||
_logger.Info("AppController.Terminate");
|
_logger.Info("AppController.Terminate");
|
||||||
MenuBarIcon.Instance.Terminate ();
|
MenuBarIcon.Instance.Terminate ();
|
||||||
|
@ -153,7 +151,7 @@ namespace MediaBrowser.Server.Mac
|
||||||
{
|
{
|
||||||
var exception = (Exception)e.ExceptionObject;
|
var exception = (Exception)e.ExceptionObject;
|
||||||
|
|
||||||
new UnhandledExceptionWriter(_appHost.ServerConfigurationManager.ApplicationPaths, _logger, _appHost.LogManager).Log(exception);
|
new UnhandledExceptionWriter(AppHost.ServerConfigurationManager.ApplicationPaths, _logger, AppHost.LogManager).Log(exception);
|
||||||
|
|
||||||
if (!Debugger.IsAttached)
|
if (!Debugger.IsAttached)
|
||||||
{
|
{
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
<ApplicationIcon>..\MediaBrowser.WebDashboard\dashboard-ui\css\images\favicon.ico</ApplicationIcon>
|
<ApplicationIcon>..\MediaBrowser.WebDashboard\dashboard-ui\css\images\favicon.ico</ApplicationIcon>
|
||||||
<ReleaseVersion>
|
<ReleaseVersion>
|
||||||
</ReleaseVersion>
|
</ReleaseVersion>
|
||||||
|
<StartupObject>MediaBrowser.Server.Mac.MainClass</StartupObject>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
||||||
<DebugSymbols>true</DebugSymbols>
|
<DebugSymbols>true</DebugSymbols>
|
||||||
|
@ -31,7 +32,6 @@
|
||||||
<PackageSigningKey>Developer ID Installer</PackageSigningKey>
|
<PackageSigningKey>Developer ID Installer</PackageSigningKey>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
||||||
<DebugType>full</DebugType>
|
|
||||||
<Optimize>true</Optimize>
|
<Optimize>true</Optimize>
|
||||||
<OutputPath>bin\Release</OutputPath>
|
<OutputPath>bin\Release</OutputPath>
|
||||||
<ErrorReport>prompt</ErrorReport>
|
<ErrorReport>prompt</ErrorReport>
|
||||||
|
@ -254,6 +254,8 @@
|
||||||
<BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\shred\content.js">
|
<BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\shred\content.js">
|
||||||
<Link>Resources\swagger-ui\lib\shred\content.js</Link>
|
<Link>Resources\swagger-ui\lib\shred\content.js</Link>
|
||||||
</BundleResource>
|
</BundleResource>
|
||||||
|
<BundleResource Include="Resources\appicon.icns" />
|
||||||
|
<BundleResource Include="Resources\MediaBrowser.Server.Mac\Images.xcassets\AppIcon.appiconset\Contents.json" />
|
||||||
<BundleResource Include="..\MediaBrowser.WebDashboard\dashboard-ui\.DS_Store">
|
<BundleResource Include="..\MediaBrowser.WebDashboard\dashboard-ui\.DS_Store">
|
||||||
<Link>Resources\dashboard-ui\.DS_Store</Link>
|
<Link>Resources\dashboard-ui\.DS_Store</Link>
|
||||||
</BundleResource>
|
</BundleResource>
|
||||||
|
@ -2960,7 +2962,5 @@
|
||||||
<BundleResource Include="..\MediaBrowser.WebDashboard\dashboard-ui\thirdparty\swipebox-master\js\jquery.swipebox.min.js">
|
<BundleResource Include="..\MediaBrowser.WebDashboard\dashboard-ui\thirdparty\swipebox-master\js\jquery.swipebox.min.js">
|
||||||
<Link>Resources\dashboard-ui\thirdparty\swipebox-master\js\jquery.swipebox.min.js</Link>
|
<Link>Resources\dashboard-ui\thirdparty\swipebox-master\js\jquery.swipebox.min.js</Link>
|
||||||
</BundleResource>
|
</BundleResource>
|
||||||
<BundleResource Include="Resources\appicon.icns" />
|
|
||||||
<BundleResource Include="Resources\MediaBrowser.Server.Mac\Images.xcassets\AppIcon.appiconset\Contents.json" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
|
@ -21,22 +21,40 @@ namespace MediaBrowser.Server.Mac
|
||||||
|
|
||||||
public static MenuBarIcon Instance;
|
public static MenuBarIcon Instance;
|
||||||
|
|
||||||
public MenuBarIcon ()
|
public MenuBarIcon (ILogger logger)
|
||||||
{
|
{
|
||||||
Instance = this;
|
Instance = this;
|
||||||
//MainClass.AddDependencies (this);
|
Logger = logger;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ShowIcon() {
|
public void ShowIcon() {
|
||||||
|
|
||||||
NSApplication.SharedApplication.BeginInvokeOnMainThread (ShowIconInternal);
|
NSApplication.SharedApplication.BeginInvokeOnMainThread (CreateMenus);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ShowIconInternal() {
|
private void CreateMenus() {
|
||||||
|
|
||||||
|
CreateNsMenu ();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Localize()
|
||||||
|
{
|
||||||
|
NSApplication.SharedApplication.BeginInvokeOnMainThread (() => {
|
||||||
|
|
||||||
|
var configManager = MainClass.AppHost.ServerConfigurationManager;
|
||||||
|
|
||||||
|
configManager.ConfigurationUpdated -= Instance_ConfigurationUpdated;
|
||||||
|
LocalizeText ();
|
||||||
|
configManager.ConfigurationUpdated += Instance_ConfigurationUpdated;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private NSStatusItem statusItem;
|
||||||
|
private void CreateNsMenu() {
|
||||||
|
|
||||||
var menu = new NSMenu ();
|
var menu = new NSMenu ();
|
||||||
|
|
||||||
var statusItem = NSStatusBar.SystemStatusBar.CreateStatusItem(30);
|
statusItem = NSStatusBar.SystemStatusBar.CreateStatusItem(30);
|
||||||
statusItem.Menu = menu;
|
statusItem.Menu = menu;
|
||||||
statusItem.Image = NSImage.ImageNamed("statusicon");
|
statusItem.Image = NSImage.ImageNamed("statusicon");
|
||||||
statusItem.HighlightMode = true;
|
statusItem.HighlightMode = true;
|
||||||
|
@ -78,22 +96,13 @@ namespace MediaBrowser.Server.Mac
|
||||||
Quit (NSApplication.SharedApplication);
|
Quit (NSApplication.SharedApplication);
|
||||||
});
|
});
|
||||||
menu.AddItem (quitMenuItem);
|
menu.AddItem (quitMenuItem);
|
||||||
|
|
||||||
NSApplication.SharedApplication.MainMenu = menu;
|
|
||||||
|
|
||||||
//ConfigurationManager.ConfigurationUpdated -= Instance_ConfigurationUpdated;
|
|
||||||
//LocalizeText ();
|
|
||||||
//ConfigurationManager.ConfigurationUpdated += Instance_ConfigurationUpdated;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public IServerApplicationHost AppHost{ get; set;}
|
private ILogger Logger{ get; set;}
|
||||||
public IServerConfigurationManager ConfigurationManager { get; set;}
|
|
||||||
public ILogger Logger{ get; set;}
|
|
||||||
public ILocalizationManager Localization { get; set;}
|
|
||||||
|
|
||||||
private void Quit(NSObject sender)
|
private void Quit(NSObject sender)
|
||||||
{
|
{
|
||||||
AppHost.Shutdown();
|
MainClass.AppHost.Shutdown();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Community(NSObject sender)
|
private void Community(NSObject sender)
|
||||||
|
@ -103,12 +112,12 @@ namespace MediaBrowser.Server.Mac
|
||||||
|
|
||||||
private void Configure(NSObject sender)
|
private void Configure(NSObject sender)
|
||||||
{
|
{
|
||||||
BrowserLauncher.OpenDashboard(AppHost, Logger);
|
BrowserLauncher.OpenDashboard(MainClass.AppHost, Logger);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Browse(NSObject sender)
|
private void Browse(NSObject sender)
|
||||||
{
|
{
|
||||||
BrowserLauncher.OpenWebClient(AppHost, Logger);
|
BrowserLauncher.OpenWebClient(MainClass.AppHost, Logger);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Github(NSObject sender)
|
private void Github(NSObject sender)
|
||||||
|
@ -118,7 +127,7 @@ namespace MediaBrowser.Server.Mac
|
||||||
|
|
||||||
private void ApiDocs(NSObject sender)
|
private void ApiDocs(NSObject sender)
|
||||||
{
|
{
|
||||||
BrowserLauncher.OpenSwagger(AppHost, Logger);
|
BrowserLauncher.OpenSwagger(MainClass.AppHost, Logger);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Terminate()
|
public void Terminate()
|
||||||
|
@ -134,7 +143,9 @@ namespace MediaBrowser.Server.Mac
|
||||||
/// <param name="e">The <see cref="EventArgs" /> instance containing the event data.</param>
|
/// <param name="e">The <see cref="EventArgs" /> instance containing the event data.</param>
|
||||||
void Instance_ConfigurationUpdated(object sender, EventArgs e)
|
void Instance_ConfigurationUpdated(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
if (!string.Equals(ConfigurationManager.Configuration.UICulture, _uiCulture,
|
var configManager = MainClass.AppHost.ServerConfigurationManager;
|
||||||
|
|
||||||
|
if (!string.Equals(configManager.Configuration.UICulture, _uiCulture,
|
||||||
StringComparison.OrdinalIgnoreCase))
|
StringComparison.OrdinalIgnoreCase))
|
||||||
{
|
{
|
||||||
LocalizeText();
|
LocalizeText();
|
||||||
|
@ -143,20 +154,24 @@ namespace MediaBrowser.Server.Mac
|
||||||
|
|
||||||
private void LocalizeText()
|
private void LocalizeText()
|
||||||
{
|
{
|
||||||
_uiCulture = ConfigurationManager.Configuration.UICulture;
|
var configManager = MainClass.AppHost.ServerConfigurationManager;
|
||||||
|
|
||||||
|
_uiCulture = configManager.Configuration.UICulture;
|
||||||
|
|
||||||
NSApplication.SharedApplication.BeginInvokeOnMainThread (LocalizeInternal);
|
NSApplication.SharedApplication.BeginInvokeOnMainThread (LocalizeInternal);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void LocalizeInternal() {
|
private void LocalizeInternal() {
|
||||||
|
|
||||||
quitMenuItem.Title = Localization.GetLocalizedString("LabelExit");
|
var localization = MainClass.AppHost.LocalizationManager;
|
||||||
communityMenuItem.Title = Localization.GetLocalizedString("LabelVisitCommunity");
|
|
||||||
githubMenuItem.Title = Localization.GetLocalizedString("LabelGithub");
|
quitMenuItem.Title = localization.GetLocalizedString("LabelExit");
|
||||||
apiMenuItem.Title = Localization.GetLocalizedString("LabelApiDocumentation");
|
communityMenuItem.Title = localization.GetLocalizedString("LabelVisitCommunity");
|
||||||
developerMenuItem.Title = Localization.GetLocalizedString("LabelDeveloperResources");
|
githubMenuItem.Title = localization.GetLocalizedString("LabelGithub");
|
||||||
browseMenuItem.Title = Localization.GetLocalizedString("LabelBrowseLibrary");
|
apiMenuItem.Title = localization.GetLocalizedString("LabelApiDocumentation");
|
||||||
configureMenuItem.Title = Localization.GetLocalizedString("LabelConfigureMediaBrowser");
|
developerMenuItem.Title = localization.GetLocalizedString("LabelDeveloperResources");
|
||||||
|
browseMenuItem.Title = localization.GetLocalizedString("LabelBrowseLibrary");
|
||||||
|
configureMenuItem.Title = localization.GetLocalizedString("LabelConfigureMediaBrowser");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user