cartodb-4.42/lib/assets/javascripts/new-dashboard/pages/Home/WelcomeSection/WelcomeCompact.vue

89 lines
2.0 KiB
Vue
Raw Normal View History

2024-04-06 13:25:13 +08:00
<template>
<section class="welcome-compact">
<div class="container welcome-compact__content">
<div class="welcome-compact__greeting title is-caption">{{ greeting }}</div>
<div class="welcome-compact__actions">
<OnboardingButton :isFirstTimeViewingDashboard="false"></OnboardingButton>
<CreateButton class="button--ghost" visualizationType="map" :disabled="!canCreateMaps">{{ $t(`HomePage.WelcomeSection.actions.createMap`) }}</CreateButton>
<CreateButton class="button--ghost" visualizationType="dataset" :disabled="!canCreateDatasets">{{ $t(`HomePage.WelcomeSection.actions.createDataset`) }}</CreateButton>
</div>
<div class="welcome-compact__extra">
<slot />
</div>
</div>
</section>
</template>
<script>
import CreateButton from 'new-dashboard/components/CreateButton.vue';
import OnboardingButton from 'new-dashboard/components/Onboarding/OnboardingButton.vue';
export default {
name: 'WelcomeCompact',
components: {
CreateButton,
OnboardingButton
},
props: {
name: String
},
computed: {
greeting () {
return this.$t('HomePage.WelcomeSection.greeting', {name: this.$props.name});
},
canCreateDatasets () {
return this.$store.getters['user/canCreateDatasets'];
},
canCreateMaps () {
return this.$store.getters['user/canCreateMaps'];
}
}
};
</script>
<style scoped lang="scss">
@import "new-dashboard/styles/variables";
.welcome-compact__content {
display: flex;
align-items: center;
max-width: 940px;
padding: 0;
}
.welcome-compact {
position: relative;
padding: 20px;
border-bottom: 1px solid #E6E8EB;
&__greeting {
display: inline-block;
margin-right: 64px;
}
&__actions {
display: inline-flex;
}
&__extra {
display: flex;
align-items: center;
margin-left: auto;
}
.button--ghost {
margin-right: 48px;
padding: 0;
background: none;
color: #047AE6;
text-transform: none;
}
.button--outline {
margin-left: 24px;
padding: 9px 16px;
}
}
</style>