Подтвердить перетаскиваемого клиента с помощью функции принятия - PullRequest
0 голосов
/ 25 января 2019

У меня есть вопрос, возможно ли это в отношении моего перетаскиваемого и сбрасываемого модуля? Здесь у меня есть классы

  1. stackDrop1 (на кухне)
  2. stackDrop2 (на дороге)
  3. stackDrop3 (Завершено)

image

Если Клиент Джордж был на Вкл.класс Road, класс In the Kitchen не позволит / Принять снова бросить покупателя Джорджа в эту коробку.Появится предупреждение, что клиент уже был на шаге 2.

Сценарий необходимо проверить: Если клиент Джордж уже был в классе stackDrop2, то класс stackDrop1прекратить прием клиента Джордж .

Мои коды Jquery:

    $(".drag-wrapper").draggable({
    appendTo: "body",
    cursor: "move",
    helper: 'clone',

});

$("#launchPad").droppable({
    tolerance: "intersect",
    accept: ".drag-wrapper",
    activeClass: "ui-state-default",
    hoverClass: "ui-state-hover",
    drop: function(event, ui) {
        // $("#launchPad").append($(ui.draggable));
    }
});

$(".stackDrop1").droppable({
    tolerance: "intersect",
    accept: ".drag-wrapper",
    revert: 'invalid',
    activeClass: "ui-state-default",
    hoverClass: "ui-state-hover",
    drop: function(event, ui) {        
        $(this).append($(ui.draggable));
        alert('In the kitchen');
    }
});

$(".stackDrop2").droppable({
    tolerance: "intersect",
    accept: ".drag-wrapper",

    activeClass: "ui-state-default",
    hoverClass: "ui-state-hover",
    drop: function(event, ui) {        
        $(this).append($(ui.draggable));
        alert('On the road');
    }
});

$(".stackDrop3").droppable({
    tolerance: "intersect",
    accept: ".drag-wrapper",

    activeClass: "ui-state-default",
    hoverClass: "ui-state-hover",
    drop: function(event, ui) {        
        $(this).append($(ui.draggable));
        alert('Completed');
    }
});

Мои коды Html:

<div class="jumbotron" style="background-color:white;">
    <div class="row">
        <div class="col-md-3">
            <div id="launchPad">
                <div class="stackHdr" style="background: linear-gradient(-25deg, #00e4d0, #5983e8); color:white; text-align: center;">
                    <text>Open Orders</text>
                </div>    
                @foreach($customer_orders_details as $transac_details)
                    <div class="drag-wrapper">
                        <div class="card">
                            <div class="card-body" style="font-weight: bold; text-align: center;">
                                <h5 class="card-title" style="text-align: center;">
                                    <i class="far fa-user-circle" style="font-size:30px;"></i>
                                    <br><br>
                                    <h6 class="card-subtitle mb-2 text-muted" style="font-weight: 300; color:black !important; font-family: 'Open Sans';">OR # {{$transac_details->or_number}}</h6>
                                    <h6 class="card-subtitle mb-2 text-muted" style="font-weight: bold; color:black !important;">Customer: {{$transac_details->customer_name}}</h6><br>
                                    <h6 class="card-subtitle mb-2 text-muted" style="font-weight: 300;">Address: {{$transac_details->order_ship_address}}</h6>
                                    <h6 class="card-subtitle mb-2 text-muted" style="font-weight: 300;">Contact #: {{$transac_details->customer_number}}</h6>
                                    <p class="card-text">Total:${{$transac_details->amount}}</p>

                                    <a href="#" class="card-link btn btn-primary">Assign</a>
                                    <a href="#" class="card-link btn btn-warning" id="gather_customer_order" data-order-id='{{$transac_details->order_id}}' data-customer-id='{{$transac_details->customer_id}}' style="color:white;" data-toggle="modal" data-target="#customer_detail_delivery">Details</a>
                                </h5>
                            </div>
                        </div>
                    </div>
                    <br>
                @endforeach
            </div>
        </div>
        <div class="col-md-3">
            <div id="dropZone">
                <div class="stack"  style="width:231px;">
                    <div class="stackHdr" style="background: linear-gradient(-10deg, #00e4d0, #5983e8); color:white;  text-align: center;">
                        <text>In the Kitchen</text>
                    </div>
                    <center>
                        <div class="stackDrop1" style="">

                        </div>
                    </center>
                </div>
            </div>
        </div>
        <div class="col-md-3">
            <div id="dropZone">
                <div class="stack"  style="width:231px;">
                    <div class="stackHdr" style="background: linear-gradient(-10deg, #00e4d0, #5983e8); color:white;  text-align: center;">
                        <text>On the Road</text>
                    </div>
                    <center>
                        <div class="stackDrop2" style="">

                        </div>
                    </center>
                </div>
            </div>
        </div>
        <div class="col-md-3">
            <div id="dropZone">
                <div class="stack"  style="width:231px;">
                    <div class="stackHdr" style="background: linear-gradient(-10deg, #00e4d0, #5983e8); color:white;  text-align: center;">
                        <text>Completed</text>
                    </div>
                    <center>
                        <div class="stackDrop3" style="">

                        </div>
                    </center>
                </div>
            </div>
        </div>
    </div>
