0

I'm creating input that shows different notes based on content. First, I tried using content attribute of CSS, but it only works for :before and :after selectors.

So, I created another div element, using :before on it to display the note text. Should I switch to using JavaScript to do this?

JS Fiddle

HTML:

<div class="link-input-container">
  <input class="link-input" placeholder="Zalijepi link ovdje..." type="text" class="url_input" name="url_input">
</div>
<div class="link-note no-input">
  <div class="link-note-content">
  </div>
</div>

CSS:

.link-input-container {
  position: relative;
  display: inline-block;
}

.link-input-container::after {
  display: block;
  content: "";
  width: 14px;
  height: 14px;
  background: transparent url('') no-repeat;
  background-size: contain;
  background-position: center;
  position: absolute;
  top: 50%;
  right: -5px;
  transform: translateY(-50%) translateX(100%);
}

.link-input-container.valid::after {
  background-image: url('')
}

.link-input {
  font-family: Courier New;
  font-size: 12px;
}

.link-input-container.valid .link-input {
  color: green;
}

.link-input-container:not(valid) .link-input {
  color: red;
}

.link-note {
  font-size: 12px;
}

.link-note.no-input {
  color: rgb(193, 162, 0);
}

.link-note.no-input .link-note-content:before {
  content: "*Link nije unesen";
}

.link-note.valid {
  color: green;
}

.link-note.valid .link-note-content:before {
  content: "*Stisni enter da dodas ovaj link";
}

.link-note.invalid {
  color: red;
}

.link-note.invalid .link-note-content:before {
  content: "*Link nije ispravan";
}

JS:

function toggleClass(elem, class_name, class_on) {
  if (class_on) {
    elem.classList.add(class_name);
  } else {
    elem.classList.remove(class_name);
  }
}

function switchClass(elem, class_list, on_class) {
  for (var i = 0; i < class_list.length; i++) {
    elem.classList.remove(class_list[i]);
  }
  elem.classList.add(on_class);
}

function LinkInput() {
  LinkInput = null;

  var self = {
    container_elem: null,
    input_elem: null,
    note_elem: null,

    init: () => {
      var container_elem = self.container_elem = document.querySelector(
        '.link-input-container'
      );

      var input_elem = self.input_elem = document.querySelector(
        '.link-input'
      );
      input_elem.size = 23;

      var note_elem = self.note_elem = document.querySelector(
        '.link-note'
      );

      input_elem.addEventListener('input', (ev) => {
        var new_val = input_elem.value;

        var new_size = new_val.length;
        input_elem.size = Math.max(new_size + 2, 23);

        if (new_val.length > 5) {
          switchClass(note_elem, [
            "no-input", "invalid", "valid"
          ], "valid");

          toggleClass(container_elem, "valid", true);
        } else {
          if (new_val === "") {
            switchClass(note_elem, [
              "no-input", "invalid", "valid"
            ], "no-input");
          } else {
            switchClass(note_elem, [
              "no-input", "invalid", "valid"
            ], "invalid");
          }

          toggleClass(container_elem, "valid", false);
        }
      });

      input_elem.addEventListener('keyup', (ev) => {
        if (ev.keyCode == 13) {
          input_elem.value = "";
          input_elem.blur();

          // Submit

          return false;
        }
      });
    },
  };

  self.init();
  return self;
}

var link_input = LinkInput();
4
  • One problem of content is that the text is not selectable Commented Jun 21, 2016 at 12:57
  • Thanks. I actually like that in this case. Commented Jun 21, 2016 at 13:02
  • What is the specific problem and question? Commented Jun 21, 2016 at 13:06
  • Is it good practice to use CSS in such cases or is it better to use Javascript? Commented Jun 21, 2016 at 13:08

1 Answer 1

1

It's up to you. I think notifications should be driven by javascript as it's not part of the site at the moment it loads. Im thinking some SEO here, not that the search engines should save notifications like that anyways. Well that's my opinion :)

Cheers!

Sign up to request clarification or add additional context in comments.

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.