mirror of
				https://github.com/mastodon/mastodon.git
				synced 2025-10-26 10:41:27 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import 'packs/public-path';
 | |
| import loadPolyfills from 'flavours/glitch/util/load_polyfills';
 | |
| import ready from 'flavours/glitch/util/ready';
 | |
| 
 | |
| function setupSidebar() {
 | |
|   const { delegate } = require('@rails/ujs');
 | |
| 
 | |
|   delegate(document, '.sidebar__toggle__icon', 'click', () => {
 | |
|     const target = document.querySelector('.sidebar ul');
 | |
| 
 | |
|     if (target.style.display === 'block') {
 | |
|       target.style.display = 'none';
 | |
|     } else {
 | |
|       target.style.display = 'block';
 | |
|     }
 | |
|   });
 | |
| }
 | |
| 
 | |
| loadPolyfills()
 | |
|   .then(setupSidebar)
 | |
|   .catch(error => {
 | |
|     console.error(error);
 | |
|   });
 | |
| 
 | |
| ready(() => {
 | |
|   const React    = require('react');
 | |
|   const ReactDOM = require('react-dom');
 | |
| 
 | |
|   [].forEach.call(document.querySelectorAll('[data-admin-component]'), element => {
 | |
|     const componentName  = element.getAttribute('data-admin-component');
 | |
|     const { locale, ...componentProps } = JSON.parse(element.getAttribute('data-props'));
 | |
| 
 | |
|     import('flavours/glitch/containers/admin_component').then(({ default: AdminComponent }) => {
 | |
|       return import('flavours/glitch/components/admin/' + componentName).then(({ default: Component }) => {
 | |
|         ReactDOM.render((
 | |
|           <AdminComponent locale={locale}>
 | |
|             <Component {...componentProps} />
 | |
|           </AdminComponent>
 | |
|         ), element);
 | |
|       });
 | |
|     }).catch(error => {
 | |
|       console.error(error);
 | |
|     });
 | |
|   });
 | |
| });
 | 
