mirror of
https://github.com/go-gitea/gitea
synced 2025-12-07 13:28:25 +00:00
A big step towards enabling strict mode in Typescript. There was definitely a good share of potential bugs while refactoring this. When in doubt, I opted to keep the potentially broken behaviour. Notably, the `DOMEvent` type is gone, it was broken and we're better of with type assertions on `e.target`. --------- Signed-off-by: silverwind <me@silverwind.io> Signed-off-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: delvh <dev.lh@web.de> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
20 lines
683 B
TypeScript
20 lines
683 B
TypeScript
import $ from 'jquery';
|
|
import {queryElemSiblings} from '../../utils/dom.ts';
|
|
|
|
export function initFomanticTab() {
|
|
$.fn.tab = function (this: any) {
|
|
for (const elBtn of this) {
|
|
const tabName = elBtn.getAttribute('data-tab');
|
|
if (!tabName) continue;
|
|
elBtn.addEventListener('click', () => {
|
|
const elTab = document.querySelector(`.ui.tab[data-tab="${tabName}"]`)!;
|
|
queryElemSiblings(elTab, `.ui.tab`, (el) => el.classList.remove('active'));
|
|
queryElemSiblings(elBtn, `[data-tab]`, (el) => el.classList.remove('active'));
|
|
elBtn.classList.add('active');
|
|
elTab.classList.add('active');
|
|
});
|
|
}
|
|
return this;
|
|
};
|
|
}
|