2018-08-17 00:30:59 +02:00
|
|
|
/*
|
2021-02-04 23:04:35 +01:00
|
|
|
* Copyright (c) 2010-2021 Tim Düsterhus.
|
2018-08-17 00:30:59 +02:00
|
|
|
*
|
|
|
|
* Use of this software is governed by the Business Source License
|
|
|
|
* included in the LICENSE file.
|
|
|
|
*
|
2021-03-05 17:19:27 +01:00
|
|
|
* Change Date: 2025-03-05
|
2018-08-17 00:30:59 +02:00
|
|
|
*
|
|
|
|
* On the date above, in accordance with the Business Source
|
|
|
|
* License, use of this software will be governed by version 2
|
|
|
|
* or later of the General Public License.
|
|
|
|
*/
|
|
|
|
|
2020-11-01 17:41:19 +01:00
|
|
|
define(['WoltLabSuite/Core/Ui/Screen'], function (UiScreen) {
|
|
|
|
'use strict'
|
2018-08-17 00:30:59 +02:00
|
|
|
|
|
|
|
const initialized = Symbol('initialized')
|
|
|
|
|
|
|
|
class Mobile {
|
|
|
|
constructor() {
|
|
|
|
this[initialized] = false
|
|
|
|
}
|
|
|
|
|
|
|
|
bootstrap() {
|
2020-11-01 17:41:19 +01:00
|
|
|
UiScreen.on('screen-md-down', {
|
|
|
|
match: this.enable.bind(this),
|
|
|
|
unmatch: this.disable.bind(this),
|
|
|
|
setup: this.init.bind(this),
|
|
|
|
})
|
2018-08-17 00:30:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
init() {
|
|
|
|
if (this[initialized]) return
|
|
|
|
|
|
|
|
this[initialized] = true
|
|
|
|
|
|
|
|
this.initQuickSettings()
|
|
|
|
}
|
|
|
|
|
2020-11-01 17:41:19 +01:00
|
|
|
enable() {}
|
2018-08-17 00:30:59 +02:00
|
|
|
|
2020-11-01 17:41:19 +01:00
|
|
|
disable() {}
|
2018-08-17 00:30:59 +02:00
|
|
|
|
|
|
|
initQuickSettings() {
|
2020-11-01 17:41:19 +01:00
|
|
|
const navigation = elBySel('#chatQuickSettingsNavigation > ul')
|
2018-08-17 00:30:59 +02:00
|
|
|
const quickSettings = elById('chatQuickSettings')
|
|
|
|
|
2020-11-01 17:41:19 +01:00
|
|
|
navigation.addEventListener(WCF_CLICK_EVENT, (event) => {
|
2018-08-17 00:30:59 +02:00
|
|
|
event.stopPropagation()
|
|
|
|
|
|
|
|
// mimic dropdown behavior
|
|
|
|
window.setTimeout(() => {
|
|
|
|
navigation.classList.remove('open')
|
|
|
|
}, 10)
|
|
|
|
})
|
|
|
|
|
2020-11-01 17:41:19 +01:00
|
|
|
quickSettings.addEventListener(WCF_CLICK_EVENT, (event) => {
|
2018-08-17 00:30:59 +02:00
|
|
|
event.preventDefault()
|
|
|
|
event.stopPropagation()
|
|
|
|
|
|
|
|
navigation.classList.toggle('open')
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return Mobile
|
2020-11-01 17:41:19 +01:00
|
|
|
})
|