Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to use form-inline bootstrap 3?

I have a view in HTML and Razor and I am trying to build a form to look like the following: mockup image

However, the best I can achieve is the following:

result image

As you can see the labels are not inlined. To achieve this I have read about the form-inline class in Bootstrap 3 (http://getbootstrap.com/components/#navbar-forms) but no matter how I use form-inline I cannot get the labels into the right place without making the whole layout a mess.

This is my current code (without form-inline):

 <fieldset class="group-border">
                    <legend class="group-border">Info</legend>

                    <div class="row">
                        <div class="col-lg-4">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.NumDoc, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.NumDoc, new { @class = "form-control input-sm", placeholder = "Nº Documento", disabled = "disabled" })
                            </div>
                        </div>
                        <div class="col-lg-4">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.ProcessNum, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.ProcessNum, new { @class = "form-control input-sm", placeholder = "Nº Processo", disabled = "disabled" })
                            </div>
                        </div>
                        <div class="col-lg-4">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.State, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.State, new { @class = "form-control input-sm", placeholder = "Estado", disabled = "disabled" })
                            </div>
                        </div>
                    </div>

                    <div class="row">
                        <div class="col-lg-6">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.Name, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.Name, new { @class = "form-control input-sm", placeholder = "Nome Documento", disabled = "disabled" })
                            </div>
                        </div>
                        <div class="col-lg-6">
                            @Html.LabelFor(doc => doc.IsArchived, new { @class = "control-label" })
                            @Html.CheckBoxFor(doc => doc.IsArchived, new { @class = "input-sm", disabled = "disabled" })
                        </div>
                    </div>

                    <div class="row">
                        <div class="col-lg-6">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.Description, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.Description, new { @class = "form-control input-sm", placeholder = "Descrição", disabled = "disabled" })
                            </div>
                        </div>
                        <div class="col-lg-6">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.Date, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.Date, new { @class = "form-control input-sm", placeholder = "dd/MM/yyyy", disabled = "disabled" })
                            </div>
                        </div>
                    </div>

                </fieldset>

Bellow is a code snippet in HTML CSS and Javascript, trying to replicate what I have.

<style> legend.group-border {
  width: inherit;
  /* Or auto */
  padding: 0 10px;
  /* To give a bit of padding on the left and right */
  border-bottom: none;
}
fieldset.group-border {
  border: 1px groove #ddd !important;
  padding: 0 1.4em 1.4em 1.4em !important;
  margin: 0 0 1.5em 0 !important;
  -webkit-box-shadow: 0px 0px 0px 0px #000;
  box-shadow: 0px 0px 0px 0px #000;
}
</style>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet" />
<fieldset class="group-border">
  <legend class="group-border">Info</legend>

  <div class="row">
    <div class="col-lg-4">
      <div class="form-group">
        <label class="control-label" for="NumDoc">Nº Documento</label>
        <input class="form-control input-sm" data-val="true" data-val-number="The field Nº Documento must be a number." data-val-required="O campo Nº Documento é necessário." disabled="disabled" id="NumDoc" name="NumDoc" placeholder="Nº Documento" type="text"
        value="21354">
      </div>
    </div>
    <div class="col-lg-4">
      <div class="form-group">
        <label class="control-label" for="ProcessNum">Nº Processo</label>
        <input class="form-control input-sm" data-val="true" data-val-number="The field Nº Processo  must be a number." data-val-required="O campo Nº Processo  é necessário." disabled="disabled" id="ProcessNum" name="ProcessNum" placeholder="Nº Processo" type="text"
        value="54463">
      </div>
    </div>
    <div class="col-lg-4">
      <div class="form-group">
        <label class="control-label" for="State">Estado</label>
        <input class="form-control input-sm" disabled="disabled" id="State" name="State" placeholder="Estado" type="text" value="Em Inbox">
      </div>
    </div>
  </div>

  <div class="row">
    <div class="col-lg-6">
      <div class="form-group">
        <label class="control-label" for="Name">Nome</label>
        <input class="form-control input-sm" disabled="disabled" id="Name" name="Name" placeholder="Nome Documento" type="text" value="A134-MULTAS">
      </div>
    </div>
    <div class="col-lg-6">
      <label class="control-label" for="IsArchived">Arquivado?</label>
      <input checked="checked" class="input-sm" data-val="true" data-val-required="O campo Arquivado? é necessário." disabled="disabled" id="IsArchived" name="IsArchived" type="checkbox" value="true">
      <input name="IsArchived" type="hidden" value="false">
    </div>
  </div>

  <div class="row">
    <div class="col-lg-6">
      <div class="form-group">
        <label class="control-label" for="Description">Descrição</label>
        <input class="form-control input-sm" disabled="disabled" id="Description" name="Description" placeholder="Descrição" type="text" value="Fast and Furious">
      </div>
    </div>
    <div class="col-lg-6">
      <div class="form-group">
        <label class="control-label" for="Date">Data Documento</label>
        <input class="form-control input-sm" data-val="true" data-val-date="The field Data Documento must be a date." data-val-required="O campo Data Documento é necessário." disabled="disabled" id="Date" name="Date" placeholder="dd/MM/yyyy" type="text" value="25/08/2015 15:03:26">
      </div>
    </div>
  </div>

