oggui/ogWebconsole/src/app/components/groups/groups.component.css

569 lines
9.6 KiB
CSS

.groups-container {
display: flex;
flex-direction: column;
width: 100%;
height: 100%;
overflow: hidden;
}
.header-container {
display: flex;
justify-content: space-between;
align-items: center;
padding: 10px 10px;
border-bottom: 1px solid #ddd;
}
.main-container {
display: flex;
flex-direction: row;
width: 100%;
height: 100%;
overflow: hidden;
}
.clients-mat-divider {
display: none;
}
@media (max-width: 992px) {
.main-container {
display: flex !important;
flex-direction: column !important;
width: 100% !important;
height: 100% !important;
overflow: hidden !important;
}
.filters-and-tree-container {
display: flex !important;
flex-direction: row !important;
flex-grow: 1 !important;
flex-shrink: 1 !important;
width: 100% !important;
max-width: none !important;
min-width: 0 !important;
padding: 1rem !important;
box-sizing: border-box !important;
min-height: 250px !important;
overflow-y: auto !important;
}
.filters-panel,
.tree-container {
flex: 1 1 50% !important;
overflow-y: auto !important;
padding: 0.5rem !important;
box-sizing: border-box !important;
margin-bottom: 0 !important;
}
.filters-container {
padding: 0 !important;
}
.tree-mat-divider {
display: none !important;
}
.clients-mat-divider {
display: inline;
}
.clients-view-header {
display: flex;
flex-direction: row !important;
justify-content: space-between !important;
margin-bottom: 0.5rem !important;
margin-top: 0.5rem !important;
align-items: center !important;
padding-right: 1rem !important;
}
.groups-button-row {
display: none !important;
}
.cards-view {
max-height: none !important;
}
.clients-table {
max-height: unset !important;
overflow: unset !important;
display: table !important;
flex-direction: unset !important;
}
.clients-container {
padding: 0em 1em 0em 1em !important;
}
}
@media (max-width: 1400px) {
.type-view-text {
display: none;
}
}
@media (max-width: 450px) {
.clients-title-name {
font-size: 20px !important;
}
}
.header-container-title {
flex-grow: 1;
text-align: left;
margin-left: 1em;
}
.groups-button-row {
display: flex;
gap: 15px;
padding-right: 0.5rem;
}
.clients-view-header {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 0.5rem;
margin-top: 0.5rem;
align-items: center;
padding-right: 1rem;
}
@media (max-width: 768px) {
.clients-view-header {
display: flex;
flex-direction: column !important;
}
}
.clients-title-name {
font-size: x-large;
display: block;
padding: 1rem 1rem 1rem 13px;
margin-left: 0.6rem;
flex: 1 1 auto;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.view-type-container {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
align-items: center;
flex-shrink: 0;
}
.clients-view {
flex-grow: 1;
overflow-y: auto;
}
.cards-view {
max-height: calc(100vh - 330px);
overflow: auto;
display: flex;
flex-direction: row;
flex-grow: 1;
overflow: auto;
}
.cards-select-all {
position: sticky;
top: 0;
z-index: 1;
padding-top: 0.5rem;
padding-left: 1rem;
}
.list-view {
overflow-x: auto;
}
.clients-table {
max-height: calc(100vh - 330px);
overflow: auto;
display: flex;
flex-direction: column;
width: 100%;
table-layout: auto;
border-collapse: collapse;
}
.clients-table th,
.clients-table td {
text-align: left;
padding: 8px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.clients-table th {
font-weight: 500;
}
.clients-table td {
border-bottom: 1px solid #ddd;
}
.paginator-container {
display: flex;
justify-content: end;
margin-top: auto;
}
.cards-paginator {
width: 100%;
margin-left: 1rem;
background-color: #fafafa;
}
.list-paginator {
width: 100%;
background-color: #f3f3f3;
}
.actions mat-icon {
color: #757575;
cursor: pointer;
transition: color 0.2s;
}
.actions mat-icon:hover {
color: #1976d2;
}
.search-container {
display: flex;
gap: 20px;
margin: 20px 0;
}
.search-container mat-form-field {
flex: 1;
}
mat-tree {
background-color: #f9f9f9;
padding: 0px 10px 10px 10px;
}
mat-tree mat-tree-node {
display: flex;
align-items: center;
padding: 10px;
border-radius: 6px;
transition: background-color 0.2s, color 0.2s;
cursor: pointer;
}
mat-tree mat-tree-node:hover {
background-color: #e3f2fd;
}
mat-tree mat-tree-node button.mat-icon-button {
margin-left: auto;
color: #757575;
}
mat-tree mat-tree-node button.mat-icon-button:hover {
color: #1976d2;
}
mat-tree mat-tree-node span {
font-size: 16px;
font-weight: 500;
color: #555;
}
mat-tree mat-tree-node mat-icon {
margin-right: 10px;
color: #757575;
transition: color 0.2s;
}
mat-tree mat-tree-node.expandable mat-icon {
color: black;
cursor: pointer;
}
mat-tree mat-tree-node.expandable.disabled mat-icon {
color: grey;
opacity: 0.5;
cursor: not-allowed;
}
mat-tree mat-tree-node:hover mat-icon {
color: black;
}
mat-tree mat-tree-node mat-icon.node-icon {
color: #757575;
margin-right: 10px;
}
mat-tree mat-tree-node mat-icon.node-icon.organizational-unit {
color: #1976d2;
}
mat-tree mat-tree-node mat-icon.node-icon.classroom {
color: #757575;
}
mat-tree mat-tree-node mat-icon.node-icon.client {
color: #757575;
}
mat-tree mat-tree-node mat-icon.node-icon.group {
color: #757575;
}
mat-tree mat-tree-node button.mat-icon-button {
margin-right: 10px;
}
mat-tree mat-tree-node button.mat-icon-button.disabled-toggle {
color: grey;
opacity: 0.5;
cursor: not-allowed;
}
mat-tree mat-tree-node button.mat-icon-button.disabled-toggle:hover {
background-color: transparent;
}
mat-tree mat-tree-node:hover {
background-color: #e3f2fd;
cursor: pointer;
}
mat-tree mat-tree-node.disabled {
cursor: not-allowed;
}
mat-tree mat-tree-node.disabled:hover {
background-color: transparent;
}
.selected-node {
background-color: #e0f7fa;
border-left: 4px solid #3F51B5;
padding-left: calc(16px - 4px);
}
.mat-menu-item .mat-menu-item-submenu-icon {
display: none;
}
.clients-card-container {
display: flex;
flex-wrap: wrap;
gap: 16px;
padding: 16px;
justify-content: flex-start;
}
.client-name {
display: block;
font-weight: 500;
margin-bottom: 5px;
margin-top: 5px;
padding-left: 1rem;
padding-right: 1rem;
}
.clients-container {
flex: 8;
box-sizing: border-box;
overflow: hidden;
display: flex;
flex-direction: column;
padding: 0rem 1rem 0rem 0.5rem;
}
.filters-and-tree-container {
flex: 2;
display: flex;
flex-direction: column;
flex-shrink: 1;
width: 100%;
box-sizing: border-box;
}
.filters-container {
display: flex;
flex-direction: column;
padding: 1em;
flex-grow: 1;
}
.filter-form-field {
flex: 1;
min-width: 150px;
max-width: 100%;
box-sizing: border-box;
}
.filters-panel {
flex-shrink: 0;
}
.tree-container {
flex-grow: 1;
overflow-y: auto;
max-height: calc(100% - var(--filters-panel-height));
margin-bottom: 1rem;
}
.client-item {
display: flex;
justify-content: center;
}
.client-card {
background-color: #fff;
border: 1px solid #ccc;
border-radius: 8px;
overflow: hidden;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
width: 100%;
max-width: 300px;
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
transition: transform 0.3s ease, box-shadow 0.3s ease;
position: relative;
}
.client-card:hover {
transform: translateY(-5px);
box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
}
.client-details {
flex-grow: 1;
display: flex;
flex-direction: column;
justify-content: space-between;
margin-top: 4px;
}
.type-view-text {
margin-left: 0.5vw;
}
.action-icons {
display: flex;
justify-content: center;
align-items: center;
gap: 1px;
margin-top: 10px;
}
.client-status-container {
display: flex;
align-items: center;
gap: 5px;
}
.client-ip {
display: block;
font-size: 0.9em;
color: #666;
}
.clients-list {
display: flex;
flex-direction: column;
gap: 4px;
}
.sync-spinner {
margin-left: 1em;
margin-right: 1em;
}
.mat-elevation-z8 {
box-shadow: 0px 0px 0px rgba(0, 0, 0, 0.2);
}
.client-info {
display: flex;
flex-direction: column;
gap: 3px;
margin: 5px;
}
.client-item {
position: relative;
}
.no-clients-info {
display: flex;
align-items: center;
gap: 10px;
margin-top: 1.5rem;
margin-left: 1.6rem;
}
mat-button-toggle-group {
border: none;
}
.mat-button-toggle-group .mat-button-toggle {
height: 36px;
background-color: #3f51b5;
color: white;
border: none;
cursor: pointer;
font-size: 16px;
transition: transform 0.3s ease;
font-family: Roboto, "Helvetica Neue", sans-serif;
display: flex;
align-items: center;
justify-content: center;
padding: 0 6px;
}
.mat-button-toggle-group .mat-button-toggle:first-child {
border-top-left-radius: 15px;
border-bottom-left-radius: 15px;
}
.mat-button-toggle-group .mat-button-toggle:last-child {
border-top-right-radius: 15px;
border-bottom-right-radius: 15px;
}
.mat-button-toggle-group .mat-button-toggle:not(:first-child):not(:last-child) {
border-radius: 0;
}
.mat-button-toggle-group .mat-button-toggle:hover {
background-color: #303f9f;
}
.mat-button-toggle-group .mat-button-toggle.mat-button-toggle-checked {
background-color: #303f9f;
}
.mat-button-toggle-group .mat-button-toggle.mat-button-toggle-disabled {
background-color: #c7c7c7;
}
.clients-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
gap: 16px;
padding: 0.5rem 1rem 1rem 1rem;
width: 100%;
box-sizing: border-box;
}