it-tools/src/layouts/base.layout.vue

219 lines
6 KiB
Vue
Raw Normal View History

2022-04-04 00:24:45 +02:00
<script lang="ts" setup>
2023-04-10 13:00:38 +02:00
import { NIcon, useThemeVars } from 'naive-ui';
2023-04-10 13:00:38 +02:00
import { RouterLink } from 'vue-router';
import { Heart, Home2, Menu2 } from '@vicons/tabler';
2023-11-01 15:38:19 +01:00
import { storeToRefs } from 'pinia';
import HeroGradient from '../assets/hero-gradient.svg?component';
import MenuLayout from '../components/MenuLayout.vue';
import NavbarButtons from '../components/NavbarButtons.vue';
2022-04-04 01:52:59 +02:00
import { useStyleStore } from '@/stores/style.store';
import { config } from '@/config';
2023-04-10 13:00:38 +02:00
import type { ToolCategory } from '@/tools/tools.types';
import { useToolStore } from '@/tools/tools.store';
import { useTracker } from '@/modules/tracker/tracker.services';
2023-03-30 23:35:34 +02:00
import CollapsibleToolMenu from '@/components/CollapsibleToolMenu.vue';
2022-04-22 23:31:40 +02:00
const themeVars = useThemeVars();
const styleStore = useStyleStore();
const version = config.app.version;
const commitSha = config.app.lastCommitSha.slice(0, 7);
2022-04-16 11:45:50 +02:00
const { tracker } = useTracker();
2023-11-01 15:38:19 +01:00
const { t } = useI18n();
const toolStore = useToolStore();
2023-11-01 15:38:19 +01:00
const { favoriteTools, toolsByCategory } = storeToRefs(toolStore);
2023-03-30 23:35:34 +02:00
const tools = computed<ToolCategory[]>(() => [
2023-11-01 15:38:19 +01:00
...(favoriteTools.value.length > 0 ? [{ name: t('tools.categories.favorite-tools'), components: favoriteTools.value }] : []),
...toolsByCategory.value,
2023-03-30 23:35:34 +02:00
]);
2022-03-31 00:33:29 +02:00
</script>
<template>
<MenuLayout class="menu-layout" :class="{ isSmallScreen: styleStore.isSmallScreen }">
2022-04-15 23:10:47 +02:00
<template #sider>
<RouterLink to="/" class="hero-wrapper">
<HeroGradient class="gradient" />
2022-04-15 23:10:47 +02:00
<div class="text-wrapper">
<div class="title">
IT - TOOLS
</div>
2022-04-15 23:10:47 +02:00
<div class="divider" />
<div class="subtitle">
{{ $t('home.subtitle') }}
</div>
2022-04-15 23:10:47 +02:00
</div>
</RouterLink>
2022-04-15 23:10:47 +02:00
<div class="sider-content">
2023-11-01 15:38:19 +01:00
<div v-if="styleStore.isSmallScreen" flex flex-col items-center>
<locale-selector w="90%" />
<div flex justify-center>
<NavbarButtons />
</div>
2023-05-27 17:36:15 +02:00
</div>
2022-04-15 23:10:47 +02:00
<CollapsibleToolMenu :tools-by-category="tools" />
2022-04-16 11:45:50 +02:00
<div class="footer">
<div>
2022-04-16 15:12:33 +02:00
IT-Tools
<c-link target="_blank" rel="noopener" :href="`https://github.com/CorentinTh/it-tools/tree/v${version}`">
2022-04-16 11:45:50 +02:00
v{{ version }}
</c-link>
2022-04-16 15:12:33 +02:00
<template v-if="commitSha && commitSha.length > 0">
-
<c-link
2022-04-16 21:01:31 +02:00
target="_blank"
rel="noopener"
type="primary"
:href="`https://github.com/CorentinTh/it-tools/tree/${commitSha}`"
2022-04-16 21:01:31 +02:00
>
2022-04-16 15:12:33 +02:00
{{ commitSha }}
</c-link>
2022-04-16 15:12:33 +02:00
</template>
2022-04-16 11:45:50 +02:00
</div>
<div>
© {{ new Date().getFullYear() }}
<c-link target="_blank" rel="noopener" href="https://corentin.tech?utm_source=it-tools&utm_medium=footer">
Corentin Thomasset
</c-link>
2022-04-16 11:45:50 +02:00
</div>
</div>
2022-04-15 23:10:47 +02:00
</div>
</template>
<template #content>
<div flex items-center justify-center gap-2>
<c-button
circle
variant="text"
:aria-label="$t('home.toggleMenu')"
@click="styleStore.isMenuCollapsed = !styleStore.isMenuCollapsed"
2022-04-16 21:01:31 +02:00
>
<NIcon size="25" :component="Menu2" />
</c-button>
<c-tooltip :tooltip="$t('home.home')" position="bottom">
<c-button to="/" circle variant="text" :aria-label="$t('home.home')">
<NIcon size="25" :component="Home2" />
</c-button>
</c-tooltip>
<c-tooltip :tooltip="$t('home.uiLib')" position="bottom">
<c-button v-if="config.app.env === 'development'" to="/c-lib" circle variant="text" :aria-label="$t('home.uiLib')">
<icon-mdi:brush-variant text-20px />
</c-button>
</c-tooltip>
<command-palette />
2022-04-15 23:10:47 +02:00
2023-11-01 15:38:19 +01:00
<locale-selector v-if="!styleStore.isSmallScreen" />
<div>
<NavbarButtons v-if="!styleStore.isSmallScreen" />
</div>
<c-tooltip position="bottom" :tooltip="$t('home.support')">
<c-button
round
href="https://www.buymeacoffee.com/cthmsst"
rel="noopener"
target="_blank"
class="support-button"
:bordered="false"
@click="() => tracker.trackEvent({ eventName: 'Support button clicked' })"
>
{{ $t('home.buyMeACoffee') }}
<NIcon v-if="!styleStore.isSmallScreen" :component="Heart" ml-2 />
</c-button>
</c-tooltip>
2022-04-15 23:10:47 +02:00
</div>
<slot />
</template>
</MenuLayout>
2022-03-31 00:33:29 +02:00
</template>
<style lang="less" scoped>
2022-04-14 23:12:36 +02:00
// ::v-deep(.n-layout-scroll-container) {
// @percent: 4%;
// @position: 25px;
// @size: 50px;
// @color: #eeeeee25;
// background-image: radial-gradient(@color @percent, transparent @percent),
// radial-gradient(@color @percent, transparent @percent);
// background-position: 0 0, @position @position;
// background-size: @size @size;
// }
2022-12-17 01:30:27 +01:00
.support-button {
background: rgb(37, 99, 108);
background: linear-gradient(48deg, rgba(37, 99, 108, 1) 0%, rgba(59, 149, 111, 1) 60%, rgba(20, 160, 88, 1) 100%);
color: #fff !important;
transition: padding ease 0.2s !important;
2022-12-17 01:30:27 +01:00
&:hover {
color: #fff;
padding-left: 30px;
padding-right: 30px;
}
}
2022-04-16 11:45:50 +02:00
.footer {
text-align: center;
color: #838587;
margin-top: 20px;
padding: 20px 0;
}
2022-04-15 12:21:09 +02:00
.sider-content {
2022-04-16 11:13:30 +02:00
padding-top: 160px;
padding-bottom: 200px;
2022-04-14 22:41:51 +02:00
}
.hero-wrapper {
2022-04-16 11:13:30 +02:00
position: absolute;
display: block;
left: 0;
width: 100%;
z-index: 10;
overflow: hidden;
.gradient {
margin-top: -65px;
}
.text-wrapper {
2022-04-14 22:41:51 +02:00
position: absolute;
left: 0;
width: 100%;
2022-04-16 11:13:30 +02:00
text-align: center;
top: 16px;
color: #fff;
2022-04-14 22:41:51 +02:00
2022-04-16 11:13:30 +02:00
.title {
font-size: 25px;
font-weight: 600;
2022-04-14 22:41:51 +02:00
}
2022-04-16 11:13:30 +02:00
.divider {
width: 50px;
height: 2px;
border-radius: 4px;
background-color: v-bind('themeVars.primaryColor');
margin: 0 auto 5px;
}
2022-04-14 22:41:51 +02:00
2022-04-16 11:13:30 +02:00
.subtitle {
font-size: 16px;
2022-04-14 22:41:51 +02:00
}
2022-04-16 11:13:30 +02:00
}
2022-04-14 22:41:51 +02:00
}
2022-04-22 23:31:40 +02:00
</style>