</fieldset>

As you can see, I have a row, divided into 3 columns (each one occupying a width of 4 units) and inside I have my forms using Razor.

How would one modify my current HTML code to achieve the result in the mockup?

like image 808
Flame_Phoenix Avatar asked Sep 08 '25 10:09

Flame_Phoenix


1 Answers

Here is the code snippet, I just changed the form-group class to the form-inline, changed the number of columns and their width, and just to make it work add the container, row and col-md-12 divs, also I tried to align vertically the checkbox to look more like your first mockup image

<style> legend.group-border {
  width: inherit;
  /* Or auto */
  padding: 0 10px;
  /* To give a bit of padding on the left and right */
  border-bottom: none;
}
fieldset.group-border {
  border: 1px groove #ddd !important;
  padding: 0 1.4em 1.4em 1.4em !important;
  margin: 0 0 1.5em 0 !important;
  -webkit-box-shadow: 0px 0px 0px 0px #000;
  box-shadow: 0px 0px 0px 0px #000;
}
</style>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet" />
<div class="container">
            <div class="row">
                <div class="col-md-12">
                    <fieldset class="group-border">
                        <legend class="group-border">Info</legend>

                        <div class="row">
                            <div class="col-lg-4">
                                <div class="form-inline">
                                    <label class="control-label" for="NumDoc">Nº Documento</label>
                                    <input class="form-control input-sm" data-val="true" data-val-number="The field Nº Documento must be a number." data-val-required="O campo Nº Documento é necessário." disabled="disabled" id="NumDoc" name="NumDoc" placeholder="Nº Documento" value="21354" type="text">
                                </div>
                            </div>
                            <div class="col-lg-4">
                                <div class="form-inline">
                                    <label class="control-label" for="ProcessNum">Nº Processo</label>
                                    <input class="form-control input-sm" data-val="true" data-val-number="The field Nº Processo  must be a number." data-val-required="O campo Nº Processo  é necessário." disabled="disabled" id="ProcessNum" name="ProcessNum" placeholder="Nº Processo" value="54463" type="text">
                                </div>
                            </div>
                            <div class="col-lg-4">
                                <div class="form-inline">
                                    <label class="control-label" for="State">Estado</label>
                                    <input class="form-control input-sm" disabled="disabled" id="State" name="State" placeholder="Estado" value="Em Inbox" type="text">
                                </div>
                            </div>
                        </div>
                        <br>
                        <div class="row">
                            <div class="col-lg-1">
                                <label class="control-label" for="Name">Nome</label>
                            </div>
                            <div class="col-lg-7">
                                <input class="form-control input-sm" disabled="disabled" id="Name" name="Name" placeholder="Nome Documento" value="A134-MULTAS" type="text">
                            </div>
                            <div style="float: left;" class="col-lg-4 text-left">
                                <input style="float: left;" checked="checked" class="input-sm" data-val="true" data-val-required="O campo Arquivado? é necessário." disabled="disabled" id="IsArchived" name="IsArchived" value="true" type="checkbox">
                                <label style="margin-top: 10px; margin-left: 9px;" class="control-label" for="IsArchived">Arquivado?</label>
                                <input name="IsArchived" value="false" type="hidden">
                            </div>
                        </div>
                        <br>
                        <div class="row">
                            <div class="col-lg-1">
                                <label class="control-label" for="Description">Descrição</label>
                            </div>
                            <div class="col-lg-7">
                                <input class="form-control input-sm" disabled="disabled" id="Description" name="Description" placeholder="Descrição" value="Fast and Furious" type="text">
                            </div>
                            <div class="col-lg-4">
                                <div class="form-inline">
                                    <label class="control-label" for="Date">Data Documento</label>
                                    <input class="form-control input-sm" data-val="true" data-val-date="The field Data Documento must be a date." data-val-required="O campo Data Documento é necessário." disabled="disabled" id="Date" name="Date" placeholder="dd/MM/yyyy" value="25/08/2015 15:03:26" type="text">
                                </div>
                            </div>
                        </div>
                    </fieldset>
                </div>
            </div>
        </div>
like image 97
Enrique Zavaleta Avatar answered Sep 11 '25 05:09

Enrique Zavaleta