Files
dezky/apps/portal/composables/usePartnerMode.ts
T
Ronni Baslund a51dc9a732 refactor(portal): extract shared partner types and data composables
Move partner domain types out of data/customers.ts into types/partner.ts so the fixture data exports can be removed later without breaking type imports. Add usePartnerTenants / usePartnerMrr composables wrapping the shared-key partner fetches.
2026-05-30 08:02:54 +02:00

42 lines
1.3 KiB
TypeScript

// Partner admin's "acting as a customer admin" state. When a partner clicks
// into a customer org, the sidebar reshapes to that customer's admin nav and
// a persistent banner indicates the partner context.
//
// In real use, every action while in this mode is logged with the partner's
// identity (not the customer's) — the design spec is explicit about this for
// trust. For the prototype we just hold the customer id.
import type { CustomerOrg } from '~/types/partner'
const activeCustomerId = ref<string | null>(null)
export const usePartnerMode = () => {
function enter(customerId: string) {
activeCustomerId.value = customerId
if (import.meta.client) {
sessionStorage.setItem('dezky-partner-active-customer', customerId)
}
}
function exit() {
activeCustomerId.value = null
if (import.meta.client) {
sessionStorage.removeItem('dezky-partner-active-customer')
}
}
function hydrate() {
if (!import.meta.client || activeCustomerId.value) return
const stored = sessionStorage.getItem('dezky-partner-active-customer')
if (stored) activeCustomerId.value = stored
}
return {
activeCustomerId,
isActive: computed(() => activeCustomerId.value !== null),
enter,
exit,
hydrate,
setCustomer: (c: CustomerOrg | null) => {
activeCustomerId.value = c?.id ?? null
},
}
}