54 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
		
		
			
		
	
	
			54 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @file
							 | 
						||
| 
								 | 
							
								 * Message template overrides.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								((Drupal) => {
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Overrides message theme function.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @param {object} message
							 | 
						||
| 
								 | 
							
								   *   The message object.
							 | 
						||
| 
								 | 
							
								   * @param {string} message.text
							 | 
						||
| 
								 | 
							
								   *   The message text.
							 | 
						||
| 
								 | 
							
								   * @param {object} options
							 | 
						||
| 
								 | 
							
								   *   The message context.
							 | 
						||
| 
								 | 
							
								   * @param {string} options.type
							 | 
						||
| 
								 | 
							
								   *   The message type.
							 | 
						||
| 
								 | 
							
								   * @param {string} options.id
							 | 
						||
| 
								 | 
							
								   *   ID of the message, for reference.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @return {HTMLElement}
							 | 
						||
| 
								 | 
							
								   *   A DOM Node.
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  Drupal.theme.message = ({ text }, { type, id }) => {
							 | 
						||
| 
								 | 
							
								    const messagesTypes = Drupal.Message.getMessageTypeLabels();
							 | 
						||
| 
								 | 
							
								    const messageWrapper = document.createElement('div');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    messageWrapper.setAttribute(
							 | 
						||
| 
								 | 
							
								      'class',
							 | 
						||
| 
								 | 
							
								      `messages messages--${type} messages-list__item`,
							 | 
						||
| 
								 | 
							
								    );
							 | 
						||
| 
								 | 
							
								    messageWrapper.setAttribute(
							 | 
						||
| 
								 | 
							
								      'role',
							 | 
						||
| 
								 | 
							
								      type === 'error' || type === 'warning' ? 'alert' : 'status',
							 | 
						||
| 
								 | 
							
								    );
							 | 
						||
| 
								 | 
							
								    messageWrapper.setAttribute('aria-labelledby', `${id}-title`);
							 | 
						||
| 
								 | 
							
								    messageWrapper.setAttribute('data-drupal-message-id', id);
							 | 
						||
| 
								 | 
							
								    messageWrapper.setAttribute('data-drupal-message-type', type);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    messageWrapper.innerHTML = `
							 | 
						||
| 
								 | 
							
								    <div class="messages__header">
							 | 
						||
| 
								 | 
							
								      <h2 id="${id}-title" class="messages__title">
							 | 
						||
| 
								 | 
							
								        ${messagesTypes[type]}
							 | 
						||
| 
								 | 
							
								      </h2>
							 | 
						||
| 
								 | 
							
								    </div>
							 | 
						||
| 
								 | 
							
								    <div class="messages__content">
							 | 
						||
| 
								 | 
							
								      ${text}
							 | 
						||
| 
								 | 
							
								    </div>
							 | 
						||
| 
								 | 
							
								  `;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return messageWrapper;
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								})(Drupal);
							 |