chore(client/ts): port switch

This commit is contained in:
Elian Doran
2025-01-29 18:38:27 +02:00
parent f86d9b11b1
commit 6aba099a29

View File

@@ -3,12 +3,12 @@ import NoteContextAwareWidget from "./note_context_aware_widget.js";
const TPL = ` const TPL = `
<div class="switch-widget"> <div class="switch-widget">
<style> <style>
.switch-widget { .switch-widget {
display: flex; display: flex;
align-items: center; align-items: center;
} }
/* The switch - the box around the slider */ /* The switch - the box around the slider */
.switch-widget .switch { .switch-widget .switch {
position: relative; position: relative;
@@ -17,11 +17,11 @@ const TPL = `
height: 24px; height: 24px;
margin: 0; margin: 0;
} }
.switch-on, .switch-off { .switch-on, .switch-off {
display: flex; display: flex;
} }
/* The slider */ /* The slider */
.switch-widget .slider { .switch-widget .slider {
border-radius: 24px; border-radius: 24px;
@@ -34,7 +34,7 @@ const TPL = `
background-color: var(--more-accented-background-color); background-color: var(--more-accented-background-color);
transition: .4s; transition: .4s;
} }
.switch-widget .slider:before { .switch-widget .slider:before {
border-radius: 50%; border-radius: 50%;
position: absolute; position: absolute;
@@ -47,20 +47,20 @@ const TPL = `
-webkit-transition: .4s; -webkit-transition: .4s;
transition: .4s; transition: .4s;
} }
.switch-widget .slider.checked { .switch-widget .slider.checked {
background-color: var(--main-text-color); background-color: var(--main-text-color);
} }
.switch-widget .slider.checked:before { .switch-widget .slider.checked:before {
transform: translateX(26px); transform: translateX(26px);
} }
.switch-widget .switch-disabled { .switch-widget .switch-disabled {
opacity: 70%; opacity: 70%;
pointer-events: none; pointer-events: none;
} }
.switch-widget .switch-help-button { .switch-widget .switch-help-button {
font-weight: 900; font-weight: 900;
border: 0; border: 0;
@@ -72,9 +72,9 @@ const TPL = `
<div class="switch-on"> <div class="switch-on">
<span class="switch-on-name"></span> <span class="switch-on-name"></span>
&nbsp; &nbsp;
<span class="switch-on-button"> <span class="switch-on-button">
<label class="switch"> <label class="switch">
<span class="slider"></span> <span class="slider"></span>
@@ -82,19 +82,28 @@ const TPL = `
</div> </div>
<div class="switch-off"> <div class="switch-off">
<span class="switch-off-name"></span> <span class="switch-off-name"></span>
&nbsp; &nbsp;
<span class="switch-off-button"> <span class="switch-off-button">
<label class="switch"> <label class="switch">
<span class="slider checked"></span> <span class="slider checked"></span>
</span> </span>
</div> </div>
<button class="switch-help-button" type="button" data-help-page="" title="${t("open-help-page")}" style="display: none;">?</button> <button class="switch-help-button" type="button" data-help-page="" title="${t("open-help-page")}" style="display: none;">?</button>
</div>`; </div>`;
export default class SwitchWidget extends NoteContextAwareWidget { export default class SwitchWidget extends NoteContextAwareWidget {
private $switchOn!: JQuery<HTMLElement>;
private $switchOnName!: JQuery<HTMLElement>;
private $switchOnButton!: JQuery<HTMLElement>;
private $switchOff!: JQuery<HTMLElement>;
private $switchOffName!: JQuery<HTMLElement>;
private $switchOffButton!: JQuery<HTMLElement>;
private $helpButton!: JQuery<HTMLElement>;
doRender() { doRender() {
this.$widget = $(TPL); this.$widget = $(TPL);
@@ -113,7 +122,7 @@ export default class SwitchWidget extends NoteContextAwareWidget {
this.$helpButton = this.$widget.find(".switch-help-button"); this.$helpButton = this.$widget.find(".switch-help-button");
} }
toggle(state) { toggle(state: boolean) {
if (state) { if (state) {
this.switchOn(); this.switchOn();
} else { } else {