diff --git a/src/Umbraco.Web/Trees/LanguageTreeController.cs b/src/Umbraco.Web/Trees/LanguageTreeController.cs
index 1fa8188376..1bf066e5ba 100644
--- a/src/Umbraco.Web/Trees/LanguageTreeController.cs
+++ b/src/Umbraco.Web/Trees/LanguageTreeController.cs
@@ -19,78 +19,31 @@ namespace Umbraco.Web.Trees
[CoreTree]
public class LanguageTreeController : TreeController
{
- ///
- /// The method called to render the contents of the tree structure
- ///
- ///
- ///
- /// All of the query string parameters passed from jsTree
- ///
- ///
- /// We are allowing an arbitrary number of query strings to be pased in so that developers are able to persist custom data from the front-end
- /// to the back end to be used in the query for model data.
- ///
protected override TreeNodeCollection GetTreeNodes(string id, FormDataCollection queryStrings)
{
- var nodes = new TreeNodeCollection();
+ //We don't have any child nodes & only use the root node to load a custom UI
+ return new TreeNodeCollection();
+ }
- if (id == Constants.System.Root.ToInvariantString())
- {
- var languages = Services.LocalizationService.GetAllLanguages();
- foreach (var language in languages)
- {
- nodes.Add(
- CreateTreeNode(
- language.Id.ToString(CultureInfo.InvariantCulture), "-1", queryStrings, language.CultureInfo.DisplayName, "icon-flag-alt", false,
- //TODO: Rebuild the language editor in angular, then we dont need to have this at all (which is just a path to the legacy editor)
- "/" + queryStrings.GetValue("application") + "/framed/" +
- Uri.EscapeDataString("settings/editLanguage.aspx?id=" + language.Id)));
- }
- }
-
- return nodes;
+ protected override MenuItemCollection GetMenuForNode(string id, FormDataCollection queryStrings)
+ {
+ //We don't have any menu item options (such as create/delete/reload) & only use the root node to load a custom UI
+ return null;
}
///
- /// Returns the menu structure for the node
+ /// Helper method to create a root model for a tree
///
- ///
- ///
///
- protected override MenuItemCollection GetMenuForNode(string id, FormDataCollection queryStrings)
+ protected override TreeNode CreateRootNode(FormDataCollection queryStrings)
{
- var menu = new MenuItemCollection();
+ var root = base.CreateRootNode(queryStrings);
- if (id == Constants.System.Root.ToInvariantString())
- {
- //Create the normal create action
- menu.Items.Add(Services.TextService.Localize("actions", ActionNew.Instance.Alias))
- //Since we haven't implemented anything for languages in angular, this needs to be converted to
- //use the legacy format
- .ConvertLegacyMenuItem(null, "initlanguages", queryStrings.GetValue("application"));
+ //this will load in a custom UI instead of the dashboard for the root node
+ root.RoutePath = string.Format("{0}/{1}/{2}", Constants.Applications.Settings, Constants.Trees.Languages, "overview");
+ root.Icon = "icon-flag-alt";
- //refresh action
- menu.Items.Add(Services.TextService.Localize("actions", ActionRefresh.Instance.Alias), true);
-
- return menu;
- }
-
- var lang = Services.LocalizationService.GetLanguageById(int.Parse(id));
- if (lang == null) return new MenuItemCollection();
-
- //add delete option for all languages
- menu.Items.Add(Services.TextService.Localize("actions", ActionDelete.Instance.Alias))
- //Since we haven't implemented anything for languages in angular, this needs to be converted to
- //use the legacy format
- .ConvertLegacyMenuItem(new EntitySlim
- {
- Id = lang.Id,
- Level = 1,
- ParentId = -1,
- Name = lang.CultureInfo.DisplayName
- }, "language", queryStrings.GetValue("application"));
-
- return menu;
+ return root;
}
}
}