summaryrefslogtreecommitdiff
path: root/packages
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-01-10 06:02:46 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-01-10 06:02:46 +0900
commit0b08fcac4a966e0af347c80e96bdbdb059451a26 (patch)
tree274ae678a089619bf2cfcb408b4d53bdbf2ba3c6 /packages
parentrefactor(client): use css modules (diff)
downloadmisskey-0b08fcac4a966e0af347c80e96bdbdb059451a26.tar.gz
misskey-0b08fcac4a966e0af347c80e96bdbdb059451a26.tar.bz2
misskey-0b08fcac4a966e0af347c80e96bdbdb059451a26.zip
refactor(client): use css modules
Diffstat (limited to 'packages')
-rw-r--r--packages/frontend/src/components/MkMenu.vue298
1 files changed, 149 insertions, 149 deletions
diff --git a/packages/frontend/src/components/MkMenu.vue b/packages/frontend/src/components/MkMenu.vue
index abae272e8f..a1020ef151 100644
--- a/packages/frontend/src/components/MkMenu.vue
+++ b/packages/frontend/src/components/MkMenu.vue
@@ -2,54 +2,54 @@
<div>
<div
ref="itemsEl" v-hotkey="keymap"
- class="rrevdjwt _popup _shadow"
- :class="{ center: align === 'center', asDrawer }"
+ class="_popup _shadow"
+ :class="[$style.root, { [$style.center]: align === 'center', [$style.asDrawer]: asDrawer }]"
:style="{ width: (width && !asDrawer) ? width + 'px' : '', maxHeight: maxHeight ? maxHeight + 'px' : '' }"
@contextmenu.self="e => e.preventDefault()"
>
<template v-for="(item, i) in items2">
- <div v-if="item === null" class="divider"></div>
- <span v-else-if="item.type === 'label'" class="label item">
+ <div v-if="item === null" :class="$style.divider"></div>
+ <span v-else-if="item.type === 'label'" :class="[$style.label, $style.item]">
<span>{{ item.text }}</span>
</span>
- <span v-else-if="item.type === 'pending'" :tabindex="i" class="pending item">
+ <span v-else-if="item.type === 'pending'" :tabindex="i" :class="[$style.pending, $style.item]">
<span><MkEllipsis/></span>
</span>
- <MkA v-else-if="item.type === 'link'" :to="item.to" :tabindex="i" class="_button item" @click.passive="close(true)" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
- <i v-if="item.icon" class="ti-fw" :class="item.icon"></i>
- <MkAvatar v-if="item.avatar" :user="item.avatar" class="avatar"/>
+ <MkA v-else-if="item.type === 'link'" :to="item.to" :tabindex="i" class="_button" :class="$style.item" @click.passive="close(true)" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
+ <i v-if="item.icon" class="ti-fw" :class="[$style.icon, item.icon]"></i>
+ <MkAvatar v-if="item.avatar" :user="item.avatar" :class="$style.avatar"/>
<span>{{ item.text }}</span>
- <span v-if="item.indicate" class="indicator"><i class="_indicatorCircle"></i></span>
+ <span v-if="item.indicate" :class="$style.indicator"><i class="_indicatorCircle"></i></span>
</MkA>
- <a v-else-if="item.type === 'a'" :href="item.href" :target="item.target" :download="item.download" :tabindex="i" class="_button item" @click="close(true)" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
- <i v-if="item.icon" class="ti-fw" :class="item.icon"></i>
+ <a v-else-if="item.type === 'a'" :href="item.href" :target="item.target" :download="item.download" :tabindex="i" class="_button" :class="$style.item" @click="close(true)" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
+ <i v-if="item.icon" class="ti-fw" :class="[$style.icon, item.icon]"></i>
<span>{{ item.text }}</span>
- <span v-if="item.indicate" class="indicator"><i class="_indicatorCircle"></i></span>
+ <span v-if="item.indicate" :class="$style.indicator"><i class="_indicatorCircle"></i></span>
</a>
- <button v-else-if="item.type === 'user'" :tabindex="i" class="_button item" :class="{ active: item.active }" :disabled="item.active" @click="clicked(item.action, $event)" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
- <MkAvatar :user="item.user" class="avatar"/><MkUserName :user="item.user"/>
- <span v-if="item.indicate" class="indicator"><i class="_indicatorCircle"></i></span>
+ <button v-else-if="item.type === 'user'" :tabindex="i" class="_button" :class="[$style.item, { [$style.active]: item.active }]" :disabled="item.active" @click="clicked(item.action, $event)" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
+ <MkAvatar :user="item.user" :class="$style.avatar"/><MkUserName :user="item.user"/>
+ <span v-if="item.indicate" :class="$style.indicator"><i class="_indicatorCircle"></i></span>
</button>
- <span v-else-if="item.type === 'switch'" :tabindex="i" class="item" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
+ <span v-else-if="item.type === 'switch'" :tabindex="i" :class="$style.item" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
<MkSwitch v-model="item.ref" :disabled="item.disabled" class="form-switch">{{ item.text }}</MkSwitch>
</span>
- <button v-else-if="item.type === 'parent'" :tabindex="i" class="_button item parent" :class="{ childShowing: childShowingItem === item }" @mouseenter="showChildren(item, $event)">
- <i v-if="item.icon" class="ti-fw" :class="item.icon"></i>
+ <button v-else-if="item.type === 'parent'" :tabindex="i" class="_button" :class="[$style.item, $style.parent, { [$style.childShowing]: childShowingItem === item }]" @mouseenter="showChildren(item, $event)">
+ <i v-if="item.icon" class="ti-fw" :class="[$style.icon, item.icon]"></i>
<span>{{ item.text }}</span>
- <span class="caret"><i class="ti ti-caret-right ti-fw"></i></span>
+ <span :class="$style.caret"><i class="ti ti-caret-right ti-fw"></i></span>
</button>
- <button v-else :tabindex="i" class="_button item" :class="{ danger: item.danger, active: item.active }" :disabled="item.active" @click="clicked(item.action, $event)" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
- <i v-if="item.icon" class="ti-fw" :class="item.icon"></i>
- <MkAvatar v-if="item.avatar" :user="item.avatar" class="avatar"/>
+ <button v-else :tabindex="i" class="_button" :class="[$style.item, { [$style.danger]: item.danger, [$style.active]: item.active }]" :disabled="item.active" @click="clicked(item.action, $event)" @mouseenter.passive="onItemMouseEnter(item)" @mouseleave.passive="onItemMouseLeave(item)">
+ <i v-if="item.icon" class="ti-fw" :class="[$style.icon, item.icon]"></i>
+ <MkAvatar v-if="item.avatar" :user="item.avatar" :class="$style.avatar"/>
<span>{{ item.text }}</span>
- <span v-if="item.indicate" class="indicator"><i class="_indicatorCircle"></i></span>
+ <span v-if="item.indicate" :class="$style.indicator"><i class="_indicatorCircle"></i></span>
</button>
</template>
- <span v-if="items2.length === 0" class="none item">
+ <span v-if="items2.length === 0" :class="[$style.none, $style.item]">
<span>{{ i18n.ts.none }}</span>
</span>
</div>
- <div v-if="childMenu" class="child">
+ <div v-if="childMenu" :class="$style.child">
<XChild ref="child" :items="childMenu" :target-element="childTarget" :root-element="itemsEl" showing @actioned="childActioned"/>
</div>
</div>
@@ -186,8 +186,8 @@ onBeforeUnmount(() => {
});
</script>
-<style lang="scss" scoped>
-.rrevdjwt {
+<style lang="scss" module>
+.root {
padding: 8px 0;
box-sizing: border-box;
min-width: 200px;
@@ -200,166 +200,166 @@ onBeforeUnmount(() => {
}
}
- > .item {
- display: block;
- position: relative;
- padding: 5px 16px;
+ &.asDrawer {
+ padding: 12px 0 calc(env(safe-area-inset-bottom, 0px) + 12px) 0;
width: 100%;
- box-sizing: border-box;
- white-space: nowrap;
- font-size: 0.9em;
- line-height: 20px;
- text-align: left;
- overflow: hidden;
- text-overflow: ellipsis;
-
- &:before {
- content: "";
- display: block;
- position: absolute;
- z-index: -1;
- top: 0;
- left: 0;
- right: 0;
- margin: auto;
- width: calc(100% - 16px);
- height: 100%;
- border-radius: 6px;
- }
+ border-radius: 24px;
+ border-bottom-right-radius: 0;
+ border-bottom-left-radius: 0;
- &:not(:disabled):hover {
- color: var(--accent);
- text-decoration: none;
+ > .item {
+ font-size: 1em;
+ padding: 12px 24px;
&:before {
- background: var(--accentedBg);
+ width: calc(100% - 24px);
+ border-radius: 12px;
+ }
+
+ > .icon {
+ margin-right: 14px;
+ width: 24px;
}
}
- &.danger {
- color: #ff2a2a;
+ > .divider {
+ margin: 12px 0;
+ }
+ }
+}
- &:hover {
- color: #fff;
+.item {
+ display: block;
+ position: relative;
+ padding: 5px 16px;
+ width: 100%;
+ box-sizing: border-box;
+ white-space: nowrap;
+ font-size: 0.9em;
+ line-height: 20px;
+ text-align: left;
+ overflow: hidden;
+ text-overflow: ellipsis;
- &:before {
- background: #ff4242;
- }
- }
+ &:before {
+ content: "";
+ display: block;
+ position: absolute;
+ z-index: -1;
+ top: 0;
+ left: 0;
+ right: 0;
+ margin: auto;
+ width: calc(100% - 16px);
+ height: 100%;
+ border-radius: 6px;
+ }
- &:active {
- color: #fff;
+ &:not(:disabled):hover {
+ color: var(--accent);
+ text-decoration: none;
- &:before {
- background: #d42e2e !important;
- }
- }
+ &:before {
+ background: var(--accentedBg);
}
+ }
- &:active,
- &.active {
- color: var(--fgOnAccent) !important;
- opacity: 1;
+ &.danger {
+ color: #ff2a2a;
+
+ &:hover {
+ color: #fff;
&:before {
- background: var(--accent) !important;
+ background: #ff4242;
}
}
- &:not(:active):focus-visible {
- box-shadow: 0 0 0 2px var(--focus) inset;
- }
-
- &.label {
- pointer-events: none;
- font-size: 0.7em;
- padding-bottom: 4px;
+ &:active {
+ color: #fff;
- > span {
- opacity: 0.7;
+ &:before {
+ background: #d42e2e !important;
}
}
+ }
- &.pending {
- pointer-events: none;
- opacity: 0.7;
- }
+ &:active,
+ &.active {
+ color: var(--fgOnAccent) !important;
+ opacity: 1;
- &.none {
- pointer-events: none;
- opacity: 0.7;
+ &:before {
+ background: var(--accent) !important;
}
+ }
- &.parent {
- display: flex;
- align-items: center;
- cursor: default;
-
- > .caret {
- margin-left: auto;
- }
-
- &.childShowing {
- color: var(--accent);
- text-decoration: none;
-
- &:before {
- background: var(--accentedBg);
- }
- }
- }
+ &:not(:active):focus-visible {
+ box-shadow: 0 0 0 2px var(--focus) inset;
+ }
- > i {
- margin-right: 5px;
- width: 20px;
- }
+ &.label {
+ pointer-events: none;
+ font-size: 0.7em;
+ padding-bottom: 4px;
- > .avatar {
- margin-right: 5px;
- width: 20px;
- height: 20px;
+ > span {
+ opacity: 0.7;
}
+ }
- > .indicator {
- position: absolute;
- top: 5px;
- left: 13px;
- color: var(--indicator);
- font-size: 12px;
- animation: blink 1s infinite;
- }
+ &.pending {
+ pointer-events: none;
+ opacity: 0.7;
}
- > .divider {
- margin: 8px 0;
- border-top: solid 0.5px var(--divider);
+ &.none {
+ pointer-events: none;
+ opacity: 0.7;
}
- &.asDrawer {
- padding: 12px 0 calc(env(safe-area-inset-bottom, 0px) + 12px) 0;
- width: 100%;
- border-radius: 24px;
- border-bottom-right-radius: 0;
- border-bottom-left-radius: 0;
+ &.parent {
+ display: flex;
+ align-items: center;
+ cursor: default;
- > .item {
- font-size: 1em;
- padding: 12px 24px;
+ &.childShowing {
+ color: var(--accent);
+ text-decoration: none;
&:before {
- width: calc(100% - 24px);
- border-radius: 12px;
- }
-
- > i {
- margin-right: 14px;
- width: 24px;
+ background: var(--accentedBg);
}
}
-
- > .divider {
- margin: 12px 0;
- }
}
}
+
+.icon {
+ margin-right: 5px;
+ width: 20px;
+}
+
+.caret {
+ margin-left: auto;
+}
+
+.avatar {
+ margin-right: 5px;
+ width: 20px;
+ height: 20px;
+}
+
+.indicator {
+ position: absolute;
+ top: 5px;
+ left: 13px;
+ color: var(--indicator);
+ font-size: 12px;
+ animation: blink 1s infinite;
+}
+
+.divider {
+ margin: 8px 0;
+ border-top: solid 0.5px var(--divider);
+}
</style>