lionix-team / vue-image-markup

vue-image-markup will provide you to edit uploaded image easily and save it.
https://image-markup.lionix-team.com
96 stars 45 forks source link

How to use uploadImage(e)? #37

Open acarlstein opened 1 year ago

acarlstein commented 1 year ago

First at all, great project and nicely done. Much appreciated.

I'm trying to use uploadImage(e) but I get:

e.target is undefined

I'm not sure if e is supposed to be an URL, data, or what.

I tried with an URL but didn't work:

https://dummyimage.com/458x340/000000/9b1bdb.png

I tried with the image as base64 below but didn't work either:

const imageDefault = "";

Also I tried by assigning the base64 string to an image but no luck:

    const image = new Image();
    image.src = imageDefault;

I also tried to pass it as FileReader with the base64 content, but didn't work either:

    const blob = new Blob([imageDefault], {type: 'text/plain'});

    const fileReader = new FileReader();
    fileReader.readAsDataURL(blob);

Also, I tried like this:

 const fileInput = document.querySelector('input[type="file"]') as HTMLInputElement;

    // Create a new File object
    const myFile = new File([imageDefault], 'myFile.txt', { type: 'text/plain' });

    const dataTransfer = new DataTransfer();
    dataTransfer.items.add(myFile);

    fileInput.files = dataTransfer.files;

Do anyone have some code example? Thank you.

akempes commented 10 months ago

I just ran into the same problem. For anyone who wants to load an image from an url:

const url = 'https://dummyimage.com/458x340/000000/9b1bdb.png';

fetch(url)
    .then(response => {

        // Check if the request was successful (status code 200)
        if (!response.ok) {
            throw new Error(`Failed to fetch data from ${url}`);
        }

        // Convert the response body to a Blob
        return response.blob();
    })
    .then(blob => {

        const e = {
            target: {
                files: [
                    blob,
                ]
            }
        };

        this.$refs.editor.uploadImage(e);
    });