Skip to main content

filepond library and plugins not being detected

I am learing Node.JS by webdevsimplified and i am developing a book library website and i am facing an issue. I have imported a filepond library and some plugins. They are working perfectly fine when i try to add a new book but when i try to edit an existing book the filepond library does not appear to be working then if i try to edit image then it throws an error an automatically filepond start to work i have debugged everything and i can not understand why is this happening. When i click to edit a cover this is what comes up and everything works without error except the cover updation. if i try to update cover it throws an error and then shows the page that is originally intended to show intended image

Some Code related to edit routes

books.js


    router.get('/:id/edit', async (req,res)=>{
        try {
            const book = await Book.findById(req.params.id)
            renderEditPage(res, book)
        } catch {
            res.redirect('/')
        }
    })
    
    // Update book route
    router.put('/:id', async (req,res)=>{
        let book
    
        try {
            book = await Book.findById(req.params.id)
            book.title = req.body.title
            book.author = req.body.author
            book.publishDate = new Date(req.body.publishDate)
            book.pageCount = req.body.pageCount
            book.description = req.body.description
            if(req.body.cover != null && req.body.cover !== ''){
            saveCover(book, req.body.cover)
            }
            await book.save()
            res.redirect(`/books/${book.id}`)
        } catch{
            if(book != null){
                renderEditPage(res,book, true)
            } else {
                redirect('/')
            }
        }
    })
    
    router.delete('/:id', async (req, res) => {
        let book
        try {
          book = await Book.findById(req.params.id)
          await book.remove()
          res.redirect('/books')
        } catch {
          if (book != null) {
            res.render('books/show', {
              book: book,
              errorMessage: 'Could not remove book'
            })
          } else {
            res.redirect('/')
          }
        }
      })
    
    async function renderNewPage(res,book , hasError = false){
        renderFormPage(res,book,'new',hasError)
    }
    
    async function renderEditPage(res,book , hasError = false){
        renderFormPage(res,book,'edit',hasError)
    }
    
    async function renderFormPage(res,book , form, hasError = false){
        try{
            const authors = await Author.find({})
            const params = {
                authors: authors,
                book: book,
            }
            if(hasError){
                if(form === 'edit'){
                    params.errorMessage = 'Error Updating Book'
                }
                else {
                    params.errorMessage = 'Error Creating Book'
                }
            }
            res.render(`books/${form}`, params)
        }catch{
            res.redirect('/books')
        }
    }
    
    function saveCover(book, coverEncoded){
        if (coverEncoded == null) return
        const cover = JSON.parse(coverEncoded)
        if (cover != null && imageMimeTypes.includes(cover.type)){
            book.coverImage = new Buffer.from(cover.data, 'base64')
            book.coverImageType = cover.type
        }
    }
    
    module.exports = router

edit.ejs


    <h2>Edit Book</h2>
    
    <form action="/books/<%= book.id %>?_method=PUT" method="POST">
        <%- include('_form_fields') %>
        <a href="/books">Cancel</a>
        <button type = "submit">Update</button>
    </form>

also the URL for the wrong edit page is http://localhost:3000/books/64ca52c7a9b8a5350ccb4e00/edit

while URL after an error is thrown becomes http://localhost:3000/books/64ca52c7a9b8a5350ccb4e00?_method=PUT

Via Active questions tagged javascript - Stack Overflow https://ift.tt/rQnPDdC

Comments

Popular posts from this blog

ValueError: X has 10 features, but LinearRegression is expecting 1 features as input

So, I am trying to predict the model but its throwing error like it has 10 features but it expacts only 1. So I am confused can anyone help me with it? more importantly its not working for me when my friend runs it. It works perfectly fine dose anyone know the reason about it? cv = KFold(n_splits = 10) all_loss = [] for i in range(9): # 1st for loop over polynomial orders poly_order = i X_train = make_polynomial(x, poly_order) loss_at_order = [] # initiate a set to collect loss for CV for train_index, test_index in cv.split(X_train): print('TRAIN:', train_index, 'TEST:', test_index) X_train_cv, X_test_cv = X_train[train_index], X_test[test_index] t_train_cv, t_test_cv = t[train_index], t[test_index] reg.fit(X_train_cv, t_train_cv) loss_at_order.append(np.mean((t_test_cv - reg.predict(X_test_cv))**2)) # collect loss at fold all_loss.append(np.mean(loss_at_order)) # collect loss at order plt.plot(np.log(al...

Sorting large arrays of big numeric stings

I was solving bigSorting() problem from hackerrank: Consider an array of numeric strings where each string is a positive number with anywhere from to digits. Sort the array's elements in non-decreasing, or ascending order of their integer values and return the sorted array. I know it works as follows: def bigSorting(unsorted): return sorted(unsorted, key=int) But I didnt guess this approach earlier. Initially I tried below: def bigSorting(unsorted): int_unsorted = [int(i) for i in unsorted] int_sorted = sorted(int_unsorted) return [str(i) for i in int_sorted] However, for some of the test cases, it was showing time limit exceeded. Why is it so? PS: I dont know exactly what those test cases were as hacker rank does not reveal all test cases. source https://stackoverflow.com/questions/73007397/sorting-large-arrays-of-big-numeric-stings

How to load Javascript with imported modules?

I am trying to import modules from tensorflowjs, and below is my code. test.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title </head> <body> <script src="https://cdn.jsdelivr.net/npm/@tensorflow/tfjs@2.0.0/dist/tf.min.js"></script> <script type="module" src="./test.js"></script> </body> </html> test.js import * as tf from "./node_modules/@tensorflow/tfjs"; import {loadGraphModel} from "./node_modules/@tensorflow/tfjs-converter"; const MODEL_URL = './model.json'; const model = await loadGraphModel(MODEL_URL); const cat = document.getElementById('cat'); model.execute(tf.browser.fromPixels(cat)); Besides, I run the server using python -m http.server in my command prompt(Windows 10), and this is the error prompt in the console log of my browser: Failed to loa...