From 0ceb15fde3ee31d2d64c55b2f47f081ebeede4c6 Mon Sep 17 00:00:00 2001 From: Henrique Dias Date: Sat, 31 Dec 2016 10:39:31 +0000 Subject: [PATCH] html5 templates --- _embed/public/js/editor.js | 117 +++++++++++++++++------------------ _embed/templates/editor.tmpl | 113 ++++++++++++++++++++++++--------- 2 files changed, 139 insertions(+), 91 deletions(-) diff --git a/_embed/public/js/editor.js b/_embed/public/js/editor.js index d7e2093c..db58f632 100644 --- a/_embed/public/js/editor.js +++ b/_embed/public/js/editor.js @@ -1,5 +1,7 @@ 'use strict'; +var templates = []; + function textareaAutoGrow() { let autogrow = function() { this.style.height = '5px'; @@ -26,7 +28,7 @@ function deleteFrontMatterItem(event) { function addFrontMatterItem(event) { event.preventDefault(); - + let clone; let temp = document.getElementById(tempID) if (temp) { temp.remove(); @@ -50,47 +52,38 @@ function addFrontMatterItem(event) { if (fieldsets.length > 0) { let newtype = fieldsets[0].dataset.type, bid = id + "[" + fieldsets.length + "]", - name = fieldsets.length, - template = `
-

${name}

-
- add -
-
- close -
-
-
-
`; - - block.insertAdjacentHTML('beforeend', template); - - document.querySelector(`div[data-delete="${bid}"]`).addEventListener('click', deleteFrontMatterItem); - document.getElementById(bid).querySelector('.action.add').addEventListener('click', addFrontMatterItem); + name = fieldsets.length; + + clone = document.importNode(templates.base.content, true); + clone.querySelector('fieldset').id = bid; + clone.querySelector('fieldset').dataset.type = newtype; + clone.querySelector('h3').innerHTML = name; + clone.querySelector('.delete').dataset.delete = bid; + clone.querySelector('.delete').addEventListener('click', deleteFrontMatterItem); + clone.querySelector('.add').addEventListener('click', addFrontMatterItem); + block.appendChild(clone); } else { - block.querySelector('.group').insertAdjacentHTML('beforeend', `
- -
- close -
-
`); - + clone = document.importNode(templates.arrayItem.content, true); + clone.querySelector('[data-type="array-item"]').id = `${fieldID}-${count}`; + clone.querySelector('input').name = fieldID; + clone.querySelector('input').id = fieldID; + clone.querySelector('div.action').dataset.delete = `${fieldID}-${count}`; + clone.querySelector('div.action').addEventListener('click', deleteFrontMatterItem); + block.querySelector('.group').appendChild(clone) document.getElementById(`${fieldID}-${count}`).querySelector('input').focus(); - document.querySelector(`div[data-delete="${fieldID}-${count}"]`).addEventListener('click', deleteFrontMatterItem); } } - if (type == "object" || type == "parent") { - let template = `
-
- - -
`; + if (type == "object" || type == "parent") { + clone = document.importNode(templates.temporary.content, true); + clone.querySelector('.group').id = tempID; + clone.querySelector('.block').id = tempID; + clone.querySelector('input').name = tempID; if (type == "parent") { - document.querySelector('div.button.add').insertAdjacentHTML('beforebegin', template); + document.querySelector('.frontmatter').insertBefore(clone, document.querySelector('div.button.add')); } else { - block.querySelector('.delete').insertAdjacentHTML('afterend', template); + block.insertBefore(clone, block.querySelector('.group')); } let temp = document.getElementById(tempID), @@ -128,27 +121,21 @@ function addFrontMatterItem(event) { switch (newtype) { case "array": - case "object": - let template = `
-

${name}

-
- add -
-
- close -
-
-
-
`; + case "object": + clone = document.importNode(templates.base.content, true); + clone.querySelector('fieldset').id = bid; + clone.querySelector('fieldset').dataset.type = newtype; + clone.querySelector('h3').innerHTML = name; + clone.querySelector('.delete').dataset.delete = bid; + clone.querySelector('.delete').addEventListener('click', deleteFrontMatterItem); + clone.querySelector('.add').addEventListener('click', addFrontMatterItem); if (type == "parent") { - document.querySelector('div.button.add').insertAdjacentHTML('beforebegin', template); + document.querySelector('.frontmatter').insertBefore(clone, document.querySelector('div.button.add')); } else { - block.insertAdjacentHTML('beforeend', template); + block.appendChild(clone); } - - document.querySelector(`div[data-delete="${bid}"]`).addEventListener('click', deleteFrontMatterItem); - document.getElementById(bid).querySelector('.action.add').addEventListener('click', addFrontMatterItem); + break; default: let group = block.querySelector('.group'); @@ -157,17 +144,19 @@ function addFrontMatterItem(event) { block.insertAdjacentHTML('afterbegin', '
'); group = block.querySelector('.group'); } - - group.insertAdjacentHTML('beforeend', `
- - -
- close -
-
`); - + + clone = document.importNode(templates.objectItem.content, true); + clone.querySelector('.block').id = `block-${bid}`; + clone.querySelector('.block').dataset.content = bid; + clone.querySelector('label').for = bid; + clone.querySelector('label').innerHTML = name; + clone.querySelector('input').name = bid; + clone.querySelector('input').id = bid; + clone.querySelector('.action').dataset.delete = `block-${bid}`; + clone.querySelector('.action').addEventListener('click', deleteFrontMatterItem); + + group.appendChild(clone) document.getElementById(bid).focus(); - document.querySelector(`div[data-delete="block-${bid}"]`).addEventListener('click', deleteFrontMatterItem); } } }); @@ -178,6 +167,12 @@ function addFrontMatterItem(event) { document.addEventListener("DOMContentLoaded", (event) => { textareaAutoGrow(); + + templates.array = document.getElementById("array-template"); + templates.arrayItem = document.getElementById("array-item-template"); + templates.base = document.getElementById('base-template'); + templates.objectItem = document.getElementById("object-item-template"); + templates.temporary = document.getElementById('temporary-template'); let container = document.getElementById('editor'), button = document.querySelector('#submit span:first-child'), diff --git a/_embed/templates/editor.tmpl b/_embed/templates/editor.tmpl index 0895b2cc..d54ddd58 100644 --- a/_embed/templates/editor.tmpl +++ b/_embed/templates/editor.tmpl @@ -1,34 +1,87 @@ {{ define "content" }} {{ with .Data }} -
-
- {{ if or (eq .Class "frontmatter-only") (eq .Class "complete") }} -
- {{ template "blocks" .FrontMatter }} -
Add field
-
- {{ end }} - - {{ if or (eq .Class "content-only") (eq .Class "complete") }} - - {{ if (eq .Class "complete")}} -

Body

- {{ end }} -
-
- -
- {{ end }} - -
- -
-
-
+
+
+{{ if or (eq .Class "frontmatter-only") (eq .Class "complete") }} +
+{{ template "blocks" .FrontMatter }} +
Add field
+
{{ end }} + +{{ if or (eq .Class "content-only") (eq .Class "complete") }} + +{{ if (eq .Class "complete")}} +

Body

+{{ end }} +
+
+ +
+{{ end }} + +
+ +
+
+
+{{ end }} + + + + + + + + + + {{ end }}