diff --git a/DNN Platform/Website/Providers/DataProviders/SqlDataProvider/09.09.02.SqlDataProvider b/DNN Platform/Website/Providers/DataProviders/SqlDataProvider/09.09.02.SqlDataProvider new file mode 100644 index 00000000000..33a259d05fa --- /dev/null +++ b/DNN Platform/Website/Providers/DataProviders/SqlDataProvider/09.09.02.SqlDataProvider @@ -0,0 +1,9 @@ +/************************************************************/ +/***** SqlDataProvider *****/ +/***** *****/ +/***** *****/ +/***** Note: To manually execute this script you must *****/ +/***** perform a search and replace operation *****/ +/***** for {databaseOwner} and {objectQualifier} *****/ +/***** *****/ +/************************************************************/ diff --git a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/Controllers/EditBarController.cs b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/Controllers/EditBarController.cs index a3bfb717b42..89a47a96915 100644 --- a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/Controllers/EditBarController.cs +++ b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/Controllers/EditBarController.cs @@ -6,13 +6,14 @@ namespace Dnn.EditBar.UI.Controllers { using System; using System.Collections.Generic; - using System.Globalization; + using System.Globalization; + using System.IO; using System.Linq; using System.Text; using System.Threading; using System.Threading.Tasks; - using System.Web; - + using System.Web; + using System.Web.Hosting; using Dnn.EditBar.Library; using Dnn.EditBar.Library.Items; using DotNetNuke.Application; @@ -46,7 +47,11 @@ public IDictionary GetConfigurations(int portalId) settings.Add("portalId", portalSettings.PortalId); settings.Add("culture", portalSettings.CultureCode); settings.Add("loginUrl", Globals.LoginURL(HttpContext.Current?.Request.RawUrl, false)); - settings.Add("items", this.GetMenuItems()); + settings.Add("items", this.GetMenuItems()); + + var customEditBarThemePath = HostingEnvironment.MapPath("~/Portals/_default/EditBarTheme.css"); + var customEditBarThemeExists = File.Exists(customEditBarThemePath); + settings.Add("editBarTheme", customEditBarThemeExists); return settings; } diff --git a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/Dnn.EditBar.UI.csproj b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/Dnn.EditBar.UI.csproj index dbddb349528..f6dc7184bef 100644 --- a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/Dnn.EditBar.UI.csproj +++ b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/Dnn.EditBar.UI.csproj @@ -119,6 +119,7 @@ + diff --git a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/css/main.css b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/css/main.css index 09dfbec2b8e..9c58cb202bc 100644 --- a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/css/main.css +++ b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/css/main.css @@ -27,7 +27,7 @@ body { visibility: visible; height: 80px; display: block; - background-color: #2f2f2f; + background-color: var(--dnn-color-editbar-background); color: white; min-height: 20px; padding: 26px 26px 0; @@ -99,9 +99,7 @@ body { .editbar .left-section { margin-left: 20px; } -.editbar .left-section ul { - -} + .editbar .left-section ul li { margin-left: 7px; } diff --git a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/css/theme.css b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/css/theme.css new file mode 100644 index 00000000000..3a98896d45b --- /dev/null +++ b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/css/theme.css @@ -0,0 +1,9 @@ +/*-------------------------------------------------------------------------------- +These default CSS variables can be overridden and customized by creating a file, +containing a copy of the below, called "EditBarTheme.css" and placing it in the +"Portals/_default" directory. If the custom CSS file exists, it will be loaded +instead of this one. +---------------------------------------------------------------------------------*/ +:root{ + --dnn-color-editbar-background: #0b1c24; +} \ No newline at end of file diff --git a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/scripts/bootstrap.js b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/scripts/bootstrap.js index 8ee69cceeb7..dc1abda6687 100644 --- a/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/scripts/bootstrap.js +++ b/Dnn.AdminExperience/EditBar/Dnn.EditBar.UI/editBar/scripts/bootstrap.js @@ -21,13 +21,23 @@ body.appendChild(script); }; - var debugMode = window.parent['editBarSettings']['debugMode'] === true; - var cdv = window.parent['editBarSettings']['buildNumber']; + var editBarSettings = window.parent['editBarSettings']; + var debugMode = editBarSettings['debugMode'] === true; + var cdv = editBarSettings['buildNumber']; var version = (cdv ? '?cdv=' + cdv : '') + (debugMode ? '&t=' + Math.random(): ''); var styles = []; var mainJs = mobi ? 'scripts/main.mobi.js' : 'scripts/main.js'; + var themeCss = 'css/theme.css'; var mainCss = mobi ? 'css/main.mobi.css' : 'css/main.css'; + var hasCustomEditBarTheme = editBarSettings['editBarTheme']; + if (hasCustomEditBarTheme){ + styles.push('../../../../Portals/_default/EditBarTheme.css'); + } + else{ + styles.push(themeCss); + } + styles.push(mainCss); addCssToHead(styles, version); diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.Library/Containers/PersonaBarContainer.cs b/Dnn.AdminExperience/Library/Dnn.PersonaBar.Library/Containers/PersonaBarContainer.cs index 8af46ea7709..05977671b4f 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.Library/Containers/PersonaBarContainer.cs +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.Library/Containers/PersonaBarContainer.cs @@ -6,8 +6,10 @@ namespace Dnn.PersonaBar.Library.Containers { using System.Collections.Generic; using System.Globalization; + using System.IO; using System.Threading; using System.Web; + using System.Web.Hosting; using System.Web.UI; using Dnn.PersonaBar.Library.Common; @@ -18,7 +20,6 @@ namespace Dnn.PersonaBar.Library.Containers using DotNetNuke.Application; using DotNetNuke.Entities.Host; using DotNetNuke.Entities.Portals; - using DotNetNuke.Entities.Users; using DotNetNuke.Services.Personalization; using Microsoft.Extensions.DependencyInjection; using Newtonsoft.Json.Linq; @@ -120,6 +121,10 @@ private IDictionary GetConfigration(PortalSettings portalSetting settings.Add("disableEditBar", Host.DisableEditBar); + var customPersonaBarThemePath = HostingEnvironment.MapPath("~/Portals/_default/PersonaBarTheme.css"); + var customPersonaBarThemeExists = File.Exists(customPersonaBarThemePath); + settings.Add("personaBarTheme", customPersonaBarThemeExists); + return settings; } } diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/Dnn.PersonaBar.UI.csproj b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/Dnn.PersonaBar.UI.csproj index ce53846bacd..6a53dbddb3c 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/Dnn.PersonaBar.UI.csproj +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/Dnn.PersonaBar.UI.csproj @@ -140,6 +140,7 @@ Designer + Designer diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/main.css b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/main.css index df0d092d839..dd78ff01b3f 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/main.css +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/main.css @@ -716,23 +716,25 @@ transform: rotate(180deg); /* persona bar Menu*/ .personabar { width: 80px; - background-color: #3d3c3c; + background-color: var(--dnn-color-pb-menu-background); height: 100%; position: fixed; top: 0; left: -100px; - z-index: 1000;display: none; + z-index: 1000; + display: none; } .personabar .personabarLogo { width: 80px; height: 103px; - background: #515050 url('../images/Logo.svg') no-repeat center center; + background: var(--dnn-pb-menu-brand-background); -ms-background-size: 32px auto; background-size: 32px auto; position: relative; + border-bottom: 1px solid var(--dnn-color-pb-menu-divider); } .personabar .personabarLogo:hover { - background-color: #2f2f2f; + background-color: var(--dnn-color-pb-menu-background-hover); } .personabar .personabarLogo a.update { text-decoration: none; @@ -757,13 +759,12 @@ transform: rotate(180deg); .personabarnav { margin: 0; padding: 0; - border-bottom: 1px solid #373737; } .personabarnav > li { list-style-type: none; margin: 0; - padding: 28px; + padding: 17px 16px; cursor: pointer; text-align: center; background-repeat: repeat-x; @@ -771,7 +772,6 @@ transform: rotate(180deg); color: #737171; font-weight: 600; position: relative; - border-top: 1px solid #373737; height: 80px; transition: background-color 200ms linear, color 200ms linear; -webkit-box-sizing: border-box; @@ -784,10 +784,10 @@ transform: rotate(180deg); } .personabarnav > li > span.icon-loader { display: inline-block; - width: 24px; - height: 24px; + width: 38px; + height: 38px; margin: 0; - padding: 0; + padding: 5px; vertical-align: top; } .personabarnav > li > span.icon-loader img { @@ -798,6 +798,12 @@ transform: rotate(180deg); .personabarnav > li > span.icon-loader svg { fill: #868484; } +.personabarnav > li > span.icon-loader svg .back { + fill: var(--dnn-color-pb-menu-icon-background); +} +.personabarnav>li>span.icon-loader svg .main { + fill: var(--dnn-color-pb-menu-icon); +} .personabarnav > li:hover > span.icon-loader svg, .personabarnav > li.active > span.icon-loader svg, .personabarnav > li.selected > span.icon-loader svg { @@ -816,13 +822,17 @@ transform: rotate(180deg); } .personabarnav > li:hover,.personabarnav > li.active { color: #fff; - background-color: #2f2f2f; + background-color: var(--dnn-color-pb-menu-background-hover); border-right: none !important; } .personabarnav > li.pending { border-right: 3px solid #9FDBF0; } +.personabarnav > li#Edit { + border-top: 1px solid var(--dnn-color-pb-menu-divider); +} + .personabarnav > li#Edit.selected { color: #737171; background-color: transparent; @@ -911,7 +921,7 @@ transform: rotate(180deg); position: absolute; left: 80px; padding: 0 0px 42px 37px; - background-color: #2f2f2f; + background-color: var(--dnn-color-pb-menu-background-hover); display: none; /* display: none; IE not apply list-style-type: none; with this active it will be applied in js @@ -1241,10 +1251,6 @@ only screen and (min-width: 768px) and (max-width: 1024px) { margin-top: 103px; } -.ie .socialpanelbody { - /*margin-top: 0;*/ -} - .socialpanelbody > div { padding: 20px 30px 30px 30px; } @@ -1902,7 +1908,7 @@ div.ui-dialog-titlebar > .ui-dialog-titlebar-close:hover { .hoverSummaryMenu { position: absolute; width: 200px; - background-color: #2f2f2f; + background-color: var(--dnn-color-pb-menu-background-hover); padding: 27px 37px 42px 37px; left: 80px; top: 0; @@ -1949,9 +1955,9 @@ div.ui-dialog-titlebar > .ui-dialog-titlebar-close:hover { } .hoverSummaryMenu ul li label { font-size: 12px; - color: #868484; - padding: 2px 0 13px 0; - border-bottom: 1px solid #868484; + color: var(--dnn-color-pb-menu-text-highlight); + padding: 11px 0 18px 0; + border-bottom: 1px solid var(--dnn-color-pb-menu-divider); text-transform: uppercase; -moz-word-break: break-all; -o-word-break: break-all; diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/personaBarContainer.css b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/personaBarContainer.css index 32583327aa7..94c5ef48490 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/personaBarContainer.css +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/personaBarContainer.css @@ -28,7 +28,7 @@ iframe#personaBar-iframe{ .personabar-placeholder { width: 80px; - background-color: #3d3c3c; + background-color: #0e2936; height: 100%; position: fixed; top: 0; diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/theme.css b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/theme.css new file mode 100644 index 00000000000..08266cee1db --- /dev/null +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/css/theme.css @@ -0,0 +1,16 @@ +/*-------------------------------------------------------------------------------- +These default CSS variables can be overridden and customized by creating a file, +containing a copy of the below, called "PersonaBarTheme.css" and placing it in +the "Portals/_default" directory. If the custom CSS file exists, it will be loaded +instead of this one. +---------------------------------------------------------------------------------*/ +:root{ + --dnn-color-pb-menu-background: #0e2936; + --dnn-color-pb-menu-background-hover: #0b1c24; + --dnn-color-pb-menu-icon: #3c7a9a; + --dnn-color-pb-menu-icon-background: #0b1c24; + --dnn-color-pb-menu-divider: #1e485e; + --dnn-color-pb-menu-text-highlight: #3c7a9a; + + --dnn-pb-menu-brand-background: url('../images/Logo.svg') no-repeat center center; +} \ No newline at end of file diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_content.svg b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_content.svg index 5077eedb2a0..c9fd064f148 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_content.svg +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_content.svg @@ -1,11 +1,12 @@ - - - - - - - - + + + + + + + + + \ No newline at end of file diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_edit.svg b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_edit.svg index 1d060d67f31..db038a7645a 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_edit.svg +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_edit.svg @@ -1,7 +1,8 @@ - - - - + + + + + diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_manage.svg b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_manage.svg index 797682e5151..c2f53fea850 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_manage.svg +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_manage.svg @@ -1,12 +1,14 @@ - - - - - + + + + + + diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_settings.svg b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_settings.svg index 314c7a2d697..b39e2afe402 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_settings.svg +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/images/nav_settings.svg @@ -1,8 +1,9 @@ - + + diff --git a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/scripts/bootstrap.js b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/scripts/bootstrap.js index c857ec1e3b0..73bfc669bf7 100644 --- a/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/scripts/bootstrap.js +++ b/Dnn.AdminExperience/Library/Dnn.PersonaBar.UI/admin/personaBar/scripts/bootstrap.js @@ -21,13 +21,18 @@ var personaBarSettings = window.parent['personaBarSettings']; var debugMode = personaBarSettings['debugMode'] === true; var cdv = personaBarSettings['buildNumber']; - var skin = personaBarSettings['skin']; var version = (cdv ? '?cdv=' + cdv : '') + (debugMode ? '&t=' + Math.random(): ''); var styles = []; var mainJs = 'scripts/main.js'; + var themeCss = 'css/theme.css'; var mainCss = 'css/main.css'; - if (skin) { - mainCss = 'css/' + skin + '.css'; + + var hasCustomPersonaBarTheme = personaBarSettings['personaBarTheme']; + if (hasCustomPersonaBarTheme){ + styles.push('../../../../Portals/_default/PersonaBarTheme.css'); + } + else{ + styles.push(themeCss); } styles.push(mainCss);