* start new server settings tabs * update properties tab to match design * better stying in general tab * feat: add suffix input for hostname field * implement tables for allocations and DNS records * add tags for dns record type * small gap adjustment * polish advanced page * adjust properties page hierarchy * fix searching properties, empty state and projection radius appearing * pnpm prepr * update copy to match designs * fix suffix input component * style fixes and match heading size * small fix * fix search allocations placeholder * adjust table styles * move all installation settings helper text to below input * update icon to use overflow menu buttons * fix modal to be consistent * open advanced properties when search * remove other and custom properties, and update styles * remove hide/show all java versions * handle mc 26 * refactor: move server settings pages into /ui and add app ServerSettingsModal * hook up server pages for app * add server page header to app * hook up server settings modal * use large size * fix card box shadow style * fix hostname input for app * fix app/website card containers * implement external tabs for billing and admin billing * fix save banner fixed to parent instead of page body * remove unused prop to FriendsList causing warning in app * fix client-only not available for app * fix bottom cut off * wire node auth * implement full copy buttons * dedup copy button tailwind styles * fix hover class not working in @apply * fix spacing * fix error validation styles * apply consistent styles and spacing * feat: update hosting server card (#5609) * fix type errors * fix some stylesheets not imported for storybook * add server listing stories * add fix for frontend stylesheet imports * remove props. * convert copy code to use tailwind * update server listing component styles * update server info label styles * start status/player count info label, more style updates and fixes * add new server card buttons * hook up server cards and implement updated styles * hook up on download button * fix tauri throwing error when api returns 204 No Content * hook up purchase server modal in app * fix upgrading state loading icon * pnpm prepr * filter out servers past 30 days after cancellation * do not apply opacity on lock or spiner icons * fix disabled server icon background * update pending change stage * handle known suspension states * refactor: reduce code duplication for server listing * update disabled state text color * fix loading icon color * clean up copy * fix disabled opacity for server card * update server listing files kept to be countdown * implement resubscribe modal * implement proper provisioning state for resubscribe * fix duplicate attribute and pnpm prepr * feat: add shared UI package auth DI * feat: update purchase server flow (#5714) * implement server list empty state component * fix stories and adjust spacing * implement select plan design refresh * implement auth for empty server list * use refs instead of reactive * pnpm prepr * fix auth usage for empty servers list * move app auth provider setup to src/providers/setup * pnpm prepr * fix max height * style fix * fix getCreds no auth is blocking api client * implement servers guest plan modal and signin which redirects back to modal's next step * refactor guest plan select logic into provider * implement sign in or create account popup * remove force empty serverList * add download button for suspended mod and generic * add handling for when user logs out * QA pass style fixes * more consistent page styles * fix duplicate export * refactor: remove all fallback stuff from resubscribe modal * implement shared download latest backup util * i18n pass * pnpm prepr * fix region being selected if ping failed * pnpm prepr * feat: servers in app finalization (#5744) * feat: start on shared console implementation into logs and overview pages * fix: terminal gap issues * feat: swap word wrap for full screen * fix: stats cards alignment * fix: stats * feat: fix console clear + remove copy * fix: lint * fix: use reset not clear * feat: shared server header & overview page for app and website (#5736) * feat: implement shared server header for app and website * feat: implement wrapped overview page with shared composable and hook it up * pnpm prepr * fix: bugs * qa: cleanup * feat: root.vue shared layout * feat: delete old options pages + fix discovery frontend * fix: discovery * fix: misc style/layout issues * fix page padding * fix: modal height jankiness * feat: implement server install content in app and server setup modal with DI * fix: spacing * remove servers in app feature flag * Revert "remove servers in app feature flag" This reverts commit 86e284c4bdd6fa42c3c8fbaf1efbec41f4d1c6d2. * fix: qa * feat: remove legacy components from apps/frontend/src/components/ui/servers --------- Co-authored-by: Calum H. (IMB11) <contact@cal.engineer> * qa pass (#5738) * fix: qa * feat: qa * fix: server icon fetch fails due to global node auth race condition overriding each other * fix: lint * fix: server icon upload/sync and centralize logic * fix: server settings modal not closing for server reset * fix: better server sorting * feat: copy address in server listing card * fix: notification panel in modal and when overlapping with action bar * fix: empty server list empty state flashing when refresh, fixed by adding isReady auth flag * feat: use floating action bar for save banner * fix: saving state in save bar * fix: edit server icon styling * fix: confirm modal to have consistent buttons * feat: loading animation for server panel + caching improvements for app * pnpm prepr * feat: search page deduplication (#5754) * fix: action bar behind modal * fix: remove warning modal for stopping * fix: server cards states * we hate webkit we hate webkit * fix: update allocation creation to not use modal * fix: properties tab spacing and styles * feat: add files tab copy * fix: advanced properties icon * fix: remove back to all servers link * feat: add files tab link in copy * fix: server header styles to be consistent with instance * fix: add header icons back * feat: update instance settings icon to be consistent * fix: icon container * feat: upload state persistence across tabs * fix: server labels text wrapping * fix: use surface-5 border * fix: loading spinner showing with onboarding below * feat: new server button shows purchase modal in website * fix: billing page not showing quarterly interval * fix: server downgrade not showing updated subscription notification * fix: server settings invalidate saved state and remove server context provider since its already provided in the page * pnpm prepr * add stripe publishable key to app build * feat: console highlighting * fix: rename servers title to modrinth hosting * feat: search fix * fix: qa/styles * fix: ip click active and remove power dont ask again * fix: qa * feat: highlighting fix console * fix: disable conflicts action * fix: error dismiss bug * feat: modal clarification * fix: files perms issue * fix: lint * feat: modal fix * enable show uptime * fix: add loading state to edit server icon * fix: notification panel take in has sidebar from settings * fix: consistency pass on app settings * fix: consistency pass on instance settings * pnpm prepr * fix: nagivate to billing button in app to go to website * fix: stripe return url in app causing app to open modrinth.com in tauri * refactor: better show polling UI code * fix: new server polling comparison to use server ids instead of length * fix: buttonstyled story * fix: button styling * fix: content.vue regression * feat: project url redirects * fix: breadcrumbs * fix: purchase with newly added card * fix: console ordering problems * fix: app-frontend missing env config and staging environment * fix: log syncing for instances and server panel accidentally * fix: QA issues * fix: server page loading state * fix: stats card logic * fix: lint * fix: qa * fix: console height padding * fix: terminal padding + loading indicator * feat: update medal server listing styling * fix: no upgrade button for medal server listing in app * fix: go to overview instead of content tab after onboarding * fix: qa * fix: teleport modals to body * fix: logs tab + qa * fix: local storage for user preferences * fix: qa loading indic * feat: considitonal debug and trace * fix: jump to top on install bug * feat: swap out server hard drive icon to server stack icon * feat: servers in app feature flag default true * fix: highlight row ufll * fix: webkit thing onto a tag * fix: input field * fix: clear fix * fix: lint * fix: fmt * feat: improve share modal and bring it back for sharing log * pnpm prepr * fix: menu overflowing * feat: remove servers in app feature flag * fix: server stat charts no longer showing color * fix: library nav no primary state * fix: better modal height and width * fix: highlighting bugs * fix: empty states * fix: delay import to fix overview page slow load on MacOS * fix: medal server listing too bright on light mode * fix: admon analysis + fix logs * fix: bug * fix: clear purchase intent from sign-in after closing modal * performance: improve server manage stats loading by splitting reactivity * fix: deploy + admon + disable highlighting * fix: clippy --------- Co-authored-by: tdgao <mr.trumgao@gmail.com> Co-authored-by: Truman Gao <106889354+tdgao@users.noreply.github.com> * feat: temp wrangler * fix: lint * fix: logs upload * fix: console empty state and admon regressions * fix: fields * feat: log deleting + prefetch for Logs.vue * feat: move delete before share * feat: clear endpoint * feat: we ball! --------- Co-authored-by: Calum H. <calum@modrinth.com> Co-authored-by: Calum H. (IMB11) <contact@cal.engineer>
1199 lines
20 KiB
SCSS
1199 lines
20 KiB
SCSS
// Bodies + Generic Global Styles
|
|
|
|
.universal-labels {
|
|
label,
|
|
.label {
|
|
:where(.label__title) {
|
|
display: block;
|
|
margin-block: var(--gap-md) var(--gap-sm);
|
|
|
|
// Same styling as h3
|
|
color: var(--color-contrast);
|
|
font-size: 1.17rem;
|
|
font-weight: bold;
|
|
|
|
.required {
|
|
color: var(--color-red);
|
|
}
|
|
|
|
&.size-card-header {
|
|
font-size: var(--font-size-xl);
|
|
margin-bottom: 1rem;
|
|
}
|
|
}
|
|
|
|
:where(.label__description) {
|
|
display: block;
|
|
margin-block-end: var(--gap-sm);
|
|
|
|
.label__subdescription {
|
|
display: block;
|
|
margin-block-start: var(--gap-md);
|
|
}
|
|
}
|
|
|
|
:where(h1, h2, h3, h4) {
|
|
margin-block: 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
.universal-body {
|
|
@extend .universal-labels;
|
|
|
|
.multiselect {
|
|
width: 15rem;
|
|
}
|
|
|
|
> :where(input + *, .input-group + *, .chips + *, .input-div + *) {
|
|
margin-block-start: var(--gap-md);
|
|
}
|
|
|
|
:where(button, .button, .btn) {
|
|
width: fit-content;
|
|
}
|
|
|
|
.input-group {
|
|
input {
|
|
width: auto;
|
|
flex-basis: 0;
|
|
}
|
|
}
|
|
|
|
:where(input) {
|
|
box-sizing: border-box;
|
|
max-height: 40px;
|
|
max-width: 100%;
|
|
}
|
|
|
|
:where(.adjacent-input, &.adjacent-input) {
|
|
display: flex;
|
|
flex-direction: row;
|
|
align-items: center;
|
|
flex-wrap: wrap;
|
|
gap: var(--gap-sm);
|
|
margin-bottom: calc(var(--gap-sm) + var(--gap-md));
|
|
|
|
.btn,
|
|
.input-group {
|
|
flex-shrink: 0;
|
|
}
|
|
|
|
input {
|
|
flex-shrink: 1;
|
|
}
|
|
|
|
> :first-child {
|
|
flex-shrink: 2;
|
|
flex-grow: 1;
|
|
flex-basis: min-content;
|
|
}
|
|
|
|
label,
|
|
.label {
|
|
.label__title {
|
|
margin-block: 0;
|
|
}
|
|
|
|
.label__description {
|
|
margin-block-end: 0;
|
|
}
|
|
|
|
.label__description:not(:first-child) {
|
|
margin-top: var(--gap-sm);
|
|
}
|
|
}
|
|
|
|
@media screen and (max-width: 750px) {
|
|
&:not(&.small) {
|
|
flex-direction: column;
|
|
align-items: start;
|
|
}
|
|
}
|
|
}
|
|
|
|
h1 {
|
|
display: flex;
|
|
align-items: center;
|
|
}
|
|
|
|
> :first-child {
|
|
margin-block-start: 0;
|
|
}
|
|
|
|
> :last-child {
|
|
margin-block-end: 0;
|
|
}
|
|
|
|
:where(.header__row) {
|
|
display: flex;
|
|
flex-direction: row;
|
|
flex-wrap: wrap;
|
|
gap: var(--gap-sm);
|
|
|
|
* {
|
|
flex-shrink: 0;
|
|
}
|
|
|
|
.header__title {
|
|
margin: 0;
|
|
flex-grow: 1;
|
|
}
|
|
|
|
&:not(:last-child) {
|
|
margin-bottom: var(--gap-md);
|
|
}
|
|
}
|
|
|
|
ul,
|
|
ol {
|
|
ul,
|
|
ol {
|
|
margin-bottom: 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
.input-group {
|
|
display: flex;
|
|
flex-direction: row;
|
|
grid-gap: var(--gap-sm);
|
|
flex-wrap: wrap;
|
|
max-width: 100%;
|
|
align-items: center;
|
|
|
|
.multiselect {
|
|
width: 15rem;
|
|
}
|
|
|
|
input {
|
|
flex-shrink: 2;
|
|
}
|
|
|
|
&.shrink-first {
|
|
:first-child {
|
|
flex-shrink: 2;
|
|
flex-grow: 1;
|
|
flex-basis: min-content;
|
|
}
|
|
|
|
:not(:first-child) {
|
|
flex-shrink: 1;
|
|
}
|
|
}
|
|
}
|
|
|
|
.push-right:not(.input-group),
|
|
.push-right.input-group > :first-child {
|
|
margin-left: auto;
|
|
margin-right: 0;
|
|
}
|
|
|
|
.input-stack {
|
|
display: flex;
|
|
flex-direction: column;
|
|
|
|
> * {
|
|
margin-bottom: var(--gap-md);
|
|
}
|
|
|
|
> .multiselect {
|
|
width: unset;
|
|
height: inherit;
|
|
}
|
|
}
|
|
|
|
.standard-body {
|
|
:last-child {
|
|
margin-bottom: 0;
|
|
}
|
|
}
|
|
|
|
// CLICKABLES/BUTTONS
|
|
a:not(.no-click-animation),
|
|
.clickable {
|
|
transition:
|
|
opacity 0.5s ease-in-out,
|
|
filter 0.2s ease-in-out,
|
|
scale 0.05s ease-in-out,
|
|
outline 0.2s ease-in-out;
|
|
|
|
&:active:not(&:disabled) {
|
|
scale: 0.95;
|
|
}
|
|
}
|
|
|
|
.button-base {
|
|
@extend .clickable;
|
|
font-weight: 500;
|
|
border: none;
|
|
outline: 2px solid transparent;
|
|
|
|
&:focus-visible:not(&:disabled),
|
|
&:hover:not(&:disabled) {
|
|
cursor: pointer;
|
|
|
|
&:not(.btn-outline.btn-hover-filled, .btn-transparent) {
|
|
filter: brightness(0.85);
|
|
}
|
|
}
|
|
|
|
&:active:not(&:disabled, .btn-outline.btn-hover-filled, .btn-transparent) {
|
|
filter: brightness(0.8);
|
|
}
|
|
|
|
&:disabled.quiet-disabled {
|
|
cursor: unset;
|
|
}
|
|
|
|
&:disabled:not(.quiet-disabled),
|
|
&[disabled]:not(.quiet-disabled) {
|
|
cursor: not-allowed;
|
|
filter: grayscale(50%);
|
|
opacity: 0.5;
|
|
box-shadow: none;
|
|
}
|
|
}
|
|
|
|
.button-within {
|
|
transition:
|
|
opacity 0.5s ease-in-out,
|
|
filter 0.2s ease-in-out,
|
|
transform 0.05s ease-in-out,
|
|
outline 0.2s ease-in-out;
|
|
|
|
&:focus-visible:not(&.disabled),
|
|
&:hover:not(&.disabled) {
|
|
filter: brightness(0.85);
|
|
}
|
|
|
|
&:active:not(&.disabled) {
|
|
filter: brightness(0.8);
|
|
}
|
|
|
|
// For some reason this within the above block makes it universal and not only applied to children. SCSS bug maybe?
|
|
&:active:not(&.disabled) button:not(&:disabled) {
|
|
transform: scale(0.95);
|
|
}
|
|
|
|
&.disabled {
|
|
cursor: not-allowed;
|
|
filter: grayscale(50%);
|
|
opacity: 0.5;
|
|
box-shadow: none;
|
|
|
|
&disabled,
|
|
&[disabled] {
|
|
cursor: not-allowed;
|
|
box-shadow: none;
|
|
}
|
|
}
|
|
}
|
|
|
|
.btn {
|
|
@extend .button-base;
|
|
|
|
--_text-color: var(--color-base);
|
|
--_background-color: var(--color-button-bg);
|
|
--_accent-color: var(--color-base);
|
|
--_shadow: var(--shadow-inset-sm), 0 0 0 0 transparent;
|
|
|
|
&.btn-outline,
|
|
&.btn-transparent {
|
|
box-sizing: border-box;
|
|
|
|
background-color: transparent;
|
|
transition:
|
|
background-color 0.2s ease-in-out,
|
|
border-color 0.2s ease-in-out,
|
|
color 0.2s ease-in-out;
|
|
box-shadow: none;
|
|
}
|
|
|
|
&.btn-transparent {
|
|
--_accent-color: var(--color-base);
|
|
color: var(--_accent-color);
|
|
|
|
&.btn-hover-filled-only {
|
|
color: var(--color-base);
|
|
}
|
|
|
|
&:focus-visible:not(&:disabled),
|
|
&:hover:not(&:disabled) {
|
|
background-color: var(--color-button-bg);
|
|
|
|
&.btn-hover-filled,
|
|
&.btn-hover-filled-only {
|
|
color: var(--_text-color);
|
|
background-color: var(--_background-color);
|
|
}
|
|
}
|
|
}
|
|
|
|
&.btn-outline {
|
|
--_accent-color: var(--color-contrast);
|
|
border: 2px solid var(--_accent-color);
|
|
padding-block: calc(var(--gap-sm) - 2px);
|
|
color: var(--_background-color);
|
|
|
|
&.btn-hover-filled-only {
|
|
color: var(--color-contrast);
|
|
border-color: var(--color-contrast);
|
|
}
|
|
|
|
&:focus-visible:not(&:disabled),
|
|
&:hover:not(&:disabled) {
|
|
&.btn-hover-filled,
|
|
&.btn-hover-filled-only {
|
|
border-color: var(--_accent-color);
|
|
color: var(--_text-color);
|
|
background-color: var(--_background-color);
|
|
}
|
|
}
|
|
}
|
|
|
|
&.btn-danger {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-red);
|
|
--_accent-color: var(--color-red);
|
|
}
|
|
|
|
&.btn-primary {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-brand);
|
|
--_accent-color: var(--color-brand);
|
|
}
|
|
|
|
&.btn-secondary {
|
|
--_text-color: var(--color-contrast);
|
|
--_background-color: var(--color-brand-highlight);
|
|
--_accent-color: var(--color-brand-highlight);
|
|
}
|
|
|
|
&.btn-highlight {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-orange);
|
|
--_accent-color: var(--color-orange);
|
|
}
|
|
|
|
&.btn-red {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-red);
|
|
--_accent-color: var(--color-red);
|
|
}
|
|
|
|
&.btn-orange {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-orange);
|
|
--_accent-color: var(--color-orange);
|
|
}
|
|
|
|
&.btn-green {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-green);
|
|
--_accent-color: var(--color-green);
|
|
}
|
|
|
|
&.btn-blue {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-blue);
|
|
--_accent-color: var(--color-blue);
|
|
}
|
|
|
|
&.btn-purple {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-purple);
|
|
--_accent-color: var(--color-purple);
|
|
}
|
|
|
|
&.btn-gray {
|
|
--_text-color: var(--color-accent-contrast);
|
|
--_background-color: var(--color-gray);
|
|
--_accent-color: var(--color-gray);
|
|
}
|
|
|
|
box-sizing: border-box;
|
|
|
|
color: var(--_text-color);
|
|
background-color: var(--_background-color);
|
|
box-shadow: var(--_shadow);
|
|
border-radius: var(--radius-md);
|
|
|
|
padding: var(--gap-sm) var(--gap-lg);
|
|
|
|
display: flex;
|
|
align-items: center;
|
|
cursor: pointer;
|
|
width: fit-content;
|
|
height: fit-content;
|
|
text-decoration: none;
|
|
gap: 0.5rem;
|
|
line-height: 1.25rem;
|
|
|
|
svg {
|
|
width: 1.25rem;
|
|
height: 1.25rem;
|
|
}
|
|
|
|
.external-icon {
|
|
width: 0.75rem;
|
|
height: 0.75rem;
|
|
margin-bottom: auto;
|
|
margin-right: 0;
|
|
}
|
|
|
|
&.icon-only {
|
|
padding: var(--gap-sm);
|
|
}
|
|
|
|
&.transparent {
|
|
background: none;
|
|
box-shadow: none;
|
|
}
|
|
|
|
&.btn-large {
|
|
font-weight: 700;
|
|
padding: 12px 16px;
|
|
font-size: 16px;
|
|
|
|
svg {
|
|
width: 1.5rem;
|
|
height: 1.5rem;
|
|
}
|
|
}
|
|
|
|
&.btn-large-round {
|
|
padding: 0.75rem;
|
|
border-radius: 50%;
|
|
}
|
|
|
|
&.btn-dropdown-animation {
|
|
svg:last-child {
|
|
transition: transform 0.125s ease-in-out;
|
|
}
|
|
|
|
&.popout-open {
|
|
svg:last-child {
|
|
transform: rotate(180deg);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.btn-dropdown-animation svg:last-child {
|
|
transition: transform 0.125s ease-in-out;
|
|
}
|
|
|
|
.v-popper--shown .btn-dropdown-animation svg:last-child {
|
|
transform: rotate(180deg);
|
|
}
|
|
|
|
.btn-group {
|
|
display: flex;
|
|
grid-gap: var(--gap-sm);
|
|
flex-wrap: wrap;
|
|
}
|
|
|
|
.joined-buttons {
|
|
display: flex;
|
|
gap: 1px;
|
|
|
|
> :not(:first-child) {
|
|
&.btn,
|
|
> .btn {
|
|
border-top-left-radius: 0;
|
|
border-bottom-left-radius: 0;
|
|
}
|
|
}
|
|
|
|
> :not(:last-child) {
|
|
&.btn,
|
|
> .btn {
|
|
border-top-right-radius: 0;
|
|
border-bottom-right-radius: 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
// CARDS
|
|
.base-card {
|
|
padding: var(--gap-xl);
|
|
position: relative;
|
|
min-height: var(--font-size-2xl);
|
|
|
|
background-color: var(--color-raised-bg);
|
|
border-radius: var(--radius-lg);
|
|
|
|
margin-bottom: var(--gap-md);
|
|
outline: 2px solid transparent;
|
|
|
|
.card__overlay {
|
|
position: absolute;
|
|
top: 1rem;
|
|
right: 1rem;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: flex-end;
|
|
grid-gap: 0.5rem;
|
|
z-index: 2;
|
|
}
|
|
|
|
&:where(&.warning, &.information) {
|
|
padding: 1.5rem;
|
|
line-height: 1.5;
|
|
min-height: 0;
|
|
|
|
a {
|
|
color: var(--color-blue);
|
|
text-decoration: underline;
|
|
}
|
|
}
|
|
|
|
// TODO: Add back later
|
|
//&.warning {
|
|
// border-left: 0.5rem solid var(--color-warning-banner-side);
|
|
// background-color: var(--color-warning-banner-bg);
|
|
// color: var(--color-warning-banner-text);
|
|
//}
|
|
//
|
|
//&.information {
|
|
// border-left: 0.5rem solid var(--color-info-banner-side);
|
|
// background-color: var(--color-info-banner-bg);
|
|
// color: var(--color-info-banner-text);
|
|
//}
|
|
}
|
|
|
|
.card {
|
|
@extend .base-card;
|
|
@extend .universal-body;
|
|
}
|
|
|
|
.navigation-card {
|
|
@extend .base-card;
|
|
|
|
padding-inline: var(--gap-xl);
|
|
padding-block: var(--gap-md);
|
|
|
|
align-items: center;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
flex-wrap: wrap;
|
|
row-gap: 0.5rem;
|
|
}
|
|
|
|
// UTILITY
|
|
|
|
.wrap-as-needed {
|
|
overflow-wrap: break-word;
|
|
word-wrap: break-word;
|
|
word-break: break-word;
|
|
-webkit-hyphens: auto;
|
|
hyphens: auto;
|
|
}
|
|
|
|
.sr-only {
|
|
position: absolute;
|
|
width: 0;
|
|
height: 0;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.card-divider {
|
|
background-color: var(--color-button-bg);
|
|
border: none;
|
|
color: var(--color-button-bg);
|
|
height: 1px;
|
|
margin: var(--gap-sm) 0;
|
|
}
|
|
|
|
// TABLE
|
|
.table {
|
|
display: grid;
|
|
grid-template-rows: repeat(auto-fill, auto);
|
|
width: 100%;
|
|
border-radius: var(--radius-md);
|
|
overflow: hidden;
|
|
|
|
.table-row {
|
|
display: grid;
|
|
|
|
transition:
|
|
opacity 0.5s ease-in-out,
|
|
filter 0.2s ease-in-out,
|
|
scale 0.05s ease-in-out,
|
|
outline 0.2s ease-in-out;
|
|
|
|
&.selectable:focus-visible,
|
|
&.selectable:hover {
|
|
cursor: pointer;
|
|
filter: brightness(0.85);
|
|
}
|
|
|
|
&.selectable:active {
|
|
filter: brightness(0.8);
|
|
scale: 0.99;
|
|
}
|
|
}
|
|
|
|
.entire-row {
|
|
grid-template-columns: 1fr !important;
|
|
align-items: center;
|
|
}
|
|
|
|
.table-head {
|
|
.table-cell {
|
|
background-color: var(--color-accent-contrast);
|
|
}
|
|
}
|
|
|
|
.table-cell {
|
|
padding: 1rem;
|
|
height: 100%;
|
|
vertical-align: center;
|
|
display: flex;
|
|
}
|
|
|
|
.name-cell {
|
|
padding-left: 0;
|
|
}
|
|
|
|
.table-text {
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: fade;
|
|
}
|
|
|
|
.table-row:nth-child(even) .table-cell {
|
|
background-color: var(--color-bg);
|
|
}
|
|
}
|
|
|
|
// CUSTOM COMPONENTS
|
|
// TODO: MOST OF THESE SHOULD BE MOVED TO AN OMORPHIA COMPONENT
|
|
|
|
// TOOLTIPS
|
|
|
|
.v-popper--theme-dropdown,
|
|
.v-popper--theme-dropdown.v-popper--theme-ribbit-popout {
|
|
.v-popper__inner {
|
|
border: 1px solid var(--color-divider) !important;
|
|
padding: var(--gap-sm) !important;
|
|
width: fit-content !important;
|
|
border-radius: var(--radius-md) !important;
|
|
background-color: var(--color-raised-bg) !important;
|
|
box-shadow: var(--shadow-floating) !important;
|
|
}
|
|
|
|
.v-popper__arrow-outer {
|
|
border-color: var(--color-divider) !important;
|
|
}
|
|
|
|
.v-popper__arrow-inner {
|
|
border-color: var(--color-raised-bg) !important;
|
|
}
|
|
}
|
|
|
|
.v-popper__popper[data-popper-placement='bottom-end'] .v-popper__wrapper {
|
|
transform-origin: top right;
|
|
}
|
|
|
|
.v-popper__popper[data-popper-placement='top-end'] .v-popper__wrapper {
|
|
transform-origin: bottom right;
|
|
}
|
|
|
|
.v-popper__popper[data-popper-placement='bottom-start'] .v-popper__wrapper {
|
|
transform-origin: top left;
|
|
}
|
|
|
|
.v-popper__popper[data-popper-placement='top-start'] .v-popper__wrapper {
|
|
transform-origin: bottom left;
|
|
}
|
|
|
|
.v-popper__popper.v-popper__popper--show-from .v-popper__wrapper {
|
|
transform: scale(0.85);
|
|
opacity: 0;
|
|
}
|
|
|
|
.v-popper__popper.v-popper__popper--show-to .v-popper__wrapper {
|
|
transform: scale(1);
|
|
opacity: 1;
|
|
transition:
|
|
transform 0.125s ease-in-out,
|
|
opacity 0.125s ease-in-out;
|
|
}
|
|
|
|
.v-popper__popper.v-popper__popper--hide-from .v-popper__wrapper {
|
|
transform: none;
|
|
opacity: 1;
|
|
transition: transform 0.0625s;
|
|
}
|
|
|
|
.v-popper__popper.v-popper__popper--hide-to .v-popper__wrapper {
|
|
//transform: scale(.9);
|
|
}
|
|
|
|
.v-popper--theme-tooltip {
|
|
.v-popper__inner {
|
|
background: var(--color-tooltip-bg) !important;
|
|
color: var(--color-tooltip-text) !important;
|
|
padding: 0.5rem 0.5rem !important;
|
|
border-radius: var(--radius-sm) !important;
|
|
filter: drop-shadow(5px 5px 0.8rem rgba(0, 0, 0, 0.35));
|
|
font-size: 0.9rem;
|
|
font-weight: bold;
|
|
line-height: 1;
|
|
}
|
|
|
|
.v-popper__arrow-outer,
|
|
.v-popper__arrow-inner {
|
|
border-color: var(--color-tooltip-bg);
|
|
}
|
|
}
|
|
|
|
.v-popper--theme-dismissable-prompt {
|
|
z-index: 10;
|
|
|
|
.v-popper__inner {
|
|
background: var(--color-raised-bg) !important;
|
|
border: 1px solid var(--color-button-border);
|
|
color: var(--color-tooltip-text) !important;
|
|
padding: 0.75rem 1rem !important;
|
|
border-radius: 0.75rem !important;
|
|
filter: drop-shadow(5px 5px 0.8rem rgba(0, 0, 0, 0.35));
|
|
font-size: 0.9rem;
|
|
font-weight: bold;
|
|
line-height: 1;
|
|
}
|
|
|
|
.v-popper__arrow-outer {
|
|
border-color: var(--color-button-border);
|
|
}
|
|
|
|
.v-popper__arrow-inner {
|
|
border-color: var(--color-raised-bg);
|
|
}
|
|
}
|
|
|
|
// MARKDOWN
|
|
|
|
.markdown-body {
|
|
h1:first-child {
|
|
margin-block-start: 0;
|
|
padding-block-start: 0;
|
|
}
|
|
|
|
blockquote,
|
|
details,
|
|
dl,
|
|
ol,
|
|
p,
|
|
code,
|
|
pre,
|
|
table,
|
|
ul {
|
|
margin-top: 0;
|
|
margin-bottom: 16px;
|
|
}
|
|
|
|
li,
|
|
p {
|
|
padding: 0;
|
|
line-height: 1.5;
|
|
}
|
|
|
|
h1 {
|
|
display: block;
|
|
}
|
|
|
|
h1,
|
|
h2,
|
|
h3 {
|
|
color: var(--color-contrast);
|
|
}
|
|
|
|
h1,
|
|
h2 {
|
|
padding: 10px 0 5px;
|
|
border-bottom: 1px solid var(--color-divider);
|
|
}
|
|
|
|
h1,
|
|
h2,
|
|
h3,
|
|
h4,
|
|
h5,
|
|
h6,
|
|
li,
|
|
p {
|
|
word-wrap: break-word;
|
|
overflow-wrap: anywhere;
|
|
}
|
|
|
|
blockquote {
|
|
padding: 0 1em;
|
|
color: var(--color-base);
|
|
border-left: 0.25em solid var(--color-button-bg);
|
|
margin-inline: 0;
|
|
}
|
|
|
|
a {
|
|
cursor: pointer;
|
|
color: var(--color-blue);
|
|
|
|
&:focus-visible,
|
|
&:hover {
|
|
filter: brightness(1.2);
|
|
text-decoration: none;
|
|
}
|
|
|
|
&:active {
|
|
filter: brightness(1.1);
|
|
text-decoration: none;
|
|
}
|
|
}
|
|
|
|
a:active > img {
|
|
scale: 0.98;
|
|
}
|
|
|
|
img {
|
|
max-width: 100%;
|
|
height: auto;
|
|
display: inline-block;
|
|
}
|
|
|
|
html:not(.dark-mode, .oled-mode) & img[src$='#gh-dark-mode-only'] {
|
|
display: none;
|
|
}
|
|
|
|
html:is(.dark-mode, .oled-mode) & img[src$='#gh-light-mode-only'] {
|
|
display: none;
|
|
}
|
|
|
|
pre {
|
|
margin-top: 1rem;
|
|
padding: 14px;
|
|
border-radius: var(--radius-sm);
|
|
background-color: var(--color-button-bg);
|
|
overflow-x: auto;
|
|
|
|
code {
|
|
font-size: 80%;
|
|
padding: 0;
|
|
border-radius: 0;
|
|
}
|
|
}
|
|
|
|
code {
|
|
padding: 0.2em 0.4em;
|
|
font-size: 80%;
|
|
border-radius: var(--radius-sm);
|
|
background-color: var(--color-button-bg);
|
|
color: var(--color-contrast);
|
|
}
|
|
|
|
hr {
|
|
margin: 20px 0;
|
|
color: var(--color-button-bg);
|
|
}
|
|
|
|
table {
|
|
display: block;
|
|
width: max-content;
|
|
max-width: 100%;
|
|
overflow: auto;
|
|
border-collapse: separate;
|
|
border-spacing: 0;
|
|
line-height: 1.5;
|
|
border: 0.1rem solid var(--color-button-bg);
|
|
border-radius: var(--radius-sm);
|
|
|
|
th {
|
|
font-weight: 600;
|
|
}
|
|
|
|
td,
|
|
th {
|
|
padding: 0.4rem 0.85rem;
|
|
}
|
|
|
|
tr:nth-child(2n) {
|
|
background-color: var(--color-accent-contrast);
|
|
}
|
|
|
|
td:not(:last-of-type),
|
|
th:not(:last-of-type) {
|
|
border-right: 0.1rem solid var(--color-button-bg);
|
|
}
|
|
|
|
tr:not(:last-of-type) td,
|
|
th {
|
|
border-bottom: 0.1rem solid var(--color-button-bg);
|
|
}
|
|
}
|
|
|
|
details {
|
|
border: 0.15rem solid var(--color-button-bg);
|
|
border-radius: var(--radius-sm);
|
|
padding: 0.5rem 0.5rem 0;
|
|
|
|
summary {
|
|
font-weight: bold;
|
|
margin: -0.5rem -0.5rem 0;
|
|
padding: 0.5rem 0.8rem;
|
|
cursor: pointer;
|
|
background-color: var(--color-button-bg);
|
|
border-radius: var(--radius-xs);
|
|
|
|
&:hover {
|
|
filter: brightness(0.85);
|
|
}
|
|
}
|
|
|
|
&[open] {
|
|
padding: 0.5rem;
|
|
|
|
summary {
|
|
margin-bottom: 0.5rem;
|
|
border-radius: var(--radius-xs) var(--radius-xs) 0 0;
|
|
}
|
|
|
|
> :last-child:not(summary) {
|
|
margin-bottom: 0 !important;
|
|
}
|
|
}
|
|
}
|
|
|
|
> :last-child {
|
|
margin-bottom: 0 !important;
|
|
}
|
|
|
|
iframe,
|
|
video {
|
|
aspect-ratio: 16 / 9;
|
|
width: 850px;
|
|
max-width: 100%;
|
|
height: auto;
|
|
}
|
|
|
|
@media screen and (max-width: 1280px) {
|
|
iframe,
|
|
video {
|
|
width: 100%;
|
|
}
|
|
}
|
|
}
|
|
|
|
select {
|
|
-webkit-appearance: none;
|
|
-moz-appearance: none;
|
|
appearance: none;
|
|
|
|
-moz-border-radius: 3px;
|
|
-webkit-border-radius: 3px;
|
|
border-radius: 3px;
|
|
background: #cccccc url(http://dropdown/arrow/url/) no-repeat right center;
|
|
color: #000000;
|
|
border: 1px solid #000000;
|
|
}
|
|
|
|
.goto-link {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 3px;
|
|
|
|
color: var(--color-blue);
|
|
}
|
|
|
|
.goto-link:hover,
|
|
.goto-link:focus-visible {
|
|
filter: brightness(1.1);
|
|
text-decoration: underline;
|
|
}
|
|
|
|
.goto-link:active {
|
|
filter: brightness(1.2);
|
|
}
|
|
|
|
.multiselect {
|
|
color: var(--color-base) !important;
|
|
outline: 2px solid transparent;
|
|
width: 100% !important;
|
|
|
|
.multiselect__input:focus-visible {
|
|
outline: none !important;
|
|
box-shadow: none !important;
|
|
padding: 0 !important;
|
|
min-height: 0 !important;
|
|
font-weight: normal !important;
|
|
margin-left: 0.5rem;
|
|
margin-bottom: 10px;
|
|
}
|
|
|
|
input {
|
|
background: transparent;
|
|
box-shadow: none;
|
|
border: none !important;
|
|
|
|
&:focus {
|
|
box-shadow: none;
|
|
}
|
|
}
|
|
|
|
input::placeholder {
|
|
color: var(--color-base);
|
|
}
|
|
|
|
.multiselect__tags {
|
|
border-radius: var(--radius-md);
|
|
background: var(--color-button-bg);
|
|
box-shadow: var(--shadow-inset-sm);
|
|
border: none;
|
|
cursor: pointer;
|
|
padding-left: 7px;
|
|
padding-top: 10px;
|
|
font-size: 1rem;
|
|
|
|
transition: background-color 0.1s ease-in-out;
|
|
|
|
&:active {
|
|
filter: brightness(1.25);
|
|
|
|
.multiselect__spinner {
|
|
filter: brightness(1.25);
|
|
}
|
|
}
|
|
|
|
.multiselect__single {
|
|
background: transparent;
|
|
}
|
|
|
|
.multiselect__tag {
|
|
border-radius: var(--radius-md);
|
|
color: var(--color-base);
|
|
background: transparent;
|
|
border: 2px solid var(--color-brand);
|
|
}
|
|
|
|
.multiselect__tag-icon {
|
|
background: transparent;
|
|
|
|
&:after {
|
|
color: var(--color-contrast);
|
|
}
|
|
}
|
|
|
|
.multiselect__placeholder {
|
|
color: var(--color-base);
|
|
margin-left: 0.5rem;
|
|
margin-bottom: 8px;
|
|
opacity: 0.6;
|
|
font-size: 1rem;
|
|
line-height: 16px;
|
|
}
|
|
}
|
|
|
|
.multiselect__content-wrapper {
|
|
background: var(--color-button-bg);
|
|
border: none;
|
|
overflow-x: hidden;
|
|
box-shadow: var(--shadow-inset-sm), var(--shadow-floating);
|
|
width: 100%;
|
|
|
|
.multiselect__element {
|
|
.multiselect__option--highlight {
|
|
background: var(--color-button-bg);
|
|
filter: brightness(1.25);
|
|
color: var(--color-contrast);
|
|
}
|
|
|
|
.multiselect__option--selected {
|
|
background: var(--color-brand);
|
|
font-weight: bold;
|
|
color: var(--color-accent-contrast);
|
|
}
|
|
}
|
|
}
|
|
|
|
.multiselect__spinner {
|
|
background: var(--color-button-bg);
|
|
|
|
&:active {
|
|
filter: brightness(1.25);
|
|
}
|
|
}
|
|
|
|
&.multiselect--disabled {
|
|
background: none;
|
|
|
|
.multiselect__current,
|
|
.multiselect__select {
|
|
background: none;
|
|
}
|
|
}
|
|
}
|
|
|
|
.multiselect--above .multiselect__content-wrapper {
|
|
border-top: none !important;
|
|
border-top-left-radius: var(--radius-md) !important;
|
|
border-top-right-radius: var(--radius-md) !important;
|
|
}
|
|
|
|
.preview-radio {
|
|
width: 100% !important;
|
|
border-radius: var(--radius-md);
|
|
padding: 0;
|
|
overflow: hidden;
|
|
border: 1px solid var(--color-divider);
|
|
background-color: var(--color-button-bg);
|
|
color: var(--color-base);
|
|
display: flex;
|
|
flex-direction: column;
|
|
outline: 2px solid transparent;
|
|
|
|
&.selected {
|
|
color: var(--color-contrast);
|
|
|
|
.label {
|
|
.radio {
|
|
color: var(--color-brand);
|
|
}
|
|
|
|
.theme-icon {
|
|
color: var(--color-text);
|
|
}
|
|
}
|
|
}
|
|
|
|
.preview {
|
|
background-color: var(--color-bg);
|
|
padding: 1.5rem;
|
|
outline: 2px solid transparent;
|
|
width: 100%;
|
|
|
|
.example-card {
|
|
margin: 0;
|
|
padding: 1rem;
|
|
outline: 2px solid transparent;
|
|
min-height: 0;
|
|
}
|
|
}
|
|
|
|
.label {
|
|
display: flex;
|
|
align-items: center;
|
|
text-align: left;
|
|
flex-grow: 1;
|
|
padding: var(--gap-md) var(--gap-lg);
|
|
|
|
.radio {
|
|
margin-right: 0.5rem;
|
|
}
|
|
|
|
.theme-icon {
|
|
color: var(--color-secondary);
|
|
margin-left: 0.25rem;
|
|
}
|
|
}
|
|
}
|