Reputation: 113
I have a small poll on three layout columns.
On Desktop it looks like this:
My problem is on mobile screen. I have one person under the other and after that questions. See the image below.
What I want to achieve is Person 1 and then questions, Person 2, and then questions, Person 3 and then questions, something like this:
Does anybody have any idea how to solve this?
Here is HTMl:
<div class="col-md-12 col-xs-12">
<div class="d-table">
<div class="d-table-row">
<div class="d-table-cell align-middle"></div>
<div class="d-table-cell align-middle">
<div class="titleMiddle">Person 1</div>
</div>
<div class="d-table-cell align-middle">
<div class="titleMiddle">Person 2</div>
</div>
<div class="d-table-cell align-middle">
<div class="titleMiddle">Person 3</div>
</div>
</div>
<div class="d-table-row">
<div class="d-table-cell align-middle pb-4">
<div class="question">
<div class="smalltitle">
<span class="prefiks">1</span>
<span>This is a very nice question</span>
</div>
</div>
</div>
<div class="d-table-cell align-middle pb-4">
<div class="horizontal">
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="1">
</div>
<div class="answerText">1</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="2">
</div>
<div class="answerText">2</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="3">
</div>
<div class="answerText">3</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="4">
</div>
<div class="answerText">4</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="5">
</div>
<div class="answerText">5</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="6">
</div>
<div class="answerText">No answer</div>
</div>
</div>
</div>
<div class="d-table-cell align-middle pb-4">
<div class="horizontal">
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="1">
</div>
<div class="answerText">1</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="2">
</div>
<div class="answerText">2</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="3">
</div>
<div class="answerText">3</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="4">
</div>
<div class="answerText">4</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="5">
</div>
<div class="answerText">5</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="6">
</div>
<div class="answerText">No Answer</div>
</div>
</div>
</div>
<div class="d-table-cell align-middle pb-4">
<div class="horizontal">
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="1">
</div>
<div class="answerText">1</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="2">
</div>
<div class="answerText">2</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="3">
</div>
<div class="answerText">3</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="4">
</div>
<div class="answerText">4</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="5">
</div>
<div class="answerText">5</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="6">
</div>
<div class="answerText">No answer</div>
</div>
</div>
</div>
</div>
</div>
</div>
CSS
.d-table {
display: table!important;
}
.d-table-row {
display: table-row !important;
}
* {
-webkit-font-smoothing: antialiased;
}
*, ::after, ::before {
box-sizing: inherit;
}
.d-table-cell {
display: table-cell!important;
}
.align-middle {
vertical-align: middle!important;
}
.align-middle > div {
margin-right: 50px;
}
.titleMiddle {
font-weight: 700;
margin-bottom: 30px;
}
.pb-4, .py-4 {
padding-bottom: 1.5rem!important;
}
.smalltitle {
margin-bottom: 20px;
}
.horizontal {
display: flex !important;
flex-direction: row !important;
}
.answer {
margin-left: 15px;
margin-bottom: 5px;
padding: 6px;
}
.answerRight {
display: flex !important;
flex-direction: row !important;
align-items: center;
}
input[type='radio'] {
width: 13px;
height: 13px;
background: white;
border-radius: 50%!important;
border: 1px solid #343c49;
-moz-appearance: none;
-webkit-appearance: none;
}
input[type='radio']:checked {
background: #06c;
}
.answerText {
margin-left: 0.375rem;
}
Upvotes: 0
Views: 656
Reputation: 329
Have you tried this?
<div class="col-md-12 col-xs-12">
<div class="d-table">
<div class="d-table-row">
<div class="d-table-cell align-middle">This is a very nice question</div>
<div class="d-table-cell align-middle">
<div class="titleMiddle">Person 1</div>
<div class="d-table-cell align-middle pb-4">
<div class="horizontal">
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="1">
</div>
<div class="answerText">1</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="2">
</div>
<div class="answerText">2</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="3">
</div>
<div class="answerText">3</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="4">
</div>
<div class="answerText">4</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="5">
</div>
<div class="answerText">5</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="6">
</div>
<div class="answerText">No answer</div>
</div>
</div>
</div>
</div>
<div class="d-table-cell align-middle">
<div class="titleMiddle">Person 2</div>
<div class="d-table-cell align-middle pb-4">
<div class="horizontal">
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="1">
</div>
<div class="answerText">1</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="2">
</div>
<div class="answerText">2</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="3">
</div>
<div class="answerText">3</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="4">
</div>
<div class="answerText">4</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="5">
</div>
<div class="answerText">5</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="6">
</div>
<div class="answerText">No answer</div>
</div>
</div>
</div>
</div>
<div class="d-table-cell align-middle">
<div class="titleMiddle">Person 3</div>
<div class="d-table-cell align-middle pb-4">
<div class="horizontal">
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="1">
</div>
<div class="answerText">1</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="2">
</div>
<div class="answerText">2</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="3">
</div>
<div class="answerText">3</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="4">
</div>
<div class="answerText">4</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="5">
</div>
<div class="answerText">5</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="6">
</div>
<div class="answerText">No answer</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
Or use for every person one class="d-table-row" with answers like this:
<div class="col-md-12 col-xs-12">
<div class="d-table">
<div class="d-table-row">
<div class="d-table-cell align-middle">This is a very nice question</div>
<div class="d-table-cell align-middle">
<div class="titleMiddle">Person 1</div>
<div class="d-table-cell align-middle pb-4">
<div class="horizontal">
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="1">
</div>
<div class="answerText">1</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="2">
</div>
<div class="answerText">2</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="3">
</div>
<div class="answerText">3</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="4">
</div>
<div class="answerText">4</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="5">
</div>
<div class="answerText">5</div>
</div>
<div class="answer answerRight">
<div class="answerInput">
<input type="radio" name="name" value="6">
</div>
<div class="answerText">No answer</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
I'm not sure if there is right number of closed divs, but this version would put every person in their row(on desktop and on mobile).
Upvotes: 1
Reputation: 19
Make different person in different div like this
.d-flex{
display: flex;
}
.row{
flex-direction: row;
}
.col{
flex-direction: column;
}
<div class="d-flex row">
<div class="d-flex col">
<div>Person 1</div>
<div class=" d-flex row">
<span>Q1</span>
<div>
<input type="radio" name="q1" value="1" >
<span >1</span>
</div>
<div>
<input type="radio" name="q2" value="2">
<span >2</span>
</div>
<div>
<input type="radio" name="q3" value="3">
<span >3</span>
</div>
</div>
</div>
<div class="d-flex col">
<div>Person 1</div>
<div class=" d-flex row">
<span>Q1</span>
<div>
<input type="radio" name="q1" value="1" >
<span >1</span>
</div>
<div>
<input type="radio" name="q2" value="2">
<span >2</span>
</div>
<div>
<input type="radio" name="q3" value="3">
<span >3</span>
</div>
</div>
</div>
</div>
This could be the structure and use media query for responsiveness.
Upvotes: 0