Prevents duplicate ruleset config tabs.
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
using Cryville.Crtr.Browsing.UI;
|
||||
using Cryville.Crtr.UI;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using Object = UnityEngine.Object;
|
||||
|
||||
namespace Cryville.Crtr.Browsing.Actions {
|
||||
@@ -9,18 +10,25 @@ namespace Cryville.Crtr.Browsing.Actions {
|
||||
|
||||
public override int Priority { get { return -50; } }
|
||||
|
||||
static Dictionary<string, int> _rulesetTabs = new Dictionary<string, int>();
|
||||
|
||||
public override void Invoke(Uri uri, ChartDetail resource) {
|
||||
var master = ResourceBrowserMaster.Instance;
|
||||
var ruleset = resource.Meta.ruleset;
|
||||
int tabId;
|
||||
if (_rulesetTabs.TryGetValue(ruleset, out tabId) && master.TryOpenTab(tabId))
|
||||
return;
|
||||
var browser = Object.Instantiate(master.m_configBrowserPrefab).GetComponent<RulesetConfigBrowser>();
|
||||
try {
|
||||
browser.Load(resource.Meta.ruleset);
|
||||
browser.Load(ruleset);
|
||||
}
|
||||
catch (Exception ex) {
|
||||
Dialog.Show(null, ex.Message);
|
||||
Game.MainLogger.Log(4, "Config", "An error occurred while loading the config: {0}", ex);
|
||||
Object.Destroy(browser.gameObject);
|
||||
return;
|
||||
}
|
||||
master.AddAndOpenTab(string.Format("Config: {0}", resource.Meta.ruleset), browser);
|
||||
_rulesetTabs[ruleset] = master.AddAndOpenTab(string.Format("Config: {0}", ruleset), browser);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user