mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-07-22 14:49:38 +02:00
28 lines
923 B
JavaScript
28 lines
923 B
JavaScript
|
import { Controller } from "@hotwired/stimulus"
|
||
|
|
||
|
export default class extends Controller {
|
||
|
static targets = ["imagePreview", "fileField", "deleteField", "clearBtn", "template"]
|
||
|
|
||
|
preview(event) {
|
||
|
const file = event.target.files[0];
|
||
|
if (file) {
|
||
|
const reader = new FileReader();
|
||
|
reader.onload = (e) => {
|
||
|
this.imagePreviewTarget.innerHTML = `<img src="${e.target.result}" alt="Preview" class="w-24 h-24 rounded-full object-cover" />`;
|
||
|
this.templateTarget.classList.add("hidden");
|
||
|
this.clearBtnTarget.classList.remove("hidden");
|
||
|
};
|
||
|
reader.readAsDataURL(file);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
clear() {
|
||
|
this.deleteFieldTarget.value = true;
|
||
|
this.fileFieldTarget.value = null;
|
||
|
this.templateTarget.classList.remove("hidden");
|
||
|
this.imagePreviewTarget.innerHTML = this.templateTarget.innerHTML;
|
||
|
this.clearBtnTarget.classList.add("hidden");
|
||
|
this.element.submit();
|
||
|
}
|
||
|
}
|