Fix file upload in custom photo upload control
Hat tip to https://web.dev/articles/more-capable-form-controls for the details.
This commit is contained in:
parent
64cd2f49dc
commit
612f2fba77
2 changed files with 17 additions and 2 deletions
|
|
@ -1,8 +1,13 @@
|
||||||
class PhotoUpload extends HTMLElement {
|
class PhotoUpload extends HTMLElement {
|
||||||
|
// make element form-associated
|
||||||
|
static formAssociated = true;
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
this.attachShadow({ mode: 'open' });
|
this.attachShadow({ mode: 'open' });
|
||||||
this.render();
|
this.render();
|
||||||
|
this.fileInput = this.shadowRoot.getElementById("photos");
|
||||||
|
this.internals = this.attachInternals();
|
||||||
}
|
}
|
||||||
|
|
||||||
connectedCallback() {
|
connectedCallback() {
|
||||||
|
|
@ -15,7 +20,17 @@ class PhotoUpload extends HTMLElement {
|
||||||
|
|
||||||
// Handle photo selection
|
// Handle photo selection
|
||||||
photoInput.addEventListener('change', () => {this._handlePhotoSelection()});
|
photoInput.addEventListener('change', () => {this._handlePhotoSelection()});
|
||||||
|
photoInput.addEventListener("input", (event) => {
|
||||||
|
let value = event.textContent;
|
||||||
|
const n = "photos";
|
||||||
|
let i = 0
|
||||||
|
const entries = new FormData();
|
||||||
|
for (const file of event.target.files) {
|
||||||
|
entries.append(n + i, file);
|
||||||
|
i = i + 1
|
||||||
|
}
|
||||||
|
this.internals.setFormValue(entries);
|
||||||
|
});
|
||||||
// Handle drag and drop
|
// Handle drag and drop
|
||||||
const photoDropArea = this.shadowRoot.querySelector('#photoDropArea');
|
const photoDropArea = this.shadowRoot.querySelector('#photoDropArea');
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -147,7 +147,7 @@ document.addEventListener('DOMContentLoaded', function() {
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Report Form -->
|
<!-- Report Form -->
|
||||||
<form id="mosquitoNuisanceForm" action="{{ .URL.NuisanceSubmit }}" method="POST">
|
<form id="mosquitoNuisanceForm" action="{{ .URL.NuisanceSubmit }}" method="POST" enctype="multipart/form-data">
|
||||||
<!-- Location & Contact Section -->
|
<!-- Location & Contact Section -->
|
||||||
<div class="form-section">
|
<div class="form-section">
|
||||||
<div class="section-heading">
|
<div class="section-heading">
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue