mirror of
https://github.com/nocodb/nocodb.git
synced 2026-05-01 11:47:01 +00:00
* fix(nc-gui): update topbar breadcrumb divider * feat(nc-gui): custom list component setup * fix(nc-gui): update reload view data tooltip * feat(nc-gui): custom list component * feat(nc-gui): add table list menu * fix(nc-gui): small changes * fix(nc-gui): add bases list dropdown * fix(nc-gui): show chevron icon in mobile view * feat(nc-gui): add view list dropdown in topbar * fix(nc-gui): auto scroll selected list option on open dropdown * feat(nc-gui): add typedocs for each fun from custom list component * chore(nc-gui): add typedocs for new functions * fix(nc-gui): view search issue on default view * fix(nc-gui): reset selected option hover state on search input * fix(nc-gui): font weight issue * fix(nc-gui): show reload data topbar option * fix(nc-gui): change view action menu position * fix(nc-gui): font weight issue * feat(nc-gui): create new table/view from topbar * fix(nc-gui): update other page headers * fix(nc-gui): project view header * fix(nc-gui): update admin panel workspaces page header * fix(nc-gui): admin panel base/workspace user page header * fix(nc-gui): admin panel scroll issue * fix(nc-gui): update project home page * fix(nc-gui): table list scroll issue * chore(nc-gui): lint * fix(nc-gui): reset breadcrumb btn hover state on open dropdown * fix(nc-gui): review changes * fix(nc-gui): use slash icon instead of text * fix(nc-gui): pr review changes * fix(nc-gui): details tab height issue * fix(nc-gui): add user account pages breadcrumb * fix(nc-gui): hide rename view option * fix(nc-gui): disable scrollIntoView on base rename * fix(nc-gui): on rename view select text * fix(nc-gui): user menu overflow issue if sidebar baselist is scrollable * feat(nc-gui): use virtual scrolling for NcList component * fix(nc-gui): reduce chevron icon opacity * chore(nc-gui): lint * fix(nc-gui): ai review changes * fix(nc-gui): view rename input focus issue * fix(nc-gui): topbar width issue * fix(nc-gui): udpate toolbar height * fix(nc-gui): update chevron icon from breadcrumb * fix(nc-gui): update breadcrumb icon size * fix(nc-gui): add min width for breadcrumb * fix(nc-gui): add topbar bottom border * fix(nc-gui): details tab heigth and alignment issue * fix(nc-gui): hide basename and show only icon * fix(nc-gui): update NcList component * fix(nc-gui): update admin panel header * fix(nc-gui): add header in account settings pages * fix(nc-gui): add account pages header oss * fix(nc-gui): udpate max width * chore(nc-gui): lint * fix(nc-gui(: reduce topbar top padding * fix(nc-gui): typo error * fix(nc-gui): review changes * fix(nc-gui): review changes * fix(nc-gui): slash icon conflict * fix(nc-gui): review changes * fix(nc-gui): remove chevron icon & add list wrapper div to control height * fix(nc-gui): ncList keyboard navigation issue * chore(nc-gui): lint
93 lines
2.6 KiB
Vue
93 lines
2.6 KiB
Vue
<script setup lang="ts">
|
|
interface Props {
|
|
disabled?: boolean
|
|
isViewToolbar?: boolean
|
|
}
|
|
|
|
const { disabled, isViewToolbar } = defineProps<Props>()
|
|
|
|
const { isMobileMode, getMainUrl } = useGlobal()
|
|
|
|
const { visibility, showShareModal } = storeToRefs(useShare())
|
|
|
|
const { activeTable } = storeToRefs(useTablesStore())
|
|
|
|
const { base, isSharedBase } = storeToRefs(useBase())
|
|
|
|
const { $e } = useNuxtApp()
|
|
|
|
const { isUIAllowed } = useRoles()
|
|
|
|
const route = useRoute()
|
|
|
|
useEventListener(document, 'keydown', async (e: KeyboardEvent) => {
|
|
const cmdOrCtrl = isMac() ? e.metaKey : e.ctrlKey
|
|
if (e.altKey && !e.shiftKey && !cmdOrCtrl) {
|
|
switch (e.keyCode) {
|
|
case 73: {
|
|
// ALT + I
|
|
if (!isDrawerOrModalExist()) {
|
|
$e('c:shortcut', { key: 'ALT + I' })
|
|
showShareModal.value = true
|
|
}
|
|
break
|
|
}
|
|
}
|
|
}
|
|
})
|
|
|
|
const copySharedBase = async () => {
|
|
const baseUrl = getMainUrl()
|
|
window.open(`${baseUrl || ''}#/copy-shared-base?base=${route.params.baseId}`, '_blank', 'noopener,noreferrer')
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<div
|
|
v-if="!isSharedBase && isUIAllowed('baseShare') && visibility !== 'hidden' && (activeTable || base)"
|
|
class="nc-share-base-button flex flex-col justify-center"
|
|
data-testid="share-base-button"
|
|
:data-sharetype="visibility"
|
|
>
|
|
<NcButton
|
|
v-e="['c:share:open']"
|
|
:size="isMobileMode ? 'medium' : 'small'"
|
|
class="z-10 !rounded-lg"
|
|
:class="{
|
|
'!px-2': !isMobileMode,
|
|
'!px-0 !max-w-8.5 !min-w-8.5': isMobileMode,
|
|
}"
|
|
type="primary"
|
|
:disabled="disabled"
|
|
@click="showShareModal = true"
|
|
>
|
|
<div v-if="!isMobileMode" class="flex flex-row items-center w-full gap-x-1">
|
|
<MaterialSymbolsPublic v-if="visibility === 'public'" class="h-3.5" />
|
|
<MaterialSymbolsLockOutline v-else-if="visibility === 'private'" class="h-3.5" />
|
|
<div class="flex">{{ $t('activity.share') }}</div>
|
|
</div>
|
|
<GeneralIcon v-else icon="mobileShare" />
|
|
</NcButton>
|
|
</div>
|
|
|
|
<template v-else-if="isSharedBase">
|
|
<div class="flex-1"></div>
|
|
<div class="flex flex-col justify-center h-full">
|
|
<div class="flex flex-row items-center w-full">
|
|
<NcButton
|
|
class="z-10 !rounded-lg !px-2 !bg-[#ff133e]"
|
|
size="small"
|
|
type="primary"
|
|
:disabled="disabled"
|
|
@click="copySharedBase"
|
|
>
|
|
<GeneralIcon class="mr-1" icon="duplicate" />
|
|
Copy Base
|
|
</NcButton>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<LazyDlgShareAndCollaborateView :is-view-toolbar="isViewToolbar" />
|
|
</template>
|