12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- /**
- * @file
- * Taxonomy behaviors.
- */
- (function ($, Drupal) {
- /**
- * Move a block in the blocks table from one region to another.
- *
- * This behavior is dependent on the tableDrag behavior, since it uses the
- * objects initialized in that behavior to update the row.
- *
- * @type {Drupal~behavior}
- *
- * @prop {Drupal~behaviorAttach} attach
- * Attaches the drag behavior to a applicable table element.
- */
- Drupal.behaviors.termDrag = {
- attach(context, settings) {
- const backStep = settings.taxonomy.backStep;
- const forwardStep = settings.taxonomy.forwardStep;
- // Get the blocks tableDrag object.
- const tableDrag = Drupal.tableDrag.taxonomy;
- const $table = $('#taxonomy');
- const rows = $table.find('tr').length;
- // When a row is swapped, keep previous and next page classes set.
- tableDrag.row.prototype.onSwap = function (swappedRow) {
- $table.find('tr.taxonomy-term-preview').removeClass('taxonomy-term-preview');
- $table.find('tr.taxonomy-term-divider-top').removeClass('taxonomy-term-divider-top');
- $table.find('tr.taxonomy-term-divider-bottom').removeClass('taxonomy-term-divider-bottom');
- const tableBody = $table[0].tBodies[0];
- if (backStep) {
- for (let n = 0; n < backStep; n++) {
- $(tableBody.rows[n]).addClass('taxonomy-term-preview');
- }
- $(tableBody.rows[backStep - 1]).addClass('taxonomy-term-divider-top');
- $(tableBody.rows[backStep]).addClass('taxonomy-term-divider-bottom');
- }
- if (forwardStep) {
- for (let k = rows - forwardStep - 1; k < rows - 1; k++) {
- $(tableBody.rows[k]).addClass('taxonomy-term-preview');
- }
- $(tableBody.rows[rows - forwardStep - 2]).addClass('taxonomy-term-divider-top');
- $(tableBody.rows[rows - forwardStep - 1]).addClass('taxonomy-term-divider-bottom');
- }
- };
- },
- };
- }(jQuery, Drupal));
|