mirror of
https://github.com/MatMoul/quickdial-webext.git
synced 2025-01-12 15:35:21 +00:00
Bug: Convert separator to empty cell
This commit is contained in:
parent
beb52273a2
commit
72ab3e5f6b
@ -436,59 +436,63 @@ app.GridNodes.sync = function(gridNode, rootPath, callback){ // Sync GridNodes w
|
|||||||
function syncNode(gridNode, bookmarkItem){
|
function syncNode(gridNode, bookmarkItem){
|
||||||
gridNode.id = bookmarkItem.id;
|
gridNode.id = bookmarkItem.id;
|
||||||
gridNode.title = bookmarkItem.title;
|
gridNode.title = bookmarkItem.title;
|
||||||
if(bookmarkItem.url){
|
switch(bookmarkItem.type){
|
||||||
gridNode.type = app.GridNodes.GridNodeType.bookmark;
|
case 'bookmark':
|
||||||
if(gridNode.url != bookmarkItem.url){
|
gridNode.type = app.GridNodes.GridNodeType.bookmark;
|
||||||
gridNode.url = bookmarkItem.url;
|
if(gridNode.url != bookmarkItem.url){
|
||||||
delete gridNode.image;
|
gridNode.url = bookmarkItem.url;
|
||||||
}
|
delete gridNode.image;
|
||||||
} else if(bookmarkItem.children){
|
}
|
||||||
gridNode.type = app.GridNodes.GridNodeType.folder;
|
break;
|
||||||
var EmptyNodes = [];
|
case 'folder':
|
||||||
if(! gridNode.children) gridNode.children = [];
|
gridNode.type = app.GridNodes.GridNodeType.folder;
|
||||||
else {
|
var EmptyNodes = [];
|
||||||
for(var i=gridNode.children.length-1; i>=0; i--){
|
if(! gridNode.children) gridNode.children = [];
|
||||||
if(!gridNode.children[i]) gridNode.children[i] = { type: app.GridNodes.GridNodeType.empty };
|
else {
|
||||||
if(gridNode.children[i].type==app.GridNodes.GridNodeType.empty){
|
for(var i=gridNode.children.length-1; i>=0; i--){
|
||||||
EmptyNodes.unshift(gridNode.children[i]);
|
if(!gridNode.children[i]) gridNode.children[i] = { type: app.GridNodes.GridNodeType.empty };
|
||||||
} else {
|
if(gridNode.children[i].type==app.GridNodes.GridNodeType.empty){
|
||||||
var found = false;
|
EmptyNodes.unshift(gridNode.children[i]);
|
||||||
for(var child of bookmarkItem.children){
|
} else {
|
||||||
if(child.id==gridNode.children[i].id){
|
var found = false;
|
||||||
found = true;
|
for(var child of bookmarkItem.children){
|
||||||
break;
|
if(child.id==gridNode.children[i].id){
|
||||||
|
found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
if(! found){
|
||||||
if(! found){
|
if(i<gridNode.children.length - 1){
|
||||||
if(i<gridNode.children.length - 1){
|
gridNode.children[i] = { type: app.GridNodes.GridNodeType.empty };
|
||||||
gridNode.children[i] = { type: app.GridNodes.GridNodeType.empty };
|
EmptyNodes.unshift(gridNode.children[i]);
|
||||||
EmptyNodes.unshift(gridNode.children[i]);
|
} else {
|
||||||
} else {
|
gridNode.children.pop();
|
||||||
gridNode.children.pop();
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
for(var child of bookmarkItem.children){
|
||||||
for(var child of bookmarkItem.children){
|
var childGridNode = app.GridNodes.getChildNode(gridNode, child.id);
|
||||||
var childGridNode = app.GridNodes.getChildNode(gridNode, child.id);
|
if(!childGridNode){
|
||||||
if(!childGridNode){
|
if(EmptyNodes.length>0){
|
||||||
if(EmptyNodes.length>0){
|
childGridNode = EmptyNodes[0];
|
||||||
childGridNode = EmptyNodes[0];
|
EmptyNodes.shift();
|
||||||
EmptyNodes.shift();
|
}else {
|
||||||
}else {
|
childGridNode = {};
|
||||||
childGridNode = {};
|
gridNode.children.push(childGridNode)
|
||||||
gridNode.children.push(childGridNode)
|
}
|
||||||
}
|
}
|
||||||
|
syncNode(childGridNode, child);
|
||||||
}
|
}
|
||||||
syncNode(childGridNode, child);
|
EmptyNodes.length = 0;
|
||||||
}
|
break;
|
||||||
EmptyNodes.length = 0;
|
default:
|
||||||
} else {
|
gridNode.type = app.GridNodes.GridNodeType.empty;
|
||||||
gridNode.type = app.GridNodes.GridNodeType.empty;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
syncNode(gridNode, bookmarkItem);
|
syncNode(gridNode, bookmarkItem);
|
||||||
delete app.GridNodes._syncing;
|
delete app.GridNodes._syncing;
|
||||||
if(app.GridNodes._needSync == true) {
|
if(app.GridNodes._needSync == true) {
|
||||||
|
Loading…
Reference in New Issue
Block a user