diff --git a/Gruntfile.js b/Gruntfile.js index b91a06770f..ce0e905909 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -40,28 +40,14 @@ module.exports = function (grunt) { pixelegg: { files: { "pixelegg/css/pixelegg.min.css": [ - "node_modules/flatpickr/dist/themes/light.css", - "api/js/egw_action/test/skins/dhtmlxmenu_egw.css", - "vendor/bower-asset/diff2html/dist/diff2html.css", - "vendor/bower-asset/cropper/dist/cropper.min.css", - "api/templates/default/css/flags.css", - "api/templates/default/css/htmlarea.css", - "api/templates/default/etemplate2.css", - "pixelegg/css/pixelegg.css", - "api/templates/default/print.css", - "pixelegg/print.css" + "node_modules/@shoelace-style/shoelace/dist/themes/light.css", + "node_modules/@shoelace-style/shoelace/dist/themes/dark.css", + "pixelegg/css/pixelegg.min.css" ], "pixelegg/css/mobile.min.css": [ - "node_modules/flatpickr/dist/themes/light.css", - "api/js/egw_action/test/skins/dhtmlxmenu_egw.css", - "vendor/bower-asset/diff2html/dist/diff2html.css", - "vendor/bower-asset/cropper/dist/cropper.min.css", - "api/templates/default/css/flags.css", - "api/templates/default/css/htmlarea.css", - "api/templates/default/etemplate2.css", - "pixelegg/css/mobile.css", - "api/templates/default/print.css", - "pixelegg/print.css" + "node_modules/@shoelace-style/shoelace/dist/themes/light.css", + "node_modules/@shoelace-style/shoelace/dist/themes/dark.css", + "pixelegg/css/mobile.min.css" ], "pixelegg/mobile/fw_mobile.min.css": [ "node_modules/flatpickr/dist/themes/light.css", @@ -76,28 +62,44 @@ module.exports = function (grunt) { "pixelegg/print.css" ], "pixelegg/css/monochrome.min.css": [ - "node_modules/flatpickr/dist/themes/light.css", - "api/js/egw_action/test/skins/dhtmlxmenu_egw.css", - "vendor/bower-asset/diff2html/dist/diff2html.css", - "vendor/bower-asset/cropper/dist/cropper.min.css", - "api/templates/default/css/flags.css", - "api/templates/default/css/htmlarea.css", - "api/templates/default/etemplate2.css", - "pixelegg/css/monochrome.css", - "api/templates/default/print.css", - "pixelegg/print.css" + "node_modules/@shoelace-style/shoelace/dist/themes/light.css", + "node_modules/@shoelace-style/shoelace/dist/themes/dark.css", + "pixelegg/css/monochrome.min.css" ], "pixelegg/css/modern.min.css": [ + "node_modules/@shoelace-style/shoelace/dist/themes/light.css", + "node_modules/@shoelace-style/shoelace/dist/themes/dark.css", + "pixelegg/css/pixelegg.min.css" + ], + "pixelegg/css/0.min.css": [ + "node_modules/@shoelace-style/shoelace/dist/themes/light.css", + "node_modules/@shoelace-style/shoelace/dist/themes/dark.css", + "pixelegg/css/pixelegg.min.css" + ], + "pixelegg/css/1.min.css": [ + "node_modules/@shoelace-style/shoelace/dist/themes/light.css", + "node_modules/@shoelace-style/shoelace/dist/themes/dark.css", + "pixelegg/css/pixelegg.min.css" + ], + "pixelegg/css/2.min.css": [ + "node_modules/@shoelace-style/shoelace/dist/themes/light.css", + "node_modules/@shoelace-style/shoelace/dist/themes/dark.css", + "pixelegg/css/pixelegg.min.css" + ], + "pixelegg/css/3.min.css": [ + "node_modules/@shoelace-style/shoelace/dist/themes/light.css", + "node_modules/@shoelace-style/shoelace/dist/themes/dark.css", + "pixelegg/css/pixelegg.min.css" + ] + } + }, + kdots: { + files: { + "kdots/css/kdots.min.css": [ "node_modules/flatpickr/dist/themes/light.css", - "api/js/egw_action/test/skins/dhtmlxmenu_egw.css", - "vendor/bower-asset/diff2html/dist/diff2html.css", - "vendor/bower-asset/cropper/dist/cropper.min.css", - "api/templates/default/css/flags.css", - "api/templates/default/css/htmlarea.css", "api/templates/default/etemplate2.css", - "pixelegg/css/pixelegg.css", - "api/templates/default/print.css", - "pixelegg/print.css" + "kdots/css/kdots.css", + "api/templates/default/print.css" ] } } @@ -108,7 +110,8 @@ module.exports = function (grunt) { "*/Gruntfile.js" ] } - } + }, + terser: null }); // Load plugin for css minification grunt.loadNpmTasks("grunt-contrib-cssmin"); diff --git a/kdots/assets/styles/framework_dark.less b/kdots/assets/styles/framework_dark.less deleted file mode 100644 index d4dc031707..0000000000 --- a/kdots/assets/styles/framework_dark.less +++ /dev/null @@ -1,35 +0,0 @@ -html[data-darkmode="1"] body { - background-color: black; - color: var(--sl-color-neutral-700); - - /*** HEADER ***/ - #egw_fw_topmenu_info_items { - #topmenu_info_timer:before { - filter:initial; - } - } - - /*** APPLICATION ***/ - - egw-app { - --application-header-text-color: var(--sl-color-neutral-700); - } - - /*** End APPLICATION ***/ - - /*** WIDGETS ***/ - /* This should mostly go away with webcomponents */ - - .et2_container { - background-color: initial; - } - - .dialogFooterToolbar et2-button::part(base):not(:hover), et2-dialog et2-button[variant='default'][slot='footer']::part(base):not(:hover) { - background-color: var(--sl-input-background-color); - } - .nextmatch_sortheader { - color: #96bcd9; - } - - /** End WIDGETS **/ -} \ No newline at end of file diff --git a/kdots/assets/styles/framework.css b/kdots/css/kdots.css similarity index 80% rename from kdots/assets/styles/framework.css rename to kdots/css/kdots.css index 20bb933f11..862ab00d10 100644 --- a/kdots/assets/styles/framework.css +++ b/kdots/css/kdots.css @@ -1,12 +1,44 @@ /** * kDots main styles * - * Note that light / dark colors should go in framework_light.less & framework_dark.less + * Note that light / dark colors should go in kdots_light.less & kdots_dark.less */ /** Theme customisations **/ -html[data-darkmode="1"] body { +:root, +:host, +html, +.sl-theme-light { + /* + color token generator using #0053c9 + https://codepen.io/claviska/full/QWveRgL + */ + --sl-color-primary-50: #f7fafd; + --sl-color-primary-100: #e4edf9; + --sl-color-primary-200: #d0dff5; + --sl-color-primary-300: #bad0f0; + --sl-color-primary-400: #9cbcea; + --sl-color-primary-500: #75a2e2; + --sl-color-primary-600: #4984d8; + --sl-color-primary-700: #2169d0; + --sl-color-primary-800: #0051c5; + --sl-color-primary-900: #003a8d; + --sl-color-primary-950: #002458; +} +html[data-darkmode="1"], +.sl-theme-dark { background-color: black; color: var(--sl-color-neutral-700); + --sl-color-primary-950: hsl(from var(--primary-color) h s calc(l + 18)); + --sl-color-primary-900: hsl(from var(--primary-color) h s calc(l + 16)); + --sl-color-primary-800: hsl(from var(--primary-color) h s calc(l + 12)); + --sl-color-primary-700: hsl(from var(--primary-color) h s calc(l + 8)); + --sl-color-primary-600: hsl(from var(--primary-color) h s calc(l + 4)); + --sl-color-primary-500: var(--primary-color); + --sl-color-primary-400: hsl(from var(--primary-color) h s calc(l - 4)); + --sl-color-primary-300: hsl(from var(--primary-color) h s calc(l - 8)); + --sl-color-primary-200: hsl(from var(--primary-color) h s calc(l - 12)); + --sl-color-primary-100: hsl(from var(--primary-color) h s calc(l - 16)); + --sl-color-primary-50: hsl(from var(--primary-color) h s calc(l - 18)); /*** HEADER ***/ /*** APPLICATION ***/ /*** End APPLICATION ***/ @@ -14,20 +46,26 @@ html[data-darkmode="1"] body { /* This should mostly go away with webcomponents */ /** End WIDGETS **/ } -html[data-darkmode="1"] body #egw_fw_topmenu_info_items #topmenu_info_timer:before { +html[data-darkmode="1"] #egw_fw_topmenu_info_items #topmenu_info_timer:before, +.sl-theme-dark #egw_fw_topmenu_info_items #topmenu_info_timer:before { filter: initial; } -html[data-darkmode="1"] body egw-app { +html[data-darkmode="1"] egw-app, +.sl-theme-dark egw-app { --application-header-text-color: var(--sl-color-neutral-700); } -html[data-darkmode="1"] body .et2_container { +html[data-darkmode="1"] .et2_container, +.sl-theme-dark .et2_container { background-color: initial; } -html[data-darkmode="1"] body .dialogFooterToolbar et2-button::part(base):not(:hover), -html[data-darkmode="1"] body et2-dialog et2-button[variant='default'][slot='footer']::part(base):not(:hover) { +html[data-darkmode="1"] .dialogFooterToolbar et2-button::part(base):not(:hover), +.sl-theme-dark .dialogFooterToolbar et2-button::part(base):not(:hover), +html[data-darkmode="1"] et2-dialog et2-button[variant='default'][slot='footer']::part(base):not(:hover), +.sl-theme-dark et2-dialog et2-button[variant='default'][slot='footer']::part(base):not(:hover) { background-color: var(--sl-input-background-color); } -html[data-darkmode="1"] body .nextmatch_sortheader { +html[data-darkmode="1"] .nextmatch_sortheader, +.sl-theme-dark .nextmatch_sortheader { color: #96bcd9; } /** End theme customisations **/ @@ -163,7 +201,7 @@ egw-framework#egw_fw_basecontainer .egw_fw_ui_sidemenu_entry_header { left: 0; width: 100%; height: 100%; - background-image: url(../../../timesheet/templates/default/images/navbar.svg); + background-image: url(../../timesheet/templates/default/images/navbar.svg); background-repeat: no-repeat; background-size: 32px; background-position: center center; @@ -174,7 +212,7 @@ egw-framework#egw_fw_basecontainer .egw_fw_ui_sidemenu_entry_header { } #egw_fw_topmenu_info_items #topmenu_info_quick_add span#quick_add { display: block; - background-image: url(../../../api/templates/default/images/add.svg); + background-image: url(../../api/templates/default/images/add.svg); background-repeat: no-repeat; background-size: 24px; background-position: center; @@ -223,7 +261,7 @@ egw-framework#egw_fw_basecontainer .egw_fw_ui_sidemenu_entry_header { width: 1em; } #egw_fw_topmenu_info_items button#topmenu_info_search { - background-image: url(../../../api/templates/default/images/topmenu_items/search.svg); + background-image: url(../../api/templates/default/images/topmenu_items/search.svg); } #topmenu_info_print_title { background-image: url(../../../api/templates/default/images/print.svg); @@ -354,7 +392,7 @@ div.et2_nextmatch .egwGridView_outer thead > tr th.optcol span.selectcols { height: 9px; padding: 4px 14px 0 2px; margin-top: 4px; - background-image: url(../../../api/templates/default/images/selectcols.svg); + background-image: url(../../api/templates/default/images/selectcols.svg); background-repeat: no-repeat; background-size: 10px 10px; display: inline-block; diff --git a/kdots/assets/styles/framework.less b/kdots/css/kdots.less similarity index 94% rename from kdots/assets/styles/framework.less rename to kdots/css/kdots.less index c7307f85ff..58fbf3ccb7 100644 --- a/kdots/assets/styles/framework.less +++ b/kdots/css/kdots.less @@ -1,12 +1,13 @@ /** * kDots main styles * - * Note that light / dark colors should go in framework_light.less & framework_dark.less + * Note that light / dark colors should go in kdots_light.less & kdots_dark.less */ /** Theme customisations **/ -@import "./framework_dark.less"; +@import "./less/light.less"; +@import "./less/dark.less"; /** End theme customisations **/ html, body { @@ -164,7 +165,7 @@ egw-framework#egw_fw_basecontainer { left: 0; width: 100%; height: 100%; - background-image: url(../../../timesheet/templates/default/images/navbar.svg); + background-image: url(../../timesheet/templates/default/images/navbar.svg); background-repeat: no-repeat; background-size: 32px; background-position: center center; @@ -177,7 +178,7 @@ egw-framework#egw_fw_basecontainer { span#quick_add { display: block; - background-image: url(../../../api/templates/default/images/add.svg); + background-image: url(../../api/templates/default/images/add.svg); background-repeat: no-repeat; background-size: 24px; background-position: center; @@ -236,7 +237,7 @@ egw-framework#egw_fw_basecontainer { } } button#topmenu_info_search { - background-image: url(../../../api/templates/default/images/topmenu_items/search.svg); + background-image: url(../../api/templates/default/images/topmenu_items/search.svg); } } @@ -383,7 +384,7 @@ div.et2_nextmatch { height: 9px; padding: 4px 14px 0 2px; margin-top: 4px; - background-image: url(../../../api/templates/default/images/selectcols.svg); + background-image: url(../../api/templates/default/images/selectcols.svg); background-repeat: no-repeat; background-size: 10px 10px; display: inline-block; diff --git a/kdots/css/less/dark.less b/kdots/css/less/dark.less new file mode 100644 index 0000000000..3bbcc2945a --- /dev/null +++ b/kdots/css/less/dark.less @@ -0,0 +1,47 @@ +html[data-darkmode="1"], .sl-theme-dark { + background-color: black; + color: var(--sl-color-neutral-700); + + --sl-color-primary-950: hsl(from var(--primary-color) h s calc(l + 18)); + --sl-color-primary-900: hsl(from var(--primary-color) h s calc(l + 16)); + --sl-color-primary-800: hsl(from var(--primary-color) h s calc(l + 12)); + --sl-color-primary-700: hsl(from var(--primary-color) h s calc(l + 8)); + --sl-color-primary-600: hsl(from var(--primary-color) h s calc(l + 4)); + --sl-color-primary-500: var(--primary-color); + --sl-color-primary-400: hsl(from var(--primary-color) h s calc(l - 4)); + --sl-color-primary-300: hsl(from var(--primary-color) h s calc(l - 8)); + --sl-color-primary-200: hsl(from var(--primary-color) h s calc(l - 12)); + --sl-color-primary-100: hsl(from var(--primary-color) h s calc(l - 16)); + --sl-color-primary-50: hsl(from var(--primary-color) h s calc(l - 18)); + + /*** HEADER ***/ + #egw_fw_topmenu_info_items { + #topmenu_info_timer:before { + filter:initial; + } + } + + /*** APPLICATION ***/ + + egw-app { + --application-header-text-color: var(--sl-color-neutral-700); + } + + /*** End APPLICATION ***/ + + /*** WIDGETS ***/ + /* This should mostly go away with webcomponents */ + + .et2_container { + background-color: initial; + } + + .dialogFooterToolbar et2-button::part(base):not(:hover), et2-dialog et2-button[variant='default'][slot='footer']::part(base):not(:hover) { + background-color: var(--sl-input-background-color); + } + .nextmatch_sortheader { + color: #96bcd9; + } + + /** End WIDGETS **/ +} \ No newline at end of file diff --git a/kdots/css/less/light.less b/kdots/css/less/light.less new file mode 100644 index 0000000000..7aa3c30d27 --- /dev/null +++ b/kdots/css/less/light.less @@ -0,0 +1,18 @@ +:root, :host, html, .sl-theme-light { + /* + color token generator using #0053c9 + https://codepen.io/claviska/full/QWveRgL + */ + --sl-color-primary-50: rgb(247 250 253); + --sl-color-primary-100: rgb(228 237 249); + --sl-color-primary-200: rgb(208 223 245); + --sl-color-primary-300: rgb(186 208 240); + --sl-color-primary-400: rgb(156 188 234); + --sl-color-primary-500: rgb(117 162 226); + --sl-color-primary-600: rgb(73 132 216); + --sl-color-primary-700: rgb(33 105 208); + --sl-color-primary-800: rgb(0 81 197); + --sl-color-primary-900: rgb(0 58 141); + --sl-color-primary-950: rgb(0 36 88); + +} \ No newline at end of file diff --git a/kdots/head.tpl b/kdots/head.tpl index 7037e7dc55..1f8518cc53 100644 --- a/kdots/head.tpl +++ b/kdots/head.tpl @@ -17,7 +17,6 @@ - {css_file}