Teuta Koraqi
Teuta Koraqi

Reputation: 1898

Prevent contenteditable adding same classes on enter

I have set contenteditable="true" to ul, and I have a list inside this.
As you can see before each list I've set checkboxes. If I click on checkbox, it toggles class checked. The problem is, when I click checkbox, and press enter, it adds same class checked to this added list.
I don't want added list to be checked. Is there anyway to prevent this?

Thank you in advance!

$(document).ready(function(){
   $(document).on('click', 'ul li',  function(){
     $(this).toggleClass('checked');
   })
    $(document).on('click', 'ul li span',  function(e){
     e.stopPropagation();
   })
});
li:before {
  background-image: url('');
  display: block;
  float: left;
  content: "";
   width: 18px;
   height: 18px;
   background-size: 100%;
}
li {
  list-style: none;
  margin-bottom: 14px;
    height: 22px;
    position: relative;
    width: 99%;
}
li.checked:before {
  background-image: url('');
  background-size: 100%;
  width: 18px;
  height: 18px;
  background-repeat: no-repeat;
} 

li span {
  display: inline-block;
  width:90%;
  margin-left: 10px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<ul contenteditable="true" id="editor">
   <li>
     <span>
       Click on checbox and press enter
     </span>
   </li>
</ul>

Upvotes: 1

Views: 104

Answers (2)

Teuta Koraqi
Teuta Koraqi

Reputation: 1898

I found the right solution of my answer: The solution was listening DOMNodeInserted event:

  $('#editor').on('DOMNodeInserted', function(e) {
     $(e.target).removeClass('checked');
   });

Upvotes: 0

Whip
Whip

Reputation: 2224

Update: Based on your requirements you can add an event listener to detect any change in the ul section and remove the class from the last li tag

$(document).ready(function(){
   $(document).on('click', 'ul li',  function(){
     $(this).toggleClass('checked');
   });
    $(document).on('click', 'ul li span',  function(e){
     e.stopPropagation();
   });
  $('#editor').on('input', function(){
    $(this).children('li').last().removeClass('checked');
  });
});

Codepen

You don't have to even check the checkbox, you can edit the contents anyway. That's because you've set the property of the ul in such a way contenteditable="true". I'm not sure why you'd want that but if you must, then you can disable this property after the checkbox has been checked

$(document).ready(function(){
   $(document).on('click', 'ul li',  function(){
     var $this = $(this);
     $this.toggleClass('checked');
     if($this.hasClass('checked')){
       $this.parent().attr('contenteditable', false);
     }
     else {
       $this.parent().attr('contenteditable', true);
     }
   })
    $(document).on('click', 'ul li span',  function(e){
     e.stopPropagation();
   })
});

Upvotes: 1

Related Questions