1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- /**
- * @file
- * Provides date format preview feature.
- */
- (function($, Drupal, drupalSettings) {
- const dateFormats = drupalSettings.dateFormats;
- /**
- * Display the preview for date format entered.
- *
- * @type {Drupal~behavior}
- *
- * @prop {Drupal~behaviorAttach} attach
- * Attach behavior for previewing date formats on input elements.
- */
- Drupal.behaviors.dateFormat = {
- attach(context) {
- const $context = $(context);
- const $source = $context
- .find('[data-drupal-date-formatter="source"]')
- .once('dateFormat');
- const $target = $context
- .find('[data-drupal-date-formatter="preview"]')
- .once('dateFormat');
- const $preview = $target.find('em');
- // All elements have to exist.
- if (!$source.length || !$target.length) {
- return;
- }
- /**
- * Event handler that replaces date characters with value.
- *
- * @param {jQuery.Event} e
- * The jQuery event triggered.
- */
- function dateFormatHandler(e) {
- const baseValue = $(e.target).val() || '';
- const dateString = baseValue.replace(
- /\\?(.?)/gi,
- (key, value) => (dateFormats[key] ? dateFormats[key] : value),
- );
- $preview.html(dateString);
- $target.toggleClass('js-hide', !dateString.length);
- }
- /**
- * On given event triggers the date character replacement.
- */
- $source
- .on(
- 'keyup.dateFormat change.dateFormat input.dateFormat',
- dateFormatHandler,
- )
- // Initialize preview.
- .trigger('keyup');
- },
- };
- })(jQuery, Drupal, drupalSettings);
|