|
|
|
/**
|
|
|
|
* Moodle forms HTML isn't changeable via renderers (yet?) so this
|
|
|
|
* .less file imports styles from the bootstrap $variables file and
|
|
|
|
* adds them to the existing Moodle form CSS ids and classes.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
.jsenabled .mform .containsadvancedelements .advanced {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.mform .containsadvancedelements .advanced.show {
|
|
|
|
display: flex;
|
|
|
|
}
|
|
|
|
|
|
|
|
#adminsettings span.error {
|
|
|
|
display: inline-block;
|
|
|
|
border: 1px solid $state-danger-border;
|
|
|
|
border-radius: 4px;
|
|
|
|
background-color: $state-danger-bg;
|
|
|
|
padding: 4px;
|
|
|
|
margin-bottom: 4px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.mform .form-inline {
|
|
|
|
.form-control,
|
|
|
|
.custom-select {
|
|
|
|
max-width: 100%;
|
|
|
|
}
|
|
|
|
.form-group {
|
|
|
|
margin: 0.1rem 0.25rem 0.1rem 0;
|
|
|
|
}
|
|
|
|
br + label {
|
|
|
|
justify-content: flex-start;
|
|
|
|
width: 100%;
|
|
|
|
margin-right: 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.unresponsive.mform .form-inline,
|
|
|
|
.unresponsive.mform .form-inline label {
|
|
|
|
display: inline-flex;
|
|
|
|
}
|
|
|
|
|
|
|
|
#jump-to-activity.custom-select {
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.mform fieldset {
|
|
|
|
margin-bottom: $spacer / 2;
|
|
|
|
border-bottom: $border-width solid $table-border-color;
|
|
|
|
}
|
|
|
|
|
|
|
|
@include media-breakpoint-up(sm) {
|
|
|
|
.mform > .form-group {
|
|
|
|
margin-left: $spacer * 1.5;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#adminsettings .form-control[size] {
|
|
|
|
width: auto;
|
|
|
|
}
|
|
|
|
|
|
|
|
.jsenabled .mform .collapsed .fcontainer {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
#adminsettings .error {
|
|
|
|
color: $danger;
|
|
|
|
}
|
|
|
|
|
|
|
|
.mform ul.file-list {
|
|
|
|
padding: 0;
|
|
|
|
margin: 0;
|
|
|
|
list-style: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.mform label .req,
|
|
|
|
.mform label .adv {
|
|
|
|
cursor: help;
|
|
|
|
}
|
|
|
|
/*rtl:ignore*/
|
|
|
|
input#id_externalurl {
|
|
|
|
direction: ltr;
|
|
|
|
}
|
|
|
|
|
|
|
|
#portfolio-add-button {
|
|
|
|
display: inline;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-defaultinfo,
|
|
|
|
.form-label .form-shortname {
|
|
|
|
color: $text-muted;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-label .form-shortname {
|
|
|
|
font-size: $font-size-xs;
|
|
|
|
display: block;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-item .form-inline {
|
|
|
|
display: inline;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-inline label:not(.sr-only):not(.accesshide) + select {
|
|
|
|
margin-left: 0.5rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
.formsettingheading .form-horizontal {
|
|
|
|
color: $text-muted;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Moodle doesn't differentiate between what Bootstrap calls
|
|
|
|
// .uneditable-inputs and form help text. Styling them both as
|
|
|
|
// uneditable looks ugly, styling both as form help is fairly
|
|
|
|
// subtle in it's impact. Going for the latter as the best option.
|
|
|
|
.no-felement.fstatic {
|
|
|
|
color: $text-muted;
|
|
|
|
padding-top: 5px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.no-fitem .fstaticlabel {
|
|
|
|
font-weight: bold;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-item .form-setting .defaultsnext > input {
|
|
|
|
display: inline-block;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-item .form-setting .form-checkbox.defaultsnext {
|
|
|
|
// Need to specify .defaultsnext and the .form-checkbox class
|
|
|
|
// is somewhat randomly re-used on various actual checkboxes
|
|
|
|
// throughout the admin forms, instead of on the wrapper div.
|
|
|
|
margin-top: 5px; // Push down checkboxes to align.
|
|
|
|
display: inline-block; // So above style sticks.
|
|
|
|
}
|
|
|
|
|
|
|
|
#adminsettings h3 {
|
|
|
|
// Copied from bootstrap/forms.less tag legend.
|
|
|
|
display: block;
|
|
|
|
width: 100%;
|
|
|
|
padding: 0;
|
|
|
|
margin-bottom: $line-height-base;
|
|
|
|
font-size: $font-size-lg;
|
|
|
|
line-height: $line-height-base * 2;
|
|
|
|
border: 0;
|
|
|
|
border-bottom: 1px solid #e5e5e5;
|
|
|
|
}
|
|
|
|
|
|
|
|
// I think this could be avoided (or at least tidied up) ifr
|
|
|
|
// we used HTML5 input types like url, phone, email, number etc.
|
|
|
|
/* rtl:ignore */
|
|
|
|
.mform .fitem .felement input[name="email"],
|
|
|
|
.mform .fitem .felement input[name="email2"],
|
|
|
|
.mform .fitem .felement input[name="url"],
|
|
|
|
.mform .fitem .felement input[name="idnumber"],
|
|
|
|
.mform .fitem .felement input[name="phone1"],
|
|
|
|
.mform .fitem .felement input[name="phone2"] {
|
|
|
|
text-align: left;
|
|
|
|
direction: ltr;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Reduce the mediaplugin width when using inside forms.
|
|
|
|
.que.match .mediaplugin {
|
|
|
|
width: 50vw;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* rtl:ignore */
|
|
|
|
#page-admin-grade-edit-scale-edit .error input#id_name {
|
|
|
|
margin-right: 170px;
|
|
|
|
}
|
|
|
|
|
|
|
|
#page-grade-edit-outcome-course .courseoutcomes {
|
|
|
|
margin-left: auto;
|
|
|
|
margin-right: auto;
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
#page-grade-edit-outcome-course .courseoutcomes td {
|
|
|
|
text-align: center;
|
|
|
|
}
|
|
|
|
/* Install Process' text fields Forms, should always be justified to the left */
|
|
|
|
/* rtl:ignore */
|
|
|
|
#installform #id_wwwroot,
|
|
|
|
#installform #id_dirroot,
|
|
|
|
#installform #id_dataroot,
|
|
|
|
#installform #id_dbhost,
|
|
|
|
#installform #id_dbname,
|
|
|
|
#installform #id_dbuser,
|
|
|
|
#installform #id_dbpass,
|
|
|
|
#installform #id_prefix {
|
|
|
|
direction: ltr;
|
|
|
|
}
|
|
|
|
|
|
|
|
.mdl-right > label {
|
|
|
|
// Workaround for repository pop-up because the : are outside the label,
|
|
|
|
// can/should be fixed in filemanager renderers.
|
|
|
|
display: inline-block;
|
|
|
|
}
|
|
|
|
|
|
|
|
.singleselect {
|
|
|
|
max-width: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-item .form-label label {
|
|
|
|
margin-bottom: 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
div#dateselector-calendar-panel {
|
|
|
|
z-index: 3100; /* Set higher than the z-index of the filemanager - see MDL-39047. */
|
|
|
|
}
|
|
|
|
|
|
|
|
fieldset.coursesearchbox label {
|
|
|
|
display: inline;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show the labels above text editors and file managers except on wide screens.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/* Section and module editing forms contain special JS components for the
|
|
|
|
availability system (if enabled). */
|
|
|
|
#id_availabilityconditionsjson[aria-hidden=true],
|
|
|
|
.availability-field [aria-hidden=true] {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.availability-field {
|
|
|
|
label {
|
|
|
|
display: inline-flex;
|
|
|
|
}
|
|
|
|
.availability-group label {
|
|
|
|
vertical-align: top;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.availability-eye {
|
|
|
|
clear: left;
|
|
|
|
float: left;
|
|
|
|
}
|
|
|
|
.availability-inner,
|
|
|
|
.availability-plugincontrols {
|
|
|
|
float: left;
|
|
|
|
@include border-radius($card-border-radius);
|
|
|
|
border: $card-border-width solid $card-border-color;
|
|
|
|
padding: 1rem;
|
|
|
|
margin-top: 0.5rem;
|
|
|
|
}
|
|
|
|
.availability-plugincontrols,
|
|
|
|
.availability-childlist .availability-inner {
|
|
|
|
margin-left: .625rem;
|
|
|
|
}
|
|
|
|
.availability-field .availability-plugincontrols .availability-group select {
|
|
|
|
max-width: 12rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Custom styles for autocomplete form element */
|
|
|
|
/* These styles reserve a standard amount of space in the DOM to avoid flicker when the original select element is replaced */
|
|
|
|
[data-fieldtype=autocomplete] select,
|
|
|
|
[data-fieldtype=tags] select,
|
|
|
|
.form-autocomplete-original-select {
|
|
|
|
visibility: hidden;
|
|
|
|
overflow: hidden;
|
|
|
|
width: 15rem;
|
|
|
|
height: 44px;
|
|
|
|
margin: 0;
|
|
|
|
padding: 0;
|
|
|
|
border: 0;
|
|
|
|
margin-top: $font-size-base * $line-height-base + $input-padding-y-sm;
|
|
|
|
vertical-align: bottom;
|
|
|
|
}
|
|
|
|
.form-autocomplete-selection {
|
|
|
|
margin: $input-padding-y-sm;
|
|
|
|
// Padding top and bottom, plus mb-1 and the 100% lineheight.
|
|
|
|
min-height: 2 * $input-padding-y-sm + 2 * $font-size-base;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-autocomplete-selection [role=option] {
|
|
|
|
cursor: pointer;
|
|
|
|
white-space: inherit;
|
|
|
|
word-break: break-word;
|
|
|
|
line-height: 1.4;
|
|
|
|
text-align: left;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-autocomplete-suggestions {
|
|
|
|
position: absolute;
|
|
|
|
background-color: white;
|
|
|
|
border: $border-width solid $input-border-color;
|
|
|
|
min-width: 206px;
|
|
|
|
max-height: 20em;
|
|
|
|
overflow: auto;
|
|
|
|
margin: $dropdown-spacer 0 0;
|
|
|
|
padding: $dropdown-padding-y 0;
|
|
|
|
z-index: 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-autocomplete-suggestions li {
|
|
|
|
list-style-type: none;
|
|
|
|
padding: $dropdown-item-padding-y $dropdown-item-padding-x;
|
|
|
|
margin: 0;
|
|
|
|
cursor: pointer;
|
|
|
|
color: $body-color;
|
|
|
|
&:hover,
|
|
|
|
&:focus,
|
|
|
|
&[aria-selected="true"] {
|
|
|
|
background-color: $dropdown-link-active-bg;
|
|
|
|
color: $dropdown-link-active-color;
|
|
|
|
}
|
|
|
|
&::before {
|
|
|
|
content: "\200B";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-autocomplete-downarrow {
|
|
|
|
color: $body-color;
|
|
|
|
top: 0.2rem;
|
|
|
|
right: 0.5rem;
|
|
|
|
cursor: pointer;
|
|
|
|
.loading-icon {
|
|
|
|
position: absolute;
|
|
|
|
top: 0;
|
|
|
|
left: 0;
|
|
|
|
background-color: $white;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Undo some bootstrap things */
|
|
|
|
.form-autocomplete-selection + input.form-control {
|
|
|
|
width: auto;
|
|
|
|
display: inline-block;
|
|
|
|
vertical-align: middle;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-autocomplete-selection [data-active-selection=true] {
|
|
|
|
padding: 0.5em;
|
|
|
|
font-size: large;
|
|
|
|
}
|
|
|
|
|
|
|
|
select.form-control {
|
|
|
|
&[size],
|
|
|
|
&[multiple] {
|
|
|
|
padding-right: 0;
|
|
|
|
option {
|
|
|
|
width: fit-content;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Non-bootstrap selects with a size show their contents outside of the element.
|
|
|
|
* Remove when we update to stable bootstrap 4. (MDL-56511) */
|
|
|
|
select[size],
|
|
|
|
select[multiple] {
|
|
|
|
overflow: auto;
|
|
|
|
}
|
|
|
|
|
|
|
|
select[size="1"] {
|
|
|
|
overflow: visible;
|
|
|
|
}
|
|
|
|
|
|
|
|
textarea[data-auto-rows] {
|
|
|
|
overflow-x: hidden;
|
|
|
|
resize: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Display elements under labels in vertical forms regardless of the screen size. */
|
|
|
|
.mform.full-width-labels {
|
|
|
|
.fitem.row {
|
|
|
|
margin-left: 0;
|
|
|
|
margin-right: 0;
|
|
|
|
& > .col-md-3,
|
|
|
|
& > .col-md-9 {
|
|
|
|
flex: 0 0 100%;
|
|
|
|
max-width: 100%;
|
|
|
|
width: inherit;
|
|
|
|
padding-right: 0;
|
|
|
|
padding-left: 0;
|
|
|
|
}
|
|
|
|
&.femptylabel > .col-md-3 {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
.form-control {
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.mform .col-form-label .form-label-addon {
|
|
|
|
margin-left: 0.25rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
@include media-breakpoint-up(sm) {
|
|
|
|
.mform:not(.full-width-labels) .col-form-label .form-label-addon {
|
|
|
|
margin-left: auto;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Allow wrapping an mform in a div with the form-inline class to have an inline, responsive form. */
|
|
|
|
.form-inline {
|
|
|
|
@include media-breakpoint-up(md) {
|
|
|
|
.col-md-9,
|
|
|
|
.col-md-3 {
|
|
|
|
label {
|
|
|
|
margin-left: 1rem;
|
|
|
|
}
|
|
|
|
margin-bottom: 1rem;
|
|
|
|
width: auto;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
[data-fieldtype="modgrade"] .form-group {
|
|
|
|
padding-bottom: $input-padding-y;
|
|
|
|
}
|
|
|
|
|
|
|
|
// We dont' use the mixin because it's expensive.
|
|
|
|
[data-fieldtype="modgrade"] {
|
|
|
|
background-color: $card-bg;
|
|
|
|
@include border-radius($card-border-radius);
|
|
|
|
border: $card-border-width solid $card-border-color;
|
|
|
|
padding: $card-spacer-x;
|
|
|
|
margin-left: $grid-gutter-width / 2;
|
|
|
|
max-width: 30rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Styles for the JS file types browser provided by the "filetypes" element.
|
|
|
|
[data-filetypesbrowserbody] {
|
|
|
|
[aria-expanded="false"] > [role="group"],
|
|
|
|
[aria-expanded="false"] [data-filetypesbrowserfeature="hideifcollapsed"],
|
|
|
|
[aria-expanded="true"] [data-filetypesbrowserfeature="hideifexpanded"] {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// The autocomplete popup needs a display:block container to correctly position to popup.
|
|
|
|
.form-inline[data-fieldtype="autocomplete"],
|
|
|
|
.form-inline[data-fieldtype="tags"] {
|
|
|
|
display: block;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Show editor at 100% width by default.
|
|
|
|
[data-fieldtype="editor"] > div {
|
|
|
|
flex-grow: 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
@include media-breakpoint-up(sm) {
|
|
|
|
.mform fieldset {
|
|
|
|
margin-left: $spacer * 1.5;
|
|
|
|
}
|
|
|
|
.mform fieldset.collapsible legend a.fheader {
|
|
|
|
padding: 0 5px 0 ($spacer * 1.5);
|
|
|
|
margin-left: -($spacer * 1.5);
|
|
|
|
background: url([[pix:t/expanded]]) 0 center no-repeat;
|
|
|
|
}
|
|
|
|
|
|
|
|
.mform fieldset.collapsed legend a.fheader {
|
|
|
|
/*rtl:raw:
|
|
|
|
background-image: url([[pix:t/collapsed_rtl]]);
|
|
|
|
*/
|
|
|
|
/*rtl:remove*/
|
|
|
|
background-image: url([[pix:t/collapsed]]);
|
|
|
|
}
|
|
|
|
|
|
|
|
.mform {
|
|
|
|
.form-inline {
|
|
|
|
.fdefaultcustom {
|
|
|
|
label {
|
|
|
|
justify-content: initial;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Form inset on the left/right.
|
|
|
|
// Used to display an icon/button within the form control.
|
|
|
|
.input-group {
|
|
|
|
&.form-inset {
|
|
|
|
.form-inset-item {
|
|
|
|
position: absolute;
|
|
|
|
padding-top: calc(#{$input-padding-y} + #{$input-border-width});
|
|
|
|
z-index: 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
&.form-inset-left {
|
|
|
|
.form-control {
|
|
|
|
padding-left: $spacer * 1.5;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
&.form-inset-right {
|
|
|
|
.form-control {
|
|
|
|
padding-right: $spacer * 1.5;
|
|
|
|
}
|
|
|
|
.form-inset-item {
|
|
|
|
right: 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|