mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-23 17:52:26 -05:00
LibWeb: Implement the DataTransfer types attribute
This commit is contained in:
parent
e8a1b89447
commit
9f4e3c7e25
Notes:
github-actions[bot]
2024-08-19 11:30:40 +00:00
Author: https://github.com/trflynn89 Commit: https://github.com/LadybirdBrowser/ladybird/commit/9f4e3c7e25b Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/1111
5 changed files with 90 additions and 8 deletions
|
@ -1,26 +1,43 @@
|
|||
Simple drag and drop:
|
||||
dragenter
|
||||
types: Files
|
||||
dragover
|
||||
types: Files
|
||||
drop
|
||||
types: Files
|
||||
|
||||
Drag enter and leave:
|
||||
dragenter
|
||||
types: Files
|
||||
dragover
|
||||
types: Files
|
||||
dragleave
|
||||
types: Files
|
||||
dragenter
|
||||
types: Files
|
||||
dragover
|
||||
types: Files
|
||||
drop
|
||||
types: Files
|
||||
|
||||
Drag enter not accepted:
|
||||
dragenter
|
||||
types: Files
|
||||
|
||||
Drag over not accepted:
|
||||
dragenter
|
||||
types: Files
|
||||
dragover
|
||||
types: Files
|
||||
dragover
|
||||
types: Files
|
||||
dragleave
|
||||
types: Files
|
||||
|
||||
Drop not accepted:
|
||||
dragenter
|
||||
types: Files
|
||||
dragover
|
||||
types: Files
|
||||
drop
|
||||
types: Files
|
||||
|
|
|
@ -5,23 +5,28 @@
|
|||
let target = document.getElementById("target");
|
||||
let acceptDragEvents = true;
|
||||
|
||||
const printEvent = (name, e) => {
|
||||
println(name);
|
||||
println(` types: ${e.dataTransfer.types}`);
|
||||
};
|
||||
|
||||
target.addEventListener("dragenter", e => {
|
||||
println("dragenter");
|
||||
printEvent("dragenter", e);
|
||||
if (acceptDragEvents) {
|
||||
e.preventDefault();
|
||||
}
|
||||
});
|
||||
target.addEventListener("dragover", e => {
|
||||
println("dragover");
|
||||
printEvent("dragover", e);
|
||||
if (acceptDragEvents) {
|
||||
e.preventDefault();
|
||||
}
|
||||
});
|
||||
target.addEventListener("dragleave", () => {
|
||||
println("dragleave");
|
||||
target.addEventListener("dragleave", e => {
|
||||
printEvent("dragleave", e);
|
||||
});
|
||||
target.addEventListener("drop", e => {
|
||||
println("drop");
|
||||
printEvent("drop", e);
|
||||
if (acceptDragEvents) {
|
||||
e.preventDefault();
|
||||
}
|
||||
|
|
|
@ -77,4 +77,57 @@ void DataTransfer::set_effect_allowed_internal(FlyString effect_allowed)
|
|||
m_effect_allowed = AK::move(effect_allowed);
|
||||
}
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/dnd.html#dom-datatransfer-types
|
||||
ReadonlySpan<String> DataTransfer::types() const
|
||||
{
|
||||
// The types attribute must return this DataTransfer object's types array.
|
||||
return m_types;
|
||||
}
|
||||
|
||||
void DataTransfer::associate_with_drag_data_store(DragDataStore& drag_data_store)
|
||||
{
|
||||
m_associated_drag_data_store = drag_data_store;
|
||||
update_data_transfer_types_list();
|
||||
}
|
||||
|
||||
void DataTransfer::disassociate_with_drag_data_store()
|
||||
{
|
||||
m_associated_drag_data_store.clear();
|
||||
update_data_transfer_types_list();
|
||||
}
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/dnd.html#concept-datatransfer-types
|
||||
void DataTransfer::update_data_transfer_types_list()
|
||||
{
|
||||
// 1. Let L be an empty sequence.
|
||||
Vector<String> types;
|
||||
|
||||
// 2. If the DataTransfer object is still associated with a drag data store, then:
|
||||
if (m_associated_drag_data_store.has_value()) {
|
||||
bool contains_file = false;
|
||||
|
||||
// 1. For each item in the DataTransfer object's drag data store item list whose kind is text, add an entry to L
|
||||
// consisting of the item's type string.
|
||||
for (auto const& item : m_associated_drag_data_store->item_list()) {
|
||||
switch (item.kind) {
|
||||
case DragDataStoreItem::Kind::Text:
|
||||
types.append(item.type_string);
|
||||
break;
|
||||
case DragDataStoreItem::Kind::File:
|
||||
contains_file = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// 2. If there are any items in the DataTransfer object's drag data store item list whose kind is File, then add
|
||||
// an entry to L consisting of the string "Files". (This value can be distinguished from the other values
|
||||
// because it is not lowercase.)
|
||||
if (contains_file)
|
||||
types.append("Files"_string);
|
||||
}
|
||||
|
||||
// 3. Set the DataTransfer object's types array to the result of creating a frozen array from L.
|
||||
m_types = move(types);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -49,20 +49,27 @@ public:
|
|||
void set_effect_allowed(FlyString);
|
||||
void set_effect_allowed_internal(FlyString);
|
||||
|
||||
void associate_with_drag_data_store(DragDataStore& drag_data_store) { m_associated_drag_data_store = drag_data_store; }
|
||||
void disassociate_with_drag_data_store() { m_associated_drag_data_store.clear(); }
|
||||
ReadonlySpan<String> types() const;
|
||||
|
||||
void associate_with_drag_data_store(DragDataStore& drag_data_store);
|
||||
void disassociate_with_drag_data_store();
|
||||
|
||||
private:
|
||||
DataTransfer(JS::Realm&);
|
||||
|
||||
virtual void initialize(JS::Realm&) override;
|
||||
|
||||
void update_data_transfer_types_list();
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/dnd.html#dom-datatransfer-dropeffect
|
||||
FlyString m_drop_effect { DataTransferEffect::none };
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/dnd.html#dom-datatransfer-effectallowed
|
||||
FlyString m_effect_allowed { DataTransferEffect::none };
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/dnd.html#concept-datatransfer-types
|
||||
Vector<String> m_types;
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/dnd.html#the-datatransfer-interface:drag-data-store-3
|
||||
Optional<DragDataStore&> m_associated_drag_data_store;
|
||||
};
|
||||
|
|
|
@ -11,7 +11,7 @@ interface DataTransfer {
|
|||
[FIXME] undefined setDragImage(Element image, long x, long y);
|
||||
|
||||
// old interface
|
||||
[FIXME] readonly attribute FrozenArray<DOMString> types;
|
||||
readonly attribute sequence<DOMString> types; // FIXME: This should be FrozenArray<DOMString>
|
||||
[FIXME] DOMString getData(DOMString format);
|
||||
[FIXME] undefined setData(DOMString format, DOMString data);
|
||||
[FIXME] undefined clearData(optional DOMString format);
|
||||
|
|
Loading…
Add table
Reference in a new issue