710 lines
16 KiB
CSS
710 lines
16 KiB
CSS
@media only screen and (orientation: landscape) {
|
|
.is-mobile .sr-flashcard {
|
|
flex-direction: row;
|
|
}
|
|
|
|
.is-mobile .sr-header {
|
|
flex-direction: column;
|
|
flex: 0 1 0;
|
|
}
|
|
|
|
.is-mobile .sr-content {
|
|
flex: 1 0 0;
|
|
}
|
|
|
|
.is-mobile .sr-response {
|
|
flex-direction: column;
|
|
flex: 0 1 0;
|
|
}
|
|
|
|
.is-mobile .sr-controls {
|
|
flex-direction: column;
|
|
}
|
|
|
|
.is-mobile .sr-title {
|
|
display: none;
|
|
}
|
|
|
|
.is-mobile .sr-response-button {
|
|
writing-mode: vertical-lr;
|
|
}
|
|
}
|
|
|
|
#sr-modal {
|
|
position: absolute;
|
|
top: 50%;
|
|
left: 50%;
|
|
transform: translate(-50%, -50%);
|
|
}
|
|
|
|
#sr-modal .modal-title {
|
|
display: none;
|
|
}
|
|
|
|
#sr-modal .modal-close-button {
|
|
z-index: 21;
|
|
}
|
|
|
|
body:not(.native-scrollbars) #sr-modal .modal-close-button {
|
|
top: 12px;
|
|
}
|
|
|
|
.sr-modal-content {
|
|
position: relative;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.sr-is-hidden {
|
|
display: none !important;
|
|
}
|
|
|
|
.sr-centered {
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
flex-direction: column;
|
|
}
|
|
|
|
.sr-deck-list,
|
|
.sr-flashcard,
|
|
.sr-edit-view {
|
|
display: flex;
|
|
flex-direction: column;
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
|
|
.sr-header {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
align-items: center;
|
|
width: 100%;
|
|
border-bottom: 1px solid var(--hr-color);
|
|
}
|
|
|
|
.sr-title {
|
|
font-size: var(--font-ui-large);
|
|
font-weight: var(--font-semibold);
|
|
text-align: center;
|
|
line-height: var(--line-height-tight);
|
|
}
|
|
|
|
.sr-sub-title {
|
|
font-size: var(--font-ui-medium);
|
|
text-align: center;
|
|
line-height: var(--line-height-tight);
|
|
color: var(--text-muted);
|
|
}
|
|
|
|
.sr-content {
|
|
overflow-y: auto;
|
|
}
|
|
|
|
.sr-button {
|
|
box-shadow: none !important;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.sr-back-button {
|
|
z-index: 21;
|
|
cursor: var(--cursor);
|
|
position: absolute;
|
|
top: 12px;
|
|
left: 12px;
|
|
font-size: 26px;
|
|
line-height: 22px;
|
|
height: 26px;
|
|
width: 26px;
|
|
padding: 0 var(--size-2-2);
|
|
border-radius: var(--radius-s);
|
|
color: var(--text-muted);
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
}
|
|
|
|
.sr-back-button:hover,
|
|
.sr-button:hover {
|
|
background-color: var(--background-modifier-hover);
|
|
}
|
|
|
|
.sr-response {
|
|
display: flex;
|
|
width: 100%;
|
|
margin-top: var(--size-4-4);
|
|
gap: var(--size-4-4);
|
|
}
|
|
|
|
.sr-response-button {
|
|
height: 48px;
|
|
flex-grow: 1;
|
|
margin: auto;
|
|
line-height: 48px;
|
|
text-align: center;
|
|
cursor: pointer;
|
|
border-radius: 4px;
|
|
user-select: text;
|
|
}
|
|
|
|
.sr-bg-blue,
|
|
.sr-bg-green,
|
|
.sr-bg-red {
|
|
color: #ffffff !important;
|
|
}
|
|
|
|
.sr-bg-green {
|
|
background-color: #4caf50 !important;
|
|
}
|
|
|
|
.sr-bg-blue {
|
|
background-color: #2094f3 !important;
|
|
}
|
|
|
|
.sr-bg-red {
|
|
background-color: #ff7043 !important;
|
|
}
|
|
|
|
.sr-deck-list .sr-tree-item-row:hover .sr-bg-green,
|
|
.sr-response-button.sr-bg-green:hover {
|
|
background-color: hsl(122, 39%, 44%) !important;
|
|
}
|
|
|
|
.sr-deck-list .sr-tree-item-row:hover .sr-bg-blue,
|
|
.sr-response-button.sr-bg-blue:hover {
|
|
background-color: hsl(207, 90%, 49%) !important;
|
|
}
|
|
|
|
.sr-deck-list .sr-tree-item-row:hover .sr-bg-red,
|
|
.sr-response-button.sr-bg-red:hover {
|
|
background-color: hsl(14, 100%, 58%) !important;
|
|
}
|
|
|
|
/* -> DeckListView */
|
|
|
|
.sr-deck-list .sr-header {
|
|
gap: 8px;
|
|
padding-bottom: 14px;
|
|
margin-bottom: 24px;
|
|
}
|
|
|
|
.sr-deck-list .sr-header-stats-container {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 8px;
|
|
}
|
|
|
|
.sr-deck-list .sr-header-stats-count {
|
|
display: flex;
|
|
color: #ffffff;
|
|
padding: 4px;
|
|
gap: 4px;
|
|
}
|
|
|
|
.sr-deck-list .sr-header-stats-count > *:first-child {
|
|
min-width: 10ch;
|
|
}
|
|
|
|
.sr-deck-list .sr-header-stats-count > *:last-child {
|
|
min-width: 3ch;
|
|
text-align: right;
|
|
}
|
|
|
|
.sr-deck-list .sr-tree-item-row {
|
|
padding-top: 2px;
|
|
padding-bottom: 2px;
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
.sr-deck-list .sr-tree-stats-container {
|
|
display: flex;
|
|
gap: 4px;
|
|
}
|
|
|
|
.sr-deck-list .sr-tree-stats-count {
|
|
min-width: 3ch;
|
|
padding: 4px;
|
|
box-sizing: content-box;
|
|
text-align: center;
|
|
color: #ffffff !important;
|
|
}
|
|
|
|
/* -> FlashcardReviewView */
|
|
|
|
.sr-flashcard .sr-header {
|
|
position: relative;
|
|
gap: 8px;
|
|
padding-bottom: 8px;
|
|
}
|
|
|
|
.sr-flashcard .sr-title-wrapper {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
align-items: center;
|
|
gap: 4px;
|
|
}
|
|
|
|
.sr-flashcard .sr-button:disabled {
|
|
cursor: not-allowed;
|
|
}
|
|
|
|
.sr-flashcard .sr-controls {
|
|
display: flex;
|
|
gap: var(--size-4-4);
|
|
}
|
|
|
|
.sr-flashcard .sr-context {
|
|
font-style: italic;
|
|
color: var(--text-faint);
|
|
display: block;
|
|
width: 100%;
|
|
margin-top: 12px;
|
|
margin-bottom: 4px;
|
|
margin-left: 8px;
|
|
}
|
|
|
|
.sr-flashcard .sr-content {
|
|
font-size: var(--font-text-size);
|
|
overflow-y: auto;
|
|
user-select: text;
|
|
padding-inline: 8px;
|
|
width: 100%;
|
|
flex-grow: 1;
|
|
}
|
|
|
|
.sr-flashcard .sr-card-divide {
|
|
backdrop-filter: invert(40%);
|
|
border-top-style: dashed;
|
|
}
|
|
|
|
/* -> EditModal */
|
|
|
|
.sr-edit-modal {
|
|
height: 80%;
|
|
}
|
|
|
|
.sr-edit-view {
|
|
height: 100%;
|
|
width: 100%;
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
align-items: center;
|
|
gap: var(--size-4-4);
|
|
}
|
|
|
|
.sr-edit-view .sr-input {
|
|
flex-grow: 1;
|
|
width: 100%;
|
|
resize: none;
|
|
}
|
|
|
|
.sr-edit-view .sr-response {
|
|
display: grid;
|
|
grid-template-columns: auto auto auto;
|
|
width: 100%;
|
|
margin-top: 0;
|
|
}
|
|
|
|
.sr-edit-view .sr-response-button {
|
|
width: 100%;
|
|
}
|
|
|
|
.sr-edit-view .sr-response-button.sr-spacer {
|
|
opacity: 0;
|
|
cursor: default;
|
|
}
|
|
|
|
/* -> Statistics */
|
|
|
|
#sr-chart-period {
|
|
appearance: menulist;
|
|
border-right: 8px solid transparent;
|
|
}
|
|
|
|
/*
|
|
* Tab elements
|
|
* This CSS is copied from https://github.com/Taitava/obsidian-shellcommands
|
|
* Jarkko Linnanvirta https://github.com/Taitava comments below...
|
|
* - Renamed classes
|
|
*
|
|
* This CSS is copied 2021-10-21 from https://www.w3schools.com/howto/howto_js_tabs.asp
|
|
* Modifications:
|
|
* - Renamed classes
|
|
* - Added tab icons.
|
|
* - Changed colors.
|
|
* - Changed/removed borders.
|
|
* - Removed button transition.
|
|
* - Changed button border-radiuses
|
|
* - Added margin-right rule to .sr-tab-header-button .
|
|
*/
|
|
|
|
/* Style the tab */
|
|
.sr-tab-header {
|
|
border-bottom: 6px solid var(--background-modifier-border);
|
|
}
|
|
|
|
/* Style the buttons that are used to open the tab content */
|
|
button.sr-tab-header-button {
|
|
background-color: unset;
|
|
border: none;
|
|
box-shadow: none; /* Remove a "border" that came via Obsidian 0.16.0. */
|
|
outline: none;
|
|
cursor: pointer;
|
|
padding: 14px 16px;
|
|
margin-right: 6px; /* Reduced margin. Obsidian's default margin-right for button is 12px (0 for other margins). */
|
|
border-radius: 10px 10px 0 0; /* 0 0 = No border-radius at bottom */
|
|
}
|
|
|
|
/* Create an active/current tablink class */
|
|
button.sr-tab-header-button.sr-tab-active,
|
|
button.sr-tab-header-button:hover {
|
|
background-color: var(--background-modifier-border);
|
|
}
|
|
|
|
.sr-tab-header-button svg {
|
|
vertical-align: middle; /* Not middle but close enough. */
|
|
}
|
|
|
|
/* Style the tab content */
|
|
.sr-tab-content {
|
|
display: none;
|
|
padding: 6px 12px;
|
|
}
|
|
|
|
.sr-tab-content.sr-tab-active {
|
|
display: block;
|
|
}
|
|
|
|
/*
|
|
* gridjs
|
|
* put everything SR plugin specific above this block
|
|
*/
|
|
.gridjs-footer button,
|
|
.gridjs-head button {
|
|
background-color: transparent;
|
|
background-image: none;
|
|
border: none;
|
|
cursor: pointer;
|
|
margin: 0;
|
|
outline: none;
|
|
padding: 0;
|
|
}
|
|
.gridjs-temp {
|
|
position: relative;
|
|
}
|
|
.gridjs-head {
|
|
margin-bottom: 5px;
|
|
padding: 5px 1px;
|
|
width: 100%;
|
|
}
|
|
.gridjs-head:after {
|
|
clear: both;
|
|
content: "";
|
|
display: block;
|
|
}
|
|
.gridjs-head:empty {
|
|
border: none;
|
|
padding: 0;
|
|
}
|
|
.gridjs-container {
|
|
color: #000;
|
|
display: inline-block;
|
|
overflow: hidden;
|
|
padding: 2px;
|
|
position: relative;
|
|
z-index: 0;
|
|
}
|
|
.gridjs-footer {
|
|
background-color: #fff;
|
|
border-bottom-width: 1px;
|
|
border-color: #e5e7eb;
|
|
border-radius: 0 0 8px 8px;
|
|
border-top: 1px solid #e5e7eb;
|
|
box-shadow:
|
|
0 1px 3px 0 rgba(0, 0, 0, 0.1),
|
|
0 1px 2px 0 rgba(0, 0, 0, 0.26);
|
|
display: block;
|
|
padding: 12px 24px;
|
|
position: relative;
|
|
width: 100%;
|
|
z-index: 5;
|
|
}
|
|
.gridjs-footer:empty {
|
|
border: none;
|
|
padding: 0;
|
|
}
|
|
input.gridjs-input {
|
|
-webkit-appearance: none;
|
|
-moz-appearance: none;
|
|
appearance: none;
|
|
background-color: #fff;
|
|
border: 1px solid #d2d6dc;
|
|
border-radius: 5px;
|
|
font-size: 14px;
|
|
line-height: 1.45;
|
|
outline: none;
|
|
padding: 10px 13px;
|
|
}
|
|
input.gridjs-input:focus {
|
|
border-color: #9bc2f7;
|
|
box-shadow: 0 0 0 3px rgba(149, 189, 243, 0.5);
|
|
}
|
|
.gridjs-pagination {
|
|
color: #3d4044;
|
|
}
|
|
.gridjs-pagination:after {
|
|
clear: both;
|
|
content: "";
|
|
display: block;
|
|
}
|
|
.gridjs-pagination .gridjs-summary {
|
|
float: left;
|
|
margin-top: 5px;
|
|
}
|
|
.gridjs-pagination .gridjs-pages {
|
|
float: right;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button {
|
|
background-color: #fff;
|
|
border: 1px solid #d2d6dc;
|
|
border-right: none;
|
|
outline: none;
|
|
padding: 5px 14px;
|
|
-webkit-user-select: none;
|
|
-moz-user-select: none;
|
|
user-select: none;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button:focus {
|
|
border-right: 1px solid #d2d6dc;
|
|
box-shadow: 0 0 0 2px rgba(149, 189, 243, 0.5);
|
|
margin-right: -1px;
|
|
position: relative;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button:hover {
|
|
background-color: #f7f7f7;
|
|
color: #3c4257;
|
|
outline: none;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button:disabled,
|
|
.gridjs-pagination .gridjs-pages button:hover:disabled,
|
|
.gridjs-pagination .gridjs-pages button[disabled] {
|
|
background-color: #fff;
|
|
color: #6b7280;
|
|
cursor: default;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button.gridjs-spread {
|
|
background-color: #fff;
|
|
box-shadow: none;
|
|
cursor: default;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button.gridjs-currentPage {
|
|
background-color: #f7f7f7;
|
|
font-weight: 700;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button:last-child {
|
|
border-bottom-right-radius: 6px;
|
|
border-right: 1px solid #d2d6dc;
|
|
border-top-right-radius: 6px;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button:first-child {
|
|
border-bottom-left-radius: 6px;
|
|
border-top-left-radius: 6px;
|
|
}
|
|
.gridjs-pagination .gridjs-pages button:last-child:focus {
|
|
margin-right: 0;
|
|
}
|
|
button.gridjs-sort {
|
|
background-color: transparent;
|
|
background-position-x: center;
|
|
background-repeat: no-repeat;
|
|
background-size: contain;
|
|
border: none;
|
|
cursor: pointer;
|
|
float: right;
|
|
height: 24px;
|
|
margin: 0;
|
|
outline: none;
|
|
padding: 0;
|
|
width: 13px;
|
|
}
|
|
button.gridjs-sort-neutral {
|
|
background-image: url("");
|
|
background-position-y: center;
|
|
opacity: 0.3;
|
|
}
|
|
button.gridjs-sort-asc {
|
|
background-image: url("");
|
|
background-position-y: 35%;
|
|
background-size: 10px;
|
|
}
|
|
button.gridjs-sort-desc {
|
|
background-image: url("");
|
|
background-position-y: 65%;
|
|
background-size: 10px;
|
|
}
|
|
button.gridjs-sort:focus {
|
|
outline: none;
|
|
}
|
|
table.gridjs-table {
|
|
border-collapse: collapse;
|
|
display: table;
|
|
margin: 0;
|
|
max-width: 100%;
|
|
overflow: auto;
|
|
padding: 0;
|
|
table-layout: fixed;
|
|
text-align: left;
|
|
width: 100%;
|
|
}
|
|
.gridjs-tbody,
|
|
td.gridjs-td {
|
|
background-color: #fff;
|
|
}
|
|
td.gridjs-td {
|
|
border: 1px solid #e5e7eb;
|
|
box-sizing: content-box;
|
|
padding: 12px 24px;
|
|
}
|
|
td.gridjs-td:first-child {
|
|
border-left: none;
|
|
}
|
|
td.gridjs-td:last-child {
|
|
border-right: none;
|
|
}
|
|
td.gridjs-message {
|
|
text-align: center;
|
|
}
|
|
th.gridjs-th {
|
|
background-color: #f9fafb;
|
|
border: 1px solid #e5e7eb;
|
|
border-top: none;
|
|
box-sizing: border-box;
|
|
color: #6b7280;
|
|
outline: none;
|
|
padding: 14px 24px;
|
|
position: relative;
|
|
-webkit-user-select: none;
|
|
-moz-user-select: none;
|
|
user-select: none;
|
|
vertical-align: middle;
|
|
white-space: nowrap;
|
|
}
|
|
th.gridjs-th .gridjs-th-content {
|
|
float: left;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
width: 100%;
|
|
}
|
|
th.gridjs-th-sort {
|
|
cursor: pointer;
|
|
}
|
|
th.gridjs-th-sort .gridjs-th-content {
|
|
width: calc(100% - 15px);
|
|
}
|
|
th.gridjs-th-sort:focus,
|
|
th.gridjs-th-sort:hover {
|
|
background-color: #e5e7eb;
|
|
}
|
|
th.gridjs-th-fixed {
|
|
box-shadow: 0 1px 0 0 #e5e7eb;
|
|
position: sticky;
|
|
}
|
|
@supports (-moz-appearance: none) {
|
|
th.gridjs-th-fixed {
|
|
box-shadow: 0 0 0 1px #e5e7eb;
|
|
}
|
|
}
|
|
th.gridjs-th:first-child {
|
|
border-left: none;
|
|
}
|
|
th.gridjs-th:last-child {
|
|
border-right: none;
|
|
}
|
|
.gridjs-tr {
|
|
border: none;
|
|
}
|
|
.gridjs-tr-selected td {
|
|
background-color: #ebf5ff;
|
|
}
|
|
.gridjs-tr:last-child td {
|
|
border-bottom: 0;
|
|
}
|
|
.gridjs *,
|
|
.gridjs :after,
|
|
.gridjs :before {
|
|
box-sizing: border-box;
|
|
}
|
|
.gridjs-wrapper {
|
|
-webkit-font-smoothing: antialiased;
|
|
-moz-osx-font-smoothing: grayscale;
|
|
border-color: #e5e7eb;
|
|
border-radius: 8px 8px 0 0;
|
|
border-top-width: 1px;
|
|
box-shadow:
|
|
0 1px 3px 0 rgba(0, 0, 0, 0.1),
|
|
0 1px 2px 0 rgba(0, 0, 0, 0.26);
|
|
display: block;
|
|
overflow: auto;
|
|
position: relative;
|
|
width: 100%;
|
|
z-index: 1;
|
|
}
|
|
.gridjs-wrapper:nth-last-of-type(2) {
|
|
border-bottom-width: 1px;
|
|
border-radius: 8px;
|
|
}
|
|
.gridjs-search {
|
|
float: left;
|
|
}
|
|
.gridjs-search-input {
|
|
width: 250px;
|
|
}
|
|
.gridjs-loading-bar {
|
|
background-color: #fff;
|
|
opacity: 0.5;
|
|
z-index: 10;
|
|
}
|
|
.gridjs-loading-bar,
|
|
.gridjs-loading-bar:after {
|
|
bottom: 0;
|
|
left: 0;
|
|
position: absolute;
|
|
right: 0;
|
|
top: 0;
|
|
}
|
|
.gridjs-loading-bar:after {
|
|
animation: shimmer 2s infinite;
|
|
background-image: linear-gradient(
|
|
90deg,
|
|
hsla(0, 0%, 80%, 0),
|
|
hsla(0, 0%, 80%, 0.2) 20%,
|
|
hsla(0, 0%, 80%, 0.5) 60%,
|
|
hsla(0, 0%, 80%, 0)
|
|
);
|
|
content: "";
|
|
transform: translateX(-100%);
|
|
}
|
|
@keyframes shimmer {
|
|
to {
|
|
transform: translateX(100%);
|
|
}
|
|
}
|
|
.gridjs-td .gridjs-checkbox {
|
|
cursor: pointer;
|
|
display: block;
|
|
margin: auto;
|
|
}
|
|
.gridjs-resizable {
|
|
bottom: 0;
|
|
position: absolute;
|
|
right: 0;
|
|
top: 0;
|
|
width: 5px;
|
|
}
|
|
.gridjs-resizable:hover {
|
|
background-color: #9bc2f7;
|
|
cursor: ew-resize;
|
|
}
|