Constructor Attributes | Constructor Name and Description |
---|---|
REDIPS.drag Version 5.3.0 (2020-03-21)
REDIPS.drag is a JavaScript drag and drop library focused on dragging table content (DIV elements) and table rows. |
Field Attributes | Field Name and Description |
---|---|
Object contains animation properties: pause and step.
|
|
Object defines several rules related to cloning DIV elements like enable cloning with shift key, enable returning cloned DIV element to its source and so on.
|
|
Property defines working types of REDIPS.drag library for dragging DIV elements: multiple, single, switch, switching, overwrite and shift.
|
|
Hover object contains 4 properties: colorTd, colorTr, borderTd and borderTr.
|
|
Table cells marked with “redips-mark” class name can be allowed or forbidden for accessing (with exceptions) – default is “deny”.
|
|
Dragging mode “cell” or “row” (readonly).
|
|
Property defines “top” or “bottom” position of dropped element in table cell (if cell already contains DIV elements).
|
|
Currently moved DIV element.
|
|
Previously moved DIV element (before clicked or cloned).
|
|
Table cells marked with “redips-only” class name can accept only defined DIV elements.
|
|
Property defines working types of REDIPS.drag library for dragging table rows: before, after, switch and overwrite.
|
|
Save content parameter name.
|
|
Scroll object contains properties needed for autoscroll option.
|
|
Object contains several properties: shift.after, shift.mode, shift.overflow and shift.animation.
|
|
Object contains styles (colors, opacity levels) for DIV elements and table rows.
|
|
Table sort is feature where tables inside drop container are sorted on each element click.
|
|
Object contains reference to previous, source, current and target table cell.
|
|
Object contains td class name (where DIV elements can be deleted) and confirmation questions for deleting DIV element or table row.
|
Method Attributes | Method Name and Description |
---|---|
ajaxCall(url, callBack, obj)
Method calls AJAX service (using GET or POST method) and runs callback function with xhr (XMLHttpRequest) object as input parameter (xhr object is implicitly created only first time).
|
|
clearTable(el)
Method deletes all DIV elements with redips-drag class name from table.
|
|
cloneObject(div, drag)
Method clones DIV element and returns cloned element reference.
|
|
deleteObject(el)
Method deletes DIV element from table.
|
|
emptyCell(tdElement, mode)
Method tests TD if is empty or removes elements from table cell.
|
|
enableDrag(enableFlag, el)
Method attaches / detaches onmousedown, ontouchstart and ondblclick events to DIV elements and attaches onscroll event to the scroll containers in initialization phase.
|
|
enableTable(enableFlag, el)
This method can select tables by class name and mark them as enabled / disabled.
|
|
findCell(param, el)
Method returns data (cell reference, row index and column index) for first or last cell in table or row / column.
|
|
findParent(tagName, el, skip)
Method returns reference of parent DOM element.
|
|
getPosition(ip)
Method returns position as array with members tableIndex, rowIndex and cellIndex (array length is 3).
|
|
Method returns current page scroll values as array (X and Y axis).
|
|
getStyle(el, styleName)
Method returns style value for requested HTML element and style name.
|
|
init(dc)
Drag container initialization.
|
|
initTables(selector)
Tables layout initialization (preparing internal “tables” array).
|
|
loadContent(targetTable, param)
Method inserts DIV elements to the target table.
|
|
moveObject(ip)
Method will calculate parameters and start animation (DIV element to the target table cell).
|
|
relocate(from, to, mode)
Method relocates DIV elements from source table cell to the target table cell (with optional animation).
|
|
rowEmpty(tblId, rowIdx, color)
Method marks selected row as empty.
|
|
rowOpacity(el, opacity, color)
Method sets opacity to table row or deletes row content.
|
|
saveContent(tbl, type)
Method scans table content and prepares query string or JSON format for submitting to the server script.
|
|
shiftCells(td1, td2)
Method shifts table content horizontally or vertically.
|
Event Attributes | Event Name and Description |
---|---|
error.ajax(xhr, obj)
This method enables handling HTTP AJAX errors.
|
|
error.loadContent(obj)
Error handler invoked if is not possible to place DIV element to the target table during content loading.
|
|
event.changed(currentCell)
Event handler invoked on every change of current (highlighted) table cell.
|
|
event.clicked(currentCell)
Event handler invoked if a mouse button is pressed down while the mouse pointer is over DIV element.
|
|
event.cloned(clonedElement)
Event handler invoked after DIV element is cloned – interactively by moving DIV element or by calling moveObject() in “cell” mode with “clone” option.
|
|
event.clonedDropped(targetCell)
Event handler invoked after cloned DIV element is dropped.
|
|
Event handler invoked if last element is cloned (type 1).
|
|
Event handler invoked if last element is cloned (type 2).
|
|
Event handler invoked if a mouse button is clicked twice while the mouse pointer is over DIV element.
|
|
event.deleted(cloned)
Event handler invoked if element is deleted (dropped to the “trash” table cell).
|
|
event.dropped(targetCell)
Event handler invoked if element is dropped to the table cell.
|
|
event.droppedBefore(targetCell)
Event handler invoked if mouse button is released but before element is dropped to the table cell.
|
|
Event handler invoked after any DIV element action.
|
|
event.moved(cloned)
Event handler invoked if element is moved from home position.
|
|
Event handler invoked if cloned element is dropped on start position or cloned element is dropped outside current table with “clone.drop” property set to false.
|
|
Event handler invoked if mouse button is pressed down and released while the mouse pointer is over DIV element (element was not actually moved).
|
|
event.relocateAfter(div, td)
Event handler invoked after DIV element is relocated.
|
|
event.relocateBefore(div, td)
Event handler invoked before DIV element will be relocated.
|
|
Event handler invoked after all DIV elements are relocated and before table is enabled (DIV elements enabled for dragging).
|
|
event.rowChanged(currentCell)
Event handler invoked on every change of current (highlighted) table row.
|
|
event.rowClicked(currentCell)
Event handler invoked if a mouse button is pressed down while the mouse pointer is over row handler (div class=”redips-drag redips-row”).
|
|
Event handler invoked if table row is cloned.
|
|
Event handler invoked if row is deleted (dropped to the “trash” table cell).
|
|
event.rowDropped(targetRow, sourceTable, sourceRowIndex)
Event handler invoked after dropping row to the table.
|
|
event.rowDroppedBefore(sourceTable, sourceRowIndex)
Event handler invoked in the moment when mouse button is released but before row is dropped to the table.
|
|
event.rowDroppedSource(targetCell)
Event handler invoked if row is moved around and dropped to the home position.
|
|
Event handler invoked if row is moved from home position.
|
|
Event handler invoked if cloned row is dropped to the source row.
|
|
Event handler invoked if a mouse button is pressed down and released while the mouse pointer is over row handler (row was not actually moved).
|
|
Event handler invoked if row is undeleted.
|
|
Event handler invoked in a moment when overflow happen in shift mode.
|
|
event.switched(targetCell)
Event handler invoked if DIV elements are switched (dropMode is set to “switch”).
|
|
Event handler invoked if element is undeleted.
|
- {Integer} animation.pause – Animation pause (lower values means the animation will go faster). Default value is 20 (milliseconds).
- {Integer} animation.step – Value defines number of pixels in each step. Higher values means bigger step (faster animation) but with less smoothness. Default value is 2 (px).
- {Boolean} clone.keyDiv – If set to true, all DIV elements on tables could be cloned with pressed SHIFT key. Default is false.
- {Boolean} clone.keyRow – If set to true, table rows could be cloned with pressed SHIFT key. Default is false.
- {Boolean} clone.sendBack – If set to true, cloned element can be returned to its source. Default is false.
- {Boolean} clone.drop – If set to true, cloned element will be always placed to the table (to the last possible cell) no matter if is dropped outside the table. Default is false.
// elements can be dropped to all table cells (multiple elements in table cell) REDIPS.drag.dropMode = 'multiple'; // elements can be dropped only to the empty table cells REDIPS.drag.dropMode = 'single'; // switch content REDIPS.drag.dropMode = 'switch'; // switching content continuously REDIPS.drag.dropMode = 'switching'; // overwrite content in table cell REDIPS.drag.dropMode = 'overwrite'; // shift table content after element is dropped or moved to trash cell REDIPS.drag.dropMode = 'shift';
- Default Value:
- multiple
// set "#9BB3DA" as hover color for TD REDIPS.drag.hover.colorTd = '#9BB3DA'; // or set "Lime" as hover color for TR REDIPS.drag.hover.colorTr = 'Lime'; // set red border for highlighted TD REDIPS.drag.hover.borderTd = '2px solid red';
- {String} action – allow / deny table cell (default is “deny”)
- {String} cname – class name of marked cells (default is “redips-mark”)
- {Array} exception – defined DIV elements can be dropped to the table cells marked with class “redips-mark” (DIV id -> class name)
// only element with Id "d8" can be dropped to the cell with class name "mark smile" REDIPS.drag.mark.exception.d8 = 'smile';
- See:
- only
// place dropped elements to cell top REDIPS.drag.multipleDrop = 'top';
- Default Value:
- bottom
- {Array} div – defined DIV elements can be dropped only to the table cells marked with class name “redips-only” (DIV id -> class name)
- {String} cname – class name of marked cells (default is “redips-only”)
- {String} other – allow / deny dropping DIV elements to other table cells (default is “deny”)
// only element with Id "a1" can be dropped to the cell with class name "redips-only last" REDIPS.drag.only.div.a1 = 'last'; // DIV elements mentioned in REDIPS.drag.only.div cannot be dropped to other cells REDIPS.drag.only.other = 'deny';
- See:
- mark
- before – row will be dropped before highlighted row
- after – row will be dropped after highlighted row
- switch – source and highlighted rows will be switched
- overwrite – highlighted row will be overwritten
Values “before” and “after” have effect only if row is dropped to other tables (not in current table). In case of only one table, after/before is defined relatively to source row position (middle row will be dropped before highlighted row if dragged to the table top or after highlighted row in other case).
- Default Value:
- before
- Default Value:
- p
- {Boolean} scroll.enable – Enable / disable autoscroll option. By default autoscroll is enabled but it can be usefull in some cases to completely turn off autoscroll (if application doesn’t need autoscrolling page nor autoscrolling DIV container). Turning off autoscroll will speed up application because extra calculations will be skipped. Default is true
- {Integer} scroll.bound – Bound size for triggering page autoScroll or autoScroll of scrollable DIV container. Default value is 25 (px).
- {Integer} scroll.speed – Autoscroll pause in milliseconds. Default value is 20 (milliseconds).
- {String} shift.after – how to shift table content after DIV element is dropped
- {String} shift.mode – shift modes (horizontal / vertical)
- {String|HTMLElement} shift.overflow – defines how to behave when DIV element falls off the end
- {Boolean} shift.animation – if set to true, table content will be relocated with animation – default is false
shift.after option has the following values: “default”, “delete” and “always” (this property will have effect only if dropMode is set to “shift”). Default value is “default”.
- default – table content will be shifted only if DIV element is dropped to the non empty cell
- delete – same as “default” + shift table content after DIV element is moved to trash
- always – table content will be always shifted
shift.mode defines shift modes: “horizontal1”, “horizontal2”, “vertical1” and “vertical2”. Default value is “horizontal1”.
- horizontal1 – horizontal shift (element shift can affect more rows)
- horizontal2 – horizontal shift (each row is treated separately)
- vertical1 – vertical shift (element shift can affect more columns)
- vertical2 – vertical shift (each column is treated separately)
shift.overflow defines how to behave when DIV element falls off the end. Possible actions are: “bunch”, “delete” and “source”. Default value is “bunch”.
- bunch – overflow will stay in last cell
- delete – overflow will be deleted
- source – overflow will be moved to the source TD
- {HTMLElement} – overflow will be moved to user defined HTML element
// DIV elements will be shifted vertically (each column is treated separately) REDIPS.drag.shift.mode = 'vertical2'; // delete overflowed DIV element REDIPS.drag.shift.overflow = 'delete';
- See:
-
dropMode
shiftCells
- {String} style.borderEnabled – Border style for enabled DIV elements. Default is “solid”.
- {String} style.borderDisabled – Border style for disabled DIV elements. Default is “dotted”.
- {Integer} style.opacityDisabled – Opacity level for disabled elements. Default is empty string.
- {String} style.rowEmptyColor – “Empty row” color. When last row from table is moved then this color will be set to “empty row”. Default is “white”.
// define border style for disabled elements REDIPS.drag.style.borderDisabled = 'dashed';
- Default Value:
- true
- {HTMLElement} td.source – reference to source table cell (set in onmousedown)
- {HTMLElement} td.previous – reference to previous table cell (set in onmousemove and autoscroll)
- {HTMLElement} td.current – reference to current table cell (set in onmousemove and autoscroll)
- {HTMLElement} td.target – reference to target table cell (target table cell is set in a moment of dropping element to the table cell)
- {String} trash.className – Class name of td which will become trash can. Default value is “redips-trash”.
- {String} trash.question – If trash.question is set then popup will appear and ask to confirm element deletion. Default value is null.
- {String} trash.questionRow – If trash.questionRow is set then popup will appear and ask to confirm row deletion. Default value is null.
// confirm DIV element delete action REDIPS.drag.trash.question = 'Are you sure you want to delete DIV element?'; // confirm row delete action REDIPS.drag.trash.questionRow = 'Are you sure you want to delete table row?';
// simple AJAX call without callback function REDIPS.drag.ajaxCall('ajax_save.php?a=1&b=2'); // simple AJAX call (GET method) REDIPS.drag.ajaxCall('ajax_menu.php?month=2&year=2017', myHandler); // AJAX call with passing dragged element as div property REDIPS.drag.ajaxCall('ajax_menu.php?month=2&year=2017', myHandler, {div: rd.obj}); // AJAX call with POST method and data in name-value format // header 'application/x-www-form-urlencoded' is automatically applied REDIPS.drag.ajaxCall('ajax_menu.php', myHandler, {method: 'POST', data: 'name1=value1&name2=value2'}); // xhr is XMLHttpRequest object and obj is passed from ajaxCall() to this callback function // obj is optionally defined and if is not needed then it can be omitted as input parameter myHandler = function (xhr, obj) { ... ... }; // it is also possible to wrap error handling inside callback function // this can be useful in case of many different AJAX calls with specific error processing to each call myHandler = function (xhr, obj) { // if status is OK if (xhr.status === 200) { ... } // otherwise display error else { setTimeout(function () { alert('AJAX error: [' + xhr.status + '] ' + xhr.statusText); }, 10); } }; // general error handler called in case of AJAX error (if xhr.status !== 200) // obj is optional parameter REDIPS.drag.error.ajax = function (xhr, obj) { // non blocking alert (alert called with setTimeout()) setTimeout(function () { alert('AJAX error: [' + xhr.status + '] ' + xhr.statusText); }, 10); // return false to stop execution of callback function return false; };
- Parameters:
- {String} url
- URL address of AJAX service. In case of GET method it should contain all parameters in name-value format.
- {Object} callBack Optional
- Callback function called after request is ended (successfully or not). Function is called with xhr (XMLHttpRequest) object and obj object as input parameters.
- {Object} obj Optional
- Object with optional AJAX parameters (like POST method and data) or used for sending additional parameters to the callback function.
- See:
- error.ajax
// delete all DIV elements from table with id=tbl1 rd.clearTable('tbl1');
- Parameters:
- {String|HTMLElement} el
- Table Id or table reference from which all elements should be deleted.
- Parameters:
- {HTMLElement} div
- DIV element to clone.
- {Boolean} drag Optional
- If set to true, then cloned DIV element will be ready for dragging (otherwise element will be only cloned).
- Returns:
- {HTMLElement} Returns cloned DIV element.
// delete DIV element in event.dropped() event handler rd.event.dropped = function () { rd.deleteObject(rd.obj); } // delete DIV element with id="d1" rd.deleteObject('d1');
- Parameters:
- {String|HTMLElement} el
- Id of DIV element or reference of DIV element that should be deleted.
// set REDIPS.drag reference var rd = REDIPS.drag; // search for TABLE element (from cell reference) tbl = rd.emptyCell(td); // how to test TD if cell is occupied var empty = rd.emptyCell(td, 'test');
- Parameters:
- {HTMLElement} tdElement
- Table cell to test or from which all the elements will be deleted.
- {String} mode Optional
- If mode is set to “test” then method will only test TD and return true or false.
- Returns:
- {Boolean|Array} Returns true/false depending on cell content or array with deleted child nodes.
// enable element with id="id123" (element id should be string according to DOM docs) rd.enableDrag(true, '#id123'); // or init manually added element with known id REDIPS.drag.enableDrag(true, '#id234'); // disable all DIV elements in drag1 subtree rd.enableDrag(false, '#drag1 div') // init DIV elements in dragging area (including newly added DIV element) // DIV initialization will work if table node stays intact (table is not generated dynamically) REDIPS.drag.enableDrag('init'); // init added element with reference myElement REDIPS.drag.enableDrag(true, myElement); // disable all DIV elements within TD (td is reference to TD node) REDIPS.drag.enableDrag(false, td);
- Parameters:
- {Boolean|String} enableFlag
- Enable / disable element (or element subtree like table, dragging container …).
- {HTMLElement|String} el Optional
- HTML node or CSS selector to enable / disable. Parameter defines element reference or CSS selector of DIV elements to enable / disable.
- See:
-
init
enableTable
// disable tables with class name 'mini' enableTable(false, 'mini');
- Parameters:
- {Boolean} enableFlag
- Enable / disable one or more tables.
- {String|HTMLElement} el
- Class name of table(s) to enable/disable or table reference to enable/disable.
- See:
- enableDrag
// find first cell in row (el is table cell reference) firstInRow = findCell('firstInRow', el); // find last cell in table (el is reference of any cell inside table) last = findCell('last', el); // find last cell in column (el is table cell reference) lastInColumn = findCell('lastInColumn', el);
- Parameters:
- {String} param
- Parameter defines first or last table cell (values are “first”, “firstInColumn”, “firstInRow”, “last”, “lastInColumn”, “lastInRow”).
- {HTMLElement} el
- Table cell reference (td). For “first” or “last” request, el can be any HTMLElement within table.
- Returns:
- {Array} Returns array with row index, column index and cell reference,
// find parent TABLE element (from cell reference) tbl = findParent('TABLE', cell); // find reference of the outside table (start node is TD in inner table - first TABLE node should be skipped) tbl = findParent('TABLE', cell, 1);
- Parameters:
- {String} tagName
- Tag name of parent element.
- {HTMLElement} el
- Start position to search.
- {Integer} skip Optional
- How many found nodes should be skipped. For example when start node is TD in inner table and findParent() should return reference of the outside table.
- Returns:
- {HTMLElement} Returns reference of the found parent element.
// set REDIPS.drag reference var rd = REDIPS.drag; // display target and source position of dropped element rd.event.dropped = function () { // get target and source position (method returns positions as array) // pos[0] - target table index // pos[1] - target row index // pos[2] - target cell (column) index // pos[3] - source table index // pos[4] - source row index // pos[5] - source cell (column) index var pos = rd.getPosition(); // display element positions console.log(pos); };
- Parameters:
- {String|HTMLElement} ip Optional
- DIV element id / reference or table cell id / reference.
- Returns:
- {Array} Returns array with members tableIndex, rowIndex and cellIndex. If position is not found then all array members will have value -1.
- Returns:
- {Array} Returns array with two values [ scrollX, scrollY ].
- Parameters:
- {HTMLElement} el
- Requested HTML element.
- {String} styleName
- Asked style name.
- Returns:
- {String} Returns style value.
// init drag container (with default id="redips-drag") REDIPS.drag.init(); // init drag container with id="my-drag1" REDIPS.drag.init('my-drag1');
- Parameters:
- {String} dc Optional
- Drag container Id (default is “redips-drag”).
- See:
-
initTables
enableDrag
// call initTables after new empty table is added to the div#redips-drag // REDIPS.init() method will also work but with some overhead REDIPS.drag.initTables(); // change default selector for table search (div#sticky may contain table that is attached out of default drag container) // this means that table should not be a part of div#redips-drag, but it should be positioned within drag container otherwise dragging will not work REDIPS.drag.initTables('#my-drag table, #sticky table'); // if new table is not empty and contains DIV elements then they should be enabled also // DIV elements in "redips-drag" container are enabled by default REDIPS.drag.initTables('#my-drag table, #sticky table'); REDIPS.drag.enableDrag(true, '#sticky div');
- Parameters:
- {String} selector Optional
- Defines selector for table search (default id “#redips-drag table”).
- Absolute or relative URL of AJAX service that returns JSON data (e.g. ‘/service/db_data.php’)
- JSON text containing information how to insert DIV elements
- Array containing information how to insert DIV elements
Form of JSON text or array is the same as produced from saveContent() method: [[“id”,r,c,”n”,”t”],[“id”,r,c,”n”,”t”], …]
- id – element id
- r – row index
- c – cell index
- n – class names
- t – DIV innerHTML
// load content from AJAX service to table with reference targetTable REDIPS.drag.loadContent(targetTable, 'db_ajax1.php'); // load content from JSON text to table with reference targetTable REDIPS.drag.loadContent(targetTable, '[["d16", 6, 2, "orange", "B2"], ["d17", 7, 4, "orange", "B1"]]'); // load content from array to table with id "myTable" REDIPS.drag.loadContent('myTable', [["d6", 6, 2, "green", "A2"], ["d7", 7, 4, "green", "A1"]]);
- Parameters:
- {HTMLElement|String} targetTable
- Reference or id of target table where DIV elements will be inserted
- {String|Array} param
- JSON text or array (JSON formatted array) or AJAX URL to retrieve JSON data
- {String} id – id of element to animate – DIV element or row handler (div class=”redips-drag redips-row”)
- {String} obj – reference of element to animate – DIV element or row handler (if “id” parameter exists, “obj” parameter will be ignored)
- {String} mode – animation mode (if mode=”row” then source and target properties should be defined)
- {Boolean} clone – if set to true then DIV element will be cloned instead of moving (used only in “cell” mode and default is false)
- {Boolean} overwrite – if set to true then elements in target cell will be overwritten (used only in “cell” mode and default is false)
- {Array} source – source position (table index and row index)
- {Array} target – target position (table, row and cell index (optional for “row” mode)
- {Function} callback – callback function executed after animation is finished
Method returns array containing reference of two object. In “cell” mode returned objects are:
- Array[0] – dragged element
- Array[1] – dragged element
In “row” mode returned objects are:
- Array[0] – tableMini
- Array[1] – source row
If “clone” parameter is set to true then event.cloned() event handler will be invoked with input parameter of cloned element.
// move element with id="a1" to the current location and after // animation is finished display alert "Finished" rd.moveObject({ id: 'a1', callback: function () { alert('Finished'); } }); // move DIV element with reference "mydiv" to the TD with reference td rd.moveObject({ obj: mydiv, target: td }); // move DIV element with reference "mydiv" to the first table, second row and third cell rd.moveObject({ obj: mydiv, target: [0, 1, 2] }); // move element with id="a2" to the first table, second row and third cell rd.moveObject({ id: 'a2', target: [0, 1, 2] }); // clone DIV element with reference "mydiv", move to the first table, second row, // third cell and overwrite all content in target cell rd.moveObject({ obj: mydiv, clone: true, overwrite: true, target: [0, 1, 2] }); // move first row and after animation is finished call "enable_button" function // "moveObject" returns Array with references of tableMini and source row row = rd.moveObject({ mode: 'row', // animation mode - row source: [0, 0], // source position (table index and row index) target: [0, 6], // target position callback: enable_button // function to call after animation is over });
- Parameters:
- {Object} ip
- Object with properties: id, mode, source, target and callback.
- Returns:
- {Array|Boolean} Returns reference of two elements in array or false. In “cell” mode both elements are dragged element, while in “row” mode first element is tableMini and second element is source row or it could be false if “emptyRow” try to move.
- See:
- relocate
- Parameters:
- {HTMLElement} from
- Source table cell.
- {HTMLElement} to
- Target table cell.
- {String} mode Optional
- Relocation mode “instant” or “animation”. Default is “instant”.
// set reference to the REDIPS.drag library rd = REDIPS.drag; // mark first row as empty in table with id="tbl1" rd.rowEmpty('tbl1', 0);
- Parameters:
- {String} tblId
- Table id.
- {Integer} rowIdx
- Row index (starts from 0).
- {String} color Optional
- Color of empty row (default is “White” or defined with REDIPS.drag.rowEmptyColor parameter).
- See:
- style.rowEmptyColor
// set reference to the REDIPS.drag library rd = REDIPS.drag; // make row semi-transparent rd.rowOpacity(rowObj, 50); // set row as empty and white (content in table cells will be deleted) rd.rowOpacity(rowObj, 'empty', 'White');
- Parameters:
- {HTMLElement|String} el
- Id of row handler (div class=”redips-drag redips-row”) or reference to element (source row or mini table).
- {Integer|String} opacity
- Opacity level (from 0 to 100) or “empty” (then content of table cells in row will be deleted – in that case first parameter should be TR).
- {String} color Optional
- Background color.
Query string: 'p[]='+id+'_'+r+'_'+c+'_'+n+'_'+t+'&p[]='+id+'_'+r+'_'+c+'_'+n+'_'+t ... JSON: [["id",r,c,"n","t"],["id",r,c,"n","t"], ...] id - element id r - row index c - cell index n - class names t - DIV innerText Query string example: p[]=d1_1_0_blue_Name1&p[]=d2_1_1_green_Name2&p[]=d3_5_2_green_Name3&p[]=d4_5_3_red_Name4 JSON output example: [["d1",1,0,"blue","Name1"],["d2",1,1,"green","Name2"],["d3",5,2,"green","Name3"],["d4",5,3,"red","Name4"]]
- Parameters:
- {String|HTMLElement} tbl
- Id or reference of table that will be scanned.
- {String} type Optional
- Type defines output format. If set to “json” then output will be JSON format otherwise output will be query string.
- Returns:
- {String} Returns table content as query string or in JSON format.
- See:
-
saveParamName
loadContent
// define first and last table cell var firstCell = document.getElementById('firstCellOnTable'), lastCell = document.getElementById('lastCellOnTable'); // enable animation REDIPS.drag.shift.animation = true; // shift content REDIPS.drag.shiftCells(lastCell, firstCell);
- Parameters:
- {HTMLElement} td1
- Source table cell.
- {HTMLElement} td2
- Target table cell.
- See:
- shift.mode
- Parameters:
- {Object} xhr Optional
- Input parameter is XMLHttpRequest object (xhr)
- {Object} obj Optional
- Object with optional AJAX parameters (like POST method and data) or used for sending additional parameters to the callback function.
- See:
- ajaxCall
- In case of AJAX error – {0, ‘AJAX error description’, null, null, null}
- If input JSON string is not parsable – {0, ‘JSON parse error’, null, null, null}
- If target table does not exist – {0, ‘Target table does not exist’, null, null, null}
- In case of nonexisting TR – {1, ‘Target TR does not exist’, ‘DIV_content’, row_index, cell_index}
- In case of nonexisting TD – {2, ‘Target TD does not exist’, ‘DIV_content’, row_index, cell_index}
Error type 0 (AJAX error, JSON parse error or table doesn’t exist) is non-recoverable error (after calling loadError() event handler, loadContent() method will stop). If boolen “false” is returned from this event handler, further processing will be stopped. It refers to error type 1 and type 2.
- Parameters:
- {Object} obj Optional
- Object properties are: type (message type), message text (error description), content (DIV content), rowIndex and cellIndex
- See:
- loadContent
// set REDIPS.drag reference var rd = REDIPS.drag; // define event.changed handler rd.event.changed = function () { // get current position (method returns positions as array) var pos = rd.getPosition(); // display current row and current cell console.log('Changed: ' + pos[1] + ' ' + pos[2]); };
- Parameters:
- {HTMLElement} currentCell Optional
- Reference to the current (highlighted) table cell.
- See:
- getPosition
- Parameters:
- {HTMLElement} currentCell Optional
- Reference to the table cell of clicked element.
- Parameters:
- {HTMLElement} clonedElement Optional
- Cloned element reference.
- See:
- moveObject
- Parameters:
- {HTMLElement} targetCell Optional
- Reference to the target table cell.
- Parameters:
- {Boolean} cloned Optional
- True if cloned element is directly moved to the trash (in one move). If cloned element is dropped to the table and then moved to the trash then “cloned” parameter will be set to false.
- Parameters:
- {HTMLElement} targetCell Optional
- Target cell reference.
- Parameters:
- {HTMLElement} targetCell Optional
- Target cell reference.
- event.droppedBefore
- event.dropped (only if event.droppedBefore doesn’t return false)
- event.finish
- So, event.finish will be called after deleting DIV element, cloning, switching and so on. Its main purpose is to execute some common code (like “cleaning”) after any DIV element action.
- Parameters:
- {Boolean} cloned Optional
- True if moved element is actually a cloned DIV. Needed for cases when obj or objOld should be used.
- See:
- clone.drop
- Parameters:
- {HTMLElement} div
- Reference of DIV element that is relocated.
- {HTMLElement} td
- Reference of TD where DIV element is relocated.
- Parameters:
- {HTMLElement} div
- Reference of DIV element that will be relocated.
- {HTMLElement} td
- Reference of TD where DIV element will be relocated.
- Parameters:
- {HTMLElement} currentCell Optional
- Reference to the current (highlighted) table cell.
- Parameters:
- {HTMLElement} currentCell Optional
- Reference to the table cell of clicked element.
- Parameters:
- {HTMLElement} targetRow Optional
- Reference to the target row (dropped row).
- {HTMLElement} sourceTable Optional
- Source table reference. If row is dropped to the same table then this reference and targetRow will be in correlation (actually “source table” contains targetRow).
- {Integer} sourceRowIndex Optional
- Source row index.
- Parameters:
- {HTMLElement} sourceTable Optional
- Source table reference.
- {Integer} sourceRowIndex Optional
- Source row index.
If boolen “false” is returned from event handler then row drop will be canceled.
- Parameters:
- {HTMLElement} targetCell Optional
- Reference to the target table cell.
- See:
- trash
- Parameters:
- {HTMLElement} td
- Reference of TD where overflow happen.
- See:
- dropMode
- Parameters:
- {HTMLElement} targetCell Optional
- Reference to the target table cell.
- See:
- dropMode
- See:
- trash
@Sergio – I’m glad it works and you are the first who uses this new functionality. I hope this week will be completed docs and example28 so new package will be uploaded from GitHub to Redips site.
Cheers!
Dear dbunic
It’s me again :)
And again, thankyou for your time and service!
Before using REDIPS i was using zepto (online demo at http://james2doyle.github.io/zepto-dragswap/)
One of the things that i am missing from zepto is the visual feedback that gives to the user.
On average, the users of my app (chrome-extension for an npo) are not very computer-skillful, so the more user-friendliness and visual feedback i provide them, the better.
My idea is to add the zepto visual feedback (fade and zoom in/out when dragging) into REDIPS. At a first glance it looks just a barely CSS copy&paste, but since you know the REDIPS library from head to feet, certainly it would save me lots of time to ask you for advice about wether it will also be necessary to tinker a bit with the REDIPS code and, if so, where should i start looking at or how should i approach it better.
And maybe in future, create a git fork :)
Thankyou!
Metta
Hi Sergio,
just to note that new REDIPS.drag library ver 5.2.2 is published (package, demo and documentation). Example 28 “Load table content” is also finished.
To add some visual effects you can use CSS. I have prepared simple jsFiddle demo to show what can be done with hover and “transition”. I assume that other styles can be applied too. Hope this will give you some ideas. Cheers!
https://jsfiddle.net/dbunic/ju9vg6gr/
Dear dbunic, thank you!
I have modified saveContent/loadContent to meet server requirements (i.e: “A1” instead of 0,0 ) but I keep this code outside REDIPS.drag to be able to keep up with future library updates from your side in a clean way.
About the visual effects, I want to detect the beginning of the drag (to change CSS on the source element and keep it for all the duration of the drag), and also detect the drop event, to change back the source CSS and also to change the CSS of the target element. So I have been logging different redips-events. When dragging element OM0001 on top of OM0002 (and dropMode is ‘switch’) this is the console for some events:
So I guess I have to work with event.clicked to capture the ORIGIN element and change its CSS and then with event.droppedBefore to detect the drop and revert back the CSS of the ORIGIN element and also capture the TARGET element to change its CSS.
Does this sound reliable? Any advice? I am unsure about the droppedBefore event. The documentation says:
Event handler invoked if mouse button is released but before element is dropped to the table cell.
… which is not very clear to me. Could you please clarify if droppedBefore is appropriate for my purpose.
Thank you!
Hi Sergio,
if you want to track the way of dragged element then your event listeners are event.clicked and event.dropped or event.droppedBefore. Difference between latter two are in possibility that event.droppedBefore can execute JS code before DIV element is dropped while event.dropped executes JS code after DIV element is dropped.
In your case, event.dropped is maybe better option because you want to return back CSS to previous state after DIV element is dropped to the target position. Anyway, I guess that JS code written in any of these event handlers (dropped or droppedBefore) will do the job.
Dear Dbunic
Here i am again. And again, thanks for your library. When using loadContent, in the 2nd parameter i pass a JSON object in the required format:
But it happens that “t” contains HTML tags i would like to be rendered as proper HTML. So i ended up doing something that i dont like: modify the source code of the redips library, specifically, line #3319:
Is there a “standard” way to achieve same result without modifiying the REDIPS library (and thus, keep future updates compatibility)?
Thank you very much!
Metta
Hi Sergio,
maybe is better to use innerHTML property than textContent (as you already made change). I will test the code with this change and apply it to the REDIPS source. With innerHTML, all should work as before but with option to send HTML tags.
Thanks
Hello , thank you for this beautifull API.
I want to know if there is a way to affect a fixed number of values to REDIPS.drag.dropMode , not just ‘multiple’ .
Thank you
Hi Jamil,
REDIPS.drag.dropMode property allows dropping more than one DIV element in a table cell. If you need to define maximum number of elements per TD, then it can be done in event.droppedBefore(targetCell) event handler. With some simple JS code inside, it’s possible to count DIV elements in “targetCell” and just return “false” if count is greater than maximum allowed number. This way, dragged DIV element will not be dropped.
Hope this info will be helpful,
cheers!
Hi Dbunic,
That’s what i wanted to know.
Thank you so much !
Hello I’m Baek,
First Thanks for your making REDIPS.
and Just wondering, How does it use required jQuery Version??
REDIPS.drag is stand-alone library and it doesn’t need jQuery but you can use jQuery with REDIPS.drag if needed.
Hi dbunic.
First of all I want to say “thank you” for your library.
I am using your library one of my requirement and I have one problem whether that is browser issue or some thing else, Darg-Drop not working in Chrome 65.0.3325.181.
So can you please help me out on same.
Regards,
Prasanna
Hi, as I can test REDIPS.drag library in https://www.browserling.com/ (Win7, Chrome ver. 65), everything is working just fine. I will suggest you to prepare JSFiddle example to show where is exactly the problem. This way I can try to make correction in library if needed. Cheers
Hi,
Thank you for this easy to use tool.
I ve just faced a problem. If I put an element with click event under div#drag , redips does not allow to work this element’s click correctly. Is there a way to fix this issue?
Hi dbunic!
I am trying to drag element and other DIVs that are in the same row and move them in block, is it possible?
Like example 12 but without selecting the DIVs to be moved, and by default, if you move B, move the D at the same time
Thanks
Hello, thank you for this amazing Drag’n’drop plugin)
Congratulations again on your product … In example 13 there is an error accessing the Database. I keep trying to adapt the PlugIn to my System
Hi Gerardo,
I’m guessing that your think on example03 “School time table”. Please see docs/readme.txt about details. In short, to have working example on local host, it’s needed to create simple MySQL database and two tables with database.sql script (script is included in example03). And last step is to set database name, user name and password in config_mysqli.php file. With created database tables and enabling access from PHP, example03 should work and you should be able to save table content (DIV type and position) to database.
Hello dbunic, maybe some way to destroy all the events etc… and clean redips? it is possible REDIPS have memory leaks on things like Vue etc….?