Home > Back-end >  Need help trying to convert radio buttons into a row
Need help trying to convert radio buttons into a row

Time:01-04

I'm trying to convert these radio buttons from a column into a row but I cannot seem to achieve this outcome. Would someone be kind enough to help me out. I have been trying to do this for hours with no success. The issue seems to be in the SCSS but im cannot figure it out.

HTML for the radio buttons

<div >
  <div >
    <input type="radio" id="huey"
      name="drone" value="huey" checked />
    <label for="huey">Word</label>
  </div>

  <div >
    <input type="radio" id="dewey"
      name="drone" value="dewey" />
    <label for="dewey">Powerpoint</label>
  </div>
              
  <div >
    <input type="radio" id="louie"
      name="drone" value="louie" />
    <label for="louie">Speech</label>
  </div>

  <div >
    <input type="radio" id="suey"
      name="drone" value="suey" />
    <label for="suey">Youtube</label>
  </div>
</div>

SCSS for the radio buttons

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500&family=Roboto:wght@300;400&display=swap');

$accentcolor: #fcae2c;
$lightcolor: #fff;
$darkcolor: rgb(110, 110, 110);

.x {
    max-width: 250px;
    position: relative;
    margin: 50px auto 0;
    font-size: 15px;
}
.radiobtn {
    position: relative;
    display: block;
    label {
        display: block;
        background: lighten($accentcolor, 30%);
        color: $darkcolor;
        border-radius: 5px;
        padding: 10px 20px;
        border: 2px solid lighten($accentcolor, 20%);
        margin-bottom: 5px;
        font-family: "Montserrat", sans-serif;
        font-weight: 400px;
        font-size: 16px;
        cursor: pointer;
        &:after,
        &:before {
            content: "";
            position: absolute;
            right: 11px;
            top: 11px;
            width: 20px;
            height: 20px;
            border-radius: 3px;
            background: lighten($accentcolor, 15%);
        }
        &:before {
            background: transparent;
            transition: 0.1s width cubic-bezier(0.075, 0.82, 0.165, 1) 0s,
                0.3s height cubic-bezier(0.075, 0.82, 0.165, 2) 0.1s;
            z-index: 2;
            overflow: hidden;
            background-repeat: no-repeat;
            background-size: 13px;
            background-position: center;
            width: 0;
            height: 0;
            background-image: url( PC9zdmc );
        }
    }
    input[type="radio"] {
        display: none;
        position: absolute;
        width: 100%;
        appearance: none;
        &:checked   label {
            background: lighten($accentcolor, 15%);
            animation-name: blink;
            animation-duration: 1s;
            border-color: $accentcolor;
            &:after {
                background: $accentcolor;
            }
            &:before {
                width: 20px;
                height: 20px;
            }
        }
    }
}

@keyframes blink {
    0% {
        background-color: lighten($accentcolor, 15%);
    }
    10% {
        background-color: lighten($accentcolor, 15%);
    }
    11% {
        background-color: lighten($accentcolor, 20%);
    }
    29% {
        background-color: lighten($accentcolor, 20%);
    }
    30% {
        background-color: lighten($accentcolor, 15%);
    }
    50% {
        background-color: lighten($accentcolor, 20%);
    }
    45% {
        background-color: lighten($accentcolor, 15%);
    }
    50% {
        background-color: lighten($accentcolor, 20%);
    }
    100% {
        background-color: lighten($accentcolor, 15%);
    }
}

CodePudding user response:

In .radiobtn{} adding display: inline-block; will get the result I believe you are looking for.

CodePudding user response:

Use implicit labels and no CSS is required

<label><input type="radio" name="drone" value="huey">Word</label>
<label><input type="radio" name="drone" value="dewey">Powerpoint</label>
<label><input type="radio" name="drone" value="louie">Speech</label>
<label><input type="radio" name="drone" value="suey">Youtube</label>

CodePudding user response:

Use 'Display: Inline' instead of 'Display: Block;' in .radiobtn class

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500&family=Roboto:wght@300;400&display=swap');
$accentcolor: #fcae2c;
$lightcolor: #fff;
$darkcolor: rgb(110,
110,
110);
.x {
  max-width: 250px;
  position: relative;
  margin: 50px auto 0;
  font-size: 15px;
}

.radiobtn {
  position: relative;
  display: inline;
  label {
    display: block;
    background: lighten($accentcolor, 30%);
    color: $darkcolor;
    border-radius: 5px;
    padding: 10px 20px;
    border: 2px solid lighten($accentcolor, 20%);
    margin-bottom: 5px;
    font-family: "Montserrat", sans-serif;
    font-weight: 400px;
    font-size: 16px;
    cursor: pointer;
    &:after,
    &:before {
      content: "";
      position: absolute;
      right: 11px;
      top: 11px;
      width: 20px;
      height: 20px;
      border-radius: 3px;
      background: lighten($accentcolor, 15%);
    }
    &:before {
      background: transparent;
      transition: 0.1s width cubic-bezier(0.075, 0.82, 0.165, 1) 0s, 0.3s height cubic-bezier(0.075, 0.82, 0.165, 2) 0.1s;
      z-index: 2;
      overflow: hidden;
      background-repeat: no-repeat;
      background-size: 13px;
      background-position: center;
      width: 0;
      height: 0;
      background-image: url( PC9zdmc );
    }
  }
  input[type="radio"] {
    display: none;
    position: absolute;
    width: 100%;
    appearance: none;
    &:checked label {
      background: lighten($accentcolor, 15%);
      animation-name: blink;
      animation-duration: 1s;
      border-color: $accentcolor;
      &:after {
        background: $accentcolor;
      }
      &:before {
        width: 20px;
        height: 20px;
      }
    }
  }
}

@keyframes blink {
  0% {
    background-color: lighten($accentcolor, 15%);
  }
  10% {
    background-color: lighten($accentcolor, 15%);
  }
  11% {
    background-color: lighten($accentcolor, 20%);
  }
  29% {
    background-color: lighten($accentcolor, 20%);
  }
  30% {
    background-color: lighten($accentcolor, 15%);
  }
  50% {
    background-color: lighten($accentcolor, 20%);
  }
  45% {
    background-color: lighten($accentcolor, 15%);
  }
  50% {
    background-color: lighten($accentcolor, 20%);
  }
  100% {
    background-color: lighten($accentcolor, 15%);
  }
}
<div >
  <div >
    <input type="radio" id="huey" name="drone" value="huey" checked />
    <label for="huey">Word</label>
  </div>

  <div >
    <input type="radio" id="dewey" name="drone" value="dewey" />
    <label for="dewey">Powerpoint</label>
  </div>

  <div >
    <input type="radio" id="louie" name="drone" value="louie" />
    <label for="louie">Speech</label>
  </div>

  <div >
    <input type="radio" id="suey" name="drone" value="suey" />
    <label for="suey">Youtube</label>
  </div>
</div>

  • Related