From 38705580c834b6a4a27a87516801f15b1c9e9e18 Mon Sep 17 00:00:00 2001 From: Gustavo Tandeciarz Date: Tue, 30 Jun 2015 14:48:02 -0400 Subject: [PATCH 01/17] Update web.config MVC bindings Updated from 5.2.0.0 to 5.2.3 --- src/Orchard.Azure/Orchard.Azure.Web/Web.config | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Orchard.Azure/Orchard.Azure.Web/Web.config b/src/Orchard.Azure/Orchard.Azure.Web/Web.config index 214fc6e72..1ba2fdcbd 100644 --- a/src/Orchard.Azure/Orchard.Azure.Web/Web.config +++ b/src/Orchard.Azure/Orchard.Azure.Web/Web.config @@ -18,7 +18,7 @@ - + @@ -60,7 +60,7 @@ - + @@ -147,7 +147,7 @@ - + From 0318db4c53854f925563a2d031f8d731691c2319 Mon Sep 17 00:00:00 2001 From: Gustavo Tandeciarz Date: Tue, 30 Jun 2015 17:53:13 -0400 Subject: [PATCH 02/17] Web.Config: Updating MVC reference to 5.2.3 web.config was still referencing 5.1.0.0 --- src/Orchard.Web/Modules/Orchard.Layouts/Web.config | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Web.config b/src/Orchard.Web/Modules/Orchard.Layouts/Web.config index fef614527..6ddbb3ba6 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Web.config +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Web.config @@ -9,7 +9,7 @@ - + @@ -29,7 +29,7 @@ - + From 993e6a1e439ec82193ddc856cb781b41f9738d0a Mon Sep 17 00:00:00 2001 From: Gustavo Tandeciarz Date: Tue, 30 Jun 2015 17:54:18 -0400 Subject: [PATCH 03/17] Web.config: MVC reference updated to 5.2.3 Was still referencing 5.1.0.0 --- src/Orchard.Web/Modules/Orchard.DynamicForms/Web.config | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Web.config b/src/Orchard.Web/Modules/Orchard.DynamicForms/Web.config index 15060b574..7bba20ca5 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Web.config +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Web.config @@ -9,7 +9,7 @@ - + @@ -29,7 +29,7 @@ - + From e021218b3c4489ea60e2adff5c04fdbf83deb5b5 Mon Sep 17 00:00:00 2001 From: Gustavo Tandeciarz Date: Tue, 30 Jun 2015 19:48:05 -0400 Subject: [PATCH 04/17] Updated bindings in azure cloud service web.config Updated bindings for system.web.http and system.net.http.formatting to 5.2.3 --- src/Orchard.Azure/Orchard.Azure.Web/Web.config | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Orchard.Azure/Orchard.Azure.Web/Web.config b/src/Orchard.Azure/Orchard.Azure.Web/Web.config index 1ba2fdcbd..81778984e 100644 --- a/src/Orchard.Azure/Orchard.Azure.Web/Web.config +++ b/src/Orchard.Azure/Orchard.Azure.Web/Web.config @@ -171,11 +171,11 @@ - + - + From eebe29fec3a1470be505dbb83bce34f056335953 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Thu, 2 Jul 2015 13:01:49 +0300 Subject: [PATCH 05/17] #5467: Fixes the issue where the "Set as homepage" setting is not retained when saving, The issue was that when you save a content item (without publishing it) while checking the "Set as homepage" checkbox, it would lose its checked status after save. With this change, the checkbox is again rendered but in a checked status, so that when you do publish, it will become the homepage. Fixes #5467 --- .../Orchard.Autoroute/Drivers/AutoroutePartDriver.cs | 5 ++--- .../ViewModels/AutoroutePartEditViewModel.cs | 1 + .../Views/EditorTemplates/Parts.Autoroute.Edit.cshtml | 10 +++++----- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.Autoroute/Drivers/AutoroutePartDriver.cs b/src/Orchard.Web/Modules/Orchard.Autoroute/Drivers/AutoroutePartDriver.cs index ca4bb47b3..cc31f3cae 100644 --- a/src/Orchard.Web/Modules/Orchard.Autoroute/Drivers/AutoroutePartDriver.cs +++ b/src/Orchard.Web/Modules/Orchard.Autoroute/Drivers/AutoroutePartDriver.cs @@ -67,9 +67,8 @@ namespace Orchard.Autoroute.Drivers { var homepage = _aliasService.Get(string.Empty); var displayRouteValues = _contentManager.GetItemMetadata(part).DisplayRouteValues; - if(homepage.Match(displayRouteValues)) { - viewModel.PromoteToHomePage = true; - } + viewModel.IsHomePage = homepage.Match(displayRouteValues); + viewModel.PromoteToHomePage = viewModel.IsHomePage || part.DisplayAlias == "/"; if (settings.PerItemConfiguration) { // if enabled, the list of all available patterns is displayed, and the user can diff --git a/src/Orchard.Web/Modules/Orchard.Autoroute/ViewModels/AutoroutePartEditViewModel.cs b/src/Orchard.Web/Modules/Orchard.Autoroute/ViewModels/AutoroutePartEditViewModel.cs index 456f70bd4..def63928a 100644 --- a/src/Orchard.Web/Modules/Orchard.Autoroute/ViewModels/AutoroutePartEditViewModel.cs +++ b/src/Orchard.Web/Modules/Orchard.Autoroute/ViewModels/AutoroutePartEditViewModel.cs @@ -4,6 +4,7 @@ namespace Orchard.Autoroute.ViewModels { public class AutoroutePartEditViewModel { public AutorouteSettings Settings { get; set; } + public bool IsHomePage { get; set; } public bool PromoteToHomePage { get; set; } public string CurrentUrl { get; set; } public string CustomPattern { get; set; } diff --git a/src/Orchard.Web/Modules/Orchard.Autoroute/Views/EditorTemplates/Parts.Autoroute.Edit.cshtml b/src/Orchard.Web/Modules/Orchard.Autoroute/Views/EditorTemplates/Parts.Autoroute.Edit.cshtml index e8b8a01ae..1fc939797 100644 --- a/src/Orchard.Web/Modules/Orchard.Autoroute/Views/EditorTemplates/Parts.Autoroute.Edit.cshtml +++ b/src/Orchard.Web/Modules/Orchard.Autoroute/Views/EditorTemplates/Parts.Autoroute.Edit.cshtml @@ -16,7 +16,7 @@ } } -@if (!Model.PromoteToHomePage) { +@if (!Model.IsHomePage) { } } else { - @T("This content is the current home page") + @T("This content is the current home page.") } From 2873eb89913e8ab4ed6814c28303879489a00f27 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Thu, 2 Jul 2015 13:37:20 +0300 Subject: [PATCH 06/17] #5337: Fixed homepage becoming lost after publishing layout template being used by the homepage. Work Item: 5337 --- .../Handlers/LayoutPartHandler.cs | 32 +++++++++++++++++-- .../Orchard.Layouts/Orchard.Layouts.csproj | 8 +++++ 2 files changed, 38 insertions(+), 2 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Handlers/LayoutPartHandler.cs b/src/Orchard.Web/Modules/Orchard.Layouts/Handlers/LayoutPartHandler.cs index 04648fb23..78f9a595b 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Handlers/LayoutPartHandler.cs +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Handlers/LayoutPartHandler.cs @@ -1,9 +1,13 @@ -using Orchard.ContentManagement; +using System; +using Orchard.Alias; +using Orchard.Autoroute.Models; +using Orchard.ContentManagement; using Orchard.ContentManagement.Handlers; using Orchard.Data; using Orchard.DisplayManagement; using Orchard.Layouts.Models; using Orchard.Layouts.Services; +using Orchard.Utility.Extensions; namespace Orchard.Layouts.Handlers { public class LayoutPartHandler : ContentHandler { @@ -13,6 +17,7 @@ namespace Orchard.Layouts.Handlers { private readonly IShapeDisplay _shapeDisplay; private readonly ILayoutSerializer _serializer; private readonly IStaticHttpContextScopeFactory _staticHttpContextScopeFactory; + private readonly IAliasService _aliasService; public LayoutPartHandler( IRepository repository, @@ -21,7 +26,8 @@ namespace Orchard.Layouts.Handlers { IContentPartDisplay contentPartDisplay, IShapeDisplay shapeDisplay, ILayoutSerializer serializer, - IStaticHttpContextScopeFactory staticHttpContextScopeFactory) { + IStaticHttpContextScopeFactory staticHttpContextScopeFactory, + IAliasService aliasService) { _layoutManager = layoutManager; _contentManager = contentManager; @@ -29,6 +35,7 @@ namespace Orchard.Layouts.Handlers { _shapeDisplay = shapeDisplay; _serializer = serializer; _staticHttpContextScopeFactory = staticHttpContextScopeFactory; + _aliasService = aliasService; Filters.Add(StorageFilter.For(repository)); OnPublished(UpdateTemplateClients); @@ -77,6 +84,12 @@ namespace Orchard.Layouts.Handlers { draft.LayoutData = _serializer.Serialize(updatedLayout); if (isPublished) { + // If the content being published is currently the homepage, we need to change the DisplayAlias from "" to "/" + // so that the autoroute part handler will not regenerate the alias and causes the homepage to become "lost". + if (IsHomePage(layout)) { + PromoteToHomePage(draft); + } + // We don't have to recurse here, since invoking Publish on a Layout will cause this handler to execute again. _contentManager.Publish(draft.ContentItem); } @@ -85,5 +98,20 @@ namespace Orchard.Layouts.Handlers { } } } + + private bool IsHomePage(IContent content) { + var homepage = _aliasService.Get(String.Empty); + var displayRouteValues = _contentManager.GetItemMetadata(content).DisplayRouteValues; + return homepage.Match(displayRouteValues); + } + + private void PromoteToHomePage(IContent content) { + var autoroutePart = content.As(); + + if (autoroutePart == null) + return; + + autoroutePart.DisplayAlias = "/"; + } } } \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj b/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj index c89069046..df50eea91 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj @@ -287,6 +287,14 @@ {3158c928-888c-4a84-8bc1-4a8257489538} Markdown + + {475b6c45-b27c-438b-8966-908b9d6d1077} + Orchard.Alias + + + {66fccd76-2761-47e3-8d11-b45d0001ddaa} + Orchard.Autoroute + {642a49d7-8752-4177-80d6-bfbbcfad3de0} Orchard.Forms From b580995e4b9fbbe98a01da4ab75d92560efe8958 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Thu, 2 Jul 2015 15:30:20 +0300 Subject: [PATCH 07/17] Added "TypeName" to element data serialization black list. Having the "TypeName" as part of the element's data field is redundant. --- .../Modules/Orchard.Layouts/Helpers/ElementDataHelper.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Helpers/ElementDataHelper.cs b/src/Orchard.Web/Modules/Orchard.Layouts/Helpers/ElementDataHelper.cs index 326d7845c..5fe9d8c36 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Helpers/ElementDataHelper.cs +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Helpers/ElementDataHelper.cs @@ -12,7 +12,7 @@ using Orchard.Utility; namespace Orchard.Layouts.Helpers { public static class ElementDataHelper { - private static readonly string[] _elementDataBlackList = { "ElementData", "__RequestVerificationToken" }; + private static readonly string[] _elementDataBlackList = { "ElementData", "__RequestVerificationToken", "TypeName" }; public static string Get(this ElementDataDictionary data, string key, string defaultValue = null) { return data != null ? data.ContainsKey(key) ? data[key] : defaultValue : defaultValue; From 3c7fffc3200d55979a83869beb088ac34002cf14 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Thu, 2 Jul 2015 15:34:08 +0300 Subject: [PATCH 08/17] Fixed that default layout data would not be applied. This fixes the issue where the default layout data string would not be applied when creating new content items of a content type with the LayoutPart attached. For example, creating new Form content items would start out with an empty canvas instead of with a default Form element and a submit button. --- .../Modules/Orchard.Layouts/Drivers/LayoutPartDriver.cs | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/LayoutPartDriver.cs b/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/LayoutPartDriver.cs index d58f4c13c..64706a49a 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/LayoutPartDriver.cs +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/LayoutPartDriver.cs @@ -11,6 +11,7 @@ using Orchard.Layouts.Framework.Elements; using Orchard.Layouts.Helpers; using Orchard.Layouts.Models; using Orchard.Layouts.Services; +using Orchard.Layouts.Settings; using Orchard.Layouts.ViewModels; using Orchard.Logging; @@ -89,6 +90,11 @@ namespace Orchard.Layouts.Drivers { protected override DriverResult Editor(LayoutPart part, IUpdateModel updater, dynamic shapeHelper) { return ContentShape("Parts_Layout_Edit", () => { + if (part.Id == 0) { + var settings = part.TypePartDefinition.Settings.GetModel(); + part.LayoutData = settings.DefaultLayoutData; + } + var viewModel = new LayoutPartViewModel { LayoutEditor = _layoutEditorFactory.Create(part) }; From b05dcf9a56308274caaa7ff5086470065d2dc384 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Thu, 2 Jul 2015 15:40:54 +0300 Subject: [PATCH 09/17] Fixed default layout data for Form. --- .../Orchard.DynamicForms/Migrations.cs | 43 ++++++++++--------- 1 file changed, 23 insertions(+), 20 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Migrations.cs b/src/Orchard.Web/Modules/Orchard.DynamicForms/Migrations.cs index 7a061022d..3aa00e1f9 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Migrations.cs +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Migrations.cs @@ -5,6 +5,27 @@ using Orchard.Data.Migration; namespace Orchard.DynamicForms { public class Migrations : DataMigrationImpl { + private const string DefaultFormLayoutData = +@"{ + ""elements"": [ + { + ""typeName"": ""Orchard.Layouts.Elements.Canvas"", + ""elements"": [ + { + ""typeName"": ""Orchard.DynamicForms.Elements.Form"", + ""data"": ""FormName=Untitled&FormAction=&FormMethod=POST&FormBindingContentType=&Publication=Draft&Notification=&RedirectUrl="", + ""elements"": [ + { + ""typeName"": ""Orchard.DynamicForms.Elements.Button"", + ""data"": ""InputName=&FormBindingContentType=&Text=Submit"" + } + ] + } + ] + } + ] +}"; + public int Create() { SchemaBuilder.CreateTable("Submission", table => table .Column("Id", c => c.PrimaryKey().Identity()) @@ -23,16 +44,7 @@ namespace Orchard.DynamicForms { .WithSetting("AutorouteSettings.PatternDefinitions", "[{\"Name\":\"Title\",\"Pattern\":\"{Content.Slug}\",\"Description\":\"my-form\"}]") .WithSetting("AutorouteSettings.DefaultPatternIndex", "0")) .WithPart("LayoutPart", p => p - .WithSetting("LayoutTypePartSettings.DefaultLayoutData", - "{" + - "\"elements\": [{" + - "\"typeName\": \"Orchard.DynamicForms.Elements.Form\"," + - "\"elements\": [{" + - "\"typeName\": \"Orchard.DynamicForms.Elements.Button\"," + - "\"state\": \"ButtonText=Submit\"" + - "}]" + - "}]" + - "}")) + .WithSetting("LayoutTypePartSettings.DefaultLayoutData", DefaultFormLayoutData)) .DisplayedAs("Form") .Listable() .Creatable() @@ -44,16 +56,7 @@ namespace Orchard.DynamicForms { .WithSetting("DateEditorSettings.ShowDateEditor", "false")) .WithPart("WidgetPart") .WithPart("LayoutPart", p => p - .WithSetting("LayoutTypePartSettings.DefaultLayoutData", - "{" + - "\"elements\": [{" + - "\"typeName\": \"Orchard.DynamicForms.Elements.Form\"," + - "\"elements\": [{" + - "\"typeName\": \"Orchard.DynamicForms.Elements.Button\"," + - "\"state\": \"ButtonText=Submit\"" + - "}]" + - "}]" + - "}")) + .WithSetting("LayoutTypePartSettings.DefaultLayoutData", DefaultFormLayoutData)) .WithSetting("Stereotype", "Widget") .DisplayedAs("Form Widget")); return 1; From b18f153e6a3e421947e896a3260eaa9449f7bb62 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Sat, 4 Jul 2015 00:37:14 +0200 Subject: [PATCH 10/17] #5445: Fixed form field binding issues. This fixes two issues: 1. Adding a Form element (and selecting the content type to create using the submitted values) and then adding a form element would not cause the Bindings tab to appear. 2. Adding nested containers (such as Grid, Row and Column) to a Form element would prevent the Bindings tab from appearing when adding a form field element such as TextField to a nested container. Work Item: #5445 --- .../Scripts/LayoutEditor.js | 33 ++++++++++++------- .../Scripts/LayoutEditor.min.js | 2 +- .../LayoutEditor/Directives/Fieldset.js | 7 ++-- .../Scripts/LayoutEditor/Directives/Form.js | 9 ++--- .../Scripts/LayoutEditor/Models/Fieldset.js | 4 +++ .../Scripts/LayoutEditor/Models/Form.js | 10 ++++-- .../Orchard.Layouts/Scripts/LayoutEditor.js | 6 ++-- .../Scripts/LayoutEditor.min.js | 2 +- .../Services/ScopeConfigurator.js | 4 ++- .../Modules/Orchard.Layouts/Scripts/Models.js | 21 ++++++++---- .../Orchard.Layouts/Scripts/Models.min.js | 2 +- .../Scripts/Models/Container.js | 9 +++-- .../Orchard.Layouts/Scripts/Models/Element.js | 10 ++++-- 13 files changed, 80 insertions(+), 39 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js index 59cd5f8c4..13fabe29a 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js @@ -37,6 +37,10 @@ var LayoutEditor; }); }; + this.applyElementEditorModel = function(model) { + this.legend = model.legend; + }; + this.setChildren(children); }; @@ -98,12 +102,11 @@ var LayoutEditor; this.setChildren = function (children) { this.children = children; _(this.children).each(function (child) { - child.parent = self; - self.linkChild(child); + child.setParent(self); }); }; - this.linkChild = function(element) { + this.onDescendantAdded = function(element) { var getEditorObject = element.getEditorObject; element.getEditorObject = function () { var dto = getEditorObject(); @@ -113,6 +116,11 @@ var LayoutEditor; }; }; + this.applyElementEditorModel = function(model) { + this.name = model.name; + this.formBindingContentType = model.formBindingContentType; + }; + this.setChildren(children); }; @@ -151,9 +159,10 @@ angular $scope.$root.editElement($scope.element).then(function (args) { if (args.cancel) return; - $scope.element.data = decodeURIComponent(args.element.data); - $scope.element.legend = args.elementEditorModel.legend; - $scope.$apply(); + $scope.$apply(function() { + $scope.element.data = decodeURIComponent(args.element.data); + $scope.element.applyElementEditorModel(args.elementEditorModel); + }); }); }; } @@ -179,10 +188,11 @@ angular $scope.$root.editElement($scope.element).then(function (args) { if (args.cancel) return; - $scope.element.data = decodeURIComponent(args.element.data); - $scope.element.name = args.elementEditorModel.name; - $scope.element.formBindingContentType = args.elementEditorModel.formBindingContentType; - $scope.$apply(); + + $scope.apply(function() { + $scope.element.data = decodeURIComponent(args.element.data); + $scope.element.applyElementEditorModel(args.elementEditorModel); + }); }); }; } @@ -191,5 +201,4 @@ angular replace: true }; } - ]); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpZWxkc2V0LmpzIiwiRm9ybS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FDN0RBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBRDFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQzNCQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6IkxheW91dEVkaXRvci5qcyIsInNvdXJjZXNDb250ZW50IjpbImFuZ3VsYXJcclxuICAgIC5tb2R1bGUoXCJMYXlvdXRFZGl0b3JcIilcclxuICAgIC5kaXJlY3RpdmUoXCJvcmNMYXlvdXRGaWVsZHNldFwiLCBbXCIkY29tcGlsZVwiLCBcInNjb3BlQ29uZmlndXJhdG9yXCIsIFwiZW52aXJvbm1lbnRcIixcclxuICAgICAgICBmdW5jdGlvbiAoJGNvbXBpbGUsIHNjb3BlQ29uZmlndXJhdG9yLCBlbnZpcm9ubWVudCkge1xyXG4gICAgICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICAgICAgcmVzdHJpY3Q6IFwiRVwiLFxyXG4gICAgICAgICAgICAgICAgc2NvcGU6IHsgZWxlbWVudDogXCI9XCIgfSxcclxuICAgICAgICAgICAgICAgIGNvbnRyb2xsZXI6IFtcIiRzY29wZVwiLCBcIiRlbGVtZW50XCIsXHJcbiAgICAgICAgICAgICAgICAgICAgZnVuY3Rpb24gKCRzY29wZSwgJGVsZW1lbnQpIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgc2NvcGVDb25maWd1cmF0b3IuY29uZmlndXJlRm9yRWxlbWVudCgkc2NvcGUsICRlbGVtZW50KTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgc2NvcGVDb25maWd1cmF0b3IuY29uZmlndXJlRm9yQ29udGFpbmVyKCRzY29wZSwgJGVsZW1lbnQpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAkc2NvcGUuc29ydGFibGVPcHRpb25zW1wiYXhpc1wiXSA9IFwieVwiO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAkc2NvcGUuZWRpdCA9IGZ1bmN0aW9uICgpIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICRzY29wZS4kcm9vdC5lZGl0RWxlbWVudCgkc2NvcGUuZWxlbWVudCkudGhlbihmdW5jdGlvbiAoYXJncykge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmIChhcmdzLmNhbmNlbClcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICRzY29wZS5lbGVtZW50LmRhdGEgPSBkZWNvZGVVUklDb21wb25lbnQoYXJncy5lbGVtZW50LmRhdGEpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICRzY29wZS5lbGVtZW50LmxlZ2VuZCA9IGFyZ3MuZWxlbWVudEVkaXRvck1vZGVsLmxlZ2VuZDtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAkc2NvcGUuJGFwcGx5KCk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgfTtcclxuICAgICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICBdLFxyXG4gICAgICAgICAgICAgICAgdGVtcGxhdGVVcmw6IGVudmlyb25tZW50LnRlbXBsYXRlVXJsKFwiRmllbGRzZXRcIiksXHJcbiAgICAgICAgICAgICAgICByZXBsYWNlOiB0cnVlXHJcbiAgICAgICAgICAgIH07XHJcbiAgICAgICAgfVxyXG4gICAgXSk7IiwiYW5ndWxhclxuICAgIC5tb2R1bGUoXCJMYXlvdXRFZGl0b3JcIilcbiAgICAuZGlyZWN0aXZlKFwib3JjTGF5b3V0Rm9ybVwiLCBbXCIkY29tcGlsZVwiLCBcInNjb3BlQ29uZmlndXJhdG9yXCIsIFwiZW52aXJvbm1lbnRcIixcbiAgICAgICAgZnVuY3Rpb24gKCRjb21waWxlLCBzY29wZUNvbmZpZ3VyYXRvciwgZW52aXJvbm1lbnQpIHtcbiAgICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAgICAgcmVzdHJpY3Q6IFwiRVwiLFxuICAgICAgICAgICAgICAgIHNjb3BlOiB7IGVsZW1lbnQ6IFwiPVwiIH0sXG4gICAgICAgICAgICAgICAgY29udHJvbGxlcjogW1wiJHNjb3BlXCIsIFwiJGVsZW1lbnRcIixcbiAgICAgICAgICAgICAgICAgICAgZnVuY3Rpb24gKCRzY29wZSwgJGVsZW1lbnQpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHNjb3BlQ29uZmlndXJhdG9yLmNvbmZpZ3VyZUZvckVsZW1lbnQoJHNjb3BlLCAkZWxlbWVudCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBzY29wZUNvbmZpZ3VyYXRvci5jb25maWd1cmVGb3JDb250YWluZXIoJHNjb3BlLCAkZWxlbWVudCk7XG4gICAgICAgICAgICAgICAgICAgICAgICAkc2NvcGUuc29ydGFibGVPcHRpb25zW1wiYXhpc1wiXSA9IFwieVwiO1xuICAgICAgICAgICAgICAgICAgICAgICAgJHNjb3BlLmVkaXQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgJHNjb3BlLiRyb290LmVkaXRFbGVtZW50KCRzY29wZS5lbGVtZW50KS50aGVuKGZ1bmN0aW9uIChhcmdzKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmIChhcmdzLmNhbmNlbClcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJHNjb3BlLmVsZW1lbnQuZGF0YSA9IGRlY29kZVVSSUNvbXBvbmVudChhcmdzLmVsZW1lbnQuZGF0YSk7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICRzY29wZS5lbGVtZW50Lm5hbWUgPSBhcmdzLmVsZW1lbnRFZGl0b3JNb2RlbC5uYW1lO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAkc2NvcGUuZWxlbWVudC5mb3JtQmluZGluZ0NvbnRlbnRUeXBlID0gYXJncy5lbGVtZW50RWRpdG9yTW9kZWwuZm9ybUJpbmRpbmdDb250ZW50VHlwZTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJHNjb3BlLiRhcHBseSgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgICAgICAgfTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIF0sXG4gICAgICAgICAgICAgICAgdGVtcGxhdGVVcmw6IGVudmlyb25tZW50LnRlbXBsYXRlVXJsKFwiRm9ybVwiKSxcbiAgICAgICAgICAgICAgICByZXBsYWNlOiB0cnVlXG4gICAgICAgICAgICB9O1xuICAgICAgICB9XG4gICAgXSk7Il0sInNvdXJjZVJvb3QiOiIvc291cmNlLyJ9 \ No newline at end of file + ]); \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js index 3b594800c..2564bccce 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js @@ -1 +1 @@ -var LayoutEditor;!function(e,t){t.Fieldset=function(n,i,o,r,l,a,c,d,s,m,h){t.Element.call(this,"Fieldset",n,i,o,r,l),t.Container.call(this,["Grid","Content"],h);var u=this;this.isContainable=!0,this.dropTargetClass="layout-common-holder",this.contentType=c,this.contentTypeLabel=d,this.contentTypeClass=s,this.legend=a||"",this.hasEditor=m,this.toObject=function(){var e=this.elementToObject();return e.legend=this.legend,e.children=this.childrenToObject(),e};var p=this.getEditorObject;this.getEditorObject=function(){var t=p();return e.extend(t,{Legend:this.legend})},this.setChildren=function(e){this.children=e,_(this.children).each(function(e){e.parent=u})},this.setChildren(h)},t.Fieldset.from=function(e){return new t.Fieldset(e.data,e.htmlId,e.htmlClass,e.htmlStyle,e.isTemplated,e.legend,e.contentType,e.contentTypeLabel,e.contentTypeClass,e.hasEditor,t.childrenFrom(e.children))},t.registerFactory("Fieldset",function(e){return t.Fieldset.from(e)})}(jQuery,LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(e,t){t.Form=function(n,i,o,r,l,a,c,d,s,m,h,u){t.Element.call(this,"Form",n,i,o,r,l),t.Container.call(this,["Grid","Content"],u);var p=this;this.isContainable=!0,this.dropTargetClass="layout-common-holder",this.contentType=d,this.contentTypeLabel=s,this.contentTypeClass=m,this.name=a||"Untitled",this.formBindingContentType=c,this.hasEditor=h,this.toObject=function(){var e=this.elementToObject();return e.name=this.name,e.formBindingContentType=this.formBindingContentType,e.children=this.childrenToObject(),e};var f=this.getEditorObject;this.getEditorObject=function(){var t=f();return e.extend(t,{FormName:this.name,FormBindingContentType:this.formBindingContentType})},this.setChildren=function(e){this.children=e,_(this.children).each(function(e){e.parent=p,p.linkChild(e)})},this.linkChild=function(t){var n=t.getEditorObject;t.getEditorObject=function(){var t=n();return e.extend(t,{FormBindingContentType:p.formBindingContentType})}},this.setChildren(u)},t.Form.from=function(e){return new t.Form(e.data,e.htmlId,e.htmlClass,e.htmlStyle,e.isTemplated,e.name,e.formBindingContentType,e.contentType,e.contentTypeLabel,e.contentTypeClass,e.hasEditor,t.childrenFrom(e.children))},t.registerFactory("Form",function(e){return t.Form.from(e)})}(jQuery,LayoutEditor||(LayoutEditor={})),angular.module("LayoutEditor").directive("orcLayoutFieldset",["$compile","scopeConfigurator","environment",function(e,t,n){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,n){t.configureForElement(e,n),t.configureForContainer(e,n),e.sortableOptions.axis="y",e.edit=function(){e.$root.editElement(e.element).then(function(t){t.cancel||(e.element.data=decodeURIComponent(t.element.data),e.element.legend=t.elementEditorModel.legend,e.$apply())})}}],templateUrl:n.templateUrl("Fieldset"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutForm",["$compile","scopeConfigurator","environment",function(e,t,n){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,n){t.configureForElement(e,n),t.configureForContainer(e,n),e.sortableOptions.axis="y",e.edit=function(){e.$root.editElement(e.element).then(function(t){t.cancel||(e.element.data=decodeURIComponent(t.element.data),e.element.name=t.elementEditorModel.name,e.element.formBindingContentType=t.elementEditorModel.formBindingContentType,e.$apply())})}}],templateUrl:n.templateUrl("Form"),replace:!0}}]); \ No newline at end of file +var LayoutEditor;!function(e,t){t.Fieldset=function(n,i,o,r,l,d,a,c,s,h,m){t.Element.call(this,"Fieldset",n,i,o,r,l),t.Container.call(this,["Grid","Content"],m);var u=this;this.isContainable=!0,this.dropTargetClass="layout-common-holder",this.contentType=a,this.contentTypeLabel=c,this.contentTypeClass=s,this.legend=d||"",this.hasEditor=h,this.toObject=function(){var e=this.elementToObject();return e.legend=this.legend,e.children=this.childrenToObject(),e};var p=this.getEditorObject;this.getEditorObject=function(){var t=p();return e.extend(t,{Legend:this.legend})},this.setChildren=function(e){this.children=e,_(this.children).each(function(e){e.parent=u})},this.applyElementEditorModel=function(e){this.legend=e.legend},this.setChildren(m)},t.Fieldset.from=function(e){return new t.Fieldset(e.data,e.htmlId,e.htmlClass,e.htmlStyle,e.isTemplated,e.legend,e.contentType,e.contentTypeLabel,e.contentTypeClass,e.hasEditor,t.childrenFrom(e.children))},t.registerFactory("Fieldset",function(e){return t.Fieldset.from(e)})}(jQuery,LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(e,t){t.Form=function(n,i,o,r,l,d,a,c,s,h,m,u){t.Element.call(this,"Form",n,i,o,r,l),t.Container.call(this,["Grid","Content"],u);var p=this;this.isContainable=!0,this.dropTargetClass="layout-common-holder",this.contentType=c,this.contentTypeLabel=s,this.contentTypeClass=h,this.name=d||"Untitled",this.formBindingContentType=a,this.hasEditor=m,this.toObject=function(){var e=this.elementToObject();return e.name=this.name,e.formBindingContentType=this.formBindingContentType,e.children=this.childrenToObject(),e};var f=this.getEditorObject;this.getEditorObject=function(){var t=f();return e.extend(t,{FormName:this.name,FormBindingContentType:this.formBindingContentType})},this.setChildren=function(e){this.children=e,_(this.children).each(function(e){e.setParent(p)})},this.onDescendantAdded=function(t){var n=t.getEditorObject;t.getEditorObject=function(){var t=n();return e.extend(t,{FormBindingContentType:p.formBindingContentType})}},this.applyElementEditorModel=function(e){this.name=e.name,this.formBindingContentType=e.formBindingContentType},this.setChildren(u)},t.Form.from=function(e){return new t.Form(e.data,e.htmlId,e.htmlClass,e.htmlStyle,e.isTemplated,e.name,e.formBindingContentType,e.contentType,e.contentTypeLabel,e.contentTypeClass,e.hasEditor,t.childrenFrom(e.children))},t.registerFactory("Form",function(e){return t.Form.from(e)})}(jQuery,LayoutEditor||(LayoutEditor={})),angular.module("LayoutEditor").directive("orcLayoutFieldset",["$compile","scopeConfigurator","environment",function(e,t,n){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,n){t.configureForElement(e,n),t.configureForContainer(e,n),e.sortableOptions.axis="y",e.edit=function(){e.$root.editElement(e.element).then(function(t){t.cancel||e.$apply(function(){e.element.data=decodeURIComponent(t.element.data),e.element.applyElementEditorModel(t.elementEditorModel)})})}}],templateUrl:n.templateUrl("Fieldset"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutForm",["$compile","scopeConfigurator","environment",function(e,t,n){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,n){t.configureForElement(e,n),t.configureForContainer(e,n),e.sortableOptions.axis="y",e.edit=function(){e.$root.editElement(e.element).then(function(t){t.cancel||e.apply(function(){e.element.data=decodeURIComponent(t.element.data),e.element.applyElementEditorModel(t.elementEditorModel)})})}}],templateUrl:n.templateUrl("Form"),replace:!0}}]); \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Fieldset.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Fieldset.js index 7e45c0208..8139fb2f7 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Fieldset.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Fieldset.js @@ -14,9 +14,10 @@ $scope.$root.editElement($scope.element).then(function (args) { if (args.cancel) return; - $scope.element.data = decodeURIComponent(args.element.data); - $scope.element.legend = args.elementEditorModel.legend; - $scope.$apply(); + $scope.$apply(function() { + $scope.element.data = decodeURIComponent(args.element.data); + $scope.element.applyElementEditorModel(args.elementEditorModel); + }); }); }; } diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Form.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Form.js index 3e4ad89f9..c8bee01ce 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Form.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Form.js @@ -14,10 +14,11 @@ $scope.$root.editElement($scope.element).then(function (args) { if (args.cancel) return; - $scope.element.data = decodeURIComponent(args.element.data); - $scope.element.name = args.elementEditorModel.name; - $scope.element.formBindingContentType = args.elementEditorModel.formBindingContentType; - $scope.$apply(); + + $scope.apply(function() { + $scope.element.data = decodeURIComponent(args.element.data); + $scope.element.applyElementEditorModel(args.elementEditorModel); + }); }); }; } diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Models/Fieldset.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Models/Fieldset.js index abe9e83f1..8d4776f45 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Models/Fieldset.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Models/Fieldset.js @@ -37,6 +37,10 @@ }); }; + this.applyElementEditorModel = function(model) { + this.legend = model.legend; + }; + this.setChildren(children); }; diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Models/Form.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Models/Form.js index 999dcf900..36737ee48 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Models/Form.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Models/Form.js @@ -36,12 +36,11 @@ this.setChildren = function (children) { this.children = children; _(this.children).each(function (child) { - child.parent = self; - self.linkChild(child); + child.setParent(self); }); }; - this.linkChild = function(element) { + this.onDescendantAdded = function(element) { var getEditorObject = element.getEditorObject; element.getEditorObject = function () { var dto = getEditorObject(); @@ -51,6 +50,11 @@ }; }; + this.applyElementEditorModel = function(model) { + this.name = model.name; + this.formBindingContentType = model.formBindingContentType; + }; + this.setChildren(children); }; diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.js index 2aba5de27..577152cb4 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.js @@ -283,12 +283,14 @@ angular // Because of this, we need to invoke "setParent" so that specific container types can perform element speficic initialization. receivedElement.setEditor(element.editor); receivedElement.setParent(element); + if (!!receivedElement.hasEditor) { $scope.$root.editElement(receivedElement).then(function (args) { if (!args.cancel) { receivedElement.data = args.element.data; + receivedElement.applyElementEditorModel(args.elementEditorModel); - if (receivedElement.setHtml) + if (!!receivedElement.setHtml) receivedElement.setHtml(args.element.html); } $timeout(function () { @@ -1036,4 +1038,4 @@ angular }; } ]); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Module.js","Clipboard.js","ScopeConfigurator.js","Editor.js","Canvas.js","Child.js","Column.js","Content.js","Html.js","Grid.js","Row.js","Popup.js","Toolbox.js","ToolboxGroup.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/TA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC3LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"LayoutEditor.js","sourcesContent":["angular.module(\"LayoutEditor\", [\"ngSanitize\", \"ngResource\", \"ui.sortable\"]);","var LayoutEditor;\n(function(LayoutEditor) {\n\n    var Clipboard = function () {\n        var self = this;\n        this._clipboardData = {};\n        this._isDisabled = false;\n        this._wasInvoked = false;\n\n        this.setData = function(contentType, data) {\n            self._clipboardData[contentType] = data;\n            self._wasInvoked = true;\n        };\n        this.getData = function (contentType) {\n            return self._clipboardData[contentType];\n            self._wasInvoked = true;\n        };\n        this.disable = function() {\n            self._isDisabled = true;\n            self._wasInvoked = false;\n            self._clipboardData = {};\n        };\n        this.isDisabled = function () {\r\n            return self._isDisabled;\r\n        }\n        this.wasInvoked = function () {\r\n            return self._wasInvoked;\r\n        }\n    }\n\n    LayoutEditor.Clipboard = new Clipboard();\n\n    angular\n        .module(\"LayoutEditor\")\n        .factory(\"clipboard\", [\n            function() {\n                return {\n                    setData: LayoutEditor.Clipboard.setData,\n                    getData: LayoutEditor.Clipboard.getData,\n                    disable: LayoutEditor.Clipboard.disable,\n                    isDisabled: LayoutEditor.Clipboard.isDisabled,\n                    wasInvoked: LayoutEditor.Clipboard.wasInvoked\n                };\n            }\n        ]);\n})(LayoutEditor || (LayoutEditor = {}));","angular\n    .module(\"LayoutEditor\")\n    .factory(\"scopeConfigurator\", [\"$timeout\", \"clipboard\",\n        function ($timeout, clipboard) {\n            return {\n\n                configureForElement: function ($scope, $element) {\n                \n                    $element.find(\".layout-panel\").click(function (e) {\n                        e.stopPropagation();\n                    });\n\n                    $element.parent().keydown(function (e) {\n                        var handled = false;\n                        var resetFocus = false;\n                        var element = $scope.element;\n                    \n                        if (element.editor.isDragging || element.editor.inlineEditingIsActive)\n                            return;\n\n                        // If native clipboard support exists, the pseudo-clipboard will have been disabled.\n                        if (!clipboard.isDisabled()) {\n                            var focusedElement = element.editor.focusedElement;\n                            if (!!focusedElement) {\n                                // Pseudo clipboard handling for browsers not allowing real clipboard operations.\n                                if (e.ctrlKey) {\n                                    switch (e.which) {\n                                    case 67: // C\n                                        focusedElement.copy(clipboard);\n                                        break;\n                                    case 88: // X\n                                        focusedElement.cut(clipboard);\n                                        break;\n                                    case 86: // V\n                                        focusedElement.paste(clipboard);\n                                        break;\n                                    }\n                                }\n                            }\n                        }\n\n                        if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 46) { // Del\n                            $scope.delete(element);\n                            handled = true;\n                        } else if (!e.ctrlKey && !e.shiftKey && !e.altKey && (e.which == 32 || e.which == 27)) { // Space or Esc\n                            $element.find(\".layout-panel-action-properties\").first().click();\n                            handled = true;\n                        }\n\n                        if (element.type == \"Content\") { // This is a content element.\n                            if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 13) { // Enter\n                                $element.find(\".layout-panel-action-edit\").first().click();\n                                handled = true;\n                            }\n                        }\n\n                        if (!!element.children) { // This is a container.\n                            if (!e.ctrlKey && !e.shiftKey && e.altKey && e.which == 40) { // Alt+Down\n                                if (element.children.length > 0)\n                                    element.children[0].setIsFocused();\n                                handled = true;\n                            }\n\n                            if (element.type == \"Column\") { // This is a column.\n                                var connectAdjacent = !e.ctrlKey;\n                                if (e.which == 37) { // Left\n                                    if (e.altKey)\n                                        element.expandLeft(connectAdjacent);\n                                    if (e.shiftKey)\n                                        element.contractRight(connectAdjacent);\n                                    handled = true;\n                                } else if (e.which == 39) { // Right\n                                    if (e.altKey)\n                                        element.contractLeft(connectAdjacent);\n                                    if (e.shiftKey)\n                                        element.expandRight(connectAdjacent);\n                                    handled = true;\n                                }\n                            }\n                        }\n\n                        if (!!element.parent) { // This is a child.\n                            if (e.altKey && e.which == 38) { // Alt+Up\n                                element.parent.setIsFocused();\n                                handled = true;\n                            }\n\n                            if (element.parent.type == \"Row\") { // Parent is a horizontal container.\n                                if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 37) { // Left\n                                    element.parent.moveFocusPrevChild(element);\n                                    handled = true;\n                                }\n                                else if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 39) { // Right\n                                    element.parent.moveFocusNextChild(element);\n                                    handled = true;\n                                }\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 37) { // Ctrl+Left\n                                    element.moveUp();\n                                    resetFocus = true;\n                                    handled = true;\n                                }\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 39) { // Ctrl+Right\n                                    element.moveDown();\n                                    handled = true;\n                                }\n                            }\n                            else { // Parent is a vertical container.\n                                if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 38) { // Up\n                                    element.parent.moveFocusPrevChild(element);\n                                    handled = true;\n                                }\n                                else if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 40) { // Down\n                                    element.parent.moveFocusNextChild(element);\n                                    handled = true;\n                                }\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 38) { // Ctrl+Up\n                                    element.moveUp();\n                                    resetFocus = true;\n                                    handled = true;\n                                }\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 40) { // Ctrl+Down\n                                    element.moveDown();\n                                    handled = true;\n                                }\n                            }\n                        }\n\n                        if (handled) {\n                            e.preventDefault();\n                        }\n\n                        e.stopPropagation();\n\n                        $scope.$apply(); // Event is not triggered by Angular directive but raw event handler on element.\n\n                        // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost.\n                        if (resetFocus) {\n                            window.setTimeout(function () {\n                                $scope.$apply(function () {\n                                    element.editor.focusedElement.setIsFocused();\n                                });\n                            }, 100);\n                        }\n                    });\n\n                    $scope.element.setIsFocusedEventHandlers.push(function () {\n                        $element.parent().focus();\n                    });\n\n                    $scope.delete = function (element) {\n                        element.delete();\n                    }\n                },\n\n                configureForContainer: function ($scope, $element) {\n                    var element = $scope.element;\n\n                    //$scope.isReceiving = false; // True when container is receiving an external element via drag/drop.\n                    $scope.getShowChildrenPlaceholder = function () {\n                        return $scope.element.children.length === 0 && !$scope.element.getIsDropTarget();\n                    };\n\n                    $scope.sortableOptions = {\n                        cursor: \"move\",\n                        delay: 150,\n                        disabled: element.getIsSealed(),\n                        distance: 5,\n                        //handle: element.children.length < 2 ? \".imaginary-class\" : false, // For some reason doesn't get re-evaluated after adding more children.\n                        start: function (e, ui) {\n                            $scope.$apply(function () {\n                                element.setIsDropTarget(true);\n                                element.editor.isDragging = true;\n                            });\n                            // Make the drop target placeholder as high as the item being dragged.\n                            ui.placeholder.height(ui.item.height() - 4);\n                            ui.placeholder.css(\"min-height\", 0);\n                        },\n                        stop: function (e, ui) {\n                            $scope.$apply(function () {\n                                element.editor.isDragging = false;\n                                element.setIsDropTarget(false);\n                            });\n                        },\n                        over: function (e, ui) {\n                            if (!!ui.sender && !!ui.sender[0].isToolbox) {\n                                if (!!ui.sender[0].dropTargetTimeout) {\n                                    $timeout.cancel(ui.sender[0].dropTargetTimeout);\n                                    ui.sender[0].dropTargetTimeout = null;\n                                }\n                                $timeout(function () {\n                                    if (element.type == \"Row\") {\n                                        // If there was a previous drop target and it was a row, roll back any pending column adds to it.\n                                        var previousDropTarget = element.editor.dropTargetElement;\n                                        if (!!previousDropTarget && previousDropTarget.type == \"Row\")\n                                            previousDropTarget.rollbackAddColumn();\n                                    }\n                                    element.setIsDropTarget(false);\n                                });\n                                ui.sender[0].dropTargetTimeout = $timeout(function () {\n                                    if (element.type == \"Row\") {\n                                        var receivedColumn = ui.item.sortable.model;\n                                        var receivedColumnWidth = Math.floor(12 / (element.children.length + 1));\n                                        receivedColumn.width = receivedColumnWidth;\n                                        receivedColumn.offset = 0;\n                                        element.beginAddColumn(receivedColumnWidth);\n                                        // Make the drop target placeholder the correct width and as high as the highest existing column in the row.\n                                        var maxHeight = _.max(_($element.find(\"> .layout-children > .layout-column:not(.ui-sortable-placeholder)\")).map(function (e) {\n                                            return $(e).height();\n                                        }));\n                                        for (i = 1; i <= 12; i++)\n                                            ui.placeholder.removeClass(\"col-xs-\" + i);\n                                        ui.placeholder.addClass(\"col-xs-\" + receivedColumn.width);\n                                        if (maxHeight > 0) {\n                                            ui.placeholder.height(maxHeight);\n                                            ui.placeholder.css(\"min-height\", 0);\n                                        }\n                                        else {\n                                            ui.placeholder.height(0);\n                                            ui.placeholder.css(\"min-height\", \"\");\n                                        }\n                                    }\n                                    element.setIsDropTarget(true);\n                                }, 150);\n                            }\n                        },\n                        receive: function (e, ui) {\n                            if (!!ui.sender && !!ui.sender[0].isToolbox) {\n                                $scope.$apply(function () {\n                                    var receivedElement = ui.item.sortable.model;\n                                    if (!!receivedElement) {\n                                        if (element.type == \"Row\")\n                                            element.commitAddColumn();\n                                        // Should ideally call LayoutEditor.Container.addChild() instead, but since this handler\n                                        // is run *before* the ui-sortable directive's handler, if we try to add the child to the\n                                        // array that handler will get an exception when trying to do the same.\n                                        // Because of this, we need to invoke \"setParent\" so that specific container types can perform element speficic initialization.\n                                        receivedElement.setEditor(element.editor);\n                                        receivedElement.setParent(element);\n                                        if (!!receivedElement.hasEditor) {\n                                            $scope.$root.editElement(receivedElement).then(function (args) {\n                                                if (!args.cancel) {\n                                                    receivedElement.data = args.element.data;\n\n                                                    if (receivedElement.setHtml)\n                                                        receivedElement.setHtml(args.element.html);\n                                                }\n                                                $timeout(function () {\n                                                    if (!!args.cancel)\n                                                        receivedElement.delete();\n                                                    else\n                                                        receivedElement.setIsFocused();\n                                                    //$scope.isReceiving = false;\n                                                    element.setIsDropTarget(false);\n\n                                                });\n                                                return;\n                                            });\n                                        }\n                                    }\n                                    $timeout(function () {\n                                        //$scope.isReceiving = false;\n                                        element.setIsDropTarget(false);\n                                        if (!!receivedElement)\n                                            receivedElement.setIsFocused();\n                                    });\n                                });\n                            }\n                        }\n                    };\n\n                    $scope.click = function (child, e) {\n                        if (!child.editor.isDragging)\n                            child.setIsFocused();\n                        e.stopPropagation();\n                    };\n\n                    $scope.getClasses = function (child) {\n                        var result = [\"layout-element\"];\n\n                        if (!!child.children) {\n                            result.push(\"layout-container\");\n                            if (child.getIsSealed())\n                                result.push(\"layout-container-sealed\");\n                        }\n\n                        result.push(\"layout-\" + child.type.toLowerCase());\n\n                        if (!!child.dropTargetClass)\n                            result.push(child.dropTargetClass);\n\n                        // TODO: Move these to either the Column directive or the Column model class.\n                        if (child.type == \"Row\") {\n                            result.push(\"row\");\n                            if (!child.canAddColumn())\n                                result.push(\"layout-row-full\");\n                        }\n                        if (child.type == \"Column\") {\n                            result.push(\"col-xs-\" + child.width);\n                            result.push(\"col-xs-offset-\" + child.offset);\n                        }\n                        if (child.type == \"Content\")\n                            result.push(\"layout-content-\" + child.contentTypeClass);\n\n                        if (child.getIsActive())\n                            result.push(\"layout-element-active\");\n                        if (child.getIsFocused())\n                            result.push(\"layout-element-focused\");\n                        if (child.getIsSelected())\n                            result.push(\"layout-element-selected\");\n                        if (child.getIsDropTarget())\n                            result.push(\"layout-element-droptarget\");\n                        if (child.isTemplated)\n                            result.push(\"layout-element-templated\");\n\n                        return result;\n                    };\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutEditor\", [\"environment\",\n        function (environment) {\n            return {\n                restrict: \"E\",\n                scope: {},\n                controller: [\"$scope\", \"$element\", \"$attrs\", \"$compile\", \"clipboard\",\n                    function ($scope, $element, $attrs, $compile, clipboard) {\n                        if (!!$attrs.model)\n                            $scope.element = eval($attrs.model);\n                        else\n                            throw new Error(\"The 'model' attribute must evaluate to a LayoutEditor.Editor object.\");\n\n                        $scope.click = function (canvas, e) {\n                            if (!canvas.editor.isDragging)\n                                canvas.setIsFocused();\n                            e.stopPropagation();\n                        };\n\n                        $scope.getClasses = function (canvas) {\n                            var result = [\"layout-element\", \"layout-container\", \"layout-canvas\"];\n\n                            if (canvas.getIsActive())\n                                result.push(\"layout-element-active\");\n                            if (canvas.getIsFocused())\n                                result.push(\"layout-element-focused\");\n                            if (canvas.getIsSelected())\n                                result.push(\"layout-element-selected\");\n                            if (canvas.getIsDropTarget())\n                                result.push(\"layout-element-droptarget\");\n                            if (canvas.isTemplated)\n                                result.push(\"layout-element-templated\");\n\n                            return result;\n                        };\n\n                        // An unfortunate side-effect of the next hack on line 54 is that the created elements aren't added to the DOM yet, so we can't use it to get to the parent \".layout-desiger\" element.\n                        // Work around: access that element directly (which efectively turns multiple layout editors on a single page impossible). \n                        // //var layoutDesignerHost = $element.closest(\".layout-designer\").data(\"layout-designer-host\");\n                        var layoutDesignerHost = $(\".layout-designer\").data(\"layout-designer-host\");\n\n                        $scope.$root.layoutDesignerHost = layoutDesignerHost;\n\n                        layoutDesignerHost.element.on(\"replacecanvas\", function (e, args) {\n                            var editor = $scope.element;\n                            var canvasData = {\n                                data: args.canvas.data,\n                                htmlId: args.canvas.htmlId,\n                                htmlClass: args.canvas.htmlClass,\n                                htmlStyle: args.canvas.htmlStyle,\n                                isTemplated: args.canvas.isTemplated,\n                                children: args.canvas.children\n                            };\n\n                            // HACK: Instead of simply updating the $scope.element with a new instance, we need to replace the entire orc-layout-editor markup\n                            // in order for angular to rebind starting with the Canvas element. Otherwise, for some reason, it will rebind starting with the first child of Canvas.\n                            // You can see this happening when setting a breakpoint in ScopeConfigurator where containers are initialized with drag & drop: on page load, the first element\n                            // is a Canvas (good), but after having selected another template, the first element is (typically) a Grid (bad).\n                            // Simply recompiling the orc-layout-editor directive will cause the entire thing to be generated, which works just fine as well (even though not is nice as simply leveraging model binding).\n                            layoutDesignerHost.editor = window.layoutEditor = new LayoutEditor.Editor(editor.config, canvasData);\n                            var template = \"<orc-layout-editor\" + \" model='window.layoutEditor' />\";\n                            var html = $compile(template)($scope);\n                            $(\".layout-editor-holder\").html(html);\n                        });\n\n                        $scope.$root.editElement = function (element) {\n                            var host = $scope.$root.layoutDesignerHost;\n                            return host.editElement(element);\n                        };\n\n                        $scope.$root.addElement = function (contentType) {\n                            var host = $scope.$root.layoutDesignerHost;\n                            return host.addElement(contentType);\n                        };\n\n                        $scope.toggleInlineEditing = function () {\n                            if (!$scope.element.inlineEditingIsActive) {\n                                $scope.element.inlineEditingIsActive = true;\n                                $element.find(\".layout-toolbar-container\").show();\n                                var selector = \"#layout-editor-\" + $scope.$id + \" .layout-html .layout-content-markup[data-templated=false]\";\n                                var firstContentEditorId = $(selector).first().attr(\"id\");\n                                tinymce.init({\n                                    selector: selector,\n                                    theme: \"modern\",\n                                    schema: \"html5\",\n                                    plugins: [\n                                        \"advlist autolink lists link image charmap print preview hr anchor pagebreak\",\n                                        \"searchreplace wordcount visualblocks visualchars code fullscreen\",\n                                        \"insertdatetime media nonbreaking table contextmenu directionality\",\n                                        \"emoticons template paste textcolor colorpicker textpattern\",\n                                        \"fullscreen autoresize\"\n                                    ],\n                                    toolbar: \"undo redo cut copy paste | bold italic | bullist numlist outdent indent formatselect | alignleft aligncenter alignright alignjustify ltr rtl | link unlink charmap | code fullscreen close\",\n                                    convert_urls: false,\n                                    valid_elements: \"*[*]\",\n                                    // Shouldn't be needed due to the valid_elements setting, but TinyMCE would strip script.src without it.\n                                    extended_valid_elements: \"script[type|defer|src|language]\",\n                                    statusbar: false,\n                                    skin: \"orchardlightgray\",\n                                    inline: true,\n                                    fixed_toolbar_container: \"#layout-editor-\" + $scope.$id + \" .layout-toolbar-container\",\n                                    init_instance_callback: function (editor) {\n                                        if (editor.id == firstContentEditorId)\n                                            tinymce.execCommand(\"mceFocus\", false, editor.id);\n                                    }\n                                });\n                            }\n                            else {\n                                tinymce.remove(\"#layout-editor-\" + $scope.$id + \" .layout-content-markup\");\n                                $element.find(\".layout-toolbar-container\").hide();\n                                $scope.element.inlineEditingIsActive = false;\n                            }\n                        };\n\n                        $(document).on(\"cut copy paste\", function (e) {\n                            // If the pseudo clipboard was already invoked (which happens on the first clipboard\n                            // operation after page load even if native clipboard support exists) then sit this\n                            // one operation out, but make sure whatever is on the pseudo clipboard gets migrated\n                            // to the native clipboard for subsequent operations.\n                            if (clipboard.wasInvoked()) {\r\n                                e.originalEvent.clipboardData.setData(\"text/plain\", clipboard.getData(\"text/plain\"));\r\n                                e.originalEvent.clipboardData.setData(\"text/json\", clipboard.getData(\"text/json\"));\r\n                                e.preventDefault();\r\n                            }\r\n                            else {\r\n                                var focusedElement = $scope.element.focusedElement;\n                                if (!!focusedElement) {\r\n                                    $scope.$apply(function () {\r\n                                        switch (e.type) {\r\n                                            case \"copy\":\n                                                focusedElement.copy(e.originalEvent.clipboardData);\n                                                break;\n                                            case \"cut\":\n                                                focusedElement.cut(e.originalEvent.clipboardData);\n                                                break;\n                                            case \"paste\":\n                                                focusedElement.paste(e.originalEvent.clipboardData);\n                                                break;\r\n                                        }\r\n                                    });\n\n                                    // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost.\n                                    window.setTimeout(function () {\r\n                                        $scope.$apply(function () {\r\n                                            if (!!$scope.element.focusedElement)\n                                                $scope.element.focusedElement.setIsFocused();\r\n                                        });\r\n                                    }, 100);\n\n                                    e.preventDefault();\r\n                                }\r\n                            }\n\n                            // Native clipboard support obviously exists, so disable the peudo clipboard from now on.\n                            clipboard.disable();\r\n                        });\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Editor\"),\n                replace: true,\n                link: function (scope, element) {\n                    // No clicks should propagate from the TinyMCE toolbars.\n                    element.find(\".layout-toolbar-container\").click(function (e) {\n                        e.stopPropagation();\n                    });\n                    // Intercept mousedown on editor while in inline editing mode to \n                    // prevent current editor from losing focus.\n                    element.mousedown(function (e) {\n                        if (scope.element.inlineEditingIsActive) {\n                            e.preventDefault();\n                            e.stopPropagation();\n                        }\n                    })\n                    // Unfocus and unselect everything on click outside of canvas.\n                    $(window).click(function (e) {\n                        // Except when in inline editing mode.\n                        if (!scope.element.inlineEditingIsActive) {\n                            scope.$apply(function () {\n                                scope.element.activeElement = null;\n                                scope.element.focusedElement = null;\n                            });\n                        }\n                    });\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutCanvas\", [\"scopeConfigurator\", \"environment\",\n        function (scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\", \"$attrs\",\n                    function ($scope, $element, $attrs) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Canvas\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutChild\", [\"$compile\",\n        function ($compile) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                link: function (scope, element) {\n                    var template = \"<orc-layout-\" + scope.element.type.toLowerCase() + \" element='element' />\";\n                    var html = $compile(template)(scope);\n                    $(element).replaceWith(html);\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutColumn\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Column\"),\n                replace: true,\n                link: function (scope, element, attrs) {\n                    element.find(\".layout-column-resize-bar\").draggable({\n                        axis: \"x\",\n                        helper: \"clone\",\n                        revert: true,\n                        start: function (e, ui) {\n                            scope.$apply(function () {\n                                scope.element.editor.isResizing = true;\n                            });\n                        },\n                        drag: function (e, ui) {\n                            var columnElement = element.parent();\n                            var columnSize = columnElement.width() / scope.element.width;\n                            var connectAdjacent = !e.ctrlKey;\n                            if ($(e.target).hasClass(\"layout-column-resize-bar-left\")) {\n                                var delta = ui.offset.left - columnElement.offset().left;\n                                if (delta < -columnSize && scope.element.canExpandLeft(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.expandLeft(connectAdjacent);\n                                    });\n                                }\n                                else if (delta > columnSize && scope.element.canContractLeft(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.contractLeft(connectAdjacent);\n                                    });\n                                }\n                            }\n                            else if ($(e.target).hasClass(\"layout-column-resize-bar-right\")) {\n                                var delta = ui.offset.left - columnElement.width() - columnElement.offset().left;\n                                if (delta > columnSize && scope.element.canExpandRight(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.expandRight(connectAdjacent);\n                                    });\n                                }\n                                else if (delta < -columnSize && scope.element.canContractRight(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.contractRight(connectAdjacent);\n                                    });\n                                }\n                            }\n\n                        },\n                        stop: function (e, ui) {\n                            scope.$apply(function () {\n                              scope.element.editor.isResizing = false;\n                            });\n                        }\n                    });\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutContent\", [\"$sce\", \"scopeConfigurator\", \"environment\",\n        function ($sce, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        $scope.edit = function () {\n                            $scope.$root.editElement($scope.element).then(function (args) {\n                                $scope.$apply(function () {\n                                    if (args.cancel)\n                                        return;\n\n                                    $scope.element.data = args.element.data;\n                                    $scope.element.setHtml(args.element.html);\n                                });\n                            });\n                        };\n\n                        // Overwrite the setHtml function so that we can use the $sce service to trust the html (and not have the html binding strip certain tags).\n                        $scope.element.setHtml = function (html) {\n                            $scope.element.html = html;\n                            $scope.element.htmlUnsafe = $sce.trustAsHtml(html);\n                        };\n\n                        $scope.element.setHtml($scope.element.html);\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Content\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutHtml\", [\"$sce\", \"scopeConfigurator\", \"environment\",\n        function ($sce, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        $scope.edit = function () {\n                            $scope.$root.editElement($scope.element).then(function (args) {\n                                $scope.$apply(function () {\n                                    if (args.cancel)\n                                        return;\n\n                                    $scope.element.data = args.element.data;\n                                    $scope.element.setHtml(args.element.html);\n                                });\n                            });\n                        };\n                        $scope.updateContent = function (e) {\n                            $scope.element.setHtml(e.target.innerHTML);\n                        };\n\n                        // Overwrite the setHtml function so that we can use the $sce service to trust the html (and not have the html binding strip certain tags).\n                        $scope.element.setHtml = function (html) {\n                            $scope.element.html = html;\n                            $scope.element.htmlUnsafe = $sce.trustAsHtml(html);\n                        };\n\n                        $scope.element.setHtml($scope.element.html);\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Html\"),\n                replace: true,\n                link: function (scope, element) {\n                    // Mouse down events must not be intercepted by drag and drop while inline editing is active,\n                    // otherwise clicks in inline editors will have no effect.\n                    element.find(\".layout-content-markup\").mousedown(function (e) {\n                        if (scope.element.editor.inlineEditingIsActive) {\n                            e.stopPropagation();\n                        }\n                    });\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutGrid\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Grid\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutRow\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"x\";\n                        $scope.sortableOptions[\"ui-floating\"] = true;\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Row\"),\n                replace: true\n            };\n        }\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutPopup\", [\r\n        function () {\r\n            return {\r\n                restrict: \"A\",\r\n                link: function (scope, element, attrs) {\r\n                    var popup = $(element);\r\n                    var trigger = popup.closest(\".layout-popup-trigger\");\r\n                    var parentElement = popup.closest(\".layout-element\");\r\n                    trigger.click(function () {\r\n                        popup.toggle();\r\n                        if (popup.is(\":visible\")) {\r\n                            popup.position({\r\n                                my: attrs.orcLayoutPopupMy || \"left top\",\r\n                                at: attrs.orcLayoutPopupAt || \"left bottom+4px\",\r\n                                of: trigger\r\n                            });\r\n                            popup.find(\"input\").first().focus();\r\n                        }\r\n                    });\r\n                    popup.click(function (e) {\r\n                        e.stopPropagation();\r\n                    });\r\n                    parentElement.click(function (e) {\r\n                        popup.hide();\r\n                    });\r\n                    popup.keydown(function (e) {\r\n                        if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 27) // Esc\r\n                            popup.hide();\r\n                        e.stopPropagation();\r\n                    });\r\n                    popup.on(\"cut copy paste\", function (e) {\n                        // Allow clipboard operations in popup without invoking clipboard event handlers on parent element.\n                        e.stopPropagation();\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutToolbox\", [\"$compile\", \"environment\",\r\n        function ($compile, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n\r\n                        $scope.resetElements = function () {\r\n\r\n                            $scope.gridElements = [\r\n                                LayoutEditor.Grid.from({\r\n                                    toolboxIcon: \"\\uf00a\",\r\n                                    toolboxLabel: \"Grid\",\r\n                                    toolboxDescription: \"Empty grid.\",\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.rowElements = [\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (1 column)\",\r\n                                    toolboxDescription: \"Row with 1 column.\",\r\n                                    children: LayoutEditor.Column.times(1)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (2 columns)\",\r\n                                    toolboxDescription: \"Row with 2 columns.\",\r\n                                    children: LayoutEditor.Column.times(2)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (3 columns)\",\r\n                                    toolboxDescription: \"Row with 3 columns.\",\r\n                                    children: LayoutEditor.Column.times(3)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (4 columns)\",\r\n                                    toolboxDescription: \"Row with 4 columns.\",\r\n                                    children: LayoutEditor.Column.times(4)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (6 columns)\",\r\n                                    toolboxDescription: \"Row with 6 columns.\",\r\n                                    children: LayoutEditor.Column.times(6)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (12 columns)\",\r\n                                    toolboxDescription: \"Row with 12 columns.\",\r\n                                    children: LayoutEditor.Column.times(12)\r\n                                }), LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (empty)\",\r\n                                    toolboxDescription: \"Empty row.\",\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.columnElements = [\r\n                                LayoutEditor.Column.from({\r\n                                    toolboxIcon: \"\\uf0db\",\r\n                                    toolboxLabel: \"Column\",\r\n                                    toolboxDescription: \"Empty column.\",\r\n                                    width: 1,\r\n                                    offset: 0,\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.contentElementCategories = _($scope.element.config.categories).map(function (category) {\r\n                                return {\r\n                                    name: category.name,\r\n                                    elements: _(category.contentTypes).map(function (contentType) {\r\n                                        var type = contentType.type;\r\n                                        var factory = LayoutEditor.factories[type] || LayoutEditor.factories[\"Content\"];\r\n                                        var item = {\r\n                                            isTemplated: false,\r\n                                            contentType: contentType.id,\r\n                                            contentTypeLabel: contentType.label,\r\n                                            contentTypeClass: contentType.typeClass,\r\n                                            data: null,\r\n                                            hasEditor: contentType.hasEditor,\r\n                                            html: contentType.html\r\n                                        };\r\n                                        var element = factory(item);\r\n                                        element.toolboxIcon = contentType.icon || \"\\uf1c9\";\r\n                                        element.toolboxLabel = contentType.label;\r\n                                        element.toolboxDescription = contentType.description;\r\n                                        return element;\r\n                                    })\r\n                                };\r\n                            });\r\n\r\n                        };\r\n\r\n                        $scope.resetElements();\r\n\r\n                        $scope.getSortableOptions = function (type) {\r\n                            var editorId = $element.closest(\".layout-editor\").attr(\"id\");\r\n                            var parentClasses;\r\n                            var placeholderClasses;\r\n                            var floating = false;\r\n\r\n                            switch (type) {\r\n                                case \"Grid\":\r\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-grid ui-sortable-placeholder\";\r\n                                    break;\r\n                                case \"Row\":\r\n                                    parentClasses = [\".layout-grid\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-row row ui-sortable-placeholder\";\r\n                                    break;\r\n                                case \"Column\":\r\n                                    parentClasses = [\".layout-row:not(.layout-row-full)\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-column ui-sortable-placeholder\";\r\n                                    floating = true; // To ensure a smooth horizontal-list reordering. https://github.com/angular-ui/ui-sortable#floating\r\n                                    break;\r\n                                case \"Content\":\r\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\r\n                                    placeholderClasses = \"layout-element layout-content ui-sortable-placeholder\";\r\n                                    break;\r\n                            }\r\n\r\n                            return {\r\n                                cursor: \"move\",\r\n                                connectWith: _(parentClasses).map(function (e) { return \"#\" + editorId + \" \" + e + \":not(.layout-container-sealed) > .layout-element-wrapper > .layout-children\"; }).join(\", \"),\r\n                                placeholder: placeholderClasses,\r\n                                \"ui-floating\": floating,\r\n                                create: function (e, ui) {\r\n                                    e.target.isToolbox = true; // Will indicate to connected sortables that dropped items were sent from toolbox.\r\n                                },\r\n                                start: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.isDragging = true;\r\n                                    });\r\n                                },\r\n                                stop: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.isDragging = false;\r\n                                        $scope.resetElements();\r\n                                    });\r\n                                },\r\n                                over: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.canvas.setIsDropTarget(false);\r\n                                    });\r\n                                },\r\n                            }\r\n                        };\r\n\r\n                        var layoutIsCollapsedCookieName = \"layoutToolboxCategory_Layout_IsCollapsed\";\r\n                        $scope.layoutIsCollapsed = $.cookie(layoutIsCollapsedCookieName) === \"true\";\r\n\r\n                        $scope.toggleLayoutIsCollapsed = function (e) {\r\n                            $scope.layoutIsCollapsed = !$scope.layoutIsCollapsed;\r\n                            $.cookie(layoutIsCollapsedCookieName, $scope.layoutIsCollapsed, { expires: 365 }); // Remember collapsed state for a year.\r\n                            e.preventDefault();\r\n                            e.stopPropagation();\r\n                        };\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Toolbox\"),\r\n                replace: true,\r\n                link: function (scope, element) {\r\n                    var toolbox = element.find(\".layout-toolbox\");\r\n                    $(window).on(\"resize scroll\", function (e) {\r\n                        var canvas = element.parent().find(\".layout-canvas\");\r\n                        // If the canvas is taller than the toolbox, make the toolbox sticky-positioned within the editor\r\n                        // to help the user avoid excessive vertical scrolling.\r\n                        var canvasIsTaller = !!canvas && canvas.height() > toolbox.height();\r\n                        var windowPos = $(window).scrollTop();\r\n                        if (canvasIsTaller && windowPos > element.offset().top + element.height() - toolbox.height()) {\r\n                            toolbox.addClass(\"sticky-bottom\");\r\n                            toolbox.removeClass(\"sticky-top\");\r\n                        }\r\n                        else if (canvasIsTaller && windowPos > element.offset().top) {\r\n                            toolbox.addClass(\"sticky-top\");\r\n                            toolbox.removeClass(\"sticky-bottom\");\r\n                        }\r\n                        else {\r\n                            toolbox.removeClass(\"sticky-top\");\r\n                            toolbox.removeClass(\"sticky-bottom\");\r\n                        }\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutToolboxGroup\", [\"$compile\", \"environment\",\n        function ($compile, environment) {\n            return {\n                restrict: \"E\",\n                scope: { category: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        var isCollapsedCookieName = \"layoutToolboxCategory_\" + $scope.category.name + \"_IsCollapsed\";\n                        $scope.isCollapsed = $.cookie(isCollapsedCookieName) === \"true\";\n                        $scope.toggleIsCollapsed = function (e) {\n                            $scope.isCollapsed = !$scope.isCollapsed;\n                            $.cookie(isCollapsedCookieName, $scope.isCollapsed, { expires: 365 }); // Remember collapsed state for a year.\n                            e.preventDefault();\n                            e.stopPropagation();\n                        };\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"ToolboxGroup\"),\n                replace: true\n            };\n        }\n    ]);"],"sourceRoot":"/source/"} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Module.js","Clipboard.js","ScopeConfigurator.js","Editor.js","Canvas.js","Child.js","Column.js","Content.js","Html.js","Grid.js","Row.js","Popup.js","Toolbox.js","ToolboxGroup.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC3LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"LayoutEditor.js","sourcesContent":["angular.module(\"LayoutEditor\", [\"ngSanitize\", \"ngResource\", \"ui.sortable\"]);","var LayoutEditor;\r\n(function(LayoutEditor) {\r\n\r\n    var Clipboard = function () {\r\n        var self = this;\r\n        this._clipboardData = {};\r\n        this._isDisabled = false;\r\n        this._wasInvoked = false;\r\n\r\n        this.setData = function(contentType, data) {\r\n            self._clipboardData[contentType] = data;\r\n            self._wasInvoked = true;\r\n        };\r\n        this.getData = function (contentType) {\r\n            return self._clipboardData[contentType];\r\n            self._wasInvoked = true;\r\n        };\r\n        this.disable = function() {\r\n            self._isDisabled = true;\r\n            self._wasInvoked = false;\r\n            self._clipboardData = {};\r\n        };\r\n        this.isDisabled = function () {\r\n            return self._isDisabled;\r\n        }\r\n        this.wasInvoked = function () {\r\n            return self._wasInvoked;\r\n        }\r\n    }\r\n\r\n    LayoutEditor.Clipboard = new Clipboard();\r\n\r\n    angular\r\n        .module(\"LayoutEditor\")\r\n        .factory(\"clipboard\", [\r\n            function() {\r\n                return {\r\n                    setData: LayoutEditor.Clipboard.setData,\r\n                    getData: LayoutEditor.Clipboard.getData,\r\n                    disable: LayoutEditor.Clipboard.disable,\r\n                    isDisabled: LayoutEditor.Clipboard.isDisabled,\r\n                    wasInvoked: LayoutEditor.Clipboard.wasInvoked\r\n                };\r\n            }\r\n        ]);\r\n})(LayoutEditor || (LayoutEditor = {}));","angular\r\n    .module(\"LayoutEditor\")\r\n    .factory(\"scopeConfigurator\", [\"$timeout\", \"clipboard\",\r\n        function ($timeout, clipboard) {\r\n            return {\r\n\r\n                configureForElement: function ($scope, $element) {\r\n                \r\n                    $element.find(\".layout-panel\").click(function (e) {\r\n                        e.stopPropagation();\r\n                    });\r\n\r\n                    $element.parent().keydown(function (e) {\r\n                        var handled = false;\r\n                        var resetFocus = false;\r\n                        var element = $scope.element;\r\n                    \r\n                        if (element.editor.isDragging || element.editor.inlineEditingIsActive)\r\n                            return;\r\n\r\n                        // If native clipboard support exists, the pseudo-clipboard will have been disabled.\r\n                        if (!clipboard.isDisabled()) {\r\n                            var focusedElement = element.editor.focusedElement;\r\n                            if (!!focusedElement) {\r\n                                // Pseudo clipboard handling for browsers not allowing real clipboard operations.\r\n                                if (e.ctrlKey) {\r\n                                    switch (e.which) {\r\n                                    case 67: // C\r\n                                        focusedElement.copy(clipboard);\r\n                                        break;\r\n                                    case 88: // X\r\n                                        focusedElement.cut(clipboard);\r\n                                        break;\r\n                                    case 86: // V\r\n                                        focusedElement.paste(clipboard);\r\n                                        break;\r\n                                    }\r\n                                }\r\n                            }\r\n                        }\r\n\r\n                        if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 46) { // Del\r\n                            $scope.delete(element);\r\n                            handled = true;\r\n                        } else if (!e.ctrlKey && !e.shiftKey && !e.altKey && (e.which == 32 || e.which == 27)) { // Space or Esc\r\n                            $element.find(\".layout-panel-action-properties\").first().click();\r\n                            handled = true;\r\n                        }\r\n\r\n                        if (element.type == \"Content\") { // This is a content element.\r\n                            if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 13) { // Enter\r\n                                $element.find(\".layout-panel-action-edit\").first().click();\r\n                                handled = true;\r\n                            }\r\n                        }\r\n\r\n                        if (!!element.children) { // This is a container.\r\n                            if (!e.ctrlKey && !e.shiftKey && e.altKey && e.which == 40) { // Alt+Down\r\n                                if (element.children.length > 0)\r\n                                    element.children[0].setIsFocused();\r\n                                handled = true;\r\n                            }\r\n\r\n                            if (element.type == \"Column\") { // This is a column.\r\n                                var connectAdjacent = !e.ctrlKey;\r\n                                if (e.which == 37) { // Left\r\n                                    if (e.altKey)\r\n                                        element.expandLeft(connectAdjacent);\r\n                                    if (e.shiftKey)\r\n                                        element.contractRight(connectAdjacent);\r\n                                    handled = true;\r\n                                } else if (e.which == 39) { // Right\r\n                                    if (e.altKey)\r\n                                        element.contractLeft(connectAdjacent);\r\n                                    if (e.shiftKey)\r\n                                        element.expandRight(connectAdjacent);\r\n                                    handled = true;\r\n                                }\r\n                            }\r\n                        }\r\n\r\n                        if (!!element.parent) { // This is a child.\r\n                            if (e.altKey && e.which == 38) { // Alt+Up\r\n                                element.parent.setIsFocused();\r\n                                handled = true;\r\n                            }\r\n\r\n                            if (element.parent.type == \"Row\") { // Parent is a horizontal container.\r\n                                if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 37) { // Left\r\n                                    element.parent.moveFocusPrevChild(element);\r\n                                    handled = true;\r\n                                }\r\n                                else if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 39) { // Right\r\n                                    element.parent.moveFocusNextChild(element);\r\n                                    handled = true;\r\n                                }\r\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 37) { // Ctrl+Left\r\n                                    element.moveUp();\r\n                                    resetFocus = true;\r\n                                    handled = true;\r\n                                }\r\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 39) { // Ctrl+Right\r\n                                    element.moveDown();\r\n                                    handled = true;\r\n                                }\r\n                            }\r\n                            else { // Parent is a vertical container.\r\n                                if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 38) { // Up\r\n                                    element.parent.moveFocusPrevChild(element);\r\n                                    handled = true;\r\n                                }\r\n                                else if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 40) { // Down\r\n                                    element.parent.moveFocusNextChild(element);\r\n                                    handled = true;\r\n                                }\r\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 38) { // Ctrl+Up\r\n                                    element.moveUp();\r\n                                    resetFocus = true;\r\n                                    handled = true;\r\n                                }\r\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 40) { // Ctrl+Down\r\n                                    element.moveDown();\r\n                                    handled = true;\r\n                                }\r\n                            }\r\n                        }\r\n\r\n                        if (handled) {\r\n                            e.preventDefault();\r\n                        }\r\n\r\n                        e.stopPropagation();\r\n\r\n                        $scope.$apply(); // Event is not triggered by Angular directive but raw event handler on element.\r\n\r\n                        // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost.\r\n                        if (resetFocus) {\r\n                            window.setTimeout(function () {\r\n                                $scope.$apply(function () {\r\n                                    element.editor.focusedElement.setIsFocused();\r\n                                });\r\n                            }, 100);\r\n                        }\r\n                    });\r\n\r\n                    $scope.element.setIsFocusedEventHandlers.push(function () {\r\n                        $element.parent().focus();\r\n                    });\r\n\r\n                    $scope.delete = function (element) {\r\n                        element.delete();\r\n                    }\r\n                },\r\n\r\n                configureForContainer: function ($scope, $element) {\r\n                    var element = $scope.element;\r\n\r\n                    //$scope.isReceiving = false; // True when container is receiving an external element via drag/drop.\r\n                    $scope.getShowChildrenPlaceholder = function () {\r\n                        return $scope.element.children.length === 0 && !$scope.element.getIsDropTarget();\r\n                    };\r\n\r\n                    $scope.sortableOptions = {\r\n                        cursor: \"move\",\r\n                        delay: 150,\r\n                        disabled: element.getIsSealed(),\r\n                        distance: 5,\r\n                        //handle: element.children.length < 2 ? \".imaginary-class\" : false, // For some reason doesn't get re-evaluated after adding more children.\r\n                        start: function (e, ui) {\r\n                            $scope.$apply(function () {\r\n                                element.setIsDropTarget(true);\r\n                                element.editor.isDragging = true;\r\n                            });\r\n                            // Make the drop target placeholder as high as the item being dragged.\r\n                            ui.placeholder.height(ui.item.height() - 4);\r\n                            ui.placeholder.css(\"min-height\", 0);\r\n                        },\r\n                        stop: function (e, ui) {\r\n                            $scope.$apply(function () {\r\n                                element.editor.isDragging = false;\r\n                                element.setIsDropTarget(false);\r\n                            });\r\n                        },\r\n                        over: function (e, ui) {\r\n                            if (!!ui.sender && !!ui.sender[0].isToolbox) {\r\n                                if (!!ui.sender[0].dropTargetTimeout) {\r\n                                    $timeout.cancel(ui.sender[0].dropTargetTimeout);\r\n                                    ui.sender[0].dropTargetTimeout = null;\r\n                                }\r\n                                $timeout(function () {\r\n                                    if (element.type == \"Row\") {\r\n                                        // If there was a previous drop target and it was a row, roll back any pending column adds to it.\r\n                                        var previousDropTarget = element.editor.dropTargetElement;\r\n                                        if (!!previousDropTarget && previousDropTarget.type == \"Row\")\r\n                                            previousDropTarget.rollbackAddColumn();\r\n                                    }\r\n                                    element.setIsDropTarget(false);\r\n                                });\r\n                                ui.sender[0].dropTargetTimeout = $timeout(function () {\r\n                                    if (element.type == \"Row\") {\r\n                                        var receivedColumn = ui.item.sortable.model;\r\n                                        var receivedColumnWidth = Math.floor(12 / (element.children.length + 1));\r\n                                        receivedColumn.width = receivedColumnWidth;\r\n                                        receivedColumn.offset = 0;\r\n                                        element.beginAddColumn(receivedColumnWidth);\r\n                                        // Make the drop target placeholder the correct width and as high as the highest existing column in the row.\r\n                                        var maxHeight = _.max(_($element.find(\"> .layout-children > .layout-column:not(.ui-sortable-placeholder)\")).map(function (e) {\r\n                                            return $(e).height();\r\n                                        }));\r\n                                        for (i = 1; i <= 12; i++)\r\n                                            ui.placeholder.removeClass(\"col-xs-\" + i);\r\n                                        ui.placeholder.addClass(\"col-xs-\" + receivedColumn.width);\r\n                                        if (maxHeight > 0) {\r\n                                            ui.placeholder.height(maxHeight);\r\n                                            ui.placeholder.css(\"min-height\", 0);\r\n                                        }\r\n                                        else {\r\n                                            ui.placeholder.height(0);\r\n                                            ui.placeholder.css(\"min-height\", \"\");\r\n                                        }\r\n                                    }\r\n                                    element.setIsDropTarget(true);\r\n                                }, 150);\r\n                            }\r\n                        },\r\n                        receive: function (e, ui) {\r\n                            if (!!ui.sender && !!ui.sender[0].isToolbox) {\r\n                                $scope.$apply(function () {\r\n                                    var receivedElement = ui.item.sortable.model;\r\n                                    if (!!receivedElement) {\r\n                                        if (element.type == \"Row\")\r\n                                            element.commitAddColumn();\r\n                                        // Should ideally call LayoutEditor.Container.addChild() instead, but since this handler\r\n                                        // is run *before* the ui-sortable directive's handler, if we try to add the child to the\r\n                                        // array that handler will get an exception when trying to do the same.\r\n                                        // Because of this, we need to invoke \"setParent\" so that specific container types can perform element speficic initialization.\r\n                                        receivedElement.setEditor(element.editor);\r\n                                        receivedElement.setParent(element);\r\n\r\n                                        if (!!receivedElement.hasEditor) {\r\n                                            $scope.$root.editElement(receivedElement).then(function (args) {\r\n                                                if (!args.cancel) {\r\n                                                    receivedElement.data = args.element.data;\r\n                                                    receivedElement.applyElementEditorModel(args.elementEditorModel);\r\n\r\n                                                    if (!!receivedElement.setHtml)\r\n                                                        receivedElement.setHtml(args.element.html);\r\n                                                }\r\n                                                $timeout(function () {\r\n                                                    if (!!args.cancel)\r\n                                                        receivedElement.delete();\r\n                                                    else\r\n                                                        receivedElement.setIsFocused();\r\n                                                    //$scope.isReceiving = false;\r\n                                                    element.setIsDropTarget(false);\r\n\r\n                                                });\r\n                                                return;\r\n                                            });\r\n                                        }\r\n                                    }\r\n                                    $timeout(function () {\r\n                                        //$scope.isReceiving = false;\r\n                                        element.setIsDropTarget(false);\r\n                                        if (!!receivedElement)\r\n                                            receivedElement.setIsFocused();\r\n                                    });\r\n                                });\r\n                            }\r\n                        }\r\n                    };\r\n\r\n                    $scope.click = function (child, e) {\r\n                        if (!child.editor.isDragging)\r\n                            child.setIsFocused();\r\n                        e.stopPropagation();\r\n                    };\r\n\r\n                    $scope.getClasses = function (child) {\r\n                        var result = [\"layout-element\"];\r\n\r\n                        if (!!child.children) {\r\n                            result.push(\"layout-container\");\r\n                            if (child.getIsSealed())\r\n                                result.push(\"layout-container-sealed\");\r\n                        }\r\n\r\n                        result.push(\"layout-\" + child.type.toLowerCase());\r\n\r\n                        if (!!child.dropTargetClass)\r\n                            result.push(child.dropTargetClass);\r\n\r\n                        // TODO: Move these to either the Column directive or the Column model class.\r\n                        if (child.type == \"Row\") {\r\n                            result.push(\"row\");\r\n                            if (!child.canAddColumn())\r\n                                result.push(\"layout-row-full\");\r\n                        }\r\n                        if (child.type == \"Column\") {\r\n                            result.push(\"col-xs-\" + child.width);\r\n                            result.push(\"col-xs-offset-\" + child.offset);\r\n                        }\r\n                        if (child.type == \"Content\")\r\n                            result.push(\"layout-content-\" + child.contentTypeClass);\r\n\r\n                        if (child.getIsActive())\r\n                            result.push(\"layout-element-active\");\r\n                        if (child.getIsFocused())\r\n                            result.push(\"layout-element-focused\");\r\n                        if (child.getIsSelected())\r\n                            result.push(\"layout-element-selected\");\r\n                        if (child.getIsDropTarget())\r\n                            result.push(\"layout-element-droptarget\");\r\n                        if (child.isTemplated)\r\n                            result.push(\"layout-element-templated\");\r\n\r\n                        return result;\r\n                    };\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutEditor\", [\"environment\",\r\n        function (environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: {},\r\n                controller: [\"$scope\", \"$element\", \"$attrs\", \"$compile\", \"clipboard\",\r\n                    function ($scope, $element, $attrs, $compile, clipboard) {\r\n                        if (!!$attrs.model)\r\n                            $scope.element = eval($attrs.model);\r\n                        else\r\n                            throw new Error(\"The 'model' attribute must evaluate to a LayoutEditor.Editor object.\");\r\n\r\n                        $scope.click = function (canvas, e) {\r\n                            if (!canvas.editor.isDragging)\r\n                                canvas.setIsFocused();\r\n                            e.stopPropagation();\r\n                        };\r\n\r\n                        $scope.getClasses = function (canvas) {\r\n                            var result = [\"layout-element\", \"layout-container\", \"layout-canvas\"];\r\n\r\n                            if (canvas.getIsActive())\r\n                                result.push(\"layout-element-active\");\r\n                            if (canvas.getIsFocused())\r\n                                result.push(\"layout-element-focused\");\r\n                            if (canvas.getIsSelected())\r\n                                result.push(\"layout-element-selected\");\r\n                            if (canvas.getIsDropTarget())\r\n                                result.push(\"layout-element-droptarget\");\r\n                            if (canvas.isTemplated)\r\n                                result.push(\"layout-element-templated\");\r\n\r\n                            return result;\r\n                        };\r\n\r\n                        // An unfortunate side-effect of the next hack on line 54 is that the created elements aren't added to the DOM yet, so we can't use it to get to the parent \".layout-desiger\" element.\r\n                        // Work around: access that element directly (which efectively turns multiple layout editors on a single page impossible). \r\n                        // //var layoutDesignerHost = $element.closest(\".layout-designer\").data(\"layout-designer-host\");\r\n                        var layoutDesignerHost = $(\".layout-designer\").data(\"layout-designer-host\");\r\n\r\n                        $scope.$root.layoutDesignerHost = layoutDesignerHost;\r\n\r\n                        layoutDesignerHost.element.on(\"replacecanvas\", function (e, args) {\r\n                            var editor = $scope.element;\r\n                            var canvasData = {\r\n                                data: args.canvas.data,\r\n                                htmlId: args.canvas.htmlId,\r\n                                htmlClass: args.canvas.htmlClass,\r\n                                htmlStyle: args.canvas.htmlStyle,\r\n                                isTemplated: args.canvas.isTemplated,\r\n                                children: args.canvas.children\r\n                            };\r\n\r\n                            // HACK: Instead of simply updating the $scope.element with a new instance, we need to replace the entire orc-layout-editor markup\r\n                            // in order for angular to rebind starting with the Canvas element. Otherwise, for some reason, it will rebind starting with the first child of Canvas.\r\n                            // You can see this happening when setting a breakpoint in ScopeConfigurator where containers are initialized with drag & drop: on page load, the first element\r\n                            // is a Canvas (good), but after having selected another template, the first element is (typically) a Grid (bad).\r\n                            // Simply recompiling the orc-layout-editor directive will cause the entire thing to be generated, which works just fine as well (even though not is nice as simply leveraging model binding).\r\n                            layoutDesignerHost.editor = window.layoutEditor = new LayoutEditor.Editor(editor.config, canvasData);\r\n                            var template = \"<orc-layout-editor\" + \" model='window.layoutEditor' />\";\r\n                            var html = $compile(template)($scope);\r\n                            $(\".layout-editor-holder\").html(html);\r\n                        });\r\n\r\n                        $scope.$root.editElement = function (element) {\r\n                            var host = $scope.$root.layoutDesignerHost;\r\n                            return host.editElement(element);\r\n                        };\r\n\r\n                        $scope.$root.addElement = function (contentType) {\r\n                            var host = $scope.$root.layoutDesignerHost;\r\n                            return host.addElement(contentType);\r\n                        };\r\n\r\n                        $scope.toggleInlineEditing = function () {\r\n                            if (!$scope.element.inlineEditingIsActive) {\r\n                                $scope.element.inlineEditingIsActive = true;\r\n                                $element.find(\".layout-toolbar-container\").show();\r\n                                var selector = \"#layout-editor-\" + $scope.$id + \" .layout-html .layout-content-markup[data-templated=false]\";\r\n                                var firstContentEditorId = $(selector).first().attr(\"id\");\r\n                                tinymce.init({\r\n                                    selector: selector,\r\n                                    theme: \"modern\",\r\n                                    schema: \"html5\",\r\n                                    plugins: [\r\n                                        \"advlist autolink lists link image charmap print preview hr anchor pagebreak\",\r\n                                        \"searchreplace wordcount visualblocks visualchars code fullscreen\",\r\n                                        \"insertdatetime media nonbreaking table contextmenu directionality\",\r\n                                        \"emoticons template paste textcolor colorpicker textpattern\",\r\n                                        \"fullscreen autoresize\"\r\n                                    ],\r\n                                    toolbar: \"undo redo cut copy paste | bold italic | bullist numlist outdent indent formatselect | alignleft aligncenter alignright alignjustify ltr rtl | link unlink charmap | code fullscreen close\",\r\n                                    convert_urls: false,\r\n                                    valid_elements: \"*[*]\",\r\n                                    // Shouldn't be needed due to the valid_elements setting, but TinyMCE would strip script.src without it.\r\n                                    extended_valid_elements: \"script[type|defer|src|language]\",\r\n                                    statusbar: false,\r\n                                    skin: \"orchardlightgray\",\r\n                                    inline: true,\r\n                                    fixed_toolbar_container: \"#layout-editor-\" + $scope.$id + \" .layout-toolbar-container\",\r\n                                    init_instance_callback: function (editor) {\r\n                                        if (editor.id == firstContentEditorId)\r\n                                            tinymce.execCommand(\"mceFocus\", false, editor.id);\r\n                                    }\r\n                                });\r\n                            }\r\n                            else {\r\n                                tinymce.remove(\"#layout-editor-\" + $scope.$id + \" .layout-content-markup\");\r\n                                $element.find(\".layout-toolbar-container\").hide();\r\n                                $scope.element.inlineEditingIsActive = false;\r\n                            }\r\n                        };\r\n\r\n                        $(document).on(\"cut copy paste\", function (e) {\r\n                            // If the pseudo clipboard was already invoked (which happens on the first clipboard\r\n                            // operation after page load even if native clipboard support exists) then sit this\r\n                            // one operation out, but make sure whatever is on the pseudo clipboard gets migrated\r\n                            // to the native clipboard for subsequent operations.\r\n                            if (clipboard.wasInvoked()) {\r\n                                e.originalEvent.clipboardData.setData(\"text/plain\", clipboard.getData(\"text/plain\"));\r\n                                e.originalEvent.clipboardData.setData(\"text/json\", clipboard.getData(\"text/json\"));\r\n                                e.preventDefault();\r\n                            }\r\n                            else {\r\n                                var focusedElement = $scope.element.focusedElement;\r\n                                if (!!focusedElement) {\r\n                                    $scope.$apply(function () {\r\n                                        switch (e.type) {\r\n                                            case \"copy\":\r\n                                                focusedElement.copy(e.originalEvent.clipboardData);\r\n                                                break;\r\n                                            case \"cut\":\r\n                                                focusedElement.cut(e.originalEvent.clipboardData);\r\n                                                break;\r\n                                            case \"paste\":\r\n                                                focusedElement.paste(e.originalEvent.clipboardData);\r\n                                                break;\r\n                                        }\r\n                                    });\r\n\r\n                                    // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost.\r\n                                    window.setTimeout(function () {\r\n                                        $scope.$apply(function () {\r\n                                            if (!!$scope.element.focusedElement)\r\n                                                $scope.element.focusedElement.setIsFocused();\r\n                                        });\r\n                                    }, 100);\r\n\r\n                                    e.preventDefault();\r\n                                }\r\n                            }\r\n\r\n                            // Native clipboard support obviously exists, so disable the peudo clipboard from now on.\r\n                            clipboard.disable();\r\n                        });\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Editor\"),\r\n                replace: true,\r\n                link: function (scope, element) {\r\n                    // No clicks should propagate from the TinyMCE toolbars.\r\n                    element.find(\".layout-toolbar-container\").click(function (e) {\r\n                        e.stopPropagation();\r\n                    });\r\n                    // Intercept mousedown on editor while in inline editing mode to \r\n                    // prevent current editor from losing focus.\r\n                    element.mousedown(function (e) {\r\n                        if (scope.element.inlineEditingIsActive) {\r\n                            e.preventDefault();\r\n                            e.stopPropagation();\r\n                        }\r\n                    })\r\n                    // Unfocus and unselect everything on click outside of canvas.\r\n                    $(window).click(function (e) {\r\n                        // Except when in inline editing mode.\r\n                        if (!scope.element.inlineEditingIsActive) {\r\n                            scope.$apply(function () {\r\n                                scope.element.activeElement = null;\r\n                                scope.element.focusedElement = null;\r\n                            });\r\n                        }\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutCanvas\", [\"scopeConfigurator\", \"environment\",\r\n        function (scopeConfigurator, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: { element: \"=\" },\r\n                controller: [\"$scope\", \"$element\", \"$attrs\",\r\n                    function ($scope, $element, $attrs) {\r\n                        scopeConfigurator.configureForElement($scope, $element);\r\n                        scopeConfigurator.configureForContainer($scope, $element);\r\n                        $scope.sortableOptions[\"axis\"] = \"y\";\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Canvas\"),\r\n                replace: true\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutChild\", [\"$compile\",\r\n        function ($compile) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: { element: \"=\" },\r\n                link: function (scope, element) {\r\n                    var template = \"<orc-layout-\" + scope.element.type.toLowerCase() + \" element='element' />\";\r\n                    var html = $compile(template)(scope);\r\n                    $(element).replaceWith(html);\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutColumn\", [\"$compile\", \"scopeConfigurator\", \"environment\",\r\n        function ($compile, scopeConfigurator, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: { element: \"=\" },\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n                        scopeConfigurator.configureForElement($scope, $element);\r\n                        scopeConfigurator.configureForContainer($scope, $element);\r\n                        $scope.sortableOptions[\"axis\"] = \"y\";\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Column\"),\r\n                replace: true,\r\n                link: function (scope, element, attrs) {\r\n                    element.find(\".layout-column-resize-bar\").draggable({\r\n                        axis: \"x\",\r\n                        helper: \"clone\",\r\n                        revert: true,\r\n                        start: function (e, ui) {\r\n                            scope.$apply(function () {\r\n                                scope.element.editor.isResizing = true;\r\n                            });\r\n                        },\r\n                        drag: function (e, ui) {\r\n                            var columnElement = element.parent();\r\n                            var columnSize = columnElement.width() / scope.element.width;\r\n                            var connectAdjacent = !e.ctrlKey;\r\n                            if ($(e.target).hasClass(\"layout-column-resize-bar-left\")) {\r\n                                var delta = ui.offset.left - columnElement.offset().left;\r\n                                if (delta < -columnSize && scope.element.canExpandLeft(connectAdjacent)) {\r\n                                    scope.$apply(function () {\r\n                                        scope.element.expandLeft(connectAdjacent);\r\n                                    });\r\n                                }\r\n                                else if (delta > columnSize && scope.element.canContractLeft(connectAdjacent)) {\r\n                                    scope.$apply(function () {\r\n                                        scope.element.contractLeft(connectAdjacent);\r\n                                    });\r\n                                }\r\n                            }\r\n                            else if ($(e.target).hasClass(\"layout-column-resize-bar-right\")) {\r\n                                var delta = ui.offset.left - columnElement.width() - columnElement.offset().left;\r\n                                if (delta > columnSize && scope.element.canExpandRight(connectAdjacent)) {\r\n                                    scope.$apply(function () {\r\n                                        scope.element.expandRight(connectAdjacent);\r\n                                    });\r\n                                }\r\n                                else if (delta < -columnSize && scope.element.canContractRight(connectAdjacent)) {\r\n                                    scope.$apply(function () {\r\n                                        scope.element.contractRight(connectAdjacent);\r\n                                    });\r\n                                }\r\n                            }\r\n\r\n                        },\r\n                        stop: function (e, ui) {\r\n                            scope.$apply(function () {\r\n                              scope.element.editor.isResizing = false;\r\n                            });\r\n                        }\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutContent\", [\"$sce\", \"scopeConfigurator\", \"environment\",\r\n        function ($sce, scopeConfigurator, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: { element: \"=\" },\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n                        scopeConfigurator.configureForElement($scope, $element);\r\n                        $scope.edit = function () {\r\n                            $scope.$root.editElement($scope.element).then(function (args) {\r\n                                $scope.$apply(function () {\r\n                                    if (args.cancel)\r\n                                        return;\r\n\r\n                                    $scope.element.data = args.element.data;\r\n                                    $scope.element.setHtml(args.element.html);\r\n                                });\r\n                            });\r\n                        };\r\n\r\n                        // Overwrite the setHtml function so that we can use the $sce service to trust the html (and not have the html binding strip certain tags).\r\n                        $scope.element.setHtml = function (html) {\r\n                            $scope.element.html = html;\r\n                            $scope.element.htmlUnsafe = $sce.trustAsHtml(html);\r\n                        };\r\n\r\n                        $scope.element.setHtml($scope.element.html);\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Content\"),\r\n                replace: true\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutHtml\", [\"$sce\", \"scopeConfigurator\", \"environment\",\r\n        function ($sce, scopeConfigurator, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: { element: \"=\" },\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n                        scopeConfigurator.configureForElement($scope, $element);\r\n                        $scope.edit = function () {\r\n                            $scope.$root.editElement($scope.element).then(function (args) {\r\n                                $scope.$apply(function () {\r\n                                    if (args.cancel)\r\n                                        return;\r\n\r\n                                    $scope.element.data = args.element.data;\r\n                                    $scope.element.setHtml(args.element.html);\r\n                                });\r\n                            });\r\n                        };\r\n                        $scope.updateContent = function (e) {\r\n                            $scope.element.setHtml(e.target.innerHTML);\r\n                        };\r\n\r\n                        // Overwrite the setHtml function so that we can use the $sce service to trust the html (and not have the html binding strip certain tags).\r\n                        $scope.element.setHtml = function (html) {\r\n                            $scope.element.html = html;\r\n                            $scope.element.htmlUnsafe = $sce.trustAsHtml(html);\r\n                        };\r\n\r\n                        $scope.element.setHtml($scope.element.html);\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Html\"),\r\n                replace: true,\r\n                link: function (scope, element) {\r\n                    // Mouse down events must not be intercepted by drag and drop while inline editing is active,\r\n                    // otherwise clicks in inline editors will have no effect.\r\n                    element.find(\".layout-content-markup\").mousedown(function (e) {\r\n                        if (scope.element.editor.inlineEditingIsActive) {\r\n                            e.stopPropagation();\r\n                        }\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutGrid\", [\"$compile\", \"scopeConfigurator\", \"environment\",\r\n        function ($compile, scopeConfigurator, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: { element: \"=\" },\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n                        scopeConfigurator.configureForElement($scope, $element);\r\n                        scopeConfigurator.configureForContainer($scope, $element);\r\n                        $scope.sortableOptions[\"axis\"] = \"y\";\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Grid\"),\r\n                replace: true\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutRow\", [\"$compile\", \"scopeConfigurator\", \"environment\",\r\n        function ($compile, scopeConfigurator, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: { element: \"=\" },\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n                        scopeConfigurator.configureForElement($scope, $element);\r\n                        scopeConfigurator.configureForContainer($scope, $element);\r\n                        $scope.sortableOptions[\"axis\"] = \"x\";\r\n                        $scope.sortableOptions[\"ui-floating\"] = true;\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Row\"),\r\n                replace: true\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutPopup\", [\r\n        function () {\r\n            return {\r\n                restrict: \"A\",\r\n                link: function (scope, element, attrs) {\r\n                    var popup = $(element);\r\n                    var trigger = popup.closest(\".layout-popup-trigger\");\r\n                    var parentElement = popup.closest(\".layout-element\");\r\n                    trigger.click(function () {\r\n                        popup.toggle();\r\n                        if (popup.is(\":visible\")) {\r\n                            popup.position({\r\n                                my: attrs.orcLayoutPopupMy || \"left top\",\r\n                                at: attrs.orcLayoutPopupAt || \"left bottom+4px\",\r\n                                of: trigger\r\n                            });\r\n                            popup.find(\"input\").first().focus();\r\n                        }\r\n                    });\r\n                    popup.click(function (e) {\r\n                        e.stopPropagation();\r\n                    });\r\n                    parentElement.click(function (e) {\r\n                        popup.hide();\r\n                    });\r\n                    popup.keydown(function (e) {\r\n                        if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 27) // Esc\r\n                            popup.hide();\r\n                        e.stopPropagation();\r\n                    });\r\n                    popup.on(\"cut copy paste\", function (e) {\r\n                        // Allow clipboard operations in popup without invoking clipboard event handlers on parent element.\r\n                        e.stopPropagation();\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutToolbox\", [\"$compile\", \"environment\",\r\n        function ($compile, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n\r\n                        $scope.resetElements = function () {\r\n\r\n                            $scope.gridElements = [\r\n                                LayoutEditor.Grid.from({\r\n                                    toolboxIcon: \"\\uf00a\",\r\n                                    toolboxLabel: \"Grid\",\r\n                                    toolboxDescription: \"Empty grid.\",\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.rowElements = [\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (1 column)\",\r\n                                    toolboxDescription: \"Row with 1 column.\",\r\n                                    children: LayoutEditor.Column.times(1)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (2 columns)\",\r\n                                    toolboxDescription: \"Row with 2 columns.\",\r\n                                    children: LayoutEditor.Column.times(2)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (3 columns)\",\r\n                                    toolboxDescription: \"Row with 3 columns.\",\r\n                                    children: LayoutEditor.Column.times(3)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (4 columns)\",\r\n                                    toolboxDescription: \"Row with 4 columns.\",\r\n                                    children: LayoutEditor.Column.times(4)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (6 columns)\",\r\n                                    toolboxDescription: \"Row with 6 columns.\",\r\n                                    children: LayoutEditor.Column.times(6)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (12 columns)\",\r\n                                    toolboxDescription: \"Row with 12 columns.\",\r\n                                    children: LayoutEditor.Column.times(12)\r\n                                }), LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (empty)\",\r\n                                    toolboxDescription: \"Empty row.\",\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.columnElements = [\r\n                                LayoutEditor.Column.from({\r\n                                    toolboxIcon: \"\\uf0db\",\r\n                                    toolboxLabel: \"Column\",\r\n                                    toolboxDescription: \"Empty column.\",\r\n                                    width: 1,\r\n                                    offset: 0,\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.contentElementCategories = _($scope.element.config.categories).map(function (category) {\r\n                                return {\r\n                                    name: category.name,\r\n                                    elements: _(category.contentTypes).map(function (contentType) {\r\n                                        var type = contentType.type;\r\n                                        var factory = LayoutEditor.factories[type] || LayoutEditor.factories[\"Content\"];\r\n                                        var item = {\r\n                                            isTemplated: false,\r\n                                            contentType: contentType.id,\r\n                                            contentTypeLabel: contentType.label,\r\n                                            contentTypeClass: contentType.typeClass,\r\n                                            data: null,\r\n                                            hasEditor: contentType.hasEditor,\r\n                                            html: contentType.html\r\n                                        };\r\n                                        var element = factory(item);\r\n                                        element.toolboxIcon = contentType.icon || \"\\uf1c9\";\r\n                                        element.toolboxLabel = contentType.label;\r\n                                        element.toolboxDescription = contentType.description;\r\n                                        return element;\r\n                                    })\r\n                                };\r\n                            });\r\n\r\n                        };\r\n\r\n                        $scope.resetElements();\r\n\r\n                        $scope.getSortableOptions = function (type) {\r\n                            var editorId = $element.closest(\".layout-editor\").attr(\"id\");\r\n                            var parentClasses;\r\n                            var placeholderClasses;\r\n                            var floating = false;\r\n\r\n                            switch (type) {\r\n                                case \"Grid\":\r\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-grid ui-sortable-placeholder\";\r\n                                    break;\r\n                                case \"Row\":\r\n                                    parentClasses = [\".layout-grid\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-row row ui-sortable-placeholder\";\r\n                                    break;\r\n                                case \"Column\":\r\n                                    parentClasses = [\".layout-row:not(.layout-row-full)\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-column ui-sortable-placeholder\";\r\n                                    floating = true; // To ensure a smooth horizontal-list reordering. https://github.com/angular-ui/ui-sortable#floating\r\n                                    break;\r\n                                case \"Content\":\r\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\r\n                                    placeholderClasses = \"layout-element layout-content ui-sortable-placeholder\";\r\n                                    break;\r\n                            }\r\n\r\n                            return {\r\n                                cursor: \"move\",\r\n                                connectWith: _(parentClasses).map(function (e) { return \"#\" + editorId + \" \" + e + \":not(.layout-container-sealed) > .layout-element-wrapper > .layout-children\"; }).join(\", \"),\r\n                                placeholder: placeholderClasses,\r\n                                \"ui-floating\": floating,\r\n                                create: function (e, ui) {\r\n                                    e.target.isToolbox = true; // Will indicate to connected sortables that dropped items were sent from toolbox.\r\n                                },\r\n                                start: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.isDragging = true;\r\n                                    });\r\n                                },\r\n                                stop: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.isDragging = false;\r\n                                        $scope.resetElements();\r\n                                    });\r\n                                },\r\n                                over: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.canvas.setIsDropTarget(false);\r\n                                    });\r\n                                },\r\n                            }\r\n                        };\r\n\r\n                        var layoutIsCollapsedCookieName = \"layoutToolboxCategory_Layout_IsCollapsed\";\r\n                        $scope.layoutIsCollapsed = $.cookie(layoutIsCollapsedCookieName) === \"true\";\r\n\r\n                        $scope.toggleLayoutIsCollapsed = function (e) {\r\n                            $scope.layoutIsCollapsed = !$scope.layoutIsCollapsed;\r\n                            $.cookie(layoutIsCollapsedCookieName, $scope.layoutIsCollapsed, { expires: 365 }); // Remember collapsed state for a year.\r\n                            e.preventDefault();\r\n                            e.stopPropagation();\r\n                        };\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Toolbox\"),\r\n                replace: true,\r\n                link: function (scope, element) {\r\n                    var toolbox = element.find(\".layout-toolbox\");\r\n                    $(window).on(\"resize scroll\", function (e) {\r\n                        var canvas = element.parent().find(\".layout-canvas\");\r\n                        // If the canvas is taller than the toolbox, make the toolbox sticky-positioned within the editor\r\n                        // to help the user avoid excessive vertical scrolling.\r\n                        var canvasIsTaller = !!canvas && canvas.height() > toolbox.height();\r\n                        var windowPos = $(window).scrollTop();\r\n                        if (canvasIsTaller && windowPos > element.offset().top + element.height() - toolbox.height()) {\r\n                            toolbox.addClass(\"sticky-bottom\");\r\n                            toolbox.removeClass(\"sticky-top\");\r\n                        }\r\n                        else if (canvasIsTaller && windowPos > element.offset().top) {\r\n                            toolbox.addClass(\"sticky-top\");\r\n                            toolbox.removeClass(\"sticky-bottom\");\r\n                        }\r\n                        else {\r\n                            toolbox.removeClass(\"sticky-top\");\r\n                            toolbox.removeClass(\"sticky-bottom\");\r\n                        }\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutToolboxGroup\", [\"$compile\", \"environment\",\r\n        function ($compile, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: { category: \"=\" },\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n                        var isCollapsedCookieName = \"layoutToolboxCategory_\" + $scope.category.name + \"_IsCollapsed\";\r\n                        $scope.isCollapsed = $.cookie(isCollapsedCookieName) === \"true\";\r\n                        $scope.toggleIsCollapsed = function (e) {\r\n                            $scope.isCollapsed = !$scope.isCollapsed;\r\n                            $.cookie(isCollapsedCookieName, $scope.isCollapsed, { expires: 365 }); // Remember collapsed state for a year.\r\n                            e.preventDefault();\r\n                            e.stopPropagation();\r\n                        };\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"ToolboxGroup\"),\r\n                replace: true\r\n            };\r\n        }\r\n    ]);"],"sourceRoot":"/source/"} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.min.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.min.js index dad14fc95..ae01b421d 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.min.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.min.js @@ -1 +1 @@ -angular.module("LayoutEditor",["ngSanitize","ngResource","ui.sortable"]);var LayoutEditor;!function(e){var t=function(){var e=this;this._clipboardData={},this._isDisabled=!1,this._wasInvoked=!1,this.setData=function(t,o){e._clipboardData[t]=o,e._wasInvoked=!0},this.getData=function(t){return e._clipboardData[t]},this.disable=function(){e._isDisabled=!0,e._wasInvoked=!1,e._clipboardData={}},this.isDisabled=function(){return e._isDisabled},this.wasInvoked=function(){return e._wasInvoked}};e.Clipboard=new t,angular.module("LayoutEditor").factory("clipboard",[function(){return{setData:e.Clipboard.setData,getData:e.Clipboard.getData,disable:e.Clipboard.disable,isDisabled:e.Clipboard.isDisabled,wasInvoked:e.Clipboard.wasInvoked}}])}(LayoutEditor||(LayoutEditor={})),angular.module("LayoutEditor").factory("scopeConfigurator",["$timeout","clipboard",function(e,t){return{configureForElement:function(e,o){o.find(".layout-panel").click(function(e){e.stopPropagation()}),o.parent().keydown(function(n){var l=!1,i=!1,a=e.element;if(!a.editor.isDragging&&!a.editor.inlineEditingIsActive){if(!t.isDisabled()){var r=a.editor.focusedElement;if(r&&n.ctrlKey)switch(n.which){case 67:r.copy(t);break;case 88:r.cut(t);break;case 86:r.paste(t)}}if(n.ctrlKey||n.shiftKey||n.altKey||46!=n.which?n.ctrlKey||n.shiftKey||n.altKey||32!=n.which&&27!=n.which||(o.find(".layout-panel-action-properties").first().click(),l=!0):(e["delete"](a),l=!0),"Content"==a.type&&(n.ctrlKey||n.shiftKey||n.altKey||13!=n.which||(o.find(".layout-panel-action-edit").first().click(),l=!0)),a.children&&(n.ctrlKey||n.shiftKey||!n.altKey||40!=n.which||(a.children.length>0&&a.children[0].setIsFocused(),l=!0),"Column"==a.type)){var c=!n.ctrlKey;37==n.which?(n.altKey&&a.expandLeft(c),n.shiftKey&&a.contractRight(c),l=!0):39==n.which&&(n.altKey&&a.contractLeft(c),n.shiftKey&&a.expandRight(c),l=!0)}a.parent&&(n.altKey&&38==n.which&&(a.parent.setIsFocused(),l=!0),"Row"==a.parent.type?n.ctrlKey||n.shiftKey||n.altKey||37!=n.which?n.ctrlKey||n.shiftKey||n.altKey||39!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||37!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||39!=n.which||(a.moveDown(),l=!0):(a.moveUp(),i=!0,l=!0):(a.parent.moveFocusNextChild(a),l=!0):(a.parent.moveFocusPrevChild(a),l=!0):n.ctrlKey||n.shiftKey||n.altKey||38!=n.which?n.ctrlKey||n.shiftKey||n.altKey||40!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||38!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||40!=n.which||(a.moveDown(),l=!0):(a.moveUp(),i=!0,l=!0):(a.parent.moveFocusNextChild(a),l=!0):(a.parent.moveFocusPrevChild(a),l=!0)),l&&n.preventDefault(),n.stopPropagation(),e.$apply(),i&&window.setTimeout(function(){e.$apply(function(){a.editor.focusedElement.setIsFocused()})},100)}}),e.element.setIsFocusedEventHandlers.push(function(){o.parent().focus()}),e["delete"]=function(e){e["delete"]()}},configureForContainer:function(t,o){var n=t.element;t.getShowChildrenPlaceholder=function(){return 0===t.element.children.length&&!t.element.getIsDropTarget()},t.sortableOptions={cursor:"move",delay:150,disabled:n.getIsSealed(),distance:5,start:function(e,o){t.$apply(function(){n.setIsDropTarget(!0),n.editor.isDragging=!0}),o.placeholder.height(o.item.height()-4),o.placeholder.css("min-height",0)},stop:function(e,o){t.$apply(function(){n.editor.isDragging=!1,n.setIsDropTarget(!1)})},over:function(t,l){l.sender&&l.sender[0].isToolbox&&(l.sender[0].dropTargetTimeout&&(e.cancel(l.sender[0].dropTargetTimeout),l.sender[0].dropTargetTimeout=null),e(function(){if("Row"==n.type){var e=n.editor.dropTargetElement;e&&"Row"==e.type&&e.rollbackAddColumn()}n.setIsDropTarget(!1)}),l.sender[0].dropTargetTimeout=e(function(){if("Row"==n.type){var e=l.item.sortable.model,t=Math.floor(12/(n.children.length+1));e.width=t,e.offset=0,n.beginAddColumn(t);var a=_.max(_(o.find("> .layout-children > .layout-column:not(.ui-sortable-placeholder)")).map(function(e){return $(e).height()}));for(i=1;i<=12;i++)l.placeholder.removeClass("col-xs-"+i);l.placeholder.addClass("col-xs-"+e.width),a>0?(l.placeholder.height(a),l.placeholder.css("min-height",0)):(l.placeholder.height(0),l.placeholder.css("min-height",""))}n.setIsDropTarget(!0)},150))},receive:function(o,l){l.sender&&l.sender[0].isToolbox&&t.$apply(function(){var o=l.item.sortable.model;o&&("Row"==n.type&&n.commitAddColumn(),o.setEditor(n.editor),o.setParent(n),o.hasEditor&&t.$root.editElement(o).then(function(t){t.cancel||(o.data=t.element.data,o.setHtml&&o.setHtml(t.element.html)),e(function(){t.cancel?o["delete"]():o.setIsFocused(),n.setIsDropTarget(!1)})})),e(function(){n.setIsDropTarget(!1),o&&o.setIsFocused()})})}},t.click=function(e,t){e.editor.isDragging||e.setIsFocused(),t.stopPropagation()},t.getClasses=function(e){var t=["layout-element"];return e.children&&(t.push("layout-container"),e.getIsSealed()&&t.push("layout-container-sealed")),t.push("layout-"+e.type.toLowerCase()),e.dropTargetClass&&t.push(e.dropTargetClass),"Row"==e.type&&(t.push("row"),e.canAddColumn()||t.push("layout-row-full")),"Column"==e.type&&(t.push("col-xs-"+e.width),t.push("col-xs-offset-"+e.offset)),"Content"==e.type&&t.push("layout-content-"+e.contentTypeClass),e.getIsActive()&&t.push("layout-element-active"),e.getIsFocused()&&t.push("layout-element-focused"),e.getIsSelected()&&t.push("layout-element-selected"),e.getIsDropTarget()&&t.push("layout-element-droptarget"),e.isTemplated&&t.push("layout-element-templated"),t}}}}]),angular.module("LayoutEditor").directive("orcLayoutEditor",["environment",function(environment){return{restrict:"E",scope:{},controller:["$scope","$element","$attrs","$compile","clipboard",function($scope,$element,$attrs,$compile,clipboard){if(!$attrs.model)throw new Error("The 'model' attribute must evaluate to a LayoutEditor.Editor object.");$scope.element=eval($attrs.model),$scope.click=function(e,t){e.editor.isDragging||e.setIsFocused(),t.stopPropagation()},$scope.getClasses=function(e){var t=["layout-element","layout-container","layout-canvas"];return e.getIsActive()&&t.push("layout-element-active"),e.getIsFocused()&&t.push("layout-element-focused"),e.getIsSelected()&&t.push("layout-element-selected"),e.getIsDropTarget()&&t.push("layout-element-droptarget"),e.isTemplated&&t.push("layout-element-templated"),t};var layoutDesignerHost=$(".layout-designer").data("layout-designer-host");$scope.$root.layoutDesignerHost=layoutDesignerHost,layoutDesignerHost.element.on("replacecanvas",function(e,t){var o=$scope.element,n={data:t.canvas.data,htmlId:t.canvas.htmlId,htmlClass:t.canvas.htmlClass,htmlStyle:t.canvas.htmlStyle,isTemplated:t.canvas.isTemplated,children:t.canvas.children};layoutDesignerHost.editor=window.layoutEditor=new LayoutEditor.Editor(o.config,n);var l="",i=$compile(l)($scope);$(".layout-editor-holder").html(i)}),$scope.$root.editElement=function(e){var t=$scope.$root.layoutDesignerHost;return t.editElement(e)},$scope.$root.addElement=function(e){var t=$scope.$root.layoutDesignerHost;return t.addElement(e)},$scope.toggleInlineEditing=function(){if($scope.element.inlineEditingIsActive)tinymce.remove("#layout-editor-"+$scope.$id+" .layout-content-markup"),$element.find(".layout-toolbar-container").hide(),$scope.element.inlineEditingIsActive=!1;else{$scope.element.inlineEditingIsActive=!0,$element.find(".layout-toolbar-container").show();var e="#layout-editor-"+$scope.$id+" .layout-html .layout-content-markup[data-templated=false]",t=$(e).first().attr("id");tinymce.init({selector:e,theme:"modern",schema:"html5",plugins:["advlist autolink lists link image charmap print preview hr anchor pagebreak","searchreplace wordcount visualblocks visualchars code fullscreen","insertdatetime media nonbreaking table contextmenu directionality","emoticons template paste textcolor colorpicker textpattern","fullscreen autoresize"],toolbar:"undo redo cut copy paste | bold italic | bullist numlist outdent indent formatselect | alignleft aligncenter alignright alignjustify ltr rtl | link unlink charmap | code fullscreen close",convert_urls:!1,valid_elements:"*[*]",extended_valid_elements:"script[type|defer|src|language]",statusbar:!1,skin:"orchardlightgray",inline:!0,fixed_toolbar_container:"#layout-editor-"+$scope.$id+" .layout-toolbar-container",init_instance_callback:function(e){e.id==t&&tinymce.execCommand("mceFocus",!1,e.id)}})}},$(document).on("cut copy paste",function(e){if(clipboard.wasInvoked())e.originalEvent.clipboardData.setData("text/plain",clipboard.getData("text/plain")),e.originalEvent.clipboardData.setData("text/json",clipboard.getData("text/json")),e.preventDefault();else{var t=$scope.element.focusedElement;t&&($scope.$apply(function(){switch(e.type){case"copy":t.copy(e.originalEvent.clipboardData);break;case"cut":t.cut(e.originalEvent.clipboardData);break;case"paste":t.paste(e.originalEvent.clipboardData)}}),window.setTimeout(function(){$scope.$apply(function(){$scope.element.focusedElement&&$scope.element.focusedElement.setIsFocused()})},100),e.preventDefault())}clipboard.disable()})}],templateUrl:environment.templateUrl("Editor"),replace:!0,link:function(e,t){t.find(".layout-toolbar-container").click(function(e){e.stopPropagation()}),t.mousedown(function(t){e.element.inlineEditingIsActive&&(t.preventDefault(),t.stopPropagation())}),$(window).click(function(t){e.element.inlineEditingIsActive||e.$apply(function(){e.element.activeElement=null,e.element.focusedElement=null})})}}}]),angular.module("LayoutEditor").directive("orcLayoutCanvas",["scopeConfigurator","environment",function(e,t){return{restrict:"E",scope:{element:"="},controller:["$scope","$element","$attrs",function(t,o,n){e.configureForElement(t,o),e.configureForContainer(t,o),t.sortableOptions.axis="y"}],templateUrl:t.templateUrl("Canvas"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutChild",["$compile",function(e){return{restrict:"E",scope:{element:"="},link:function(t,o){var n="",l=e(n)(t);$(o).replaceWith(l)}}}]),angular.module("LayoutEditor").directive("orcLayoutColumn",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="y"}],templateUrl:o.templateUrl("Column"),replace:!0,link:function(e,t,o){t.find(".layout-column-resize-bar").draggable({axis:"x",helper:"clone",revert:!0,start:function(t,o){e.$apply(function(){e.element.editor.isResizing=!0})},drag:function(o,n){var l=t.parent(),i=l.width()/e.element.width,a=!o.ctrlKey;if($(o.target).hasClass("layout-column-resize-bar-left")){var r=n.offset.left-l.offset().left;-i>r&&e.element.canExpandLeft(a)?e.$apply(function(){e.element.expandLeft(a)}):r>i&&e.element.canContractLeft(a)&&e.$apply(function(){e.element.contractLeft(a)})}else if($(o.target).hasClass("layout-column-resize-bar-right")){var r=n.offset.left-l.width()-l.offset().left;r>i&&e.element.canExpandRight(a)?e.$apply(function(){e.element.expandRight(a)}):-i>r&&e.element.canContractRight(a)&&e.$apply(function(){e.element.contractRight(a)})}},stop:function(t,o){e.$apply(function(){e.element.editor.isResizing=!1})}})}}}]),angular.module("LayoutEditor").directive("orcLayoutContent",["$sce","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(o,n){t.configureForElement(o,n),o.edit=function(){o.$root.editElement(o.element).then(function(e){o.$apply(function(){e.cancel||(o.element.data=e.element.data,o.element.setHtml(e.element.html))})})},o.element.setHtml=function(t){o.element.html=t,o.element.htmlUnsafe=e.trustAsHtml(t)},o.element.setHtml(o.element.html)}],templateUrl:o.templateUrl("Content"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutHtml",["$sce","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(o,n){t.configureForElement(o,n),o.edit=function(){o.$root.editElement(o.element).then(function(e){o.$apply(function(){e.cancel||(o.element.data=e.element.data,o.element.setHtml(e.element.html))})})},o.updateContent=function(e){o.element.setHtml(e.target.innerHTML)},o.element.setHtml=function(t){o.element.html=t,o.element.htmlUnsafe=e.trustAsHtml(t)},o.element.setHtml(o.element.html)}],templateUrl:o.templateUrl("Html"),replace:!0,link:function(e,t){t.find(".layout-content-markup").mousedown(function(t){e.element.editor.inlineEditingIsActive&&t.stopPropagation()})}}}]),angular.module("LayoutEditor").directive("orcLayoutGrid",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="y"}],templateUrl:o.templateUrl("Grid"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutRow",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="x",e.sortableOptions["ui-floating"]=!0}],templateUrl:o.templateUrl("Row"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutPopup",[function(){return{restrict:"A",link:function(e,t,o){var n=$(t),l=n.closest(".layout-popup-trigger"),i=n.closest(".layout-element");l.click(function(){n.toggle(),n.is(":visible")&&(n.position({my:o.orcLayoutPopupMy||"left top",at:o.orcLayoutPopupAt||"left bottom+4px",of:l}),n.find("input").first().focus())}),n.click(function(e){e.stopPropagation()}),i.click(function(e){n.hide()}),n.keydown(function(e){e.ctrlKey||e.shiftKey||e.altKey||27!=e.which||n.hide(),e.stopPropagation()}),n.on("cut copy paste",function(e){e.stopPropagation()})}}}]),angular.module("LayoutEditor").directive("orcLayoutToolbox",["$compile","environment",function(e,t){return{restrict:"E",controller:["$scope","$element",function(e,t){e.resetElements=function(){e.gridElements=[LayoutEditor.Grid.from({toolboxIcon:"",toolboxLabel:"Grid",toolboxDescription:"Empty grid.",children:[]})],e.rowElements=[LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (1 column)",toolboxDescription:"Row with 1 column.",children:LayoutEditor.Column.times(1)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (2 columns)",toolboxDescription:"Row with 2 columns.",children:LayoutEditor.Column.times(2)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (3 columns)",toolboxDescription:"Row with 3 columns.",children:LayoutEditor.Column.times(3)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (4 columns)",toolboxDescription:"Row with 4 columns.",children:LayoutEditor.Column.times(4)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (6 columns)",toolboxDescription:"Row with 6 columns.",children:LayoutEditor.Column.times(6)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (12 columns)",toolboxDescription:"Row with 12 columns.",children:LayoutEditor.Column.times(12)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (empty)",toolboxDescription:"Empty row.",children:[]})],e.columnElements=[LayoutEditor.Column.from({toolboxIcon:"",toolboxLabel:"Column",toolboxDescription:"Empty column.",width:1,offset:0,children:[]})],e.contentElementCategories=_(e.element.config.categories).map(function(e){return{name:e.name,elements:_(e.contentTypes).map(function(e){var t=e.type,o=LayoutEditor.factories[t]||LayoutEditor.factories.Content,n={isTemplated:!1,contentType:e.id,contentTypeLabel:e.label,contentTypeClass:e.typeClass,data:null,hasEditor:e.hasEditor,html:e.html},l=o(n);return l.toolboxIcon=e.icon||"",l.toolboxLabel=e.label,l.toolboxDescription=e.description,l})}})},e.resetElements(),e.getSortableOptions=function(o){var n,l,i=t.closest(".layout-editor").attr("id"),a=!1;switch(o){case"Grid":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-container layout-grid ui-sortable-placeholder";break;case"Row":n=[".layout-grid"],l="layout-element layout-container layout-row row ui-sortable-placeholder";break;case"Column":n=[".layout-row:not(.layout-row-full)"],l="layout-element layout-container layout-column ui-sortable-placeholder",a=!0;break;case"Content":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-content ui-sortable-placeholder"}return{cursor:"move",connectWith:_(n).map(function(e){return"#"+i+" "+e+":not(.layout-container-sealed) > .layout-element-wrapper > .layout-children"}).join(", "),placeholder:l,"ui-floating":a,create:function(e,t){e.target.isToolbox=!0},start:function(t,o){e.$apply(function(){e.element.isDragging=!0})},stop:function(t,o){e.$apply(function(){e.element.isDragging=!1,e.resetElements()})},over:function(t,o){e.$apply(function(){e.element.canvas.setIsDropTarget(!1)})}}};var o="layoutToolboxCategory_Layout_IsCollapsed";e.layoutIsCollapsed="true"===$.cookie(o),e.toggleLayoutIsCollapsed=function(t){e.layoutIsCollapsed=!e.layoutIsCollapsed,$.cookie(o,e.layoutIsCollapsed,{expires:365}),t.preventDefault(),t.stopPropagation()}}],templateUrl:t.templateUrl("Toolbox"),replace:!0,link:function(e,t){var o=t.find(".layout-toolbox");$(window).on("resize scroll",function(e){var n=t.parent().find(".layout-canvas"),l=!!n&&n.height()>o.height(),i=$(window).scrollTop();l&&i>t.offset().top+t.height()-o.height()?(o.addClass("sticky-bottom"),o.removeClass("sticky-top")):l&&i>t.offset().top?(o.addClass("sticky-top"),o.removeClass("sticky-bottom")):(o.removeClass("sticky-top"),o.removeClass("sticky-bottom"))})}}}]),angular.module("LayoutEditor").directive("orcLayoutToolboxGroup",["$compile","environment",function(e,t){return{restrict:"E",scope:{category:"="},controller:["$scope","$element",function(e,t){var o="layoutToolboxCategory_"+e.category.name+"_IsCollapsed";e.isCollapsed="true"===$.cookie(o),e.toggleIsCollapsed=function(t){e.isCollapsed=!e.isCollapsed,$.cookie(o,e.isCollapsed,{expires:365}),t.preventDefault(),t.stopPropagation()}}],templateUrl:t.templateUrl("ToolboxGroup"),replace:!0}}]); \ No newline at end of file +angular.module("LayoutEditor",["ngSanitize","ngResource","ui.sortable"]);var LayoutEditor;!function(e){var t=function(){var e=this;this._clipboardData={},this._isDisabled=!1,this._wasInvoked=!1,this.setData=function(t,o){e._clipboardData[t]=o,e._wasInvoked=!0},this.getData=function(t){return e._clipboardData[t]},this.disable=function(){e._isDisabled=!0,e._wasInvoked=!1,e._clipboardData={}},this.isDisabled=function(){return e._isDisabled},this.wasInvoked=function(){return e._wasInvoked}};e.Clipboard=new t,angular.module("LayoutEditor").factory("clipboard",[function(){return{setData:e.Clipboard.setData,getData:e.Clipboard.getData,disable:e.Clipboard.disable,isDisabled:e.Clipboard.isDisabled,wasInvoked:e.Clipboard.wasInvoked}}])}(LayoutEditor||(LayoutEditor={})),angular.module("LayoutEditor").factory("scopeConfigurator",["$timeout","clipboard",function(e,t){return{configureForElement:function(e,o){o.find(".layout-panel").click(function(e){e.stopPropagation()}),o.parent().keydown(function(n){var l=!1,i=!1,a=e.element;if(!a.editor.isDragging&&!a.editor.inlineEditingIsActive){if(!t.isDisabled()){var r=a.editor.focusedElement;if(r&&n.ctrlKey)switch(n.which){case 67:r.copy(t);break;case 88:r.cut(t);break;case 86:r.paste(t)}}if(n.ctrlKey||n.shiftKey||n.altKey||46!=n.which?n.ctrlKey||n.shiftKey||n.altKey||32!=n.which&&27!=n.which||(o.find(".layout-panel-action-properties").first().click(),l=!0):(e["delete"](a),l=!0),"Content"==a.type&&(n.ctrlKey||n.shiftKey||n.altKey||13!=n.which||(o.find(".layout-panel-action-edit").first().click(),l=!0)),a.children&&(n.ctrlKey||n.shiftKey||!n.altKey||40!=n.which||(a.children.length>0&&a.children[0].setIsFocused(),l=!0),"Column"==a.type)){var c=!n.ctrlKey;37==n.which?(n.altKey&&a.expandLeft(c),n.shiftKey&&a.contractRight(c),l=!0):39==n.which&&(n.altKey&&a.contractLeft(c),n.shiftKey&&a.expandRight(c),l=!0)}a.parent&&(n.altKey&&38==n.which&&(a.parent.setIsFocused(),l=!0),"Row"==a.parent.type?n.ctrlKey||n.shiftKey||n.altKey||37!=n.which?n.ctrlKey||n.shiftKey||n.altKey||39!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||37!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||39!=n.which||(a.moveDown(),l=!0):(a.moveUp(),i=!0,l=!0):(a.parent.moveFocusNextChild(a),l=!0):(a.parent.moveFocusPrevChild(a),l=!0):n.ctrlKey||n.shiftKey||n.altKey||38!=n.which?n.ctrlKey||n.shiftKey||n.altKey||40!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||38!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||40!=n.which||(a.moveDown(),l=!0):(a.moveUp(),i=!0,l=!0):(a.parent.moveFocusNextChild(a),l=!0):(a.parent.moveFocusPrevChild(a),l=!0)),l&&n.preventDefault(),n.stopPropagation(),e.$apply(),i&&window.setTimeout(function(){e.$apply(function(){a.editor.focusedElement.setIsFocused()})},100)}}),e.element.setIsFocusedEventHandlers.push(function(){o.parent().focus()}),e["delete"]=function(e){e["delete"]()}},configureForContainer:function(t,o){var n=t.element;t.getShowChildrenPlaceholder=function(){return 0===t.element.children.length&&!t.element.getIsDropTarget()},t.sortableOptions={cursor:"move",delay:150,disabled:n.getIsSealed(),distance:5,start:function(e,o){t.$apply(function(){n.setIsDropTarget(!0),n.editor.isDragging=!0}),o.placeholder.height(o.item.height()-4),o.placeholder.css("min-height",0)},stop:function(e,o){t.$apply(function(){n.editor.isDragging=!1,n.setIsDropTarget(!1)})},over:function(t,l){l.sender&&l.sender[0].isToolbox&&(l.sender[0].dropTargetTimeout&&(e.cancel(l.sender[0].dropTargetTimeout),l.sender[0].dropTargetTimeout=null),e(function(){if("Row"==n.type){var e=n.editor.dropTargetElement;e&&"Row"==e.type&&e.rollbackAddColumn()}n.setIsDropTarget(!1)}),l.sender[0].dropTargetTimeout=e(function(){if("Row"==n.type){var e=l.item.sortable.model,t=Math.floor(12/(n.children.length+1));e.width=t,e.offset=0,n.beginAddColumn(t);var a=_.max(_(o.find("> .layout-children > .layout-column:not(.ui-sortable-placeholder)")).map(function(e){return $(e).height()}));for(i=1;i<=12;i++)l.placeholder.removeClass("col-xs-"+i);l.placeholder.addClass("col-xs-"+e.width),a>0?(l.placeholder.height(a),l.placeholder.css("min-height",0)):(l.placeholder.height(0),l.placeholder.css("min-height",""))}n.setIsDropTarget(!0)},150))},receive:function(o,l){l.sender&&l.sender[0].isToolbox&&t.$apply(function(){var o=l.item.sortable.model;o&&("Row"==n.type&&n.commitAddColumn(),o.setEditor(n.editor),o.setParent(n),o.hasEditor&&t.$root.editElement(o).then(function(t){t.cancel||(o.data=t.element.data,o.applyElementEditorModel(t.elementEditorModel),o.setHtml&&o.setHtml(t.element.html)),e(function(){t.cancel?o["delete"]():o.setIsFocused(),n.setIsDropTarget(!1)})})),e(function(){n.setIsDropTarget(!1),o&&o.setIsFocused()})})}},t.click=function(e,t){e.editor.isDragging||e.setIsFocused(),t.stopPropagation()},t.getClasses=function(e){var t=["layout-element"];return e.children&&(t.push("layout-container"),e.getIsSealed()&&t.push("layout-container-sealed")),t.push("layout-"+e.type.toLowerCase()),e.dropTargetClass&&t.push(e.dropTargetClass),"Row"==e.type&&(t.push("row"),e.canAddColumn()||t.push("layout-row-full")),"Column"==e.type&&(t.push("col-xs-"+e.width),t.push("col-xs-offset-"+e.offset)),"Content"==e.type&&t.push("layout-content-"+e.contentTypeClass),e.getIsActive()&&t.push("layout-element-active"),e.getIsFocused()&&t.push("layout-element-focused"),e.getIsSelected()&&t.push("layout-element-selected"),e.getIsDropTarget()&&t.push("layout-element-droptarget"),e.isTemplated&&t.push("layout-element-templated"),t}}}}]),angular.module("LayoutEditor").directive("orcLayoutEditor",["environment",function(environment){return{restrict:"E",scope:{},controller:["$scope","$element","$attrs","$compile","clipboard",function($scope,$element,$attrs,$compile,clipboard){if(!$attrs.model)throw new Error("The 'model' attribute must evaluate to a LayoutEditor.Editor object.");$scope.element=eval($attrs.model),$scope.click=function(e,t){e.editor.isDragging||e.setIsFocused(),t.stopPropagation()},$scope.getClasses=function(e){var t=["layout-element","layout-container","layout-canvas"];return e.getIsActive()&&t.push("layout-element-active"),e.getIsFocused()&&t.push("layout-element-focused"),e.getIsSelected()&&t.push("layout-element-selected"),e.getIsDropTarget()&&t.push("layout-element-droptarget"),e.isTemplated&&t.push("layout-element-templated"),t};var layoutDesignerHost=$(".layout-designer").data("layout-designer-host");$scope.$root.layoutDesignerHost=layoutDesignerHost,layoutDesignerHost.element.on("replacecanvas",function(e,t){var o=$scope.element,n={data:t.canvas.data,htmlId:t.canvas.htmlId,htmlClass:t.canvas.htmlClass,htmlStyle:t.canvas.htmlStyle,isTemplated:t.canvas.isTemplated,children:t.canvas.children};layoutDesignerHost.editor=window.layoutEditor=new LayoutEditor.Editor(o.config,n);var l="",i=$compile(l)($scope);$(".layout-editor-holder").html(i)}),$scope.$root.editElement=function(e){var t=$scope.$root.layoutDesignerHost;return t.editElement(e)},$scope.$root.addElement=function(e){var t=$scope.$root.layoutDesignerHost;return t.addElement(e)},$scope.toggleInlineEditing=function(){if($scope.element.inlineEditingIsActive)tinymce.remove("#layout-editor-"+$scope.$id+" .layout-content-markup"),$element.find(".layout-toolbar-container").hide(),$scope.element.inlineEditingIsActive=!1;else{$scope.element.inlineEditingIsActive=!0,$element.find(".layout-toolbar-container").show();var e="#layout-editor-"+$scope.$id+" .layout-html .layout-content-markup[data-templated=false]",t=$(e).first().attr("id");tinymce.init({selector:e,theme:"modern",schema:"html5",plugins:["advlist autolink lists link image charmap print preview hr anchor pagebreak","searchreplace wordcount visualblocks visualchars code fullscreen","insertdatetime media nonbreaking table contextmenu directionality","emoticons template paste textcolor colorpicker textpattern","fullscreen autoresize"],toolbar:"undo redo cut copy paste | bold italic | bullist numlist outdent indent formatselect | alignleft aligncenter alignright alignjustify ltr rtl | link unlink charmap | code fullscreen close",convert_urls:!1,valid_elements:"*[*]",extended_valid_elements:"script[type|defer|src|language]",statusbar:!1,skin:"orchardlightgray",inline:!0,fixed_toolbar_container:"#layout-editor-"+$scope.$id+" .layout-toolbar-container",init_instance_callback:function(e){e.id==t&&tinymce.execCommand("mceFocus",!1,e.id)}})}},$(document).on("cut copy paste",function(e){if(clipboard.wasInvoked())e.originalEvent.clipboardData.setData("text/plain",clipboard.getData("text/plain")),e.originalEvent.clipboardData.setData("text/json",clipboard.getData("text/json")),e.preventDefault();else{var t=$scope.element.focusedElement;t&&($scope.$apply(function(){switch(e.type){case"copy":t.copy(e.originalEvent.clipboardData);break;case"cut":t.cut(e.originalEvent.clipboardData);break;case"paste":t.paste(e.originalEvent.clipboardData)}}),window.setTimeout(function(){$scope.$apply(function(){$scope.element.focusedElement&&$scope.element.focusedElement.setIsFocused()})},100),e.preventDefault())}clipboard.disable()})}],templateUrl:environment.templateUrl("Editor"),replace:!0,link:function(e,t){t.find(".layout-toolbar-container").click(function(e){e.stopPropagation()}),t.mousedown(function(t){e.element.inlineEditingIsActive&&(t.preventDefault(),t.stopPropagation())}),$(window).click(function(t){e.element.inlineEditingIsActive||e.$apply(function(){e.element.activeElement=null,e.element.focusedElement=null})})}}}]),angular.module("LayoutEditor").directive("orcLayoutCanvas",["scopeConfigurator","environment",function(e,t){return{restrict:"E",scope:{element:"="},controller:["$scope","$element","$attrs",function(t,o,n){e.configureForElement(t,o),e.configureForContainer(t,o),t.sortableOptions.axis="y"}],templateUrl:t.templateUrl("Canvas"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutChild",["$compile",function(e){return{restrict:"E",scope:{element:"="},link:function(t,o){var n="",l=e(n)(t);$(o).replaceWith(l)}}}]),angular.module("LayoutEditor").directive("orcLayoutColumn",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="y"}],templateUrl:o.templateUrl("Column"),replace:!0,link:function(e,t,o){t.find(".layout-column-resize-bar").draggable({axis:"x",helper:"clone",revert:!0,start:function(t,o){e.$apply(function(){e.element.editor.isResizing=!0})},drag:function(o,n){var l=t.parent(),i=l.width()/e.element.width,a=!o.ctrlKey;if($(o.target).hasClass("layout-column-resize-bar-left")){var r=n.offset.left-l.offset().left;-i>r&&e.element.canExpandLeft(a)?e.$apply(function(){e.element.expandLeft(a)}):r>i&&e.element.canContractLeft(a)&&e.$apply(function(){e.element.contractLeft(a)})}else if($(o.target).hasClass("layout-column-resize-bar-right")){var r=n.offset.left-l.width()-l.offset().left;r>i&&e.element.canExpandRight(a)?e.$apply(function(){e.element.expandRight(a)}):-i>r&&e.element.canContractRight(a)&&e.$apply(function(){e.element.contractRight(a)})}},stop:function(t,o){e.$apply(function(){e.element.editor.isResizing=!1})}})}}}]),angular.module("LayoutEditor").directive("orcLayoutContent",["$sce","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(o,n){t.configureForElement(o,n),o.edit=function(){o.$root.editElement(o.element).then(function(e){o.$apply(function(){e.cancel||(o.element.data=e.element.data,o.element.setHtml(e.element.html))})})},o.element.setHtml=function(t){o.element.html=t,o.element.htmlUnsafe=e.trustAsHtml(t)},o.element.setHtml(o.element.html)}],templateUrl:o.templateUrl("Content"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutHtml",["$sce","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(o,n){t.configureForElement(o,n),o.edit=function(){o.$root.editElement(o.element).then(function(e){o.$apply(function(){e.cancel||(o.element.data=e.element.data,o.element.setHtml(e.element.html))})})},o.updateContent=function(e){o.element.setHtml(e.target.innerHTML)},o.element.setHtml=function(t){o.element.html=t,o.element.htmlUnsafe=e.trustAsHtml(t)},o.element.setHtml(o.element.html)}],templateUrl:o.templateUrl("Html"),replace:!0,link:function(e,t){t.find(".layout-content-markup").mousedown(function(t){e.element.editor.inlineEditingIsActive&&t.stopPropagation()})}}}]),angular.module("LayoutEditor").directive("orcLayoutGrid",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="y"}],templateUrl:o.templateUrl("Grid"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutRow",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="x",e.sortableOptions["ui-floating"]=!0}],templateUrl:o.templateUrl("Row"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutPopup",[function(){return{restrict:"A",link:function(e,t,o){var n=$(t),l=n.closest(".layout-popup-trigger"),i=n.closest(".layout-element");l.click(function(){n.toggle(),n.is(":visible")&&(n.position({my:o.orcLayoutPopupMy||"left top",at:o.orcLayoutPopupAt||"left bottom+4px",of:l}),n.find("input").first().focus())}),n.click(function(e){e.stopPropagation()}),i.click(function(e){n.hide()}),n.keydown(function(e){e.ctrlKey||e.shiftKey||e.altKey||27!=e.which||n.hide(),e.stopPropagation()}),n.on("cut copy paste",function(e){e.stopPropagation()})}}}]),angular.module("LayoutEditor").directive("orcLayoutToolbox",["$compile","environment",function(e,t){return{restrict:"E",controller:["$scope","$element",function(e,t){e.resetElements=function(){e.gridElements=[LayoutEditor.Grid.from({toolboxIcon:"",toolboxLabel:"Grid",toolboxDescription:"Empty grid.",children:[]})],e.rowElements=[LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (1 column)",toolboxDescription:"Row with 1 column.",children:LayoutEditor.Column.times(1)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (2 columns)",toolboxDescription:"Row with 2 columns.",children:LayoutEditor.Column.times(2)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (3 columns)",toolboxDescription:"Row with 3 columns.",children:LayoutEditor.Column.times(3)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (4 columns)",toolboxDescription:"Row with 4 columns.",children:LayoutEditor.Column.times(4)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (6 columns)",toolboxDescription:"Row with 6 columns.",children:LayoutEditor.Column.times(6)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (12 columns)",toolboxDescription:"Row with 12 columns.",children:LayoutEditor.Column.times(12)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (empty)",toolboxDescription:"Empty row.",children:[]})],e.columnElements=[LayoutEditor.Column.from({toolboxIcon:"",toolboxLabel:"Column",toolboxDescription:"Empty column.",width:1,offset:0,children:[]})],e.contentElementCategories=_(e.element.config.categories).map(function(e){return{name:e.name,elements:_(e.contentTypes).map(function(e){var t=e.type,o=LayoutEditor.factories[t]||LayoutEditor.factories.Content,n={isTemplated:!1,contentType:e.id,contentTypeLabel:e.label,contentTypeClass:e.typeClass,data:null,hasEditor:e.hasEditor,html:e.html},l=o(n);return l.toolboxIcon=e.icon||"",l.toolboxLabel=e.label,l.toolboxDescription=e.description,l})}})},e.resetElements(),e.getSortableOptions=function(o){var n,l,i=t.closest(".layout-editor").attr("id"),a=!1;switch(o){case"Grid":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-container layout-grid ui-sortable-placeholder";break;case"Row":n=[".layout-grid"],l="layout-element layout-container layout-row row ui-sortable-placeholder";break;case"Column":n=[".layout-row:not(.layout-row-full)"],l="layout-element layout-container layout-column ui-sortable-placeholder",a=!0;break;case"Content":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-content ui-sortable-placeholder"}return{cursor:"move",connectWith:_(n).map(function(e){return"#"+i+" "+e+":not(.layout-container-sealed) > .layout-element-wrapper > .layout-children"}).join(", "),placeholder:l,"ui-floating":a,create:function(e,t){e.target.isToolbox=!0},start:function(t,o){e.$apply(function(){e.element.isDragging=!0})},stop:function(t,o){e.$apply(function(){e.element.isDragging=!1,e.resetElements()})},over:function(t,o){e.$apply(function(){e.element.canvas.setIsDropTarget(!1)})}}};var o="layoutToolboxCategory_Layout_IsCollapsed";e.layoutIsCollapsed="true"===$.cookie(o),e.toggleLayoutIsCollapsed=function(t){e.layoutIsCollapsed=!e.layoutIsCollapsed,$.cookie(o,e.layoutIsCollapsed,{expires:365}),t.preventDefault(),t.stopPropagation()}}],templateUrl:t.templateUrl("Toolbox"),replace:!0,link:function(e,t){var o=t.find(".layout-toolbox");$(window).on("resize scroll",function(e){var n=t.parent().find(".layout-canvas"),l=!!n&&n.height()>o.height(),i=$(window).scrollTop();l&&i>t.offset().top+t.height()-o.height()?(o.addClass("sticky-bottom"),o.removeClass("sticky-top")):l&&i>t.offset().top?(o.addClass("sticky-top"),o.removeClass("sticky-bottom")):(o.removeClass("sticky-top"),o.removeClass("sticky-bottom"))})}}}]),angular.module("LayoutEditor").directive("orcLayoutToolboxGroup",["$compile","environment",function(e,t){return{restrict:"E",scope:{category:"="},controller:["$scope","$element",function(e,t){var o="layoutToolboxCategory_"+e.category.name+"_IsCollapsed";e.isCollapsed="true"===$.cookie(o),e.toggleIsCollapsed=function(t){e.isCollapsed=!e.isCollapsed,$.cookie(o,e.isCollapsed,{expires:365}),t.preventDefault(),t.stopPropagation()}}],templateUrl:t.templateUrl("ToolboxGroup"),replace:!0}}]); \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/ScopeConfigurator.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/ScopeConfigurator.js index d7da1feb8..988fdde43 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/ScopeConfigurator.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/ScopeConfigurator.js @@ -236,12 +236,14 @@ // Because of this, we need to invoke "setParent" so that specific container types can perform element speficic initialization. receivedElement.setEditor(element.editor); receivedElement.setParent(element); + if (!!receivedElement.hasEditor) { $scope.$root.editElement(receivedElement).then(function (args) { if (!args.cancel) { receivedElement.data = args.element.data; + receivedElement.applyElementEditorModel(args.elementEditorModel); - if (receivedElement.setHtml) + if (!!receivedElement.setHtml) receivedElement.setHtml(args.element.html); } $timeout(function () { diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.js index 205f708ad..ddeeaba76 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.js @@ -102,9 +102,13 @@ var LayoutEditor; this.setParent = function(parentElement) { this.parent = parentElement; + this.parent.onChildAdded(this); - if (!!this.parent.linkChild) - this.parent.linkChild(this); + var currentAncestor = parentElement; + while (!!currentAncestor) { + currentAncestor.onDescendantAdded(this, parentElement); + currentAncestor = currentAncestor.parent; + } }; this.setIsTemplated = function (value) { @@ -116,6 +120,8 @@ var LayoutEditor; } }; + this.applyElementEditorModel = function() { /* Virtual */ }; + this.getIsActive = function () { if (!this.editor) return false; @@ -259,12 +265,15 @@ var LayoutEditor; this.children = children; this.isContainer = true; - var _self = this; + var self = this; + + this.onChildAdded = function (element) { /* Virtual */ }; + this.onDescendantAdded = function (element, parentElement) { /* Virtual */ }; this.setChildren = function (children) { this.children = children; _(this.children).each(function (child) { - child.parent = _self; + child.setParent(self); }); }; @@ -281,7 +290,7 @@ var LayoutEditor; this.children.push(child); child.setEditor(this.editor); child.setIsTemplated(false); - child.parent = this; + child.setParent(this); }; this.deleteChild = function (child) { @@ -986,4 +995,4 @@ var LayoutEditor; LayoutEditor.registerFactory("Html", function(value) { return LayoutEditor.Html.from(value); }); })(jQuery, LayoutEditor || (LayoutEditor = {})); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Helpers.js","Editor.js","Element.js","Container.js","Canvas.js","Grid.js","Row.js","Column.js","Content.js","Html.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AChLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC5RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"Models.js","sourcesContent":["var LayoutEditor;\n(function (LayoutEditor) {\n\n    Array.prototype.move = function (from, to) {\n        this.splice(to, 0, this.splice(from, 1)[0]);\n    };\n\n    LayoutEditor.childrenFrom = function(values) {\n        return _(values).map(function(value) {\n            return LayoutEditor.elementFrom(value);\n        });\n    };\n\n    var registerFactory = LayoutEditor.registerFactory = function(type, factory) {\n        var factories = LayoutEditor.factories = LayoutEditor.factories || {};\n        factories[type] = factory;\n    };\n\n    registerFactory(\"Grid\", function(value) { return LayoutEditor.Grid.from(value); });\n    registerFactory(\"Row\", function(value) { return LayoutEditor.Row.from(value); });\n    registerFactory(\"Column\", function(value) { return LayoutEditor.Column.from(value); });\n    registerFactory(\"Content\", function(value) { return LayoutEditor.Content.from(value); });\n\n    LayoutEditor.elementFrom = function (value) {\n        var factory = LayoutEditor.factories[value.type];\n\n        if (!factory)\n            throw new Error(\"No element with type \\\"\" + value.type + \"\\\" was found.\");\n\n        var element = factory(value);\n        return element;\n    };\n\n    LayoutEditor.setModel = function (elementSelector, model) {\n        $(elementSelector).scope().element = model;\n    };\n\n    LayoutEditor.getModel = function (elementSelector) {\n        return $(elementSelector).scope().element;\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Editor = function (config, canvasData) {\n        this.config = config;\n        this.canvas = LayoutEditor.Canvas.from(canvasData);\n        this.initialState = JSON.stringify(this.canvas.toObject());\n        this.activeElement = null;\n        this.focusedElement = null;\n        this.dropTargetElement = null;\n        this.isDragging = false;\n        this.inlineEditingIsActive = false;\n        this.isResizing = false;\n\n        this.resetToolboxElements = function () {\n            this.toolboxElements = [\n                LayoutEditor.Row.from({\n                    children: []\n                })\n            ];\n        };\n\n        this.isDirty = function() {\n            var currentState = JSON.stringify(this.canvas.toObject());\n            return this.initialState != currentState;\n        };\n\n        this.resetToolboxElements();\n        this.canvas.setEditor(this);\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));\n","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Element = function (type, data, htmlId, htmlClass, htmlStyle, isTemplated) {\n        if (!type)\n            throw new Error(\"Parameter 'type' is required.\");\n\n        this.type = type;\n        this.data = data;\n        this.htmlId = htmlId;\n        this.htmlClass = htmlClass;\n        this.htmlStyle = htmlStyle;\n        this.isTemplated = isTemplated;\n\n        this.editor = null;\n        this.parent = null;\n        this.setIsFocusedEventHandlers = [];\n\n        this.setEditor = function (editor) {\n            this.editor = editor;\n            if (!!this.children && _.isArray(this.children)) {\n                _(this.children).each(function (child) {\n                    child.setEditor(editor);\n                });\n            }\n        };\n\n        this.setParent = function(parentElement) {\n            this.parent = parentElement;\n\n            if (!!this.parent.linkChild)\n                this.parent.linkChild(this);\n        };\n\n        this.setIsTemplated = function (value) {\n            this.isTemplated = value;\n            if (!!this.children && _.isArray(this.children)) {\n                _(this.children).each(function (child) {\n                    child.setIsTemplated(value);\n                });\n            }\n        };\n\n        this.getIsActive = function () {\n            if (!this.editor)\n                return false;\n            return this.editor.activeElement === this && !this.getIsFocused();\n        };\n\n        this.setIsActive = function (value) {\n            if (!this.editor)\n                return;\n            if (this.editor.isDragging || this.editor.inlineEditingIsActive || this.editor.isResizing)\n                return;\n\n            if (value)\n                this.editor.activeElement = this;\n            else\n                this.editor.activeElement = this.parent;\n        };\n\n        this.getIsFocused = function () {\n            if (!this.editor)\n                return false;\n            return this.editor.focusedElement === this;\n        };\n\n        this.setIsFocused = function () {\n            if (!this.editor)\n            \treturn;\n            if (this.isTemplated)\n            \treturn;\n            if (this.editor.isDragging || this.editor.inlineEditingIsActive || this.editor.isResizing)\n                return;\n\n            this.editor.focusedElement = this;\n            _(this.setIsFocusedEventHandlers).each(function (item) {\n                try {\n                    item();\n                }\n                catch (ex) {\n                    // Ignore.\n                }\n            });\n        };\n\n        this.getIsSelected = function () {\n            if (this.getIsFocused())\n                return true;\n\n            if (!!this.children && _.isArray(this.children)) {\n                return _(this.children).any(function(child) {\n                    return child.getIsSelected();\n                });\n            }\n\n            return false;\n        };\n\n        this.getIsDropTarget = function () {\n            if (!this.editor)\n                return false;\n            return this.editor.dropTargetElement === this;\n        }\n\n        this.setIsDropTarget = function (value) {\n            if (!this.editor)\n                return;\n            if (value)\n                this.editor.dropTargetElement = this;\n            else\n                this.editor.dropTargetElement = null;\n        };\n\n        this.delete = function () {\n            if (!!this.parent)\n                this.parent.deleteChild(this);\n        };\n\n        this.canMoveUp = function () {\n            if (!this.parent)\n                return false;\n            return this.parent.canMoveChildUp(this);\n        };\n\n        this.moveUp = function () {\n            if (!!this.parent)\n                this.parent.moveChildUp(this);\n        };\n\n        this.canMoveDown = function () {\n            if (!this.parent)\n                return false;\n            return this.parent.canMoveChildDown(this);\n        };\n\n        this.moveDown = function () {\n            if (!!this.parent)\n                this.parent.moveChildDown(this);\n        };\n\n        this.elementToObject = function () {\n            return {\n                type: this.type,\n                data: this.data,\n                htmlId: this.htmlId,\n                htmlClass: this.htmlClass,\n                htmlStyle: this.htmlStyle,\n                isTemplated: this.isTemplated\n            };\n        };\n\n        this.getEditorObject = function() {\n            return {};\n        };\n\n        this.copy = function (clipboardData) {\n            var text = this.getInnerText();\n            clipboardData.setData(\"text/plain\", text);\n\n            var data = this.toObject();\n            var json = JSON.stringify(data, null, \"\\t\");\n            clipboardData.setData(\"text/json\", json);\n        };\n\n        this.cut = function (clipboardData) {\n            this.copy(clipboardData);\n            this.delete();\n        };\n\n        this.paste = function (clipboardData) {\n            if (!!this.parent)\n                this.parent.paste(clipboardData);\n        };\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Container = function (allowedChildTypes, children) {\n\n        this.allowedChildTypes = allowedChildTypes;\n        this.children = children;\n        this.isContainer = true;\n\n        var _self = this;\n\n        this.setChildren = function (children) {\n            this.children = children;\n            _(this.children).each(function (child) {\n                child.parent = _self;\n            });\n        };\n\n        this.setChildren(children);\n\n        this.getIsSealed = function () {\n            return _(this.children).any(function (child) {\n                return child.isTemplated;\n            });\n        };\n\n        this.addChild = function (child) {\n            if (!_(this.children).contains(child) && (_(this.allowedChildTypes).contains(child.type) || child.isContainable))\n                this.children.push(child);\n            child.setEditor(this.editor);\n            child.setIsTemplated(false);\n            child.parent = this;\n        };\n\n        this.deleteChild = function (child) {\n            var index = _(this.children).indexOf(child);\n            if (index >= 0) {\n                this.children.splice(index, 1);\n                if (child.getIsActive())\n                    this.editor.activeElement = null;\n                if (child.getIsFocused()) {\n                    // If the deleted child was focused, try to set new focus to the most appropriate sibling or parent.\n                    if (this.children.length > index)\n                        this.children[index].setIsFocused();\n                    else if (index > 0)\n                        this.children[index - 1].setIsFocused();\n                    else\n                        this.setIsFocused();\n                }\n            }\n        };\n\n        this.moveFocusPrevChild = function (child) {\n            if (this.children.length < 2)\n                return;\n            var index = _(this.children).indexOf(child);\n            if (index > 0)\n                this.children[index - 1].setIsFocused();\n        };\n\n        this.moveFocusNextChild = function (child) {\n            if (this.children.length < 2)\n                return;\n            var index = _(this.children).indexOf(child);\n            if (index < this.children.length - 1)\n                this.children[index + 1].setIsFocused();\n        };\n\n        this.insertChild = function (child, afterChild) {\n            if (!_(this.children).contains(child)) {\n                var index = Math.max(_(this.children).indexOf(afterChild), 0);\n                this.children.splice(index + 1, 0, child);\n                child.setEditor(this.editor);\n                child.parent = this;\n            }\n        };\n\n        this.moveChildUp = function (child) {\n            if (!this.canMoveChildUp(child))\n                return;\n            var index = _(this.children).indexOf(child);\n            this.children.move(index, index - 1);\n        };\n\n        this.moveChildDown = function (child) {\n            if (!this.canMoveChildDown(child))\n                return;\n            var index = _(this.children).indexOf(child);\n            this.children.move(index, index + 1);\n        };\n\n        this.canMoveChildUp = function (child) {\n            var index = _(this.children).indexOf(child);\n            return index > 0;\n        };\n\n        this.canMoveChildDown = function (child) {\n            var index = _(this.children).indexOf(child);\n            return index < this.children.length - 1;\n        };\n\n        this.childrenToObject = function () {\n            return _(this.children).map(function (child) {\n                return child.toObject();\n            });\n        };\n\n        this.getInnerText = function () {\n            return _(this.children).reduce(function (memo, child) {\n                return memo + \"\\n\" + child.getInnerText();\n            }, \"\");\n        }\n\n        this.paste = function (clipboardData) {\n            var json = clipboardData.getData(\"text/json\");\n            if (!!json) {\n                var data = JSON.parse(json);\n                var child = LayoutEditor.elementFrom(data);\n                this.pasteChild(child);\n            }\n        };\n\n        this.pasteChild = function (child) {\n            if (_(this.allowedChildTypes).contains(child.type) || child.isContainable) {\n                this.addChild(child);\n                child.setIsFocused();\n            }\n            else if (!!this.parent)\n                this.parent.pasteChild(child);\n        }\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Canvas = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\n        LayoutEditor.Element.call(this, \"Canvas\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n        LayoutEditor.Container.call(this, [\"Grid\", \"Content\"], children);\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.children = this.childrenToObject();\n            return result;\n        };\n    };\n\n    LayoutEditor.Canvas.from = function (value) {\n        return new LayoutEditor.Canvas(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            LayoutEditor.childrenFrom(value.children));\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));\n","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Grid = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\n        LayoutEditor.Element.call(this, \"Grid\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n        LayoutEditor.Container.call(this, [\"Row\"], children);\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.children = this.childrenToObject();\n            return result;\n        };\n    };\n\n    LayoutEditor.Grid.from = function (value) {\n        var result = new LayoutEditor.Grid(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            LayoutEditor.childrenFrom(value.children));\n        result.toolboxIcon = value.toolboxIcon;\n        result.toolboxLabel = value.toolboxLabel;\n        result.toolboxDescription = value.toolboxDescription;\n        return result;\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Row = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\n        LayoutEditor.Element.call(this, \"Row\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n        LayoutEditor.Container.call(this, [\"Column\"], children);\n\n        var _self = this;\n\n        function _getTotalColumnsWidth() {\n            return _(_self.children).reduce(function (memo, child) {\n                return memo + child.offset + child.width;\n            }, 0);\n        }\n\n        // Implements a simple algorithm to distribute space (either positive or negative)\n        // between the child columns of the row. Negative space is distributed when making\n        // room for a new column (e.c. clipboard paste or dropping from the toolbox) while\n        // positive space is distributed when filling the grap of a removed column.\n        function _distributeSpace(space) {\n            if (space == 0)\n                return true;\n             \n            var undistributedSpace = space;\n\n            if (undistributedSpace < 0) {\n                var vacantSpace = 12 - _getTotalColumnsWidth();\n                undistributedSpace += vacantSpace;\n                if (undistributedSpace > 0)\n                    undistributedSpace = 0;\n            }\n\n            // If space is negative, try to decrease offsets first.\n            while (undistributedSpace < 0 && _(_self.children).any(function (column) { return column.offset > 0; })) { // While there is still offset left to remove.\n                for (i = 0; i < _self.children.length && undistributedSpace < 0; i++) {\n                    var column = _self.children[i];\n                    if (column.offset > 0) {\n                        column.offset--;\n                        undistributedSpace++;\n                    }\n                }\n            }\n\n            function hasWidth(column) {\n                if (undistributedSpace > 0)\n                    return column.width < 12;\n                else if (undistributedSpace < 0)\n                    return column.width > 1;\n                return false;\n            }\n\n            // Try to distribute remaining space (could be negative or positive) using widths.\n            while (undistributedSpace != 0) {\n                // Any more column width available for distribution?\n                if (!_(_self.children).any(hasWidth))\n                    break;\n                for (i = 0; i < _self.children.length && undistributedSpace != 0; i++) {\n                    var column = _self.children[i % _self.children.length];\n                    if (hasWidth(column)) {\n                        var delta = undistributedSpace / Math.abs(undistributedSpace);\n                        column.width += delta;\n                        undistributedSpace -= delta;\n                    }\n                }                \n            }\n\n            return undistributedSpace == 0;\n        }\n\n        var _isAddingColumn = false;\n\n        this.canAddColumn = function () {\n            return this.children.length < 12;\n        };\n\n        this.beginAddColumn = function (newColumnWidth) {\n            if (!!_isAddingColumn)\n                throw new Error(\"Column add operation is already in progress.\")\n            _(this.children).each(function (column) {\n                column.beginChange();\n            });\n            if (_distributeSpace(-newColumnWidth)) {\n                _isAddingColumn = true;\n                return true;\n            }\n            _(this.children).each(function (column) {\n                column.rollbackChange();\n            });\n            return false;\n        };\n\n        this.commitAddColumn = function () {\n            if (!_isAddingColumn)\n                throw new Error(\"No column add operation in progress.\")\n            _(this.children).each(function (column) {\n                column.commitChange();\n            });\n            _isAddingColumn = false;\n        };\n\n        this.rollbackAddColumn = function () {\n            if (!_isAddingColumn)\n                throw new Error(\"No column add operation in progress.\")\n            _(this.children).each(function (column) {\n                column.rollbackChange();\n            });\n            _isAddingColumn = false;\n        };\n\n        var _baseDeleteChild = this.deleteChild;\n        this.deleteChild = function (column) { \n            var width = column.width;\n            _baseDeleteChild.call(this, column);\n            _distributeSpace(width);\n        };\n\n        this.canContractColumnRight = function (column, connectAdjacent) {\n            var index = _(this.children).indexOf(column);\n            if (index >= 0)\n                return column.width > 1;\n            return false;\n        };\n\n        this.contractColumnRight = function (column, connectAdjacent) {\n            if (!this.canContractColumnRight(column, connectAdjacent))\n                return;\n\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (column.width > 1) {\n                    column.width--;\n                    if (this.children.length > index + 1) {\n                        var nextColumn = this.children[index + 1];\n                        if (connectAdjacent && nextColumn.offset == 0)\n                            nextColumn.width++;\n                        else\n                            nextColumn.offset++;\n                    }\n                }\n            }\n        };\n\n        this.canExpandColumnRight = function (column, connectAdjacent) {\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (column.width >= 12)\n                    return false;\n                if (this.children.length > index + 1) {\n                    var nextColumn = this.children[index + 1];\n                    if (connectAdjacent && nextColumn.offset == 0)\n                        return nextColumn.width > 1;\n                    else\n                        return nextColumn.offset > 0;\n                }\n                return _getTotalColumnsWidth() < 12;\n            }\n            return false;\n        };\n\n        this.expandColumnRight = function (column, connectAdjacent) {\n            if (!this.canExpandColumnRight(column, connectAdjacent))\n                return;\n\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (this.children.length > index + 1) {\n                    var nextColumn = this.children[index + 1];\n                    if (connectAdjacent && nextColumn.offset == 0)\n                        nextColumn.width--;\n                    else\n                        nextColumn.offset--;\n                }\n                column.width++;\n            }\n        };\n\n        this.canExpandColumnLeft = function (column, connectAdjacent) {\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (column.width >= 12)\n                    return false;\n                if (index > 0) {\n                    var prevColumn = this.children[index - 1];\n                    if (connectAdjacent && column.offset == 0)\n                        return prevColumn.width > 1;\n                }\n                return column.offset > 0;\n            }\n            return false;\n        };\n\n        this.expandColumnLeft = function (column, connectAdjacent) {\n            if (!this.canExpandColumnLeft(column, connectAdjacent))\n                return;\n\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (index > 0) {\n                    var prevColumn = this.children[index - 1];\n                    if (connectAdjacent && column.offset == 0)\n                        prevColumn.width--;\n                    else\n                        column.offset--;\n                }\n                else\n                    column.offset--;\n                column.width++;\n            }\n        };\n\n        this.canContractColumnLeft = function (column, connectAdjacent) {\n            var index = _(this.children).indexOf(column);\n            if (index >= 0)\n                return column.width > 1;\n            return false;\n        };\n\n        this.contractColumnLeft = function (column, connectAdjacent) {\n            if (!this.canContractColumnLeft(column, connectAdjacent))\n                return;\n\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (index > 0) {\n                    var prevColumn = this.children[index - 1];\n                    if (connectAdjacent && column.offset == 0)\n                        prevColumn.width++;\n                    else\n                        column.offset++;\n                }\n                else\n                    column.offset++;\n                column.width--;\n            }\n        };\n\n        this.evenColumns = function () {\n            if (this.children.length == 0)\n                return;\n\n            var evenWidth = Math.floor(12 / this.children.length);\n            _(this.children).each(function (column) {\n                column.width = evenWidth;\n                column.offset = 0;\n            });\n\n            var rest = 12 % this.children.length;\n            if (rest > 0)\n                _distributeSpace(rest);\n        };\n\n        var _basePasteChild = this.pasteChild;\n        this.pasteChild = function (child) {\n            if (child.type == \"Column\") {\n                if (this.beginAddColumn(child.width)) {\n                    this.commitAddColumn();\n                    _basePasteChild.call(this, child)\n                }\n            }\n            else if (!!this.parent)\n                this.parent.pasteChild(child);\n        }\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.children = this.childrenToObject();\n            return result;\n        };\n    };\n\n    LayoutEditor.Row.from = function (value) {\n        var result = new LayoutEditor.Row(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            LayoutEditor.childrenFrom(value.children));\n        result.toolboxIcon = value.toolboxIcon;\n        result.toolboxLabel = value.toolboxLabel;\n        result.toolboxDescription = value.toolboxDescription;\n        return result;\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Column = function (data, htmlId, htmlClass, htmlStyle, isTemplated, width, offset, children) {\n        LayoutEditor.Element.call(this, \"Column\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n        LayoutEditor.Container.call(this, [\"Grid\", \"Content\"], children);\n\n        this.width = width;\n        this.offset = offset;\n\n        var _hasPendingChange = false;\n        var _origWidth = 0;\n        var _origOffset = 0;\n\n        this.beginChange = function () {\n            if (!!_hasPendingChange)\n                throw new Error(\"Column already has a pending change.\")\n            _hasPendingChange = true;\n            _origWidth = this.width;\n            _origOffset = this.offset;\n        };\n\n        this.commitChange = function () {\n            if (!_hasPendingChange)\n                throw new Error(\"Column has no pending change.\")\n            _origWidth = 0;\n            _origOffset = 0;\n            _hasPendingChange = false;\n        };\n\n        this.rollbackChange = function () {\n            if (!_hasPendingChange)\n                throw new Error(\"Column has no pending change.\")\n            this.width = _origWidth;\n            this.offset = _origOffset;\n            _origWidth = 0;\n            _origOffset = 0;\n            _hasPendingChange = false;\n        };\n\n        this.canSplit = function () {\n            return this.width > 1;\n        };\n\n        this.split = function () {\n            if (!this.canSplit())\n                return;\n\n            var newColumnWidth = Math.floor(this.width / 2);\n            var newColumn = LayoutEditor.Column.from({\n                data: null,\n                htmlId: null,\n                htmlClass: null,\n                htmlStyle: null,\n                width: newColumnWidth,\n                offset: 0,\n                children: []\n            });\n            \n            this.width = this.width - newColumnWidth;\n            this.parent.insertChild(newColumn, this);\n            newColumn.setIsFocused();\n        };\n\n        this.canContractRight = function (connectAdjacent) {\n            return this.parent.canContractColumnRight(this, connectAdjacent);\n        };\n\n        this.contractRight = function (connectAdjacent) {\n            this.parent.contractColumnRight(this, connectAdjacent);\n        };\n\n        this.canExpandRight = function (connectAdjacent) {\n            return this.parent.canExpandColumnRight(this, connectAdjacent);\n        };\n\n        this.expandRight = function (connectAdjacent) {\n            this.parent.expandColumnRight(this, connectAdjacent);\n        };\n\n        this.canExpandLeft = function (connectAdjacent) {\n            return this.parent.canExpandColumnLeft(this, connectAdjacent);\n        };\n\n        this.expandLeft = function (connectAdjacent) {\n            this.parent.expandColumnLeft(this, connectAdjacent);\n        };\n\n        this.canContractLeft = function (connectAdjacent) {\n            return this.parent.canContractColumnLeft(this, connectAdjacent);\n        };\n\n        this.contractLeft = function (connectAdjacent) {\n            this.parent.contractColumnLeft(this, connectAdjacent);\n        };\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.width = this.width;\n            result.offset = this.offset;\n            result.children = this.childrenToObject();\n            return result;\n        };\n    };\n\n    LayoutEditor.Column.from = function (value) {\n        var result = new LayoutEditor.Column(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            value.width,\n            value.offset,\n            LayoutEditor.childrenFrom(value.children));\n        result.toolboxIcon = value.toolboxIcon;\n        result.toolboxLabel = value.toolboxLabel;\n        result.toolboxDescription = value.toolboxDescription;\n        return result;\n    };\n\n    LayoutEditor.Column.times = function (value) {\n        return _.times(value, function (n) {\n            return LayoutEditor.Column.from({\n                data: null,\n                htmlId: null,\n                htmlClass: null,\n                isTemplated: false,\n                width: 12 / value,\n                offset: 0,\n                children: []\n            });\n        });\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Content = function (data, htmlId, htmlClass, htmlStyle, isTemplated, contentType, contentTypeLabel, contentTypeClass, html, hasEditor) {\n        LayoutEditor.Element.call(this, \"Content\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n\n        this.contentType = contentType;\n        this.contentTypeLabel = contentTypeLabel;\n        this.contentTypeClass = contentTypeClass;\n        this.html = html;\n        this.hasEditor = hasEditor;\n\n        this.getInnerText = function () {\n            return $($.parseHTML(\"<div>\" + this.html + \"</div>\")).text();\n        };\n\n        // This function will be overwritten by the Content directive.\n        this.setHtml = function (html) {\n            this.html = html;\n            this.htmlUnsafe = html;\n        }\n\n        this.toObject = function () {\n            return {\n                \"type\": \"Content\"\n            };\n        };\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.contentType = this.contentType;\n            result.contentTypeLabel = this.contentTypeLabel;\n            result.contentTypeClass = this.contentTypeClass;\n            result.html = this.html;\n            result.hasEditor = hasEditor;\n            return result;\n        };\n\n        this.setHtml(html);\n    };\n\n    LayoutEditor.Content.from = function (value) {\n        var result = new LayoutEditor.Content(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            value.contentType,\n            value.contentTypeLabel,\n            value.contentTypeClass,\n            value.html,\n            value.hasEditor);\n\n        return result;\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function ($, LayoutEditor) {\n\n    LayoutEditor.Html = function (data, htmlId, htmlClass, htmlStyle, isTemplated, contentType, contentTypeLabel, contentTypeClass, html, hasEditor) {\n        LayoutEditor.Element.call(this, \"Html\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n\n        this.contentType = contentType;\n        this.contentTypeLabel = contentTypeLabel;\n        this.contentTypeClass = contentTypeClass;\n        this.html = html;\n        this.hasEditor = hasEditor;\n        this.isContainable = true;\n\n        this.getInnerText = function () {\n            return $($.parseHTML(\"<div>\" + this.html + \"</div>\")).text();\n        };\n\n        // This function will be overwritten by the Content directive.\n        this.setHtml = function (html) {\n            this.html = html;\n            this.htmlUnsafe = html;\n        }\n\n        this.toObject = function () {\n            return {\n                \"type\": \"Html\"\n            };\n        };\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.contentType = this.contentType;\n            result.contentTypeLabel = this.contentTypeLabel;\n            result.contentTypeClass = this.contentTypeClass;\n            result.html = this.html;\n            result.hasEditor = hasEditor;\n            return result;\n        };\n\n        var getEditorObject = this.getEditorObject;\n        this.getEditorObject = function () {\n            var dto = getEditorObject();\n            return $.extend(dto, {\n                Content: this.html\n            });\n        }\n\n        this.setHtml(html);\n    };\n\n    LayoutEditor.Html.from = function (value) {\n        var result = new LayoutEditor.Html(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            value.contentType,\n            value.contentTypeLabel,\n            value.contentTypeClass,\n            value.html,\n            value.hasEditor);\n\n        return result;\n    };\n\n    LayoutEditor.registerFactory(\"Html\", function(value) { return LayoutEditor.Html.from(value); });\n\n})(jQuery, LayoutEditor || (LayoutEditor = {}));"],"sourceRoot":"/source/"} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Helpers.js","Editor.js","Element.js","Container.js","Canvas.js","Grid.js","Row.js","Column.js","Content.js","Html.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACtLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC5RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"Models.js","sourcesContent":["var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    Array.prototype.move = function (from, to) {\r\n        this.splice(to, 0, this.splice(from, 1)[0]);\r\n    };\r\n\r\n    LayoutEditor.childrenFrom = function(values) {\r\n        return _(values).map(function(value) {\r\n            return LayoutEditor.elementFrom(value);\r\n        });\r\n    };\r\n\r\n    var registerFactory = LayoutEditor.registerFactory = function(type, factory) {\r\n        var factories = LayoutEditor.factories = LayoutEditor.factories || {};\r\n        factories[type] = factory;\r\n    };\r\n\r\n    registerFactory(\"Grid\", function(value) { return LayoutEditor.Grid.from(value); });\r\n    registerFactory(\"Row\", function(value) { return LayoutEditor.Row.from(value); });\r\n    registerFactory(\"Column\", function(value) { return LayoutEditor.Column.from(value); });\r\n    registerFactory(\"Content\", function(value) { return LayoutEditor.Content.from(value); });\r\n\r\n    LayoutEditor.elementFrom = function (value) {\r\n        var factory = LayoutEditor.factories[value.type];\r\n\r\n        if (!factory)\r\n            throw new Error(\"No element with type \\\"\" + value.type + \"\\\" was found.\");\r\n\r\n        var element = factory(value);\r\n        return element;\r\n    };\r\n\r\n    LayoutEditor.setModel = function (elementSelector, model) {\r\n        $(elementSelector).scope().element = model;\r\n    };\r\n\r\n    LayoutEditor.getModel = function (elementSelector) {\r\n        return $(elementSelector).scope().element;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Editor = function (config, canvasData) {\r\n        this.config = config;\r\n        this.canvas = LayoutEditor.Canvas.from(canvasData);\r\n        this.initialState = JSON.stringify(this.canvas.toObject());\r\n        this.activeElement = null;\r\n        this.focusedElement = null;\r\n        this.dropTargetElement = null;\r\n        this.isDragging = false;\r\n        this.inlineEditingIsActive = false;\r\n        this.isResizing = false;\r\n\r\n        this.resetToolboxElements = function () {\r\n            this.toolboxElements = [\r\n                LayoutEditor.Row.from({\r\n                    children: []\r\n                })\r\n            ];\r\n        };\r\n\r\n        this.isDirty = function() {\r\n            var currentState = JSON.stringify(this.canvas.toObject());\r\n            return this.initialState != currentState;\r\n        };\r\n\r\n        this.resetToolboxElements();\r\n        this.canvas.setEditor(this);\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));\r\n","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Element = function (type, data, htmlId, htmlClass, htmlStyle, isTemplated) {\r\n        if (!type)\r\n            throw new Error(\"Parameter 'type' is required.\");\r\n\r\n        this.type = type;\r\n        this.data = data;\r\n        this.htmlId = htmlId;\r\n        this.htmlClass = htmlClass;\r\n        this.htmlStyle = htmlStyle;\r\n        this.isTemplated = isTemplated;\r\n\r\n        this.editor = null;\r\n        this.parent = null;\r\n        this.setIsFocusedEventHandlers = [];\r\n\r\n        this.setEditor = function (editor) {\r\n            this.editor = editor;\r\n            if (!!this.children && _.isArray(this.children)) {\r\n                _(this.children).each(function (child) {\r\n                    child.setEditor(editor);\r\n                });\r\n            }\r\n        };\r\n\r\n        this.setParent = function(parentElement) {\r\n            this.parent = parentElement;\r\n            this.parent.onChildAdded(this);\r\n\r\n            var currentAncestor = parentElement;\r\n            while (!!currentAncestor) {\r\n                currentAncestor.onDescendantAdded(this, parentElement);\r\n                currentAncestor = currentAncestor.parent;\r\n            }\r\n        };\r\n\r\n        this.setIsTemplated = function (value) {\r\n            this.isTemplated = value;\r\n            if (!!this.children && _.isArray(this.children)) {\r\n                _(this.children).each(function (child) {\r\n                    child.setIsTemplated(value);\r\n                });\r\n            }\r\n        };\r\n\r\n        this.applyElementEditorModel = function() { /* Virtual */ };\r\n\r\n        this.getIsActive = function () {\r\n            if (!this.editor)\r\n                return false;\r\n            return this.editor.activeElement === this && !this.getIsFocused();\r\n        };\r\n\r\n        this.setIsActive = function (value) {\r\n            if (!this.editor)\r\n                return;\r\n            if (this.editor.isDragging || this.editor.inlineEditingIsActive || this.editor.isResizing)\r\n                return;\r\n\r\n            if (value)\r\n                this.editor.activeElement = this;\r\n            else\r\n                this.editor.activeElement = this.parent;\r\n        };\r\n\r\n        this.getIsFocused = function () {\r\n            if (!this.editor)\r\n                return false;\r\n            return this.editor.focusedElement === this;\r\n        };\r\n\r\n        this.setIsFocused = function () {\r\n            if (!this.editor)\r\n            \treturn;\r\n            if (this.isTemplated)\r\n            \treturn;\r\n            if (this.editor.isDragging || this.editor.inlineEditingIsActive || this.editor.isResizing)\r\n                return;\r\n\r\n            this.editor.focusedElement = this;\r\n            _(this.setIsFocusedEventHandlers).each(function (item) {\r\n                try {\r\n                    item();\r\n                }\r\n                catch (ex) {\r\n                    // Ignore.\r\n                }\r\n            });\r\n        };\r\n\r\n        this.getIsSelected = function () {\r\n            if (this.getIsFocused())\r\n                return true;\r\n\r\n            if (!!this.children && _.isArray(this.children)) {\r\n                return _(this.children).any(function(child) {\r\n                    return child.getIsSelected();\r\n                });\r\n            }\r\n\r\n            return false;\r\n        };\r\n\r\n        this.getIsDropTarget = function () {\r\n            if (!this.editor)\r\n                return false;\r\n            return this.editor.dropTargetElement === this;\r\n        }\r\n\r\n        this.setIsDropTarget = function (value) {\r\n            if (!this.editor)\r\n                return;\r\n            if (value)\r\n                this.editor.dropTargetElement = this;\r\n            else\r\n                this.editor.dropTargetElement = null;\r\n        };\r\n\r\n        this.delete = function () {\r\n            if (!!this.parent)\r\n                this.parent.deleteChild(this);\r\n        };\r\n\r\n        this.canMoveUp = function () {\r\n            if (!this.parent)\r\n                return false;\r\n            return this.parent.canMoveChildUp(this);\r\n        };\r\n\r\n        this.moveUp = function () {\r\n            if (!!this.parent)\r\n                this.parent.moveChildUp(this);\r\n        };\r\n\r\n        this.canMoveDown = function () {\r\n            if (!this.parent)\r\n                return false;\r\n            return this.parent.canMoveChildDown(this);\r\n        };\r\n\r\n        this.moveDown = function () {\r\n            if (!!this.parent)\r\n                this.parent.moveChildDown(this);\r\n        };\r\n\r\n        this.elementToObject = function () {\r\n            return {\r\n                type: this.type,\r\n                data: this.data,\r\n                htmlId: this.htmlId,\r\n                htmlClass: this.htmlClass,\r\n                htmlStyle: this.htmlStyle,\r\n                isTemplated: this.isTemplated\r\n            };\r\n        };\r\n\r\n        this.getEditorObject = function() {\r\n            return {};\r\n        };\r\n\r\n        this.copy = function (clipboardData) {\r\n            var text = this.getInnerText();\r\n            clipboardData.setData(\"text/plain\", text);\r\n\r\n            var data = this.toObject();\r\n            var json = JSON.stringify(data, null, \"\\t\");\r\n            clipboardData.setData(\"text/json\", json);\r\n        };\r\n\r\n        this.cut = function (clipboardData) {\r\n            this.copy(clipboardData);\r\n            this.delete();\r\n        };\r\n\r\n        this.paste = function (clipboardData) {\r\n            if (!!this.parent)\r\n                this.parent.paste(clipboardData);\r\n        };\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Container = function (allowedChildTypes, children) {\r\n\r\n        this.allowedChildTypes = allowedChildTypes;\r\n        this.children = children;\r\n        this.isContainer = true;\r\n\r\n        var self = this;\r\n\r\n        this.onChildAdded = function (element) { /* Virtual */ };\r\n        this.onDescendantAdded = function (element, parentElement) { /* Virtual */ };\r\n\r\n        this.setChildren = function (children) {\r\n            this.children = children;\r\n            _(this.children).each(function (child) {\r\n                child.setParent(self);\r\n            });\r\n        };\r\n\r\n        this.setChildren(children);\r\n\r\n        this.getIsSealed = function () {\r\n            return _(this.children).any(function (child) {\r\n                return child.isTemplated;\r\n            });\r\n        };\r\n\r\n        this.addChild = function (child) {\r\n            if (!_(this.children).contains(child) && (_(this.allowedChildTypes).contains(child.type) || child.isContainable))\r\n                this.children.push(child);\r\n            child.setEditor(this.editor);\r\n            child.setIsTemplated(false);\r\n            child.setParent(this);\r\n        };\r\n\r\n        this.deleteChild = function (child) {\r\n            var index = _(this.children).indexOf(child);\r\n            if (index >= 0) {\r\n                this.children.splice(index, 1);\r\n                if (child.getIsActive())\r\n                    this.editor.activeElement = null;\r\n                if (child.getIsFocused()) {\r\n                    // If the deleted child was focused, try to set new focus to the most appropriate sibling or parent.\r\n                    if (this.children.length > index)\r\n                        this.children[index].setIsFocused();\r\n                    else if (index > 0)\r\n                        this.children[index - 1].setIsFocused();\r\n                    else\r\n                        this.setIsFocused();\r\n                }\r\n            }\r\n        };\r\n\r\n        this.moveFocusPrevChild = function (child) {\r\n            if (this.children.length < 2)\r\n                return;\r\n            var index = _(this.children).indexOf(child);\r\n            if (index > 0)\r\n                this.children[index - 1].setIsFocused();\r\n        };\r\n\r\n        this.moveFocusNextChild = function (child) {\r\n            if (this.children.length < 2)\r\n                return;\r\n            var index = _(this.children).indexOf(child);\r\n            if (index < this.children.length - 1)\r\n                this.children[index + 1].setIsFocused();\r\n        };\r\n\r\n        this.insertChild = function (child, afterChild) {\r\n            if (!_(this.children).contains(child)) {\r\n                var index = Math.max(_(this.children).indexOf(afterChild), 0);\r\n                this.children.splice(index + 1, 0, child);\r\n                child.setEditor(this.editor);\r\n                child.parent = this;\r\n            }\r\n        };\r\n\r\n        this.moveChildUp = function (child) {\r\n            if (!this.canMoveChildUp(child))\r\n                return;\r\n            var index = _(this.children).indexOf(child);\r\n            this.children.move(index, index - 1);\r\n        };\r\n\r\n        this.moveChildDown = function (child) {\r\n            if (!this.canMoveChildDown(child))\r\n                return;\r\n            var index = _(this.children).indexOf(child);\r\n            this.children.move(index, index + 1);\r\n        };\r\n\r\n        this.canMoveChildUp = function (child) {\r\n            var index = _(this.children).indexOf(child);\r\n            return index > 0;\r\n        };\r\n\r\n        this.canMoveChildDown = function (child) {\r\n            var index = _(this.children).indexOf(child);\r\n            return index < this.children.length - 1;\r\n        };\r\n\r\n        this.childrenToObject = function () {\r\n            return _(this.children).map(function (child) {\r\n                return child.toObject();\r\n            });\r\n        };\r\n\r\n        this.getInnerText = function () {\r\n            return _(this.children).reduce(function (memo, child) {\r\n                return memo + \"\\n\" + child.getInnerText();\r\n            }, \"\");\r\n        }\r\n\r\n        this.paste = function (clipboardData) {\r\n            var json = clipboardData.getData(\"text/json\");\r\n            if (!!json) {\r\n                var data = JSON.parse(json);\r\n                var child = LayoutEditor.elementFrom(data);\r\n                this.pasteChild(child);\r\n            }\r\n        };\r\n\r\n        this.pasteChild = function (child) {\r\n            if (_(this.allowedChildTypes).contains(child.type) || child.isContainable) {\r\n                this.addChild(child);\r\n                child.setIsFocused();\r\n            }\r\n            else if (!!this.parent)\r\n                this.parent.pasteChild(child);\r\n        }\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Canvas = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\r\n        LayoutEditor.Element.call(this, \"Canvas\", data, htmlId, htmlClass, htmlStyle, isTemplated);\r\n        LayoutEditor.Container.call(this, [\"Grid\", \"Content\"], children);\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.children = this.childrenToObject();\r\n            return result;\r\n        };\r\n    };\r\n\r\n    LayoutEditor.Canvas.from = function (value) {\r\n        return new LayoutEditor.Canvas(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            LayoutEditor.childrenFrom(value.children));\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));\r\n","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Grid = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\r\n        LayoutEditor.Element.call(this, \"Grid\", data, htmlId, htmlClass, htmlStyle, isTemplated);\r\n        LayoutEditor.Container.call(this, [\"Row\"], children);\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.children = this.childrenToObject();\r\n            return result;\r\n        };\r\n    };\r\n\r\n    LayoutEditor.Grid.from = function (value) {\r\n        var result = new LayoutEditor.Grid(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            LayoutEditor.childrenFrom(value.children));\r\n        result.toolboxIcon = value.toolboxIcon;\r\n        result.toolboxLabel = value.toolboxLabel;\r\n        result.toolboxDescription = value.toolboxDescription;\r\n        return result;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Row = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\r\n        LayoutEditor.Element.call(this, \"Row\", data, htmlId, htmlClass, htmlStyle, isTemplated);\r\n        LayoutEditor.Container.call(this, [\"Column\"], children);\r\n\r\n        var _self = this;\r\n\r\n        function _getTotalColumnsWidth() {\r\n            return _(_self.children).reduce(function (memo, child) {\r\n                return memo + child.offset + child.width;\r\n            }, 0);\r\n        }\r\n\r\n        // Implements a simple algorithm to distribute space (either positive or negative)\r\n        // between the child columns of the row. Negative space is distributed when making\r\n        // room for a new column (e.c. clipboard paste or dropping from the toolbox) while\r\n        // positive space is distributed when filling the grap of a removed column.\r\n        function _distributeSpace(space) {\r\n            if (space == 0)\r\n                return true;\r\n             \r\n            var undistributedSpace = space;\r\n\r\n            if (undistributedSpace < 0) {\r\n                var vacantSpace = 12 - _getTotalColumnsWidth();\r\n                undistributedSpace += vacantSpace;\r\n                if (undistributedSpace > 0)\r\n                    undistributedSpace = 0;\r\n            }\r\n\r\n            // If space is negative, try to decrease offsets first.\r\n            while (undistributedSpace < 0 && _(_self.children).any(function (column) { return column.offset > 0; })) { // While there is still offset left to remove.\r\n                for (i = 0; i < _self.children.length && undistributedSpace < 0; i++) {\r\n                    var column = _self.children[i];\r\n                    if (column.offset > 0) {\r\n                        column.offset--;\r\n                        undistributedSpace++;\r\n                    }\r\n                }\r\n            }\r\n\r\n            function hasWidth(column) {\r\n                if (undistributedSpace > 0)\r\n                    return column.width < 12;\r\n                else if (undistributedSpace < 0)\r\n                    return column.width > 1;\r\n                return false;\r\n            }\r\n\r\n            // Try to distribute remaining space (could be negative or positive) using widths.\r\n            while (undistributedSpace != 0) {\r\n                // Any more column width available for distribution?\r\n                if (!_(_self.children).any(hasWidth))\r\n                    break;\r\n                for (i = 0; i < _self.children.length && undistributedSpace != 0; i++) {\r\n                    var column = _self.children[i % _self.children.length];\r\n                    if (hasWidth(column)) {\r\n                        var delta = undistributedSpace / Math.abs(undistributedSpace);\r\n                        column.width += delta;\r\n                        undistributedSpace -= delta;\r\n                    }\r\n                }                \r\n            }\r\n\r\n            return undistributedSpace == 0;\r\n        }\r\n\r\n        var _isAddingColumn = false;\r\n\r\n        this.canAddColumn = function () {\r\n            return this.children.length < 12;\r\n        };\r\n\r\n        this.beginAddColumn = function (newColumnWidth) {\r\n            if (!!_isAddingColumn)\r\n                throw new Error(\"Column add operation is already in progress.\")\r\n            _(this.children).each(function (column) {\r\n                column.beginChange();\r\n            });\r\n            if (_distributeSpace(-newColumnWidth)) {\r\n                _isAddingColumn = true;\r\n                return true;\r\n            }\r\n            _(this.children).each(function (column) {\r\n                column.rollbackChange();\r\n            });\r\n            return false;\r\n        };\r\n\r\n        this.commitAddColumn = function () {\r\n            if (!_isAddingColumn)\r\n                throw new Error(\"No column add operation in progress.\")\r\n            _(this.children).each(function (column) {\r\n                column.commitChange();\r\n            });\r\n            _isAddingColumn = false;\r\n        };\r\n\r\n        this.rollbackAddColumn = function () {\r\n            if (!_isAddingColumn)\r\n                throw new Error(\"No column add operation in progress.\")\r\n            _(this.children).each(function (column) {\r\n                column.rollbackChange();\r\n            });\r\n            _isAddingColumn = false;\r\n        };\r\n\r\n        var _baseDeleteChild = this.deleteChild;\r\n        this.deleteChild = function (column) { \r\n            var width = column.width;\r\n            _baseDeleteChild.call(this, column);\r\n            _distributeSpace(width);\r\n        };\r\n\r\n        this.canContractColumnRight = function (column, connectAdjacent) {\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0)\r\n                return column.width > 1;\r\n            return false;\r\n        };\r\n\r\n        this.contractColumnRight = function (column, connectAdjacent) {\r\n            if (!this.canContractColumnRight(column, connectAdjacent))\r\n                return;\r\n\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (column.width > 1) {\r\n                    column.width--;\r\n                    if (this.children.length > index + 1) {\r\n                        var nextColumn = this.children[index + 1];\r\n                        if (connectAdjacent && nextColumn.offset == 0)\r\n                            nextColumn.width++;\r\n                        else\r\n                            nextColumn.offset++;\r\n                    }\r\n                }\r\n            }\r\n        };\r\n\r\n        this.canExpandColumnRight = function (column, connectAdjacent) {\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (column.width >= 12)\r\n                    return false;\r\n                if (this.children.length > index + 1) {\r\n                    var nextColumn = this.children[index + 1];\r\n                    if (connectAdjacent && nextColumn.offset == 0)\r\n                        return nextColumn.width > 1;\r\n                    else\r\n                        return nextColumn.offset > 0;\r\n                }\r\n                return _getTotalColumnsWidth() < 12;\r\n            }\r\n            return false;\r\n        };\r\n\r\n        this.expandColumnRight = function (column, connectAdjacent) {\r\n            if (!this.canExpandColumnRight(column, connectAdjacent))\r\n                return;\r\n\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (this.children.length > index + 1) {\r\n                    var nextColumn = this.children[index + 1];\r\n                    if (connectAdjacent && nextColumn.offset == 0)\r\n                        nextColumn.width--;\r\n                    else\r\n                        nextColumn.offset--;\r\n                }\r\n                column.width++;\r\n            }\r\n        };\r\n\r\n        this.canExpandColumnLeft = function (column, connectAdjacent) {\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (column.width >= 12)\r\n                    return false;\r\n                if (index > 0) {\r\n                    var prevColumn = this.children[index - 1];\r\n                    if (connectAdjacent && column.offset == 0)\r\n                        return prevColumn.width > 1;\r\n                }\r\n                return column.offset > 0;\r\n            }\r\n            return false;\r\n        };\r\n\r\n        this.expandColumnLeft = function (column, connectAdjacent) {\r\n            if (!this.canExpandColumnLeft(column, connectAdjacent))\r\n                return;\r\n\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (index > 0) {\r\n                    var prevColumn = this.children[index - 1];\r\n                    if (connectAdjacent && column.offset == 0)\r\n                        prevColumn.width--;\r\n                    else\r\n                        column.offset--;\r\n                }\r\n                else\r\n                    column.offset--;\r\n                column.width++;\r\n            }\r\n        };\r\n\r\n        this.canContractColumnLeft = function (column, connectAdjacent) {\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0)\r\n                return column.width > 1;\r\n            return false;\r\n        };\r\n\r\n        this.contractColumnLeft = function (column, connectAdjacent) {\r\n            if (!this.canContractColumnLeft(column, connectAdjacent))\r\n                return;\r\n\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (index > 0) {\r\n                    var prevColumn = this.children[index - 1];\r\n                    if (connectAdjacent && column.offset == 0)\r\n                        prevColumn.width++;\r\n                    else\r\n                        column.offset++;\r\n                }\r\n                else\r\n                    column.offset++;\r\n                column.width--;\r\n            }\r\n        };\r\n\r\n        this.evenColumns = function () {\r\n            if (this.children.length == 0)\r\n                return;\r\n\r\n            var evenWidth = Math.floor(12 / this.children.length);\r\n            _(this.children).each(function (column) {\r\n                column.width = evenWidth;\r\n                column.offset = 0;\r\n            });\r\n\r\n            var rest = 12 % this.children.length;\r\n            if (rest > 0)\r\n                _distributeSpace(rest);\r\n        };\r\n\r\n        var _basePasteChild = this.pasteChild;\r\n        this.pasteChild = function (child) {\r\n            if (child.type == \"Column\") {\r\n                if (this.beginAddColumn(child.width)) {\r\n                    this.commitAddColumn();\r\n                    _basePasteChild.call(this, child)\r\n                }\r\n            }\r\n            else if (!!this.parent)\r\n                this.parent.pasteChild(child);\r\n        }\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.children = this.childrenToObject();\r\n            return result;\r\n        };\r\n    };\r\n\r\n    LayoutEditor.Row.from = function (value) {\r\n        var result = new LayoutEditor.Row(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            LayoutEditor.childrenFrom(value.children));\r\n        result.toolboxIcon = value.toolboxIcon;\r\n        result.toolboxLabel = value.toolboxLabel;\r\n        result.toolboxDescription = value.toolboxDescription;\r\n        return result;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Column = function (data, htmlId, htmlClass, htmlStyle, isTemplated, width, offset, children) {\r\n        LayoutEditor.Element.call(this, \"Column\", data, htmlId, htmlClass, htmlStyle, isTemplated);\r\n        LayoutEditor.Container.call(this, [\"Grid\", \"Content\"], children);\r\n\r\n        this.width = width;\r\n        this.offset = offset;\r\n\r\n        var _hasPendingChange = false;\r\n        var _origWidth = 0;\r\n        var _origOffset = 0;\r\n\r\n        this.beginChange = function () {\r\n            if (!!_hasPendingChange)\r\n                throw new Error(\"Column already has a pending change.\")\r\n            _hasPendingChange = true;\r\n            _origWidth = this.width;\r\n            _origOffset = this.offset;\r\n        };\r\n\r\n        this.commitChange = function () {\r\n            if (!_hasPendingChange)\r\n                throw new Error(\"Column has no pending change.\")\r\n            _origWidth = 0;\r\n            _origOffset = 0;\r\n            _hasPendingChange = false;\r\n        };\r\n\r\n        this.rollbackChange = function () {\r\n            if (!_hasPendingChange)\r\n                throw new Error(\"Column has no pending change.\")\r\n            this.width = _origWidth;\r\n            this.offset = _origOffset;\r\n            _origWidth = 0;\r\n            _origOffset = 0;\r\n            _hasPendingChange = false;\r\n        };\r\n\r\n        this.canSplit = function () {\r\n            return this.width > 1;\r\n        };\r\n\r\n        this.split = function () {\r\n            if (!this.canSplit())\r\n                return;\r\n\r\n            var newColumnWidth = Math.floor(this.width / 2);\r\n            var newColumn = LayoutEditor.Column.from({\r\n                data: null,\r\n                htmlId: null,\r\n                htmlClass: null,\r\n                htmlStyle: null,\r\n                width: newColumnWidth,\r\n                offset: 0,\r\n                children: []\r\n            });\r\n            \r\n            this.width = this.width - newColumnWidth;\r\n            this.parent.insertChild(newColumn, this);\r\n            newColumn.setIsFocused();\r\n        };\r\n\r\n        this.canContractRight = function (connectAdjacent) {\r\n            return this.parent.canContractColumnRight(this, connectAdjacent);\r\n        };\r\n\r\n        this.contractRight = function (connectAdjacent) {\r\n            this.parent.contractColumnRight(this, connectAdjacent);\r\n        };\r\n\r\n        this.canExpandRight = function (connectAdjacent) {\r\n            return this.parent.canExpandColumnRight(this, connectAdjacent);\r\n        };\r\n\r\n        this.expandRight = function (connectAdjacent) {\r\n            this.parent.expandColumnRight(this, connectAdjacent);\r\n        };\r\n\r\n        this.canExpandLeft = function (connectAdjacent) {\r\n            return this.parent.canExpandColumnLeft(this, connectAdjacent);\r\n        };\r\n\r\n        this.expandLeft = function (connectAdjacent) {\r\n            this.parent.expandColumnLeft(this, connectAdjacent);\r\n        };\r\n\r\n        this.canContractLeft = function (connectAdjacent) {\r\n            return this.parent.canContractColumnLeft(this, connectAdjacent);\r\n        };\r\n\r\n        this.contractLeft = function (connectAdjacent) {\r\n            this.parent.contractColumnLeft(this, connectAdjacent);\r\n        };\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.width = this.width;\r\n            result.offset = this.offset;\r\n            result.children = this.childrenToObject();\r\n            return result;\r\n        };\r\n    };\r\n\r\n    LayoutEditor.Column.from = function (value) {\r\n        var result = new LayoutEditor.Column(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.width,\r\n            value.offset,\r\n            LayoutEditor.childrenFrom(value.children));\r\n        result.toolboxIcon = value.toolboxIcon;\r\n        result.toolboxLabel = value.toolboxLabel;\r\n        result.toolboxDescription = value.toolboxDescription;\r\n        return result;\r\n    };\r\n\r\n    LayoutEditor.Column.times = function (value) {\r\n        return _.times(value, function (n) {\r\n            return LayoutEditor.Column.from({\r\n                data: null,\r\n                htmlId: null,\r\n                htmlClass: null,\r\n                isTemplated: false,\r\n                width: 12 / value,\r\n                offset: 0,\r\n                children: []\r\n            });\r\n        });\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Content = function (data, htmlId, htmlClass, htmlStyle, isTemplated, contentType, contentTypeLabel, contentTypeClass, html, hasEditor) {\r\n        LayoutEditor.Element.call(this, \"Content\", data, htmlId, htmlClass, htmlStyle, isTemplated);\r\n\r\n        this.contentType = contentType;\r\n        this.contentTypeLabel = contentTypeLabel;\r\n        this.contentTypeClass = contentTypeClass;\r\n        this.html = html;\r\n        this.hasEditor = hasEditor;\r\n\r\n        this.getInnerText = function () {\r\n            return $($.parseHTML(\"<div>\" + this.html + \"</div>\")).text();\r\n        };\r\n\r\n        // This function will be overwritten by the Content directive.\r\n        this.setHtml = function (html) {\r\n            this.html = html;\r\n            this.htmlUnsafe = html;\r\n        }\r\n\r\n        this.toObject = function () {\r\n            return {\r\n                \"type\": \"Content\"\r\n            };\r\n        };\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.contentType = this.contentType;\r\n            result.contentTypeLabel = this.contentTypeLabel;\r\n            result.contentTypeClass = this.contentTypeClass;\r\n            result.html = this.html;\r\n            result.hasEditor = hasEditor;\r\n            return result;\r\n        };\r\n\r\n        this.setHtml(html);\r\n    };\r\n\r\n    LayoutEditor.Content.from = function (value) {\r\n        var result = new LayoutEditor.Content(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.contentType,\r\n            value.contentTypeLabel,\r\n            value.contentTypeClass,\r\n            value.html,\r\n            value.hasEditor);\r\n\r\n        return result;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function ($, LayoutEditor) {\r\n\r\n    LayoutEditor.Html = function (data, htmlId, htmlClass, htmlStyle, isTemplated, contentType, contentTypeLabel, contentTypeClass, html, hasEditor) {\r\n        LayoutEditor.Element.call(this, \"Html\", data, htmlId, htmlClass, htmlStyle, isTemplated);\r\n\r\n        this.contentType = contentType;\r\n        this.contentTypeLabel = contentTypeLabel;\r\n        this.contentTypeClass = contentTypeClass;\r\n        this.html = html;\r\n        this.hasEditor = hasEditor;\r\n        this.isContainable = true;\r\n\r\n        this.getInnerText = function () {\r\n            return $($.parseHTML(\"<div>\" + this.html + \"</div>\")).text();\r\n        };\r\n\r\n        // This function will be overwritten by the Content directive.\r\n        this.setHtml = function (html) {\r\n            this.html = html;\r\n            this.htmlUnsafe = html;\r\n        }\r\n\r\n        this.toObject = function () {\r\n            return {\r\n                \"type\": \"Html\"\r\n            };\r\n        };\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.contentType = this.contentType;\r\n            result.contentTypeLabel = this.contentTypeLabel;\r\n            result.contentTypeClass = this.contentTypeClass;\r\n            result.html = this.html;\r\n            result.hasEditor = hasEditor;\r\n            return result;\r\n        };\r\n\r\n        var getEditorObject = this.getEditorObject;\r\n        this.getEditorObject = function () {\r\n            var dto = getEditorObject();\r\n            return $.extend(dto, {\r\n                Content: this.html\r\n            });\r\n        }\r\n\r\n        this.setHtml(html);\r\n    };\r\n\r\n    LayoutEditor.Html.from = function (value) {\r\n        var result = new LayoutEditor.Html(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.contentType,\r\n            value.contentTypeLabel,\r\n            value.contentTypeClass,\r\n            value.html,\r\n            value.hasEditor);\r\n\r\n        return result;\r\n    };\r\n\r\n    LayoutEditor.registerFactory(\"Html\", function(value) { return LayoutEditor.Html.from(value); });\r\n\r\n})(jQuery, LayoutEditor || (LayoutEditor = {}));"],"sourceRoot":"/source/"} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.min.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.min.js index 9e2520803..740af1ba0 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.min.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.min.js @@ -1 +1 @@ -var LayoutEditor;!function(t){Array.prototype.move=function(t,i){this.splice(i,0,this.splice(t,1)[0])},t.childrenFrom=function(i){return _(i).map(function(i){return t.elementFrom(i)})};var i=t.registerFactory=function(i,n){var e=t.factories=t.factories||{};e[i]=n};i("Grid",function(i){return t.Grid.from(i)}),i("Row",function(i){return t.Row.from(i)}),i("Column",function(i){return t.Column.from(i)}),i("Content",function(i){return t.Content.from(i)}),t.elementFrom=function(i){var n=t.factories[i.type];if(!n)throw new Error('No element with type "'+i.type+'" was found.');var e=n(i);return e},t.setModel=function(t,i){$(t).scope().element=i},t.getModel=function(t){return $(t).scope().element}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Editor=function(i,n){this.config=i,this.canvas=t.Canvas.from(n),this.initialState=JSON.stringify(this.canvas.toObject()),this.activeElement=null,this.focusedElement=null,this.dropTargetElement=null,this.isDragging=!1,this.inlineEditingIsActive=!1,this.isResizing=!1,this.resetToolboxElements=function(){this.toolboxElements=[t.Row.from({children:[]})]},this.isDirty=function(){var t=JSON.stringify(this.canvas.toObject());return this.initialState!=t},this.resetToolboxElements(),this.canvas.setEditor(this)}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Element=function(t,i,n,e,h,o){if(!t)throw new Error("Parameter 'type' is required.");this.type=t,this.data=i,this.htmlId=n,this.htmlClass=e,this.htmlStyle=h,this.isTemplated=o,this.editor=null,this.parent=null,this.setIsFocusedEventHandlers=[],this.setEditor=function(t){this.editor=t,this.children&&_.isArray(this.children)&&_(this.children).each(function(i){i.setEditor(t)})},this.setParent=function(t){this.parent=t,this.parent.linkChild&&this.parent.linkChild(this)},this.setIsTemplated=function(t){this.isTemplated=t,this.children&&_.isArray(this.children)&&_(this.children).each(function(i){i.setIsTemplated(t)})},this.getIsActive=function(){return this.editor?this.editor.activeElement===this&&!this.getIsFocused():!1},this.setIsActive=function(t){this.editor&&(this.editor.isDragging||this.editor.inlineEditingIsActive||this.editor.isResizing||(this.editor.activeElement=t?this:this.parent))},this.getIsFocused=function(){return this.editor?this.editor.focusedElement===this:!1},this.setIsFocused=function(){this.editor&&(this.isTemplated||this.editor.isDragging||this.editor.inlineEditingIsActive||this.editor.isResizing||(this.editor.focusedElement=this,_(this.setIsFocusedEventHandlers).each(function(t){try{t()}catch(i){}})))},this.getIsSelected=function(){return this.getIsFocused()?!0:this.children&&_.isArray(this.children)?_(this.children).any(function(t){return t.getIsSelected()}):!1},this.getIsDropTarget=function(){return this.editor?this.editor.dropTargetElement===this:!1},this.setIsDropTarget=function(t){this.editor&&(this.editor.dropTargetElement=t?this:null)},this["delete"]=function(){this.parent&&this.parent.deleteChild(this)},this.canMoveUp=function(){return this.parent?this.parent.canMoveChildUp(this):!1},this.moveUp=function(){this.parent&&this.parent.moveChildUp(this)},this.canMoveDown=function(){return this.parent?this.parent.canMoveChildDown(this):!1},this.moveDown=function(){this.parent&&this.parent.moveChildDown(this)},this.elementToObject=function(){return{type:this.type,data:this.data,htmlId:this.htmlId,htmlClass:this.htmlClass,htmlStyle:this.htmlStyle,isTemplated:this.isTemplated}},this.getEditorObject=function(){return{}},this.copy=function(t){var i=this.getInnerText();t.setData("text/plain",i);var n=this.toObject(),e=JSON.stringify(n,null," ");t.setData("text/json",e)},this.cut=function(t){this.copy(t),this["delete"]()},this.paste=function(t){this.parent&&this.parent.paste(t)}}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Container=function(i,n){this.allowedChildTypes=i,this.children=n,this.isContainer=!0;var e=this;this.setChildren=function(t){this.children=t,_(this.children).each(function(t){t.parent=e})},this.setChildren(n),this.getIsSealed=function(){return _(this.children).any(function(t){return t.isTemplated})},this.addChild=function(t){_(this.children).contains(t)||!_(this.allowedChildTypes).contains(t.type)&&!t.isContainable||this.children.push(t),t.setEditor(this.editor),t.setIsTemplated(!1),t.parent=this},this.deleteChild=function(t){var i=_(this.children).indexOf(t);i>=0&&(this.children.splice(i,1),t.getIsActive()&&(this.editor.activeElement=null),t.getIsFocused()&&(this.children.length>i?this.children[i].setIsFocused():i>0?this.children[i-1].setIsFocused():this.setIsFocused()))},this.moveFocusPrevChild=function(t){if(!(this.children.length<2)){var i=_(this.children).indexOf(t);i>0&&this.children[i-1].setIsFocused()}},this.moveFocusNextChild=function(t){if(!(this.children.length<2)){var i=_(this.children).indexOf(t);i0},this.canMoveChildDown=function(t){var i=_(this.children).indexOf(t);return i0?t.width<12:0>e?t.width>1:!1}if(0==t)return!0;var e=t;if(0>e){var h=12-l();e+=h,e>0&&(e=0)}for(;0>e&&_(a.children).any(function(t){return t.offset>0});)for(i=0;ie;i++){var o=a.children[i];o.offset>0&&(o.offset--,e++)}for(;0!=e&&_(a.children).any(n);)for(i=0;i=0?t.width>1:!1},this.contractColumnRight=function(t,i){if(this.canContractColumnRight(t,i)){var n=_(this.children).indexOf(t);if(n>=0&&t.width>1&&(t.width--,this.children.length>n+1)){var e=this.children[n+1];i&&0==e.offset?e.width++:e.offset++}}},this.canExpandColumnRight=function(t,i){var n=_(this.children).indexOf(t);if(n>=0){if(t.width>=12)return!1;if(this.children.length>n+1){var e=this.children[n+1];return i&&0==e.offset?e.width>1:e.offset>0}return l()<12}return!1},this.expandColumnRight=function(t,i){if(this.canExpandColumnRight(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(this.children.length>n+1){var e=this.children[n+1];i&&0==e.offset?e.width--:e.offset--}t.width++}}},this.canExpandColumnLeft=function(t,i){var n=_(this.children).indexOf(t);if(n>=0){if(t.width>=12)return!1;if(n>0){var e=this.children[n-1];if(i&&0==t.offset)return e.width>1}return t.offset>0}return!1},this.expandColumnLeft=function(t,i){if(this.canExpandColumnLeft(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(n>0){var e=this.children[n-1];i&&0==t.offset?e.width--:t.offset--}else t.offset--;t.width++}}},this.canContractColumnLeft=function(t,i){var n=_(this.children).indexOf(t);return n>=0?t.width>1:!1},this.contractColumnLeft=function(t,i){if(this.canContractColumnLeft(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(n>0){var e=this.children[n-1];i&&0==t.offset?e.width++:t.offset++}else t.offset++;t.width--}}},this.evenColumns=function(){if(0!=this.children.length){var t=Math.floor(12/this.children.length);_(this.children).each(function(i){i.width=t,i.offset=0});var i=12%this.children.length;i>0&&c(i)}};var f=this.pasteChild;this.pasteChild=function(t){"Column"==t.type?this.beginAddColumn(t.width)&&(this.commitAddColumn(),f.call(this,t)):this.parent&&this.parent.pasteChild(t)},this.toObject=function(){var t=this.elementToObject();return t.children=this.childrenToObject(),t}},t.Row.from=function(i){var n=new t.Row(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,t.childrenFrom(i.children));return n.toolboxIcon=i.toolboxIcon,n.toolboxLabel=i.toolboxLabel,n.toolboxDescription=i.toolboxDescription,n}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Column=function(i,n,e,h,o,s,r,l){t.Element.call(this,"Column",i,n,e,h,o),t.Container.call(this,["Grid","Content"],l),this.width=s,this.offset=r;var c=!1,a=0,d=0;this.beginChange=function(){if(c)throw new Error("Column already has a pending change.");c=!0,a=this.width,d=this.offset},this.commitChange=function(){if(!c)throw new Error("Column has no pending change.");a=0,d=0,c=!1},this.rollbackChange=function(){if(!c)throw new Error("Column has no pending change.");this.width=a,this.offset=d,a=0,d=0,c=!1},this.canSplit=function(){return this.width>1},this.split=function(){if(this.canSplit()){var i=Math.floor(this.width/2),n=t.Column.from({data:null,htmlId:null,htmlClass:null,htmlStyle:null,width:i,offset:0,children:[]});this.width=this.width-i,this.parent.insertChild(n,this),n.setIsFocused()}},this.canContractRight=function(t){return this.parent.canContractColumnRight(this,t)},this.contractRight=function(t){this.parent.contractColumnRight(this,t)},this.canExpandRight=function(t){return this.parent.canExpandColumnRight(this,t)},this.expandRight=function(t){this.parent.expandColumnRight(this,t)},this.canExpandLeft=function(t){return this.parent.canExpandColumnLeft(this,t)},this.expandLeft=function(t){this.parent.expandColumnLeft(this,t)},this.canContractLeft=function(t){return this.parent.canContractColumnLeft(this,t)},this.contractLeft=function(t){this.parent.contractColumnLeft(this,t)},this.toObject=function(){var t=this.elementToObject();return t.width=this.width,t.offset=this.offset,t.children=this.childrenToObject(),t}},t.Column.from=function(i){var n=new t.Column(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.width,i.offset,t.childrenFrom(i.children));return n.toolboxIcon=i.toolboxIcon,n.toolboxLabel=i.toolboxLabel,n.toolboxDescription=i.toolboxDescription,n},t.Column.times=function(i){return _.times(i,function(n){return t.Column.from({data:null,htmlId:null,htmlClass:null,isTemplated:!1,width:12/i,offset:0,children:[]})})}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Content=function(i,n,e,h,o,s,r,l,c,a){t.Element.call(this,"Content",i,n,e,h,o),this.contentType=s,this.contentTypeLabel=r,this.contentTypeClass=l,this.html=c,this.hasEditor=a,this.getInnerText=function(){return $($.parseHTML("
"+this.html+"
")).text()},this.setHtml=function(t){this.html=t,this.htmlUnsafe=t},this.toObject=function(){return{type:"Content"}},this.toObject=function(){var t=this.elementToObject();return t.contentType=this.contentType,t.contentTypeLabel=this.contentTypeLabel,t.contentTypeClass=this.contentTypeClass,t.html=this.html,t.hasEditor=a,t},this.setHtml(c)},t.Content.from=function(i){var n=new t.Content(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.contentType,i.contentTypeLabel,i.contentTypeClass,i.html,i.hasEditor);return n}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t,i){i.Html=function(n,e,h,o,s,r,l,c,a,d){i.Element.call(this,"Html",n,e,h,o,s),this.contentType=r,this.contentTypeLabel=l,this.contentTypeClass=c,this.html=a,this.hasEditor=d,this.isContainable=!0,this.getInnerText=function(){return t(t.parseHTML("
"+this.html+"
")).text()},this.setHtml=function(t){this.html=t,this.htmlUnsafe=t},this.toObject=function(){return{type:"Html"}},this.toObject=function(){var t=this.elementToObject();return t.contentType=this.contentType,t.contentTypeLabel=this.contentTypeLabel,t.contentTypeClass=this.contentTypeClass,t.html=this.html,t.hasEditor=d,t};var u=this.getEditorObject;this.getEditorObject=function(){var i=u();return t.extend(i,{Content:this.html})},this.setHtml(a)},i.Html.from=function(t){var n=new i.Html(t.data,t.htmlId,t.htmlClass,t.htmlStyle,t.isTemplated,t.contentType,t.contentTypeLabel,t.contentTypeClass,t.html,t.hasEditor);return n},i.registerFactory("Html",function(t){return i.Html.from(t)})}(jQuery,LayoutEditor||(LayoutEditor={})); \ No newline at end of file +var LayoutEditor;!function(t){Array.prototype.move=function(t,i){this.splice(i,0,this.splice(t,1)[0])},t.childrenFrom=function(i){return _(i).map(function(i){return t.elementFrom(i)})};var i=t.registerFactory=function(i,n){var e=t.factories=t.factories||{};e[i]=n};i("Grid",function(i){return t.Grid.from(i)}),i("Row",function(i){return t.Row.from(i)}),i("Column",function(i){return t.Column.from(i)}),i("Content",function(i){return t.Content.from(i)}),t.elementFrom=function(i){var n=t.factories[i.type];if(!n)throw new Error('No element with type "'+i.type+'" was found.');var e=n(i);return e},t.setModel=function(t,i){$(t).scope().element=i},t.getModel=function(t){return $(t).scope().element}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Editor=function(i,n){this.config=i,this.canvas=t.Canvas.from(n),this.initialState=JSON.stringify(this.canvas.toObject()),this.activeElement=null,this.focusedElement=null,this.dropTargetElement=null,this.isDragging=!1,this.inlineEditingIsActive=!1,this.isResizing=!1,this.resetToolboxElements=function(){this.toolboxElements=[t.Row.from({children:[]})]},this.isDirty=function(){var t=JSON.stringify(this.canvas.toObject());return this.initialState!=t},this.resetToolboxElements(),this.canvas.setEditor(this)}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Element=function(t,i,n,e,h,o){if(!t)throw new Error("Parameter 'type' is required.");this.type=t,this.data=i,this.htmlId=n,this.htmlClass=e,this.htmlStyle=h,this.isTemplated=o,this.editor=null,this.parent=null,this.setIsFocusedEventHandlers=[],this.setEditor=function(t){this.editor=t,this.children&&_.isArray(this.children)&&_(this.children).each(function(i){i.setEditor(t)})},this.setParent=function(t){this.parent=t,this.parent.onChildAdded(this);for(var i=t;i;)i.onDescendantAdded(this,t),i=i.parent},this.setIsTemplated=function(t){this.isTemplated=t,this.children&&_.isArray(this.children)&&_(this.children).each(function(i){i.setIsTemplated(t)})},this.applyElementEditorModel=function(){},this.getIsActive=function(){return this.editor?this.editor.activeElement===this&&!this.getIsFocused():!1},this.setIsActive=function(t){this.editor&&(this.editor.isDragging||this.editor.inlineEditingIsActive||this.editor.isResizing||(this.editor.activeElement=t?this:this.parent))},this.getIsFocused=function(){return this.editor?this.editor.focusedElement===this:!1},this.setIsFocused=function(){this.editor&&(this.isTemplated||this.editor.isDragging||this.editor.inlineEditingIsActive||this.editor.isResizing||(this.editor.focusedElement=this,_(this.setIsFocusedEventHandlers).each(function(t){try{t()}catch(i){}})))},this.getIsSelected=function(){return this.getIsFocused()?!0:this.children&&_.isArray(this.children)?_(this.children).any(function(t){return t.getIsSelected()}):!1},this.getIsDropTarget=function(){return this.editor?this.editor.dropTargetElement===this:!1},this.setIsDropTarget=function(t){this.editor&&(this.editor.dropTargetElement=t?this:null)},this["delete"]=function(){this.parent&&this.parent.deleteChild(this)},this.canMoveUp=function(){return this.parent?this.parent.canMoveChildUp(this):!1},this.moveUp=function(){this.parent&&this.parent.moveChildUp(this)},this.canMoveDown=function(){return this.parent?this.parent.canMoveChildDown(this):!1},this.moveDown=function(){this.parent&&this.parent.moveChildDown(this)},this.elementToObject=function(){return{type:this.type,data:this.data,htmlId:this.htmlId,htmlClass:this.htmlClass,htmlStyle:this.htmlStyle,isTemplated:this.isTemplated}},this.getEditorObject=function(){return{}},this.copy=function(t){var i=this.getInnerText();t.setData("text/plain",i);var n=this.toObject(),e=JSON.stringify(n,null," ");t.setData("text/json",e)},this.cut=function(t){this.copy(t),this["delete"]()},this.paste=function(t){this.parent&&this.parent.paste(t)}}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Container=function(i,n){this.allowedChildTypes=i,this.children=n,this.isContainer=!0;var e=this;this.onChildAdded=function(t){},this.onDescendantAdded=function(t,i){},this.setChildren=function(t){this.children=t,_(this.children).each(function(t){t.setParent(e)})},this.setChildren(n),this.getIsSealed=function(){return _(this.children).any(function(t){return t.isTemplated})},this.addChild=function(t){_(this.children).contains(t)||!_(this.allowedChildTypes).contains(t.type)&&!t.isContainable||this.children.push(t),t.setEditor(this.editor),t.setIsTemplated(!1),t.setParent(this)},this.deleteChild=function(t){var i=_(this.children).indexOf(t);i>=0&&(this.children.splice(i,1),t.getIsActive()&&(this.editor.activeElement=null),t.getIsFocused()&&(this.children.length>i?this.children[i].setIsFocused():i>0?this.children[i-1].setIsFocused():this.setIsFocused()))},this.moveFocusPrevChild=function(t){if(!(this.children.length<2)){var i=_(this.children).indexOf(t);i>0&&this.children[i-1].setIsFocused()}},this.moveFocusNextChild=function(t){if(!(this.children.length<2)){var i=_(this.children).indexOf(t);i0},this.canMoveChildDown=function(t){var i=_(this.children).indexOf(t);return i0?t.width<12:0>e?t.width>1:!1}if(0==t)return!0;var e=t;if(0>e){var h=12-l();e+=h,e>0&&(e=0)}for(;0>e&&_(a.children).any(function(t){return t.offset>0});)for(i=0;ie;i++){var o=a.children[i];o.offset>0&&(o.offset--,e++)}for(;0!=e&&_(a.children).any(n);)for(i=0;i=0?t.width>1:!1},this.contractColumnRight=function(t,i){if(this.canContractColumnRight(t,i)){var n=_(this.children).indexOf(t);if(n>=0&&t.width>1&&(t.width--,this.children.length>n+1)){var e=this.children[n+1];i&&0==e.offset?e.width++:e.offset++}}},this.canExpandColumnRight=function(t,i){var n=_(this.children).indexOf(t);if(n>=0){if(t.width>=12)return!1;if(this.children.length>n+1){var e=this.children[n+1];return i&&0==e.offset?e.width>1:e.offset>0}return l()<12}return!1},this.expandColumnRight=function(t,i){if(this.canExpandColumnRight(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(this.children.length>n+1){var e=this.children[n+1];i&&0==e.offset?e.width--:e.offset--}t.width++}}},this.canExpandColumnLeft=function(t,i){var n=_(this.children).indexOf(t);if(n>=0){if(t.width>=12)return!1;if(n>0){var e=this.children[n-1];if(i&&0==t.offset)return e.width>1}return t.offset>0}return!1},this.expandColumnLeft=function(t,i){if(this.canExpandColumnLeft(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(n>0){var e=this.children[n-1];i&&0==t.offset?e.width--:t.offset--}else t.offset--;t.width++}}},this.canContractColumnLeft=function(t,i){var n=_(this.children).indexOf(t);return n>=0?t.width>1:!1},this.contractColumnLeft=function(t,i){if(this.canContractColumnLeft(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(n>0){var e=this.children[n-1];i&&0==t.offset?e.width++:t.offset++}else t.offset++;t.width--}}},this.evenColumns=function(){if(0!=this.children.length){var t=Math.floor(12/this.children.length);_(this.children).each(function(i){i.width=t,i.offset=0});var i=12%this.children.length;i>0&&c(i)}};var f=this.pasteChild;this.pasteChild=function(t){"Column"==t.type?this.beginAddColumn(t.width)&&(this.commitAddColumn(),f.call(this,t)):this.parent&&this.parent.pasteChild(t)},this.toObject=function(){var t=this.elementToObject();return t.children=this.childrenToObject(),t}},t.Row.from=function(i){var n=new t.Row(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,t.childrenFrom(i.children));return n.toolboxIcon=i.toolboxIcon,n.toolboxLabel=i.toolboxLabel,n.toolboxDescription=i.toolboxDescription,n}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Column=function(i,n,e,h,o,s,r,l){t.Element.call(this,"Column",i,n,e,h,o),t.Container.call(this,["Grid","Content"],l),this.width=s,this.offset=r;var c=!1,a=0,d=0;this.beginChange=function(){if(c)throw new Error("Column already has a pending change.");c=!0,a=this.width,d=this.offset},this.commitChange=function(){if(!c)throw new Error("Column has no pending change.");a=0,d=0,c=!1},this.rollbackChange=function(){if(!c)throw new Error("Column has no pending change.");this.width=a,this.offset=d,a=0,d=0,c=!1},this.canSplit=function(){return this.width>1},this.split=function(){if(this.canSplit()){var i=Math.floor(this.width/2),n=t.Column.from({data:null,htmlId:null,htmlClass:null,htmlStyle:null,width:i,offset:0,children:[]});this.width=this.width-i,this.parent.insertChild(n,this),n.setIsFocused()}},this.canContractRight=function(t){return this.parent.canContractColumnRight(this,t)},this.contractRight=function(t){this.parent.contractColumnRight(this,t)},this.canExpandRight=function(t){return this.parent.canExpandColumnRight(this,t)},this.expandRight=function(t){this.parent.expandColumnRight(this,t)},this.canExpandLeft=function(t){return this.parent.canExpandColumnLeft(this,t)},this.expandLeft=function(t){this.parent.expandColumnLeft(this,t)},this.canContractLeft=function(t){return this.parent.canContractColumnLeft(this,t)},this.contractLeft=function(t){this.parent.contractColumnLeft(this,t)},this.toObject=function(){var t=this.elementToObject();return t.width=this.width,t.offset=this.offset,t.children=this.childrenToObject(),t}},t.Column.from=function(i){var n=new t.Column(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.width,i.offset,t.childrenFrom(i.children));return n.toolboxIcon=i.toolboxIcon,n.toolboxLabel=i.toolboxLabel,n.toolboxDescription=i.toolboxDescription,n},t.Column.times=function(i){return _.times(i,function(n){return t.Column.from({data:null,htmlId:null,htmlClass:null,isTemplated:!1,width:12/i,offset:0,children:[]})})}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Content=function(i,n,e,h,o,s,r,l,c,a){t.Element.call(this,"Content",i,n,e,h,o),this.contentType=s,this.contentTypeLabel=r,this.contentTypeClass=l,this.html=c,this.hasEditor=a,this.getInnerText=function(){return $($.parseHTML("
"+this.html+"
")).text()},this.setHtml=function(t){this.html=t,this.htmlUnsafe=t},this.toObject=function(){return{type:"Content"}},this.toObject=function(){var t=this.elementToObject();return t.contentType=this.contentType,t.contentTypeLabel=this.contentTypeLabel,t.contentTypeClass=this.contentTypeClass,t.html=this.html,t.hasEditor=a,t},this.setHtml(c)},t.Content.from=function(i){var n=new t.Content(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.contentType,i.contentTypeLabel,i.contentTypeClass,i.html,i.hasEditor);return n}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t,i){i.Html=function(n,e,h,o,s,r,l,c,a,d){i.Element.call(this,"Html",n,e,h,o,s),this.contentType=r,this.contentTypeLabel=l,this.contentTypeClass=c,this.html=a,this.hasEditor=d,this.isContainable=!0,this.getInnerText=function(){return t(t.parseHTML("
"+this.html+"
")).text()},this.setHtml=function(t){this.html=t,this.htmlUnsafe=t},this.toObject=function(){return{type:"Html"}},this.toObject=function(){var t=this.elementToObject();return t.contentType=this.contentType,t.contentTypeLabel=this.contentTypeLabel,t.contentTypeClass=this.contentTypeClass,t.html=this.html,t.hasEditor=d,t};var u=this.getEditorObject;this.getEditorObject=function(){var i=u();return t.extend(i,{Content:this.html})},this.setHtml(a)},i.Html.from=function(t){var n=new i.Html(t.data,t.htmlId,t.htmlClass,t.htmlStyle,t.isTemplated,t.contentType,t.contentTypeLabel,t.contentTypeClass,t.html,t.hasEditor);return n},i.registerFactory("Html",function(t){return i.Html.from(t)})}(jQuery,LayoutEditor||(LayoutEditor={})); \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Container.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Container.js index ad732d545..b91ab5f08 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Container.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Container.js @@ -7,12 +7,15 @@ this.children = children; this.isContainer = true; - var _self = this; + var self = this; + + this.onChildAdded = function (element) { /* Virtual */ }; + this.onDescendantAdded = function (element, parentElement) { /* Virtual */ }; this.setChildren = function (children) { this.children = children; _(this.children).each(function (child) { - child.parent = _self; + child.setParent(self); }); }; @@ -29,7 +32,7 @@ this.children.push(child); child.setEditor(this.editor); child.setIsTemplated(false); - child.parent = this; + child.setParent(this); }; this.deleteChild = function (child) { diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Element.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Element.js index 2cd44511e..370571cb2 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Element.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Element.js @@ -27,9 +27,13 @@ this.setParent = function(parentElement) { this.parent = parentElement; + this.parent.onChildAdded(this); - if (!!this.parent.linkChild) - this.parent.linkChild(this); + var currentAncestor = parentElement; + while (!!currentAncestor) { + currentAncestor.onDescendantAdded(this, parentElement); + currentAncestor = currentAncestor.parent; + } }; this.setIsTemplated = function (value) { @@ -41,6 +45,8 @@ } }; + this.applyElementEditorModel = function() { /* Virtual */ }; + this.getIsActive = function () { if (!this.editor) return false; From 1fe436e05a64c4a3a44fe1887ea0a0c87b33c029 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Sat, 4 Jul 2015 09:32:51 +0200 Subject: [PATCH 11/17] Fixed incorrect method error. --- .../Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js | 2 +- .../Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js | 2 +- .../Scripts/LayoutEditor/Directives/Form.js | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js index 13fabe29a..dc29855df 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.js @@ -189,7 +189,7 @@ angular if (args.cancel) return; - $scope.apply(function() { + $scope.$apply(function() { $scope.element.data = decodeURIComponent(args.element.data); $scope.element.applyElementEditorModel(args.elementEditorModel); }); diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js index 2564bccce..f16311228 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor.min.js @@ -1 +1 @@ -var LayoutEditor;!function(e,t){t.Fieldset=function(n,i,o,r,l,d,a,c,s,h,m){t.Element.call(this,"Fieldset",n,i,o,r,l),t.Container.call(this,["Grid","Content"],m);var u=this;this.isContainable=!0,this.dropTargetClass="layout-common-holder",this.contentType=a,this.contentTypeLabel=c,this.contentTypeClass=s,this.legend=d||"",this.hasEditor=h,this.toObject=function(){var e=this.elementToObject();return e.legend=this.legend,e.children=this.childrenToObject(),e};var p=this.getEditorObject;this.getEditorObject=function(){var t=p();return e.extend(t,{Legend:this.legend})},this.setChildren=function(e){this.children=e,_(this.children).each(function(e){e.parent=u})},this.applyElementEditorModel=function(e){this.legend=e.legend},this.setChildren(m)},t.Fieldset.from=function(e){return new t.Fieldset(e.data,e.htmlId,e.htmlClass,e.htmlStyle,e.isTemplated,e.legend,e.contentType,e.contentTypeLabel,e.contentTypeClass,e.hasEditor,t.childrenFrom(e.children))},t.registerFactory("Fieldset",function(e){return t.Fieldset.from(e)})}(jQuery,LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(e,t){t.Form=function(n,i,o,r,l,d,a,c,s,h,m,u){t.Element.call(this,"Form",n,i,o,r,l),t.Container.call(this,["Grid","Content"],u);var p=this;this.isContainable=!0,this.dropTargetClass="layout-common-holder",this.contentType=c,this.contentTypeLabel=s,this.contentTypeClass=h,this.name=d||"Untitled",this.formBindingContentType=a,this.hasEditor=m,this.toObject=function(){var e=this.elementToObject();return e.name=this.name,e.formBindingContentType=this.formBindingContentType,e.children=this.childrenToObject(),e};var f=this.getEditorObject;this.getEditorObject=function(){var t=f();return e.extend(t,{FormName:this.name,FormBindingContentType:this.formBindingContentType})},this.setChildren=function(e){this.children=e,_(this.children).each(function(e){e.setParent(p)})},this.onDescendantAdded=function(t){var n=t.getEditorObject;t.getEditorObject=function(){var t=n();return e.extend(t,{FormBindingContentType:p.formBindingContentType})}},this.applyElementEditorModel=function(e){this.name=e.name,this.formBindingContentType=e.formBindingContentType},this.setChildren(u)},t.Form.from=function(e){return new t.Form(e.data,e.htmlId,e.htmlClass,e.htmlStyle,e.isTemplated,e.name,e.formBindingContentType,e.contentType,e.contentTypeLabel,e.contentTypeClass,e.hasEditor,t.childrenFrom(e.children))},t.registerFactory("Form",function(e){return t.Form.from(e)})}(jQuery,LayoutEditor||(LayoutEditor={})),angular.module("LayoutEditor").directive("orcLayoutFieldset",["$compile","scopeConfigurator","environment",function(e,t,n){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,n){t.configureForElement(e,n),t.configureForContainer(e,n),e.sortableOptions.axis="y",e.edit=function(){e.$root.editElement(e.element).then(function(t){t.cancel||e.$apply(function(){e.element.data=decodeURIComponent(t.element.data),e.element.applyElementEditorModel(t.elementEditorModel)})})}}],templateUrl:n.templateUrl("Fieldset"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutForm",["$compile","scopeConfigurator","environment",function(e,t,n){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,n){t.configureForElement(e,n),t.configureForContainer(e,n),e.sortableOptions.axis="y",e.edit=function(){e.$root.editElement(e.element).then(function(t){t.cancel||e.apply(function(){e.element.data=decodeURIComponent(t.element.data),e.element.applyElementEditorModel(t.elementEditorModel)})})}}],templateUrl:n.templateUrl("Form"),replace:!0}}]); \ No newline at end of file +var LayoutEditor;!function(e,t){t.Fieldset=function(n,i,o,r,l,d,a,c,s,h,m){t.Element.call(this,"Fieldset",n,i,o,r,l),t.Container.call(this,["Grid","Content"],m);var u=this;this.isContainable=!0,this.dropTargetClass="layout-common-holder",this.contentType=a,this.contentTypeLabel=c,this.contentTypeClass=s,this.legend=d||"",this.hasEditor=h,this.toObject=function(){var e=this.elementToObject();return e.legend=this.legend,e.children=this.childrenToObject(),e};var p=this.getEditorObject;this.getEditorObject=function(){var t=p();return e.extend(t,{Legend:this.legend})},this.setChildren=function(e){this.children=e,_(this.children).each(function(e){e.parent=u})},this.applyElementEditorModel=function(e){this.legend=e.legend},this.setChildren(m)},t.Fieldset.from=function(e){return new t.Fieldset(e.data,e.htmlId,e.htmlClass,e.htmlStyle,e.isTemplated,e.legend,e.contentType,e.contentTypeLabel,e.contentTypeClass,e.hasEditor,t.childrenFrom(e.children))},t.registerFactory("Fieldset",function(e){return t.Fieldset.from(e)})}(jQuery,LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(e,t){t.Form=function(n,i,o,r,l,d,a,c,s,h,m,u){t.Element.call(this,"Form",n,i,o,r,l),t.Container.call(this,["Grid","Content"],u);var p=this;this.isContainable=!0,this.dropTargetClass="layout-common-holder",this.contentType=c,this.contentTypeLabel=s,this.contentTypeClass=h,this.name=d||"Untitled",this.formBindingContentType=a,this.hasEditor=m,this.toObject=function(){var e=this.elementToObject();return e.name=this.name,e.formBindingContentType=this.formBindingContentType,e.children=this.childrenToObject(),e};var f=this.getEditorObject;this.getEditorObject=function(){var t=f();return e.extend(t,{FormName:this.name,FormBindingContentType:this.formBindingContentType})},this.setChildren=function(e){this.children=e,_(this.children).each(function(e){e.setParent(p)})},this.onDescendantAdded=function(t){var n=t.getEditorObject;t.getEditorObject=function(){var t=n();return e.extend(t,{FormBindingContentType:p.formBindingContentType})}},this.applyElementEditorModel=function(e){this.name=e.name,this.formBindingContentType=e.formBindingContentType},this.setChildren(u)},t.Form.from=function(e){return new t.Form(e.data,e.htmlId,e.htmlClass,e.htmlStyle,e.isTemplated,e.name,e.formBindingContentType,e.contentType,e.contentTypeLabel,e.contentTypeClass,e.hasEditor,t.childrenFrom(e.children))},t.registerFactory("Form",function(e){return t.Form.from(e)})}(jQuery,LayoutEditor||(LayoutEditor={})),angular.module("LayoutEditor").directive("orcLayoutFieldset",["$compile","scopeConfigurator","environment",function(e,t,n){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,n){t.configureForElement(e,n),t.configureForContainer(e,n),e.sortableOptions.axis="y",e.edit=function(){e.$root.editElement(e.element).then(function(t){t.cancel||e.$apply(function(){e.element.data=decodeURIComponent(t.element.data),e.element.applyElementEditorModel(t.elementEditorModel)})})}}],templateUrl:n.templateUrl("Fieldset"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutForm",["$compile","scopeConfigurator","environment",function(e,t,n){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,n){t.configureForElement(e,n),t.configureForContainer(e,n),e.sortableOptions.axis="y",e.edit=function(){e.$root.editElement(e.element).then(function(t){t.cancel||e.$apply(function(){e.element.data=decodeURIComponent(t.element.data),e.element.applyElementEditorModel(t.elementEditorModel)})})}}],templateUrl:n.templateUrl("Form"),replace:!0}}]); \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Form.js b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Form.js index c8bee01ce..05f11520d 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Form.js +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Scripts/LayoutEditor/Directives/Form.js @@ -15,7 +15,7 @@ if (args.cancel) return; - $scope.apply(function() { + $scope.$apply(function() { $scope.element.data = decodeURIComponent(args.element.data); $scope.element.applyElementEditorModel(args.elementEditorModel); }); From 1093e16a81e4a3218f1b7e2d3488901ceda94d18 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Sat, 4 Jul 2015 09:36:31 +0200 Subject: [PATCH 12/17] #5452: Improved ContentItem and Projection elements by rendering an abstract representation instead. Fixes #5452 --- .../Styles/forms-admin.css | 9 +- .../Styles/forms-admin.min.css | 2 +- .../Views/Elements/HiddenField.Design.cshtml | 2 +- .../Elements/ValidationMessage.Design.cshtml | 2 +- .../Elements/ValidationSummary.Design.cshtml | 2 +- .../Orchard.Layouts/Orchard.Layouts.csproj | 3 - .../Orchard.Layouts/Styles/LayoutEditor.css | 5 +- .../Styles/LayoutEditor.min.css | 2 +- .../Styles/LayoutEditor/Editor.less | 4 + .../Orchard.Layouts/Styles/designer.css | 321 ------------------ .../Views/Elements/ContentItem.Design.cshtml | 10 +- .../Views/Elements/Projection.Design.cshtml | 17 +- .../Views/Elements/Shape.Design.cshtml | 3 +- .../Views/Layout-Designer-Wrapper.cshtml | 13 - .../Views/Layout-Designer.cshtml | 7 - 15 files changed, 34 insertions(+), 368 deletions(-) delete mode 100644 src/Orchard.Web/Modules/Orchard.Layouts/Styles/designer.css delete mode 100644 src/Orchard.Web/Modules/Orchard.Layouts/Views/Layout-Designer-Wrapper.cshtml delete mode 100644 src/Orchard.Web/Modules/Orchard.Layouts/Views/Layout-Designer.cshtml diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Styles/forms-admin.css b/src/Orchard.Web/Modules/Orchard.DynamicForms/Styles/forms-admin.css index 8016fe8ec..329a53a84 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Styles/forms-admin.css +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Styles/forms-admin.css @@ -1,11 +1,4 @@ -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > .validation-message, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > .validation-summary { - border: 1px dashed #ccc; - padding: 0.2em; - background: #e8e8e8; -} - -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > .form-field-element input[type="text"], +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > .form-field-element input[type="text"], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > .form-field-element input[type="password"], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > .form-field-element input[type="email"], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > .form-field-element input[type="tel"], diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Styles/forms-admin.min.css b/src/Orchard.Web/Modules/Orchard.DynamicForms/Styles/forms-admin.min.css index 0249593e0..199c157e0 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Styles/forms-admin.min.css +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Styles/forms-admin.min.css @@ -1 +1 @@ -.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.validation-message,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.validation-summary{border:1px dashed #ccc;padding:.2em;background:#e8e8e8}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element input[type=text],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element input[type=password],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element input[type=email],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element input[type=tel],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element textarea{width:100%}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element.form-field-element-enumeration ol{list-style:none} \ No newline at end of file +.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element input[type=text],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element input[type=password],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element input[type=email],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element input[type=tel],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element textarea{width:100%}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>.form-field-element.form-field-element-enumeration ol{list-style:none} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/HiddenField.Design.cshtml b/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/HiddenField.Design.cshtml index b87c96360..76e817975 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/HiddenField.Design.cshtml +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/HiddenField.Design.cshtml @@ -2,4 +2,4 @@ @{ var element = (HiddenField) Model.Element; } -
@element.Name
\ No newline at end of file +
@element.Name
\ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/ValidationMessage.Design.cshtml b/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/ValidationMessage.Design.cshtml index 3b8d37ddf..8c828df47 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/ValidationMessage.Design.cshtml +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/ValidationMessage.Design.cshtml @@ -3,7 +3,7 @@ var element = (ValidationMessage)Model.Element; var forField = element.For; } -
+
@if (String.IsNullOrWhiteSpace(forField)) { @T("Validation message (target not specified)") } diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/ValidationSummary.Design.cshtml b/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/ValidationSummary.Design.cshtml index 381ff1c2f..a7da7701a 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/ValidationSummary.Design.cshtml +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Views/Elements/ValidationSummary.Design.cshtml @@ -1 +1 @@ -
@T("Validation summary")
\ No newline at end of file +
@T("Validation summary")
\ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj b/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj index df50eea91..3da9b75dd 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj @@ -148,7 +148,6 @@ - @@ -178,8 +177,6 @@ - - diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.css b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.css index f56724eb4..a2ac0056c 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.css +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.css @@ -23,6 +23,9 @@ .layout-editor > .layout-canvas-wrapper > .layout-toolbar-container > .mce-panel { width: 100% !important; } +.layout-editor .layout-snippet { + background: #e8e8e8; +} .layout-editor .layout-element { position: relative; @@ -1040,4 +1043,4 @@ table[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th { font-size: 0.9em; } -/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Editor.less","LayoutEditor.css","Element.less","Container.less","Canvas.less","Row.less","Column.less","Content.less","Reset.less","Toolbox.less","Popup.less"],"names":[],"mappings":"AAEA;EACI,sBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,gBAAA;EACA,gBAAA;EACA,6BAAA;MAAA,wBAAA;UAAA,qBAAA;CCDH;ADHD;EAOQ,qBAAA;MAAA,qBAAA;UAAA,aAAA;EACA,0BAAA;EACA,0BAAA;CCDP;ADRD;EAYY,cAAA;EACA,oBAAA;EACA,iBAAA;CCDX;ADbD;EAiBgB,uBAAA;CCDf;;AChBD;EAEQ,mBAAA;EACA,cAAA;EACA,gBAAA;EACA,iBAAA;EACA,WAAA;CDkBP;ACfO;EACI,eAAA;CDiBX;AC3BD;EAegB,cAAA;EACA,mBAAA;EACA,UAAA;EACA,YAAA;EACA,aAAA;EACA,eAAA;EACA,iBAAA;EACA,oBAAA;EACA,kBAAA;EACA,uBAAA;CDef;ACvCD;EA2BoB,sBAAA;EACA,aAAA;EACA,mBAAA;CDenB;AC5CD;EAiCoB,gBAAA;CDcnB;AC/CD;EAqCoB,cAAA;EACA,YAAA;EACA,gBAAA;EACA,mBAAA;CDanB;ACrDD;EA6CgB,WAAA;EACA,WAAA;CDWf;ACzDD;EAqDQ,iBAAA;CDOP;ACJG;;EAGQ,kBAAA;EACA,oBAAA;CDKX;ACTG;;EAOY,aAAA;CDMf;ACbG;EAcQ,uCAAA;CDEX;AChBG;EAiBY,eAAA;EACA,YAAA;EACA,2CAAA;CDEf;ACrBG;EA2BQ,sBAAA;CDHX;ACxBG;EA8BY,eAAA;EACA,0BAAA;EACA,eAAA;CDHf;AC7BG;EAmCgB,sBAAA;CDHnB;ACImB;EACI,0BAAA;CDFvB;ACKmB;EACI,gBAAA;EACA,gCAAA;CDHvB;ACKuB;EACI,0BAAA;CDH3B;ACOmB;EACI,eAAA;EACA,0BAAA;CDLvB;ACOuB;EACI,0BAAA;CDL3B;ACjDG;EA+DQ,2CAAA;CDXX;AC5GD;EA4HQ,cAAA;CDbP;AC/GD;EAiIQ,uDAAA;CDfP;AClHD;EAoIY,eAAA;EACA,+BAAA;EACA,iBAAA;EACA,sCAAA;EACA,2CAAA;CDfX;ACzHD;EA+IY,gBAAA;EACA,iBAAA;CDnBX;;AE7HD;EAMgB,cAAA;EACA,+BAAA;MAAA,2BAAA;UAAA,uBAAA;EACA,aAAA;EACA,iBAAA;EACA,4CAAA;EACA,mBAAA;EACA,cAAA;EACA,gCAAA;MAAA,sBAAA;UAAA,wBAAA;EACA,gBAAA;EACA,mBAAA;EACA,aAAA;EACA,mBAAA;CF2Hf;AE5ID;EAqBgB,cAAA;CF0Hf;AE/ID;EAyBoB,iBAAA;CFyHnB;AElJD;EA8BoB,cAAA;CFuHnB;AEnHW;EAEQ,sBAAA;EAAA,qBAAA;EAAA,cAAA;CFoHnB;AEtHW;EAMQ,mBAAA;EACA,OAAA;EACA,SAAA;EACA,UAAA;EACA,QAAA;CFmHnB;AE7GG;EAGY,4CAAA;CF6Gf;AEhHG;EAMgB,aAAA;CF6GnB;AEnHG;EAWY,cAAA;CF2Gf;AEtHG;EAcgB,cAAA;CF2GnB;;AG3KD;EAGY,cAAA;CH4KX;;AI7KO;EAEQ,2DAAA;CJ+Kf;AIjLO;EAIY,4BAAA;CJgLnB;AIpLO;EASQ,0BAAA;CJ8Kf;AIvLO;EAWY,0BAAA;CJ+KnB;;AK5LD;EAIgB,cAAA;EACA,mBAAA;EACA,YAAA;EACA,OAAA;EACA,YAAA;EACA,aAAA;EACA,mBAAA;CL4Lf;AKtMD;EAcgB,WAAA;CL2Lf;AKzMD;EAkBgB,YAAA;CL0Lf;AKtLO;EACI,eAAA;CLwLX;;AM9MD;;EAEQ,gBAAA;CNiNP;AMnND;;EAOgB,aAAA;EACA,mBAAA;EACA,oBAAA;ENgNd,yFAAyF;EACzF,qCAAqC;EACrC,qCAAqC;EACrC,uDAAuD;EACvD,wDAAwD;EACxD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BC;CACF;AMzPD;;ECAQ,UAAA;EACA,WAAA;EACA,wBAAA;CP6PP;AM/PD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECOQ,eAAA;CP0RP;AMjSD;;;;;;;;;;;;;;ECWQ,gBAAA;EACA,mBAAA;CPsSP;AMlTD;;;;ECgBQ,kBAAA;EACA,mBAAA;CPwSP;AMzTD;;ECqBQ,mBAAA;CPwSP;AM7TD;;;;;;;;ECyBQ,uBAAA;EACA,iBAAA;CP8SP;AMxUD;;;;;;;;;;EC8BQ,mBAAA;CPsTP;AMpVD;;;;ECkCQ,oBAAA;CPwTP;AM1VD;;;;;;;;ECsCQ,uBAAA;CP8TP;AMpWD;;EC0CQ,kBAAA;CP8TP;AMxWD;;EC8CQ,mBAAA;CP8TP;AM5WD;;ECkDQ,oBAAA;CP8TP;AMhXD;;ECsDQ,sBAAA;CP8TP;AMpXD;;;;EC0DQ,oBAAA;EACA,mBAAA;CPgUP;AM3XD;;ECgEQ,cAAA;CP+TP;AM/XD;;ECoEQ,mBAAA;EACA,oBAAA;CP+TP;AMpYD;;ECyEQ,mBAAA;EACA,oBAAA;EACA,eAAA;EACA,8BAAA;EACA,4BAAA;UAAA,oBAAA;CP+TP;AM5YD;;ECiFQ,6BAAA;CP+TP;AMhZD;;ECqFQ,6BAAA;CP+TP;AMpZD;;;;;;;;;;ECyFQ,sBAAA;CPuUP;AMhaD;;EC8FQ,eAAA;CPsUP;AMpaD;;ECkGQ,eAAA;CPsUP;AMxaD;;;;ECsGQ,2BAAA;CPwUP;AM9aD;;;;;;;;EC2GQ,aAAA;CP6UP;AMxbD;;EC+GQ,cAAA;CP6UP;AM5bD;;ECmHQ,mBAAA;EACA,aAAA;CP6UP;AMjcD;;;;ECwHQ,kCAAA;CP+UP;AMvcD;;;;EC4HQ,2BAAA;CPiVP;AM7cD;;;;;;ECgIQ,8BAAA;CPqVP;AMrdD;;ECoIQ,uBAAA;CPqVP;AMzdD;;ECwIQ,oBAAA;CPqVP;AM7dD;;EC4IQ,qBAAA;CPqVP;AMjeD;;ECgJQ,cAAA;EACA,iBAAA;CPqVP;AMteD;;ECqJQ,oBAAA;CPqVP;AM1eD;;ECyJQ,iBAAA;CPqVP;AM9eD;;EC6JQ,oBAAA;CPqVP;AMlfD;;;;;;;;;;;;;;;;;;;;;;ECiKQ,eAAA;CPyWP;AM1gBD;;ECqKQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPyWP;AMjhBD;;EC4KQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPyWP;AMxhBD;;ECmLQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPyWP;AM/hBD;;EC0LQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPyWP;AMtiBD;;ECiMQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPyWP;AM7iBD;;ECwMQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPyWP;AMpjBD;;;;;;;;;;;;EC+MQ,eAAA;CPmXP;AMlkBD;;ECmNQ,mBAAA;CPmXP;AMtkBD;;;;;;;;ECuNQ,gBAAA;EACA,mBAAA;CPyXP;AMjlBD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EC+NY,cAAA;EACA,iBAAA;CPoZX;AMpnBD;;ECoOQ,kBAAA;CPoZP;AMxnBD;;;;;;ECwOQ,mBAAA;CPwZP;AMhoBD;;EC4OQ,yBAAA;CPwZP;AMpoBD;;;;ECgPQ,sBAAA;CP0ZP;AM1oBD;;;;;;;;;;;;ECsPY,wBAAA;CPkaX;AMxpBD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECkQgB,wBAAA;CP4bf;AM9rBD;;ECsQQ,eAAA;CP4bP;AMlsBD;;EC0QQ,uBAAA;CP4bP;AMtsBD;;;;EC8QQ,4BAAA;CP8bP;AM5sBD;;;;ECkRQ,sBAAA;CPgcP;AMltBD;;;;ECsRQ,4BAAA;CPkcP;AMxtBD;;;;EC0RQ,yBAAA;CPocP;AM9tBD;;;;EC8RQ,4BAAA;CPscP;AMpuBD;;;;ECkSQ,mBAAA;CPwcP;AM1uBD;;;;;;;;ECsSQ,oBAAA;CP8cP;AMpvBD;;;;;;;;;;;;;;;;EC2SY,qBAAA;CP2dX;AMtwBD;;EC+SQ,uBAAA;EACA,oBAAA;EACA,0BAAA;EACA,qBAAA;CP2dP;AM7wBD;;;;ECsTQ,aAAA;CP6dP;AMnxBD;;EC0TQ,kBAAA;CP6dP;AMvxBD;;;;;;;;EC8TQ,uBAAA;CPmeP;AMjyBD;;;;;;ECkUQ,wBAAA;CPueP;AMzyBD;;;;;;ECsUQ,mBAAA;CP2eP;AMjzBD;;;;;;;;EC0UQ,sBAAA;CPifP;AM3zBD;;;;;;;;;;;;;;ECwWQ,qBAAA;CPmeP;AM30BD;;EC4WQ,sBAAA;CPmeP;AM/0BD;;;;;;;;;;;;;;ECiXQ,uBAAA;CP8eP;AM/1BD;;;;ECqXQ,qBAAA;CPgfP;AMr2BD;;ECyXQ,YAAA;EACA,oBAAA;EACA,kBAAA;EACA,mBAAA;CPgfP;AM52BD;;ECgYQ,iBAAA;EACA,kBAAA;EACA,8BAAA;EACA,+BAAA;CPgfP;AMn3BD;;ECuYQ,kBAAA;EACA,mBAAA;CPgfP;AMx3BD;;EAeoB,yBAAA;CN62BnB;AM53BD;;EAmBoB,4BAAA;CN62BnB;AMx2BO;;;;EAEQ,eAAA;EACA,YAAA;EACA,gBAAA;EACA,aAAA;CN42Bf;AMz4BD;;EAmCQ,eAAA;EACA,YAAA;EACA,gBAAA;EACA,aAAA;CN02BP;;AQj5BD;EAEQ,mBAAA;EACA,kBAAA;EACA,aAAA;EACA,uBAAA;MAAA,qBAAA;UAAA,eAAA;CRm5BP;AQx5BD;EAQY,0BAAA;EACA,aAAA;EACA,kBAAA;EACA,aAAA;EACA,0BAAA;CRm5BX;AQj5BW;EACI,gBAAA;EACA,OAAA;EACA,iBAAA;EACA,iBAAA;CRm5Bf;AQh5BW;EACI,mBAAA;EACA,UAAA;CRk5Bf;AQz6BD;EA2BgB,iBAAA;CRi5Bf;AQ56BD;EA8BoB,eAAA;EACA,mBAAA;EACA,sBAAA;CRi5BnB;AQ/4BmB;EACI,sBAAA;EACA,YAAA;EACA,kBAAA;EACA,8CAAA;EACA,mBAAA;EACA,iBAAA;CRi5BvB;AQ74Be;EAEQ,iBAAA;CR84BvB;AQh5Be;EAMQ,cAAA;CR64BvB;AQ/7BD;EAuDoB,gBAAA;CR24BnB;AQl8BD;EA2DoB,0BAAA;EACA,uBAAA;EACA,kBAAA;EACA,gBAAA;CR04BnB;AQx8BD;EAiEwB,sBAAA;EACA,YAAA;EACA,8CAAA;CR04BvB;AQ78BD;EAuEwB,gBAAA;CRy4BvB;AQh9BD;EA4EoB,gBAAA;CRu4BnB;;ASn9BD;EAEQ,cAAA;EACA,mBAAA;EACA,UAAA;EAGA,iDAAA;EACA,0BAAA;EACA,eAAA;EACA,0BAAA;EACA,iBAAA;EACA,YAAA;EACA,eAAA;EACA,iBAAA;EACA,gBAAA;EACA,oBAAA;EACA,oBAAA;CTq9BP;ASt+BD;EAoBY,sBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,iBAAA;CTq9BX;AS1+BD;EAwBgB,iBAAA;EACA,iDAAA;EACA,kBAAA;CTq9Bf;AS/+BD;EA+BY,iBAAA;CTm9BX;ASl/BD;EAmCY,iBAAA;EACA,kBAAA;EACA,eAAA;CTk9BX;ASv/BD;EAyCY,0BAAA;EACA,gBAAA;CTi9BX;AS3/BD;EA+CgB,eAAA;EACA,iBAAA;CT+8Bf","file":"LayoutEditor.css","sourcesContent":["@import \"Variables.less\";\n\n.layout-editor {\n    display: flex;\n    margin-top: 1em;\n    font-size: @font-size;\n    align-items: stretch;\n\n    > .layout-canvas-wrapper {\n        flex-grow: 1;\n        background-color: @gray-bg;\n        border: 1px solid @gray-border;\n\n        > .layout-toolbar-container {\n            display: none;\n            margin: @container-padding @container-padding 0;\n            min-height: 71px;\n\n            > .mce-panel {\n                width: 100% !important;\n            }\n        }\n    }\n}\n",".layout-editor {\n  display: flex;\n  margin-top: 1em;\n  font-size: 14px;\n  align-items: stretch;\n}\n.layout-editor > .layout-canvas-wrapper {\n  flex-grow: 1;\n  background-color: #f3f4f5;\n  border: 1px solid #e4e5e6;\n}\n.layout-editor > .layout-canvas-wrapper > .layout-toolbar-container {\n  display: none;\n  margin: 12px 12px 0;\n  min-height: 71px;\n}\n.layout-editor > .layout-canvas-wrapper > .layout-toolbar-container > .mce-panel {\n  width: 100% !important;\n}\n\n.layout-editor .layout-element {\n  position: relative;\n  margin-top: 0;\n  margin-right: 0;\n  margin-bottom: 0;\n  padding: 0;\n}\n.layout-editor .layout-element:not(.layout-column) {\n  margin-left: 0;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel {\n  display: none;\n  position: absolute;\n  margin: 0;\n  z-index: 20;\n  height: 25px;\n  padding: 0 6px;\n  list-style: none;\n  white-space: nowrap;\n  line-height: 25px;\n  vertical-align: middle;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-item {\n  display: inline-block;\n  height: 25px;\n  padding: 1px 6px 0;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-label {\n  font-size: 13px;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-action {\n  display: none;\n  width: 28px;\n  cursor: pointer;\n  text-align: center;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel-main {\n  top: -27px;\n  left: -2px;\n}\n.layout-editor li.layout-element {\n  list-style: none;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active,\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused {\n  border-width: 2px;\n  border-style: solid;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active > .layout-element-wrapper,\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper {\n  margin: -2px;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active {\n  border-color: rgba(104, 104, 104, 0.1);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active > .layout-element-wrapper > .layout-panel-main {\n  display: block;\n  z-index: 30;\n  background-color: rgba(104, 104, 104, 0.1);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused {\n  border-color: #648721;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel {\n  display: block;\n  background-color: #648721;\n  color: #fefefe;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action {\n  display: inline-block;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action:hover {\n  background-color: #82b02b;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.disabled {\n  cursor: default;\n  color: rgba(254, 254, 254, 0.4);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.disabled:hover {\n  background-color: #648721;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.active {\n  color: #deff42;\n  background-color: #739b26;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.active:hover {\n  background-color: #82b02b;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-selected {\n  background-color: rgba(100, 135, 33, 0.08);\n}\n.layout-editor .ui-sortable-placeholder {\n  display: none;\n}\n.layout-editor .layout-element-droptarget {\n  box-shadow: inset 0 0 12px 6px rgba(100, 135, 33, 0.5);\n}\n.layout-editor .layout-element-droptarget .ui-sortable-placeholder {\n  display: block;\n  visibility: visible !important;\n  min-height: 78px;\n  border: 2px dashed #648721 !important;\n  background-color: rgba(100, 135, 33, 0.16);\n}\n.layout-editor .media-thumbnail img {\n  max-width: 100%;\n  max-height: 100%;\n}\n\n.layout-editor .layout-container > .layout-element-wrapper > .layout-container-children-placeholder {\n  display: none;\n  flex-direction: column;\n  margin: 11px;\n  min-height: 80px;\n  border: 1px dashed rgba(124, 124, 124, 0.4);\n  border-radius: 4px;\n  padding: 12px;\n  justify-content: center;\n  font-size: 13px;\n  font-style: italic;\n  opacity: 0.6;\n  text-align: center;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children {\n  padding: 12px;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-container) + .layout-element:not(.layout-container) {\n  margin-top: 12px;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children > .ui-sortable-helper:first-child + .layout-element:not(.layout-container) {\n  margin-top: 0;\n}\n.layout-editor .layout-container > .layout-element-wrapper.layout-container-empty > .layout-container-children-placeholder {\n  display: flex;\n}\n.layout-editor .layout-container > .layout-element-wrapper.layout-container-empty > .layout-children {\n  position: absolute;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) {\n  border: 1px dashed rgba(124, 124, 124, 0.6);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin: -1px;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-container + .layout-container:not(.layout-element-active) {\n  border-top: 0;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-container + .layout-container:not(.layout-element-active) > .layout-element-wrapper {\n  margin-top: 0;\n}\n\n.layout-editor .layout-canvas #dummy {\n  display: none;\n}\n\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) {\n  border-top: 1px dashed rgba(124, 124, 124, 0.6) !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin-top: -1px !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element + .layout-element:not(.layout-element-active) {\n  border-left: 0 !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element + .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin-left: 0 !important;\n}\n\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar {\n  display: none;\n  position: absolute;\n  z-index: 30;\n  top: 0;\n  width: 16px;\n  height: 100%;\n  cursor: col-resize;\n}\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar-left {\n  left: -6px;\n}\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar-right {\n  right: -6px;\n}\n.layout-editor .layout-column.layout-element-focused > .layout-element-wrapper > .layout-column-resize-bar {\n  display: block;\n}\n\n.layout-editor .layout-content,\n.layout-editor .layout-html {\n  min-height: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup {\n  padding: 2px;\n  overflow-x: hidden;\n  line-height: normal;\n  /* this color is just a suggestion and can be changed based on implementation feedback */\n  /* this also has bidi implications */\n  /* this also has bidi implications */\n  /* LTR-specific: use 'margin-right' for rtl elements */\n  /* LTR-specific: use 'padding-right' for rtl elements */\n  /*table[rules=none i], table[rules=groups i], table[rules=rows i],\ntable[rules=cols i], table[rules=all i], table[frame=void i],\ntable[frame=above i], table[frame=below i], table[frame=hsides i],\ntable[frame=lhs i], table[frame=rhs i], table[frame=vsides i],\ntable[frame=box i], table[frame=border i],\ntable[rules=none i] > tr > td, table[rules=none i] > tr > th,\ntable[rules=groups i] > tr > td, table[rules=groups i] > tr > th,\ntable[rules=rows i] > tr > td, table[rules=rows i] > tr > th,\ntable[rules=cols i] > tr > td, table[rules=cols i] > tr > th,\ntable[rules=all i] > tr > td, table[rules=all i] > tr > th,\ntable[rules=none i] > thead > tr > td, table[rules=none i] > thead > tr > th,\ntable[rules=groups i] > thead > tr > td, table[rules=groups i] > thead > tr > th,\ntable[rules=rows i] > thead > tr > td, table[rules=rows i] > thead > tr > th,\ntable[rules=cols i] > thead > tr > td, table[rules=cols i] > thead > tr > th,\ntable[rules=all i] > thead > tr > td, table[rules=all i] > thead > tr > th,\ntable[rules=none i] > tbody > tr > td, table[rules=none i] > tbody > tr > th,\ntable[rules=groups i] > tbody > tr > td, table[rules=groups i] > tbody > tr > th,\ntable[rules=rows i] > tbody > tr > td, table[rules=rows i] > tbody > tr > th,\ntable[rules=cols i] > tbody > tr > td, table[rules=cols i] > tbody > tr > th,\ntable[rules=all i] > tbody > tr > td, table[rules=all i] > tbody > tr > th,\ntable[rules=none i] > tfoot > tr > td, table[rules=none i] > tfoot > tr > th,\ntable[rules=groups i] > tfoot > tr > td, table[rules=groups i] > tfoot > tr > th,\ntable[rules=rows i] > tfoot > tr > td, table[rules=rows i] > tfoot > tr > th,\ntable[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th,\ntable[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th {\n    border-color: black;\n}*/\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup *,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup * {\n  margin: 0;\n  padding: 0;\n  box-sizing: content-box;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup center,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup center,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup div,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup div,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figcaption,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figcaption,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup footer,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup footer,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup form,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup form,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup header,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup header,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  margin-top: 1em;\n  margin-bottom: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure {\n  margin-left: 40px;\n  margin-right: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup address {\n  font-style: italic;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  font-family: monospace;\n  white-space: pre;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup cite,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup cite,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dfn,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dfn,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup em,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup em,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup i,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup i,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup var,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup var {\n  font-style: italic;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup b,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup b,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strong,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup strong {\n  font-weight: bolder;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup code,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup code,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup kbd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup kbd,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup samp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup samp,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tt {\n  font-family: monospace;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup big,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup big {\n  font-size: larger;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup small,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup small {\n  font-size: smaller;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sub {\n  vertical-align: sub;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sup {\n  vertical-align: super;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sup {\n  line-height: normal;\n  font-size: smaller;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ruby {\n  display: ruby;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rb {\n  display: ruby-base;\n  white-space: nowrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rt {\n  display: ruby-text;\n  white-space: nowrap;\n  font-size: 50%;\n  font-variant-east-asian: ruby;\n  text-emphasis: none;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rbc {\n  display: ruby-base-container;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rtc {\n  display: ruby-text-container;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rtc {\n  unicode-bidi: isolate;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :link {\n  color: #0000EE;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :visited {\n  color: #551A8B;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :visited {\n  text-decoration: underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:link[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup a:link[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:visited[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup a:visited[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:link[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup area:link[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:visited[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup area:visited[rel~=help] {\n  cursor: help;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :focus,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :focus {\n  outline: auto;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup mark,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup mark {\n  background: yellow;\n  color: black;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup abbr[title],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup abbr[title],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup acronym[title],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup acronym[title] {\n  text-decoration: dotted underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ins,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ins,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup u,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup u {\n  text-decoration: underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup del,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup del,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup s,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup s,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strike,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup strike {\n  text-decoration: line-through;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blink,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blink {\n  text-decoration: blink;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::before,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup q::before {\n  content: open-quote;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::after,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup q::after {\n  content: close-quote;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup br,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup br {\n  content: '\\A';\n  white-space: pre;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nobr {\n  white-space: nowrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup wbr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup wbr {\n  content: '\\200B';\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr wbr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nobr wbr {\n  white-space: normal;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup article,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup article,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup aside,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup aside,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nav,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nav,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup section,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup section {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h1 {\n  margin-top: 0.67em;\n  margin-bottom: 0.67em;\n  font-size: 2.00em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h2 {\n  margin-top: 0.83em;\n  margin-bottom: 0.83em;\n  font-size: 1.50em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h3 {\n  margin-top: 1.00em;\n  margin-bottom: 1.00em;\n  font-size: 1.17em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h4 {\n  margin-top: 1.33em;\n  margin-bottom: 1.33em;\n  font-size: 1.00em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h5 {\n  margin-top: 1.67em;\n  margin-bottom: 1.67em;\n  font-size: 0.83em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h6 {\n  margin-top: 2.33em;\n  margin-bottom: 2.33em;\n  font-size: 0.67em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dt,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup li,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup li {\n  display: list-item;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  margin-top: 1em;\n  margin-bottom: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul {\n  margin-top: 0;\n  margin-bottom: 0;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dd {\n  margin-left: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  padding-left: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol {\n  list-style-type: decimal;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  list-style-type: disc;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul {\n  list-style-type: circle;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul ul {\n  list-style-type: square;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table {\n  display: table;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup caption,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup caption {\n  display: table-caption;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup[hidden] {\n  display: table-column-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col[hidden] {\n  display: table-column;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead[hidden] {\n  display: table-header-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody[hidden] {\n  display: table-row-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot[hidden] {\n  display: table-footer-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr[hidden] {\n  display: table-row;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th[hidden] {\n  display: table-cell;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th[hidden] {\n  visibility: collapse;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table {\n  box-sizing: border-box;\n  border-spacing: 2px;\n  border-collapse: separate;\n  text-indent: initial;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  padding: 1px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table > tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table > tr {\n  vertical-align: middle;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  vertical-align: inherit;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  border-color: gray;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr {\n  border-color: inherit;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup option,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup option,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup optgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup optgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup keygen,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup keygen {\n  text-indent: initial;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup textarea {\n  white-space: pre-wrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"radio\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"radio\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"checkbox\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"checkbox\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"reset\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"reset\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"submit\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"submit\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button {\n  box-sizing: border-box;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button {\n  padding: 0.3em 0.5em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hr {\n  color: gray;\n  border-style: inset;\n  border-width: 1px;\n  margin: 0.5em auto;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup fieldset,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup fieldset {\n  margin-left: 2px;\n  margin-right: 2px;\n  border: groove 2px ThreeDFace;\n  padding: 0.35em 0.625em 0.75em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup legend {\n  padding-left: 2px;\n  padding-right: 2px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:first-child,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup > *:first-child {\n  margin-top: 0 !important;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:last-child,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup > *:last-child {\n  margin-bottom: 0 !important;\n}\n.layout-editor .layout-content.layout-content-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-html.layout-content-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-content.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-html.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img {\n  display: block;\n  width: 100%;\n  max-width: 100%;\n  height: auto;\n}\n.layout-editor .img-responsive,\n.layout-editor .img-responsive img {\n  display: block;\n  width: 100%;\n  max-width: 100%;\n  height: auto;\n}\n\n.layout-editor > .layout-toolbox-wrapper {\n  position: relative;\n  margin-left: 12px;\n  width: 220px;\n  flex-shrink: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox {\n  border: 1px solid #e4e5e6;\n  width: 220px;\n  min-height: 400px;\n  padding: 6px;\n  background-color: #f3f4f5;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-top {\n  position: fixed;\n  top: 0;\n  max-height: 100%;\n  overflow-y: auto;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-bottom {\n  position: absolute;\n  bottom: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group {\n  margin-top: 12px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading {\n  display: block;\n  margin-bottom: 4px;\n  text-decoration: none;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading:before {\n  display: inline-block;\n  width: 10px;\n  margin-right: 4px;\n  font: normal normal normal 14px/1 FontAwesome;\n  text-align: center;\n  content: \"\\f0d7\";\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-group-heading:before {\n  content: \"\\f0da\";\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-items {\n  display: none;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-section + .layout-toolbox-section {\n  margin-top: 4px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item {\n  border: 1px solid #e4e5e6;\n  background-color: #fff;\n  padding: 9px 12px;\n  cursor: default;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item i {\n  display: inline-block;\n  width: 16px;\n  font: normal normal normal 14px/1 FontAwesome;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item + .layout-toolbox-item {\n  margin-top: 4px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group + .layout-toolbox-group {\n  margin-top: 6px;\n}\n\n.layout-editor .layout-popup {\n  display: none;\n  position: absolute;\n  margin: 0;\n  -moz-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  -webkit-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  border: 1px solid #e4e5e6;\n  padding: 2px 0;\n  background-color: #f7f7f7;\n  list-style: none;\n  z-index: 20;\n  color: #7c7c7c;\n  text-align: left;\n  cursor: default;\n  white-space: nowrap;\n  line-height: normal;\n}\n.layout-editor .layout-popup .layout-popup-flex {\n  display: flex;\n  padding: 2px 5px;\n}\n.layout-editor .layout-popup .layout-popup-flex .layout-popup-column + .layout-popup-column {\n  margin-left: 4px;\n  border-left: 1px solid rgba(128, 128, 128, 0.15);\n  padding-left: 4px;\n}\n.layout-editor .layout-popup .layout-popup-item {\n  padding: 4px 6px;\n}\n.layout-editor .layout-popup .layout-popup-label {\n  font-size: 0.9em;\n  font-weight: bold;\n  color: #7c7c7c;\n}\n.layout-editor .layout-popup .layout-popup-action:hover {\n  background-color: #f3f4f5;\n  cursor: pointer;\n}\n.layout-editor .layout-popup .layout-popup-input > label {\n  display: block;\n  font-size: 0.9em;\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-element {\n        position: relative;\n        margin-top: 0;\n        margin-right: 0;\n        margin-bottom: 0;\n        padding: 0;\n\n        // We don't fuck with the left margin of columns, because Bootstrap uses these to render column offsets.\n        &:not(.layout-column) {\n            margin-left: 0;\n        }\n\n        > .layout-element-wrapper {\n            > .layout-panel {\n                display: none; // Shown only in active or focused states.\n                position: absolute;\n                margin: 0;\n                z-index: 20;\n                height: 25px;\n                padding: 0 6px;\n                list-style: none;\n                white-space: nowrap;\n                line-height: 25px;\n                vertical-align: middle;\n\n                > .layout-panel-item {\n                    display: inline-block;\n                    height: 25px;\n                    padding: 1px 6px 0;\n                }\n\n                > .layout-panel-label {\n                    font-size: @font-size - 1;\n                }\n\n                > .layout-panel-action {\n                    display: none; // Shown only in focused state.\n                    width: 28px;\n                    cursor: pointer;\n                    text-align: center;\n                }\n            }\n\n            > .layout-panel-main {\n                top: -27px;\n                left: -2px;\n            }\n        }\n    }\n\n    // When dragging from toolbox, elements will be li rather than div.\n    li.layout-element {\n        list-style: none;\n    }\n\n    &:not(.layout-editor-dragging) {\n\n        .layout-element-active, .layout-element-focused {\n            border-width: 2px;\n            border-style: solid;\n\n            > .layout-element-wrapper {\n                margin: -2px;\n            }\n        }\n\n        .layout-element-active {\n            @active-highlight: fade(#686868, 10%);\n\n            border-color: @active-highlight;\n\n            > .layout-element-wrapper > .layout-panel-main {\n                display: block; // To reveal.\n                z-index: 30;\n                background-color: @active-highlight;\n            }\n        }\n\n        .layout-element-focused {\n            @focused-highlight: #648721;\n            @focused-text: #fefefe;\n\n            border-color: @focused-highlight;\n\n            > .layout-element-wrapper > .layout-panel {\n                display: block; // To reveal.\n                background-color: @focused-highlight;\n                color: @focused-text;\n\n                > .layout-panel-action {\n                    display: inline-block; // To reveal.\n                    &:hover {\n                        background-color: lighten(@focused-highlight, 10%);\n                    }\n\n                    &.disabled {\n                        cursor: default;\n                        color: fade(@focused-text, 40%);\n\n                        &:hover {\n                            background-color: @focused-highlight;\n                        }\n                    }\n\n                    &.active {\n                        color: lighten(saturate(spin(@focused-highlight, -10), 100%), 30%);\n                        background-color: lighten(@focused-highlight, 5%);\n\n                        &:hover {\n                            background-color: lighten(@focused-highlight, 10%);\n                        }\n                    }\n                }\n            }\n        }\n\n        .layout-element-selected {\n            @selected-highlight: #648721;\n            background-color: fade(@selected-highlight, 8%);\n        }\n    }\n\n    .ui-sortable-placeholder {\n        display: none;\n    }\n\n    .layout-element-droptarget {\n        @droptarget-highlight: #648721;\n        box-shadow: inset 0 0 12px 6px fade(@droptarget-highlight, 50%);\n\n        .ui-sortable-placeholder {\n            display: block; // To reveal.\n            visibility: visible !important;\n            min-height: @element-min-height - 2px;\n            border: 2px dashed @droptarget-highlight !important;\n            background-color: fade(@droptarget-highlight, 16%);\n        }\n    }\n\n    // A CSS fix for media item elements.\n    .media-thumbnail {\n        img {\n            max-width:100%;\n            max-height: 100%;\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-container {\n\n        > .layout-element-wrapper {\n\n            > .layout-container-children-placeholder {\n                display: none;\n                flex-direction: column;\n                margin: @container-padding - 1px;\n                min-height: @element-min-height;\n                border: 1px dashed fade(@gray-text, 40%);\n                border-radius: 4px;\n                padding: @container-padding;\n                justify-content: center;\n                font-size: @font-size - 1;\n                font-style: italic;\n                opacity: 0.6;\n                text-align: center;\n            }\n\n            > .layout-children {\n                padding: @container-padding;\n\n                // All adjacent non-container children need some space between...\n                > .layout-element:not(.layout-container) + .layout-element:not(.layout-container) {\n                    margin-top: @content-spacing;\n                }\n\n                // ... except when jQuery UI sortable helper is the first element (because that one is absolutely positioned and \"floating\").\n                > .ui-sortable-helper:first-child + .layout-element:not(.layout-container) {\n                    margin-top: 0;\n                }\n            }\n\n            &.layout-container-empty {\n                > .layout-container-children-placeholder {\n                    display: flex; // To reveal.\n                }\n\n                > .layout-children {\n                    position: absolute;\n                    top: 0;\n                    right: 0;\n                    bottom: 0;\n                    left: 0;\n                }\n            }\n        }\n    }\n\n    &:not(.layout-editor-dragging) {\n        .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children {\n            > .layout-element:not(.layout-element-active) {\n                border: 1px dashed fade(@gray-text, 60%);\n\n                > .layout-element-wrapper {\n                    margin: -1px;\n                }\n            }\n\n            > .layout-container + .layout-container:not(.layout-element-active) {\n                border-top: 0;\n\n                > .layout-element-wrapper {\n                    margin-top: 0;\n                }\n            }\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-canvas {\n        #dummy { // Only added because WE doesn't compile if there are no rules.\n            display: none;\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-row {\n        &.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children {\n            > .layout-element:not(.layout-element-active) {\n                border-top: 1px dashed fade(@gray-text, 60%) !important;\n                > .layout-element-wrapper {\n                    margin-top: -1px !important;\n                }\n            }\n\n            > .layout-element + .layout-element:not(.layout-element-active) {\n                border-left: 0 !important;\n                > .layout-element-wrapper {\n                    margin-left: 0 !important;\n                }\n            }\n        }\n    }\n}","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-column {\n        > .layout-element-wrapper {\n            > .layout-column-resize-bar {\n                display: none;\n                position: absolute;\n                z-index: 30;\n                top: 0;\n                width: 16px;\n                height: 100%;\n                cursor: col-resize;\n            }\n\n            > .layout-column-resize-bar-left {\n                left: -6px;\n            }\n\n            > .layout-column-resize-bar-right {\n                right: -6px;\n            }\n        }\n\n        &.layout-element-focused > .layout-element-wrapper > .layout-column-resize-bar {\n            display: block;\n        }\n    }\n}\n","@import \"Variables.less\";\n@import \"Reset.less\";\n\n.layout-editor {\n    .layout-content, .layout-html {\n        min-height: 1em;\n\n        > .layout-element-wrapper {\n            .layout-content-markup {\n\n                padding: 2px;\n                overflow-x: hidden;\n                line-height: normal;\n\n                // Reset to HTML5 W3C standard default styling within content.\n                .reset();\n\n                > *:first-child {\n                    margin-top: 0 !important; // Important because site.css of the admin theme styles heading margins with a very high specificity.\n                }\n\n                > *:last-child {\n                    margin-bottom: 0 !important;\n                }\n            }\n        }\n\n        &.layout-content-image, &.layout-content-vector-image {\n            > .layout-element-wrapper > .layout-content-markup > img {\n                display: block;\n                width: 100%;\n                max-width: 100%;\n                height: auto;\n            }\n        }\n    }\n\n    .img-responsive, .img-responsive img {\n        display: block;\n        width: 100%;\n        max-width: 100%;\n        height: auto;\n    }\n}\n","﻿.reset() {\n\n    * {\n        margin: 0;\n        padding: 0;\n        box-sizing: content-box;\n    }\n\n    address, blockquote, center, div, figure, figcaption, footer, form,\n    header, hr, legend, listing, p, plaintext, pre, xmp {\n        display: block;\n    }\n\n    blockquote, figure, listing, p, plaintext, pre, xmp {\n        margin-top: 1em;\n        margin-bottom: 1em;\n    }\n\n    blockquote, figure {\n        margin-left: 40px;\n        margin-right: 40px;\n    }\n\n    address {\n        font-style: italic;\n    }\n\n    listing, plaintext, pre, xmp {\n        font-family: monospace;\n        white-space: pre;\n    }\n\n    cite, dfn, em, i, var {\n        font-style: italic;\n    }\n\n    b, strong {\n        font-weight: bolder;\n    }\n\n    code, kbd, samp, tt {\n        font-family: monospace;\n    }\n\n    big {\n        font-size: larger;\n    }\n\n    small {\n        font-size: smaller;\n    }\n\n    sub {\n        vertical-align: sub;\n    }\n\n    sup {\n        vertical-align: super;\n    }\n\n    sub, sup {\n        line-height: normal;\n        font-size: smaller;\n    }\n\n\n    ruby {\n        display: ruby;\n    }\n\n    rb {\n        display: ruby-base;\n        white-space: nowrap;\n    }\n\n    rt {\n        display: ruby-text;\n        white-space: nowrap;\n        font-size: 50%;\n        font-variant-east-asian: ruby;\n        text-emphasis: none;\n    }\n\n    rbc {\n        display: ruby-base-container;\n    }\n\n    rtc {\n        display: ruby-text-container;\n    }\n\n    ruby, rb, rt, rbc, rtc {\n        unicode-bidi: isolate;\n    }\n\n\n    :link {\n        color: #0000EE;\n    }\n\n    :visited {\n        color: #551A8B;\n    }\n\n    :link, :visited {\n        text-decoration: underline;\n    }\n\n    a:link[rel~=help], a:visited[rel~=help],\n    area:link[rel~=help], area:visited[rel~=help] {\n        cursor: help;\n    }\n\n    :focus {\n        outline: auto;\n    }\n\n    mark {\n        background: yellow;\n        color: black;\n    }\n    /* this color is just a suggestion and can be changed based on implementation feedback */\n    abbr[title], acronym[title] {\n        text-decoration: dotted underline;\n    }\n\n    ins, u {\n        text-decoration: underline;\n    }\n\n    del, s, strike {\n        text-decoration: line-through;\n    }\n\n    blink {\n        text-decoration: blink;\n    }\n\n    q::before {\n        content: open-quote;\n    }\n\n    q::after {\n        content: close-quote;\n    }\n\n    br {\n        content: '\\A';\n        white-space: pre;\n    }\n    /* this also has bidi implications */\n    nobr {\n        white-space: nowrap;\n    }\n\n    wbr {\n        content: '\\200B';\n    }\n    /* this also has bidi implications */\n    nobr wbr {\n        white-space: normal;\n    }\n\n    article, aside, h1, h2, h3, h4, h5, h6, hgroup, nav, section {\n        display: block;\n    }\n\n    h1 {\n        margin-top: 0.67em;\n        margin-bottom: 0.67em;\n        font-size: 2.00em;\n        font-weight: bold;\n    }\n\n    h2 {\n        margin-top: 0.83em;\n        margin-bottom: 0.83em;\n        font-size: 1.50em;\n        font-weight: bold;\n    }\n\n    h3 {\n        margin-top: 1.00em;\n        margin-bottom: 1.00em;\n        font-size: 1.17em;\n        font-weight: bold;\n    }\n\n    h4 {\n        margin-top: 1.33em;\n        margin-bottom: 1.33em;\n        font-size: 1.00em;\n        font-weight: bold;\n    }\n\n    h5 {\n        margin-top: 1.67em;\n        margin-bottom: 1.67em;\n        font-size: 0.83em;\n        font-weight: bold;\n    }\n\n    h6 {\n        margin-top: 2.33em;\n        margin-bottom: 2.33em;\n        font-size: 0.67em;\n        font-weight: bold;\n    }\n\n    dir, dd, dl, dt, ol, ul {\n        display: block;\n    }\n\n    li {\n        display: list-item;\n    }\n\n    dir, dl, ol, ul {\n        margin-top: 1em;\n        margin-bottom: 1em;\n    }\n\n        dir dir, dir dl, dir ol, dir ul,\n        dl dir, dl dl, dl ol, dl ul,\n        ol dir, ol dl, ol ol, ol ul,\n        ul dir, ul dl, ul ol, ul ul {\n            margin-top: 0;\n            margin-bottom: 0;\n        }\n\n    dd {\n        margin-left: 40px;\n    }\n    /* LTR-specific: use 'margin-right' for rtl elements */\n    dir, ol, ul {\n        padding-left: 40px;\n    }\n    /* LTR-specific: use 'padding-right' for rtl elements */\n    ol {\n        list-style-type: decimal;\n    }\n\n    dir, ul {\n        list-style-type: disc;\n    }\n\n        dir dir, dir ul,\n        ol dir, ol ul,\n        ul dir, ul ul {\n            list-style-type: circle;\n        }\n\n            dir dir dir, dir dir ul,\n            dir ol dir, dir ol ul,\n            dir ul dir, dir ul ul,\n            ol dir dir, ol dir ul,\n            ol ol dir, ol ol ul,\n            ol ul dir, ol ul ul,\n            ul dir dir, ul dir ul,\n            ul ol dir, ul ol ul,\n            ul ul dir, ul ul ul {\n                list-style-type: square;\n            }\n\n    table {\n        display: table;\n    }\n\n    caption {\n        display: table-caption;\n    }\n\n    colgroup, colgroup[hidden] {\n        display: table-column-group;\n    }\n\n    col, col[hidden] {\n        display: table-column;\n    }\n\n    thead, thead[hidden] {\n        display: table-header-group;\n    }\n\n    tbody, tbody[hidden] {\n        display: table-row-group;\n    }\n\n    tfoot, tfoot[hidden] {\n        display: table-footer-group;\n    }\n\n    tr, tr[hidden] {\n        display: table-row;\n    }\n\n    td, th, td[hidden], th[hidden] {\n        display: table-cell;\n    }\n\n        colgroup[hidden], col[hidden], thead[hidden], tbody[hidden],\n        tfoot[hidden], tr[hidden], td[hidden], th[hidden] {\n            visibility: collapse;\n        }\n\n    table {\n        box-sizing: border-box;\n        border-spacing: 2px;\n        border-collapse: separate;\n        text-indent: initial;\n    }\n\n    td, th {\n        padding: 1px;\n    }\n\n    th {\n        font-weight: bold;\n    }\n\n    thead, tbody, tfoot, table > tr {\n        vertical-align: middle;\n    }\n\n    tr, td, th {\n        vertical-align: inherit;\n    }\n\n    table, td, th {\n        border-color: gray;\n    }\n\n    thead, tbody, tfoot, tr {\n        border-color: inherit;\n    }\n    /*table[rules=none i], table[rules=groups i], table[rules=rows i],\ntable[rules=cols i], table[rules=all i], table[frame=void i],\ntable[frame=above i], table[frame=below i], table[frame=hsides i],\ntable[frame=lhs i], table[frame=rhs i], table[frame=vsides i],\ntable[frame=box i], table[frame=border i],\ntable[rules=none i] > tr > td, table[rules=none i] > tr > th,\ntable[rules=groups i] > tr > td, table[rules=groups i] > tr > th,\ntable[rules=rows i] > tr > td, table[rules=rows i] > tr > th,\ntable[rules=cols i] > tr > td, table[rules=cols i] > tr > th,\ntable[rules=all i] > tr > td, table[rules=all i] > tr > th,\ntable[rules=none i] > thead > tr > td, table[rules=none i] > thead > tr > th,\ntable[rules=groups i] > thead > tr > td, table[rules=groups i] > thead > tr > th,\ntable[rules=rows i] > thead > tr > td, table[rules=rows i] > thead > tr > th,\ntable[rules=cols i] > thead > tr > td, table[rules=cols i] > thead > tr > th,\ntable[rules=all i] > thead > tr > td, table[rules=all i] > thead > tr > th,\ntable[rules=none i] > tbody > tr > td, table[rules=none i] > tbody > tr > th,\ntable[rules=groups i] > tbody > tr > td, table[rules=groups i] > tbody > tr > th,\ntable[rules=rows i] > tbody > tr > td, table[rules=rows i] > tbody > tr > th,\ntable[rules=cols i] > tbody > tr > td, table[rules=cols i] > tbody > tr > th,\ntable[rules=all i] > tbody > tr > td, table[rules=all i] > tbody > tr > th,\ntable[rules=none i] > tfoot > tr > td, table[rules=none i] > tfoot > tr > th,\ntable[rules=groups i] > tfoot > tr > td, table[rules=groups i] > tfoot > tr > th,\ntable[rules=rows i] > tfoot > tr > td, table[rules=rows i] > tfoot > tr > th,\ntable[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th,\ntable[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th {\n    border-color: black;\n}*/\n    input, select, option, optgroup, button, textarea, keygen {\n        text-indent: initial;\n    }\n\n    textarea {\n        white-space: pre-wrap;\n    }\n\n    input[type=\"radio\"], input[type=\"checkbox\"], input[type=\"reset\"], input[type=\"button\"],\n    input[type=\"submit\"], select, button {\n        box-sizing: border-box;\n    }\n\n    input[type=\"button\"], button {\n        padding: 0.3em 0.5em;\n    }\n\n    hr {\n        color: gray;\n        border-style: inset;\n        border-width: 1px;\n        margin: 0.5em auto;\n    }\n\n    fieldset {\n        margin-left: 2px;\n        margin-right: 2px;\n        border: groove 2px ThreeDFace;\n        padding: 0.35em 0.625em 0.75em;\n    }\n\n    legend {\n        padding-left: 2px;\n        padding-right: 2px;\n    }\n}\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    > .layout-toolbox-wrapper {\r\n        position: relative;\r\n        margin-left: @container-padding;\r\n        width: 220px;\r\n        flex-shrink: 0;\r\n\r\n        > .layout-toolbox {\r\n            border: 1px solid @gray-border;\r\n            width: 220px;\r\n            min-height: 400px;\r\n            padding: @container-padding / 2;\r\n            background-color: @gray-bg;\r\n\r\n            &.sticky-top {\r\n                position: fixed;\r\n                top: 0;\r\n                max-height: 100%;\r\n                overflow-y: auto;\r\n            }\r\n\r\n            &.sticky-bottom {\r\n                position: absolute;\r\n                bottom: 0;\r\n            }\r\n\r\n            .layout-toolbox-group {\r\n                margin-top: @container-padding;\r\n\r\n                .layout-toolbox-group-heading {\r\n                    display: block;\r\n                    margin-bottom: @container-padding / 3;\r\n                    text-decoration: none;\r\n                \r\n                    &:before {\r\n                        display: inline-block;\r\n                        width: 10px;\r\n                        margin-right: @container-padding / 3;\r\n                        font: normal normal normal 14px/1 FontAwesome;\r\n                        text-align: center;\r\n                        content: \"\\f0d7\";\r\n                    }\r\n                }\r\n            \r\n                &.collapsed {\r\n                    .layout-toolbox-group-heading:before {\r\n                        content: \"\\f0da\";\r\n                    }\r\n\r\n                    .layout-toolbox-items {\r\n                        display: none;\r\n                    }\r\n                }\r\n\r\n                .layout-toolbox-section + .layout-toolbox-section {\r\n                    margin-top: @container-padding / 3;\r\n                }\r\n\r\n                .layout-toolbox-item {\r\n                    border: 1px solid @gray-border;\r\n                    background-color: #fff;\r\n                    padding: (@container-padding - 3) @container-padding;\r\n                    cursor: default;\r\n\r\n                    i {\r\n                        display: inline-block;\r\n                        width: 16px;\r\n                        font: normal normal normal 14px/1 FontAwesome;\r\n                    }\r\n\r\n                    + .layout-toolbox-item {\r\n                        margin-top: @container-padding / 3;\r\n                    }\r\n                }\r\n\r\n                + .layout-toolbox-group {\r\n                    margin-top: @container-padding / 2;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-popup {\n        display: none; // Shown only in active or focused states.\n        position: absolute;\n        margin: 0;\n        -moz-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n        -webkit-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n        box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n        border: 1px solid @gray-border;\n        padding: 2px 0;\n        background-color: #f7f7f7;\n        list-style: none;\n        z-index: 20;\n        color: @gray-text;\n        text-align: left;\n        cursor: default;\n        white-space: nowrap;\n        line-height: normal;\n\n        .layout-popup-flex {\n            display: flex;\n            padding: 2px 5px;\n\n            .layout-popup-column + .layout-popup-column {\n                margin-left: 4px;\n                border-left: 1px solid fade(gray, 15%);\n                padding-left: 4px;\n            }\n        }\n\n        .layout-popup-item {\n            padding: 4px 6px;\n        }\n\n        .layout-popup-label {\n            font-size: 0.9em;\n            font-weight: bold;\n            color: @gray-text;\n        }\n\n        .layout-popup-action:hover {\n            background-color: @gray-bg;\n            cursor: pointer;\n        }\n\n        .layout-popup-input {\n            > label {\n                display: block;\n                font-size: 0.9em;\n            }\n        }\n    }\n}\n"],"sourceRoot":"/source/"} */ \ No newline at end of file +/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Editor.less","LayoutEditor.css","Element.less","Container.less","Canvas.less","Row.less","Column.less","Content.less","Reset.less","Toolbox.less","Popup.less"],"names":[],"mappings":"AAEA;EACI,sBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,gBAAA;EACA,gBAAA;EACA,6BAAA;MAAA,wBAAA;UAAA,qBAAA;CCDH;ADHD;EAOQ,qBAAA;MAAA,qBAAA;UAAA,aAAA;EACA,0BAAA;EACA,0BAAA;CCDP;ADRD;EAYY,cAAA;EACA,oBAAA;EACA,iBAAA;CCDX;ADbD;EAiBgB,uBAAA;CCDf;ADhBD;EAuBQ,oBAAA;CCJP;;ACnBD;EAEQ,mBAAA;EACA,cAAA;EACA,gBAAA;EACA,iBAAA;EACA,WAAA;CDqBP;AClBO;EACI,eAAA;CDoBX;AC9BD;EAegB,cAAA;EACA,mBAAA;EACA,UAAA;EACA,YAAA;EACA,aAAA;EACA,eAAA;EACA,iBAAA;EACA,oBAAA;EACA,kBAAA;EACA,uBAAA;CDkBf;AC1CD;EA2BoB,sBAAA;EACA,aAAA;EACA,mBAAA;CDkBnB;AC/CD;EAiCoB,gBAAA;CDiBnB;AClDD;EAqCoB,cAAA;EACA,YAAA;EACA,gBAAA;EACA,mBAAA;CDgBnB;ACxDD;EA6CgB,WAAA;EACA,WAAA;CDcf;AC5DD;EAqDQ,iBAAA;CDUP;ACPG;;EAGQ,kBAAA;EACA,oBAAA;CDQX;ACZG;;EAOY,aAAA;CDSf;AChBG;EAcQ,uCAAA;CDKX;ACnBG;EAiBY,eAAA;EACA,YAAA;EACA,2CAAA;CDKf;ACxBG;EA2BQ,sBAAA;CDAX;AC3BG;EA8BY,eAAA;EACA,0BAAA;EACA,eAAA;CDAf;AChCG;EAmCgB,sBAAA;CDAnB;ACCmB;EACI,0BAAA;CDCvB;ACEmB;EACI,gBAAA;EACA,gCAAA;CDAvB;ACEuB;EACI,0BAAA;CDA3B;ACImB;EACI,eAAA;EACA,0BAAA;CDFvB;ACIuB;EACI,0BAAA;CDF3B;ACpDG;EA+DQ,2CAAA;CDRX;AC/GD;EA4HQ,cAAA;CDVP;AClHD;EAiIQ,uDAAA;CDZP;ACrHD;EAoIY,eAAA;EACA,+BAAA;EACA,iBAAA;EACA,sCAAA;EACA,2CAAA;CDZX;AC5HD;EA+IY,gBAAA;EACA,iBAAA;CDhBX;;AEhID;EAMgB,cAAA;EACA,+BAAA;MAAA,2BAAA;UAAA,uBAAA;EACA,aAAA;EACA,iBAAA;EACA,4CAAA;EACA,mBAAA;EACA,cAAA;EACA,gCAAA;MAAA,sBAAA;UAAA,wBAAA;EACA,gBAAA;EACA,mBAAA;EACA,aAAA;EACA,mBAAA;CF8Hf;AE/ID;EAqBgB,cAAA;CF6Hf;AElJD;EAyBoB,iBAAA;CF4HnB;AErJD;EA8BoB,cAAA;CF0HnB;AEtHW;EAEQ,sBAAA;EAAA,qBAAA;EAAA,cAAA;CFuHnB;AEzHW;EAMQ,mBAAA;EACA,OAAA;EACA,SAAA;EACA,UAAA;EACA,QAAA;CFsHnB;AEhHG;EAGY,4CAAA;CFgHf;AEnHG;EAMgB,aAAA;CFgHnB;AEtHG;EAWY,cAAA;CF8Gf;AEzHG;EAcgB,cAAA;CF8GnB;;AG9KD;EAGY,cAAA;CH+KX;;AIhLO;EAEQ,2DAAA;CJkLf;AIpLO;EAIY,4BAAA;CJmLnB;AIvLO;EASQ,0BAAA;CJiLf;AI1LO;EAWY,0BAAA;CJkLnB;;AK/LD;EAIgB,cAAA;EACA,mBAAA;EACA,YAAA;EACA,OAAA;EACA,YAAA;EACA,aAAA;EACA,mBAAA;CL+Lf;AKzMD;EAcgB,WAAA;CL8Lf;AK5MD;EAkBgB,YAAA;CL6Lf;AKzLO;EACI,eAAA;CL2LX;;AMjND;;EAEQ,gBAAA;CNoNP;AMtND;;EAOgB,aAAA;EACA,mBAAA;EACA,oBAAA;ENmNd,yFAAyF;EACzF,qCAAqC;EACrC,qCAAqC;EACrC,uDAAuD;EACvD,wDAAwD;EACxD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BC;CACF;AM5PD;;ECAQ,UAAA;EACA,WAAA;EACA,wBAAA;CPgQP;AMlQD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECOQ,eAAA;CP6RP;AMpSD;;;;;;;;;;;;;;ECWQ,gBAAA;EACA,mBAAA;CPySP;AMrTD;;;;ECgBQ,kBAAA;EACA,mBAAA;CP2SP;AM5TD;;ECqBQ,mBAAA;CP2SP;AMhUD;;;;;;;;ECyBQ,uBAAA;EACA,iBAAA;CPiTP;AM3UD;;;;;;;;;;EC8BQ,mBAAA;CPyTP;AMvVD;;;;ECkCQ,oBAAA;CP2TP;AM7VD;;;;;;;;ECsCQ,uBAAA;CPiUP;AMvWD;;EC0CQ,kBAAA;CPiUP;AM3WD;;EC8CQ,mBAAA;CPiUP;AM/WD;;ECkDQ,oBAAA;CPiUP;AMnXD;;ECsDQ,sBAAA;CPiUP;AMvXD;;;;EC0DQ,oBAAA;EACA,mBAAA;CPmUP;AM9XD;;ECgEQ,cAAA;CPkUP;AMlYD;;ECoEQ,mBAAA;EACA,oBAAA;CPkUP;AMvYD;;ECyEQ,mBAAA;EACA,oBAAA;EACA,eAAA;EACA,8BAAA;EACA,4BAAA;UAAA,oBAAA;CPkUP;AM/YD;;ECiFQ,6BAAA;CPkUP;AMnZD;;ECqFQ,6BAAA;CPkUP;AMvZD;;;;;;;;;;ECyFQ,sBAAA;CP0UP;AMnaD;;EC8FQ,eAAA;CPyUP;AMvaD;;ECkGQ,eAAA;CPyUP;AM3aD;;;;ECsGQ,2BAAA;CP2UP;AMjbD;;;;;;;;EC2GQ,aAAA;CPgVP;AM3bD;;EC+GQ,cAAA;CPgVP;AM/bD;;ECmHQ,mBAAA;EACA,aAAA;CPgVP;AMpcD;;;;ECwHQ,kCAAA;CPkVP;AM1cD;;;;EC4HQ,2BAAA;CPoVP;AMhdD;;;;;;ECgIQ,8BAAA;CPwVP;AMxdD;;ECoIQ,uBAAA;CPwVP;AM5dD;;ECwIQ,oBAAA;CPwVP;AMheD;;EC4IQ,qBAAA;CPwVP;AMpeD;;ECgJQ,cAAA;EACA,iBAAA;CPwVP;AMzeD;;ECqJQ,oBAAA;CPwVP;AM7eD;;ECyJQ,iBAAA;CPwVP;AMjfD;;EC6JQ,oBAAA;CPwVP;AMrfD;;;;;;;;;;;;;;;;;;;;;;ECiKQ,eAAA;CP4WP;AM7gBD;;ECqKQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP4WP;AMphBD;;EC4KQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP4WP;AM3hBD;;ECmLQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP4WP;AMliBD;;EC0LQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP4WP;AMziBD;;ECiMQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP4WP;AMhjBD;;ECwMQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP4WP;AMvjBD;;;;;;;;;;;;EC+MQ,eAAA;CPsXP;AMrkBD;;ECmNQ,mBAAA;CPsXP;AMzkBD;;;;;;;;ECuNQ,gBAAA;EACA,mBAAA;CP4XP;AMplBD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EC+NY,cAAA;EACA,iBAAA;CPuZX;AMvnBD;;ECoOQ,kBAAA;CPuZP;AM3nBD;;;;;;ECwOQ,mBAAA;CP2ZP;AMnoBD;;EC4OQ,yBAAA;CP2ZP;AMvoBD;;;;ECgPQ,sBAAA;CP6ZP;AM7oBD;;;;;;;;;;;;ECsPY,wBAAA;CPqaX;AM3pBD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECkQgB,wBAAA;CP+bf;AMjsBD;;ECsQQ,eAAA;CP+bP;AMrsBD;;EC0QQ,uBAAA;CP+bP;AMzsBD;;;;EC8QQ,4BAAA;CPicP;AM/sBD;;;;ECkRQ,sBAAA;CPmcP;AMrtBD;;;;ECsRQ,4BAAA;CPqcP;AM3tBD;;;;EC0RQ,yBAAA;CPucP;AMjuBD;;;;EC8RQ,4BAAA;CPycP;AMvuBD;;;;ECkSQ,mBAAA;CP2cP;AM7uBD;;;;;;;;ECsSQ,oBAAA;CPidP;AMvvBD;;;;;;;;;;;;;;;;EC2SY,qBAAA;CP8dX;AMzwBD;;EC+SQ,uBAAA;EACA,oBAAA;EACA,0BAAA;EACA,qBAAA;CP8dP;AMhxBD;;;;ECsTQ,aAAA;CPgeP;AMtxBD;;EC0TQ,kBAAA;CPgeP;AM1xBD;;;;;;;;EC8TQ,uBAAA;CPseP;AMpyBD;;;;;;ECkUQ,wBAAA;CP0eP;AM5yBD;;;;;;ECsUQ,mBAAA;CP8eP;AMpzBD;;;;;;;;EC0UQ,sBAAA;CPofP;AM9zBD;;;;;;;;;;;;;;ECwWQ,qBAAA;CPseP;AM90BD;;EC4WQ,sBAAA;CPseP;AMl1BD;;;;;;;;;;;;;;ECiXQ,uBAAA;CPifP;AMl2BD;;;;ECqXQ,qBAAA;CPmfP;AMx2BD;;ECyXQ,YAAA;EACA,oBAAA;EACA,kBAAA;EACA,mBAAA;CPmfP;AM/2BD;;ECgYQ,iBAAA;EACA,kBAAA;EACA,8BAAA;EACA,+BAAA;CPmfP;AMt3BD;;ECuYQ,kBAAA;EACA,mBAAA;CPmfP;AM33BD;;EAeoB,yBAAA;CNg3BnB;AM/3BD;;EAmBoB,4BAAA;CNg3BnB;AM32BO;;;;EAEQ,eAAA;EACA,YAAA;EACA,gBAAA;EACA,aAAA;CN+2Bf;AM54BD;;EAmCQ,eAAA;EACA,YAAA;EACA,gBAAA;EACA,aAAA;CN62BP;;AQp5BD;EAEQ,mBAAA;EACA,kBAAA;EACA,aAAA;EACA,uBAAA;MAAA,qBAAA;UAAA,eAAA;CRs5BP;AQ35BD;EAQY,0BAAA;EACA,aAAA;EACA,kBAAA;EACA,aAAA;EACA,0BAAA;CRs5BX;AQp5BW;EACI,gBAAA;EACA,OAAA;EACA,iBAAA;EACA,iBAAA;CRs5Bf;AQn5BW;EACI,mBAAA;EACA,UAAA;CRq5Bf;AQ56BD;EA2BgB,iBAAA;CRo5Bf;AQ/6BD;EA8BoB,eAAA;EACA,mBAAA;EACA,sBAAA;CRo5BnB;AQl5BmB;EACI,sBAAA;EACA,YAAA;EACA,kBAAA;EACA,8CAAA;EACA,mBAAA;EACA,iBAAA;CRo5BvB;AQh5Be;EAEQ,iBAAA;CRi5BvB;AQn5Be;EAMQ,cAAA;CRg5BvB;AQl8BD;EAuDoB,gBAAA;CR84BnB;AQr8BD;EA2DoB,0BAAA;EACA,uBAAA;EACA,kBAAA;EACA,gBAAA;CR64BnB;AQ38BD;EAiEwB,sBAAA;EACA,YAAA;EACA,8CAAA;CR64BvB;AQh9BD;EAuEwB,gBAAA;CR44BvB;AQn9BD;EA4EoB,gBAAA;CR04BnB;;ASt9BD;EAEQ,cAAA;EACA,mBAAA;EACA,UAAA;EAGA,iDAAA;EACA,0BAAA;EACA,eAAA;EACA,0BAAA;EACA,iBAAA;EACA,YAAA;EACA,eAAA;EACA,iBAAA;EACA,gBAAA;EACA,oBAAA;EACA,oBAAA;CTw9BP;ASz+BD;EAoBY,sBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,iBAAA;CTw9BX;AS7+BD;EAwBgB,iBAAA;EACA,iDAAA;EACA,kBAAA;CTw9Bf;ASl/BD;EA+BY,iBAAA;CTs9BX;ASr/BD;EAmCY,iBAAA;EACA,kBAAA;EACA,eAAA;CTq9BX;AS1/BD;EAyCY,0BAAA;EACA,gBAAA;CTo9BX;AS9/BD;EA+CgB,eAAA;EACA,iBAAA;CTk9Bf","file":"LayoutEditor.css","sourcesContent":["@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    display: flex;\r\n    margin-top: 1em;\r\n    font-size: @font-size;\r\n    align-items: stretch;\r\n\r\n    > .layout-canvas-wrapper {\r\n        flex-grow: 1;\r\n        background-color: @gray-bg;\r\n        border: 1px solid @gray-border;\r\n\r\n        > .layout-toolbar-container {\r\n            display: none;\r\n            margin: @container-padding @container-padding 0;\r\n            min-height: 71px;\r\n\r\n            > .mce-panel {\r\n                width: 100% !important;\r\n            }\r\n        }\r\n    }\r\n\r\n    .layout-snippet {\r\n        background: #e8e8e8;\r\n    }\r\n}\r\n",".layout-editor {\n  display: flex;\n  margin-top: 1em;\n  font-size: 14px;\n  align-items: stretch;\n}\n.layout-editor > .layout-canvas-wrapper {\n  flex-grow: 1;\n  background-color: #f3f4f5;\n  border: 1px solid #e4e5e6;\n}\n.layout-editor > .layout-canvas-wrapper > .layout-toolbar-container {\n  display: none;\n  margin: 12px 12px 0;\n  min-height: 71px;\n}\n.layout-editor > .layout-canvas-wrapper > .layout-toolbar-container > .mce-panel {\n  width: 100% !important;\n}\n.layout-editor .layout-snippet {\n  background: #e8e8e8;\n}\n\n.layout-editor .layout-element {\n  position: relative;\n  margin-top: 0;\n  margin-right: 0;\n  margin-bottom: 0;\n  padding: 0;\n}\n.layout-editor .layout-element:not(.layout-column) {\n  margin-left: 0;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel {\n  display: none;\n  position: absolute;\n  margin: 0;\n  z-index: 20;\n  height: 25px;\n  padding: 0 6px;\n  list-style: none;\n  white-space: nowrap;\n  line-height: 25px;\n  vertical-align: middle;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-item {\n  display: inline-block;\n  height: 25px;\n  padding: 1px 6px 0;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-label {\n  font-size: 13px;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-action {\n  display: none;\n  width: 28px;\n  cursor: pointer;\n  text-align: center;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel-main {\n  top: -27px;\n  left: -2px;\n}\n.layout-editor li.layout-element {\n  list-style: none;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active,\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused {\n  border-width: 2px;\n  border-style: solid;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active > .layout-element-wrapper,\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper {\n  margin: -2px;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active {\n  border-color: rgba(104, 104, 104, 0.1);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active > .layout-element-wrapper > .layout-panel-main {\n  display: block;\n  z-index: 30;\n  background-color: rgba(104, 104, 104, 0.1);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused {\n  border-color: #648721;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel {\n  display: block;\n  background-color: #648721;\n  color: #fefefe;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action {\n  display: inline-block;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action:hover {\n  background-color: #82b02b;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.disabled {\n  cursor: default;\n  color: rgba(254, 254, 254, 0.4);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.disabled:hover {\n  background-color: #648721;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.active {\n  color: #deff42;\n  background-color: #739b26;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.active:hover {\n  background-color: #82b02b;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-selected {\n  background-color: rgba(100, 135, 33, 0.08);\n}\n.layout-editor .ui-sortable-placeholder {\n  display: none;\n}\n.layout-editor .layout-element-droptarget {\n  box-shadow: inset 0 0 12px 6px rgba(100, 135, 33, 0.5);\n}\n.layout-editor .layout-element-droptarget .ui-sortable-placeholder {\n  display: block;\n  visibility: visible !important;\n  min-height: 78px;\n  border: 2px dashed #648721 !important;\n  background-color: rgba(100, 135, 33, 0.16);\n}\n.layout-editor .media-thumbnail img {\n  max-width: 100%;\n  max-height: 100%;\n}\n\n.layout-editor .layout-container > .layout-element-wrapper > .layout-container-children-placeholder {\n  display: none;\n  flex-direction: column;\n  margin: 11px;\n  min-height: 80px;\n  border: 1px dashed rgba(124, 124, 124, 0.4);\n  border-radius: 4px;\n  padding: 12px;\n  justify-content: center;\n  font-size: 13px;\n  font-style: italic;\n  opacity: 0.6;\n  text-align: center;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children {\n  padding: 12px;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-container) + .layout-element:not(.layout-container) {\n  margin-top: 12px;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children > .ui-sortable-helper:first-child + .layout-element:not(.layout-container) {\n  margin-top: 0;\n}\n.layout-editor .layout-container > .layout-element-wrapper.layout-container-empty > .layout-container-children-placeholder {\n  display: flex;\n}\n.layout-editor .layout-container > .layout-element-wrapper.layout-container-empty > .layout-children {\n  position: absolute;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) {\n  border: 1px dashed rgba(124, 124, 124, 0.6);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin: -1px;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-container + .layout-container:not(.layout-element-active) {\n  border-top: 0;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-container + .layout-container:not(.layout-element-active) > .layout-element-wrapper {\n  margin-top: 0;\n}\n\n.layout-editor .layout-canvas #dummy {\n  display: none;\n}\n\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) {\n  border-top: 1px dashed rgba(124, 124, 124, 0.6) !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin-top: -1px !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element + .layout-element:not(.layout-element-active) {\n  border-left: 0 !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element + .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin-left: 0 !important;\n}\n\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar {\n  display: none;\n  position: absolute;\n  z-index: 30;\n  top: 0;\n  width: 16px;\n  height: 100%;\n  cursor: col-resize;\n}\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar-left {\n  left: -6px;\n}\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar-right {\n  right: -6px;\n}\n.layout-editor .layout-column.layout-element-focused > .layout-element-wrapper > .layout-column-resize-bar {\n  display: block;\n}\n\n.layout-editor .layout-content,\n.layout-editor .layout-html {\n  min-height: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup {\n  padding: 2px;\n  overflow-x: hidden;\n  line-height: normal;\n  /* this color is just a suggestion and can be changed based on implementation feedback */\n  /* this also has bidi implications */\n  /* this also has bidi implications */\n  /* LTR-specific: use 'margin-right' for rtl elements */\n  /* LTR-specific: use 'padding-right' for rtl elements */\n  /*table[rules=none i], table[rules=groups i], table[rules=rows i],\ntable[rules=cols i], table[rules=all i], table[frame=void i],\ntable[frame=above i], table[frame=below i], table[frame=hsides i],\ntable[frame=lhs i], table[frame=rhs i], table[frame=vsides i],\ntable[frame=box i], table[frame=border i],\ntable[rules=none i] > tr > td, table[rules=none i] > tr > th,\ntable[rules=groups i] > tr > td, table[rules=groups i] > tr > th,\ntable[rules=rows i] > tr > td, table[rules=rows i] > tr > th,\ntable[rules=cols i] > tr > td, table[rules=cols i] > tr > th,\ntable[rules=all i] > tr > td, table[rules=all i] > tr > th,\ntable[rules=none i] > thead > tr > td, table[rules=none i] > thead > tr > th,\ntable[rules=groups i] > thead > tr > td, table[rules=groups i] > thead > tr > th,\ntable[rules=rows i] > thead > tr > td, table[rules=rows i] > thead > tr > th,\ntable[rules=cols i] > thead > tr > td, table[rules=cols i] > thead > tr > th,\ntable[rules=all i] > thead > tr > td, table[rules=all i] > thead > tr > th,\ntable[rules=none i] > tbody > tr > td, table[rules=none i] > tbody > tr > th,\ntable[rules=groups i] > tbody > tr > td, table[rules=groups i] > tbody > tr > th,\ntable[rules=rows i] > tbody > tr > td, table[rules=rows i] > tbody > tr > th,\ntable[rules=cols i] > tbody > tr > td, table[rules=cols i] > tbody > tr > th,\ntable[rules=all i] > tbody > tr > td, table[rules=all i] > tbody > tr > th,\ntable[rules=none i] > tfoot > tr > td, table[rules=none i] > tfoot > tr > th,\ntable[rules=groups i] > tfoot > tr > td, table[rules=groups i] > tfoot > tr > th,\ntable[rules=rows i] > tfoot > tr > td, table[rules=rows i] > tfoot > tr > th,\ntable[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th,\ntable[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th {\n    border-color: black;\n}*/\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup *,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup * {\n  margin: 0;\n  padding: 0;\n  box-sizing: content-box;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup center,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup center,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup div,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup div,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figcaption,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figcaption,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup footer,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup footer,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup form,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup form,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup header,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup header,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  margin-top: 1em;\n  margin-bottom: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure {\n  margin-left: 40px;\n  margin-right: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup address {\n  font-style: italic;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  font-family: monospace;\n  white-space: pre;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup cite,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup cite,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dfn,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dfn,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup em,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup em,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup i,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup i,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup var,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup var {\n  font-style: italic;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup b,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup b,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strong,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup strong {\n  font-weight: bolder;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup code,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup code,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup kbd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup kbd,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup samp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup samp,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tt {\n  font-family: monospace;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup big,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup big {\n  font-size: larger;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup small,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup small {\n  font-size: smaller;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sub {\n  vertical-align: sub;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sup {\n  vertical-align: super;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sup {\n  line-height: normal;\n  font-size: smaller;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ruby {\n  display: ruby;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rb {\n  display: ruby-base;\n  white-space: nowrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rt {\n  display: ruby-text;\n  white-space: nowrap;\n  font-size: 50%;\n  font-variant-east-asian: ruby;\n  text-emphasis: none;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rbc {\n  display: ruby-base-container;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rtc {\n  display: ruby-text-container;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rtc {\n  unicode-bidi: isolate;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :link {\n  color: #0000EE;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :visited {\n  color: #551A8B;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :visited {\n  text-decoration: underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:link[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup a:link[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:visited[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup a:visited[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:link[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup area:link[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:visited[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup area:visited[rel~=help] {\n  cursor: help;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :focus,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :focus {\n  outline: auto;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup mark,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup mark {\n  background: yellow;\n  color: black;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup abbr[title],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup abbr[title],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup acronym[title],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup acronym[title] {\n  text-decoration: dotted underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ins,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ins,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup u,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup u {\n  text-decoration: underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup del,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup del,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup s,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup s,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strike,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup strike {\n  text-decoration: line-through;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blink,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blink {\n  text-decoration: blink;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::before,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup q::before {\n  content: open-quote;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::after,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup q::after {\n  content: close-quote;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup br,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup br {\n  content: '\\A';\n  white-space: pre;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nobr {\n  white-space: nowrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup wbr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup wbr {\n  content: '\\200B';\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr wbr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nobr wbr {\n  white-space: normal;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup article,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup article,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup aside,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup aside,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nav,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nav,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup section,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup section {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h1 {\n  margin-top: 0.67em;\n  margin-bottom: 0.67em;\n  font-size: 2.00em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h2 {\n  margin-top: 0.83em;\n  margin-bottom: 0.83em;\n  font-size: 1.50em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h3 {\n  margin-top: 1.00em;\n  margin-bottom: 1.00em;\n  font-size: 1.17em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h4 {\n  margin-top: 1.33em;\n  margin-bottom: 1.33em;\n  font-size: 1.00em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h5 {\n  margin-top: 1.67em;\n  margin-bottom: 1.67em;\n  font-size: 0.83em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h6 {\n  margin-top: 2.33em;\n  margin-bottom: 2.33em;\n  font-size: 0.67em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dt,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup li,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup li {\n  display: list-item;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  margin-top: 1em;\n  margin-bottom: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul {\n  margin-top: 0;\n  margin-bottom: 0;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dd {\n  margin-left: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  padding-left: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol {\n  list-style-type: decimal;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  list-style-type: disc;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul {\n  list-style-type: circle;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul ul {\n  list-style-type: square;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table {\n  display: table;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup caption,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup caption {\n  display: table-caption;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup[hidden] {\n  display: table-column-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col[hidden] {\n  display: table-column;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead[hidden] {\n  display: table-header-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody[hidden] {\n  display: table-row-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot[hidden] {\n  display: table-footer-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr[hidden] {\n  display: table-row;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th[hidden] {\n  display: table-cell;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th[hidden] {\n  visibility: collapse;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table {\n  box-sizing: border-box;\n  border-spacing: 2px;\n  border-collapse: separate;\n  text-indent: initial;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  padding: 1px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table > tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table > tr {\n  vertical-align: middle;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  vertical-align: inherit;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  border-color: gray;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr {\n  border-color: inherit;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup option,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup option,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup optgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup optgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup keygen,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup keygen {\n  text-indent: initial;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup textarea {\n  white-space: pre-wrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"radio\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"radio\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"checkbox\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"checkbox\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"reset\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"reset\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"submit\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"submit\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button {\n  box-sizing: border-box;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button {\n  padding: 0.3em 0.5em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hr {\n  color: gray;\n  border-style: inset;\n  border-width: 1px;\n  margin: 0.5em auto;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup fieldset,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup fieldset {\n  margin-left: 2px;\n  margin-right: 2px;\n  border: groove 2px ThreeDFace;\n  padding: 0.35em 0.625em 0.75em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup legend {\n  padding-left: 2px;\n  padding-right: 2px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:first-child,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup > *:first-child {\n  margin-top: 0 !important;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:last-child,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup > *:last-child {\n  margin-bottom: 0 !important;\n}\n.layout-editor .layout-content.layout-content-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-html.layout-content-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-content.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-html.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img {\n  display: block;\n  width: 100%;\n  max-width: 100%;\n  height: auto;\n}\n.layout-editor .img-responsive,\n.layout-editor .img-responsive img {\n  display: block;\n  width: 100%;\n  max-width: 100%;\n  height: auto;\n}\n\n.layout-editor > .layout-toolbox-wrapper {\n  position: relative;\n  margin-left: 12px;\n  width: 220px;\n  flex-shrink: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox {\n  border: 1px solid #e4e5e6;\n  width: 220px;\n  min-height: 400px;\n  padding: 6px;\n  background-color: #f3f4f5;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-top {\n  position: fixed;\n  top: 0;\n  max-height: 100%;\n  overflow-y: auto;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-bottom {\n  position: absolute;\n  bottom: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group {\n  margin-top: 12px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading {\n  display: block;\n  margin-bottom: 4px;\n  text-decoration: none;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading:before {\n  display: inline-block;\n  width: 10px;\n  margin-right: 4px;\n  font: normal normal normal 14px/1 FontAwesome;\n  text-align: center;\n  content: \"\\f0d7\";\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-group-heading:before {\n  content: \"\\f0da\";\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-items {\n  display: none;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-section + .layout-toolbox-section {\n  margin-top: 4px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item {\n  border: 1px solid #e4e5e6;\n  background-color: #fff;\n  padding: 9px 12px;\n  cursor: default;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item i {\n  display: inline-block;\n  width: 16px;\n  font: normal normal normal 14px/1 FontAwesome;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item + .layout-toolbox-item {\n  margin-top: 4px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group + .layout-toolbox-group {\n  margin-top: 6px;\n}\n\n.layout-editor .layout-popup {\n  display: none;\n  position: absolute;\n  margin: 0;\n  -moz-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  -webkit-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  border: 1px solid #e4e5e6;\n  padding: 2px 0;\n  background-color: #f7f7f7;\n  list-style: none;\n  z-index: 20;\n  color: #7c7c7c;\n  text-align: left;\n  cursor: default;\n  white-space: nowrap;\n  line-height: normal;\n}\n.layout-editor .layout-popup .layout-popup-flex {\n  display: flex;\n  padding: 2px 5px;\n}\n.layout-editor .layout-popup .layout-popup-flex .layout-popup-column + .layout-popup-column {\n  margin-left: 4px;\n  border-left: 1px solid rgba(128, 128, 128, 0.15);\n  padding-left: 4px;\n}\n.layout-editor .layout-popup .layout-popup-item {\n  padding: 4px 6px;\n}\n.layout-editor .layout-popup .layout-popup-label {\n  font-size: 0.9em;\n  font-weight: bold;\n  color: #7c7c7c;\n}\n.layout-editor .layout-popup .layout-popup-action:hover {\n  background-color: #f3f4f5;\n  cursor: pointer;\n}\n.layout-editor .layout-popup .layout-popup-input > label {\n  display: block;\n  font-size: 0.9em;\n}\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    .layout-element {\r\n        position: relative;\r\n        margin-top: 0;\r\n        margin-right: 0;\r\n        margin-bottom: 0;\r\n        padding: 0;\r\n\r\n        // We don't fuck with the left margin of columns, because Bootstrap uses these to render column offsets.\r\n        &:not(.layout-column) {\r\n            margin-left: 0;\r\n        }\r\n\r\n        > .layout-element-wrapper {\r\n            > .layout-panel {\r\n                display: none; // Shown only in active or focused states.\r\n                position: absolute;\r\n                margin: 0;\r\n                z-index: 20;\r\n                height: 25px;\r\n                padding: 0 6px;\r\n                list-style: none;\r\n                white-space: nowrap;\r\n                line-height: 25px;\r\n                vertical-align: middle;\r\n\r\n                > .layout-panel-item {\r\n                    display: inline-block;\r\n                    height: 25px;\r\n                    padding: 1px 6px 0;\r\n                }\r\n\r\n                > .layout-panel-label {\r\n                    font-size: @font-size - 1;\r\n                }\r\n\r\n                > .layout-panel-action {\r\n                    display: none; // Shown only in focused state.\r\n                    width: 28px;\r\n                    cursor: pointer;\r\n                    text-align: center;\r\n                }\r\n            }\r\n\r\n            > .layout-panel-main {\r\n                top: -27px;\r\n                left: -2px;\r\n            }\r\n        }\r\n    }\r\n\r\n    // When dragging from toolbox, elements will be li rather than div.\r\n    li.layout-element {\r\n        list-style: none;\r\n    }\r\n\r\n    &:not(.layout-editor-dragging) {\r\n\r\n        .layout-element-active, .layout-element-focused {\r\n            border-width: 2px;\r\n            border-style: solid;\r\n\r\n            > .layout-element-wrapper {\r\n                margin: -2px;\r\n            }\r\n        }\r\n\r\n        .layout-element-active {\r\n            @active-highlight: fade(#686868, 10%);\r\n\r\n            border-color: @active-highlight;\r\n\r\n            > .layout-element-wrapper > .layout-panel-main {\r\n                display: block; // To reveal.\r\n                z-index: 30;\r\n                background-color: @active-highlight;\r\n            }\r\n        }\r\n\r\n        .layout-element-focused {\r\n            @focused-highlight: #648721;\r\n            @focused-text: #fefefe;\r\n\r\n            border-color: @focused-highlight;\r\n\r\n            > .layout-element-wrapper > .layout-panel {\r\n                display: block; // To reveal.\r\n                background-color: @focused-highlight;\r\n                color: @focused-text;\r\n\r\n                > .layout-panel-action {\r\n                    display: inline-block; // To reveal.\r\n                    &:hover {\r\n                        background-color: lighten(@focused-highlight, 10%);\r\n                    }\r\n\r\n                    &.disabled {\r\n                        cursor: default;\r\n                        color: fade(@focused-text, 40%);\r\n\r\n                        &:hover {\r\n                            background-color: @focused-highlight;\r\n                        }\r\n                    }\r\n\r\n                    &.active {\r\n                        color: lighten(saturate(spin(@focused-highlight, -10), 100%), 30%);\r\n                        background-color: lighten(@focused-highlight, 5%);\r\n\r\n                        &:hover {\r\n                            background-color: lighten(@focused-highlight, 10%);\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        .layout-element-selected {\r\n            @selected-highlight: #648721;\r\n            background-color: fade(@selected-highlight, 8%);\r\n        }\r\n    }\r\n\r\n    .ui-sortable-placeholder {\r\n        display: none;\r\n    }\r\n\r\n    .layout-element-droptarget {\r\n        @droptarget-highlight: #648721;\r\n        box-shadow: inset 0 0 12px 6px fade(@droptarget-highlight, 50%);\r\n\r\n        .ui-sortable-placeholder {\r\n            display: block; // To reveal.\r\n            visibility: visible !important;\r\n            min-height: @element-min-height - 2px;\r\n            border: 2px dashed @droptarget-highlight !important;\r\n            background-color: fade(@droptarget-highlight, 16%);\r\n        }\r\n    }\r\n\r\n    // A CSS fix for media item elements.\r\n    .media-thumbnail {\r\n        img {\r\n            max-width:100%;\r\n            max-height: 100%;\r\n        }\r\n    }\r\n}\r\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    .layout-container {\r\n\r\n        > .layout-element-wrapper {\r\n\r\n            > .layout-container-children-placeholder {\r\n                display: none;\r\n                flex-direction: column;\r\n                margin: @container-padding - 1px;\r\n                min-height: @element-min-height;\r\n                border: 1px dashed fade(@gray-text, 40%);\r\n                border-radius: 4px;\r\n                padding: @container-padding;\r\n                justify-content: center;\r\n                font-size: @font-size - 1;\r\n                font-style: italic;\r\n                opacity: 0.6;\r\n                text-align: center;\r\n            }\r\n\r\n            > .layout-children {\r\n                padding: @container-padding;\r\n\r\n                // All adjacent non-container children need some space between...\r\n                > .layout-element:not(.layout-container) + .layout-element:not(.layout-container) {\r\n                    margin-top: @content-spacing;\r\n                }\r\n\r\n                // ... except when jQuery UI sortable helper is the first element (because that one is absolutely positioned and \"floating\").\r\n                > .ui-sortable-helper:first-child + .layout-element:not(.layout-container) {\r\n                    margin-top: 0;\r\n                }\r\n            }\r\n\r\n            &.layout-container-empty {\r\n                > .layout-container-children-placeholder {\r\n                    display: flex; // To reveal.\r\n                }\r\n\r\n                > .layout-children {\r\n                    position: absolute;\r\n                    top: 0;\r\n                    right: 0;\r\n                    bottom: 0;\r\n                    left: 0;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    &:not(.layout-editor-dragging) {\r\n        .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children {\r\n            > .layout-element:not(.layout-element-active) {\r\n                border: 1px dashed fade(@gray-text, 60%);\r\n\r\n                > .layout-element-wrapper {\r\n                    margin: -1px;\r\n                }\r\n            }\r\n\r\n            > .layout-container + .layout-container:not(.layout-element-active) {\r\n                border-top: 0;\r\n\r\n                > .layout-element-wrapper {\r\n                    margin-top: 0;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    .layout-canvas {\r\n        #dummy { // Only added because WE doesn't compile if there are no rules.\r\n            display: none;\r\n        }\r\n    }\r\n}\r\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    .layout-row {\r\n        &.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children {\r\n            > .layout-element:not(.layout-element-active) {\r\n                border-top: 1px dashed fade(@gray-text, 60%) !important;\r\n                > .layout-element-wrapper {\r\n                    margin-top: -1px !important;\r\n                }\r\n            }\r\n\r\n            > .layout-element + .layout-element:not(.layout-element-active) {\r\n                border-left: 0 !important;\r\n                > .layout-element-wrapper {\r\n                    margin-left: 0 !important;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    .layout-column {\r\n        > .layout-element-wrapper {\r\n            > .layout-column-resize-bar {\r\n                display: none;\r\n                position: absolute;\r\n                z-index: 30;\r\n                top: 0;\r\n                width: 16px;\r\n                height: 100%;\r\n                cursor: col-resize;\r\n            }\r\n\r\n            > .layout-column-resize-bar-left {\r\n                left: -6px;\r\n            }\r\n\r\n            > .layout-column-resize-bar-right {\r\n                right: -6px;\r\n            }\r\n        }\r\n\r\n        &.layout-element-focused > .layout-element-wrapper > .layout-column-resize-bar {\r\n            display: block;\r\n        }\r\n    }\r\n}\r\n","@import \"Variables.less\";\r\n@import \"Reset.less\";\r\n\r\n.layout-editor {\r\n    .layout-content, .layout-html {\r\n        min-height: 1em;\r\n\r\n        > .layout-element-wrapper {\r\n            .layout-content-markup {\r\n\r\n                padding: 2px;\r\n                overflow-x: hidden;\r\n                line-height: normal;\r\n\r\n                // Reset to HTML5 W3C standard default styling within content.\r\n                .reset();\r\n\r\n                > *:first-child {\r\n                    margin-top: 0 !important; // Important because site.css of the admin theme styles heading margins with a very high specificity.\r\n                }\r\n\r\n                > *:last-child {\r\n                    margin-bottom: 0 !important;\r\n                }\r\n            }\r\n        }\r\n\r\n        &.layout-content-image, &.layout-content-vector-image {\r\n            > .layout-element-wrapper > .layout-content-markup > img {\r\n                display: block;\r\n                width: 100%;\r\n                max-width: 100%;\r\n                height: auto;\r\n            }\r\n        }\r\n    }\r\n\r\n    .img-responsive, .img-responsive img {\r\n        display: block;\r\n        width: 100%;\r\n        max-width: 100%;\r\n        height: auto;\r\n    }\r\n}\r\n","﻿.reset() {\r\n\r\n    * {\r\n        margin: 0;\r\n        padding: 0;\r\n        box-sizing: content-box;\r\n    }\r\n\r\n    address, blockquote, center, div, figure, figcaption, footer, form,\r\n    header, hr, legend, listing, p, plaintext, pre, xmp {\r\n        display: block;\r\n    }\r\n\r\n    blockquote, figure, listing, p, plaintext, pre, xmp {\r\n        margin-top: 1em;\r\n        margin-bottom: 1em;\r\n    }\r\n\r\n    blockquote, figure {\r\n        margin-left: 40px;\r\n        margin-right: 40px;\r\n    }\r\n\r\n    address {\r\n        font-style: italic;\r\n    }\r\n\r\n    listing, plaintext, pre, xmp {\r\n        font-family: monospace;\r\n        white-space: pre;\r\n    }\r\n\r\n    cite, dfn, em, i, var {\r\n        font-style: italic;\r\n    }\r\n\r\n    b, strong {\r\n        font-weight: bolder;\r\n    }\r\n\r\n    code, kbd, samp, tt {\r\n        font-family: monospace;\r\n    }\r\n\r\n    big {\r\n        font-size: larger;\r\n    }\r\n\r\n    small {\r\n        font-size: smaller;\r\n    }\r\n\r\n    sub {\r\n        vertical-align: sub;\r\n    }\r\n\r\n    sup {\r\n        vertical-align: super;\r\n    }\r\n\r\n    sub, sup {\r\n        line-height: normal;\r\n        font-size: smaller;\r\n    }\r\n\r\n\r\n    ruby {\r\n        display: ruby;\r\n    }\r\n\r\n    rb {\r\n        display: ruby-base;\r\n        white-space: nowrap;\r\n    }\r\n\r\n    rt {\r\n        display: ruby-text;\r\n        white-space: nowrap;\r\n        font-size: 50%;\r\n        font-variant-east-asian: ruby;\r\n        text-emphasis: none;\r\n    }\r\n\r\n    rbc {\r\n        display: ruby-base-container;\r\n    }\r\n\r\n    rtc {\r\n        display: ruby-text-container;\r\n    }\r\n\r\n    ruby, rb, rt, rbc, rtc {\r\n        unicode-bidi: isolate;\r\n    }\r\n\r\n\r\n    :link {\r\n        color: #0000EE;\r\n    }\r\n\r\n    :visited {\r\n        color: #551A8B;\r\n    }\r\n\r\n    :link, :visited {\r\n        text-decoration: underline;\r\n    }\r\n\r\n    a:link[rel~=help], a:visited[rel~=help],\r\n    area:link[rel~=help], area:visited[rel~=help] {\r\n        cursor: help;\r\n    }\r\n\r\n    :focus {\r\n        outline: auto;\r\n    }\r\n\r\n    mark {\r\n        background: yellow;\r\n        color: black;\r\n    }\r\n    /* this color is just a suggestion and can be changed based on implementation feedback */\r\n    abbr[title], acronym[title] {\r\n        text-decoration: dotted underline;\r\n    }\r\n\r\n    ins, u {\r\n        text-decoration: underline;\r\n    }\r\n\r\n    del, s, strike {\r\n        text-decoration: line-through;\r\n    }\r\n\r\n    blink {\r\n        text-decoration: blink;\r\n    }\r\n\r\n    q::before {\r\n        content: open-quote;\r\n    }\r\n\r\n    q::after {\r\n        content: close-quote;\r\n    }\r\n\r\n    br {\r\n        content: '\\A';\r\n        white-space: pre;\r\n    }\r\n    /* this also has bidi implications */\r\n    nobr {\r\n        white-space: nowrap;\r\n    }\r\n\r\n    wbr {\r\n        content: '\\200B';\r\n    }\r\n    /* this also has bidi implications */\r\n    nobr wbr {\r\n        white-space: normal;\r\n    }\r\n\r\n    article, aside, h1, h2, h3, h4, h5, h6, hgroup, nav, section {\r\n        display: block;\r\n    }\r\n\r\n    h1 {\r\n        margin-top: 0.67em;\r\n        margin-bottom: 0.67em;\r\n        font-size: 2.00em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h2 {\r\n        margin-top: 0.83em;\r\n        margin-bottom: 0.83em;\r\n        font-size: 1.50em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h3 {\r\n        margin-top: 1.00em;\r\n        margin-bottom: 1.00em;\r\n        font-size: 1.17em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h4 {\r\n        margin-top: 1.33em;\r\n        margin-bottom: 1.33em;\r\n        font-size: 1.00em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h5 {\r\n        margin-top: 1.67em;\r\n        margin-bottom: 1.67em;\r\n        font-size: 0.83em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h6 {\r\n        margin-top: 2.33em;\r\n        margin-bottom: 2.33em;\r\n        font-size: 0.67em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    dir, dd, dl, dt, ol, ul {\r\n        display: block;\r\n    }\r\n\r\n    li {\r\n        display: list-item;\r\n    }\r\n\r\n    dir, dl, ol, ul {\r\n        margin-top: 1em;\r\n        margin-bottom: 1em;\r\n    }\r\n\r\n        dir dir, dir dl, dir ol, dir ul,\r\n        dl dir, dl dl, dl ol, dl ul,\r\n        ol dir, ol dl, ol ol, ol ul,\r\n        ul dir, ul dl, ul ol, ul ul {\r\n            margin-top: 0;\r\n            margin-bottom: 0;\r\n        }\r\n\r\n    dd {\r\n        margin-left: 40px;\r\n    }\r\n    /* LTR-specific: use 'margin-right' for rtl elements */\r\n    dir, ol, ul {\r\n        padding-left: 40px;\r\n    }\r\n    /* LTR-specific: use 'padding-right' for rtl elements */\r\n    ol {\r\n        list-style-type: decimal;\r\n    }\r\n\r\n    dir, ul {\r\n        list-style-type: disc;\r\n    }\r\n\r\n        dir dir, dir ul,\r\n        ol dir, ol ul,\r\n        ul dir, ul ul {\r\n            list-style-type: circle;\r\n        }\r\n\r\n            dir dir dir, dir dir ul,\r\n            dir ol dir, dir ol ul,\r\n            dir ul dir, dir ul ul,\r\n            ol dir dir, ol dir ul,\r\n            ol ol dir, ol ol ul,\r\n            ol ul dir, ol ul ul,\r\n            ul dir dir, ul dir ul,\r\n            ul ol dir, ul ol ul,\r\n            ul ul dir, ul ul ul {\r\n                list-style-type: square;\r\n            }\r\n\r\n    table {\r\n        display: table;\r\n    }\r\n\r\n    caption {\r\n        display: table-caption;\r\n    }\r\n\r\n    colgroup, colgroup[hidden] {\r\n        display: table-column-group;\r\n    }\r\n\r\n    col, col[hidden] {\r\n        display: table-column;\r\n    }\r\n\r\n    thead, thead[hidden] {\r\n        display: table-header-group;\r\n    }\r\n\r\n    tbody, tbody[hidden] {\r\n        display: table-row-group;\r\n    }\r\n\r\n    tfoot, tfoot[hidden] {\r\n        display: table-footer-group;\r\n    }\r\n\r\n    tr, tr[hidden] {\r\n        display: table-row;\r\n    }\r\n\r\n    td, th, td[hidden], th[hidden] {\r\n        display: table-cell;\r\n    }\r\n\r\n        colgroup[hidden], col[hidden], thead[hidden], tbody[hidden],\r\n        tfoot[hidden], tr[hidden], td[hidden], th[hidden] {\r\n            visibility: collapse;\r\n        }\r\n\r\n    table {\r\n        box-sizing: border-box;\r\n        border-spacing: 2px;\r\n        border-collapse: separate;\r\n        text-indent: initial;\r\n    }\r\n\r\n    td, th {\r\n        padding: 1px;\r\n    }\r\n\r\n    th {\r\n        font-weight: bold;\r\n    }\r\n\r\n    thead, tbody, tfoot, table > tr {\r\n        vertical-align: middle;\r\n    }\r\n\r\n    tr, td, th {\r\n        vertical-align: inherit;\r\n    }\r\n\r\n    table, td, th {\r\n        border-color: gray;\r\n    }\r\n\r\n    thead, tbody, tfoot, tr {\r\n        border-color: inherit;\r\n    }\r\n    /*table[rules=none i], table[rules=groups i], table[rules=rows i],\r\ntable[rules=cols i], table[rules=all i], table[frame=void i],\r\ntable[frame=above i], table[frame=below i], table[frame=hsides i],\r\ntable[frame=lhs i], table[frame=rhs i], table[frame=vsides i],\r\ntable[frame=box i], table[frame=border i],\r\ntable[rules=none i] > tr > td, table[rules=none i] > tr > th,\r\ntable[rules=groups i] > tr > td, table[rules=groups i] > tr > th,\r\ntable[rules=rows i] > tr > td, table[rules=rows i] > tr > th,\r\ntable[rules=cols i] > tr > td, table[rules=cols i] > tr > th,\r\ntable[rules=all i] > tr > td, table[rules=all i] > tr > th,\r\ntable[rules=none i] > thead > tr > td, table[rules=none i] > thead > tr > th,\r\ntable[rules=groups i] > thead > tr > td, table[rules=groups i] > thead > tr > th,\r\ntable[rules=rows i] > thead > tr > td, table[rules=rows i] > thead > tr > th,\r\ntable[rules=cols i] > thead > tr > td, table[rules=cols i] > thead > tr > th,\r\ntable[rules=all i] > thead > tr > td, table[rules=all i] > thead > tr > th,\r\ntable[rules=none i] > tbody > tr > td, table[rules=none i] > tbody > tr > th,\r\ntable[rules=groups i] > tbody > tr > td, table[rules=groups i] > tbody > tr > th,\r\ntable[rules=rows i] > tbody > tr > td, table[rules=rows i] > tbody > tr > th,\r\ntable[rules=cols i] > tbody > tr > td, table[rules=cols i] > tbody > tr > th,\r\ntable[rules=all i] > tbody > tr > td, table[rules=all i] > tbody > tr > th,\r\ntable[rules=none i] > tfoot > tr > td, table[rules=none i] > tfoot > tr > th,\r\ntable[rules=groups i] > tfoot > tr > td, table[rules=groups i] > tfoot > tr > th,\r\ntable[rules=rows i] > tfoot > tr > td, table[rules=rows i] > tfoot > tr > th,\r\ntable[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th,\r\ntable[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th {\r\n    border-color: black;\r\n}*/\r\n    input, select, option, optgroup, button, textarea, keygen {\r\n        text-indent: initial;\r\n    }\r\n\r\n    textarea {\r\n        white-space: pre-wrap;\r\n    }\r\n\r\n    input[type=\"radio\"], input[type=\"checkbox\"], input[type=\"reset\"], input[type=\"button\"],\r\n    input[type=\"submit\"], select, button {\r\n        box-sizing: border-box;\r\n    }\r\n\r\n    input[type=\"button\"], button {\r\n        padding: 0.3em 0.5em;\r\n    }\r\n\r\n    hr {\r\n        color: gray;\r\n        border-style: inset;\r\n        border-width: 1px;\r\n        margin: 0.5em auto;\r\n    }\r\n\r\n    fieldset {\r\n        margin-left: 2px;\r\n        margin-right: 2px;\r\n        border: groove 2px ThreeDFace;\r\n        padding: 0.35em 0.625em 0.75em;\r\n    }\r\n\r\n    legend {\r\n        padding-left: 2px;\r\n        padding-right: 2px;\r\n    }\r\n}\r\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    > .layout-toolbox-wrapper {\r\n        position: relative;\r\n        margin-left: @container-padding;\r\n        width: 220px;\r\n        flex-shrink: 0;\r\n\r\n        > .layout-toolbox {\r\n            border: 1px solid @gray-border;\r\n            width: 220px;\r\n            min-height: 400px;\r\n            padding: @container-padding / 2;\r\n            background-color: @gray-bg;\r\n\r\n            &.sticky-top {\r\n                position: fixed;\r\n                top: 0;\r\n                max-height: 100%;\r\n                overflow-y: auto;\r\n            }\r\n\r\n            &.sticky-bottom {\r\n                position: absolute;\r\n                bottom: 0;\r\n            }\r\n\r\n            .layout-toolbox-group {\r\n                margin-top: @container-padding;\r\n\r\n                .layout-toolbox-group-heading {\r\n                    display: block;\r\n                    margin-bottom: @container-padding / 3;\r\n                    text-decoration: none;\r\n                \r\n                    &:before {\r\n                        display: inline-block;\r\n                        width: 10px;\r\n                        margin-right: @container-padding / 3;\r\n                        font: normal normal normal 14px/1 FontAwesome;\r\n                        text-align: center;\r\n                        content: \"\\f0d7\";\r\n                    }\r\n                }\r\n            \r\n                &.collapsed {\r\n                    .layout-toolbox-group-heading:before {\r\n                        content: \"\\f0da\";\r\n                    }\r\n\r\n                    .layout-toolbox-items {\r\n                        display: none;\r\n                    }\r\n                }\r\n\r\n                .layout-toolbox-section + .layout-toolbox-section {\r\n                    margin-top: @container-padding / 3;\r\n                }\r\n\r\n                .layout-toolbox-item {\r\n                    border: 1px solid @gray-border;\r\n                    background-color: #fff;\r\n                    padding: (@container-padding - 3) @container-padding;\r\n                    cursor: default;\r\n\r\n                    i {\r\n                        display: inline-block;\r\n                        width: 16px;\r\n                        font: normal normal normal 14px/1 FontAwesome;\r\n                    }\r\n\r\n                    + .layout-toolbox-item {\r\n                        margin-top: @container-padding / 3;\r\n                    }\r\n                }\r\n\r\n                + .layout-toolbox-group {\r\n                    margin-top: @container-padding / 2;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    .layout-popup {\r\n        display: none; // Shown only in active or focused states.\r\n        position: absolute;\r\n        margin: 0;\r\n        -moz-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\r\n        -webkit-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\r\n        box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\r\n        border: 1px solid @gray-border;\r\n        padding: 2px 0;\r\n        background-color: #f7f7f7;\r\n        list-style: none;\r\n        z-index: 20;\r\n        color: @gray-text;\r\n        text-align: left;\r\n        cursor: default;\r\n        white-space: nowrap;\r\n        line-height: normal;\r\n\r\n        .layout-popup-flex {\r\n            display: flex;\r\n            padding: 2px 5px;\r\n\r\n            .layout-popup-column + .layout-popup-column {\r\n                margin-left: 4px;\r\n                border-left: 1px solid fade(gray, 15%);\r\n                padding-left: 4px;\r\n            }\r\n        }\r\n\r\n        .layout-popup-item {\r\n            padding: 4px 6px;\r\n        }\r\n\r\n        .layout-popup-label {\r\n            font-size: 0.9em;\r\n            font-weight: bold;\r\n            color: @gray-text;\r\n        }\r\n\r\n        .layout-popup-action:hover {\r\n            background-color: @gray-bg;\r\n            cursor: pointer;\r\n        }\r\n\r\n        .layout-popup-input {\r\n            > label {\r\n                display: block;\r\n                font-size: 0.9em;\r\n            }\r\n        }\r\n    }\r\n}\r\n"],"sourceRoot":"/source/"} */ \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.min.css b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.min.css index 0d88e7535..0b0301724 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.min.css +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.min.css @@ -1 +1 @@ -.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup cite,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dfn,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup em,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup i,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup var,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup cite,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dfn,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup em,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup i,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup var{font-style:italic}.layout-editor{display:-webkit-flex;display:-ms-flexbox;display:flex;margin-top:1em;font-size:14px;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.layout-editor>.layout-canvas-wrapper{-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;background-color:#f3f4f5;border:1px solid #e4e5e6}.layout-editor>.layout-canvas-wrapper>.layout-toolbar-container{display:none;margin:12px 12px 0;min-height:71px}.layout-editor>.layout-canvas-wrapper>.layout-toolbar-container>.mce-panel{width:100%!important}.layout-editor .layout-element{position:relative;margin-top:0;margin-right:0;margin-bottom:0;padding:0}.layout-editor .layout-element:not(.layout-column){margin-left:0}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel{display:none;position:absolute;margin:0;z-index:20;height:25px;padding:0 6px;list-style:none;white-space:nowrap;line-height:25px;vertical-align:middle}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-item{display:inline-block;height:25px;padding:1px 6px 0}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-label{font-size:13px}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-action{display:none;width:28px;cursor:pointer;text-align:center}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel-main{top:-27px;left:-2px}.layout-editor li.layout-element{list-style:none}.layout-editor:not(.layout-editor-dragging) .layout-element-active,.layout-editor:not(.layout-editor-dragging) .layout-element-focused{border-width:2px;border-style:solid}.layout-editor:not(.layout-editor-dragging) .layout-element-active>.layout-element-wrapper,.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper{margin:-2px}.layout-editor:not(.layout-editor-dragging) .layout-element-active{border-color:rgba(104,104,104,.1)}.layout-editor:not(.layout-editor-dragging) .layout-element-active>.layout-element-wrapper>.layout-panel-main{display:block;z-index:30;background-color:rgba(104,104,104,.1)}.layout-editor:not(.layout-editor-dragging) .layout-element-focused{border-color:#648721}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel{display:block;background-color:#648721;color:#fefefe}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action{display:inline-block}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action:hover{background-color:#82b02b}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.disabled{cursor:default;color:rgba(254,254,254,.4)}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.disabled:hover{background-color:#648721}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.active{color:#deff42;background-color:#739b26}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.active:hover{background-color:#82b02b}.layout-editor:not(.layout-editor-dragging) .layout-element-selected{background-color:rgba(100,135,33,.08)}.layout-editor .ui-sortable-placeholder{display:none}.layout-editor .layout-element-droptarget{box-shadow:inset 0 0 12px 6px rgba(100,135,33,.5)}.layout-editor .layout-element-droptarget .ui-sortable-placeholder{display:block;visibility:visible!important;min-height:78px;border:2px dashed #648721!important;background-color:rgba(100,135,33,.16)}.layout-editor .media-thumbnail img{max-width:100%;max-height:100%}.layout-editor .layout-container>.layout-element-wrapper>.layout-container-children-placeholder{display:none;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;margin:11px;min-height:80px;border:1px dashed rgba(124,124,124,.4);border-radius:4px;padding:12px;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;font-size:13px;font-style:italic;opacity:.6;text-align:center}.layout-editor .layout-container>.layout-element-wrapper>.layout-children{padding:12px}.layout-editor .layout-container>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-container)+.layout-element:not(.layout-container){margin-top:12px}.layout-editor .layout-container>.layout-element-wrapper>.layout-children>.ui-sortable-helper:first-child+.layout-element:not(.layout-container){margin-top:0}.layout-editor .layout-container>.layout-element-wrapper.layout-container-empty>.layout-container-children-placeholder{display:-webkit-flex;display:-ms-flexbox;display:flex}.layout-editor .layout-container>.layout-element-wrapper.layout-container-empty>.layout-children{position:absolute;top:0;right:0;bottom:0;left:0}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active){border:1px dashed rgba(124,124,124,.6)}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin:-1px}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-container+.layout-container:not(.layout-element-active){border-top:0}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-container+.layout-container:not(.layout-element-active)>.layout-element-wrapper{margin-top:0}.layout-editor .layout-canvas #dummy{display:none}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active){border-top:1px dashed rgba(124,124,124,.6)!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin-top:-1px!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element+.layout-element:not(.layout-element-active){border-left:0!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element+.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin-left:0!important}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar{display:none;position:absolute;z-index:30;top:0;width:16px;height:100%;cursor:col-resize}.layout-editor .layout-column.layout-element-focused>.layout-element-wrapper>.layout-column-resize-bar,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup center,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup div,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figcaption,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup footer,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup form,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup header,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup center,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup div,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figcaption,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup footer,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup form,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup header,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{display:block}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar-left{left:-6px}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar-right{right:-6px}.layout-editor .layout-content,.layout-editor .layout-html{min-height:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup{padding:2px;overflow-x:hidden;line-height:normal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup *,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup *{margin:0;padding:0;box-sizing:content-box}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{margin-top:1em;margin-bottom:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure{margin-left:40px;margin-right:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{font-family:monospace;white-space:pre}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup b,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup strong,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup b,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup strong{font-weight:bolder}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup code,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup kbd,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup samp,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup code,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup kbd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup samp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tt{font-family:monospace}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup big,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup big{font-size:larger}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup small,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup small{font-size:smaller}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sub{vertical-align:sub}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sup{vertical-align:super}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sup{line-height:normal;font-size:smaller}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ruby,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ruby{display:ruby}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rb{display:ruby-base;white-space:nowrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rt{display:ruby-text;white-space:nowrap;font-size:50%;font-variant-east-asian:ruby;-webkit-text-emphasis:none;text-emphasis:none}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rbc{display:ruby-base-container}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rtc{display:ruby-text-container}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup article,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup aside,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dt,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nav,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup section,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup article,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup aside,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nav,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup section,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{display:block}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ruby,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ruby{unicode-bidi:isolate}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :link{color:#00E}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :visited,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :visited{color:#551A8B}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :visited,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :visited{text-decoration:underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup a:link[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup a:visited[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup area:link[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup area:visited[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup a:link[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup a:visited[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup area:link[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup area:visited[rel~=help]{cursor:help}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :focus,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :focus{outline:auto}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup mark,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup mark{background:#ff0;color:#000}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup abbr[title],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup acronym[title],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup abbr[title],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup acronym[title]{text-decoration:dotted underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ins,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup u,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ins,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup u{text-decoration:underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup del,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup s,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup strike,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup del,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup s,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup strike{text-decoration:line-through}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blink,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blink{text-decoration:blink}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup q::before,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup q::before{content:open-quote}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup q::after,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup q::after{content:close-quote}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup br,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup br{content:'\A';white-space:pre}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nobr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nobr{white-space:nowrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup wbr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup wbr{content:'\200B'}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nobr wbr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nobr wbr{white-space:normal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h1{margin-top:.67em;margin-bottom:.67em;font-size:2em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h2{margin-top:.83em;margin-bottom:.83em;font-size:1.5em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h3{margin-top:1em;margin-bottom:1em;font-size:1.17em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h4{margin-top:1.33em;margin-bottom:1.33em;font-size:1em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h5{margin-top:1.67em;margin-bottom:1.67em;font-size:.83em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h6{margin-top:2.33em;margin-bottom:2.33em;font-size:.67em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup li,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup li{display:list-item}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{margin-top:1em;margin-bottom:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul{margin-top:0;margin-bottom:0}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dd{margin-left:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{padding-left:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol{list-style-type:decimal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{list-style-type:disc}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul{list-style-type:circle}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul ul{list-style-type:square}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table{display:table;box-sizing:border-box;border-spacing:2px;border-collapse:separate;text-indent:initial}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup caption,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup caption{display:table-caption}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup[hidden]{display:table-column-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col[hidden]{display:table-column}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead[hidden]{display:table-header-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody[hidden]{display:table-row-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot[hidden]{display:table-footer-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr[hidden]{display:table-row}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th[hidden]{display:table-cell}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr[hidden]{visibility:collapse}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{padding:1px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table>tr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table>tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead{vertical-align:middle}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr{vertical-align:inherit}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{border-color:gray}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr{border-color:inherit}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup keygen,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup optgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup option,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup textarea,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup keygen,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup optgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup option,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup textarea{text-indent:initial}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup textarea,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup textarea{white-space:pre-wrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=radio],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=checkbox],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=reset],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=submit],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=radio],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=checkbox],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=reset],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=submit],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup select{box-sizing:border-box}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=button]{padding:.3em .5em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hr{color:gray;border-style:inset;border-width:1px;margin:.5em auto}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup fieldset,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup fieldset{margin-left:2px;margin-right:2px;border:2px groove ThreeDFace;padding:.35em .625em .75em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup legend{padding-left:2px;padding-right:2px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>:first-child,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup>:first-child{margin-top:0!important}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>:last-child,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup>:last-child{margin-bottom:0!important}.layout-editor .img-responsive,.layout-editor .img-responsive img,.layout-editor .layout-content.layout-content-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-content.layout-content-vector-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-html.layout-content-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-html.layout-content-vector-image>.layout-element-wrapper>.layout-content-markup>img{display:block;width:100%;max-width:100%;height:auto}.layout-editor>.layout-toolbox-wrapper{position:relative;margin-left:12px;width:220px;-webkit-flex-shrink:0;-ms-flex-negative:0;flex-shrink:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox{border:1px solid #e4e5e6;width:220px;min-height:400px;padding:6px;background-color:#f3f4f5}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox.sticky-top{position:fixed;top:0;max-height:100%;overflow-y:auto}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox.sticky-bottom{position:absolute;bottom:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group{margin-top:12px}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item+.layout-toolbox-item,.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-section+.layout-toolbox-section{margin-top:4px}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading{display:block;margin-bottom:4px;text-decoration:none}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading:before{display:inline-block;width:10px;margin-right:4px;font:normal normal normal 14px/1 FontAwesome;text-align:center;content:"\f0d7"}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-group-heading:before{content:"\f0da"}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-items{display:none}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item{border:1px solid #e4e5e6;background-color:#fff;padding:9px 12px;cursor:default}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item i{display:inline-block;width:16px;font:normal normal normal 14px/1 FontAwesome}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group+.layout-toolbox-group{margin-top:6px}.layout-editor .layout-popup{display:none;position:absolute;margin:0;box-shadow:3px 3px 11px 0 rgba(50,50,50,.5);border:1px solid #e4e5e6;padding:2px 0;background-color:#f7f7f7;list-style:none;z-index:20;color:#7c7c7c;text-align:left;cursor:default;white-space:nowrap;line-height:normal}.layout-editor .layout-popup .layout-popup-flex{display:-webkit-flex;display:-ms-flexbox;display:flex;padding:2px 5px}.layout-editor .layout-popup .layout-popup-flex .layout-popup-column+.layout-popup-column{margin-left:4px;border-left:1px solid rgba(128,128,128,.15);padding-left:4px}.layout-editor .layout-popup .layout-popup-item{padding:4px 6px}.layout-editor .layout-popup .layout-popup-label{font-size:.9em;font-weight:700;color:#7c7c7c}.layout-editor .layout-popup .layout-popup-action:hover{background-color:#f3f4f5;cursor:pointer}.layout-editor .layout-popup .layout-popup-input>label{display:block;font-size:.9em} \ No newline at end of file +.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup cite,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dfn,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup em,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup i,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup var,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup cite,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dfn,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup em,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup i,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup var{font-style:italic}.layout-editor{display:-webkit-flex;display:-ms-flexbox;display:flex;margin-top:1em;font-size:14px;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.layout-editor>.layout-canvas-wrapper{-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;background-color:#f3f4f5;border:1px solid #e4e5e6}.layout-editor>.layout-canvas-wrapper>.layout-toolbar-container{display:none;margin:12px 12px 0;min-height:71px}.layout-editor>.layout-canvas-wrapper>.layout-toolbar-container>.mce-panel{width:100%!important}.layout-editor .layout-snippet{background:#e8e8e8}.layout-editor .layout-element{position:relative;margin-top:0;margin-right:0;margin-bottom:0;padding:0}.layout-editor .layout-element:not(.layout-column){margin-left:0}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel{display:none;position:absolute;margin:0;z-index:20;height:25px;padding:0 6px;list-style:none;white-space:nowrap;line-height:25px;vertical-align:middle}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-item{display:inline-block;height:25px;padding:1px 6px 0}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-label{font-size:13px}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-action{display:none;width:28px;cursor:pointer;text-align:center}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel-main{top:-27px;left:-2px}.layout-editor li.layout-element{list-style:none}.layout-editor:not(.layout-editor-dragging) .layout-element-active,.layout-editor:not(.layout-editor-dragging) .layout-element-focused{border-width:2px;border-style:solid}.layout-editor:not(.layout-editor-dragging) .layout-element-active>.layout-element-wrapper,.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper{margin:-2px}.layout-editor:not(.layout-editor-dragging) .layout-element-active{border-color:rgba(104,104,104,.1)}.layout-editor:not(.layout-editor-dragging) .layout-element-active>.layout-element-wrapper>.layout-panel-main{display:block;z-index:30;background-color:rgba(104,104,104,.1)}.layout-editor:not(.layout-editor-dragging) .layout-element-focused{border-color:#648721}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel{display:block;background-color:#648721;color:#fefefe}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action{display:inline-block}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action:hover{background-color:#82b02b}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.disabled{cursor:default;color:rgba(254,254,254,.4)}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.disabled:hover{background-color:#648721}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.active{color:#deff42;background-color:#739b26}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.active:hover{background-color:#82b02b}.layout-editor:not(.layout-editor-dragging) .layout-element-selected{background-color:rgba(100,135,33,.08)}.layout-editor .ui-sortable-placeholder{display:none}.layout-editor .layout-element-droptarget{box-shadow:inset 0 0 12px 6px rgba(100,135,33,.5)}.layout-editor .layout-element-droptarget .ui-sortable-placeholder{display:block;visibility:visible!important;min-height:78px;border:2px dashed #648721!important;background-color:rgba(100,135,33,.16)}.layout-editor .media-thumbnail img{max-width:100%;max-height:100%}.layout-editor .layout-container>.layout-element-wrapper>.layout-container-children-placeholder{display:none;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;margin:11px;min-height:80px;border:1px dashed rgba(124,124,124,.4);border-radius:4px;padding:12px;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;font-size:13px;font-style:italic;opacity:.6;text-align:center}.layout-editor .layout-container>.layout-element-wrapper>.layout-children{padding:12px}.layout-editor .layout-container>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-container)+.layout-element:not(.layout-container){margin-top:12px}.layout-editor .layout-container>.layout-element-wrapper>.layout-children>.ui-sortable-helper:first-child+.layout-element:not(.layout-container){margin-top:0}.layout-editor .layout-container>.layout-element-wrapper.layout-container-empty>.layout-container-children-placeholder{display:-webkit-flex;display:-ms-flexbox;display:flex}.layout-editor .layout-container>.layout-element-wrapper.layout-container-empty>.layout-children{position:absolute;top:0;right:0;bottom:0;left:0}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active){border:1px dashed rgba(124,124,124,.6)}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin:-1px}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-container+.layout-container:not(.layout-element-active){border-top:0}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-container+.layout-container:not(.layout-element-active)>.layout-element-wrapper{margin-top:0}.layout-editor .layout-canvas #dummy{display:none}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active){border-top:1px dashed rgba(124,124,124,.6)!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin-top:-1px!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element+.layout-element:not(.layout-element-active){border-left:0!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element+.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin-left:0!important}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar{display:none;position:absolute;z-index:30;top:0;width:16px;height:100%;cursor:col-resize}.layout-editor .layout-column.layout-element-focused>.layout-element-wrapper>.layout-column-resize-bar,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup center,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup div,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figcaption,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup footer,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup form,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup header,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup center,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup div,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figcaption,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup footer,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup form,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup header,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{display:block}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar-left{left:-6px}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar-right{right:-6px}.layout-editor .layout-content,.layout-editor .layout-html{min-height:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup{padding:2px;overflow-x:hidden;line-height:normal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup *,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup *{margin:0;padding:0;box-sizing:content-box}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{margin-top:1em;margin-bottom:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure{margin-left:40px;margin-right:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{font-family:monospace;white-space:pre}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup b,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup strong,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup b,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup strong{font-weight:bolder}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup code,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup kbd,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup samp,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup code,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup kbd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup samp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tt{font-family:monospace}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup big,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup big{font-size:larger}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup small,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup small{font-size:smaller}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sub{vertical-align:sub}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sup{vertical-align:super}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sup{line-height:normal;font-size:smaller}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ruby,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ruby{display:ruby}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rb{display:ruby-base;white-space:nowrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rt{display:ruby-text;white-space:nowrap;font-size:50%;font-variant-east-asian:ruby;-webkit-text-emphasis:none;text-emphasis:none}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rbc{display:ruby-base-container}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rtc{display:ruby-text-container}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup article,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup aside,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dt,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nav,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup section,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup article,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup aside,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nav,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup section,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{display:block}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ruby,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ruby{unicode-bidi:isolate}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :link{color:#00E}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :visited,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :visited{color:#551A8B}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :visited,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :visited{text-decoration:underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup a:link[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup a:visited[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup area:link[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup area:visited[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup a:link[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup a:visited[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup area:link[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup area:visited[rel~=help]{cursor:help}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :focus,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :focus{outline:auto}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup mark,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup mark{background:#ff0;color:#000}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup abbr[title],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup acronym[title],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup abbr[title],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup acronym[title]{text-decoration:dotted underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ins,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup u,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ins,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup u{text-decoration:underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup del,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup s,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup strike,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup del,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup s,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup strike{text-decoration:line-through}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blink,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blink{text-decoration:blink}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup q::before,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup q::before{content:open-quote}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup q::after,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup q::after{content:close-quote}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup br,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup br{content:'\A';white-space:pre}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nobr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nobr{white-space:nowrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup wbr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup wbr{content:'\200B'}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nobr wbr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nobr wbr{white-space:normal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h1{margin-top:.67em;margin-bottom:.67em;font-size:2em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h2{margin-top:.83em;margin-bottom:.83em;font-size:1.5em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h3{margin-top:1em;margin-bottom:1em;font-size:1.17em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h4{margin-top:1.33em;margin-bottom:1.33em;font-size:1em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h5{margin-top:1.67em;margin-bottom:1.67em;font-size:.83em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h6{margin-top:2.33em;margin-bottom:2.33em;font-size:.67em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup li,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup li{display:list-item}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{margin-top:1em;margin-bottom:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul{margin-top:0;margin-bottom:0}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dd{margin-left:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{padding-left:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol{list-style-type:decimal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{list-style-type:disc}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul{list-style-type:circle}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul ul{list-style-type:square}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table{display:table;box-sizing:border-box;border-spacing:2px;border-collapse:separate;text-indent:initial}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup caption,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup caption{display:table-caption}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup[hidden]{display:table-column-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col[hidden]{display:table-column}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead[hidden]{display:table-header-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody[hidden]{display:table-row-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot[hidden]{display:table-footer-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr[hidden]{display:table-row}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th[hidden]{display:table-cell}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr[hidden]{visibility:collapse}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{padding:1px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table>tr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table>tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead{vertical-align:middle}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr{vertical-align:inherit}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{border-color:gray}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr{border-color:inherit}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup keygen,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup optgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup option,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup textarea,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup keygen,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup optgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup option,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup textarea{text-indent:initial}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup textarea,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup textarea{white-space:pre-wrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=radio],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=checkbox],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=reset],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=submit],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=radio],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=checkbox],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=reset],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=submit],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup select{box-sizing:border-box}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=button]{padding:.3em .5em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hr{color:gray;border-style:inset;border-width:1px;margin:.5em auto}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup fieldset,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup fieldset{margin-left:2px;margin-right:2px;border:2px groove ThreeDFace;padding:.35em .625em .75em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup legend{padding-left:2px;padding-right:2px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>:first-child,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup>:first-child{margin-top:0!important}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>:last-child,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup>:last-child{margin-bottom:0!important}.layout-editor .img-responsive,.layout-editor .img-responsive img,.layout-editor .layout-content.layout-content-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-content.layout-content-vector-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-html.layout-content-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-html.layout-content-vector-image>.layout-element-wrapper>.layout-content-markup>img{display:block;width:100%;max-width:100%;height:auto}.layout-editor>.layout-toolbox-wrapper{position:relative;margin-left:12px;width:220px;-webkit-flex-shrink:0;-ms-flex-negative:0;flex-shrink:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox{border:1px solid #e4e5e6;width:220px;min-height:400px;padding:6px;background-color:#f3f4f5}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox.sticky-top{position:fixed;top:0;max-height:100%;overflow-y:auto}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox.sticky-bottom{position:absolute;bottom:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group{margin-top:12px}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item+.layout-toolbox-item,.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-section+.layout-toolbox-section{margin-top:4px}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading{display:block;margin-bottom:4px;text-decoration:none}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading:before{display:inline-block;width:10px;margin-right:4px;font:normal normal normal 14px/1 FontAwesome;text-align:center;content:"\f0d7"}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-group-heading:before{content:"\f0da"}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-items{display:none}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item{border:1px solid #e4e5e6;background-color:#fff;padding:9px 12px;cursor:default}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item i{display:inline-block;width:16px;font:normal normal normal 14px/1 FontAwesome}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group+.layout-toolbox-group{margin-top:6px}.layout-editor .layout-popup{display:none;position:absolute;margin:0;box-shadow:3px 3px 11px 0 rgba(50,50,50,.5);border:1px solid #e4e5e6;padding:2px 0;background-color:#f7f7f7;list-style:none;z-index:20;color:#7c7c7c;text-align:left;cursor:default;white-space:nowrap;line-height:normal}.layout-editor .layout-popup .layout-popup-flex{display:-webkit-flex;display:-ms-flexbox;display:flex;padding:2px 5px}.layout-editor .layout-popup .layout-popup-flex .layout-popup-column+.layout-popup-column{margin-left:4px;border-left:1px solid rgba(128,128,128,.15);padding-left:4px}.layout-editor .layout-popup .layout-popup-item{padding:4px 6px}.layout-editor .layout-popup .layout-popup-label{font-size:.9em;font-weight:700;color:#7c7c7c}.layout-editor .layout-popup .layout-popup-action:hover{background-color:#f3f4f5;cursor:pointer}.layout-editor .layout-popup .layout-popup-input>label{display:block;font-size:.9em} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Editor.less b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Editor.less index 64e009ab7..e97d95bd6 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Editor.less +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Editor.less @@ -21,4 +21,8 @@ } } } + + .layout-snippet { + background: #e8e8e8; + } } diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/designer.css b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/designer.css deleted file mode 100644 index b1826fb34..000000000 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/designer.css +++ /dev/null @@ -1,321 +0,0 @@ -.zone-content { - padding: 3px; -} - -.canvas-toolbar ol li { - float: left; - margin-right: 1em; -} - -.canvas-toolbar a.icon { - color: #000; - font-size: 1.5em; - line-height: 1.5em; -} - -.layout-editor .canvas { - padding: 0; - min-height: 5em; -} - - .layout-editor .canvas .snippet { - padding: 1em; - background: #f3f4f5; - -ms-border-radius: 4px; - border-radius: 8px; - } - - .layout-editor .canvas .snippet em { - font-style: italic; - } - - .layout-editor .canvas .table { - background: none repeat scroll 0 0 #fafafa; - border: 1px solid #bdbcbc; - margin: 0 0 0.3em; - padding: 20px 0.3em 20px 0; - position: relative; - } - - .layout-editor .canvas > .table { - -ms-border-radius: 4px; - border-radius: 4px; - -webkit-box-shadow: 2px 5px 15px #525252; - -ms-box-shadow: 2px 5px 15px #525252; - box-shadow: 3px 2px 10px #e7e7e7; - } - - .layout-editor .canvas .x-root { - min-height: 100px; - position: relative; - padding: 23px 0 42px 0; - } - - .layout-editor .canvas .x-column { - background-color: #fafafa; - } - - .layout-editor .canvas .x-container.x-root > a.add { - background: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAEXSURBVDhPrdVPSwJBHMbxTVl9Ab6DpKMnX0ewVFCgd99IeBXBi7c6BB0KPIfgK5AudSi03kGHhLxZ32f/5LQ7qwPNA5/xJ86sM/tnNihJHV3cY4mPlOo7dKA+TjnDO773eMMpSlPFELbBuwygsYWMYBvgQhP5kwi2jq42OEacGhawdZQZsqi29ZFXhBWaEzTx3xwh0gG1XF+JdHX6aMRft5lCt4U84gFKC1/IfjuEmVDNCvnz4Zr8uE8t+QDeooPp6uiEmpmnn4rqXlIGY7STMo5ZKy9qbpGfusn1tpEbLXkCX4mPpSujqdr+UVxn+ITfZ9rro5dF96Ots4tLFOJ9+8ribYM1o+39Atd4xjql+grnsLwCguAHjCrBxU/oR+AAAAAASUVORK5CYII='); - width: 20px; - height: 20px; - left: 50%; - bottom: 0; - } - - .layout-editor .canvas .x-container.x-root > a.add.start { - background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAANYSURBVHhe5dvJjwxhHMbxsURsYx3hgpMZS4hIuMzBhTiIsziIhISjcLDExUXmYr1aDv4DDuKAAwcHEiEYMyTcEEYMY52E8X2ql/Ty09Xd9dbW75N80jWTeave9523ut+qfmtSV/xZgs1YgxVF8zEL06CM4zs+4xVeYhB38R65yyacwzNMRKR9nMVGZDrzcAxDsBriwgscxVxkJoswgC+wKh2HUZxCD1KLzt+T0LlrVTIJ36A6lN5LEstKPIRVqTQ8QB8SyUH8hFWRNKlO+xFbJuM8rINnyRmork4zA9dhHTCLrkF1dhK9wdyEdaAsu4HIb45Tkaf/fC3VfQrazgVYO86T02gre2DtMI92o6WshiYZ1s7yaAyr0FR0hXgf1o7y7B6auvo9AGsHnWAfGkbX6R9gFXYlLFYZV95hDsqpnTEdhq7uOjW6OXOosFkfXc/rMtPqOZfCYpVx6RO6EaRyBOxFpm40xJQFUFvrMgyrx1wLi1XGteeoiu7hWX8Yh7BYZeKwAeVTYGfx1acEbS51wLbiq08J2qyZkT4a3ha3k0jYcTQ8k4iOs1gjoB9JNT5LUZv71QFrgx/9zDp1gO7w+po+dUBvYbvtaCi1IixWmUaipFcdsLCw7WV61AGzC9tepltD6Dei3D2NOgyjJsrH5rhGQNoNSDMT6gDdL/M1Y753wFd1wMfCtpcZUQdoPU6UlC4vmxUWq0wjUTKsDtCSFl8zpA7QaixfM6iPQM0EdStcnZFEwj52ow7rZvMHwUxQd0mf6jee5TFGS//1O8VXn1LV5vWofXeNS1isMnHQF8BVeQLrD10Li1XGtUcIUvnGd7X46kPMts5E3F+MSlisMi7pBvB0BKkcAT+gJTGdHrXxV2GzPt59PW5F62mswp1gF0KjmZrXS2SUZdAM0dpRHo1gKVrKDvyFtcM8URu2o614vVBS0TlzBdaO8+Aymj7v/xevF0uXogXHl2AdKIsuItIiaSuaNepROOuAWaJzvnKG6zxboRmVdfA0qU5bkEiW4zasiqThFjR3STyaK7yBVakkvIbqkGq06vIENNuyKhkHHes4MvXNtjpCj7XG/ejsEZSXumY1uXl4OvIsqYlYj8/rmV8tzi6tTdYibT17rKGd4OPzXV3/APplq+e/m5jfAAAAAElFTkSuQmCC'); - width: 64px; - height: 64px; - left: 50%; - top: 32%; - display: block; - } - - .layout-editor .canvas .x-grid .drag-handle { - cursor: move; - left: 11px; - position: absolute; - right: 0; - top: 0; - z-index: 25; - } - - .layout-editor .canvas > .x-grid .drag-handle a { - color: #646464; - } - - .layout-editor .canvas > .x-grid .drag-handle { - -ms-border-radius: 0; - border-radius: 3px 3px 0 0; - } - - .layout-editor .canvas .x-grid .grid-toolbar { - background: none; - margin: 0; - padding: 0 0.5em 0 0; - } - - .layout-editor .canvas .x-grid .drag-handle:hover a.remove, - .layout-editor .canvas .x-grid .drag-handle:hover a.edit { - } - - .layout-editor .canvas .x-row { - position: relative; - margin: 0; - padding-left: 20px; - } - - .layout-editor .canvas .x-row .row-toolbar { - display: none; - } - - .layout-editor .canvas .x-row .row-toolbar.sortable { - cursor: move; - -ms-border-radius: 3px; - border-radius: 3px; - bottom: 6px; - left: 8px; - top: 1px; - width: 10px; - padding: 5px 4px 2px 1px; - z-index: 5; - position: absolute; - cursor: move; - background: transparent; - } - - .layout-editor .canvas .x-row .row-toolbar a { - display: block; - margin: 0; - width: 16px; - } - - .layout-editor .canvas .x-row .x-column { - padding: 0.5em; - position: relative; - } - - .layout-editor .canvas .x-row .x-column .ui-resizable-handle { - background: #e4e4e4; - height: 100%; - width: 7px; - top: 0; - -ms-border-radius: 25px; - border-radius: 25px; - -ms-opacity: 0.75; - opacity: 0.75; - } - - .layout-editor .canvas .x-row .x-column .ui-resizable-handle:hover { - -ms-opacity: 1; - opacity: 1; - } - - .layout-editor .canvas .x-row .x-column .ui-resizable-e { - right: -10px; - } - - .layout-editor .canvas .x-row .x-column .toolbar.column-toolbar { - position: absolute; - top: 1px; - right: 1px; - left: 1px; - cursor: move; - background: none; - display: none; - } - - .layout-editor .canvas .x-row .x-column.highlight { - border: 1px solid #90a664; - } - - .layout-editor .canvas .x-row .x-column .column-container { - border: 1px dashed #bdbcbc; - min-height: 5em; - padding: 2.1em 27px 24px; - } - - .layout-editor .canvas .x-row .x-column.templated .element.container { - padding-top: 0.5em; - } - - .layout-editor .canvas .x-container a.add { - display: none; - width: 20px; - height: 20px; - position: absolute; - bottom: 5px; - right: 5px; - background: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAEXSURBVDhPrdVPSwJBHMbxTVl9Ab6DpKMnX0ewVFCgd99IeBXBi7c6BB0KPIfgK5AudSi03kGHhLxZ32f/5LQ7qwPNA5/xJ86sM/tnNihJHV3cY4mPlOo7dKA+TjnDO773eMMpSlPFELbBuwygsYWMYBvgQhP5kwi2jq42OEacGhawdZQZsqi29ZFXhBWaEzTx3xwh0gG1XF+JdHX6aMRft5lCt4U84gFKC1/IfjuEmVDNCvnz4Zr8uE8t+QDeooPp6uiEmpmnn4rqXlIGY7STMo5ZKy9qbpGfusn1tpEbLXkCX4mPpSujqdr+UVxn+ITfZ9rro5dF96Ots4tLFOJ9+8ribYM1o+39Atd4xjql+grnsLwCguAHjCrBxU/oR+AAAAAASUVORK5CYII='); - -ms-opacity: 0.3; - opacity: 0.3; - z-index: 1200; - } - - .layout-editor .canvas .x-container a.add:hover { - -ms-opacity: 1; - opacity: 1; - } - - .layout-editor .canvas .toolbar { - padding: 0 0.6em; - background: #e4e4e4; - border: none; - } - - .layout-editor .canvas .toolbar a { - color: #646464; - margin-right: 1.5em; - line-height: 2em; - } - - .layout-editor .canvas .name { - display: block; - color: #9da0a4; - padding: 0 7px; - float: left; - } - - .layout-editor .canvas article.element-box { - position: relative; - padding: 0.7em 0 0 0; - } - - .layout-editor .canvas article.element-box > header { - padding: 0 0.5em 0 0.5em; - -ms-border-radius: 2px; - border-radius: 2px; - background: #9e9e9e; - color: #fff; - cursor: move; - position: absolute; - top: -23px; - left: 0; - right: 0; - height: 27px; - display: none; - z-index: 1; - } - - .layout-editor .canvas article.element-box .element-overlay { - background: #333a26; - -ms-opacity: 0.12; - opacity: 0.12; - position: absolute; - left: 0; - right: 0; - top: 1px; - bottom: -5px; - display: none; - cursor: move; - -ms-border-radius: 0 0 2px 2px; - border-radius: 0 0 2px 2px; - } - - .layout-editor .canvas article.element-box:hover .element-overlay { - display: block; - } - - .layout-editor .canvas article.element-box:hover > header { - display: block; - } - - .layout-editor .canvas article.element-box > header a { - color: #fff; - } - - .layout-editor .canvas article.element-box > header .actions a { - margin-right: 0.5em; - line-height: 2em; - } - - .layout-editor .canvas article.element-box > header .name { - line-height: 2.5em; - } - - .layout-editor .canvas .sortable-placeholder { - display: block; - height: 2.5em; - padding: 0.5em; - border: 1px dashed #bdbcbc; - } - - .layout-editor .canvas .x-row .x-column .x-holder .x-container-widget .x-grid { - background: none repeat scroll 0 0 #fafafa; - border: 1px solid #bdbcbc; - margin: 27px 0 0; - position: relative; - } - - .layout-editor .canvas .x-container-widget .x-grid .grid-toolbar { - padding: 0 0.5em 0 0.5em; - } - -.layout-editor .trash { - display: none; -} - -.layout-editor .element-component { - background: #e5e5e5; - padding: 0.5em; - -ms-opacity: .3; - opacity: .3; -} - -.layout-editor .element-snippet { - background: #e5e5e5; - padding: 0.5em; -} - -.element.element-label label { - font-weight: bold; -} - -.media-element { - overflow: hidden; -} - -textarea.text.large { - width: 98%; -} diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/ContentItem.Design.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/ContentItem.Design.cshtml index ce5cb8c4c..c732cef6b 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/ContentItem.Design.cshtml +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/ContentItem.Design.cshtml @@ -1,3 +1,9 @@ -@foreach (var contentItem in Model.ContentItems) { - @Display(contentItem) +@using Orchard.ContentManagement +@foreach (var contentItemShape in Model.ContentItems) { + var contentItem = (ContentItem)contentItemShape.ContentItem; + var displayTextHtmlString = Html.ItemDisplayText(contentItem); + var displayText = displayTextHtmlString != null ? displayTextHtmlString.ToString() : T("-").ToString(); +
+ @displayText +
} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Projection.Design.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Projection.Design.cshtml index 7919b2d76..c7c8148c6 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Projection.Design.cshtml +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Projection.Design.cshtml @@ -1,10 +1,15 @@ -@{ - var contentShapes = ((Func>)Model.BuildShapes)("Summary").ToList(); - var list = New.List(); - list.AddRange(contentShapes); +@using Orchard.ContentManagement +@{ + var contentItems = (IList)Model.ContentItems; } -@if (contentShapes.Any()) { - @Display(list) +@if (contentItems.Any()) { + foreach (var contentItem in contentItems) { + var displayTextHtmlString = Html.ItemDisplayText(contentItem); + var displayText = displayTextHtmlString != null ? displayTextHtmlString.ToString() : T("-").ToString(); +
+ @displayText +
+ } } else {

@T("The query returned no results.")

diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Shape.Design.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Shape.Design.cshtml index 84f60ed49..407119227 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Shape.Design.cshtml +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Shape.Design.cshtml @@ -2,7 +2,6 @@ @{ var element = (Shape) Model.Element; } -
- @T("Shape -") +
@element.ShapeType
\ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Layout-Designer-Wrapper.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Layout-Designer-Wrapper.cshtml deleted file mode 100644 index 0cfffbe01..000000000 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Layout-Designer-Wrapper.cshtml +++ /dev/null @@ -1,13 +0,0 @@ -@using Orchard.Mvc.Html; - - - - - - @Display(Model.Head) - - - @Display(Model.Body) - @Display(Model.Tail) - - \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Layout-Designer.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Layout-Designer.cshtml deleted file mode 100644 index f19dcb999..000000000 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Layout-Designer.cshtml +++ /dev/null @@ -1,7 +0,0 @@ -@model dynamic -@{ - SetMeta("X-UA-Compatible", "IE=edge,chrome=1"); - Style.Include("layout-designer.css"); - Script.Require("jQuery").AtFoot(); -} -@Display(Model.Content) \ No newline at end of file From 2508f503b78426abb9e2e8ea7fe8d89e119c5770 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Sat, 4 Jul 2015 09:51:05 +0200 Subject: [PATCH 13/17] #5298: Suppressed input validation on SMPT test form. This fixes the issue when you try and use address formats such as "User " and adds support for sending HTML as part of the message body. Fixes #5298 --- .../Modules/Orchard.Email/Controllers/EmailAdminController.cs | 1 + 1 file changed, 1 insertion(+) diff --git a/src/Orchard.Web/Modules/Orchard.Email/Controllers/EmailAdminController.cs b/src/Orchard.Web/Modules/Orchard.Email/Controllers/EmailAdminController.cs index 6aca6ba30..941cb1290 100644 --- a/src/Orchard.Web/Modules/Orchard.Email/Controllers/EmailAdminController.cs +++ b/src/Orchard.Web/Modules/Orchard.Email/Controllers/EmailAdminController.cs @@ -23,6 +23,7 @@ namespace Orchard.Email.Controllers { public Localizer T { get; set; } [HttpPost] + [ValidateInput(false)] public ActionResult TestSettings(TestSmtpSettings testSettings) { ILogger logger = null; try { From 22fa33c06f8c1620b0e690efd3bf13db2aeb0b22 Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Sat, 4 Jul 2015 12:25:23 +0200 Subject: [PATCH 14/17] #5279: Fixed "potentially dangerous request" error. Fixes #5279 --- .../Orchard.DynamicForms/Controllers/FormController.cs | 1 + .../Orchard.DynamicForms/Drivers/FormElementDriver.cs | 9 ++++++++- .../Modules/Orchard.DynamicForms/Elements/Form.cs | 5 +++++ .../Modules/Orchard.DynamicForms/Services/FormService.cs | 8 +++++++- 4 files changed, 21 insertions(+), 2 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs b/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs index 3a033fa65..4630fe116 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs @@ -35,6 +35,7 @@ namespace Orchard.DynamicForms.Controllers { public ILogger Logger { get; set; } [HttpPost] + [ValidateInput(false)] public ActionResult Submit(int contentId, string formName) { var layoutPart = _layoutManager.GetLayout(contentId); var form = _formService.FindForm(layoutPart, formName); diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Drivers/FormElementDriver.cs b/src/Orchard.Web/Modules/Orchard.DynamicForms/Drivers/FormElementDriver.cs index 1a8b72db7..7c6a0be09 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Drivers/FormElementDriver.cs +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Drivers/FormElementDriver.cs @@ -78,12 +78,19 @@ namespace Orchard.DynamicForms.Drivers { Title: "Store Submission", Value: "true", Description: T("Stores the submitted form into the database.")), + _HtmlEncode: shape.Checkbox( + Id: "HtmlEncode", + Name: "HtmlEncode", + Title: "Html Encode", + Value: "true", + Checked: true, + Description: T("Check this option to automatically HTML encode submitted values to prevent code injection.")), _CreateContent: shape.Checkbox( Id: "CreateContent", Name: "CreateContent", Title: "Create Content", Value: "true", - Description: T("Check this to create a content item based using the submitted values. You will have to select a Content Type here and bind the form fields to the various parts and fields of the selected Content Type.")), + Description: T("Check this option to create a content item based using the submitted values. You will have to select a Content Type here and bind the form fields to the various parts and fields of the selected Content Type.")), _ContentType: shape.SelectList( Id: "FormBindingContentType", Name: "FormBindingContentType", diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Elements/Form.cs b/src/Orchard.Web/Modules/Orchard.DynamicForms/Elements/Form.cs index 3360dafc8..2c6c44996 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Elements/Form.cs +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Elements/Form.cs @@ -32,6 +32,11 @@ namespace Orchard.DynamicForms.Elements { set { this.Store(x => x.StoreSubmission, value); } } + public bool HtmlEncode { + get { return this.Retrieve(x => x.HtmlEncode, () => true); } + set { this.Store(x => x.HtmlEncode, value); } + } + public bool? CreateContent { get { return this.Retrieve(x => x.CreateContent); } set { this.Store(x => x.CreateContent, value); } diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Services/FormService.cs b/src/Orchard.Web/Modules/Orchard.DynamicForms/Services/FormService.cs index 8dcaf52ec..97f2fbaca 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Services/FormService.cs +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Services/FormService.cs @@ -3,6 +3,7 @@ using System.Collections.Generic; using System.Collections.Specialized; using System.Data; using System.Linq; +using System.Web; using System.Web.Mvc; using Orchard.Collections; using Orchard.ContentManagement; @@ -179,7 +180,12 @@ namespace Orchard.DynamicForms.Services { ReadElementValues(element, context); foreach (var key in from string key in context.Output where !String.IsNullOrWhiteSpace(key) && values[key] == null select key) { - values.Add(key, context.Output[key]); + var value = context.Output[key]; + + if (form.HtmlEncode) + value = HttpUtility.HtmlEncode(value); + + values.Add(key, value); } } From c8f2c2731170aef6b54f44896ac5bb277a69c05d Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Sat, 4 Jul 2015 12:45:17 +0200 Subject: [PATCH 15/17] Fixed form redirect issue. This fixes the issue where you would not stay on the same page after a model validation occurred. --- .../Modules/Orchard.DynamicForms/Controllers/FormController.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs b/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs index 4630fe116..d76a2335e 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs @@ -39,7 +39,7 @@ namespace Orchard.DynamicForms.Controllers { public ActionResult Submit(int contentId, string formName) { var layoutPart = _layoutManager.GetLayout(contentId); var form = _formService.FindForm(layoutPart, formName); - var urlReferrer = Request.UrlReferrer != null && Url.IsLocalUrl(Request.UrlReferrer.ToString()) ? Request.UrlReferrer.ToString() : "~/"; + var urlReferrer = Request.UrlReferrer != null ? Request.UrlReferrer.LocalPath : "~/"; if (form == null) { Logger.Warning("The specified form \"{0}\" could not be found.", formName); From 6bce34f3796221c38d563196e70cfcd96818029f Mon Sep 17 00:00:00 2001 From: Sipke Schoorstra Date: Sat, 4 Jul 2015 13:01:17 +0200 Subject: [PATCH 16/17] #5260: Fixed the issue where form validation result gets output cached. Fixes #5260 --- .../Controllers/FormController.cs | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs b/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs index d76a2335e..fc5ad4c88 100644 --- a/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs +++ b/src/Orchard.Web/Modules/Orchard.DynamicForms/Controllers/FormController.cs @@ -6,6 +6,7 @@ using Orchard.DynamicForms.Services; using Orchard.Layouts.Services; using Orchard.Localization; using Orchard.Logging; +using Orchard.Services; using Orchard.Tokens; using Orchard.UI.Notify; using IController = Orchard.DynamicForms.Services.IController; @@ -16,17 +17,20 @@ namespace Orchard.DynamicForms.Controllers { private readonly ILayoutManager _layoutManager; private readonly IFormService _formService; private readonly ITokenizer _tokenizer; + private readonly IClock _clock; public FormController( INotifier notifier, ILayoutManager layoutManager, IFormService formService, - ITokenizer tokenizer) { + ITokenizer tokenizer, + IClock clock) { _notifier = notifier; _layoutManager = layoutManager; _formService = formService; _tokenizer = tokenizer; + _clock = clock; T = NullLocalizer.Instance; Logger = NullLogger.Instance; } @@ -50,8 +54,12 @@ namespace Orchard.DynamicForms.Controllers { var values = _formService.SubmitForm(layoutPart, form, ValueProvider, ModelState, this); this.TransferFormSubmission(form, values); - if (!ModelState.IsValid) - return Redirect(urlReferrer); + if (!ModelState.IsValid) { + // We need a way to inform the output cache filter to not cache the upcoming request. + var epoch = new DateTime(2014, DateTimeKind.Utc).Ticks; + var refresh = _clock.UtcNow.Ticks - epoch; + return Redirect(urlReferrer + "?__r=" + refresh); + } if(Response.IsRequestBeingRedirected) return new EmptyResult(); From b6db85b8af00fc9eb42fdf854ef53d9fad9b263d Mon Sep 17 00:00:00 2001 From: Lombiq Date: Sun, 5 Jul 2015 14:19:37 +0200 Subject: [PATCH 17/17] Untabifying CommentPartDriver --- .../Modules/Orchard.Comments/Drivers/CommentPartDriver.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Orchard.Web/Modules/Orchard.Comments/Drivers/CommentPartDriver.cs b/src/Orchard.Web/Modules/Orchard.Comments/Drivers/CommentPartDriver.cs index f5651bfc7..a2488a61f 100644 --- a/src/Orchard.Web/Modules/Orchard.Comments/Drivers/CommentPartDriver.cs +++ b/src/Orchard.Web/Modules/Orchard.Comments/Drivers/CommentPartDriver.cs @@ -53,7 +53,7 @@ namespace Orchard.Comments.Drivers { else { return ContentShape("Parts_Comment_Edit", () => shapeHelper.EditorTemplate(TemplateName: "Parts.Comment", Model: part, Prefix: Prefix)); - } + } } // POST