* Migrate to Nuxt 3 * Update vercel config * remove tsconfig comment * Changelog experiment + working proj pages * Fix package json * Prevent vercel complaining * fix deploy (hopefully) * Tag generator * Switch to yarn * Vercel pls 🙏 * Fix tag generation bug * Make (most) non-logged in pages work * fix base build * Linting + state * Eradicate axios, make most user pages work * Fix checkbox state being set incorrectly * Make most things work * Final stretch * Finish (most) things * Move to update model value * Fix modal text getting blurred from transforms (#964) * Adjust nav-link border radius when focused (#961) * Transition between animation states on TextLogo (#955) * Transition between animation states on TextLogo * Remove unused refs * Fixes from review * Disable tabbing to pagination arrows when disabled (#972) * Make position of the "no results" text on grid/gallery views consistent (fixes #963) (#965) * Fix position of the "no results" text on grid view * fix padding * Remove extra margin on main page, fixes #957 (#959) * Fix layout shift and placeholder line height (#973) * Fix a lot of issues * Fix more nuxt 3 issues * fix not all versions showing up (temp) * inline inter css file * More nuxt 3 fixes * [skip ci] broken- backup changes * Change modpack warnings to blue instead of red (#991) * Fix some hydration issues * Update nuxt * Fix some images not showing * Add pagination to versions page + fix lag * Make changelog page consistent with versions page * sync before merge * Delete old file * Fix actions failing * update branch * Fixes navbar transition animation. (#1012) * Fixes navbar transition animation. * Fixes Y-axis animation. Fixes mobile menu. Removes highlightjs prop. * Changes xss call to renderString. * Fixes renderString call. * Removes unnecessary styling. * Reverts mobile nav change. * Nuxt 3 Lazy Loading Search (#1022) * Uses lazyFetch for results. onSearchChange refreshes. Adds loading circle. * Removes console.log * Preserves old page when paging. * Diagnosing filtering bugs. * Fix single facet filtering * Implements useAuth in settings/account. * tiny ssr fix * Updating nuxt.config checklist. * Implements useAuth in revenue, moneitzation, and dashboard index pages. * Fixes setups. * Eliminates results when path changes. Adds animated logo. * Ensures loading animation renders on search page. --------- Co-authored-by: Jai A <jaiagr+gpg@pm.me> * Fix navigation issues * Square button fix (#1023) * Removes checklist from nuxt.config. * Modifies Nuxt CI to build after linting. * Fixes prettierignore file. * bug fixes * Update whitelist domains * Page improvements, fix CLS * Fix a lot of things * Fix project type redirect * Fix 404 errors * Fix user settings + hydration error * Final fixes * fix(creator-section): border radius on icons not aligning with bg (#1027) Co-authored-by: MagnusHJensen <magnus.holm.jensen@lego.dk> * Improvements to the mobile navbar (#984) * Transition between animation states on TextLogo * Remove unused refs * Fixes from review * Improvements to the mobile nav menu * fix avatar alt text * Nevermind, got confused for a moment * Tab bar, menu layout improvements * Highlight search icon when menu is open * Update layouts/default.vue Co-authored-by: Magnus Jensen <magnushjensen.mail@gmail.com> * Fix some issues * Use caret instead * Run prettier * Add create a project --------- Co-authored-by: Magnus Jensen <magnushjensen.mail@gmail.com> Co-authored-by: Geometrically <18202329+Geometrically@users.noreply.github.com> Co-authored-by: Jai A <jaiagr+gpg@pm.me> * Fix mobile menu issues * More issues * Fix lint --------- Co-authored-by: Kaeden Murphy <kmurphy@kaedenmurphy.dev> Co-authored-by: triphora <emmaffle@modrinth.com> Co-authored-by: Zach Baird <30800863+ZachBaird@users.noreply.github.com> Co-authored-by: stairman06 <36215135+stairman06@users.noreply.github.com> Co-authored-by: Zachary Baird <zdb1994@yahoo.com> Co-authored-by: Magnus Jensen <magnushjensen.mail@gmail.com> Co-authored-by: MagnusHJensen <magnus.holm.jensen@lego.dk>
113 lines
2.7 KiB
JavaScript
113 lines
2.7 KiB
JavaScript
export const useUser = async (force = false) => {
|
|
const user = useState('user', () => {})
|
|
|
|
if (!user.value || force || (user.value && Date.now() - user.value.lastUpdated > 300000)) {
|
|
user.value = await initUser()
|
|
}
|
|
|
|
return user
|
|
}
|
|
|
|
export const initUser = async () => {
|
|
const auth = (await useAuth()).value
|
|
|
|
const user = {
|
|
notifications: [],
|
|
follows: [],
|
|
projects: [],
|
|
lastUpdated: 0,
|
|
}
|
|
|
|
if (auth.user && auth.user.id) {
|
|
try {
|
|
const [notifications, follows, projects] = await Promise.all([
|
|
useBaseFetch(`user/${auth.user.id}/notifications`, auth.headers),
|
|
useBaseFetch(`user/${auth.user.id}/follows`, auth.headers),
|
|
useBaseFetch(`user/${auth.user.id}/projects`, auth.headers),
|
|
])
|
|
|
|
user.notifications = notifications
|
|
user.follows = follows
|
|
user.projects = projects
|
|
user.lastUpdated = Date.now()
|
|
} catch (err) {
|
|
console.error(err)
|
|
}
|
|
}
|
|
|
|
return user
|
|
}
|
|
|
|
export const initUserNotifs = async () => {
|
|
const auth = (await useAuth()).value
|
|
const user = (await useUser()).value
|
|
|
|
if (auth.user && auth.user.id) {
|
|
try {
|
|
user.notifications = await useBaseFetch(`user/${auth.user.id}/notifications`, auth.headers)
|
|
} catch (err) {
|
|
console.error(err)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const initUserFollows = async () => {
|
|
const auth = (await useAuth()).value
|
|
const user = (await useUser()).value
|
|
|
|
if (auth.user && auth.user.id) {
|
|
try {
|
|
user.follows = await useBaseFetch(`user/${auth.user.id}/follows`, auth.headers)
|
|
} catch (err) {
|
|
console.error(err)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const initUserProjects = async () => {
|
|
const auth = (await useAuth()).value
|
|
const user = (await useUser()).value
|
|
|
|
if (auth.user && auth.user.id) {
|
|
try {
|
|
user.projects = await useBaseFetch(`user/${auth.user.id}/projects`, auth.headers)
|
|
} catch (err) {
|
|
console.error(err)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const userFollowProject = async (project) => {
|
|
const auth = (await useAuth()).value
|
|
const user = (await useUser()).value
|
|
|
|
user.follows = user.follows.concat(project)
|
|
|
|
setTimeout(() => {
|
|
useBaseFetch(`project/${project.id}/follow`, {
|
|
method: 'POST',
|
|
...auth.headers,
|
|
})
|
|
})
|
|
}
|
|
|
|
export const userUnfollowProject = async (project) => {
|
|
const auth = (await useAuth()).value
|
|
const user = (await useUser()).value
|
|
|
|
user.follows = user.follows.filter((x) => x.id !== project.id)
|
|
|
|
setTimeout(() => {
|
|
useBaseFetch(`project/${project.id}/follow`, {
|
|
method: 'DELETE',
|
|
...auth.headers,
|
|
})
|
|
})
|
|
}
|
|
|
|
export const userDeleteNotification = async (id) => {
|
|
const user = (await useUser()).value
|
|
|
|
user.notifications = user.notifications.filter((x) => x.id !== id)
|
|
}
|