@5minds/node-red-dashboard-2-processcube-dynamic-form
Version:
The ui component for the ProcessCube dynamic-form
704 lines (592 loc) • 14.2 kB
CSS
.dynamic-form-wrapper {
padding: 10px;
margin: 10px;
border: 1px solid black;
}
.dynamic-form-class {
color: green;
font-weight: bold;
}
h1 {
margin-bottom: 10px;
}
h2 {
margin-top: 1.5rem;
margin-bottom: 0.75rem;
}
h3 {
margin-top: 1rem;
}
p {
margin-bottom: 5px;
}
ul li {
list-style-type: circle;
list-style-position: inside;
margin-left: 15px;
}
pre {
padding: 12px;
margin: 12px;
background-color: #eee;
}
code {
font-size: 0.825rem;
color: #ae0000;
}
.ui-dynamic-form-common {
border-radius: 8px;
}
.ui-dynamic-form-light {
box-shadow: 0 4px 16px -3px rgba(0, 0, 0, 0.5);
}
.ui-dynamic-form-dark {
box-shadow: 0 4px 16px -3px rgba(255, 255, 255, 0.9);
background-color: rgba(44, 44, 44, 255);
color: rgba(165, 165, 165, 255);
color-scheme: dark;
}
.ui-dynamic-form-default {
border-bottom: 4px solid rgb(var(--v-theme-primary));
box-shadow: 0px 0px 32px 0px #bababa;
background-color: #fff;
color: rgb(var(--v-theme-on-group-background));
}
.ui-dynamic-form-title-default {
background: linear-gradient(131deg, #18181a 26.76%, #242326 100.16%);
padding: 32px;
color: #fff;
font-size: 36px;
font-weight: 700;
border-radius: 8px 8px 0px 0px;
margin-top: 0px;
border: 2px solid #f6f5fa;
border-bottom: none;
text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}
.ui-dynamic-form-title-default hr {
border: 4px solid rgb(var(--v-theme-primary));
border-radius: 2px;
}
.ui-dynamic-form-title-minimal {
padding: 16px;
margin-top: 0px;
border: 2px solid #f6f5fa;
border-bottom: none;
}
.ui-dynamic-form-title-outside {
padding-bottom: 24px;
padding-top: 24px;
font-size: 24px;
font-weight: 700;
}
.ui-dynamic-form-footer-common {
display: flex;
flex-direction: column;
gap: 8px;
margin: 0;
padding-top: 16px;
border-bottom-left-radius: 8px;
border-bottom-right-radius: 8px;
}
.ui-dynamic-form-footer-light {
background-color: rgba(249, 250, 251, 1);
}
.ui-dynamic-form-footer-dark {
background-color: rgba(35, 35, 35, 255);
}
.ui-dynamic-form-footer-action-primary {
border-radius: 8px;
background-color: rgb(var(--v-theme-primary));
padding: 8px;
}
.ui-dynamic-form-footer-action-secondary {
border-radius: 8px;
background-color: transparent ;
border-color: rgb(var(--v-theme-primary));
border: 2px solid;
color: rgb(var(--v-theme-primary));
padding: 8px;
}
.ui-dynamic-form-footer-action-terminate {
background-color: transparent ;
border: none ;
color: #dc3545 ;
text-decoration: none;
padding: 4px 8px ;
min-height: auto ;
font-size: 0.875rem;
cursor: pointer;
box-shadow: none ;
}
.ui-dynamic-form-footer-action-terminate:hover {
background-color: transparent ;
color: #b02a37 ;
text-decoration: underline;
}
.ui-dynamic-form-footer-actions-container {
display: flex;
justify-content: space-between;
align-items: center;
gap: 12px;
width: 100%;
box-sizing: border-box;
}
.ui-dynamic-form-footer-actions-left,
.ui-dynamic-form-footer-actions-right {
display: flex;
gap: 8px;
align-items: center;
}
.ui-dynamic-form-footer-action-button {
min-height: 36px;
padding: 8px 12px;
box-sizing: border-box;
white-space: normal;
word-wrap: break-word;
}
@media screen and (min-width: 600px) {
.ui-dynamic-form-footer-actions-container {
flex-wrap: wrap;
}
.ui-dynamic-form-footer-action-button {
white-space: normal;
word-wrap: break-word;
}
}
.ui-dynamic-form-wrapper {
--fk-color-primary: rgb(var(--v-theme-primary)) ;
--fk-color-border: rgb(var(--v-theme-group-outline)); /* Does not work somehow */
--fk-bg-input: #fff;
--fk-color-input: rgb(var(--v-theme-on-group-background));
--fk-color-help: rgb(var(--v-theme-on-group-background));
--fk-color-border-focus: rgb(var(--v-theme-primary));
}
@media only screen and (min-width: 600px) {
.ui-dynamic-form-external-sizing-wrapper {
max-width: none;
max-height: 90%;
}
}
@media only screen and (max-width: 599px) {
.ui-dynamic-form-external-sizing-wrapper {
max-width: 100vw;
margin: 0;
padding: 0;
overflow-x: hidden;
}
.ui-dynamic-form-wrapper {
padding: 8px;
margin: 0;
overflow-x: hidden;
}
.ui-dynamic-form-formfield-positioner {
padding: 16px;
padding-top: 8px;
max-height: calc(100vh - 200px);
column-gap: 0px;
flex-direction: column;
border-left: none;
border-right: none;
overflow-x: hidden;
}
.ui-dynamic-form-title-default {
padding: 16px;
font-size: 24px;
border-left: none;
border-right: none;
}
.ui-dynamic-form-title-minimal {
padding: 12px;
border-left: none;
border-right: none;
}
.ui-dynamic-form-title-outside {
padding: 12px 16px;
font-size: 20px;
}
.ui-dynamic-form-footer-common {
padding: 12px 16px;
gap: 12px;
margin: 0;
}
.input-light,
.input-default,
.input-dark {
font-size: 16px;
padding: 12px 8px;
min-height: 44px;
}
.ui-dynamic-form-input-label {
font-size: 16px;
padding-bottom: 8px;
}
.ui-dynamic-form-footer-actions-container {
flex-direction: column;
gap: 12px;
align-items: stretch;
width: 100%;
}
.ui-dynamic-form-footer-actions-left,
.ui-dynamic-form-footer-actions-right {
flex-direction: column;
gap: 8px;
width: 100%;
}
.ui-dynamic-form-footer-actions-left > div,
.ui-dynamic-form-footer-actions-right > div {
width: 100%;
}
.ui-dynamic-form-footer-action-button {
min-height: 44px;
padding: 12px 16px;
font-size: 16px;
width: 100%;
box-sizing: border-box;
white-space: normal;
word-wrap: break-word;
}
.ui-dynamic-form-footer-action-button .v-btn__content {
white-space: normal ;
word-wrap: break-word ;
max-width: 100% ;
display: block ;
}
.ui-dynamic-form-footer-action-primary,
.ui-dynamic-form-footer-action-secondary {
min-height: 44px;
font-size: 16px;
width: 100%;
box-sizing: border-box;
}
.ui-dynamic-form-footer-action-primary .v-btn__content,
.ui-dynamic-form-footer-action-secondary .v-btn__content {
white-space: normal ;
word-wrap: break-word ;
max-width: 100% ;
display: block ;
}
.ui-dynamic-form-formfield-positioner .v-row {
margin-bottom: 16px;
flex-basis: 100% ;
}
.ui-dynamic-form-formfield-positioner select,
.ui-dynamic-form-formfield-positioner textarea {
font-size: 16px;
min-height: 44px;
padding: 12px 8px;
}
.ui-dynamic-form-formfield-positioner input[type='checkbox'],
.ui-dynamic-form-formfield-positioner input[type='radio'] {
width: 20px;
height: 20px;
margin-right: 8px;
}
.ui-dynamic-form-formfield-positioner input[type='file'] {
font-size: 16px;
padding: 12px 8px;
}
.ui-dynamic-form-title-default h3 svg,
.ui-dynamic-form-title-minimal h3 svg,
.ui-dynamic-form-title-outside h3 svg {
width: 20px;
height: 20px;
}
.ui-dynamic-form-title-responsive {
gap: 15px ;
flex-wrap: wrap;
}
.ui-dynamic-form-title-responsive img {
max-width: 32px;
height: auto;
}
.ui-dynamic-form-formfield-positioner {
-webkit-overflow-scrolling: touch;
}
}
@media only screen and (max-width: 480px) {
.ui-dynamic-form-formfield-positioner {
padding: 12px;
padding-top: 4px;
}
.ui-dynamic-form-title-default {
padding: 12px;
font-size: 20px;
}
.ui-dynamic-form-title-outside {
font-size: 18px;
}
.input-light,
.input-default,
.input-dark {
font-size: 16px;
padding: 10px 6px;
}
.ui-dynamic-form-input-label {
font-size: 14px;
}
.ui-dynamic-form-footer-action-button {
min-height: 48px;
font-size: 16px;
padding: 12px 16px;
}
}
.cardCollapse-leave-active {
transition: max-height 0.5s ease, opacity 0.2s ease;
max-height: 100vh;
}
.cardCollapse-enter-active {
transition: max-height 0.2s ease, opacity 0.5s ease;
max-height: 100vh;
}
.cardCollapse-enter-from,
.cardCollapse-leave-to {
max-height: 0px;
opacity: 0;
}
.ui-dynamic-form-formfield-positioner {
padding: 32px;
padding-top: 0px;
max-height: 550px;
overflow-y: auto;
display: flex;
flex-wrap: wrap;
flex-direction: row;
column-gap: 20px;
border-left: 2px solid #f6f5fa;
border-right: 2px solid #f6f5fa;
border-radius: 0px 0px 6px 6px;
}
@media (min-width: 600px) {
.ui-dynamic-form-formfield-positioner .v-row:not(.ui-dynamic-form-header-row) {
flex-basis: calc(50% - 10px); /* Default 2 columns, adjust based on form_columns */
}
.ui-dynamic-form-formfield-positioner[data-columns='1'] .v-row:not(.ui-dynamic-form-header-row) {
flex-basis: 100%;
}
.ui-dynamic-form-formfield-positioner[data-columns='2'] .v-row:not(.ui-dynamic-form-header-row) {
flex-basis: calc(50% - 10px);
}
.ui-dynamic-form-formfield-positioner[data-columns='3'] .v-row:not(.ui-dynamic-form-header-row) {
flex-basis: calc(33.333% - 14px);
}
.ui-dynamic-form-formfield-positioner[data-columns='4'] .v-row:not(.ui-dynamic-form-header-row) {
flex-basis: calc(25% - 15px);
}
}
.ui-dynamic-form-formfield-positioner h1,
.ui-dynamic-form-formfield-positioner h2,
.ui-dynamic-form-formfield-positioner h3 {
margin: 0px;
}
.reset-background,
.reset-background .formkit-input:focus {
--fk-bg-input: none ; /*maybe none or (revert)*/
background-color: var(--fk-bg-input) ;
}
.custom-fieldset {
max-width: none ;
}
.input-dark {
background-color: rgba(85, 85, 85, 255);
color: white ;
}
.input-light,
.input-default,
.input-dark {
border-radius: 0px 0px 0px 8px;
font-size: 18px;
font-weight: 400;
font-style: normal;
padding: 4px 8px;
}
.input-light:focus,
.input-dark:focus,
.input-default:focus {
background-color: #f6f5fa;
border-radius: 0 8px 0px 5px;
}
.ui-dynamic-form-input-outlines {
box-shadow: none ;
border-radius: 0px 0px 0px 8px;
border-bottom: 2px solid rgb(var(--v-theme-primary));
border-left: 2px solid rgb(var(--v-theme-primary));
padding-bottom: 2px;
}
.ui-dynamic-form-input-outlines:focus-within {
transition: padding-bottom 0.1s ease-in-out, border-width 0.1s ease-in-out;
border-width: 4px;
padding-bottom: 0px;
}
.ui-dynamic-form-input-label {
font-size: 18px;
font-weight: 400;
font-style: normal;
padding-bottom: 16px;
}
.ui-dynamic-form-paragraph {
font-size: 0.875rem;
line-height: 1.25rem;
}
.ui-dynamic-form-paragraph p {
margin: 1rem 0;
}
.ui-dynamic-form-paragraph p:first-of-type {
margin-top: 0;
margin-bottom: 1rem;
}
.ui-dynamic-form-paragraph a {
color: #2563eb;
text-decoration: underline;
}
.ui-dynamic-form-paragraph a:hover {
color: #1e40af;
}
.ui-dynamic-form-paragraph h1 {
font-size: 1.5rem;
font-weight: bold;
margin: revert;
}
.ui-dynamic-form-paragraph h2 {
font-size: 1.25rem;
font-weight: bold;
margin: revert;
}
.ui-dynamic-form-paragraph h3 {
font-size: 1.125rem;
font-weight: bold;
margin: revert;
}
.ui-dynamic-form-paragraph h4 {
font-size: 1rem;
font-weight: bold;
margin: revert;
}
.ui-dynamic-form-paragraph h5 {
font-size: 0.875rem;
font-weight: bold;
margin: revert;
}
.ui-dynamic-form-paragraph h6 {
font-size: 0.75rem;
font-weight: bold;
margin: revert;
}
.ui-dynamic-form-paragraph code {
color: #e83e8c;
}
.ui-dynamic-form-paragraph pre {
margin: 1rem 0;
background-color: #f3f4f6;
padding: 0.5rem;
border-radius: 0.25rem;
}
.ui-dynamic-form-paragraph pre code {
color: inherit;
}
.ui-dynamic-form-paragraph ol {
list-style-type: decimal;
margin: revert;
padding: revert;
}
.ui-dynamic-form-paragraph ul {
list-style-type: disc;
margin: revert;
padding: revert;
}
.ui-dynamic-form-paragraph blockquote {
margin: revert;
padding: revert;
}
.ui-dynamic-form-image-previews {
margin-bottom: 16px;
padding: 16px;
border: 1px solid #e0e0e0;
border-radius: 8px;
background-color: #f9f9f9;
}
.ui-dynamic-form-image-previews h4 {
margin: 0 0 12px 0;
color: #333;
font-size: 14px;
font-weight: 600;
}
.ui-dynamic-form-preview-grid {
display: flex;
flex-wrap: wrap;
gap: 12px;
}
.ui-dynamic-form-preview-item {
display: flex;
flex-direction: column;
align-items: center;
padding: 8px;
border: 1px solid #ddd;
border-radius: 6px;
background-color: white;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
transition: transform 0.2s ease, box-shadow 0.2s ease;
max-width: 150px;
}
.ui-dynamic-form-preview-item:hover {
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}
.ui-dynamic-form-preview-image {
width: 120px;
height: 80px;
object-fit: cover;
border-radius: 4px;
cursor: pointer;
border: 2px solid transparent;
transition: border-color 0.2s ease;
}
.ui-dynamic-form-preview-image:hover {
border-color: #1976d2;
}
.ui-dynamic-form-preview-info {
display: flex;
flex-direction: column;
align-items: center;
margin-top: 8px;
text-align: center;
}
.ui-dynamic-form-preview-name {
font-size: 12px;
font-weight: 500;
color: #333;
word-break: break-word;
max-width: 120px;
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2;
line-clamp: 2;
-webkit-box-orient: vertical;
}
.ui-dynamic-form-preview-size {
font-size: 10px;
color: #666;
margin-top: 4px;
}
.ui-dynamic-form-file-wrapper {
width: 100%;
}
/* Dark theme adjustments */
.ui-dynamic-form-dark .ui-dynamic-form-image-previews {
background-color: #2d2d2d;
border-color: #555;
}
.ui-dynamic-form-dark .ui-dynamic-form-image-previews h4 {
color: #fff;
}
.ui-dynamic-form-dark .ui-dynamic-form-preview-item {
background-color: #3d3d3d;
border-color: #555;
}
.ui-dynamic-form-dark .ui-dynamic-form-preview-name {
color: #fff;
}
.ui-dynamic-form-dark .ui-dynamic-form-preview-size {
color: #ccc;
}