From 703b6facdffe2738a674f9793fe08391a072e6cd Mon Sep 17 00:00:00 2001 From: Jasmin Savard Date: Fri, 12 Apr 2024 02:24:49 -0400 Subject: [PATCH] Fix shortcode button with easy mde editor --- .../Assets/scss/shortcodes.scss | 17 +++---- .../wwwroot/Icons/shortcode-dark.svg | 50 +++++++++++++++++++ .../wwwroot/Icons/shortcode-light.svg | 50 +++++++++++++++++++ .../wwwroot/Styles/shortcodes.css | 14 ++---- .../wwwroot/Styles/shortcodes.min.css | 2 +- 5 files changed, 114 insertions(+), 19 deletions(-) create mode 100644 src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Icons/shortcode-dark.svg create mode 100644 src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Icons/shortcode-light.svg diff --git a/src/OrchardCore.Modules/OrchardCore.Shortcodes/Assets/scss/shortcodes.scss b/src/OrchardCore.Modules/OrchardCore.Shortcodes/Assets/scss/shortcodes.scss index 2fc86183052..83646c336d2 100644 --- a/src/OrchardCore.Modules/OrchardCore.Shortcodes/Assets/scss/shortcodes.scss +++ b/src/OrchardCore.Modules/OrchardCore.Shortcodes/Assets/scss/shortcodes.scss @@ -1,7 +1,7 @@ - @import "../../node_modules/bootstrap/scss/functions"; @import "../../node_modules/bootstrap/scss/variables"; @import "../../node_modules/bootstrap/scss/mixins/breakpoints"; +@import '../../node_modules/bootstrap/scss/mixins/_color-mode'; .shortcode-modal-btn { position: absolute; @@ -31,13 +31,12 @@ max-width: 310px; } -$icon-shortcode-bg: url("data:image/svg+xml,") !default; +.icon-shortcode::after { + content: escape-svg(url(../Icons/shortcode-light.svg)); +} -.icon-shortcode { - display: inline-block; - width: 20px; - height: 20px; - background: no-repeat 50% / 100% 100% !important; - color: var(--bs-body-color, #808080) !important; - background-image: escape-svg($icon-shortcode-bg) !important; +@include color-mode(dark){ + .icon-shortcode::after { + content: escape-svg(url(../Icons/shortcode-dark.svg)); + } } diff --git a/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Icons/shortcode-dark.svg b/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Icons/shortcode-dark.svg new file mode 100644 index 00000000000..43564a99708 --- /dev/null +++ b/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Icons/shortcode-dark.svg @@ -0,0 +1,50 @@ + + + + + + + + + + + diff --git a/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Icons/shortcode-light.svg b/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Icons/shortcode-light.svg new file mode 100644 index 00000000000..464a6fd1f6d --- /dev/null +++ b/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Icons/shortcode-light.svg @@ -0,0 +1,50 @@ + + + + + + + + + + + diff --git a/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Styles/shortcodes.css b/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Styles/shortcodes.css index 74e907e9359..54d842099c5 100644 --- a/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Styles/shortcodes.css +++ b/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Styles/shortcodes.css @@ -24,15 +24,11 @@ max-width: 310px; } -.icon-shortcode { - display: inline-block; - width: 20px; - height: 20px; - color: var(--bs-body-color, #808080) !important; +.icon-shortcode::after { + content: url(../Icons/shortcode-light.svg); } -[dir] .icon-shortcode { - background: no-repeat 50%/100% 100% !important; - background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3cpath d='M16 4.2v1.5h2.5v12.5H16v1.5h4V4.2h-4zM4.2 19.8h4v-1.5H5.8V5.8h2.5V4.2h-4l-.1 15.6zm5.1-3.1l1.4.6 4-10-1.4-.6-4 10z'%3e%3c/path%3e%3c/svg%3e") !important; +[data-bs-theme=dark] .icon-shortcode::after { + content: url(../Icons/shortcode-dark.svg); } -/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["shortcodes.scss","shortcodes.css","../../node_modules/bootstrap/scss/mixins/_breakpoints.scss"],"names":[],"mappings":"AAKA;EACI,kBAAA;EACA,MAAA;EAOA,YAAA;ACTJ,CDAA;EAGI,QAAA;ACHJ,CDAA;EAGI,OAAA;ACHJ;ADKI;EACI,WAAA;ACHR;;ADSA;EACI,kBAAA;ACNJ;;ACmDI;EFxCI;IACI,iBAAA;ECPV;AACF;ADWA;EACI,gBAAA;ACTJ;;ADcA;EACI,qBAAA;EACA,WAAA;EACA,YAAA;EAEA,+CAAA;ACVJ;;ADKA;EAII,8CAAA;EAEA,6QAAA;ACXJ","file":"shortcodes.css","sourcesContent":["\r\n@import \"../../node_modules/bootstrap/scss/functions\";\r\n@import \"../../node_modules/bootstrap/scss/variables\";\r\n@import \"../../node_modules/bootstrap/scss/mixins/breakpoints\";\r\n\r\n.shortcode-modal-btn {\r\n    position: absolute;\r\n    top: 0;\r\n    right: 0;\r\n\r\n    svg {\r\n        width: 24px;\r\n    }\r\n\r\n    z-index: 500;\r\n}\r\n\r\n.shortcode-modal-wrapper {\r\n    position: relative;\r\n}\r\n\r\n@include media-breakpoint-up(lg) {\r\n    .modal-shortcodes {\r\n        .modal-lg {\r\n            max-width: 1200px;\r\n        }\r\n    }\r\n}\r\n\r\n#shortcodePreview {\r\n    max-width: 310px;\r\n}\r\n\r\n$icon-shortcode-bg: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M16 4.2v1.5h2.5v12.5H16v1.5h4V4.2h-4zM4.2 19.8h4v-1.5H5.8V5.8h2.5V4.2h-4l-.1 15.6zm5.1-3.1l1.4.6 4-10-1.4-.6-4 10z'></path></svg>\") !default;\r\n\r\n.icon-shortcode {\r\n    display: inline-block;\r\n    width: 20px;\r\n    height: 20px;\r\n    background: no-repeat 50% / 100% 100% !important;\r\n    color: var(--bs-body-color, #808080) !important;\r\n    background-image: escape-svg($icon-shortcode-bg) !important;\r\n}\r\n",".shortcode-modal-btn {\n  position: absolute;\n  top: 0;\n  right: 0;\n  z-index: 500;\n}\n.shortcode-modal-btn svg {\n  width: 24px;\n}\n\n.shortcode-modal-wrapper {\n  position: relative;\n}\n\n@media (min-width: 992px) {\n  .modal-shortcodes .modal-lg {\n    max-width: 1200px;\n  }\n}\n#shortcodePreview {\n  max-width: 310px;\n}\n\n.icon-shortcode {\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  background: no-repeat 50%/100% 100% !important;\n  color: var(--bs-body-color, #808080) !important;\n  background-image: url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3cpath d='M16 4.2v1.5h2.5v12.5H16v1.5h4V4.2h-4zM4.2 19.8h4v-1.5H5.8V5.8h2.5V4.2h-4l-.1 15.6zm5.1-3.1l1.4.6 4-10-1.4-.6-4 10z'%3e%3c/path%3e%3c/svg%3e\") !important;\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl xxl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @if not $n {\n    @error \"breakpoint `#{$name}` not found in `#{$breakpoints}`\";\n  }\n  @return if($n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width.\n// The maximum value is reduced by 0.02px to work around the limitations of\n// `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(md, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $max: map-get($breakpoints, $name);\n  @return if($max and $max > 0, $max - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min:  breakpoint-min($name, $breakpoints);\n  $next: breakpoint-next($name, $breakpoints);\n  $max:  breakpoint-max($next, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($next, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */ +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["shortcodes.scss","shortcodes.css","../../node_modules/bootstrap/scss/mixins/_breakpoints.scss"],"names":[],"mappings":"AAKA;EACI,kBAAA;EACA,MAAA;EAOA,YAAA;ACTJ,CDAA;EAGI,QAAA;ACHJ,CDAA;EAGI,OAAA;ACHJ;ADKI;EACI,WAAA;ACHR;;ADSA;EACI,kBAAA;ACNJ;;ACmDI;EFxCI;IACI,iBAAA;ECPV;AACF;ADWA;EACI,gBAAA;ACTJ;;ADYA;EACI,0CAAA;ACTJ;;ADaI;EACI,yCAAA;ACVR","file":"shortcodes.css","sourcesContent":["@import \"../../node_modules/bootstrap/scss/functions\";\r\n@import \"../../node_modules/bootstrap/scss/variables\";\r\n@import \"../../node_modules/bootstrap/scss/mixins/breakpoints\";\r\n@import '../../node_modules/bootstrap/scss/mixins/_color-mode';\r\n\r\n.shortcode-modal-btn {\r\n    position: absolute;\r\n    top: 0;\r\n    right: 0;\r\n\r\n    svg {\r\n        width: 24px;\r\n    }\r\n\r\n    z-index: 500;\r\n}\r\n\r\n.shortcode-modal-wrapper {\r\n    position: relative;\r\n}\r\n\r\n@include media-breakpoint-up(lg) {\r\n    .modal-shortcodes {\r\n        .modal-lg {\r\n            max-width: 1200px;\r\n        }\r\n    }\r\n}\r\n\r\n#shortcodePreview {\r\n    max-width: 310px;\r\n}\r\n\r\n.icon-shortcode::after {\r\n    content: escape-svg(url(../Icons/shortcode-light.svg));\r\n}\r\n\r\n@include color-mode(dark){\r\n    .icon-shortcode::after {\r\n        content: escape-svg(url(../Icons/shortcode-dark.svg));\r\n    }\r\n}\r\n",".shortcode-modal-btn {\n  position: absolute;\n  top: 0;\n  right: 0;\n  z-index: 500;\n}\n.shortcode-modal-btn svg {\n  width: 24px;\n}\n\n.shortcode-modal-wrapper {\n  position: relative;\n}\n\n@media (min-width: 992px) {\n  .modal-shortcodes .modal-lg {\n    max-width: 1200px;\n  }\n}\n#shortcodePreview {\n  max-width: 310px;\n}\n\n.icon-shortcode::after {\n  content: url(../Icons/shortcode-light.svg);\n}\n\n[data-bs-theme=dark] .icon-shortcode::after {\n  content: url(../Icons/shortcode-dark.svg);\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl xxl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @if not $n {\n    @error \"breakpoint `#{$name}` not found in `#{$breakpoints}`\";\n  }\n  @return if($n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width.\n// The maximum value is reduced by 0.02px to work around the limitations of\n// `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(md, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $max: map-get($breakpoints, $name);\n  @return if($max and $max > 0, $max - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min:  breakpoint-min($name, $breakpoints);\n  $next: breakpoint-next($name, $breakpoints);\n  $max:  breakpoint-max($next, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($next, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */ diff --git a/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Styles/shortcodes.min.css b/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Styles/shortcodes.min.css index fdae871dc69..b2f9e2364a9 100644 --- a/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Styles/shortcodes.min.css +++ b/src/OrchardCore.Modules/OrchardCore.Shortcodes/wwwroot/Styles/shortcodes.min.css @@ -1 +1 @@ -.shortcode-modal-btn{position:absolute;top:0;z-index:500}[dir=ltr] .shortcode-modal-btn{right:0}[dir=rtl] .shortcode-modal-btn{left:0}.shortcode-modal-btn svg{width:24px}.shortcode-modal-wrapper{position:relative}@media (min-width:992px){.modal-shortcodes .modal-lg{max-width:1200px}}#shortcodePreview{max-width:310px}.icon-shortcode{display:inline-block;width:20px;height:20px;color:var(--bs-body-color,grey)!important}[dir] .icon-shortcode{background:no-repeat 50%/100% 100%!important;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3cpath d='M16 4.2v1.5h2.5v12.5H16v1.5h4V4.2h-4zM4.2 19.8h4v-1.5H5.8V5.8h2.5V4.2h-4l-.1 15.6zm5.1-3.1l1.4.6 4-10-1.4-.6-4 10z'%3e%3c/path%3e%3c/svg%3e")!important} +.shortcode-modal-btn{position:absolute;top:0;z-index:500}[dir=ltr] .shortcode-modal-btn{right:0}[dir=rtl] .shortcode-modal-btn{left:0}.shortcode-modal-btn svg{width:24px}.shortcode-modal-wrapper{position:relative}@media (min-width:992px){.modal-shortcodes .modal-lg{max-width:1200px}}#shortcodePreview{max-width:310px}.icon-shortcode::after{content:url(../Icons/shortcode-light.svg)}[data-bs-theme=dark] .icon-shortcode::after{content:url(../Icons/shortcode-dark.svg)}