375
回編集
編集の要約なし タグ: モバイル編集 モバイルウェブ編集 |
編集の要約なし タグ: モバイル編集 モバイルウェブ編集 |
||
85行目: | 85行目: | ||
hrefForMenuDataItemComponent(component) { | hrefForMenuDataItemComponent(component) { | ||
switch (component.id) { | switch (component.id) { | ||
case | case "mobile-ui-page-short-url": | ||
return ( | return ( | ||
this.wgServer | this.wgServer | ||
112行目: | 112行目: | ||
element.id = component.id || ""; | element.id = component.id || ""; | ||
element.classList.add(...[].concat(component.class || [])); | element.classList.add(...[].concat(component.class || [])); | ||
element.setAttribute( | element.setAttribute("data-event-name", component.dataEventName || ""); | ||
return element; | return element; | ||
176行目: | 176行目: | ||
return children; | return children; | ||
} | |||
/** | |||
* @param {boolean} isVisible | |||
*/ | |||
static setRightMenuVisible(isVisible) { | |||
MobileUIBuilder | |||
.menuContainerElement | |||
.setAttribute("data-mobile-ui-right-menu-visible", String(Boolean(isVisible))); | |||
} | } | ||
181行目: | 190行目: | ||
* @returns {HTMLElement} | * @returns {HTMLElement} | ||
*/ | */ | ||
get menuContainerElement() { | static get menuContainerElement() { | ||
return window.document.getElementById( | return window.document | ||
.getElementById("mw-mf-page-left"); | |||
} | } | ||
188行目: | 198行目: | ||
* @returns {HTMLDivElement | null} | * @returns {HTMLDivElement | null} | ||
*/ | */ | ||
get menuElement() { | static get menuElement() { | ||
return /** @type {HTMLDivElement} */ ( | return /** @type {HTMLDivElement} */ ( | ||
MobileUIBuilder | |||
.menuContainerElement | |||
.getElementsByClassName(MobileUIBuilder.menuClass) | |||
.item(0) | |||
); | |||
} | |||
/** | |||
* @returns {HTMLBodyElement | null} | |||
*/ | |||
static get authenticatedBody() { | |||
return /** @type {HTMLBodyElement} */ ( | |||
window.document | |||
.getElementsByClassName("is-authenticated") | |||
.item(0) | |||
); | |||
} | |||
/** | |||
* @returns {HTMLFormElement} | |||
*/ | |||
static get headerElement() { | |||
return /** @type {HTMLFormElement} */ ( | |||
window.document | |||
.getElementsByClassName("header") | |||
.item(0) | |||
); | |||
} | |||
/** | |||
* @returns {HTMLAnchorElement | null} | |||
*/ | |||
static get userButton() { | |||
return /** @type {HTMLAnchorElement} */ ( | |||
MobileUIBuilder | |||
.headerElement | |||
.getElementsByClassName("user-button") | |||
.item(0) | |||
); | |||
} | |||
/** | |||
* @returns {HTMLButtonElement | null} | |||
*/ | |||
static get rightMenuButtonElement() { | |||
return /** @type {HTMLButtonElement} */ ( | |||
window.document | |||
.getElementById(MobileUIBuilder.rightMenuButtonID) | |||
); | ); | ||
} | |||
setNotArticleClass() { | |||
if (this.wgIsArticle && !this.wgIsMainPage) return; | |||
MobileUIBuilder | |||
.menuContainerElement | |||
.classList | |||
.add("mobile-ui-not-article"); | |||
} | |||
assembleRightMenuButton() { | |||
if (!this.wgUserId) return; | |||
if (!MobileUIBuilder.authenticatedBody) return; | |||
if (MobileUIBuilder.rightMenuButtonElement) return; | |||
const userButton = MobileUIBuilder.userButton; | |||
if (userButton && !userButton.text.trim()) { | |||
userButton.parentElement.classList.add(MobileUIBuilder.hiddenClass); | |||
} | |||
const button = window.document.createElement("button"); | |||
button.id = MobileUIBuilder.rightMenuButtonID; | |||
button.classList.add( | |||
"mw-ui-icon", | |||
"mw-ui-icon-element", | |||
"mobile-ui-icon-puzzle", | |||
); | |||
button.addEventListener("click", function (event) { | |||
event.preventDefault(); | |||
const body = MobileUIBuilder.authenticatedBody; | |||
if (!body) return; | |||
if (body.classList.contains(MobileUIBuilder.navigationEnabledClass)) return; | |||
MobileUIBuilder.setRightMenuVisible(true); | |||
body.classList.add( | |||
MobileUIBuilder.navigationEnabledClass, | |||
MobileUIBuilder.secondaryNavigationEnabledClass, | |||
); | |||
}); | |||
const buttonWrapper = window.document.createElement("div"); | |||
buttonWrapper.append(button); | |||
MobileUIBuilder.headerElement.append(buttonWrapper); | |||
} | |||
prebuild() { | |||
this.setNotArticleClass(); | |||
this.assembleRightMenuButton(); | |||
} | } | ||
198行目: | 305行目: | ||
*/ | */ | ||
modify(mobileUI) { | modify(mobileUI) { | ||
const leftMenu = | const leftMenu = MobileUIBuilder.menuElement; | ||
if (leftMenu.classList.contains(MobileUIBuilder.leftMenuClass)) return; | if (leftMenu.classList.contains(MobileUIBuilder.leftMenuClass)) return; | ||
MobileUIBuilder.setRightMenuVisible(false); | |||
menuContainer | const menuContainer = MobileUIBuilder.menuContainerElement; | ||
menuContainer.addEventListener("transitionend", function () { | menuContainer.addEventListener("transitionend", function () { | ||
if ( | const body = MobileUIBuilder.authenticatedBody; | ||
if (!body || body.classList.contains(MobileUIBuilder.secondaryNavigationEnabledClass)) return; | |||
MobileUIBuilder.setRightMenuVisible(false); | |||
}); | }); | ||
const firstGroup = leftMenu.getElementsByTagName("ul").item(0); | const firstGroup = leftMenu.getElementsByTagName("ul").item(0); | ||
234行目: | 339行目: | ||
*/ | */ | ||
build(mobileUI) { | build(mobileUI) { | ||
if ( | if (MobileUIBuilder.menuElement) { | ||
this.modify(mobileUI); | this.modify(mobileUI); | ||
return; | return; | ||
252行目: | 357行目: | ||
}); | }); | ||
observer.observe( | observer.observe(MobileUIBuilder.menuContainerElement, { childList: true }); | ||
} | } | ||
} | } | ||
MobileUIBuilder. | MobileUIBuilder.rightMenuButtonID = "mobile-ui-right-menu-button"; | ||
MobileUIBuilder.menuClass = "menu"; | MobileUIBuilder.menuClass = "menu"; | ||
MobileUIBuilder.leftMenuClass = "mobile-ui-left-menu"; | MobileUIBuilder.leftMenuClass = "mobile-ui-left-menu"; | ||
MobileUIBuilder.rightMenuClass = "mobile-ui-right-menu"; | MobileUIBuilder.rightMenuClass = "mobile-ui-right-menu"; | ||
MobileUIBuilder.hiddenClass = "mobile-ui-hidden"; | MobileUIBuilder.hiddenClass = "mobile-ui-hidden"; | ||
MobileUIBuilder.navigationEnabledClass = "navigation-enabled"; | MobileUIBuilder.navigationEnabledClass = "navigation-enabled"; | ||
MobileUIBuilder.secondaryNavigationEnabledClass = "secondary-navigation-enabled"; | MobileUIBuilder.secondaryNavigationEnabledClass = "secondary-navigation-enabled"; |