Skip to content

Commit

Permalink
TS: more fixed for load()
Browse files Browse the repository at this point in the history
* more fixed for #1286
* load() was not correctly clearing the HTML items, and calling removed callback
* added sample text case
* also fixed other use cases includes
  • Loading branch information
adumesny committed Aug 17, 2020
1 parent 6e8b5dc commit 50a95c3
Show file tree
Hide file tree
Showing 8 changed files with 58 additions and 32 deletions.
6 changes: 1 addition & 5 deletions spec/e2e/html/1017-items-no-x-y-for-autoPosition.html
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,7 @@
<meta name="viewport" content="width=device-width, initial-scale=1">

<link rel="stylesheet" href="../../../demo/demo.css"/>

<script src="../../../dist/jquery.min.js"></script>
<script src="../../../dist/jquery-ui.min.js"></script>
<script src="../../../src/gridstack.js"></script>
<script src="../../../src/gridstack.jQueryUI.js"></script>
<script src="../../../dist/gridstack.all.js"></script>

<style type="text/css">
.upper .grid-stack-item-content {
Expand Down
2 changes: 0 additions & 2 deletions spec/e2e/html/1102-button-between-grids.html
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,7 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>lose functionality</title>

<link rel="stylesheet" href="../../../demo/demo.css"/>

<script src="../../../dist/gridstack.all.js"></script>
</head>
<body>
Expand Down
7 changes: 1 addition & 6 deletions spec/e2e/html/1142_change_event_missing.html
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,8 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>1142 demo</title>

<link rel="stylesheet" href="../../../demo/demo.css"/>

<script src="../../../dist/jquery.min.js"></script>
<script src="../../../dist/jquery-ui.min.js"></script>
<script src="../../../src/gridstack.js"></script>
<script src="../../../src/gridstack.jQueryUI.js"></script>
<script src="../../../dist/gridstack.all.js"></script>
</head>
<body>
<div class="grid-stack">
Expand Down
7 changes: 1 addition & 6 deletions spec/e2e/html/1143_nested_acceptWidget_types.html
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,7 @@

<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css">
<link rel="stylesheet" href="../../../demo/demo.css"/>

<script src="../../../dist/jquery.min.js"></script>
<script src="../../../dist/jquery-ui.min.js"></script>
<script src="../../../src/gridstack.js"></script>
<script src="../../../src/gridstack.jQueryUI.js"></script>

<script src="../../../dist/gridstack.all.js"></script>
<style type="text/css">
.grid-stack-item-removing {
opacity: 0.8;
Expand Down
7 changes: 1 addition & 6 deletions spec/e2e/html/1155-max-row.html
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,8 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>maxRow Test</title>

<link rel="stylesheet" href="../../../demo/demo.css"/>

<script src="../../../dist/jquery.min.js"></script>
<script src="../../../dist/jquery-ui.min.js"></script>
<script src="../../../src/gridstack.js"></script>
<script src="../../../src/gridstack.jQueryUI.js"></script>
<script src="../../../dist/gridstack.all.js"></script>
</head>
<body>
<div class="container-fluid">
Expand Down
36 changes: 36 additions & 0 deletions spec/e2e/html/1286-load.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>load() Test</title>
<link rel="stylesheet" href="../../../demo/demo.css"/>
<script src="../../../demo/events.js"></script>
<script src="../../../dist/gridstack.all.js"></script>
</head>
<body>
<div class="container-fluid">
<h1>load() Test</h1>
<br/>
<div class="grid-stack">
<div class="grid-stack-item" data-gs-x="0" data-gs-y="0" data-gs-width="4" data-gs-height="2" data-gs-id="item1" id="item1">
<div class="grid-stack-item-content">item 1</div>
</div>
<div class="grid-stack-item" data-gs-x="4" data-gs-y="0" data-gs-width="4" data-gs-height="4" data-gs-id="item2" id="item2">
<div class="grid-stack-item-content">item 2</div>
</div>
</div>
</div>
<script type="text/javascript">
var grid = GridStack.init();
addEvents(grid);

grid.load([{width:2, height:1, id:'item3'}], true);
var layout = grid.save();
console.log('layout should be {x:0, y:0, width:2, height:1, id:item3}');
console.log(layout);
// expect(layout).toEqual([{x:0, y:0, width:2, height:1, id:'item3'}]);
</script>
</body>
</html>
3 changes: 2 additions & 1 deletion src/gridstack-engine.ts
Original file line number Diff line number Diff line change
Expand Up @@ -325,7 +325,8 @@ export class GridStackEngine {
}
node._id = null; // hint that node is being removed
// TODO: .splice(findIndex(),1) would be faster but apparently there are cases we have 2 instances ! (see spec 'load add new, delete others')
this.nodes = this.nodes.filter(n => n !== node);
// this.nodes = this.nodes.filter(n => n !== node);
this.nodes.splice(this.nodes.findIndex(n => n === node), 1);
if (!this.float) {
this._packNodes();
}
Expand Down
22 changes: 16 additions & 6 deletions src/gridstack.ts
Original file line number Diff line number Diff line change
Expand Up @@ -372,16 +372,19 @@ export class GridStack {
**/
public load(layout: GridStackWidget[], addAndRemove: boolean | ((w: GridStackWidget, add: boolean) => void) = true) {
let items = GridStack.Utils.sort(layout);
let removed: GridStackNode[] = [];
this.batchUpdate();
// see if any items are missing from new layout and need to be removed first
if (addAndRemove) {
this.engine.nodes.forEach(n => {
let copyNodes = [...this.engine.nodes]; // don't loop through array you modify
copyNodes.forEach(n => {
let item = items.find(w => n.id === w.id);
if (!item) {
if (typeof(addAndRemove) === 'function') {
addAndRemove(n, false);
} else {
this.removeWidget(n.el);
removed.push(n); // batch keep track
this.removeWidget(n.el, true, false);
}
}
});
Expand All @@ -399,6 +402,7 @@ export class GridStack {
}
}
});
this.engine.removedNodes = removed;
this.commit();
}

Expand Down Expand Up @@ -892,7 +896,7 @@ export class GridStack {
* @param el widget or selector to modify
* @param removeDOM if `false` DOM element won't be removed from the tree (Default? true).
*/
public removeWidget(els: GridStackElement, removeDOM = true): GridStack {
public removeWidget(els: GridStackElement, removeDOM = true, triggerEvent = true): GridStack {
this.getElements(els).forEach(el => {
if (el.parentElement !== this.el) return; // not our child!
let node = el.gridstackNode;
Expand All @@ -906,10 +910,16 @@ export class GridStack {
delete el.gridstackNode;
this.dd.draggable(el, 'destroy').resizable(el, 'destroy');

this.engine.removeNode(node, removeDOM, true); // true for trigger event
this.engine.removeNode(node, removeDOM, triggerEvent);

if (removeDOM && el.parentElement) {
el.remove(); // in batch mode engine.removeNode doesn't call back to remove DOM
}
});
this._triggerRemoveEvent();
this._triggerChangeEvent();
if (triggerEvent) {
this._triggerRemoveEvent();
this._triggerChangeEvent();
}
return this;
}

Expand Down

0 comments on commit 50a95c3

Please sign in to comment.