Как обновить первое значение td на клике, как при перетаскивании - PullRequest
0 голосов
/ 29 августа 2018

Я переписал свой вопрос, чтобы лучше прояснить, что я пытаюсь достичь и что я пытался до сих пор.

У меня на сайте есть таблица, которая динамически загружает строки таблицы из базы данных. Я успешно интегрировал функциональность jQuery «Sortable» и «Draggable» для этой страницы. В результате изменения числового значения происходят при перетаскивании строк выше или ниже соседних строк и в результате всегда обновляется первый столбец чисел в таблице.

Вот таблица

<form action="" method="post" id="sort_picks">

 <div class="sort-picks-container">

 <table class="table-preference-order" id="sortable">
<tbody class="ui-sortable">

<?php
    $counter = 1;
    foreach ( $result as $query ){ 
        $pickcheck = "SELECT * FROM picks";
        $pickcutoffcheck = $wpdb->get_results( $wpdb->prepare ($pickcheck, OBJECT_K ));
        foreach ($pickcutoffcheck as $pickcutoffresult) { ?>

        <div style="display:none;"><?php echo $pickcutoffresult->pickCutoff; ?></div>
        <?php } ?>
        <?php $maxlimit = $wpdb->get_row("SELECT count(*) as CNT1 FROM picks where User='$userid'"  ); ?>
      <tr class="ui-state-default preference-row">

        <td class="index preference-pick-order">
            <input type="text" class="pick-order" id="sort" name="sort[]" pattern="[1-<?php echo $maxlimit->CNT1; ?>]{1,2}" value="<?php echo $counter; ?>" style="border:0px;max-width:60px;font-size:20px;" readonly>
        </td>

        <td class="preference-pick-order">
          <input type="text" name="rem[]" class="borderless" style="text-align:left;width:25px;display:none;" value="<?php echo $query->REM; ?>" readonly><?php echo $query->REM; ?>
        </td>
        <td class="preference-emp-info">
          <input type="text" name="empname[]" class="borderless" style="display:none;" value="<?php echo $query->EmpName; ?>" readonly><b><?php echo $query->EmpName; ?></b>
        </td>
        <td class="preference-start-class">
          <input type="text" name="starttime[]" class="borderless" style="text-align:left;max-width:75px;display:none;" value="<?php echo $query->StartTime; ?>" readonly><?php echo $query->StartTime; ?>
        </td>
        <td class="preference-details">
            <input type="text" name="job_details[]" class="borderless" value="<?php echo $query->Job_Details; ?>" readonly style="display:none;"><?php echo $query->Job_Details; ?>
          <br>
                <input type="text" name="startdate[]" class="borderless" style="font-weight:bold;width:100%;text-align:left;display:none;" value="<?php if($query->StartDate!=""){echo date('l\, F jS Y', strtotime($query->StartDate)); }?>" readonly><?php if($query->StartDate!=""){echo date('l\, F jS Y', strtotime($query->StartDate)); }?>
        </td>
      </tr>
    <?php $counter++; ?>
 <?php  }?>
      </tbody>
 </table>

 </div>
 <br>
 <div class="sorters-holder">
    <button onclick="upNdown('up');return false;" class="sorters">&wedge; </button><br>
    <button onclick="upNdown('down');return false;" class="sorters">&vee;</button>
 </div>
        <div style="display:block;margin:auto;text-align:center;">


 <input type="submit" name="submit[]" value="Next" class="job-select-submit" id="validate">&nbsp;&nbsp;<input type="button" onclick="window.history.go(-1); return false;" value="Back" class="job-select-submit">
    </div>
 </form>

Это рабочий скрипт jQuery

 <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
 <script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.10.3/jquery-ui.js"></script>
 <script src="../wp-content/themes/Excellence_At_Work/jquery.ui.touch-punch.min.js"></script>
 <script>
 var $j = jQuery.noConflict();
 var sort;
 $j(function() {
   $j("#sortable tbody").sortable({
     change: function(event, ui) {
  sort = 0;
  $j('#sortable tr.ui-state-default:not(".ui-sortable-helper")').each(function() {
    sort++;
    if ($j(this).hasClass('ui-sortable-placeholder'))
      ui.helper.find('td input[name^=sort]').attr('name', 'sort[]').attr('value', sort).val(sort);
    else
      $j(this).find('td input[name^=sort]').attr('name', 'sort[]').attr('value', sort).val(sort);
  });
     }
   });

$j("#sortable tbody").disableSelection();
 });
 </script>
 <script>jQuery('#sortable').draggable();</script>

Как вы можете видеть в html-коде, я успешно интегрировал кнопки, необходимые для перемещения строк, однако при этом мне нужно, чтобы значение первого td также обновлялось соответствующим образом, как и метод drab and drop. Что бы я добавил к приведенному ниже javascript, чтобы получить значение ввода с именем sort [], чтобы изменить его на соответствующее числовое место в строках таблицы вновь измененного порядка по щелчку мыши?

<script>
 var order;  // variable to set the selected row index
 function getSelectedRow()
 {
    var table = document.getElementById("sortable");
    for(var i = 0; i < table.rows.length; i++)
    {
        table.rows[i].onclick = function()
        {
        if(typeof order !== "undefined"){
            table.rows[order].classList.toggle("selected");
        }

        order = this.rowIndex;
        this.classList.toggle("selected");

        };
    }

 }
 getSelectedRow();

 function upNdown(direction)
 {
    var rows = document.getElementById("sortable").rows,
        parent = rows[order].parentNode;
     if(direction === "up")
     {
     if(order > 0){
        parent.insertBefore(rows[order],rows[order - 1]);  
        // when the row go up the index will be equal to index - 1
        order--;
    }

 }

 if(direction === "down")
 {
     if(order < rows.length){
        parent.insertBefore(rows[order + 1],rows[order]);
        // when the row go down the index will be equal to index + 1
        order++;
    }
 }
 }
 </script>

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

UPDATE

Мне удалось успешно обновить строки сначала значениями td по щелчку, добавив следующий скрипт после order- и order ++, однако это решение приводит к тому, что поля ввода выпадают из td. Любое понимание того, как изменить этот скрипт, чтобы включить поле ввода?

        Array.prototype.forEach.call(document.querySelectorAll('td:first-child'), function (elem, idx) {
        elem.innerHTML = idx + 1;

ФИНАЛЬНОЕ ОБНОВЛЕНИЕ

Я успешно выполнил свою миссию и, внеся незначительные изменения в фрагмент из последнего обновления, я смог заставить вышеуказанную форму работать, как указано.

  Array.prototype.forEach.call(document.querySelectorAll('td:first-child input[name^=sort]'), function (elem, idx) {
    elem.value = idx + 1;

Изменяя

 'td:first-child'

до

'td:first-child input[name^=sort]'

Я смог сослаться на конкретное поле ввода в отличие от всех полей ввода в первом столбце td и больше не заменяю поля ввода обычным текстом.

1 Ответ

0 голосов
/ 04 сентября 2018

ФИНАЛЬНОЕ ОБНОВЛЕНИЕ

Я успешно выполнил свою миссию и, внеся незначительные изменения в фрагмент из последнего обновления, я смог заставить вышеуказанную форму работать, как указано.

Array.prototype.forEach.call(document.querySelectorAll('td:first-child input[name^=sort]'), function (elem, idx) {
elem.value = idx + 1;

Изменяя

'td:first-child'

до

'td:first-child input[name^=sort]'

Я смог сослаться на конкретное поле ввода, а не на все поля ввода в первом столбце td, и больше не заменяю поля ввода обычным текстом.

...