diff --git a/public/favicon.ico b/public/favicon.ico index 0561d178dadb78ee5f28f65c07b6110898bed797..a3a60ad1a1c4cc25cdd17ada13a725131d8f6d3c 100644 Binary files a/public/favicon.ico and b/public/favicon.ico differ diff --git a/src/assets/base.css b/src/assets/base.css index 71dc55a3cb5a72589496743a327c738ead3e1c83..6b40a5ee14a7249f6935bc5967bedf02728976d5 100644 --- a/src/assets/base.css +++ b/src/assets/base.css @@ -36,20 +36,6 @@ --section-gap: 160px; } -@media (prefers-color-scheme: dark) { - :root { - --color-background: var(--vt-c-black); - --color-background-soft: var(--vt-c-black-soft); - --color-background-mute: var(--vt-c-black-mute); - - --color-border: var(--vt-c-divider-dark-2); - --color-border-hover: var(--vt-c-divider-dark-1); - - --color-heading: var(--vt-c-text-dark-1); - --color-text: var(--vt-c-text-dark-2); - } -} - *, *::before, *::after { diff --git a/src/assets/images/clowm.svg b/src/assets/images/clowm.svg new file mode 100644 index 0000000000000000000000000000000000000000..0e6b6d7885d9babdbc4a072201665c66b05f4efb --- /dev/null +++ b/src/assets/images/clowm.svg @@ -0,0 +1,80 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> + +<svg + version="1.1" + id="svg200" + width="91.579002" + height="91.972" + viewBox="0 0 91.579 91.972" + xmlns="http://www.w3.org/2000/svg" + xmlns:svg="http://www.w3.org/2000/svg"> + <defs + id="defs204" /> + <g + id="g208" + transform="matrix(1.3333333,0,0,1.3333333,0,-1.2257119e-6)"> + <g + id="g210"> + <g + id="g212" + transform="translate(-8.83218,-6.5391791)"> + <path + d="M 60.5,34.246 49.148,39.395" + style="fill:none;stroke:#bfbfbf;stroke-width:2.41445;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" + id="path214" /> + </g> + <path + d="m 61.24582,25.394821 c 0,3.328 -2.695,6.023 -6.019,6.023 -3.329,0 -6.024,-2.695 -6.024,-6.023 0,-3.325 2.695,-6.024 6.024,-6.024 3.324,0 6.019,2.699 6.019,6.024 z" + style="fill:#0d6efd;fill-opacity:1;fill-rule:nonzero;stroke:none" + id="path220" /> + <g + id="g222" + transform="translate(-8.83218,-6.5391791)"> + <path + d="m 35.695,24.883 4.485,9.91" + style="fill:none;stroke:#bfbfbf;stroke-width:2.41445;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" + id="path224" /> + </g> + <g + id="g226" + transform="translate(-8.83218,-6.5391791)"> + <path + d="m 19.148,48.34 c 4.969,11.328 17.723,18.93 33.77,14.547" + style="fill:none;stroke:#bfbfbf;stroke-width:2.41445;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" + id="path228" /> + </g> + <g + id="g230" + transform="translate(-8.83218,-6.5391791)"> + <path + d="M 34.93,42.086 22.516,43.523" + style="fill:none;stroke:#bfbfbf;stroke-width:2.41445;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" + id="path232" /> + </g> + <path + d="m 31.43382,14.269821 c 0,3.324 -2.696,6.019 -6.024,6.019 -3.324,0 -6.019,-2.695 -6.019,-6.019 0,-3.329 2.695,-6.0240001 6.019,-6.0240001 3.328,0 6.024,2.6950001 6.024,6.0240001 z" + style="fill:#0d6efd;fill-opacity:1;fill-rule:nonzero;stroke:none" + id="path234" /> + <path + d="m 43.32782,34.823821 c 0,5.071 -4.113,9.18 -9.183,9.18 -5.071,0 -9.18,-4.109 -9.18,-9.18 0,-5.07 4.109,-9.183 9.18,-9.183 5.07,0 9.183,4.113 9.183,9.183 z" + style="fill:#dc3545;fill-opacity:1;fill-rule:nonzero;stroke:none" + id="path236" /> + <path + d="m 15.01182,38.198821 c 0,2.746 -2.223,4.969 -4.965,4.969 -2.742,0 -4.969,-2.223 -4.969,-4.969 0,-2.742 2.227,-4.965 4.969,-4.965 2.742,0 4.965,2.223 4.965,4.965 z" + style="fill:#198754;fill-opacity:1;fill-rule:nonzero;stroke:none" + id="path238" /> + <path + d="m 51.17582,53.667821 c 0,2.742 -2.223,4.965 -4.969,4.965 -2.742,0 -4.965,-2.223 -4.965,-4.965 0,-2.746 2.223,-4.969 4.965,-4.969 2.746,0 4.969,2.223 4.969,4.969 z" + style="fill:#198754;fill-opacity:1;fill-rule:nonzero;stroke:none" + id="path240" /> + <g + id="g242" + transform="translate(-8.83218,-6.5391791)"> + <path + d="m 76.121,40.961 c 0,18.152 -14.715,32.867 -32.867,32.867 -18.152,0 -32.867,-14.715 -32.867,-32.867 0,-18.152 14.715,-32.867 32.867,-32.867 18.152,0 32.867,14.715 32.867,32.867 z" + style="fill:none;stroke:#bfbfbf;stroke-width:1.60964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" + id="path244" /> + </g> + </g> + </g> +</svg> diff --git a/src/assets/images/denbi.svg b/src/assets/images/denbi.svg deleted file mode 100644 index 9e87849f29b451ab324563b4d6b1fc0c718d4c6d..0000000000000000000000000000000000000000 --- a/src/assets/images/denbi.svg +++ /dev/null @@ -1,540 +0,0 @@ -<?xml version="1.0" encoding="UTF-8" standalone="no"?> -<!-- Created with Inkscape (http://www.inkscape.org/) --> - -<svg - xmlns:dc="http://purl.org/dc/elements/1.1/" - xmlns:cc="http://creativecommons.org/ns#" - xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" - xmlns:svg="http://www.w3.org/2000/svg" - xmlns="http://www.w3.org/2000/svg" - xmlns:xlink="http://www.w3.org/1999/xlink" - xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" - xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" - width="98.794556mm" - height="98.992439mm" - viewBox="0 0 98.794556 98.99244" - version="1.1" - id="svg2615" - inkscape:version="0.92.2 2405546, 2018-03-11" - sodipodi:docname="denbi.svg"> - <defs - id="defs2609"> - <clipPath - clipPathUnits="userSpaceOnUse" - id="clipPath22622-0-7-4-2"> - <path - d="M 0,0 H 841.89 V 595.276 H 0 Z" - id="path22620-9-9-7-9" - inkscape:connector-curvature="0" /> - </clipPath> - <mask - maskUnits="userSpaceOnUse" - x="0" - y="0" - width="1" - height="1" - id="mask22632-9-1-2-3"> - <g - id="g22642-8-9-1-9"> - <g - clip-path="url(#clipPath22630-0-4-8-0)" - id="g22640-0-6-7-0"> - <g - id="g22638-2-3-9-8"> - <g - transform="matrix(131.04001,0,0,131.04001,508.79009,98.838959)" - id="g22636-4-6-5-8"> - <image - width="1" - height="1" - style="image-rendering:optimizeSpeed" - preserveAspectRatio="none" - transform="matrix(1,0,0,-1,0,1)" - xlink:href="" - id="image22634-9-8-6-5" /> - </g> - </g> - </g> - </g> - </mask> - <clipPath - clipPathUnits="userSpaceOnUse" - id="clipPath22630-0-4-8-0"> - <path - d="M 508.79,229.879 H 639.83 V 98.839 H 508.79 Z" - id="path22628-1-6-9-9" - inkscape:connector-curvature="0" /> - </clipPath> - <clipPath - clipPathUnits="userSpaceOnUse" - id="clipPath22650-2-6-5-6"> - <path - d="m 510.95,227.719 h 126 v -126.36 h -126 z" - id="path22648-0-7-5-3" - inkscape:connector-curvature="0" /> - </clipPath> - <mask - maskUnits="userSpaceOnUse" - x="0" - y="0" - width="1" - height="1" - id="mask22666-0-2-2-8"> - <g - id="g22676-6-7-1-5"> - <g - clip-path="url(#clipPath22664-3-6-6-9)" - id="g22674-3-4-5-6"> - <g - id="g22672-9-1-9-1"> - <g - transform="matrix(132.84001,0,0,133.20001,500.7401,104.72902)" - id="g22670-0-0-9-1"> - <image - width="1" - height="1" - style="image-rendering:optimizeSpeed" - preserveAspectRatio="none" - transform="matrix(1,0,0,-1,0,1)" - xlink:href="" - id="image22668-8-0-1-5" /> - </g> - </g> - </g> - </g> - </mask> - <clipPath - clipPathUnits="userSpaceOnUse" - id="clipPath22664-3-6-6-9"> - <path - d="m 500.74,237.929 h 132.84 v -133.2 H 500.74 Z" - id="path22662-8-4-2-8" - inkscape:connector-curvature="0" /> - </clipPath> - <clipPath - clipPathUnits="userSpaceOnUse" - id="clipPath22684-7-4-1-4"> - <path - d="M 502.9,235.769 H 631.06 V 107.609 H 502.9 Z" - id="path22682-3-3-0-81" - inkscape:connector-curvature="0" /> - </clipPath> - </defs> - <sodipodi:namedview - id="base" - pagecolor="#ffffff" - bordercolor="#666666" - borderopacity="1.0" - inkscape:pageopacity="0.0" - inkscape:pageshadow="2" - inkscape:zoom="0.35" - inkscape:cx="-538.82989" - inkscape:cy="27.194867" - inkscape:document-units="mm" - inkscape:current-layer="g55323-4" - showgrid="false" - inkscape:window-width="1920" - inkscape:window-height="1019" - inkscape:window-x="0" - inkscape:window-y="0" - inkscape:window-maximized="1" - fit-margin-top="0" - fit-margin-left="0" - fit-margin-right="0" - fit-margin-bottom="0" /> - <metadata - id="metadata2612"> - <rdf:RDF> - <cc:Work - rdf:about=""> - <dc:format>image/svg+xml</dc:format> - <dc:type - rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> - <dc:title></dc:title> - </cc:Work> - </rdf:RDF> - </metadata> - <g - inkscape:label="Layer 1" - inkscape:groupmode="layer" - id="layer1" - transform="translate(-94.184455,-57.036206)"> - <g - inkscape:export-ydpi="376.83823" - inkscape:export-xdpi="376.83823" - transform="matrix(9.0110139,0,0,9.0110139,-521.22726,-839.71092)" - id="g55323-4" - style="stroke:none;stroke-width:0.1109753"> - <g - id="g22692-1" - transform="matrix(0.09477835,0,0,-0.09477835,78.653045,104.47736)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -19.887,-8.434 -1.182,2.786 19.887,8.434 z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22694-8" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22696-5" - transform="matrix(0.09477835,0,0,-0.09477835,71.391489,106.95995)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -28.38,29.335 2.175,2.104 28.38,-29.335 z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22698-9" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22700-7" - transform="matrix(0.09477835,0,0,-0.09477835,73.983601,101.98815)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="M 0,0 -2.504,1.699 9.704,19.686 12.208,17.987 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22702-53" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22704-8" - transform="matrix(0.09477835,0,0,-0.09477835,76.233657,109.07867)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="M 0,0 3.048,40.702 6.066,40.476 3.017,-0.226 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22706-8" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22708-3" - transform="matrix(0.09477835,0,0,-0.09477835,71.390627,109.54218)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="M 0,0 -3.326,30.585 -0.317,30.912 3.008,0.327 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22710-18" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22712-9" - transform="matrix(0.09477835,0,0,-0.09477835,70.92027,106.22977)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="M 0,0 -14.527,38.144 -11.699,39.22 2.828,1.077 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22714-64" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22716-33" - transform="matrix(0.09477835,0,0,-0.09477835,73.447638,109.99767)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -22.809,33.848 2.51,1.69 L 2.509,1.691 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22718-3" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22720-8" - transform="matrix(0.09477835,0,0,-0.09477835,71.677578,106.69283)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -30.325,5.185 0.51,2.983 L 0.51,2.983 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22722-60" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22724-4" - transform="matrix(0.09477835,0,0,-0.09477835,69.743596,108.00648)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -2.022,2.251 16.459,14.782 2.022,-2.251 z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22726-8" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22728-8" - transform="matrix(0.09477835,0,0,-0.09477835,73.683325,102.20827)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="M 0,0 -26.613,14.834 -25.14,17.478 1.473,2.643 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22730-8" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22732-9" - transform="matrix(0.09477835,0,0,-0.09477835,73.859971,102.0234)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -2.871,-0.956 -6.866,20.626 2.871,0.956 z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22734-7" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22736-7" - transform="matrix(0.09477835,0,0,-0.09477835,73.655564,102.36073)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -1.21,2.774 30.397,13.264 1.21,-2.773 z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22738-64" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22740-3" - transform="matrix(0.09477835,0,0,-0.09477835,76.901749,104.93084)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -2.584,1.576 14.568,23.872 2.583,-1.576 z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22742-0" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22744-3" - transform="matrix(0.09477835,0,0,-0.09477835,78.639473,106.33723)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="M 0,0 -19.143,10.008 -17.741,12.69 1.402,2.682 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22746-0" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22748-9" - transform="matrix(0.09477835,0,0,-0.09477835,77.685236,107.83956)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="M 0,0 -11.205,26.753 -8.413,27.922 2.792,1.169 Z" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22750-25" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22752-4" - transform="matrix(0.09477835,0,0,-0.09477835,74.067432,104.98559)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -6.052,-0.057 -0.29,30.653 6.052,0.058 z" - style="fill:#7b7979;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22754-0" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22756-5" - transform="matrix(0.09477835,0,0,-0.09477835,71.366023,106.76728)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 -3.108,5.194 27.03,16.173 3.108,-5.194 z" - style="fill:#7b7979;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22758-9" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22760-46" - transform="matrix(0.09477835,0,0,-0.09477835,76.709559,105.37532)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="M 0,0 -31.006,1.058 -30.8,7.108 0.207,6.05 Z" - style="fill:#7b7979;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22762-9" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22772-2" - transform="matrix(0.09477835,0,0,-0.09477835,75.153373,104.70079)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 1.675,-8 -3.452,-15.842 -11.451,-17.517 -7.999,-1.675 -15.842,3.451 -17.517,11.451 -1.675,7.999 3.452,15.842 11.451,17.517 C -9.518,13.126 -1.675,7.999 0,0" - style="fill:#ec008c;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22774-2" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22776-4" - transform="matrix(0.09477835,0,0,-0.09477835,74.452734,101.93648)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.854,-4.077 -1.759,-8.074 -5.836,-8.928 -4.077,-0.854 -8.074,1.76 -8.927,5.836 -0.854,4.077 1.759,8.074 5.836,8.928 C -4.851,6.689 -0.854,4.076 0,0" - style="fill:#7b7979;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22778-7" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22780-7" - transform="matrix(0.09477835,0,0,-0.09477835,71.918341,106.37464)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.854,-4.077 -1.759,-8.073 -5.836,-8.927 -4.077,-0.854 -8.073,1.759 -8.927,5.836 -0.854,4.077 1.759,8.074 5.836,8.927 C -4.85,6.69 -0.854,4.077 0,0" - style="fill:#7b7979;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22782-5" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22784-48" - transform="matrix(0.09477835,0,0,-0.09477835,77.35278,104.956)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.854,-4.077 -1.759,-8.074 -5.836,-8.927 -4.077,-0.854 -8.074,1.759 -8.927,5.836 -0.854,4.076 1.759,8.073 5.836,8.927 C -4.851,6.689 -0.854,4.077 0,0" - style="fill:#7b7979;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22786-1" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22788-2" - transform="matrix(0.09477835,0,0,-0.09477835,78.677734,102.45883)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.256,-5.767 -4.168,-6.377 -2.913,-0.609 -5.767,1.257 -6.377,4.169 -0.61,2.912 1.256,5.767 4.168,6.377 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22790-8" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22792-93" - transform="matrix(0.09477835,0,0,-0.09477835,79.149807,106.06643)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.169,-6.377 -2.912,-0.609 -5.767,1.257 -6.376,4.169 -0.61,2.912 1.256,5.767 4.168,6.377 C -3.465,4.779 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22794-6" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22796-8" - transform="matrix(0.09477835,0,0,-0.09477835,78.353536,107.79556)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.256,-5.767 -4.168,-6.377 -2.913,-0.61 -5.767,1.257 -6.377,4.169 -0.61,2.912 1.256,5.767 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22798-0" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22800-2" - transform="matrix(0.09477835,0,0,-0.09477835,77.136203,100.75546)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.256,-5.767 -4.169,-6.377 -2.912,-0.609 -5.766,1.257 -6.376,4.169 -0.61,2.911 1.256,5.766 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22802-1" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22804-0" - transform="matrix(0.09477835,0,0,-0.09477835,73.549704,99.922771)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.169,-6.377 -2.912,-0.61 -5.767,1.257 -6.376,4.169 -0.61,2.912 1.256,5.767 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22806-5" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22808-1" - transform="matrix(0.09477835,0,0,-0.09477835,71.73051,100.57238)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.256,-5.767 -4.168,-6.377 -2.913,-0.61 -5.767,1.257 -6.377,4.169 -0.61,2.912 1.256,5.767 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22810-1" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22812-0" - transform="matrix(0.09477835,0,0,-0.09477835,69.378158,105.96222)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.256,-5.767 -4.169,-6.377 -2.912,-0.61 -5.767,1.257 -6.376,4.169 -0.61,2.911 1.256,5.767 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22814-8" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22816-5" - transform="matrix(0.09477835,0,0,-0.09477835,70.22488,107.78177)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.168,-6.377 -2.913,-0.61 -5.768,1.257 -6.377,4.169 -0.61,2.911 1.256,5.767 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22818-0" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22820-6" - transform="matrix(0.09477835,0,0,-0.09477835,72.008409,109.34911)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.169,-6.377 -2.912,-0.61 -5.767,1.257 -6.376,4.169 -0.61,2.911 1.256,5.767 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22822-4" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22824-6" - transform="matrix(0.09477835,0,0,-0.09477835,70.043076,102.19979)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.169,-6.377 -2.912,-0.609 -5.766,1.257 -6.376,4.169 -0.61,2.912 1.256,5.767 4.168,6.377 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22826-2" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22828-5" - transform="matrix(0.09477835,0,0,-0.09477835,74.132231,109.88718)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.169,-6.377 -2.912,-0.609 -5.767,1.257 -6.376,4.169 -0.61,2.912 1.256,5.767 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22830-8" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22832-6" - transform="matrix(0.09477835,0,0,-0.09477835,76.870283,109.17076)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.169,-6.377 -2.912,-0.61 -5.767,1.257 -6.376,4.169 -0.61,2.911 1.256,5.767 4.168,6.377 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22834-28" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22836-4" - transform="matrix(0.09477835,0,0,-0.09477835,75.549414,100.04888)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.256,-5.767 -4.168,-6.377 -2.913,-0.61 -5.767,1.257 -6.377,4.169 -0.61,2.912 1.256,5.767 4.168,6.376 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22838-7" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22840-2" - transform="matrix(0.09477835,0,0,-0.09477835,69.30589,103.944)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.169,-6.377 -2.912,-0.609 -5.767,1.257 -6.376,4.169 -0.61,2.912 1.256,5.767 4.168,6.377 C -3.465,4.779 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22842-4" - inkscape:connector-curvature="0" /> - </g> - <g - id="g22844-0" - transform="matrix(0.09477835,0,0,-0.09477835,79.248311,104.18049)" - style="stroke:none;stroke-width:0.1109753"> - <path - d="m 0,0 c 0.61,-2.912 -1.257,-5.767 -4.168,-6.377 -2.913,-0.609 -5.767,1.257 -6.377,4.169 -0.61,2.912 1.256,5.767 4.168,6.377 C -3.465,4.778 -0.61,2.912 0,0" - style="fill:#bdbcbc;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1109753" - id="path22846-6" - inkscape:connector-curvature="0" /> - </g> - </g> - </g> -</svg> diff --git a/src/assets/main.css b/src/assets/main.css index 6edc4b79b14192dfbe9a7f35b62861d14b807e29..24f661e1ba5b45e145150f636947b284828c9656 100644 --- a/src/assets/main.css +++ b/src/assets/main.css @@ -1,7 +1,4 @@ @import "base.css"; -body { - background: var(--vt-c-black); -} .fs-0 { font-size: 3.5rem; @@ -20,9 +17,18 @@ body { } pre { - backdrop-filter: brightness(1.4); + backdrop-filter: brightness(0.9); padding: .5rem; color: var(--bs-code-color); width: fit-content; min-width: 50%; } + +.hover-shadow { + transition: transform 0.2s ease-out; +} +.hover-shadow:hover { + box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important; + transform: translateY(-2px); + backdrop-filter: brightness(0.95); +} diff --git a/src/components/NavbarTop.vue b/src/components/NavbarTop.vue index 513a676a266db8a7fd1a621add16c88a224381b9..7e67629a6c83b85899066d95e72e45d573e7f218 100644 --- a/src/components/NavbarTop.vue +++ b/src/components/NavbarTop.vue @@ -47,7 +47,7 @@ watch( <template> <header - class="navbar navbar-expand-lg navbar-dark bd-navbar bg-dark sticky-top border-bottom border-secondary" + class="navbar navbar-expand-lg bd-navbar sticky-top border-bottom border-secondary" > <nav class="container-xxl bd-gutter flex-wrap flex-lg-nowrap text-light"> <button @@ -62,12 +62,15 @@ watch( > <span class="navbar-toggler-icon"></span> </button> - <router-link class="navbar-brand ms-3" to="/"> + <router-link + class="navbar-brand ms-3 text-white d-flex align-items-center" + to="/" + > <img - src="/src/assets/images/denbi.svg" - alt="Denbi Icon" - width="24" - height="24" + src="/src/assets/images/clowm.svg" + alt="CloWM Icon" + width="32" + height="32" class="d-inline-block align-text-top me-2" /> CloWM @@ -90,7 +93,7 @@ watch( > Object Storage </a> - <ul class="dropdown-menu dropdown-menu-dark"> + <ul class="dropdown-menu shadow"> <li> <router-link class="dropdown-item" :to="{ name: 'buckets' }" >Buckets</router-link @@ -116,7 +119,7 @@ watch( > Workflows </a> - <ul class="dropdown-menu dropdown-menu-dark"> + <ul class="dropdown-menu shadow"> <li> <router-link class="dropdown-item" :to="{ name: 'workflows' }" >Workflows</router-link @@ -166,7 +169,7 @@ watch( <font-awesome-icon icon="fa-solid fa-circle-user" class="fs-5" /> </a> <ul - class="dropdown-menu dropdown-menu-dark text-small shadow" + class="dropdown-menu text-small shadow" aria-labelledby="dropdownUser1" > <li> @@ -263,4 +266,8 @@ watch( </bootstrap-modal> </template> -<style scoped></style> +<style scoped> +header { + background: #da6409; +} +</style> diff --git a/src/components/modals/BootstrapModal.vue b/src/components/modals/BootstrapModal.vue index ed4eb2ad902442451ad76dd3325621bb098c5028..cc2b4071374b560d85a2ae74b59e516351af93d8 100644 --- a/src/components/modals/BootstrapModal.vue +++ b/src/components/modals/BootstrapModal.vue @@ -16,7 +16,7 @@ defineProps<{ :data-bs-backdrop="staticBackdrop ? 'static' : null" > <div - class="modal-dialog modal-dialog-centered modal-dialog-scrollable text-dark" + class="modal-dialog modal-dialog-centered modal-dialog-scrollable" style="min-width: 35%" > <div class="modal-content"> diff --git a/src/components/object-storage/BucketListItem.vue b/src/components/object-storage/BucketListItem.vue index 00c40364c0d400a1e9dab89fbe61ea8aeb3ef751..ea6b4d7957930e5270d9d2721276da492ac7175f 100644 --- a/src/components/object-storage/BucketListItem.vue +++ b/src/components/object-storage/BucketListItem.vue @@ -71,11 +71,12 @@ onMounted(() => { > <span class="placeholder w-75"></span> </div> - <div v-else> + <template v-else> <router-link class="list-group-item list-group-item-action d-flex justify-content-between align-items-center" :class="{ active: props.active, + 'hover-shadow': !props.active, rounded: !props.active, 'rounded-top': props.active, }" @@ -88,7 +89,7 @@ onMounted(() => { <span class="text-truncate" style="width: 80%">{{ bucket.name }}</span> <div> <font-awesome-icon - v-if="props.active && permission == null && props.deletable" + v-if="props.active && !permission && props.deletable" icon="fa-solid fa-trash" class="delete-icon me-2" @click="emit('delete-bucket', bucket.name)" @@ -104,14 +105,12 @@ onMounted(() => { </router-link> <div :hidden="!props.active" - class="ps-2 pe-2 rounded-bottom bg-light text-bg-light border border-3 border-top-0 border-primary" + class="px-2 rounded-bottom border shadow-sm border-3 border-top-0 border-primary" > - <div v-if="permission != null" class="ms-1 pt-1 text-info"> - Foreign Bucket - </div> + <div v-if="permission" class="ms-1 pt-1 text-info">Foreign Bucket</div> <table class="table table-sm table-borderless mb-0"> <tbody> - <tr v-if="permission != null"> + <tr v-if="permission"> <th scope="row" class="fw-bold">Permission</th> <td> <a @@ -147,7 +146,7 @@ onMounted(() => { </tbody> </table> </div> - </div> + </template> </div> </template> diff --git a/src/components/parameter-schema/ParameterSchemaDescriptionComponent.vue b/src/components/parameter-schema/ParameterSchemaDescriptionComponent.vue index 43ce261108a16742579d4ca04515b9f378952f39..d5b940c916c16a557c3ae41a514600d80b0b9e52 100644 --- a/src/components/parameter-schema/ParameterSchemaDescriptionComponent.vue +++ b/src/components/parameter-schema/ParameterSchemaDescriptionComponent.vue @@ -54,7 +54,7 @@ const parameterGroups = computed<Record<string, never>>( class="col-3 sticky-top" style="top: 70px !important; max-height: calc(100vh - 150px)" > - <nav class="h-100 bg-dark rounded-1"> + <nav class="h-100 rounded-1 border"> <nav class="nav"> <ul class="ps-0"> <li diff --git a/src/components/parameter-schema/ParameterSchemaFormComponent.vue b/src/components/parameter-schema/ParameterSchemaFormComponent.vue index a11a9c5ccade26b8e95957fc9cc27463a91b64bd..135a1520ca31b4c6ae51b3852354fc69bb3dad77 100644 --- a/src/components/parameter-schema/ParameterSchemaFormComponent.vue +++ b/src/components/parameter-schema/ParameterSchemaFormComponent.vue @@ -216,7 +216,7 @@ onMounted(() => { @submit.prevent="startWorkflow" novalidate > - <div class="card bg-dark mb-3"> + <div class="card mb-3"> <h2 class="card-header" id="pipelineGeneralOptions"> <font-awesome-icon icon="fa-solid fa-gear" class="me-2" /> Pipeline Options @@ -227,10 +227,7 @@ onMounted(() => { </h5> <div class="input-group"> <span class="input-group-text" id="pipelineNotes"> - <font-awesome-icon - class="me-2 text-dark" - icon="fa-solid fa-sticky-note" - /> + <font-awesome-icon class="me-2" icon="fa-solid fa-sticky-note" /> <code>--notes</code> </span> <textarea @@ -244,10 +241,7 @@ onMounted(() => { > <div class="input-group"> <span class="input-group-text" id="pipelineNotes"> - <font-awesome-icon - class="me-2 text-dark" - icon="fa-solid fa-sticky-note" - /> + <font-awesome-icon class="me-2" icon="fa-solid fa-sticky-note" /> <code>--report_output_bucket</code> </span> <parameter-string-input @@ -279,7 +273,7 @@ onMounted(() => { </form> <!-- Loading card --> <div v-else class="col-9"> - <div class="card bg-dark mb-3"> + <div class="card mb-3"> <h2 class="card-header placeholder-glow"> <span class="placeholder col-6"></span> </h2> @@ -299,7 +293,7 @@ onMounted(() => { </div> </div> <div - class="col-3 sticky-top bg-dark rounded-1 px-0" + class="col-3 sticky-top border shadow-sm rounded-1 px-0" style="top: 70px !important; max-height: calc(100vh - 150px)" > <div class="d-flex pt-2"> diff --git a/src/components/parameter-schema/description-mode/ParameterDescription.vue b/src/components/parameter-schema/description-mode/ParameterDescription.vue index ab9b7f58d1fd110a7c3952affacd469842080dc8..aada14f5cfb70606fb262e4119f30b50b68d4bcd 100644 --- a/src/components/parameter-schema/description-mode/ParameterDescription.vue +++ b/src/components/parameter-schema/description-mode/ParameterDescription.vue @@ -52,7 +52,7 @@ const showRightColum = computed<boolean>( > <div class="fs-6 col-3"> <font-awesome-icon :icon="icon" v-if="icon" class="me-2" /> - <code class="bg-dark p-1" :id="props.parameterName" + <code class="border rounded p-1" :id="props.parameterName" >--{{ props.parameterName }}</code > <br /> @@ -69,7 +69,7 @@ const showRightColum = computed<boolean>( v-if="showRightColum" > <button - class="btn btn-outline-info btn-sm my-1" + class="btn btn-info btn-sm my-1" type="button" data-bs-toggle="collapse" :data-bs-target="'#helpCollapse' + randomIDSuffix" @@ -82,7 +82,7 @@ const showRightColum = computed<boolean>( </button> <div v-if="enumValues" class="dropdown w-fit my-1"> <a - class="bg-dark rounded-1 p-1 dropdown-toggle text-reset text-decoration-none" + class="rounded-1 p-1 dropdown-toggle text-reset text-decoration-none border" href="#" role="button" data-bs-toggle="dropdown" @@ -93,13 +93,13 @@ const showRightColum = computed<boolean>( ><code>{{ defaultValue }}</code> (default)</span > </a> - <ul class="dropdown-menu dropdown-menu-dark" v-if="enumValues"> - <li v-for="val in enumValues" :key="val" class="px-2 w-100"> + <ul class="dropdown-menu shadow" v-if="enumValues"> + <li v-for="val in enumValues" :key="val" class="px-2"> {{ val }} <span v-if="val === defaultValue">(default)</span> </li> </ul> </div> - <span v-else-if="defaultValue" class="bg-dark rounded-1 py-0 px-1 my-1" + <span v-else-if="defaultValue" class="rounded-1 py-0 px-1 my-1" >default: <code>{{ defaultValue }}</code></span > @@ -110,7 +110,7 @@ const showRightColum = computed<boolean>( > </div> <div - class="collapse p-2 pb-0 bg-dark m-2 flex-shrink-1" + class="collapse p-2 pb-0 border rounded m-2 flex-shrink-1" :id="'helpCollapse' + randomIDSuffix" v-if="helpText" > @@ -133,4 +133,7 @@ li:hover { a:hover { filter: brightness(1.2); } +code.border { + backdrop-filter: brightness(0.95); +} </style> diff --git a/src/components/parameter-schema/form-mode/ParameterBooleanInput.vue b/src/components/parameter-schema/form-mode/ParameterBooleanInput.vue index 2ee50311314e471790e694dd2574ce0b895de99e..39599eb8e38cc292b3763f6028a666140844cdd9 100644 --- a/src/components/parameter-schema/form-mode/ParameterBooleanInput.vue +++ b/src/components/parameter-schema/form-mode/ParameterBooleanInput.vue @@ -36,7 +36,7 @@ const emit = defineEmits<{ <template> <div - class="flex-fill mb-0 text-bg-light fs-6 ps-4 d-flex align-items-center justify-content-start" + class="flex-fill mb-0 text-bg-light fs-6 ps-4 d-flex align-items-center justify-content-start border" :class="{ 'rounded-end': !helpTextPresent }" > <div class="form-check form-check-inline"> diff --git a/src/components/parameter-schema/form-mode/ParameterGroupForm.vue b/src/components/parameter-schema/form-mode/ParameterGroupForm.vue index f399ddb88d4ab8f578d96cbae02cd4bbcef903a6..34bab4686b68ab76d261b9a2807446c3a343af8b 100644 --- a/src/components/parameter-schema/form-mode/ParameterGroupForm.vue +++ b/src/components/parameter-schema/form-mode/ParameterGroupForm.vue @@ -71,7 +71,7 @@ watch( </script> <template> - <div class="card bg-dark mb-3" v-if="!groupHidden"> + <div class="card mb-3" v-if="!groupHidden"> <h2 class="card-header" :id="props.parameterGroupName"> <font-awesome-icon :icon="icon" class="me-2" v-if="icon" /> {{ title }} @@ -86,7 +86,7 @@ watch( <div class="input-group"> <span class="input-group-text" :id="parameterName + '-help'"> <font-awesome-icon - class="me-2 text-dark" + class="me-2" :icon="parameter['fa_icon']" v-if="parameter['fa_icon']" /> @@ -156,7 +156,7 @@ watch( ><markdown-renderer :markdown="parameter['description']" /></label> <div - class="collapse p-2 pb-0 bg-dark mx-2 mt-1 flex-shrink-1" + class="collapse p-2 pb-0 mx-2 mb-2 mt-1 flex-shrink-1 border rounded" :id="'helpCollapse' + parameterName" v-if="parameter['help_text']" > diff --git a/src/components/workflows/WorkflowCard.vue b/src/components/workflows/WorkflowCard.vue index ffddccfe35a024c27b092626aa737f0f36a763a8..05cb287a5f760b03b8de6206bae0c79dd47ca4d7 100644 --- a/src/components/workflows/WorkflowCard.vue +++ b/src/components/workflows/WorkflowCard.vue @@ -25,7 +25,7 @@ onMounted(() => { </script> <template> - <div class="card-hover border border-secondary card text-bg-dark m-2"> + <div class="card-hover border border-secondary card m-2"> <div class="card-body"> <div class="card-title fs-3 d-flex justify-content-between align-items-center" @@ -108,6 +108,7 @@ onMounted(() => { .card-hover:hover { transform: translate(0, -5px); + box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important; } .icon { diff --git a/src/components/workflows/WorkflowStatisticsChart.vue b/src/components/workflows/WorkflowStatisticsChart.vue index 9572134c4e7c116b1c0e846ff53cefcf3fe6c140..c9d5e5f5a30098b0c048b1569e8b361b85247406 100644 --- a/src/components/workflows/WorkflowStatisticsChart.vue +++ b/src/components/workflows/WorkflowStatisticsChart.vue @@ -59,6 +59,12 @@ function updateData(chart: Chart, newStats: WorkflowStatistic[]) { (sum += value.count) )(0) ); + // eslint-disable-next-line @typescript-eslint/ban-ts-comment + // @ts-ignore + chart.options.scales.x.time.unit = + newStats.length > 0 + ? xAxisLabelUnit(newStats[0].day, dayjs().toISOString()) + : "week"; // render new chart chart.update(); // eslint-disable-next-line @typescript-eslint/ban-ts-comment @@ -72,21 +78,37 @@ function resetZoom() { } } +function xAxisLabelUnit(max: number | string, min: number | string): string { + return dayjs(min).diff(dayjs(max), "week") < 12 ? "week" : "month"; +} + // pad or trim stats to one year const paddedStats = computed<WorkflowStatistic[]>(() => { - const lastYear = dayjs().subtract(1, "year"); - // Find index in stats list where the stat is from a day after the same day last year - let statsIndex = props.stats.findIndex((stat) => - lastYear.isSameOrBefore(dayjs(stat.day), "day") - ); - if (statsIndex < 0) { + // select first day in statistics: last year, first day of statistics or last month + let statsIndex = 0; + let firstDay = dayjs().subtract(1, "month"); + if (props.stats.length > 0) { + const firstStatDay = dayjs(props.stats[0].day); + if (firstStatDay.isSameOrBefore(firstDay, "day")) { + firstDay = firstStatDay; + } + const lastYear = dayjs().subtract(1, "year"); + if (firstDay.isSameOrBefore(lastYear, "day")) { + firstDay = lastYear; + // Find index in stats list where the stat is from a day after the same day last year + statsIndex = props.stats.findIndex((stat) => + lastYear.isSameOrBefore(dayjs(stat.day), "day") + ); + } + } else { statsIndex = 1; } - // Pad or trim workflow statistics to exactly one year - return Array.from({ length: 365 }, (e, i) => { + const timespan = dayjs().diff(firstDay, "day") + 1; + // Pad or trim workflow statistics + return Array.from({ length: timespan }, (e, i) => { let count = 0; const day = dayjs() - .subtract(365 - i, "day") + .subtract(timespan - i, "day") .format("YYYY-MM-DD"); if ( statsIndex < props.stats.length && @@ -205,8 +227,10 @@ onMounted(() => { if (tempChart.chart.options.scales?.x) { // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore - tempChart.chart.options.scales.x.time.unit = - tempChart.chart.getZoomLevel() > 3.5 ? "week" : "month"; + tempChart.chart.options.scales.x.time.unit = xAxisLabelUnit( + tempChart.chart.scales.x.min, + tempChart.chart.scales.x.max + ); tempChart.chart.update(); disableZoomReset.value = !tempChart.chart.isZoomedOrPanned(); } @@ -230,6 +254,8 @@ onMounted(() => { // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore position: "top", // position tooltip on top of canvas + mode: "index", + intersect: false, backgroundColor: "rgba(108, 117, 125, 0.9)", // greyish background color yAlign: "bottom", // Position of the tooltip caret in the Y direction }, @@ -245,7 +271,7 @@ onMounted(() => { <template> <div class="w-100 row"> - <span class="mx-auto w-fit fw-bold">Workflow Statistics</span> + <h5 class="mx-auto w-fit">Workflow Usage Statistics</h5> </div> <div class="d-flex align-items-center mb-4"> <div @@ -253,7 +279,7 @@ onMounted(() => { style="height: 150px" > <div> - {{ dayjs().subtract(1, "year").format("MMM YYYY") }} - + {{ dayjs(paddedStats[0].day).format("MMM YYYY") }} - {{ dayjs().format("MMM YYYY") }} </div> <button @@ -265,7 +291,7 @@ onMounted(() => { Reset Zoom </button> </div> - <div style="max-height: 150px" class="flex-fill"> + <div style="max-height: 200px" class="flex-fill"> <canvas ref="canvas"></canvas> </div> </div> diff --git a/src/components/workflows/WorkflowWithVersionsCard.vue b/src/components/workflows/WorkflowWithVersionsCard.vue index 5a30e8f212b402a2f9e4c7137cb070e41205e8a2..6c39b9a2e6758e7dd0c37ed31269df6ef6ef0d50 100644 --- a/src/components/workflows/WorkflowWithVersionsCard.vue +++ b/src/components/workflows/WorkflowWithVersionsCard.vue @@ -26,7 +26,7 @@ const statusToIconMapping: Record<string, string> = { </script> <template> - <div class="card-hover border border-secondary card text-bg-dark m-2"> + <div class="card-hover border border-secondary card m-2"> <div class="card-body"> <div class="card-title fs-3 d-flex justify-content-between align-items-center" @@ -79,7 +79,7 @@ const statusToIconMapping: Record<string, string> = { <span class="placeholder col-md-1 offset-md-1 bg-primary"></span> </div> <div v-else> - <table class="table table-dark table-sm table-hover"> + <table class="table table-sm table-hover"> <tbody> <tr v-for="version in sortedVersions(props.workflow.versions)" @@ -143,6 +143,7 @@ const statusToIconMapping: Record<string, string> = { .card-hover:hover { transform: translate(0, -5px); + box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important; } td > img { max-width: 1em; diff --git a/src/views/LoginView.vue b/src/views/LoginView.vue index 14337c434499bf79fbd8147f6ffb03c2c190f2db..454dbb1646a42db0d00aadef4f063db4e93be369 100644 --- a/src/views/LoginView.vue +++ b/src/views/LoginView.vue @@ -58,11 +58,11 @@ onMounted(() => { </div> </div> <div - class="card text-center bg-dark ms-md-auto position-fixed top-50 start-50 translate-middle" + class="card text-center ms-md-auto position-fixed top-50 start-50 translate-middle shadow" > - <div class="card-header text-dark bg-light">CloWM</div> + <div class="card-header">CloWM</div> <div class="card-body p-5"> - <h5 class="card-title text-light">Login</h5> + <h5 class="card-title">Login</h5> <p class="card-text text-secondary"> Login to this service with LifeScience </p> @@ -73,4 +73,8 @@ onMounted(() => { </div> </template> -<style scoped></style> +<style scoped> +img:hover { + filter: brightness(0.9); +} +</style> diff --git a/src/views/NotFoundView.vue b/src/views/NotFoundView.vue index 1bf21c077823b5aaf6135081d3e15e30045037a5..73393efccd69109bfc8e8619fe799737d26ddc05 100644 --- a/src/views/NotFoundView.vue +++ b/src/views/NotFoundView.vue @@ -2,11 +2,11 @@ <template> <div - class="card min-w-25 text-center bg-dark ms-md-auto position-fixed top-50 start-50 translate-middle" + class="card min-w-25 text-center ms-md-auto position-fixed top-50 start-50 translate-middle shadow" > - <div class="card-header text-dark bg-light fs-4">Something went wrong</div> + <div class="card-header fs-4">Something went wrong</div> <div class="card-body p-5"> - <h1 class="card-title text-light mb-5">Page Not Found</h1> + <h1 class="card-title mb-5">Page Not Found</h1> <p class="card-text text-secondary fs-4"> Back to the <router-link to="/">HomePage</router-link> </p> diff --git a/src/views/object-storage/BucketView.vue b/src/views/object-storage/BucketView.vue index 4ebcf3dd1150a5919b04f26b3b610d1a9e9c25af..77bcb0dde6387c0d5e3b9ce4c28fe35cd310cfc3 100644 --- a/src/views/object-storage/BucketView.vue +++ b/src/views/object-storage/BucketView.vue @@ -577,7 +577,7 @@ watch( <!-- Search bucket text input --> <div class="row"> <div class="col-8"> - <div class="input-group mt-2"> + <div class="input-group mt-2 rounded shadow-sm"> <span class="input-group-text" id="objects-search-wrapping" ><font-awesome-icon icon="fa-solid fa-magnifying-glass" /></span> @@ -596,13 +596,13 @@ watch( <div id="BucketViewButtons" class="col-auto"> <button type="button" - class="btn btn-secondary me-2 tooltip-container" + class="btn btn-light me-2 tooltip-container border shadow-sm" :disabled="errorLoadingObjects || !writableBucket" data-bs-toggle="modal" data-bs-title="Upload Object" data-bs-target="#upload-object-modal" > - <font-awesome-icon icon="fa-solid fa-upload" fill="white" /> + <font-awesome-icon icon="fa-solid fa-upload" /> <span class="visually-hidden">Upload Object</span> </button> <upload-object-modal @@ -616,7 +616,7 @@ watch( <!-- Add folder button --> <button type="button" - class="btn btn-secondary m-2 tooltip-container" + class="btn btn-light m-2 tooltip-container border shadow-sm" :disabled="errorLoadingObjects || !writableBucket" data-bs-toggle="modal" data-bs-title="Create Folder" @@ -638,7 +638,7 @@ watch( v-if="!authStore.foreignUser" :hidden="!bucketRepository.permissionFeatureAllowed(props.bucketName)" type="button" - class="btn btn-secondary m-2 tooltip-container" + class="btn btn-light m-2 tooltip-container border shadow-sm" :disabled="errorLoadingObjects" data-bs-toggle="modal" data-bs-title="Create Bucket Permission" @@ -665,7 +665,7 @@ watch( v-if="!authStore.foreignUser" :hidden="!bucketRepository.permissionFeatureAllowed(props.bucketName)" type="button" - class="btn btn-secondary m-2 tooltip-container" + class="btn btn-light m-2 tooltip-container border shadow-sm" :disabled="errorLoadingObjects" data-bs-title="List Bucket Permission" data-bs-toggle="modal" @@ -714,9 +714,7 @@ watch( <!-- Show content of bucket --> <div v-else> <!-- Table header --> - <table - class="table table-dark table-striped table-hover caption-top align-middle" - > + <table class="table table-hover caption-top align-middle"> <caption> Displaying {{ @@ -807,7 +805,7 @@ watch( <span class="visually-hidden">Toggle Dropdown</span> </button> <!-- Dropdown menu --> - <ul class="dropdown-menu dropdown-menu-dark"> + <ul class="dropdown-menu dropdown-menu"> <li> <button class="dropdown-item" diff --git a/src/views/object-storage/BucketsView.vue b/src/views/object-storage/BucketsView.vue index f62c71472a525e3444ed4a7161fe9c483928f568..89d1bc520d36e6576faf48930e0f889aa68ba076 100644 --- a/src/views/object-storage/BucketsView.vue +++ b/src/views/object-storage/BucketsView.vue @@ -70,16 +70,16 @@ onMounted(() => { modalID="create-bucket-modal" v-if="!authStore.foreignUser" /> - <div class="row m-2 border-bottom border-light"> + <div class="row m-2 border-bottom"> <div class="col-12"></div> - <h1 class="mb-2 text-light">Buckets</h1> + <h1 class="mb-2">Buckets</h1> </div> <div class="row m-2 mt-4"> <div class="col-3"> <div class="d-flex justify-content-between"> <button type="button" - class="btn btn-light" + class="btn btn-light border shadow-sm" @click.stop.prevent="fetchBuckets" > <font-awesome-icon @@ -91,7 +91,7 @@ onMounted(() => { <button v-if="!authStore.foreignUser" type="button" - class="btn btn-light" + class="btn btn-light border shadow-sm" data-bs-toggle="modal" data-bs-target="#create-bucket-modal" > @@ -99,7 +99,7 @@ onMounted(() => { <span class="visually-hidden">Create Bucket</span> </button> </div> - <div class="input-group flex-nowrap mt-2"> + <div class="input-group mt-2 rounded shadow-sm"> <span class="input-group-text" id="buckets-search-wrapping" ><font-awesome-icon icon="fa-solid fa-magnifying-glass" /></span> diff --git a/src/views/object-storage/S3KeyView.vue b/src/views/object-storage/S3KeyView.vue index ed567a80fa4c3d177a9a3ef1d2729b9635938b01..accd651eddb9aa3aa9c0f3de13c5516160a22a73 100644 --- a/src/views/object-storage/S3KeyView.vue +++ b/src/views/object-storage/S3KeyView.vue @@ -43,7 +43,7 @@ function deleteKeyTrigger() { </div> <input v-else - class="form-control-plaintext text-white fs-4" + class="form-control-plaintext fs-4" type="text" :value="props.s3key.access_key" aria-label="S3 Access Key" @@ -70,7 +70,7 @@ function deleteKeyTrigger() { <input v-else id="s3-secret-key" - class="form-control-plaintext text-white fs-4 mb-3" + class="form-control-plaintext fs-4 mb-3" :type="visibleSecret ? 'text' : 'password'" :value="props.s3key.secret_key" aria-label="S3 Access Key" diff --git a/src/views/object-storage/S3KeysView.vue b/src/views/object-storage/S3KeysView.vue index f7b997e110a351f6520c36b2bf638749f0e11833..7e8ba0641874715cf89646df536ff3b89d78eb39 100644 --- a/src/views/object-storage/S3KeysView.vue +++ b/src/views/object-storage/S3KeysView.vue @@ -103,16 +103,16 @@ onMounted(() => { </div> </div> </div> - <div class="row m-2 border-bottom border-light mt-4"> + <div class="row m-2 border-bottom mt-4"> <div class="col-12"></div> - <h1 class="mb-2 text-light">S3 Keys</h1> + <h1 class="mb-2">S3 Keys</h1> </div> <div class="row m-2 mt-4"> <div class="col-4"> <div class="d-flex justify-content-between mb-4"> <button type="button" - class="btn btn-light" + class="btn btn-light border shadow-sm" @click="refreshKeys(authStore.currentUID)" > <font-awesome-icon @@ -121,7 +121,11 @@ onMounted(() => { /> <span class="visually-hidden">Refresh S3 Keys</span> </button> - <button type="button" class="btn btn-light" @click="createKey"> + <button + type="button" + class="btn btn-light border shadow-sm" + @click="createKey" + > <font-awesome-icon icon="fa-solid fa-plus" class="fs-5" /> <span class="visually-hidden">Create S3 Key</span> </button> @@ -135,16 +139,17 @@ onMounted(() => { class="btn w-100 fs-5 mb-3 btn-secondary disabled placeholder" /> </div> - <div v-else> + <div v-else class="d-grid gap-3"> <button v-for="(s3key, index) in keyState.keys" :key="s3key.access_key" - class="btn w-100 fs-5 mb-3 text-truncate" + class="btn fs-5 text-truncate border hover-shadow" type="button" @click="keyState.activeKey = index" :class="{ 'btn-light': keyState.activeKey !== index, 'btn-primary': keyState.activeKey === index, + shadow: keyState.activeKey === index, }" > {{ s3key.access_key }} diff --git a/src/views/workflows/ListWorkflowExecutionsView.vue b/src/views/workflows/ListWorkflowExecutionsView.vue index ebfa317c90a1d867e5e7338792020bc050def7b2..a7c4395bd793a7ac4021ffb09ac51ee54f1b5bc1 100644 --- a/src/views/workflows/ListWorkflowExecutionsView.vue +++ b/src/views/workflows/ListWorkflowExecutionsView.vue @@ -223,21 +223,24 @@ onMounted(() => { " /> <div - class="row m-2 border-bottom border-light mb-4 justify-content-between align-items-center" + class="row m-2 border-bottom mb-4 justify-content-between align-items-center" > - <h1 class="mb-2 text-light w-fit">My Workflow Executions</h1> + <h1 class="mb-2 w-fit">My Workflow Executions</h1> <div class="w-fit"> - <button class="btn btn-light me-2" @click="updateExecutions"> + <button + class="btn btn-light me-2 shadow-sm border" + @click="updateExecutions" + > <font-awesome-icon icon="fa-solid fa-arrow-rotate-right" /> </button> - <router-link :to="{ name: 'workflows' }" class="btn btn-primary" + <router-link + :to="{ name: 'workflows' }" + class="btn btn-primary shadow-sm border" >Start Workflow Execution</router-link > </div> </div> - <table - class="table table-dark table-striped table-hover caption-top align-middle" - > + <table class="table table-hover caption-top align-middle"> <caption> Displaying {{ @@ -277,7 +280,7 @@ onMounted(() => { <div class="btn-group btn-group-sm dropdown-center dropdown-menu-start" > - <button type="button" class="btn btn-secondary" disabled> + <button type="button" class="btn btn-secondary border" disabled> Details </button> <button @@ -317,7 +320,7 @@ onMounted(() => { </td> <td> <span - class="rounded-pill py-1 px-2" + class="rounded-pill py-1 px-2 text-light" :class="statusToColorMapping[execution.status]" ><font-awesome-icon class="me-2" @@ -349,7 +352,7 @@ onMounted(() => { > <span class="visually-hidden">Toggle Dropdown</span> </button> - <ul class="dropdown-menu dropdown-menu-dark"> + <ul class="dropdown-menu dropdown-menu"> <li v-if="workflowExecutionCancable(execution.status)"> <button class="dropdown-item text-danger align-middle" diff --git a/src/views/workflows/ListWorkflowsView.vue b/src/views/workflows/ListWorkflowsView.vue index 362e885d07fa0fd8173ff63b34018605b65cf2be..8c40805a39d88f4eb4b06b1ab2cc371be8e29b4f 100644 --- a/src/views/workflows/ListWorkflowsView.vue +++ b/src/views/workflows/ListWorkflowsView.vue @@ -74,12 +74,12 @@ onMounted(() => { </script> <template> - <div class="row m-2 border-bottom border-light mb-4"> - <h1 class="mb-2 text-light">Workflows</h1> + <div class="row m-2 border-bottom mb-4"> + <h1 class="mb-2">Workflows</h1> </div> <div class="d-flex m-2 mb-3 align-items-center justify-content-between"> <div class="col-5 me-auto"> - <div class="input-group"> + <div class="input-group rounded shadow-sm"> <span class="input-group-text" id="workflows-search-wrapping" ><font-awesome-icon icon="fa-solid fa-magnifying-glass" /></span> @@ -95,9 +95,9 @@ onMounted(() => { /> </div> </div> - <span class="fs-5 me-3">Sort By</span> + <span class="fs-5 me-3 bla">Sort By</span> <div - class="btn-group btn-group-sm w-fit" + class="btn-group btn-group-sm w-fit shadow-sm" role="group" aria-label="Basic radio toggle button group" > @@ -197,4 +197,8 @@ onMounted(() => { </div> </template> -<style scoped></style> +<style scoped> +.bla { + text-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important; +} +</style> diff --git a/src/views/workflows/MyWorkflowsView.vue b/src/views/workflows/MyWorkflowsView.vue index cf18673417aa0cbefeb5c9c7f568ff73ee5d6b06..f9507273f1b97194524127a0d9edb96a43de8312 100644 --- a/src/views/workflows/MyWorkflowsView.vue +++ b/src/views/workflows/MyWorkflowsView.vue @@ -105,9 +105,9 @@ onMounted(() => { " /> <div - class="row m-2 border-bottom border-light mb-4 justify-content-between align-items-center pb-2" + class="row m-2 border-bottom mb-4 justify-content-between align-items-center pb-2" > - <h1 class="w-fit text-light">My Workflows</h1> + <h1 class="w-fit">My Workflows</h1> <button class="btn btn-lg btn-primary w-fit" data-bs-toggle="modal" diff --git a/src/views/workflows/ReviewWorkflowsView.vue b/src/views/workflows/ReviewWorkflowsView.vue index 61f8c5cf153fca0592b8c25f109a78bcb502b68b..c752ad89036e6648a8fe436148ad9e65dd8144c3 100644 --- a/src/views/workflows/ReviewWorkflowsView.vue +++ b/src/views/workflows/ReviewWorkflowsView.vue @@ -89,8 +89,8 @@ onMounted(() => { </script> <template> - <div class="row m-2 border-bottom border-light mb-4"> - <h1 class="mb-2 text-light">Workflow Reviews</h1> + <div class="row m-2 border-bottom mb-4"> + <h1 class="mb-2">Workflow Reviews</h1> </div> <div v-if="workflowsState.loading" class="text-center mt-5"> <div class="spinner-border" style="width: 3rem; height: 3rem" role="status"> @@ -98,7 +98,7 @@ onMounted(() => { </div> </div> <table - class="table table-dark table-striped mx-auto" + class="table table-striped mx-auto" v-else-if="workflowsState.workflows.length > 0" > <thead class="fs-5"> @@ -132,7 +132,7 @@ onMounted(() => { </tr> <tr> <td colspan="4" class="px-5"> - <table class="table table-dark mb-0"> + <table class="table mb-0"> <colgroup> <col span="1" style="width: 1%" /> </colgroup> diff --git a/src/views/workflows/WorkflowVersionView.vue b/src/views/workflows/WorkflowVersionView.vue index 7f3ffb15301c4fbb7ea6c881518bfd78213d1408..7dacd5d4d42a9bf3a2c5c6d1d015b82ed42fd8b5 100644 --- a/src/views/workflows/WorkflowVersionView.vue +++ b/src/views/workflows/WorkflowVersionView.vue @@ -100,7 +100,7 @@ onMounted(() => { </script> <template> - <ul class="nav justify-content-evenly nav-tabs bg-dark fs-5 mb-3"> + <ul class="nav justify-content-evenly nav-tabs fs-5 mb-3"> <li class="nav-item"> <router-link class="nav-link" diff --git a/src/views/workflows/WorkflowView.vue b/src/views/workflows/WorkflowView.vue index ad6394d5867275a4d771db3e4f44efd9353a253c..0c36fd54ef209bad186f29e4129336d9a57d0eda 100644 --- a/src/views/workflows/WorkflowView.vue +++ b/src/views/workflows/WorkflowView.vue @@ -198,7 +198,7 @@ onMounted(() => { </div> <div v-else-if="workflowState.workflow"> <div class="d-flex justify-content-between align-items-center"> - <div class="fs-0 w-fit text-light"> + <div class="fs-0 w-fit"> {{ workflowState.workflow.name }} <span v-if="activeVersionString">@{{ activeVersionString }}</span> </div> @@ -280,7 +280,7 @@ onMounted(() => { </select> </div> </div> - <div class="row w-100 mb-4 mt-2 mx-0"> + <div class="row w-100 mb-4 mt-2 mx-0 border-bottom pb-2"> <a :href="workflowState.workflow.repository_url" target="_blank"