Update rails/ujs delegate method usage (#27538)
				
					
				
			This commit is contained in:
		
							parent
							
								
									134de736dc
								
							
						
					
					
						commit
						bc3afb6311
					
				
					 2 changed files with 24 additions and 24 deletions
				
			
		|  | @ -2,7 +2,7 @@ import './public-path'; | ||||||
| import React from 'react'; | import React from 'react'; | ||||||
| import { createRoot } from 'react-dom/client'; | import { createRoot } from 'react-dom/client'; | ||||||
| 
 | 
 | ||||||
| import delegate from '@rails/ujs'; | import Rails from '@rails/ujs'; | ||||||
| 
 | 
 | ||||||
| import ready from '../mastodon/ready'; | import ready from '../mastodon/ready'; | ||||||
| 
 | 
 | ||||||
|  | @ -20,7 +20,7 @@ const setAnnouncementEndsAttributes = (target) => { | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| delegate(document, 'input[type="datetime-local"]#announcement_starts_at', 'change', ({ target }) => { | Rails.delegate(document, 'input[type="datetime-local"]#announcement_starts_at', 'change', ({ target }) => { | ||||||
|   setAnnouncementEndsAttributes(target); |   setAnnouncementEndsAttributes(target); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | @ -43,7 +43,7 @@ const hideSelectAll = () => { | ||||||
|   hiddenField.value = '0'; |   hiddenField.value = '0'; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| delegate(document, '#batch_checkbox_all', 'change', ({ target }) => { | Rails.delegate(document, '#batch_checkbox_all', 'change', ({ target }) => { | ||||||
|   const selectAllMatchingElement = document.querySelector('.batch-table__select-all'); |   const selectAllMatchingElement = document.querySelector('.batch-table__select-all'); | ||||||
| 
 | 
 | ||||||
|   [].forEach.call(document.querySelectorAll(batchCheckboxClassName), (content) => { |   [].forEach.call(document.querySelectorAll(batchCheckboxClassName), (content) => { | ||||||
|  | @ -59,7 +59,7 @@ delegate(document, '#batch_checkbox_all', 'change', ({ target }) => { | ||||||
|   } |   } | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, '.batch-table__select-all button', 'click', () => { | Rails.delegate(document, '.batch-table__select-all button', 'click', () => { | ||||||
|   const hiddenField = document.querySelector('#select_all_matching'); |   const hiddenField = document.querySelector('#select_all_matching'); | ||||||
|   const active = hiddenField.value === '1'; |   const active = hiddenField.value === '1'; | ||||||
|   const selectedMsg = document.querySelector('.batch-table__select-all .selected'); |   const selectedMsg = document.querySelector('.batch-table__select-all .selected'); | ||||||
|  | @ -76,7 +76,7 @@ delegate(document, '.batch-table__select-all button', 'click', () => { | ||||||
|   } |   } | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, batchCheckboxClassName, 'change', () => { | Rails.delegate(document, batchCheckboxClassName, 'change', () => { | ||||||
|   const checkAllElement = document.querySelector('#batch_checkbox_all'); |   const checkAllElement = document.querySelector('#batch_checkbox_all'); | ||||||
|   const selectAllMatchingElement = document.querySelector('.batch-table__select-all'); |   const selectAllMatchingElement = document.querySelector('.batch-table__select-all'); | ||||||
| 
 | 
 | ||||||
|  | @ -94,19 +94,19 @@ delegate(document, batchCheckboxClassName, 'change', () => { | ||||||
|   } |   } | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, '.media-spoiler-show-button', 'click', () => { | Rails.delegate(document, '.media-spoiler-show-button', 'click', () => { | ||||||
|   [].forEach.call(document.querySelectorAll('button.media-spoiler'), (element) => { |   [].forEach.call(document.querySelectorAll('button.media-spoiler'), (element) => { | ||||||
|     element.click(); |     element.click(); | ||||||
|   }); |   }); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, '.media-spoiler-hide-button', 'click', () => { | Rails.delegate(document, '.media-spoiler-hide-button', 'click', () => { | ||||||
|   [].forEach.call(document.querySelectorAll('.spoiler-button.spoiler-button--visible button'), (element) => { |   [].forEach.call(document.querySelectorAll('.spoiler-button.spoiler-button--visible button'), (element) => { | ||||||
|     element.click(); |     element.click(); | ||||||
|   }); |   }); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, '.filter-subset--with-select select', 'change', ({ target }) => { | Rails.delegate(document, '.filter-subset--with-select select', 'change', ({ target }) => { | ||||||
|   target.form.submit(); |   target.form.submit(); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | @ -123,7 +123,7 @@ const onDomainBlockSeverityChange = (target) => { | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| delegate(document, '#domain_block_severity', 'change', ({ target }) => onDomainBlockSeverityChange(target)); | Rails.delegate(document, '#domain_block_severity', 'change', ({ target }) => onDomainBlockSeverityChange(target)); | ||||||
| 
 | 
 | ||||||
| const onEnableBootstrapTimelineAccountsChange = (target) => { | const onEnableBootstrapTimelineAccountsChange = (target) => { | ||||||
|   const bootstrapTimelineAccountsField = document.querySelector('#form_admin_settings_bootstrap_timeline_accounts'); |   const bootstrapTimelineAccountsField = document.querySelector('#form_admin_settings_bootstrap_timeline_accounts'); | ||||||
|  | @ -140,7 +140,7 @@ const onEnableBootstrapTimelineAccountsChange = (target) => { | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| delegate(document, '#form_admin_settings_enable_bootstrap_timeline_accounts', 'change', ({ target }) => onEnableBootstrapTimelineAccountsChange(target)); | Rails.delegate(document, '#form_admin_settings_enable_bootstrap_timeline_accounts', 'change', ({ target }) => onEnableBootstrapTimelineAccountsChange(target)); | ||||||
| 
 | 
 | ||||||
| const onChangeRegistrationMode = (target) => { | const onChangeRegistrationMode = (target) => { | ||||||
|   const enabled = target.value === 'approved'; |   const enabled = target.value === 'approved'; | ||||||
|  | @ -177,7 +177,7 @@ const convertLocalDatetimeToUTC = (value) => { | ||||||
|   return fullISO8601.slice(0, fullISO8601.indexOf('T') + 6); |   return fullISO8601.slice(0, fullISO8601.indexOf('T') + 6); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| delegate(document, '#form_admin_settings_registrations_mode', 'change', ({ target }) => onChangeRegistrationMode(target)); | Rails.delegate(document, '#form_admin_settings_registrations_mode', 'change', ({ target }) => onChangeRegistrationMode(target)); | ||||||
| 
 | 
 | ||||||
| ready(() => { | ready(() => { | ||||||
|   const domainBlockSeverityInput = document.getElementById('domain_block_severity'); |   const domainBlockSeverityInput = document.getElementById('domain_block_severity'); | ||||||
|  | @ -214,7 +214,7 @@ ready(() => { | ||||||
|     } |     } | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   delegate(document, 'form', 'submit', ({ target }) => { |   Rails.delegate(document, 'form', 'submit', ({ target }) => { | ||||||
|     [].forEach.call(target.querySelectorAll('input[type="datetime-local"]'), element => { |     [].forEach.call(target.querySelectorAll('input[type="datetime-local"]'), element => { | ||||||
|       if (element.value && element.validity.valid) { |       if (element.value && element.validity.valid) { | ||||||
|         element.value = convertLocalDatetimeToUTC(element.value); |         element.value = convertLocalDatetimeToUTC(element.value); | ||||||
|  |  | ||||||
|  | @ -5,7 +5,7 @@ import './public-path'; | ||||||
| import { IntlMessageFormat }  from 'intl-messageformat'; | import { IntlMessageFormat }  from 'intl-messageformat'; | ||||||
| import { defineMessages } from 'react-intl'; | import { defineMessages } from 'react-intl'; | ||||||
| 
 | 
 | ||||||
| import delegate from '@rails/ujs'; | import Rails from '@rails/ujs'; | ||||||
| import axios from 'axios'; | import axios from 'axios'; | ||||||
| import { throttle } from 'lodash'; | import { throttle } from 'lodash'; | ||||||
| 
 | 
 | ||||||
|  | @ -145,7 +145,7 @@ function loaded() { | ||||||
|       }); |       }); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   delegate(document, '#user_account_attributes_username', 'input', throttle(({ target }) => { |   Rails.delegate(document, '#user_account_attributes_username', 'input', throttle(({ target }) => { | ||||||
|     if (target.value && target.value.length > 0) { |     if (target.value && target.value.length > 0) { | ||||||
|       axios.get('/api/v1/accounts/lookup', { params: { acct: target.value } }).then(() => { |       axios.get('/api/v1/accounts/lookup', { params: { acct: target.value } }).then(() => { | ||||||
|         target.setCustomValidity(formatMessage(messages.usernameTaken)); |         target.setCustomValidity(formatMessage(messages.usernameTaken)); | ||||||
|  | @ -157,7 +157,7 @@ function loaded() { | ||||||
|     } |     } | ||||||
|   }, 500, { leading: false, trailing: true })); |   }, 500, { leading: false, trailing: true })); | ||||||
| 
 | 
 | ||||||
|   delegate(document, '#user_password,#user_password_confirmation', 'input', () => { |   Rails.delegate(document, '#user_password,#user_password_confirmation', 'input', () => { | ||||||
|     const password = document.getElementById('user_password'); |     const password = document.getElementById('user_password'); | ||||||
|     const confirmation = document.getElementById('user_password_confirmation'); |     const confirmation = document.getElementById('user_password_confirmation'); | ||||||
|     if (!confirmation) return; |     if (!confirmation) return; | ||||||
|  | @ -171,7 +171,7 @@ function loaded() { | ||||||
|     } |     } | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   delegate(document, '.status__content__spoiler-link', 'click', function() { |   Rails.delegate(document, '.status__content__spoiler-link', 'click', function() { | ||||||
|     const statusEl = this.parentNode.parentNode; |     const statusEl = this.parentNode.parentNode; | ||||||
| 
 | 
 | ||||||
|     if (statusEl.dataset.spoiler === 'expanded') { |     if (statusEl.dataset.spoiler === 'expanded') { | ||||||
|  | @ -192,7 +192,7 @@ function loaded() { | ||||||
|   }); |   }); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| delegate(document, '#edit_profile input[type=file]', 'change', ({ target }) => { | Rails.delegate(document, '#edit_profile input[type=file]', 'change', ({ target }) => { | ||||||
|   const avatar = document.getElementById(target.id + '-preview'); |   const avatar = document.getElementById(target.id + '-preview'); | ||||||
|   const [file] = target.files || []; |   const [file] = target.files || []; | ||||||
|   const url = file ? URL.createObjectURL(file) : avatar.dataset.originalSrc; |   const url = file ? URL.createObjectURL(file) : avatar.dataset.originalSrc; | ||||||
|  | @ -200,13 +200,13 @@ delegate(document, '#edit_profile input[type=file]', 'change', ({ target }) => { | ||||||
|   avatar.src = url; |   avatar.src = url; | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, '.input-copy input', 'click', ({ target }) => { | Rails.delegate(document, '.input-copy input', 'click', ({ target }) => { | ||||||
|   target.focus(); |   target.focus(); | ||||||
|   target.select(); |   target.select(); | ||||||
|   target.setSelectionRange(0, target.value.length); |   target.setSelectionRange(0, target.value.length); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, '.input-copy button', 'click', ({ target }) => { | Rails.delegate(document, '.input-copy button', 'click', ({ target }) => { | ||||||
|   const input = target.parentNode.querySelector('.input-copy__wrapper input'); |   const input = target.parentNode.querySelector('.input-copy__wrapper input'); | ||||||
| 
 | 
 | ||||||
|   const oldReadOnly = input.readonly; |   const oldReadOnly = input.readonly; | ||||||
|  | @ -248,23 +248,23 @@ const toggleSidebar = () => { | ||||||
|   sidebar.classList.toggle('visible'); |   sidebar.classList.toggle('visible'); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| delegate(document, '.sidebar__toggle__icon', 'click', () => { | Rails.delegate(document, '.sidebar__toggle__icon', 'click', () => { | ||||||
|   toggleSidebar(); |   toggleSidebar(); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, '.sidebar__toggle__icon', 'keydown', e => { | Rails.delegate(document, '.sidebar__toggle__icon', 'keydown', e => { | ||||||
|   if (e.key === ' ' || e.key === 'Enter') { |   if (e.key === ' ' || e.key === 'Enter') { | ||||||
|     e.preventDefault(); |     e.preventDefault(); | ||||||
|     toggleSidebar(); |     toggleSidebar(); | ||||||
|   } |   } | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| delegate(document, '.custom-emoji', 'mouseover', ({ target }) => target.src = target.getAttribute('data-original')); | Rails.delegate(document, '.custom-emoji', 'mouseover', ({ target }) => target.src = target.getAttribute('data-original')); | ||||||
| delegate(document, '.custom-emoji', 'mouseout', ({ target }) => target.src = target.getAttribute('data-static')); | Rails.delegate(document, '.custom-emoji', 'mouseout', ({ target }) => target.src = target.getAttribute('data-static')); | ||||||
| 
 | 
 | ||||||
| // Empty the honeypot fields in JS in case something like an extension | // Empty the honeypot fields in JS in case something like an extension | ||||||
| // automatically filled them. | // automatically filled them. | ||||||
| delegate(document, '#registration_new_user,#new_user', 'submit', () => { | Rails.delegate(document, '#registration_new_user,#new_user', 'submit', () => { | ||||||
|   ['user_website', 'user_confirm_password', 'registration_user_website', 'registration_user_confirm_password'].forEach(id => { |   ['user_website', 'user_confirm_password', 'registration_user_website', 'registration_user_confirm_password'].forEach(id => { | ||||||
|     const field = document.getElementById(id); |     const field = document.getElementById(id); | ||||||
|     if (field) { |     if (field) { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue