Topic: Access Modal Data Programmically

cwilliams priority asked 2 years ago


Expected behavior var description = document.getElementsByName("description"); alert(description);

This should display the text in the description field of the add event modal for the mdb calendar plugin.

Actual behavior I am getting this message. [object NodeList]

Resources (screenshots, code snippets etc.)

How would I go about getting a hold of the event modal values programmatically after they are submitted when the "Add" button is pressed on the add event modal. I am wanting to save them to a database during the same process that adds them to the calendar?


cwilliams priority answered 2 years ago


How do you go about adding or removing elements from the add event modal. I need to add a select box and a radio button.


Grzegorz Bujański free commented 2 years ago

At the moment we do not have the option to customize the modal content. If you want to add or remove modal elements, you have to do it on your own by modifying source files.


cwilliams priority commented 2 years ago

Can you please offer some guidance on how to do that?


Mateusz Lazaru staff commented 2 years ago

Use our Webpack-starter. You can add your own changes to the source code and build your custom version of MDB using npm run buildMDB


cwilliams priority commented 2 years ago

Can you guys build us the modal we want for a small fee?


Grzegorz Bujański free answered 2 years ago


getElementsByName method returns NodeList of all elements with name="description" set. You can find more information about this method here.

I prepare a snippet for you where you can see 2 examples of how to get input value with name="description": https://mdbootstrap.com/snippets/standard/grzegorz-bujanski/4506347#js-tab-view

After clicking the Add button in the modal, the event addEvent.mdb.calendar is triggered. You can listen to this event and use it to get all event data and save them on your server.

calendarElement.addEventListener('addEvent.mdb.calendar', (e) => {
  // all event data is returned as e.event.  
  // you need send this data to your API. ForExample:

   fetch('https://your.api/new-calendar-event', {
     method: 'post',
     body: JSON.stringify({
       summary: e.event.summary,
       description: e.event.description,
       startDate: e.event.start.date,
       startDateTime: e.event.start.dateTime,
       endDate: e.event.end.date,
       endDateTime: e.event.end.dateTime,
       colorBackground: e.color.background,
       colorForefground: e.color.foreground
     })
   });
});


Please insert min. 20 characters.

FREE CONSULTATION

Hire our experts to build a dedicated project. We'll analyze your business requirements, for free.

Status

Answered

Specification of the issue

  • ForumUser: Priority
  • Premium support: Yes
  • Technology: MDB jQuery
  • MDB Version: MDB4 4.20.0
  • Device: Desktop
  • Browser: Firefox
  • OS: Windows
  • Provided sample code: No
  • Provided link: No