mirror of
https://github.com/OrchardCMS/Orchard.git
synced 2025-10-15 19:54:57 +08:00
#5452: Improved ContentItem and Projection elements by rendering an abstract representation instead.
Fixes #5452
This commit is contained in:
@@ -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"],
|
||||
|
@@ -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}
|
||||
.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}
|
@@ -2,4 +2,4 @@
|
||||
@{
|
||||
var element = (HiddenField) Model.Element;
|
||||
}
|
||||
<div class="hidden-field">@element.Name</div>
|
||||
<div class="layout-snippet">@element.Name</div>
|
@@ -3,7 +3,7 @@
|
||||
var element = (ValidationMessage)Model.Element;
|
||||
var forField = element.For;
|
||||
}
|
||||
<div class="validation-message">
|
||||
<div class="layout-snippet">
|
||||
@if (String.IsNullOrWhiteSpace(forField)) {
|
||||
@T("Validation message (target not specified)")
|
||||
}
|
||||
|
@@ -1 +1 @@
|
||||
<div class="validation-summary">@T("Validation summary")</div>
|
||||
<div class="layout-snippet">@T("Validation summary")</div>
|
@@ -148,7 +148,6 @@
|
||||
<Content Include="Styles\menu.elements.png" />
|
||||
<Content Include="Styles\element-editor.css" />
|
||||
<Content Include="Styles\element-browser.css" />
|
||||
<Content Include="Styles\designer.css" />
|
||||
<Content Include="Styles\default-grid.css" />
|
||||
<Content Include="Styles\edit.png" />
|
||||
<Content Include="Styles\menu.layouts.png" />
|
||||
@@ -178,8 +177,6 @@
|
||||
<Content Include="Views\Elements\MediaItem.cshtml" />
|
||||
<Content Include="Views\Elements\Snippet.cshtml" />
|
||||
<Content Include="Views\Layout-Dialog.cshtml" />
|
||||
<Content Include="Views\Layout-Designer.cshtml" />
|
||||
<Content Include="Views\Layout-Designer-Wrapper.cshtml" />
|
||||
<Content Include="Views\DialogTemplate.cshtml" />
|
||||
<Content Include="Views\Element\Create.cshtml" />
|
||||
<Content Include="Views\Elements\ContentPart.cshtml" />
|
||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@@ -21,4 +21,8 @@
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.layout-snippet {
|
||||
background: #e8e8e8;
|
||||
}
|
||||
}
|
||||
|
@@ -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('');
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
left: 50%;
|
||||
bottom: 0;
|
||||
}
|
||||
|
||||
.layout-editor .canvas .x-container.x-root > a.add.start {
|
||||
background-image: url('');
|
||||
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('');
|
||||
-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%;
|
||||
}
|
@@ -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();
|
||||
<div class="layout-snippet">
|
||||
@displayText
|
||||
</div>
|
||||
}
|
@@ -1,10 +1,15 @@
|
||||
@{
|
||||
var contentShapes = ((Func<string, IEnumerable<dynamic>>)Model.BuildShapes)("Summary").ToList();
|
||||
var list = New.List();
|
||||
list.AddRange(contentShapes);
|
||||
@using Orchard.ContentManagement
|
||||
@{
|
||||
var contentItems = (IList<ContentItem>)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();
|
||||
<div class="layout-snippet">
|
||||
@displayText
|
||||
</div>
|
||||
}
|
||||
}
|
||||
else {
|
||||
<p>@T("The query returned no results.")</p>
|
||||
|
@@ -2,7 +2,6 @@
|
||||
@{
|
||||
var element = (Shape) Model.Element;
|
||||
}
|
||||
<div class="element-snippet">
|
||||
<strong>@T("Shape -")</strong>
|
||||
<div class="layout-snippet">
|
||||
@element.ShapeType
|
||||
</div>
|
@@ -1,13 +0,0 @@
|
||||
@using Orchard.Mvc.Html;
|
||||
<!DOCTYPE html>
|
||||
<html lang="@WorkContext.CurrentCulture" class="static @Html.ClassForPage()">
|
||||
<head>
|
||||
<title></title>
|
||||
<meta charset="utf-8" />
|
||||
@Display(Model.Head)
|
||||
</head>
|
||||
<body>
|
||||
@Display(Model.Body)
|
||||
@Display(Model.Tail)
|
||||
</body>
|
||||
</html>
|
@@ -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)
|
Reference in New Issue
Block a user