Skip to content
This repository has been archived by the owner on Dec 2, 2024. It is now read-only.

Commit

Permalink
fix: handle multiple user sessions for grid (#511)
Browse files Browse the repository at this point in the history
  • Loading branch information
dzbo authored Oct 26, 2024
1 parent a63dfda commit fb1291c
Show file tree
Hide file tree
Showing 5 changed files with 95 additions and 38 deletions.
4 changes: 2 additions & 2 deletions app.vue
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ const { cacheValue } = useCache()
const { currencyList } = storeToRefs(useCurrencyStore())
const { initProvider, reconnect } = useWalletConnectProvider()
const { formatMessage } = useIntl()
const { gridChainId, tempGrid } = storeToRefs(useGridStore())
const { gridChainId, tempGrids } = storeToRefs(useGridStore())
const setupTranslations = () => {
useIntl().setupIntl(defaultConfig)
Expand Down Expand Up @@ -117,7 +117,7 @@ const setupNetwork = async () => {
// reset temp grid layout if network is changed
if (gridChainId.value !== selectedChainId.value) {
tempGrid.value = []
tempGrids.value = {}
}
gridChainId.value = selectedChainId.value
Expand Down
55 changes: 40 additions & 15 deletions components/ProfileView.vue
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
<script setup lang="ts">
const { gridsForTabs, gridsForDisplay, canEditGrid, initializeGrid } = useGrid()
const { isOwned, setFilters, filters } = useFilters()
const { isConnected } = storeToRefs(useAppStore())
const viewedProfileAddress = getCurrentProfileAddress()
const viewedProfile = useProfile().getProfile(viewedProfileAddress)
const assetsData = useProfileAssets()(viewedProfileAddress)
const assets = computed(() => assetsData.value || [])
const isLoadingAssets = computed(() =>
assets.value.some(asset => asset.isLoading)
)
const { gridsForDisplay } = useGrid()
const filteredAssets = computed(() => {
return (
Expand Down Expand Up @@ -84,28 +85,52 @@ const handleTabChange = (tab: ProfileViewTab) => {
}
const tabs = computed<ProfileViewTab[]>(() => {
return [
{
const _tabs = [] as ProfileViewTab[]
if (gridsForTabs.value.length > 0) {
_tabs.push({
id: 'grid',
count:
gridsForDisplay.value.length > 1 ? gridsForDisplay.value.length : 0,
},
{
id: 'collectibles',
count: isOwned.value
? ownedCollectiblesCount.value
: createdCollectiblesCount.value,
},
{
id: 'tokens',
count: isOwned.value ? ownedTokensCount.value : createdTokensCount.value,
},
]
})
}
_tabs.push({
id: 'collectibles',
count: isOwned.value
? ownedCollectiblesCount.value
: createdCollectiblesCount.value,
})
_tabs.push({
id: 'tokens',
count: isOwned.value ? ownedTokensCount.value : createdTokensCount.value,
})
return _tabs
})
const activeTab = computed(() => {
return filters.assetGroup
})
watch(
[isConnected, viewedProfileAddress],
async () => {
// we initialize grid at this point so we can switch tabs if user has no grids
await initializeGrid(viewedProfileAddress, canEditGrid.value)
await nextTick()
// if user has grids we switch to grid tab, otherwise we switch to collectibles or tokens
if (gridsForDisplay.value.length > 0) {
setFilters({ assetGroup: 'grid' }, undefined, true)
} else if (ownedCollectiblesCount.value > 0) {
setFilters({ assetGroup: 'collectibles' }, undefined, true)
} else {
setFilters({ assetGroup: 'tokens' }, undefined, true)
}
},
{ immediate: true }
)
</script>

<template>
Expand Down
24 changes: 6 additions & 18 deletions domains/grid/components/GridView.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
import { useElementSize } from '@vueuse/core'
import { GridItem, GridLayout } from 'grid-layout-plus'
const { isConnected, isMobile } = storeToRefs(useAppStore())
const { isMobile } = storeToRefs(useAppStore())
const {
isEditingGrid,
tempGrid,
Expand All @@ -12,7 +12,6 @@ const {
selectedGridId,
} = storeToRefs(useGridStore())
const {
initializeGrid,
saveGrid,
canEditGrid,
getSelectedGridWidgets,
Expand All @@ -26,14 +25,14 @@ const gridWidgets = ref<GridWidget[]>([])
const movementX = ref(0)
const address = computed(() => getCurrentProfileAddress())
const currentGrid = computed(() => {
const currentGrid = () => {
// when user is editing and has unsaved changes, use temp grid
if (canEditGrid.value && hasUnsavedGrid.value) {
return tempGrid.value
}
return viewedGrid.value
})
}
const gridRowHeight = computed(() => {
const columnSpacing = GRID_SPACING_PX * (gridColumnNumber.value - 1)
Expand All @@ -47,7 +46,7 @@ const gridRowHeight = computed(() => {
const gridColumnNumber = computed(() =>
isMobile.value
? 1
: getGridById(currentGrid.value, selectedGridId.value)?.gridColumns ||
: getGridById(currentGrid(), selectedGridId.value)?.gridColumns ||
GRID_COLUMNS_MIN
)
Expand Down Expand Up @@ -129,7 +128,7 @@ const handleItemResized = () => {
// - user make modifications in widgets (add/edit/remove/resize)
// - user toggles edit mode
watch(
[tempGrid, isEditingGrid, selectedGridId, isMobile],
[tempGrid, isEditingGrid, selectedGridId, isMobile, viewedGrid],
() => {
const updatedViewedGrid = buildGrid(
viewedGrid.value,
Expand Down Expand Up @@ -159,18 +158,7 @@ watch(
// re-init selected grid id when user toggles edit mode in case the selected grid was changed
initSelectedGridId()
},
{ deep: true }
)
// initialize grid on initial render and when user connects/disconnects
watch(
[isConnected],
async () => {
await initializeGrid(address.value, canEditGrid.value)
console.log('Grid initialized', getSelectedGridWidgets(currentGrid.value))
gridWidgets.value = getSelectedGridWidgets(currentGrid.value)
},
{ immediate: true }
{ deep: true, immediate: true }
)
onMounted(() => {
Expand Down
20 changes: 19 additions & 1 deletion domains/grid/composables/useGrid.ts
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,19 @@ export const useGrid = () => {
})
})

const gridsForTabs = computed(() => {
const grids =
isConnected.value && isConnectedUserViewingOwnProfile.value
? tempGrid.value
: viewedGrid.value.filter(grid => grid.grid.length > 0)

return grids.map(grid => {
return {
grid,
}
})
})

return {
initializeGrid: async (
address?: Address,
Expand Down Expand Up @@ -104,7 +117,11 @@ export const useGrid = () => {

// in case we don't have a temp grid yet we initialize it
const _initTempGrid = () => {
if (tempGrid.value.length === 0 && viewedGrid.value.length !== 0) {
if (
tempGrid.value.length === 0 &&
viewedGrid.value.length !== 0 &&
isConnectedUserViewingOwnProfile.value
) {
tempGrid.value = cloneObject(grid)
}
}
Expand Down Expand Up @@ -308,5 +325,6 @@ export const useGrid = () => {
initSelectedGridId,
getGridById,
gridsForDisplay,
gridsForTabs,
}
}
30 changes: 28 additions & 2 deletions stores/grid.ts
Original file line number Diff line number Diff line change
@@ -1,20 +1,46 @@
export const useGridStore = defineStore(
'grid',
() => {
const { connectedProfileAddress } = storeToRefs(useAppStore())

const isEditingGrid = ref(false)
const hasUnsavedGrid = ref(false)
const viewedGrid = ref<Grid[]>([])
const tempGrid = ref<Grid[]>([])
const isSavingGrid = ref(false)
const selectedGridId = ref<string | undefined>()
const gridRowHeightRatio = ref(DEFAULT_GRID_ROW_HEIGHT_RATIO)
const gridChainId = ref<string>(DEFAULT_NETWORK_CHAIN_ID)
const tempGrids = ref<Record<string, Grid[]>>({})

// We use tempGrid as a proxy to the actual grid data stored in tempGrids
const tempGrid = computed<Grid[]>({
get: () => {
if (!connectedProfileAddress.value) {
return []
}

return (
tempGrids.value[connectedProfileAddress.value.toLowerCase()] || []
)
},
set: value => {
if (!connectedProfileAddress.value) {
return
}

tempGrids.value = {
...tempGrids.value,
[connectedProfileAddress.value.toLowerCase()]: value,
}
},
})

return {
isEditingGrid,
hasUnsavedGrid,
viewedGrid,
tempGrid,
tempGrids,
isSavingGrid,
selectedGridId,
gridRowHeightRatio,
Expand All @@ -29,7 +55,7 @@ export const useGridStore = defineStore(
'selectedGridId',
'gridRowHeightRatio',
'gridChainId',
'tempGrid',
'tempGrids',
],
key: STORAGE_KEY.GRID_STORE,
},
Expand Down

0 comments on commit fb1291c

Please sign in to comment.