diff --git a/admin/css/screen.css b/admin/css/screen.css index 3d4aeaba0..cfcd30abc 100644 --- a/admin/css/screen.css +++ b/admin/css/screen.css @@ -150,7 +150,7 @@ form.nostyle .middleColumn { margin-left: 0; } form.nostyle input.text, form.nostyle textarea, form.nostyle select, form.nostyle .TreeDropdownField { width: auto; max-width: auto; } .field { display: block; border-bottom: 1px solid #d0d3d5; -webkit-box-shadow: 0 1px 0 rgba(245, 245, 245, 0.8); -moz-box-shadow: 0 1px 0 rgba(245, 245, 245, 0.8); box-shadow: 0 1px 0 rgba(245, 245, 245, 0.8); padding: 0 0 7px 0; margin: 8px 0; *zoom: 1; } -.field:last-child { border-bottom: none; -webkit-box-shadow: none; -moz-box-shadow: none; box-shadow: none; } +.field.noborder, .field:last-child { padding-bottom: 0; border-bottom: none; -webkit-box-shadow: none; -moz-box-shadow: none; box-shadow: none; } .field:after { content: "\0020"; display: block; height: 0; clear: both; overflow: hidden; visibility: hidden; } .field.nolabel .middleColumn { margin-left: 0; } .field.nolabel .description { margin-left: 0; } @@ -160,7 +160,7 @@ form.nostyle input.text, form.nostyle textarea, form.nostyle select, form.nostyl .field .middleColumn { margin-left: 184px; } .field span.readonly { padding-top: 8px; line-height: 16px; display: block; } .field .fieldgroup .fieldgroup-field.last { /* This is used on page/settings/visibility */ padding-bottom: 8px; /* replicates li item spacing */ } -.field .description { clear: both; color: #777777; display: block; font-style: italic; margin: 4px 0 0 184px; } +.field .description { clear: both; color: #777777; display: block; font-style: italic; line-height: 16px; margin: 4px 0 0 184px; } .field.checkbox .description, .field.ss-gridfield .description { margin-left: 0; } .field input.text, .field textarea, .field select, .field .TreeDropdownField { margin-left: 10px; width: 100%; max-width: 512px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } .field input.text.description, .field textarea.description, .field select.description, .field .TreeDropdownField.description { margin: 0; } @@ -636,21 +636,22 @@ body.cms-dialog { overflow: auto; background: url("../images/textures/bg_cms_mai /** -------------------------------------------- "Insert X" forms -------------------------------------------- */ .htmleditorfield-dialog.ui-dialog-content { padding: 0; position: relative; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb .CompositeField { overflow: hidden; *zoom: 1; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb #RemoteURL { border: none; -moz-box-shadow: none; -webkit-box-shadow: none; box-shadow: none; width: 55%; max-width: 512px; float: left; position: relative; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb #RemoteURL label { position: absolute; left: 8px; top: 13px; font-weight: normal; color: #888; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb #RemoteURL .middleColumn { margin-left: 0; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb #RemoteURL input.remoteurl { padding-left: 40px; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb button.add-url { margin-top: 5px; padding-top: 15px; overflow: hidden; *zoom: 1; border: none; background: none; opacity: 0.8; cursor: hand; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb button.add-url .btn-icon-addMedia { width: 20px; height: 20px; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb button.add-url .ui-button-text { margin-left: 10px; margin-top: -5px; line-height: 20px; float: left; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb button.add-url:hover, .htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb button.add-url:active { border: none; -moz-box-shadow: none; -webkit-box-shadow: none; box-shadow: none; opacity: 1; } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb button.add-url.ui-state-disabled, .htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb button.add-url.ui-state-disabled:hover, .htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb button.add-url.ui-state-disabled:active { opacity: 0.35; filter: Alpha(Opacity=35); } -.htmleditorfield-dialog #MediaFormInsertMediaTabs_FromWeb .loading button.add-url .ui-icon { background-image: url(../images/throbber.gif); background-position: 50% 50%; background-repeat: no-repeat; } +.htmleditorfield-dialog .htmleditorfield-from-web .CompositeField { overflow: hidden; *zoom: 1; } +.htmleditorfield-dialog .htmleditorfield-from-web #RemoteURL { border: none; -moz-box-shadow: none; -webkit-box-shadow: none; box-shadow: none; width: 55%; max-width: 512px; float: left; position: relative; } +.htmleditorfield-dialog .htmleditorfield-from-web #RemoteURL label { position: absolute; left: 8px; top: 13px; font-weight: normal; color: #888; } +.htmleditorfield-dialog .htmleditorfield-from-web #RemoteURL .middleColumn { margin-left: 0; } +.htmleditorfield-dialog .htmleditorfield-from-web #RemoteURL input.remoteurl { padding-left: 40px; } +.htmleditorfield-dialog .htmleditorfield-from-web button.add-url { margin-top: 5px; padding-top: 15px; overflow: hidden; *zoom: 1; border: none; background: none; opacity: 0.8; cursor: hand; } +.htmleditorfield-dialog .htmleditorfield-from-web button.add-url .btn-icon-addMedia { width: 20px; height: 20px; } +.htmleditorfield-dialog .htmleditorfield-from-web button.add-url .ui-button-text { margin-left: 10px; margin-top: -5px; line-height: 20px; float: left; } +.htmleditorfield-dialog .htmleditorfield-from-web button.add-url:hover, .htmleditorfield-dialog .htmleditorfield-from-web button.add-url:active { border: none; -moz-box-shadow: none; -webkit-box-shadow: none; box-shadow: none; opacity: 1; } +.htmleditorfield-dialog .htmleditorfield-from-web button.add-url.ui-state-disabled, .htmleditorfield-dialog .htmleditorfield-from-web button.add-url.ui-state-disabled:hover, .htmleditorfield-dialog .htmleditorfield-from-web button.add-url.ui-state-disabled:active { opacity: 0.35; filter: Alpha(Opacity=35); } +.htmleditorfield-dialog .htmleditorfield-from-web .loading button.add-url .ui-icon { background-image: url(../images/throbber.gif); background-position: 50% 50%; background-repeat: no-repeat; } .htmleditorfield-dialog .cms-content-header { padding: 0; width: 100%; height: 40px; } .htmleditorfield-dialog .cms-content-header h3 { padding: 0 8px; margin: 10px; } .htmleditorfield-dialog .ss-insert-media, .htmleditorfield-dialog .Actions, .htmleditorfield-dialog .ss-insert-link { padding: 8px 16px; } -.htmleditorfield-dialog .details .file-url { display: block; width: 450px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; -o-text-overflow: ellipsis; } +.htmleditorfield-dialog .ss-insert-media .ui-tabs-panel, .htmleditorfield-dialog .Actions .ui-tabs-panel, .htmleditorfield-dialog .ss-insert-link .ui-tabs-panel { padding: 0; } +.htmleditorfield-dialog .details .file-url { display: block; width: 300px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; -o-text-overflow: ellipsis; } .htmleditorfield-dialog .details .cms-file-info .field { border: none; -webkit-box-shadow: 0 0 0 rgba(0, 0, 0, 0); -moz-box-shadow: 0 0 0 rgba(0, 0, 0, 0); box-shadow: 0 0 0 rgba(0, 0, 0, 0); } .htmleditorfield-dialog .details .field { border-bottom: 1px solid rgba(201, 205, 206, 0.8); -webkit-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8); -moz-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8); box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8); } .htmleditorfield-dialog .details .field.last { border-bottom: none; -webkit-box-shadow: 0 0 0 rgba(0, 0, 0, 0); -moz-box-shadow: 0 0 0 rgba(0, 0, 0, 0); box-shadow: 0 0 0 rgba(0, 0, 0, 0); margin-bottom: 0; } @@ -658,13 +659,14 @@ body.cms-dialog { overflow: auto; background: url("../images/textures/bg_cms_mai .htmleditorfield-linkform .step2 { margin-bottom: 16px; } -.htmleditorfield-mediaform .ss-gridfield tbody td:first-child img { max-height: 30px; } -.htmleditorfield-mediaform .ss-uploadfield.from-web, .htmleditorfield-mediaform .ss-uploadfield.from-CMS { margin-bottom: 48px; } -.htmleditorfield-mediaform .ss-uploadfield.from-web .middleColumn, .htmleditorfield-mediaform .ss-uploadfield.from-CMS .middleColumn { width: auto; background: none; border: none; margin-top: 13px; } -.htmleditorfield-mediaform .ss-uploadfield.from-CMS { margin-top: 33px; } -.htmleditorfield-mediaform .ss-uploadfield.from-CMS h4 { margin-top: 3px; } -.htmleditorfield-mediaform .ss-uploadfield.from-CMS .middleColumn { margin-top: 0; } -.htmleditorfield-mediaform .ss-uploadfield.from-CMS .middleColumn .TreeDropdownField { margin-top: 23px; } +.htmleditorfield-mediaform .ss-gridfield .gridfield-button-delete { display: none; } +.htmleditorfield-mediaform .ss-gridfield table.ss-gridfield-table tbody td:first-child { padding: 0; text-align: center; } +.htmleditorfield-mediaform .ss-gridfield table.ss-gridfield-table tbody td:first-child img { max-height: 30px; } +.htmleditorfield-mediaform .ss-gridfield table.ss-gridfield-table tr td { padding: 4px; } +.htmleditorfield-mediaform .htmleditorfield-from-web .ss-uploadfield .middleColumn, .htmleditorfield-mediaform .htmleditorfield-from-cms .ss-uploadfield .middleColumn { width: auto; background: none; border: none; margin-top: 13px; } +.htmleditorfield-mediaform .htmleditorfield-from-cms .ss-uploadfield h4 { float: left; margin-top: 4px; margin-bottom: 0; } +.htmleditorfield-mediaform .htmleditorfield-from-cms .ss-uploadfield .middleColumn { margin-top: 16px; margin-left: 184px; } +.htmleditorfield-mediaform .htmleditorfield-from-cms .ss-uploadfield .field.treedropdown { border-bottom: 0; padding: 0; } .htmleditorfield-mediaform .ss-uploadfield-editandorganize { display: none; } /** -------------------------------------------- Search forms (used in AssetAdmin, ModelAdmin, etc) -------------------------------------------- */ @@ -681,9 +683,11 @@ body.cms-dialog { overflow: auto; background: url("../images/textures/bg_cms_mai /** -------------------------------------------- Item Edit Form -------------------------------------------- */ .cms-file-info { overflow: auto; border-bottom: 1px solid rgba(201, 205, 206, 0.8); -webkit-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8); -moz-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8); box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8); margin-bottom: 8px; } .cms-file-info .cms-file-info-preview { float: left; width: 176px; margin-right: 8px; } -.cms-file-info .cms-file-info-preview img { max-width: 176px; } +.cms-file-info .cms-file-info-preview img { max-width: 176px; max-height: 128px; } .cms-file-info .cms-file-info-data { float: left; } -.cms-file-info .cms-file-info-data .field { margin-bottom: 0; padding-bottom: 8px; border: none; box-shadow: none; } +.cms-file-info .cms-file-info-data .field { margin: 0; padding-bottom: 8px; border: none; box-shadow: none; } +.cms-file-info .cms-file-info-data .field label.left { width: 96px; } +.cms-file-info .cms-file-info-data .field .middleColumn { margin-left: 104px; } .cms-file-info .cms-file-info-data .field label, .cms-file-info .cms-file-info-data .field span { padding: 0; } form.small .cms-file-info-preview { width: 112px; } @@ -716,7 +720,6 @@ form.import-form label.left { width: 250px; } .cms-container .CMSMain.CMSPageSettingsController .tab#Root_Settings .optionset li { white-space: nowrap; } .cms-container .CMSMain.CMSPageSettingsController .tab#Root_Settings .optionset li label { padding-left: 2px; } .cms-container .CMSMain.CMSPageSettingsController .tab#Root_Settings .fieldgroup .fieldgroup-field { width: 216px; padding-left: 0; } -.cms-container .CMSMain.CMSPageSettingsController .tab#Root_Settings .TreeDropdownField .treedropdownfield-toggle-panel-link { border-left: none; background: none; background-image: none; } /** -------------------------------------------- Buttons for FileUpload -------------------------------------------- */ .ss-uploadfield-item-edit-all .ui-button-text { padding-right: 0; } diff --git a/admin/scss/_forms.scss b/admin/scss/_forms.scss index 06ae68140..292b7311e 100644 --- a/admin/scss/_forms.scss +++ b/admin/scss/_forms.scss @@ -23,12 +23,12 @@ form.nostyle { //overflow: hidden; // bottom padding accounts for the border and we have a negative - // margin with a postive padding to ensure the bottom border extends - // over the edges + // margin with a postive padding to ensure the bottom border extends over the edges padding: 0 0 $grid-y - 1 0; margin: $grid-y 0; - &:last-child { + &.noborder, &:last-child { + padding-bottom: 0; border-bottom: none; @include box-shadow(none); } @@ -37,7 +37,7 @@ form.nostyle { // need to use relative positioning and overflow hidden will not expand // the containing boxes @include legacy-pie-clearfix(); - + &.nolabel { .middleColumn { margin-left: 0; @@ -95,6 +95,7 @@ form.nostyle { color: lighten($color-text, 20%); display: block; font-style: italic; + line-height: $grid-y * 2; margin: $grid-y/2 0 0 $grid-x*23; // left align with .middleColumn } diff --git a/admin/scss/_style.scss b/admin/scss/_style.scss index 5d1548d81..fdffea04b 100644 --- a/admin/scss/_style.scss +++ b/admin/scss/_style.scss @@ -1366,7 +1366,7 @@ body.cms-dialog { position:relative; } - #MediaFormInsertMediaTabs_FromWeb{ + .htmleditorfield-from-web { .CompositeField{ @include clearfix; } @@ -1442,11 +1442,14 @@ body.cms-dialog { .ss-insert-media, .Actions, .ss-insert-link{ padding:$grid-y $grid-x*2 ; + .ui-tabs-panel { + padding: 0; + } } .details{ .file-url{ display:block; - width:450px; + width:300px; @include hide-text-overflow; } .cms-file-info{ @@ -1483,15 +1486,26 @@ body.cms-dialog { .htmleditorfield-mediaform { .ss-gridfield { - // Set thumbnail size - tbody td:first-child img { - max-height: 30px; + .gridfield-button-delete { + // TODO Remove from PHP instead of hiding + display: none; // delete action shouldn't be allowed here + } + table.ss-gridfield-table { + tbody td:first-child { + padding: 0; + text-align: center; + img { + max-height: 30px; // same thumbnail size as uploadfield rows + } + } + tr td { + padding: $grid-x/2; // more compressed space + } } } - .ss-uploadfield{ - &.from-web, &.from-CMS{ - margin-bottom:48px; + .htmleditorfield-from-web, .htmleditorfield-from-cms { + .ss-uploadfield { .middleColumn { width:auto; background:none; @@ -1499,20 +1513,24 @@ body.cms-dialog { margin-top:13px; } } + } - &.from-CMS{ - margin-top:33px; - h4{ - margin-top:3px; + .htmleditorfield-from-cms { + .ss-uploadfield { + h4 { + float: left; // headline and dropdown on same line + margin-top: $grid-y/2; // bring to same baseline as dropdown + margin-bottom: 0; } .middleColumn { - margin-top:0; - .TreeDropdownField{ - margin-top:23px; - } + margin-top: $grid-y*2; // same as left-floated h4 + margin-left: $grid-x*23; // make room for headline + } + .field.treedropdown { + border-bottom: 0; // don't show border, dropdown and gridfield visually belong together + padding: 0; } } - } .ss-uploadfield-editandorganize { @@ -1590,6 +1608,7 @@ body.cms-dialog { img { max-width: $grid-x * 22; // Same as ".field label" + max-height: $grid-x * 16; // Fitting typical info displayed (~5 rows) } } .cms-file-info-data { @@ -1597,10 +1616,16 @@ body.cms-dialog { .field { // Unsetting styles from .field, make it more compact visually - margin-bottom: 0; + margin: 0; padding-bottom: $grid-x; border: none; box-shadow: none; + label.left { + width: $grid-x*12; + } + .middleColumn { + margin-left: $grid-x*13; + } label, span { padding: 0; } @@ -1702,11 +1727,6 @@ form.import-form { width:$grid-x*27; padding-left:0; } - .TreeDropdownField .treedropdownfield-toggle-panel-link { - border-left:none; - background:none; - background-image:none; - } } } diff --git a/css/AssetUploadField.css b/css/AssetUploadField.css index a6380044f..b74c4cbe9 100644 --- a/css/AssetUploadField.css +++ b/css/AssetUploadField.css @@ -38,7 +38,7 @@ body.cms.ss-uploadfield-edit-iframe .fieldholder-small label, .composite.ss-asse .ss-assetuploadfield .ss-uploadfield-files .ss-uploadfield-item .info { position: relative; padding: 7px; overflow: hidden; background-color: #FFBE66; border: 1px solid #FF9300; } .ss-assetuploadfield .ss-uploadfield-files .ss-uploadfield-item-preview { position: absolute; height: 30px; width: 40px; overflow: hidden; z-index: 1; } .ss-assetuploadfield .ss-uploadfield-files .ss-uploadfield-item-preview .no-preview { display: block; height: 100%; width: 100%; background: url("../images/icons/document.png") 2px 0px no-repeat; } -.ss-assetuploadfield .ss-uploadfield-files .ss-uploadfield-item-info { position: relative; line-height: 30px; font-size: 14px; overflow: hidden; background-color: #5db4df; background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #5db4df), color-stop(8%, #5db1dd), color-stop(50%, #439bcb), color-stop(54%, #3f99cd), color-stop(96%, #207db6), color-stop(100%, #1e7cba)); background-image: -webkit-linear-gradient(top, #5db4df 0%, #5db1dd 8%, #439bcb 50%, #3f99cd 54%, #207db6 96%, #1e7cba 100%); background-image: -moz-linear-gradient(top, #5db4df 0%, #5db1dd 8%, #439bcb 50%, #3f99cd 54%, #207db6 96%, #1e7cba 100%); background-image: -o-linear-gradient(top, #5db4df 0%, #5db1dd 8%, #439bcb 50%, #3f99cd 54%, #207db6 96%, #1e7cba 100%); background-image: linear-gradient(top, #5db4df 0%, #5db1dd 8%, #439bcb 50%, #3f99cd 54%, #207db6 96%, #1e7cba 100%); } +.ss-assetuploadfield .ss-uploadfield-files .ss-uploadfield-item-info { position: relative; line-height: 30px; overflow: hidden; background-color: #5db4df; background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #5db4df), color-stop(8%, #5db1dd), color-stop(50%, #439bcb), color-stop(54%, #3f99cd), color-stop(96%, #207db6), color-stop(100%, #1e7cba)); background-image: -webkit-linear-gradient(top, #5db4df 0%, #5db1dd 8%, #439bcb 50%, #3f99cd 54%, #207db6 96%, #1e7cba 100%); background-image: -moz-linear-gradient(top, #5db4df 0%, #5db1dd 8%, #439bcb 50%, #3f99cd 54%, #207db6 96%, #1e7cba 100%); background-image: -o-linear-gradient(top, #5db4df 0%, #5db1dd 8%, #439bcb 50%, #3f99cd 54%, #207db6 96%, #1e7cba 100%); background-image: linear-gradient(top, #5db4df 0%, #5db1dd 8%, #439bcb 50%, #3f99cd 54%, #207db6 96%, #1e7cba 100%); } .ss-assetuploadfield .ss-uploadfield-files .ui-state-error .ss-uploadfield-item-info { background-color: #c11f1d; padding-right: 130px; background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #c11f1d), color-stop(4%, #bf1d1b), color-stop(8%, #b71b1c), color-stop(15%, #b61e1d), color-stop(27%, #b11d1d), color-stop(31%, #ab1d1c), color-stop(42%, #a51b1b), color-stop(46%, #9f1b19), color-stop(50%, #9f1b19), color-stop(54%, #991c1a), color-stop(58%, #971a18), color-stop(62%, #911b1b), color-stop(65%, #911b1b), color-stop(88%, #7e1816), color-stop(92%, #771919), color-stop(100%, #731817)); background-image: -webkit-linear-gradient(top, #c11f1d 0%, #bf1d1b 4%, #b71b1c 8%, #b61e1d 15%, #b11d1d 27%, #ab1d1c 31%, #a51b1b 42%, #9f1b19 46%, #9f1b19 50%, #991c1a 54%, #971a18 58%, #911b1b 62%, #911b1b 65%, #7e1816 88%, #771919 92%, #731817 100%); background-image: -moz-linear-gradient(top, #c11f1d 0%, #bf1d1b 4%, #b71b1c 8%, #b61e1d 15%, #b11d1d 27%, #ab1d1c 31%, #a51b1b 42%, #9f1b19 46%, #9f1b19 50%, #991c1a 54%, #971a18 58%, #911b1b 62%, #911b1b 65%, #7e1816 88%, #771919 92%, #731817 100%); background-image: -o-linear-gradient(top, #c11f1d 0%, #bf1d1b 4%, #b71b1c 8%, #b61e1d 15%, #b11d1d 27%, #ab1d1c 31%, #a51b1b 42%, #9f1b19 46%, #9f1b19 50%, #991c1a 54%, #971a18 58%, #911b1b 62%, #911b1b 65%, #7e1816 88%, #771919 92%, #731817 100%); background-image: linear-gradient(top, #c11f1d 0%, #bf1d1b 4%, #b71b1c 8%, #b61e1d 15%, #b11d1d 27%, #ab1d1c 31%, #a51b1b 42%, #9f1b19 46%, #9f1b19 50%, #991c1a 54%, #971a18 58%, #911b1b 62%, #911b1b 65%, #7e1816 88%, #771919 92%, #731817 100%); } .ss-assetuploadfield .ss-uploadfield-files .ui-state-error .ss-uploadfield-item-info .ss-uploadfield-item-name { width: 100%; cursor: default; background: #bcb9b9; background: rgba(201, 198, 198, 0.9); } .ss-assetuploadfield .ss-uploadfield-files .ui-state-error .ss-uploadfield-item-info .ss-uploadfield-item-name .name { text-shadow: 0px 1px 0px rgba(255, 255, 255, 0.7); } diff --git a/css/GridField.css b/css/GridField.css index 4e7d2b35c..e86ab7032 100644 --- a/css/GridField.css +++ b/css/GridField.css @@ -30,7 +30,7 @@ Used in side panels and action tabs .cms .ss-gridfield .add-existing-autocompleter span { display: -moz-inline-stack; display: inline-block; vertical-align: top; *vertical-align: auto; zoom: 1; *display: inline; } .cms .ss-gridfield .add-existing-autocompleter input.relation-search { width: 270px; margin-bottom: 12px; } .cms .ss-gridfield .grid-csv-button, .cms .ss-gridfield .grid-print-button { margin-bottom: 12px; display: -moz-inline-stack; display: inline-block; vertical-align: middle; *vertical-align: auto; zoom: 1; *display: inline; } -.cms table.ss-gridfield-table { display: table; -moz-box-shadow: none; -webkit-box-shadow: none; box-shadow: none; padding: 0; border-collapse: separate; border-bottom: 0 none; width: 100%; margin-bottom: 12px; } +.cms table.ss-gridfield-table { display: table; -moz-box-shadow: none; -webkit-box-shadow: none; box-shadow: none; padding: 0; border-collapse: separate; border-bottom: 0 none; width: 100%; } .cms table.ss-gridfield-table thead { color: #323e46; background: transparent; } .cms table.ss-gridfield-table thead tr.filter-header .fieldgroup { max-width: 512px; } .cms table.ss-gridfield-table thead tr.filter-header .fieldgroup .fieldgroup-field { padding: 0; } @@ -114,7 +114,7 @@ Used in side panels and action tabs .cms table.ss-gridfield-table tr td.bottom-all { -moz-border-radius-bottomleft: 5px; -webkit-border-bottom-left-radius: 5px; border-bottom-left-radius: 5px; -moz-border-radius-bottomright: 5px; -webkit-border-bottom-right-radius: 5px; border-bottom-right-radius: 5px; background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjUwJSIgeTE9IjAlIiB4Mj0iNTAlIiB5Mj0iMTAwJSI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2IwYmVjNyIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iIzk4YWFiNiIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA=='); background-size: 100%; background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #b0bec7), color-stop(100%, #98aab6)); background-image: -webkit-linear-gradient(#b0bec7, #98aab6); background-image: -moz-linear-gradient(#b0bec7, #98aab6); background-image: -o-linear-gradient(#b0bec7, #98aab6); background-image: linear-gradient(#b0bec7, #98aab6); padding: 4px 12px; } .cms table.ss-gridfield-table tr td.bottom-all .datagrid-footer-message { text-align: center; padding-top: 6px; color: white; } .cms table.ss-gridfield-table tr td.bottom-all .datagrid-pagination { padding-top: 1px; position: absolute; left: 50%; margin-left: -116px; z-index: 5; } -.cms table.ss-gridfield-table tr td.bottom-all .datagrid-pagination .pagination-page-number { color: white; text-shadow: 0px -1px 0 rgba(0, 0, 0, 0.2); } +.cms table.ss-gridfield-table tr td.bottom-all .datagrid-pagination .pagination-page-number { color: white; text-align: center; text-shadow: 0px -1px 0 rgba(0, 0, 0, 0.2); } .cms table.ss-gridfield-table tr td.bottom-all .datagrid-pagination .pagination-page-number input { width: 35px; height: 18px; margin-bottom: -6px; padding: 0px; border: 1px solid #899eab; border-bottom: 1px solid #a7b7c1; } .cms table.ss-gridfield-table tr td.bottom-all .datagrid-pagination button { -moz-box-shadow: none; -webkit-box-shadow: none; box-shadow: none; border: none; width: 10px; margin: 0 10px; display: inline; float: none; } .cms table.ss-gridfield-table tr td.bottom-all .datagrid-pagination button span { text-indent: -9999em; } @@ -127,3 +127,4 @@ Used in side panels and action tabs .cms table.ss-gridfield-table tr.last td { border-bottom: 0 none; } .cms table.ss-gridfield-table td:first-child { border-left: 1px solid rgba(0, 0, 0, 0.1); } .cms table.ss-gridfield-table td:last-child { border-right: 1px solid rgba(0, 0, 0, 0.1); } +.cms .grid-bottom-button { margin-top: 12px; } diff --git a/css/TreeDropdownField.css b/css/TreeDropdownField.css index bda6fbbd9..dfd84351e 100644 --- a/css/TreeDropdownField.css +++ b/css/TreeDropdownField.css @@ -5,7 +5,7 @@ div.TreeDropdownField .treedropdownfield-panel { clear: left; position: absolute div.TreeDropdownField .treedropdownfield-panel.loading { min-height: 30px; background: white url("../images/network-save.gif") 7px 7px no-repeat; } div.TreeDropdownField .treedropdownfield-panel ul.tree { margin: 0; } div.TreeDropdownField .treedropdownfield-panel ul.tree a { font-size: 12px; } -div.TreeDropdownField .treedropdownfield-toggle-panel-link { border: none; margin: 0; z-index: 0; padding: 7px 3px; overflow: hidden; -webkit-border-radius: 0 4px 4px 0; -moz-border-radius: 0 4px 4px 0; border-radius: 0 4px 4px 0; -moz-background-clip: padding; -webkit-background-clip: padding-box; background-clip: padding-box; background: #ccc; background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #cccccc), color-stop(0.6, #eeeeee)); background-image: -webkit-linear-gradient(center bottom, #cccccc 0%, #eeeeee 60%); background-image: -moz-linear-gradient(center bottom, #cccccc 0%, #eeeeee 60%); background-image: -o-linear-gradient(bottom, #cccccc 0%, #eeeeee 60%); background-image: -ms-linear-gradient(top, #cccccc 0%, #eeeeee 60%); filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#cccccc', endColorstr='#eeeeee',GradientType=0 ); background-image: linear-gradient(top, #cccccc 0%, #eeeeee 60%); border-left: 1px solid #aaa; } +div.TreeDropdownField .treedropdownfield-toggle-panel-link { border: none; margin: 0; z-index: 0; padding: 7px 3px; overflow: hidden; -webkit-border-radius: 0 4px 4px 0; -moz-border-radius: 0 4px 4px 0; border-radius: 0 4px 4px 0; } div.TreeDropdownField .treedropdownfield-toggle-panel-link.treedropdownfield-open-tree { background: transparent; border: none; } div.TreeDropdownField .treedropdownfield-toggle-panel-link a { text-decoration: none; display: block; border: 0; margin: 0; opacity: 0.5; } div.TreeDropdownField a.jstree-loading .jstree-pageicon { background: white url("../images/network-save.gif") center center no-repeat; } diff --git a/css/UploadField.css b/css/UploadField.css index 884c2f7e4..050a051db 100644 --- a/css/UploadField.css +++ b/css/UploadField.css @@ -11,9 +11,6 @@ Used in side panels and action tabs */ .ss-uploadfield .clear { clear: both; } -.ss-insert-media .ss-uploadfield { margin-top: 20px; } -.ss-insert-media .ss-uploadfield h4 { float: left; } -.ss-insert-media .ss-uploadfield.from-CMS .nolabel.treedropdown .middleColumn { margin-left: 184px; } .ss-uploadfield .middleColumn { width: 510px; padding: 0; background: #fff; border: 1px solid #b3b3b3; -webkit-border-radius: 4px; -moz-border-radius: 4px; -ms-border-radius: 4px; -o-border-radius: 4px; border-radius: 4px; background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #efefef), color-stop(10%, #ffffff), color-stop(90%, #ffffff), color-stop(100%, #efefef)); background-image: -webkit-linear-gradient(#efefef, #ffffff 10%, #ffffff 90%, #efefef); background-image: -moz-linear-gradient(#efefef, #ffffff 10%, #ffffff 90%, #efefef); background-image: -o-linear-gradient(#efefef, #ffffff 10%, #ffffff 90%, #efefef); background-image: linear-gradient(#efefef, #ffffff 10%, #ffffff 90%, #efefef); } .ss-uploadfield .ss-uploadfield-item { margin: 0; padding: 15px; overflow: auto; } .ss-uploadfield .ss-uploadfield-item .ss-uploadfield-item-preview { height: 60px; line-height: 60px; width: 80px; text-align: center; font-weight: bold; float: left; overflow: hidden; } diff --git a/forms/HtmlEditorField.php b/forms/HtmlEditorField.php index 2809566d2..c2e87f102 100644 --- a/forms/HtmlEditorField.php +++ b/forms/HtmlEditorField.php @@ -380,6 +380,8 @@ class HtmlEditorField_Toolbar extends RequestHandler { new GridFieldSortableHeader(), new GridFieldDataColumns(), new GridFieldPaginator(5), + // TODO Shouldn't allow delete here, its too confusing with a "remove from editor view" action. + // Remove once we can fit the search button in the last actual title column new GridFieldDeleteAction(), new GridFieldDetailForm() ); @@ -399,11 +401,11 @@ class HtmlEditorField_Toolbar extends RequestHandler { $fromCMS = new CompositeField( new LiteralField('headerSelect', '

'.sprintf($numericLabelTmpl, '1', _t('HtmlEditorField.FindInFolder', 'Find in Folder')).'

'), - $select = new TreeDropdownField('ParentID', "", 'Folder'), + $select = TreeDropdownField::create('ParentID', "", 'Folder')->addExtraClass('noborder'), $fileField ); - $fromCMS->addExtraClass('content ss-uploadfield from-CMS'); + $fromCMS->addExtraClass('content ss-uploadfield'); $select->addExtraClass('content-select'); @@ -416,7 +418,7 @@ class HtmlEditorField_Toolbar extends RequestHandler { ); $remoteURL->addExtraClass('remoteurl'); - $fromWeb->addExtraClass('content ss-uploadfield from-web'); + $fromWeb->addExtraClass('content ss-uploadfield'); Requirements::css(FRAMEWORK_DIR . '/css/AssetUploadField.css'); $computerUploadField = Object::create('UploadField', 'AssetUploadField', ''); @@ -431,27 +433,27 @@ class HtmlEditorField_Toolbar extends RequestHandler { $tabSet = new TabSet( "MediaFormInsertMediaTabs", - new Tab( + Tab::create( 'FromComputer', _t('HtmlEditorField.FROMCOMPUTER','From your computer'), $computerUploadField - ), - new Tab( + )->addExtraClass('htmleditorfield-from-computer'), + Tab::create( 'FromWeb', _t('HtmlEditorField.FROMWEB', 'From the web'), $fromWeb - ), - new Tab( + )->addExtraClass('htmleditorfield-from-web'), + Tab::create( 'FromCms', _t('HtmlEditorField.FROMCMS','From the CMS'), $fromCMS - ) + )->addExtraClass('htmleditorfield-from-cms') ); $tabSet->addExtraClass('cms-tabset-primary'); $allFields = new CompositeField( $tabSet, - new LiteralField('headerEdit', '

' . sprintf($numericLabelTmpl, '2', + new LiteralField('headerEdit', '

' . sprintf($numericLabelTmpl, '2', _t('HtmlEditorField.ADJUSTDETAILSDIMENSIONS', 'Details & dimensions')) . '

'), $editComposite = new CompositeField( new LiteralField('contentEdit', '
') @@ -711,15 +713,15 @@ class HtmlEditorField_Toolbar extends RequestHandler { )->setName("FilePreviewImage")->addExtraClass('cms-file-info-preview'), CompositeField::create( CompositeField::create( - new ReadonlyField("FileType", _t('AssetTableField.TYPE','File type') . ':', $file->FileType), - new ReadonlyField("Size", _t('AssetTableField.SIZE','File size') . ':', $file->getSize()), + new ReadonlyField("FileType", _t('AssetTableField.TYPE','File type'), $file->FileType), + new ReadonlyField("Size", _t('AssetTableField.SIZE','File size'), $file->getSize()), $urlField = new ReadonlyField('ClickableURL', _t('AssetTableField.URL','URL'), - sprintf('%s', - $file->Link(), $file->RelativeLink()) + sprintf('%s', + $file->Link(), $file->Link(), $file->RelativeLink()) ), - new DateField_Disabled("Created", _t('AssetTableField.CREATED','First uploaded') . ':', + new DateField_Disabled("Created", _t('AssetTableField.CREATED','First uploaded'), $file->Created), - new DateField_Disabled("LastEdited", _t('AssetTableField.LASTEDIT','Last changed') . ':', + new DateField_Disabled("LastEdited", _t('AssetTableField.LASTEDIT','Last changed'), $file->LastEdited) ) )->setName("FilePreviewData")->addExtraClass('cms-file-info-data') diff --git a/forms/gridfield/GridFieldExportButton.php b/forms/gridfield/GridFieldExportButton.php index a7c5d18b7..85d3c78b9 100644 --- a/forms/gridfield/GridFieldExportButton.php +++ b/forms/gridfield/GridFieldExportButton.php @@ -53,7 +53,7 @@ class GridFieldExportButton implements GridField_HTMLProvider, GridField_ActionP $button->setAttribute('data-icon', 'download-csv'); $button->addExtraClass('no-ajax'); return array( - $this->targetFragment => '

' . $button->Field() . '

', + $this->targetFragment => '

' . $button->Field() . '

', ); } diff --git a/javascript/HtmlEditorField.js b/javascript/HtmlEditorField.js index 138bd2537..dc6c443b9 100644 --- a/javascript/HtmlEditorField.js +++ b/javascript/HtmlEditorField.js @@ -826,7 +826,7 @@ ss.editorWrappers['default'] = ss.editorWrappers.tinyMCE; } this.redraw(); }, - redraw: function() { + redraw: function(updateExisting) { this._super(); var node = this.getSelection(), @@ -835,7 +835,7 @@ ss.editorWrappers['default'] = ss.editorWrappers.tinyMCE; header = this.find('.header-edit'); // Only show second step if files are selected - if(header) header[(hasItems) ? 'show' : 'hide'](); + header[(hasItems) ? 'show' : 'hide'](); // Disable "insert" button if no files are selected this.find('.Actions :submit') @@ -845,11 +845,15 @@ ss.editorWrappers['default'] = ss.editorWrappers.tinyMCE; // Hide file selection and step labels when editing an existing file this.find('#MediaFormInsertMediaTabs,.header-edit')[editingSelected ? 'hide' : 'show'](); - var updateExisting = Boolean(this.find('.ss-htmleditorfield-file').length); - this.find('.htmleditorfield-mediaform-heading.insert')[updateExisting ? 'hide' : 'show'](); - this.find('.Actions .media-insert')[updateExisting ? 'hide' : 'show'](); - this.find('.htmleditorfield-mediaform-heading.update')[updateExisting ? 'show' : 'hide'](); - this.find('.Actions .media-update')[updateExisting ? 'show' : 'hide'](); + // TODO Way too much knowledge on UploadField internals, use viewfile URL directly instead + this.find('.htmleditorfield-mediaform-heading.insert')[editingSelected ? 'hide' : 'show'](); + this.find('.ss-uploadfield-item-actions')[editingSelected ? 'hide' : 'show'](); + this.find('.ss-uploadfield-item-name')[editingSelected ? 'hide' : 'show'](); + this.find('.ss-uploadfield-item-preview')[editingSelected ? 'hide' : 'show'](); + this.find('.Actions .media-insert')[editingSelected ? 'hide' : 'show'](); + this.find('.htmleditorfield-mediaform-heading.update')[editingSelected ? 'show' : 'hide'](); + this.find('.Actions .media-update')[editingSelected ? 'show' : 'hide'](); + this.find('.ss-uploadfield-item-editform').toggleEditForm(editingSelected); }, resetFields: function() { this.find('.ss-htmleditorfield-file').remove(); // Remove any existing views @@ -866,7 +870,7 @@ ss.editorWrappers['default'] = ss.editorWrappers.tinyMCE; var self = this, params = (Number(idOrUrl) == idOrUrl) ? {ID: idOrUrl} : {FileURL: idOrUrl}; var item = $('
'); - this.find('.content-edit').append(item); + this.find('.content-edit').prepend(item); var dfr = $.Deferred(); @@ -1302,11 +1306,11 @@ ss.editorWrappers['default'] = ss.editorWrappers.tinyMCE; }); $('div.ss-assetuploadfield .ss-uploadfield-item-editform').entwine({ - toggleEditForm: function() { + toggleEditForm: function(bool) { var itemInfo = this.prev('.ss-uploadfield-item-info'), status = itemInfo.find('.ss-uploadfield-item-status'); var text=""; - if(this.height() === 0) { + if(bool === true || (bool !== false && this.height() === 0)) { text = ss.i18n._t('UploadField.Editing', "Editing ..."); this.height('auto'); itemInfo.find('.toggle-details-icon').addClass('opened'); diff --git a/scss/AssetUploadField.scss b/scss/AssetUploadField.scss index 1452b1c31..4234c7517 100644 --- a/scss/AssetUploadField.scss +++ b/scss/AssetUploadField.scss @@ -141,7 +141,6 @@ body.cms.ss-uploadfield-edit-iframe, .composite.ss-assetuploadfield .details fie .ss-uploadfield-item-info { position: relative; line-height: 30px; - font-size: 14px; overflow: hidden; background-color: #5db4df; @include background-image(linear-gradient(top, #5db4df 0%,#5db1dd 8%,#439bcb 50%,#3f99cd 54%,#207db6 96%,#1e7cba 100%)); diff --git a/scss/GridField.scss b/scss/GridField.scss index 88805b659..af80c8b8d 100644 --- a/scss/GridField.scss +++ b/scss/GridField.scss @@ -127,7 +127,6 @@ $gf_grid_x: 16px; border-collapse: separate; border-bottom: 0 none; width: 100%; - margin-bottom:$gf_grid_y; thead { color: darken($color-base, 50%); @@ -583,6 +582,7 @@ $gf_grid_x: 16px; margin-left:-116px; //half the width of .datagrid-pagination - centers pagination .pagination-page-number { color:$color-text-light; + text-align: center; @include single-text-shadow($gf_colour_text_shadow, 0px, -1px, 0); input { width:35px; //exact width so that a four digit number can be entered @@ -641,4 +641,8 @@ $gf_grid_x: 16px; border-right: 1px solid $gf_colour_border; } } + + .grid-bottom-button { + margin-top:$gf_grid_y; + } } diff --git a/scss/TreeDropdownField.scss b/scss/TreeDropdownField.scss index 05605f61f..576854a06 100755 --- a/scss/TreeDropdownField.scss +++ b/scss/TreeDropdownField.scss @@ -62,20 +62,7 @@ div.TreeDropdownField { -webkit-border-radius: 0 4px 4px 0; -moz-border-radius: 0 4px 4px 0; border-radius: 0 4px 4px 0; - -moz-background-clip : padding; - -webkit-background-clip: padding-box; - background-clip: padding-box; - background: #ccc; - background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #ccc), color-stop(0.6, #eee)); - background-image: -webkit-linear-gradient(center bottom, #ccc 0%, #eee 60%); - background-image: -moz-linear-gradient(center bottom, #ccc 0%, #eee 60%); - background-image: -o-linear-gradient(bottom, #ccc 0%, #eee 60%); - background-image: -ms-linear-gradient(top, #cccccc 0%,#eeeeee 60%); - filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#cccccc', endColorstr='#eeeeee',GradientType=0 ); - background-image: linear-gradient(top, #cccccc 0%,#eeeeee 60%); - border-left: 1px solid #aaa; - &.treedropdownfield-open-tree { background: transparent; border: none; diff --git a/scss/UploadField.scss b/scss/UploadField.scss index 08c5ad5c8..a56a994fb 100644 --- a/scss/UploadField.scss +++ b/scss/UploadField.scss @@ -10,20 +10,6 @@ clear: both; } - .ss-insert-media &{ - margin-top:20px; - - h4{ - float:left; - } - - // Stop nolabel from resetting margin on tree dropdown - &.from-CMS .nolabel.treedropdown .middleColumn{ - margin-left:184px; - } - - } - .middleColumn { // TODO .middleColumn styling should probably be theme specific (eg cms ui will look different than blackcandy) // so we should move this style into the cms and black candy files @@ -104,7 +90,7 @@ display: block; float: left; margin: 0 10px 6px 0; - + &.ss-uploadfield-fromcomputer { position: relative; overflow: hidden;