mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-29 10:57:44 +09:00 
			
		
		
		
	The "primary button" is used at many places, but sometimes they might conflict (due to button switch, hidden panel, dropdown menu, etc). Sometimes we could add a special CSS class for the buttons, but sometimes not (see the comment of QuickSubmit) This PR introduces `querySingleVisibleElem` to help to get the correct primary button (the only visible one), and prevent from querying the wrong buttons. Fix #32437 --------- Co-authored-by: silverwind <me@silverwind.io>
		
			
				
	
	
		
			28 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {createElementFromAttrs, createElementFromHTML, querySingleVisibleElem} from './dom.ts';
 | |
| 
 | |
| test('createElementFromHTML', () => {
 | |
|   expect(createElementFromHTML('<a>foo<span>bar</span></a>').outerHTML).toEqual('<a>foo<span>bar</span></a>');
 | |
| });
 | |
| 
 | |
| test('createElementFromAttrs', () => {
 | |
|   const el = createElementFromAttrs('button', {
 | |
|     id: 'the-id',
 | |
|     class: 'cls-1 cls-2',
 | |
|     disabled: true,
 | |
|     checked: false,
 | |
|     required: null,
 | |
|     tabindex: 0,
 | |
|     'data-foo': 'the-data',
 | |
|   }, 'txt', createElementFromHTML('<span>inner</span>'));
 | |
|   expect(el.outerHTML).toEqual('<button id="the-id" class="cls-1 cls-2" disabled="" tabindex="0" data-foo="the-data">txt<span>inner</span></button>');
 | |
| });
 | |
| 
 | |
| test('querySingleVisibleElem', () => {
 | |
|   let el = createElementFromHTML('<div><span>foo</span></div>');
 | |
|   expect(querySingleVisibleElem(el, 'span').textContent).toEqual('foo');
 | |
|   el = createElementFromHTML('<div><span style="display: none;">foo</span><span>bar</span></div>');
 | |
|   expect(querySingleVisibleElem(el, 'span').textContent).toEqual('bar');
 | |
|   el = createElementFromHTML('<div><span>foo</span><span>bar</span></div>');
 | |
|   expect(() => querySingleVisibleElem(el, 'span')).toThrowError('Expected exactly one visible element');
 | |
| });
 |