# Conflicts:
#	src/oc-community-frontend/src/components/CommunityPage.vue
linfangfang_branch
psnci6hgk 2 months ago
commit 1c45054ab9

@ -100,13 +100,14 @@
</template>
<script setup>
import { ref, computed, onMounted, onUnmounted } from 'vue'
import { ref, computed, onMounted, onUnmounted, watch } from 'vue'
import { User, Avatar, Phone } from '@element-plus/icons-vue'
import PhoneWidget from './PhoneWidget.vue'
import UserCenterDialog from './UserCenterDialog.vue'
import OCListDialog from './OCListDialog.vue'
import OCInfoDialog from './OCInfoDialog.vue'
import { ocList } from '../stores/ocStore.js'
import { ocList, loadOCFromStorage } from '../stores/ocStore.js'
import { currentUser } from '../stores/userStore.js'
//
const defaultAvatar = ''
@ -130,6 +131,8 @@ const locationCoords = {
const ocPositions = ref([])
// oc
const locationStatuses = ref([])
// ocList
const ocLoadedForUser = ref(false)
//
const handleImageError = (event) => {
@ -283,6 +286,19 @@ const computePositions = () => {
let posTimer = null
onMounted(() => {
// OC
if (currentUser.value && currentUser.value.username) {
try {
loadOCFromStorage(currentUser.value.username)
ocLoadedForUser.value = true
} catch (e) {
console.error('Failed to load user-specific OC list:', e)
ocLoadedForUser.value = false
}
} else {
ocLoadedForUser.value = false
}
computePositions()
posTimer = setInterval(computePositions, 60 * 1000)
document.addEventListener('click', closePopoverOnClickOutside)
@ -292,6 +308,24 @@ onUnmounted(() => {
document.removeEventListener('click', closePopoverOnClickOutside)
})
// OC OC
watch(currentUser, (val) => {
if (val && val.username) {
try {
loadOCFromStorage(val.username)
ocLoadedForUser.value = true
} catch (e) {
console.error('Failed to load OC list for user on change:', e)
ocLoadedForUser.value = false
}
} else {
ocLoadedForUser.value = false
// OC
loadOCFromStorage()
}
computePositions()
})
// OC /
const showOCInfo = ref(false)
const selectedOC = ref(null)
@ -349,7 +383,7 @@ const closePopoverOnClickOutside = (event) => {
.community-container {
display: flex;
height: 100vh;
background: linear-gradient(135deg, #ffc6c6 0%, #7486c0 100%);
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
position: relative;
overflow: hidden;
}

Loading…
Cancel
Save