</div>

1 Ответ

0 голосов
/ 25 января 2019

Вы можете настроить класс для перетаскиваемого таким образом, чтобы каждый сбрасываемый объект воспринимал только определенные классы. Рассмотрим следующий код.

$(function() {
  $(".drag-wrapper").draggable({
    appendTo: "body",
    cursor: "move",
    helper: 'clone'
  });

  $("#launchPad").droppable({
    tolerance: "intersect",
    accept: ".drag-wrapper",
    activeClass: "ui-state-default",
    hoverClass: "ui-state-hover",
    drop: function(event, ui) {
      // $("#launchPad").append($(ui.draggable));
    }
  });

  $(".stackDrop1").droppable({
    tolerance: "intersect",
    accept: ".from-launch",
    revert: 'invalid',
    activeClass: "ui-state-default",
    hoverClass: "ui-state-hover",
    drop: function(event, ui) {
      ui.draggable.removeClass("from-launch").addClass("from-kitchen");
      $(this).append($(ui.draggable));
      console.log('In the kitchen');
    }
  });

  $(".stackDrop2").droppable({
    tolerance: "intersect",
    accept: ".from-kitchen",
    activeClass: "ui-state-default",
    hoverClass: "ui-state-hover",
    drop: function(event, ui) {
      $(this).append($(ui.draggable));
      console.log('On the road');
    }
  });
});
<link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.2.1/css/bootstrap.min.css" integrity="sha384-GJzZqFGwb1QTTN6wy59ffF1BuGJpLSa9DkKMp0DgiMDm4iYMj70gZWKYbI706tWS" crossorigin="anonymous">
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>

<div class="jumbotron" style="background-color:white;">
  <div class="row">
    <div class="col-md-3">
      <div id="launchPad">
        <div class="stackHdr" style="background: linear-gradient(-25deg, #00e4d0, #5983e8); color:white; text-align: center;">
          <text>Open Orders</text>
        </div>
        <div class="drag-wrapper from-launch">
          <div class="card">
            <div class="card-body" style="font-weight: bold; text-align: center;">
              <h5 class="card-title" style="text-align: center;">
                <i class="far fa-user-circle" style="font-size:30px;"></i>
                <br><br>
                <h6 class="card-subtitle mb-2 text-muted" style="font-weight: 300; color:black !important; font-family: 'Open Sans';">OR # 1001</h6>
                <h6 class="card-subtitle mb-2 text-muted" style="font-weight: bold; color:black !important;">Customer: George</h6><br>
                <h6 class="card-subtitle mb-2 text-muted" style="font-weight: 300;">Address: 123 Main St, City</h6>
                <h6 class="card-subtitle mb-2 text-muted" style="font-weight: 300;">Contact #: (415) 555-1212</h6>
                <p class="card-text">Total:$0.00</p>

                <a href="#" class="card-link btn btn-primary">Assign</a>
                <a href="#" class="card-link btn btn-warning" id="gather_customer_order" data-order-id='OR-1001' data-customer-id='C-1' style="color:white;" data-toggle="modal" data-target="#customer_detail_delivery">Details</a>
              </h5>
            </div>
          </div>
        </div>
        <br>
      </div>
    </div>
    <div class="col-md-3">
      <div id="dropZone">
        <div class="stack" style="width:231px;">
          <div class="stackHdr" style="background: linear-gradient(-10deg, #00e4d0, #5983e8); color:white;  text-align: center;">
            <text>In the Kitchen</text>
          </div>
          <center>
            <div class="stackDrop1" style="height: 400px">
            </div>
          </center>
        </div>
      </div>
    </div>
    <div class="col-md-3">
      <div id="dropZone">
        <div class="stack" style="width:231px;">
          <div class="stackHdr" style="background: linear-gradient(-10deg, #00e4d0, #5983e8); color:white;  text-align: center;">
            <text>On the Road</text>
          </div>
          <center>
            <div class="stackDrop2" style="height: 400px;">

            </div>
          </center>
        </div>
      </div>
    </div>
    <div class="col-md-3">
      <div id="dropZone">
        <div class="stack" style="width:231px;">
          <div class="stackHdr" style="background: linear-gradient(-10deg, #00e4d0, #5983e8); color:white;  text-align: center;">
            <text>Completed</text>
          </div>
          <center>
            <div class="stackDrop3" style="height: 400px;">

            </div>
          </center>
        </div>
      </div>
    </div>
  </div>
</div>

Когда пользователь перемещает элементы с места на место, классы добавляются и удаляются к элементу. Каждый сбрасываемый предмет может принимать предметы определенного класса. Это предотвращает перемещение объекта пользователем в неправильное место.

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...