mirror of
				https://github.com/zulip/zulip-desktop.git
				synced 2025-10-26 01:23:32 +00:00 
			
		
		
		
	Creating the new functional tab for setting tab was unnecessary as we already have a sticky setting icon at the bottom. This PR adds a functionality to highlight that settings icon instead of creating the new one. Fixes: #418.
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| const Tab = require(__dirname + '/../components/tab.js');
 | |
| 
 | |
| class FunctionalTab extends Tab {
 | |
| 	template() {
 | |
| 		return `<div class="tab functional-tab" data-tab-id="${this.props.tabIndex}">
 | |
| 					<div class="server-tab-badge close-button">
 | |
| 						<i class="material-icons">close</i>
 | |
| 					</div>
 | |
| 					<div class="server-tab">
 | |
| 						<i class="material-icons">${this.props.materialIcon}</i>
 | |
| 					</div>
 | |
| 				</div>`;
 | |
| 	}
 | |
| 
 | |
| 	init() {
 | |
| 		this.$el = this.generateNodeFromTemplate(this.template());
 | |
| 		if (this.props.name !== 'Settings') {
 | |
| 			this.props.$root.appendChild(this.$el);
 | |
| 			this.$closeButton = this.$el.getElementsByClassName('server-tab-badge')[0];
 | |
| 			this.registerListeners();
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	registerListeners() {
 | |
| 		super.registerListeners();
 | |
| 
 | |
| 		this.$el.addEventListener('mouseover', () => {
 | |
| 			this.$closeButton.classList.add('active');
 | |
| 		});
 | |
| 
 | |
| 		this.$el.addEventListener('mouseout', () => {
 | |
| 			this.$closeButton.classList.remove('active');
 | |
| 		});
 | |
| 
 | |
| 		this.$closeButton.addEventListener('click', e => {
 | |
| 			this.props.onDestroy();
 | |
| 			e.stopPropagation();
 | |
| 		});
 | |
| 	}
 | |
| }
 | |
| 
 | |
| module.exports = FunctionalTab;
 |