Skip to content

Commit

Permalink
feat: preferredMailSender 1/2 - sortableList property
Browse files Browse the repository at this point in the history
This allows for a new 'sortableList' property type.
This property should be a draggable list of items that, when saved,
saves order they were arranged in.
  • Loading branch information
ammopt committed Jun 12, 2024
1 parent 0bedc43 commit 9769036
Show file tree
Hide file tree
Showing 3 changed files with 115 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -569,6 +569,8 @@
{/if}
{/foreach}
</div>
{elseif $property.type == 'sortableList'}
{include file="DataObjectUtil/sortableList.tpl"}
{/if}
</div>
Expand Down
111 changes: 111 additions & 0 deletions code/web/interface/themes/responsive/DataObjectUtil/sortableList.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,111 @@
{strip}
<ol class="list-unstyled" id="sortable">
{foreach from=$property.values item=propertyName key=propertyValue}
<li draggable="true" style="cursor:grab" data-value='{$propertyValue}'><i class="fas fa-grip-vertical"></i> {$propertyName|escape}</li>
{/foreach}
</ol>
<input type='hidden' name='{$propName}' id='{$propName}' value='{$propValue|escape}'>

<script type="text/javascript">
$(document).ready(function(){
refreshListOptions();
const sortableList =
document.getElementById("sortable");
let draggedItem = null;
function refreshListValue(){
let listOptions = [];
$( "#sortable li" ).each(function( index ) {
listOptions.push($(this).text().trim().replace('|',''));
});
let text = listOptions.join('|');
$("#{$propName}").val(text.trim());
}
function refreshListOptions(drag){
let value = $("#{$propName}").val();
let optionsFromText = value.split("|");
optionsFromText.forEach(textOption => {
$('#sortable').children().each(function () {
if(textOption.trim() == $(this).data().value){
$('#sortable').append($(this));
}
});
});
}
sortableList.addEventListener(
"dragstart",
(e) => {
draggedItem = e.target;
setTimeout(() => {
e.target.style.display =
"none";
}, 0);
});
sortableList.addEventListener(
"dragend",
(e) => {
setTimeout(() => {
e.target.style.display = "";
draggedItem = null;
refreshListValue();
}, 0);
});
sortableList.addEventListener(
"dragover",
(e) => {
e.preventDefault();
const afterElement =
getDragAfterElement(
sortableList,
e.clientY);
const currentElement =
document.querySelector(
".dragging");
if (afterElement == null) {
sortableList.appendChild(
draggedItem
);
} else {
sortableList.insertBefore(
draggedItem,
afterElement
);
}
});
const getDragAfterElement = (
container, y
) => {
const draggableElements = [
...container.querySelectorAll(
"li:not(.dragging)"
),
];
return draggableElements.reduce(
(closest, child) => {
const box =
child.getBoundingClientRect();
const offset =
y - box.top - box.height / 2;
if (
offset < 0 &&
offset > closest.offset) {
return {
offset: offset,
element: child,
};
} else {
return closest;
}
}, {
offset: Number.NEGATIVE_INFINITY,
}
).element;
};
});
</script>
2 changes: 2 additions & 0 deletions code/web/sys/DataObjectUtil.php
Original file line number Diff line number Diff line change
Expand Up @@ -575,6 +575,8 @@ static function processProperty(DataObject $object, $property) {
}

$object->$propertyName = $values;
} elseif ($property['type'] == 'sortableList') {
$object->setProperty($propertyName, $_REQUEST[$propertyName], $property);
}
}
}

0 comments on commit 9769036

Please sign in to comment.