Initial Drupal 11 with DDEV setup
This commit is contained in:
69
web/core/modules/system/js/system.date.js
Normal file
69
web/core/modules/system/js/system.date.js
Normal file
@ -0,0 +1,69 @@
|
||||
/**
|
||||
* @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 source = once(
|
||||
'dateFormat',
|
||||
'[data-drupal-date-formatter="source"]',
|
||||
context,
|
||||
);
|
||||
const target = once(
|
||||
'dateFormat',
|
||||
'[data-drupal-date-formatter="preview"]',
|
||||
context,
|
||||
);
|
||||
|
||||
// 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.value || '';
|
||||
const dateString = baseValue.replace(/\\?(.?)/gi, (key, value) =>
|
||||
dateFormats[key] ? dateFormats[key] : value,
|
||||
);
|
||||
|
||||
// Set date preview.
|
||||
target.forEach((item) => {
|
||||
item.querySelectorAll('em').forEach((em) => {
|
||||
em.textContent = 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);
|
||||
Reference in New Issue
Block a user