mirror of
https://github.com/YunoHost-Apps/ihatemoney_ynh.git
synced 2024-09-03 19:26:15 +02:00
37be0f4fa1
Uses uni-form to style forms and add a macro to ease this. Of course, the overall thing has to be reworked, but having this in place will help us to have something easier to change when we will really care about design. All the form templates can now be defined in templates/forms.html and be called thansk to {{ forms.name_of_the_form(form) }}. I've done some styling, but that's really not my thing, feel free to modify it.
164 lines
No EOL
8 KiB
CSS
Executable file
164 lines
No EOL
8 KiB
CSS
Executable file
/* ------------------------------------------------------------------------------
|
|
|
|
Copyright (c) 2010, Dragan Babic
|
|
|
|
Permission is hereby granted, free of charge, to any person
|
|
obtaining a copy of this software and associated documentation
|
|
files (the "Software"), to deal in the Software without
|
|
restriction, including without limitation the rights to use,
|
|
copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
copies of the Software, and to permit persons to whom the
|
|
Software is furnished to do so, subject to the following
|
|
conditions:
|
|
|
|
The above copyright notice and this permission notice shall be
|
|
included in all copies or substantial portions of the Software.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
|
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
|
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
|
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
|
OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
------------------------------------------------------------------------------ */
|
|
/* ############################# GENERALS ################################### */
|
|
/* ------------------------------------------------------------------------------ */
|
|
|
|
.uniForm{ margin: 0; padding: 0; position: relative; z-index: 1; } /* reset stuff */
|
|
|
|
/* Some generals and more resets */
|
|
.uniForm fieldset{ border: none; margin: 0; padding: 0; }
|
|
.uniForm fieldset legend{ margin: 0; padding: 0; }
|
|
|
|
/* This are the main units that contain form elements */
|
|
.uniForm .ctrlHolder,
|
|
.uniForm .buttonHolder{ margin: 0; padding: 0; clear: both; }
|
|
|
|
/* Clear all floats */
|
|
.uniForm:after,
|
|
.uniForm .buttonHolder:after,
|
|
.uniForm .ctrlHolder:after,
|
|
.uniForm .ctrlHolder .multiField:after,
|
|
.uniForm .inlineLabel:after{ content: "."; display: block; height: 0; line-height: 0; font-size: 0; clear: both; min-height: 0; visibility: hidden; }
|
|
|
|
.uniForm label,
|
|
.uniForm button{ cursor: pointer; }
|
|
|
|
/* ------------------------------------------------------------------------------ */
|
|
/* ########################## DEFAULT LAYOUT ################################ */
|
|
/* ------------------------------------------------------------------------------ */
|
|
/* Styles for form controls where labels are above the input elements */
|
|
/* ------------------------------------------------------------------------------ */
|
|
|
|
.uniForm label,
|
|
.uniForm .label{ display: block; float: none; margin: 0 0 .5em 0; padding: 0; line-height: 100%; width: auto; }
|
|
|
|
/* Float the input elements */
|
|
.uniForm .textInput,
|
|
.uniForm .fileUpload,
|
|
.uniForm .selectInput,
|
|
.uniForm select,
|
|
.uniForm textarea{ float: left; width: 53%; margin: 0; }
|
|
|
|
/* Read-Only output */
|
|
.uniForm .readOnlyLabel{ margin: 0; font-size: 1em; font-weight: bold; }
|
|
.uniForm .readOnly{ font-size: .85em; }
|
|
.uniForm .readOnly .choiceLabel{ color: #777; text-transform: uppercase; font-size: .75em; letter-spacing: .15em; }
|
|
|
|
/* Postition the hints */
|
|
.uniForm .formHint{ float: right; width: 43%; margin: 0; clear: none; }
|
|
|
|
/* Position the elements inside combo boxes (multiple inputs/selects/checkboxes/radio buttons per unit) */
|
|
.uniForm ul{ float: left; width: 53%; margin: 0; padding: 0; }
|
|
.uniForm ul li{ margin: 0 0 .5em 0; list-style: none; }
|
|
.uniForm ul li label{ margin: 0; float: none; display: block; overflow: visible; }
|
|
/* Alternate layout */
|
|
.uniForm ul.alternate li{ float: left; width: 30%; margin-right: 3%; }
|
|
.uniForm ul.alternate li label{ float: none; display: block; width: 98%; }
|
|
.uniForm ul .textInput,
|
|
.uniForm ul .selectInput,
|
|
.uniForm ul select,
|
|
.uniForm ul.alternate .textInput,
|
|
.uniForm ul.alternate .selectInput,
|
|
.uniForm ul.alternate select{ width: 98%; margin-top: .5em; display: block; float: none; }
|
|
|
|
/* Required fields asterisk styling */
|
|
.uniForm label em,
|
|
.uniForm .label em{ float: left; width: 1em; margin: 0 0 0 -1em; }
|
|
|
|
/* ------------------------------------------------------------------------------ */
|
|
/* ######################### ALTERNATE LAYOUT ############################### */
|
|
/* ------------------------------------------------------------------------------ */
|
|
/* Styles for form controls where labels are in line with the input elements */
|
|
/* Set the class of the parent (preferably to a fieldset) to .inlineLabels */
|
|
/* ------------------------------------------------------------------------------ */
|
|
|
|
.uniForm .inlineLabels label,
|
|
.uniForm .inlineLabels .label,
|
|
.uniForm .inlineLabels .readOnlyLabel{ float: left; margin: .3em 2% 0 0; padding: 0; line-height: 1; position: relative; width: 32%; }
|
|
|
|
.uniForm .inlineLabels .readOnlyLabel{ margin: 0; }
|
|
|
|
/* Float the input elements */
|
|
.uniForm .inlineLabels .textInput,
|
|
.uniForm .inlineLabels .fileUpload,
|
|
.uniForm .inlineLabels .selectInput,
|
|
.uniForm .inlineLabels select,
|
|
.uniForm .inlineLabels textarea{ float: left; width: 64%; }
|
|
|
|
/* Postition the hints */
|
|
.uniForm .inlineLabels .formHint{ clear: both; float: none; width: auto; margin-left: 34%; position: static; }
|
|
|
|
/* Position the elements inside combo boxes (multiple inputs/selects/checkboxes/radio buttons per unit) */
|
|
.uniForm .inlineLabels ul{ float: left; width: 66%; }
|
|
.uniForm .inlineLabels ul li{ margin: .5em 0; }
|
|
.uniForm .inlineLabels ul li label{ float: none; display: block; width: 100%; }
|
|
/* Alternate layout */
|
|
.uniForm .inlineLabels ul.alternate li{ margin-right: 3%; margin-top: .25em; }
|
|
.uniForm .inlineLabels ul li label .textInput,
|
|
.uniForm .inlineLabels ul li label textarea,
|
|
.uniForm .inlineLabels ul li label select{ float: none; display: block; width: 98%; }
|
|
|
|
.uniForm .inlineLabels .readOnly{ float: right; width: 66%; }
|
|
|
|
/* Required fields asterisk styling */
|
|
.uniForm .inlineLabels label em,
|
|
.uniForm .inlineLabels .label em{ display: block; float: none; margin: 0; position: absolute; right: 0; }
|
|
|
|
/* ----------------------------------------------------------------------------- */
|
|
/* ########################### Additional Stuff ################################ */
|
|
/* ----------------------------------------------------------------------------- */
|
|
|
|
/* Generals */
|
|
.uniForm legend{ color: inherit; }
|
|
|
|
.uniForm .secondaryAction{ float: left; }
|
|
|
|
/* .inlineLabel is used for inputs within labels - checkboxes and radio buttons */
|
|
.uniForm .inlineLabel input,
|
|
.uniForm .inlineLabels .inlineLabel input,
|
|
.uniForm .blockLabels .inlineLabel input,
|
|
/* class .inlineLabel is depreciated */
|
|
.uniForm label input{ float: none; display: inline; margin: 0; padding: 0; border: none; }
|
|
|
|
.uniForm .buttonHolder .inlineLabel,
|
|
.uniForm .buttonHolder label{ float: left; margin: .5em 0 0 0; width: auto; max-width: 60%; text-align: left; }
|
|
|
|
/* When you don't want to use a label */
|
|
.uniForm .inlineLabels .noLabel ul{ margin-left: 34%; /* Match to width of label + gap to field */ }
|
|
|
|
/* Classes for control of the widths of the fields */
|
|
.uniForm .small { width: 30% !important; }
|
|
.uniForm .medium{ width: 45% !important; }
|
|
.uniForm .large { } /* Large is default and should match the value you set for .textInput, textarea or select */
|
|
.uniForm .auto { width: auto !important; height: auto !important; }
|
|
.uniForm .small,
|
|
.uniForm .medium,
|
|
.uniForm .auto{ margin-right: 4px; }
|
|
|
|
/* Columns */
|
|
.uniForm .col{ float: left; }
|
|
.uniForm .col{ width: 50%; } |