mirror of
https://github.com/zombieFox/nightTab.git
synced 2025-01-01 11:39:02 +01:00
425 lines
10 KiB
JavaScript
425 lines
10 KiB
JavaScript
|
var links = (function() {
|
||
|
|
||
|
var _bind = function(override) {
|
||
|
var options = {
|
||
|
element: null,
|
||
|
action: null
|
||
|
};
|
||
|
if (override) {
|
||
|
options = helper.applyOptions(options, override);
|
||
|
}
|
||
|
var action = {
|
||
|
edit: function() {
|
||
|
options.element.addEventListener("click", function() {
|
||
|
edit(this);
|
||
|
}, false);
|
||
|
},
|
||
|
delete: function() {
|
||
|
options.element.addEventListener("click", function() {
|
||
|
remove(this);
|
||
|
}, false);
|
||
|
}
|
||
|
};
|
||
|
if (options.element != null) {
|
||
|
action[options.action]();
|
||
|
}
|
||
|
};
|
||
|
|
||
|
var currentEditIndex = null;
|
||
|
var currentAction = null;
|
||
|
|
||
|
var add = function() {
|
||
|
currentAction = "add";
|
||
|
var form = _makeLinkForm();
|
||
|
modal.render({
|
||
|
heading: "Add a new bookmark",
|
||
|
action: save,
|
||
|
actionText: "Add",
|
||
|
size: "small",
|
||
|
content: form
|
||
|
});
|
||
|
};
|
||
|
|
||
|
var edit = function(button) {
|
||
|
currentAction = "edit";
|
||
|
currentEditIndex = parseInt(button.closest(".link-item").dataset.index, 10);
|
||
|
var currentBookmark = bookmarks.get()[currentEditIndex];
|
||
|
var form = _makeLinkForm();
|
||
|
form.querySelector(".link-form-input-letter").value = currentBookmark.letter;
|
||
|
form.querySelector(".link-form-input-name").value = currentBookmark.name;
|
||
|
form.querySelector(".link-form-input-url").value = currentBookmark.url;
|
||
|
modal.render({
|
||
|
heading: "Edit " + currentBookmark.name,
|
||
|
action: save,
|
||
|
actionText: "Save",
|
||
|
size: "small",
|
||
|
content: form
|
||
|
});
|
||
|
};
|
||
|
|
||
|
var save = function(button) {
|
||
|
var action = {
|
||
|
add: function(newLinkData) {
|
||
|
bookmarks.add(newLinkData);
|
||
|
},
|
||
|
edit: function(newLinkData) {
|
||
|
bookmarks.edit(newLinkData, currentEditIndex);
|
||
|
}
|
||
|
};
|
||
|
var form = helper.e(".link-form");
|
||
|
var newLinkData = {
|
||
|
letter: form.querySelector(".link-form-input-letter").value,
|
||
|
name: form.querySelector(".link-form-input-name").value,
|
||
|
url: form.querySelector(".link-form-input-url").value
|
||
|
};
|
||
|
action[currentAction](newLinkData);
|
||
|
currentEditIndex = null;
|
||
|
currentAction = null;
|
||
|
clear();
|
||
|
render();
|
||
|
data.save();
|
||
|
};
|
||
|
|
||
|
var remove = function(button) {
|
||
|
var index = parseInt(button.closest(".link-item").dataset.index, 10);
|
||
|
bookmarks.remove(index);
|
||
|
clear();
|
||
|
render();
|
||
|
data.save();
|
||
|
};
|
||
|
|
||
|
var _makeElement = function(override) {
|
||
|
var options = {
|
||
|
tag: null,
|
||
|
classes: null,
|
||
|
text: null,
|
||
|
url: null,
|
||
|
index: null,
|
||
|
attr: null
|
||
|
};
|
||
|
if (override) {
|
||
|
options = helper.applyOptions(options, override);
|
||
|
};
|
||
|
var element = document.createElement(options.tag);
|
||
|
if (options.text != null) {
|
||
|
element.textContent = options.text;
|
||
|
};
|
||
|
if (options.attr != null) {
|
||
|
options.attr.forEach(function(arrayItem, index) {
|
||
|
if ("key" in arrayItem && "value" in arrayItem) {
|
||
|
element.setAttribute(arrayItem.key, arrayItem.value);
|
||
|
} else if ("key" in arrayItem) {
|
||
|
element.setAttribute(arrayItem.key, "");
|
||
|
}
|
||
|
});
|
||
|
};
|
||
|
return element;
|
||
|
};
|
||
|
|
||
|
var _makeLinkForm = function() {
|
||
|
var form = _makeElement({
|
||
|
tag: "form",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-form"
|
||
|
}]
|
||
|
});
|
||
|
var fieldset = _makeElement({
|
||
|
tag: "fieldset"
|
||
|
});
|
||
|
var letterLabel = _makeElement({
|
||
|
tag: "label",
|
||
|
text: "Letters",
|
||
|
attr: [{
|
||
|
key: "for",
|
||
|
value: "letters"
|
||
|
}]
|
||
|
});
|
||
|
var letterInput = _makeElement({
|
||
|
tag: "input",
|
||
|
attr: [{
|
||
|
key: "type",
|
||
|
value: "text"
|
||
|
}, {
|
||
|
key: "class",
|
||
|
value: "link-form-input-letter"
|
||
|
}, {
|
||
|
key: "id",
|
||
|
value: "letters"
|
||
|
}, {
|
||
|
key: "placeholder",
|
||
|
value: "E"
|
||
|
}, {
|
||
|
key: "tabindex",
|
||
|
value: "1"
|
||
|
}, {
|
||
|
key: "autocomplete",
|
||
|
value: "off"
|
||
|
}]
|
||
|
});
|
||
|
var nameLabel = _makeElement({
|
||
|
tag: "label",
|
||
|
text: "Name",
|
||
|
attr: [{
|
||
|
key: "for",
|
||
|
value: "name"
|
||
|
}]
|
||
|
});
|
||
|
var nameInput = _makeElement({
|
||
|
tag: "input",
|
||
|
attr: [{
|
||
|
key: "type",
|
||
|
value: "text"
|
||
|
}, {
|
||
|
key: "class",
|
||
|
value: "link-form-input-name"
|
||
|
}, {
|
||
|
key: "id",
|
||
|
value: "name"
|
||
|
}, {
|
||
|
key: "placeholder",
|
||
|
value: "Example"
|
||
|
}, {
|
||
|
key: "tabindex",
|
||
|
value: "1"
|
||
|
}, {
|
||
|
key: "autocomplete",
|
||
|
value: "off"
|
||
|
}]
|
||
|
});
|
||
|
var urlLabel = _makeElement({
|
||
|
tag: "label",
|
||
|
text: "URL",
|
||
|
attr: [{
|
||
|
key: "for",
|
||
|
value: "url"
|
||
|
}]
|
||
|
});
|
||
|
var urlInput = _makeElement({
|
||
|
tag: "input",
|
||
|
attr: [{
|
||
|
key: "type",
|
||
|
value: "text"
|
||
|
}, {
|
||
|
key: "class",
|
||
|
value: "link-form-input-url"
|
||
|
}, {
|
||
|
key: "id",
|
||
|
value: "url"
|
||
|
}, {
|
||
|
key: "placeholder",
|
||
|
value: "https://www.example.com/"
|
||
|
}, {
|
||
|
key: "tabindex",
|
||
|
value: "1"
|
||
|
}, {
|
||
|
key: "autocomplete",
|
||
|
value: "off"
|
||
|
}]
|
||
|
});
|
||
|
fieldset.appendChild(letterLabel);
|
||
|
fieldset.appendChild(letterInput);
|
||
|
fieldset.appendChild(nameLabel);
|
||
|
fieldset.appendChild(nameInput);
|
||
|
fieldset.appendChild(urlLabel);
|
||
|
fieldset.appendChild(urlInput);
|
||
|
form.appendChild(fieldset);
|
||
|
return form;
|
||
|
};
|
||
|
|
||
|
var render = function(array) {
|
||
|
var makeLinks = function(arrayOflinks) {
|
||
|
arrayOflinks.forEach(function(item, index) {
|
||
|
var gridItemBody = helper.e(".grid-item-body");
|
||
|
var linkItem = _makeElement({
|
||
|
tag: "div",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-item"
|
||
|
}, {
|
||
|
key: "data-index",
|
||
|
value: index
|
||
|
}]
|
||
|
});
|
||
|
var linkPanelFront = _makeElement({
|
||
|
tag: "a",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-panel-front"
|
||
|
}, {
|
||
|
key: "href",
|
||
|
value: item.url
|
||
|
}, {
|
||
|
key: "tabindex",
|
||
|
value: 1
|
||
|
}]
|
||
|
});
|
||
|
var linkPanelBack = _makeElement({
|
||
|
tag: "div",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-panel-back"
|
||
|
}]
|
||
|
});
|
||
|
var linkLetter = _makeElement({
|
||
|
tag: "p",
|
||
|
text: item.letter,
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-letter"
|
||
|
}, {
|
||
|
key: "data-index",
|
||
|
value: item.url
|
||
|
}]
|
||
|
});
|
||
|
var linkName = _makeElement({
|
||
|
tag: "p",
|
||
|
text: item.name,
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-name"
|
||
|
}]
|
||
|
});
|
||
|
var linkUrl = _makeElement({
|
||
|
tag: "div",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-url"
|
||
|
}]
|
||
|
});
|
||
|
var linkUrlText = _makeElement({
|
||
|
tag: "p",
|
||
|
text: item.url.replace(/^https?\:\/\//i, "").replace(/\/$/, ""),
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-url-text"
|
||
|
}]
|
||
|
});
|
||
|
var linkControl = _makeElement({
|
||
|
tag: "div",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "link-control"
|
||
|
}]
|
||
|
});
|
||
|
var linkEdit = _makeElement({
|
||
|
tag: "button",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "button button-small link-control-item link-edit"
|
||
|
}, {
|
||
|
key: "tabindex",
|
||
|
value: -1
|
||
|
}]
|
||
|
});
|
||
|
// var linkEditText = _makeElement({
|
||
|
// tag: "span",
|
||
|
// text: "Edit",
|
||
|
// attr: [{
|
||
|
// key: "class",
|
||
|
// value: "button-text"
|
||
|
// }]
|
||
|
// });
|
||
|
var linkEditIcon = _makeElement({
|
||
|
tag: "span",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "button-icon icon-edit"
|
||
|
}]
|
||
|
});
|
||
|
var linkDelete = _makeElement({
|
||
|
tag: "button",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "button button-small link-control-item link-delete"
|
||
|
}, {
|
||
|
key: "tabindex",
|
||
|
value: -1
|
||
|
}]
|
||
|
});
|
||
|
// var linkDeleteText = _makeElement({
|
||
|
// tag: "span",
|
||
|
// text: "Delete",
|
||
|
// attr: [{
|
||
|
// key: "class",
|
||
|
// value: "button-text"
|
||
|
// }]
|
||
|
// });
|
||
|
var linkDeleteIcon = _makeElement({
|
||
|
tag: "span",
|
||
|
attr: [{
|
||
|
key: "class",
|
||
|
value: "button-icon icon-close"
|
||
|
}]
|
||
|
});
|
||
|
|
||
|
_bind({
|
||
|
element: linkEdit,
|
||
|
action: "edit"
|
||
|
});
|
||
|
_bind({
|
||
|
element: linkDelete,
|
||
|
action: "delete"
|
||
|
});
|
||
|
|
||
|
linkPanelFront.appendChild(linkLetter);
|
||
|
linkPanelFront.appendChild(linkName);
|
||
|
linkEdit.appendChild(linkEditIcon);
|
||
|
// linkEdit.appendChild(linkEditText);
|
||
|
linkDelete.appendChild(linkDeleteIcon);
|
||
|
// linkDelete.appendChild(linkDeleteText);
|
||
|
linkControl.appendChild(linkEdit);
|
||
|
linkControl.appendChild(linkDelete);
|
||
|
linkUrl.appendChild(linkUrlText);
|
||
|
linkPanelBack.appendChild(linkUrl);
|
||
|
linkPanelBack.appendChild(linkControl);
|
||
|
linkItem.appendChild(linkPanelFront);
|
||
|
linkItem.appendChild(linkPanelBack);
|
||
|
gridItemBody.appendChild(linkItem);
|
||
|
});
|
||
|
};
|
||
|
if (array) {
|
||
|
makeLinks(array);
|
||
|
} else {
|
||
|
makeLinks(bookmarks.get());
|
||
|
};
|
||
|
};
|
||
|
|
||
|
var tabindex = function() {
|
||
|
var allLinkControlItem = helper.eA(".link-control-item");
|
||
|
if (control.state.edit) {
|
||
|
allLinkControlItem.forEach(function(arrayItem, index) {
|
||
|
arrayItem.tabIndex = 1;
|
||
|
});
|
||
|
} else {
|
||
|
allLinkControlItem.forEach(function(arrayItem, index) {
|
||
|
arrayItem.tabIndex = -1;
|
||
|
});
|
||
|
};
|
||
|
};
|
||
|
|
||
|
var clear = function() {
|
||
|
var gridItemBody = helper.e(".grid-item-body");
|
||
|
while (gridItemBody.lastChild) {
|
||
|
gridItemBody.removeChild(gridItemBody.lastChild);
|
||
|
};
|
||
|
};
|
||
|
|
||
|
var init = function() {
|
||
|
render();
|
||
|
};
|
||
|
|
||
|
// exposed methods
|
||
|
return {
|
||
|
init: init,
|
||
|
clear: clear,
|
||
|
add: add,
|
||
|
edit: edit,
|
||
|
save: save,
|
||
|
remove: remove,
|
||
|
render: render,
|
||
|
tabindex: tabindex
|
||
|
};
|
||
|
|
||
|
})();
|