1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- /**
- * @file
- * Taxonomy behaviors.
- */
- (function($, Drupal) {
- /**
- * Reorder taxonomy terms.
- *
- * 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 taxonomy 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);
|