Skip to content

Commit

Permalink
add del & italic formats
Browse files Browse the repository at this point in the history
  • Loading branch information
MAX-786 committed Aug 10, 2024
1 parent 7fbb8bf commit 5316e84
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 171 deletions.
242 changes: 72 additions & 170 deletions packages/hydra-js/hydra.js
Original file line number Diff line number Diff line change
Expand Up @@ -175,95 +175,75 @@ class Bridge {

// Create the bold button
const boldButton = document.createElement('button');
boldButton.className = `volto-hydra-bold-button`;
boldButton.className = `volto-hydra-format-button`;
boldButton.innerHTML = boldSVG;
boldButton.addEventListener('click', () => {
this.formatSelectedText('bold');
// const selection = window.getSelection();
// const isActive = boldButton.classList.toggle("active");
// const startNode = this.findParentWithAttribute(
// selection.anchorNode.parentElement,
// "data-hydra-node"
// );
// const endNode = this.findParentWithAttribute(
// selection.focusNode.parentElement,
// "data-hydra-node"
// );
// const startOffset = selection.anchorOffset;
// const endOffset = selection.focusOffset;

// // Prepare data to send to admin UI

// const selectionData = {
// startNodeId: Math.min(
// startNode.getAttribute("data-hydra-node"),
// endNode.getAttribute("data-hydra-node")
// ),
// endNodeId: Math.max(
// startNode.getAttribute("data-hydra-node"),
// endNode.getAttribute("data-hydra-node")
// ),
// startOffset: Math.min(startOffset, endOffset),
// endOffset: Math.max(startOffset, endOffset),
// text: selection.toString(),
// };
// console.log(selectionData);
// this.formData.blocks[this.selectedBlockUid] = this.toggleMark(
// this.formData.blocks[this.selectedBlockUid],
// selectionData,
// isActive
// );
// // this.setDataCallback(this.formData);
// window.parent.postMessage({type: "TOGGLE_MARK", data: this.formData}, this.adminOrigin);
});

// Check if the selected text is bold
const isBold = (selection) => {
if (selection.rangeCount > 0) {
const range = selection.getRangeAt(0);
const parentNode = range.commonAncestorContainer.parentNode;
return (
parentNode.nodeName === 'B' ||
parentNode.nodeName === 'STRONG' ||
window.getComputedStyle(parentNode).fontWeight === 'bold' ||
window.getComputedStyle(parentNode).fontWeight === '700'
);
}
return false;
};

// Function to handle the text selection and show/hide the bold button
const handleSelectionChange = () => {
const selection = window.getSelection();
const selectedText = selection.toString();
const anchorNode = selection.anchorNode;

// Check if anchorNode is an element, if not get its parent element
const parentElement =
anchorNode.nodeType === Node.ELEMENT_NODE
? anchorNode
: anchorNode.parentElement;

const parentBlock = parentElement.closest(
'[data-editable-field="value"]',
);
// Create the italic button
const italicButton = document.createElement('button');
italicButton.className = `volto-hydra-format-button`;
italicButton.innerHTML = italicSVG;
italicButton.addEventListener('click', () => {
this.formatSelectedText('italic');
});

// Append the bold button only if text is selected and the block has the data-editable-field="value" attribute
if (selectedText.length > 0 && parentBlock) {
boldButton.classList.toggle('show', true);
boldButton.classList.toggle('active', isBold(selection));
} else {
boldButton.classList.toggle('show', false);
}
};
// Create the del button
const delButton = document.createElement('button');
delButton.className = `volto-hydra-format-button`;
delButton.innerHTML = delSVG;
delButton.addEventListener('click', () => {
this.formatSelectedText('del');
});

// Add event listener to handle text selection within the block
this.handleMouseUp = (e) => {
if (e.target.closest('[data-editable-field="value"]')) {
handleSelectionChange();
}
};
this.currentlySelectedBlock.addEventListener('mouseup', this.handleMouseUp);
// // Check if the selected text is bold
// const isBold = (selection) => {
// if (selection.rangeCount > 0) {
// const range = selection.getRangeAt(0);
// const parentNode = range.commonAncestorContainer.parentNode;
// return (
// parentNode.nodeName === "B" ||
// parentNode.nodeName === "STRONG" ||
// window.getComputedStyle(parentNode).fontWeight === "bold" ||
// window.getComputedStyle(parentNode).fontWeight === "700"
// );
// }
// return false;
// };

// // Function to handle the text selection and show/hide the bold button
// const handleSelectionChange = () => {
// const selection = window.getSelection();
// const selectedText = selection.toString();
// const anchorNode = selection.anchorNode;

// // Check if anchorNode is an element, if not get its parent element
// const parentElement =
// anchorNode.nodeType === Node.ELEMENT_NODE
// ? anchorNode
// : anchorNode.parentElement;

// const parentBlock = parentElement.closest(
// '[data-editable-field="value"]'
// );

// // Append the bold button only if text is selected and the block has the data-editable-field="value" attribute
// if (selectedText.length > 0 && parentBlock) {
// boldButton.classList.toggle("show", true);
// boldButton.classList.toggle("active", isBold(selection));
// } else {
// boldButton.classList.toggle("show", false);
// }
// };

// // Add event listener to handle text selection within the block
// this.handleMouseUp = (e) => {
// if (e.target.closest('[data-editable-field="value"]')) {
// handleSelectionChange();
// }
// };
// this.currentlySelectedBlock.addEventListener("mouseup", this.handleMouseUp);

// Create the three-dot menu button
const menuButton = document.createElement('button');
Expand Down Expand Up @@ -309,6 +289,8 @@ class Bridge {
// Append elements to the quantaToolbar
this.quantaToolbar.appendChild(dragButton);
this.quantaToolbar.appendChild(boldButton);
this.quantaToolbar.appendChild(italicButton);
this.quantaToolbar.appendChild(delButton);
this.quantaToolbar.appendChild(menuButton);
this.quantaToolbar.appendChild(dropdownMenu);

Expand Down Expand Up @@ -659,85 +641,6 @@ class Bridge {
return null;
}

// toggleMark(blockData, selection, active) {
// const { startNodeId, endNodeId, startOffset, endOffset } = selection;
// let json = JSON.parse(JSON.stringify(blockData));
// const jsonData = json.value;
// let startNodeParent = null;

// const findNode = (nodeId, nodes, parent = null) => {
// for (let node of nodes) {
// if (node.nodeId === parseInt(nodeId)) {
// if (!startNodeParent) {
// startNodeParent = parent;
// }
// return node;
// }
// if (node.children) {
// const found = findNode(nodeId, node.children, node);
// if (found) {
// return found;
// }
// }
// }
// return null;
// };

// let startNode = findNode(startNodeId, jsonData);
// let endNode = findNode(endNodeId, jsonData);

// if (!startNode || !endNode) {
// console.warn("No matching nodes found");
// return json; // No matching nodes found, return original data
// }
// console.log('selection', selection);
// const startText = startNode.text.substring(0, startOffset);
// const middleText = startNode.text.substring(
// startOffset,
// endNode.text.length - (endNode.text.length - endOffset)
// );
// const endText = endNode.text.substring(endOffset);

// const updatedNodes = [
// { nodeId: startNode.nodeId, text: startText },
// active
// ? {
// nodeId: startNode.nodeId + 1,
// type: "strong",
// children: [{ nodeId: startNode.nodeId + 2, text: middleText }],
// }
// : { nodeId: startNode.nodeId + 1, text: startText + middleText + endText},
// { nodeId: startNode.nodeId + 3, text: endText },
// ];
// console.log('updatednode', updatedNodes);
// // Remove nodes within the range of [startNodeId, endNodeId] and insert updated nodes
// console.log('value before',json.value);
// if (startNodeParent && startNodeParent.children) {
// let insertIndex = -1;
// startNodeParent.children = startNodeParent.children.filter(
// (node, index) => {
// if (
// node.nodeId >= Math.min(startNode.nodeId, endNode.nodeId) &&
// node.nodeId <= Math.max(startNode.nodeId, endNode.nodeId)
// ) {
// if (insertIndex === -1) {
// insertIndex = index;
// }
// return false;
// }
// return true;
// }
// );

// if (insertIndex !== -1) {
// if (active) startNodeParent.children.splice(insertIndex, 0, ...updatedNodes);
// else startNodeParent.children.splice(insertIndex, 0, updatedNodes[1]);
// }
// }
// console.log('value after',json.value);
// json.value = this.addNodeIds(jsonData);
// return json;
// }
getSelectionHTML(range) {
const div = document.createElement('div');
div.appendChild(range.cloneContents());
Expand Down Expand Up @@ -992,23 +895,20 @@ class Bridge {
}
.volto-hydra-drag-button,
.volto-hydra-menu-button,
.volto-hydra-bold-button {
.volto-hydra-format-button {
background: none;
border: none;
cursor: pointer;
padding: 0.5em;
margin: 0;
}
.volto-hydra-bold-button {
.volto-hydra-format-button {
border-radius: 5px;
margin: 1px;
display: none;
}
.volto-hydra-bold-button.show {
display: block !important;
display: block;
}
.volto-hydra-bold-button.active,
.volto-hydra-bold-button:hover {
.volto-hydra-format-button.active,
.volto-hydra-format-button:hover {
background-color: #ddd;
}
.volto-hydra-drag-button {
Expand All @@ -1023,7 +923,7 @@ class Bridge {
display: none;
position: absolute;
top: 100%;
right: -200%;
right: -80%;
background: white;
border: 1px solid #ccc;
border-radius: 4px;
Expand Down Expand Up @@ -1143,6 +1043,8 @@ const dragSVG = `<svg width="20px" height="20px" viewBox="0 0 24 24" fill="none"
<g id="SVGRepo_iconCarrier"> <path d="M8 6.5C9.38071 6.5 10.5 5.38071 10.5 4C10.5 2.61929 9.38071 1.5 8 1.5C6.61929 1.5 5.5 2.61929 5.5 4C5.5 5.38071 6.61929 6.5 8 6.5Z" fill="#4A5B68"/> <path d="M15.5 6.5C16.8807 6.5 18 5.38071 18 4C18 2.61929 16.8807 1.5 15.5 1.5C14.1193 1.5 13 2.61929 13 4C13 5.38071 14.1193 6.5 15.5 6.5Z" fill="#4A5B68"/> <path d="M10.5 12C10.5 13.3807 9.38071 14.5 8 14.5C6.61929 14.5 5.5 13.3807 5.5 12C5.5 10.6193 6.61929 9.5 8 9.5C9.38071 9.5 10.5 10.6193 10.5 12Z" fill="#4A5B68"/> <path d="M15.5 14.5C16.8807 14.5 18 13.3807 18 12C18 10.6193 16.8807 9.5 15.5 9.5C14.1193 9.5 13 10.6193 13 12C13 13.3807 14.1193 14.5 15.5 14.5Z" fill="#4A5B68"/> <path d="M10.5 20C10.5 21.3807 9.38071 22.5 8 22.5C6.61929 22.5 5.5 21.3807 5.5 20C5.5 18.6193 6.61929 17.5 8 17.5C9.38071 17.5 10.5 18.6193 10.5 20Z" fill="#4A5B68"/> <path d="M15.5 22.5C16.8807 22.5 18 21.3807 18 20C18 18.6193 16.8807 17.5 15.5 17.5C14.1193 17.5 13 18.6193 13 20C13 21.3807 14.1193 22.5 15.5 22.5Z" fill="#4A5B68"/> </g>
</svg>`;
const boldSVG = `<img widht="20px" height="20px" src="">`;
const italicSVG = `<img widht="20px" height="20px" src="">`;
const delSVG = `<img widht="20px" height="20px" src="">`;
const addSVG = `<img widht="20px" height="20px" src=''/>`;
const threeDotsSVG = `<svg width="24px" height="24px" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M5 10C6.10457 10 7 10.8954 7 12C7 13.1046 6.10457 14 5 14C3.89543 14 3 13.1046 3 12C3 10.8954 3.89543 10 5 10Z" fill="#000000"/>
Expand Down
2 changes: 1 addition & 1 deletion packages/volto-hydra/src/components/Iframe/View.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -299,7 +299,7 @@ const Iframe = (props) => {
]);

useEffect(() => {
console.log('form data changed', form?.blocks[selectedBlock]);
// console.log('form data changed', form?.blocks[selectedBlock]);
if (
!isInlineEditingRef.current &&
form &&
Expand Down
6 changes: 6 additions & 0 deletions packages/volto-hydra/src/utils/toggleMark.js
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,12 @@ const deserialize = (el, markAttributes = {}) => {
);
case 'STRONG': // Handle <strong> elements explicitly
return jsx('element', { type: 'strong' }, children);

case 'EM': // Handle <strong> elements explicitly
return jsx('element', { type: 'em' }, children);

case 'DEL': // Handle <strong> elements explicitly
return jsx('element', { type: 'del' }, children);
default:
return children;
}
Expand Down

0 comments on commit 5316e84

Please sign in to comment.