🇦🇺Australia @zimny

Account created on 10 October 2011, over 13 years ago
#

Recent comments

🇦🇺Australia zimny

@rfmarcelino, it's obvious that the latest version works on a clean installation. This is not my issue here.

I specifically indicated that this happens after updating from 1.1.2 upwards and I run it on Drupal 10.4.1. The real question is what major changes were done to your module between those versions. I know that a new requirement of webform_ui was added. What about js libraries etc.? Btw, I use the Bootstrap 3 theme, the latest version.

At this stage for my particular project I don't need the latest bells and whistles like paypal integration. I can hack the 1.1.2 version to make it to work with my project. However some things have been changed significantly since this is happening for me.

My point is that sometimes it is just not possible to start fresh. Hopefully you understand that.

Still love your module. Thanks for all the hard work!

🇦🇺Australia zimny

drush updb, drush cr. Yes, thank you. As I mentioned, I even uninstalled the module and tried 1.1.3, 1.1.4 and dev versions.

The code that breaks the js functionality for me is located in webform_booking.js, line 458. Should that value be left like that, i.e . document.getElementById(`selected-slot-${elementId}`).value = '';?

On the other hand, I'm wondering whether there might be some js library issue that I'm using, like version mismatch or something?

Is this only me?

🇦🇺Australia zimny

I'm facing exactly the same issue here as #7. Starting from the version 1.1.0 and including the latest dev (dev-1.0.x 1314827), when making the webform booking field mandatory, validation is not letting it through.

My temporary quick/dirty fix was to edit webform_booking/src/Plugin/WebformElement/WebformBooking.php and change line 539 from

if (!empty($element['#required']) && (empty($value) || empty($value['slot']))) {
to
if (!empty($element['#required']) && (empty($value))) {

It results in omitting the slot validation in that field and only validating the date/time part. As I mentioned above, I'm considering it a dirty hack as it doesn't solve the issue in a long-term and how the date/time/slot is saved.

The old (prior to 1.1.0) date/time format was YYYY-MM-DD HH:MM (regardless of the US/Rest of the world issue), and it gave us a lot of flexibility. Despite not being a dedicated date field, I could easily prepopulate a dedicated date field with its value to further use it in views and apply sorting by date, datepicker, etc.

The new format is YYYY-MM-DD HH:MM | X, where X is the slot quantity. This approach changes a lot negatively, at least for me and takes away that flexibility.

@rfmarcelino, could you reconsider removing the slot value from that field and place it in a dedicated field? Is there any practical or technical meaning that stays behind that change?

🇦🇺Australia zimny

I can confirm this issue is no more in the last dev release. It can be pushed to the next stable.

@rfmarcelino, thanks a bunch!

🇦🇺Australia zimny

This functionality is broken for all releases starting from 1.0.13. For 1.0.13 the fix is simple but for the 1.1* versions it is not that easy to make it to work.

@rfmarcelino, can you please look into it when you have a second?

🇦🇺Australia zimny

Looking at the commit from the linked reference in my previous comment, I have slightly modified rfmarcelino's original code to match my needs and after some testing and to my surprise I wanted to let you know that it works and does exactly what I wanted.

I am not sure yet how to apply those commits, so please see below the attached code. Feel free to do the testing and possibly push it to the future updates. I am quite sure it can come handy.

WebformBookingController.php

    // Adjusting end date based on 'days_visible' if set.
    if (isset($config['#days_visible']) && is_numeric($config['#days_visible'])) {
      $visibleDate = (new \DateTime())->modify('+' . $config['#days_visible'] . ' days');
      if ($actualEndDate > $visibleDate) {
        $actualEndDate = $visibleDate;
      }
    }

WebformBooking.php

protected function defineDefaultProperties() {
 $properties = parent::defineDefaultProperties() + [
...
      'days_visable' => '0',
...

    // Days visable.
    $form['appointment_settings']['days_visible'] = [
      '#type' => 'number',
      '#title' => $this->t('Days Visiblee'),
      '#default_value' => $this->getDefaultProperty('days_visible'),
      '#description' => $this->t('Number of days from now a booking can be made'),
    ];

I think that at this stage we still have to create a condition that takes into account the original "Days in Advance" setting to ensure that those two not interfere with each other, i.e. "Days in Advance" number can not be higher than "Days Visible".
What do you think?

🇦🇺Australia zimny

zimny created an issue.

Production build 0.71.5 2024