summaryrefslogtreecommitdiff
path: root/packages/frontend/src/ui/_common_
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-05-31 13:41:38 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-05-31 13:41:38 +0900
commit9521519cb82ef8e1b95b2a1fcb544912a25175a7 (patch)
tree824c778c75249a12b7837acbd056b084928a06f0 /packages/frontend/src/ui/_common_
parentrefactor (diff)
downloadmisskey-9521519cb82ef8e1b95b2a1fcb544912a25175a7.tar.gz
misskey-9521519cb82ef8e1b95b2a1fcb544912a25175a7.tar.bz2
misskey-9521519cb82ef8e1b95b2a1fcb544912a25175a7.zip
reafactor
Diffstat (limited to 'packages/frontend/src/ui/_common_')
-rw-r--r--packages/frontend/src/ui/_common_/navbar-for-mobile.vue402
1 files changed, 197 insertions, 205 deletions
diff --git a/packages/frontend/src/ui/_common_/navbar-for-mobile.vue b/packages/frontend/src/ui/_common_/navbar-for-mobile.vue
index 6aacdd0150..365486a0ae 100644
--- a/packages/frontend/src/ui/_common_/navbar-for-mobile.vue
+++ b/packages/frontend/src/ui/_common_/navbar-for-mobile.vue
@@ -1,43 +1,41 @@
<template>
-<div class="kmwsukvl">
- <div class="body">
- <div class="top">
- <div class="banner" :style="{ backgroundImage: `url(${ instance.bannerUrl })` }"></div>
- <button v-click-anime class="item _button instance" @click="openInstanceMenu">
- <img :src="instance.iconUrl || instance.faviconUrl || '/favicon.ico'" alt="" class="icon"/>
- </button>
- </div>
- <div class="middle">
- <MkA v-click-anime class="item index" activeClass="active" to="/" exact>
- <i class="icon ti ti-home ti-fw"></i><span class="text">{{ i18n.ts.timeline }}</span>
- </MkA>
- <template v-for="item in menu">
- <div v-if="item === '-'" class="divider"></div>
- <component :is="navbarItemDef[item].to ? 'MkA' : 'button'" v-else-if="navbarItemDef[item] && (navbarItemDef[item].show !== false)" v-click-anime class="item _button" :class="[item, { active: navbarItemDef[item].active }]" activeClass="active" :to="navbarItemDef[item].to" v-on="navbarItemDef[item].action ? { click: navbarItemDef[item].action } : {}">
- <i class="icon ti-fw" :class="navbarItemDef[item].icon"></i><span class="text">{{ navbarItemDef[item].title }}</span>
- <span v-if="navbarItemDef[item].indicated" class="indicator"><i class="icon _indicatorCircle"></i></span>
- </component>
- </template>
- <div class="divider"></div>
- <MkA v-if="$i.isAdmin || $i.isModerator" v-click-anime class="item" activeClass="active" to="/admin">
- <i class="icon ti ti-dashboard ti-fw"></i><span class="text">{{ i18n.ts.controlPanel }}</span>
- </MkA>
- <button v-click-anime class="item _button" @click="more">
- <i class="icon ti ti-grid-dots ti-fw"></i><span class="text">{{ i18n.ts.more }}</span>
- <span v-if="otherMenuItemIndicated" class="indicator"><i class="icon _indicatorCircle"></i></span>
- </button>
- <MkA v-click-anime class="item" activeClass="active" to="/settings">
- <i class="icon ti ti-settings ti-fw"></i><span class="text">{{ i18n.ts.settings }}</span>
- </MkA>
- </div>
- <div class="bottom">
- <button class="item _button post" data-cy-open-post-form @click="os.post">
- <i class="icon ti ti-pencil ti-fw"></i><span class="text">{{ i18n.ts.note }}</span>
- </button>
- <button v-click-anime class="item _button account" @click="openAccountMenu">
- <MkAvatar :user="$i" class="avatar"/><MkAcct class="text _nowrap" :user="$i"/>
- </button>
- </div>
+<div :class="$style.root">
+ <div :class="$style.top">
+ <div :class="$style.banner" :style="{ backgroundImage: `url(${ instance.bannerUrl })` }"></div>
+ <button class="_button" :class="$style.instance" @click="openInstanceMenu">
+ <img :src="instance.iconUrl || instance.faviconUrl || '/favicon.ico'" alt="" :class="$style.instanceIcon"/>
+ </button>
+ </div>
+ <div :class="$style.middle">
+ <MkA :class="$style.item" :activeClass="$style.active" to="/" exact>
+ <i :class="$style.itemIcon" class="ti ti-home ti-fw"></i><span :class="$style.itemText">{{ i18n.ts.timeline }}</span>
+ </MkA>
+ <template v-for="item in menu">
+ <div v-if="item === '-'" :class="$style.divider"></div>
+ <component :is="navbarItemDef[item].to ? 'MkA' : 'button'" v-else-if="navbarItemDef[item] && (navbarItemDef[item].show !== false)" class="_button" :class="[$style.item, { [$style.active]: navbarItemDef[item].active }]" :activeClass="$style.active" :to="navbarItemDef[item].to" v-on="navbarItemDef[item].action ? { click: navbarItemDef[item].action } : {}">
+ <i class="ti-fw" :class="[$style.itemIcon, navbarItemDef[item].icon]"></i><span :class="$style.itemText">{{ navbarItemDef[item].title }}</span>
+ <span v-if="navbarItemDef[item].indicated" :class="$style.itemIndicator"><i class="_indicatorCircle"></i></span>
+ </component>
+ </template>
+ <div :class="$style.divider"></div>
+ <MkA v-if="$i.isAdmin || $i.isModerator" :class="$style.item" :activeClass="$style.active" to="/admin">
+ <i :class="$style.itemIcon" class="ti ti-dashboard ti-fw"></i><span :class="$style.itemText">{{ i18n.ts.controlPanel }}</span>
+ </MkA>
+ <button :class="$style.item" class="_button" @click="more">
+ <i :class="$style.itemIcon" class="ti ti-grid-dots ti-fw"></i><span :class="$style.itemText">{{ i18n.ts.more }}</span>
+ <span v-if="otherMenuItemIndicated" :class="$style.itemIndicator"><i class="_indicatorCircle"></i></span>
+ </button>
+ <MkA :class="$style.item" :activeClass="$style.active" to="/settings">
+ <i :class="$style.itemIcon" class="ti ti-settings ti-fw"></i><span :class="$style.itemText">{{ i18n.ts.settings }}</span>
+ </MkA>
+ </div>
+ <div :class="$style.bottom">
+ <button class="_button" :class="$style.post" data-cy-open-post-form @click="os.post">
+ <i :class="$style.postIcon" class="ti ti-pencil ti-fw"></i><span style="position: relative;">{{ i18n.ts.note }}</span>
+ </button>
+ <button class="_button" :class="$style.account" @click="openAccountMenu">
+ <MkAvatar :user="$i" :class="$style.avatar"/><MkAcct :class="$style.acct" class="_nowrap" :user="$i"/>
+ </button>
</div>
</div>
</template>
@@ -73,192 +71,186 @@ function more() {
}
</script>
-<style lang="scss" scoped>
-.kmwsukvl {
- > .body {
- display: flex;
- flex-direction: column;
-
- > .top {
- position: sticky;
- top: 0;
- z-index: 1;
- padding: 20px 0;
- background: var(--X14);
- -webkit-backdrop-filter: var(--blur, blur(8px));
- backdrop-filter: var(--blur, blur(8px));
+<style lang="scss" module>
+.root {
+ display: flex;
+ flex-direction: column;
+}
- > .banner {
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- background-size: cover;
- background-position: center center;
- -webkit-mask-image: linear-gradient(0deg, rgba(0,0,0,0) 15%, rgba(0,0,0,0.75) 100%);
- mask-image: linear-gradient(0deg, rgba(0,0,0,0) 15%, rgba(0,0,0,0.75) 100%);
- }
+.top {
+ position: sticky;
+ top: 0;
+ z-index: 1;
+ padding: 20px 0;
+ background: var(--X14);
+ -webkit-backdrop-filter: var(--blur, blur(8px));
+ backdrop-filter: var(--blur, blur(8px));
+}
- > .instance {
- position: relative;
- display: block;
- text-align: center;
- width: 100%;
+.banner {
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ background-size: cover;
+ background-position: center center;
+ -webkit-mask-image: linear-gradient(0deg, rgba(0,0,0,0) 15%, rgba(0,0,0,0.75) 100%);
+ mask-image: linear-gradient(0deg, rgba(0,0,0,0) 15%, rgba(0,0,0,0.75) 100%);
+}
- > .icon {
- display: inline-block;
- width: 38px;
- aspect-ratio: 1;
- }
- }
- }
+.instance {
+ position: relative;
+ display: block;
+ text-align: center;
+ width: 100%;
+}
- > .bottom {
- position: sticky;
- bottom: 0;
- padding: 20px 0;
- background: var(--X14);
- -webkit-backdrop-filter: var(--blur, blur(8px));
- backdrop-filter: var(--blur, blur(8px));
+.instanceIcon {
+ display: inline-block;
+ width: 38px;
+ aspect-ratio: 1;
+}
- > .post {
- position: relative;
- display: block;
- width: 100%;
- height: 40px;
- color: var(--fgOnAccent);
- font-weight: bold;
- text-align: left;
+.bottom {
+ position: sticky;
+ bottom: 0;
+ padding: 20px 0;
+ background: var(--X14);
+ -webkit-backdrop-filter: var(--blur, blur(8px));
+ backdrop-filter: var(--blur, blur(8px));
+}
- &:before {
- content: "";
- display: block;
- width: calc(100% - 38px);
- height: 100%;
- margin: auto;
- position: absolute;
- top: 0;
- left: 0;
- right: 0;
- bottom: 0;
- border-radius: 999px;
- background: linear-gradient(90deg, var(--buttonGradateA), var(--buttonGradateB));
- }
+.post {
+ position: relative;
+ display: block;
+ width: 100%;
+ height: 40px;
+ color: var(--fgOnAccent);
+ font-weight: bold;
+ text-align: left;
- &:hover, &.active {
- &:before {
- background: var(--accentLighten);
- }
- }
+ &:before {
+ content: "";
+ display: block;
+ width: calc(100% - 38px);
+ height: 100%;
+ margin: auto;
+ position: absolute;
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ border-radius: 999px;
+ background: linear-gradient(90deg, var(--buttonGradateA), var(--buttonGradateB));
+ }
- > .icon {
- position: relative;
- margin-left: 30px;
- margin-right: 8px;
- width: 32px;
- }
+ &:hover, &.active {
+ &:before {
+ background: var(--accentLighten);
+ }
+ }
+}
- > .text {
- position: relative;
- }
- }
+.postIcon {
+ position: relative;
+ margin-left: 30px;
+ margin-right: 8px;
+ width: 32px;
+}
- > .account {
- position: relative;
- display: flex;
- align-items: center;
- padding-left: 30px;
- width: 100%;
- text-align: left;
- box-sizing: border-box;
- margin-top: 16px;
+.account {
+ position: relative;
+ display: flex;
+ align-items: center;
+ padding-left: 30px;
+ width: 100%;
+ text-align: left;
+ box-sizing: border-box;
+ margin-top: 16px;
+}
- > .avatar {
- display: block;
- flex-shrink: 0;
- position: relative;
- width: 32px;
- aspect-ratio: 1;
- margin-right: 8px;
- }
+.avatar {
+ display: block;
+ flex-shrink: 0;
+ position: relative;
+ width: 32px;
+ aspect-ratio: 1;
+ margin-right: 8px;
+}
- > .text {
- display: block;
- flex-shrink: 1;
- padding-right: 8px;
- }
- }
- }
+.acct {
+ display: block;
+ flex-shrink: 1;
+ padding-right: 8px;
+}
- > .middle {
- flex: 1;
+.middle {
+ flex: 1;
+}
- > .divider {
- margin: 16px 16px;
- border-top: solid 0.5px var(--divider);
- }
+.divider {
+ margin: 16px 16px;
+ border-top: solid 0.5px var(--divider);
+}
- > .item {
- position: relative;
- display: block;
- padding-left: 24px;
- line-height: 2.85rem;
- text-overflow: ellipsis;
- overflow: hidden;
- white-space: nowrap;
- width: 100%;
- text-align: left;
- box-sizing: border-box;
- color: var(--navFg);
+.item {
+ position: relative;
+ display: block;
+ padding-left: 24px;
+ line-height: 2.85rem;
+ text-overflow: ellipsis;
+ overflow: hidden;
+ white-space: nowrap;
+ width: 100%;
+ text-align: left;
+ box-sizing: border-box;
+ color: var(--navFg);
- > .icon {
- position: relative;
- width: 32px;
- margin-right: 8px;
- }
+ &:hover {
+ text-decoration: none;
+ color: var(--navHoverFg);
+ }
- > .indicator {
- position: absolute;
- top: 0;
- left: 20px;
- color: var(--navIndicator);
- font-size: 8px;
- animation: blink 1s infinite;
- }
+ &.active {
+ color: var(--navActive);
+ }
- > .text {
- position: relative;
- font-size: 0.9em;
- }
+ &:hover, &.active {
+ &:before {
+ content: "";
+ display: block;
+ width: calc(100% - 24px);
+ height: 100%;
+ margin: auto;
+ position: absolute;
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ border-radius: 999px;
+ background: var(--accentedBg);
+ }
+ }
+}
- &:hover {
- text-decoration: none;
- color: var(--navHoverFg);
- }
+.itemIcon {
+ position: relative;
+ width: 32px;
+ margin-right: 8px;
+}
- &.active {
- color: var(--navActive);
- }
+.itemIndicator {
+ position: absolute;
+ top: 0;
+ left: 20px;
+ color: var(--navIndicator);
+ font-size: 8px;
+ animation: blink 1s infinite;
+}
- &:hover, &.active {
- &:before {
- content: "";
- display: block;
- width: calc(100% - 24px);
- height: 100%;
- margin: auto;
- position: absolute;
- top: 0;
- left: 0;
- right: 0;
- bottom: 0;
- border-radius: 999px;
- background: var(--accentedBg);
- }
- }
- }
- }
- }
+.itemText {
+ position: relative;
+ font-size: 0.9em;
}
</style>